Compare commits

...

2 Commits

Author SHA1 Message Date
e5b35f3fcc Improvements to Optional type 2024-10-30 23:54:11 -04:00
e6a94c487e Add a variadic constructor for container.Set 2024-09-20 17:07:16 -04:00
2 changed files with 27 additions and 18 deletions

View File

@ -1,31 +1,31 @@
package ucontainer package ucontainer
// Optional is an optional value. // Optional can either hold a value, or nothing.
type Optional[T any] struct { type Optional[T any] struct {
value T value T
exists bool exists bool
} }
// Value returns the value and true if the value exists. If not, it returns the // O creates a new optional with the specified value.
// last set value and false. func O[T any] (value T) Optional[T] {
func (this *Optional[T]) Value () (T, bool) { return Optional[T] {
return this.value, this.exists value: value,
exists: true,
}
} }
// Set sets the value. // Void returns an optional with no value.
func (this *Optional[T]) Set (value T) { func Void[T any] () Optional[T] {
this.value = value return Optional[T] { }
this.exists = true
}
// Unset unsets the value.
func (this *Optional[T]) Unset () {
var zero T
this.value = zero
this.exists = false
} }
// Exists returns if the value is currently set. // Exists returns if the value is currently set.
func (this *Optional[T]) Exists () bool { func (optional Optional[T]) Exists () bool {
return this.exists return optional.exists
}
// Value returns the value and true if the value exists. If not, it returns the
// zero value and false.
func (optional Optional[T]) Value () (T, bool) {
return optional.value, optional.exists
} }

View File

@ -3,6 +3,15 @@ package ucontainer
// Set is a set of unique items, built on top of map. // Set is a set of unique items, built on top of map.
type Set[T comparable] map[T] struct { } type Set[T comparable] map[T] struct { }
// NewSet creates a new set that contains all specified items.
func NewSet[T comparable] (items ...T) Set[T] {
set := make(Set[T])
for _, item := range items {
set.Add(item)
}
return set
}
// Empty returns true if there are no items in the set. // Empty returns true if there are no items in the set.
func (set Set[T]) Empty () bool { func (set Set[T]) Empty () bool {
return set == nil || len(set) == 0 return set == nil || len(set) == 0