Compare commits
2 Commits
0f903cc8ec
...
e5b35f3fcc
Author | SHA1 | Date | |
---|---|---|---|
e5b35f3fcc | |||
e6a94c487e |
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Reference in New Issue
Block a user