75 lines
1.4 KiB
Go
75 lines
1.4 KiB
Go
package impl
|
|
|
|
import (
|
|
"fmt"
|
|
"sort"
|
|
)
|
|
|
|
// Set is a set of TypeName.
|
|
type Set struct {
|
|
items map[TypeName]struct{}
|
|
}
|
|
|
|
// New creates a new TypeName set.
|
|
func New(items ...TypeName) *Set {
|
|
s := &Set{items: make(map[TypeName]struct{}, len(items))}
|
|
s.Add(items...)
|
|
return s
|
|
}
|
|
|
|
// Add adds given items to the set.
|
|
func (s *Set) Add(items ...TypeName) *Set {
|
|
for _, item := range items {
|
|
s.items[item] = struct{}{}
|
|
}
|
|
return s
|
|
}
|
|
|
|
// Remove delete given items from the set.
|
|
func (s *Set) Remove(items ...TypeName) *Set {
|
|
for _, item := range items {
|
|
delete(s.items, item)
|
|
}
|
|
return s
|
|
}
|
|
|
|
// Has returns true if all the given items are included in the set.
|
|
func (s *Set) Has(items ...TypeName) bool {
|
|
for _, item := range items {
|
|
if _, ok := s.items[item]; !ok {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// Len returns the size of the set.
|
|
func (s *Set) Len() int {
|
|
return len(s.items)
|
|
}
|
|
|
|
// Slice returns items of the set as a slice.
|
|
func (s *Set) Slice() []TypeName {
|
|
sl := make([]TypeName, len(s.items))
|
|
i := 0
|
|
for item := range s.items {
|
|
sl[i] = item
|
|
i++
|
|
}
|
|
return sl
|
|
}
|
|
|
|
// SortedSlice returns items of the set as a slice sorted ascending.
|
|
func (s *Set) SortedSlice() []TypeName {
|
|
ss := s.Slice()
|
|
sort.Slice(ss, func(i, j int) bool {
|
|
return ss[i] < ss[j]
|
|
})
|
|
return ss
|
|
}
|
|
|
|
// String implements fmt.Stringer interface.
|
|
func (s *Set) String() string {
|
|
return fmt.Sprintf("[%v]", s.Slice())
|
|
}
|