-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathunordered.go
82 lines (62 loc) · 1.22 KB
/
unordered.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package set
type (
stub struct{}
// Unordered is a simple and effective un-ordered generic set.
Unordered[T comparable] map[T]stub
)
// NewUnordered create empty unordered Set for given type.
func NewUnordered[T comparable]() Set[T] {
return make(Unordered[T])
}
// Add implements Set interface.
func (u Unordered[T]) Add(v T) bool {
prev := len(u)
u[v] = stub{}
return prev != len(u)
}
// Del implements Set interface.
func (u Unordered[T]) Del(v T) {
delete(u, v)
}
// Clear implements Set interface.
func (u Unordered[T]) Clear() {
clear(u)
}
// Len implements Set interface.
func (u Unordered[T]) Len() int {
return len(u)
}
// Has implements Set interface.
func (u Unordered[T]) Has(v T) (ok bool) {
_, ok = u[v]
return
}
// Iter implements Set interface.
func (u Unordered[T]) Iter(it func(T) bool) {
for k := range u {
if !it(k) {
break
}
}
}
// Clone implements Set interface.
func (u Unordered[T]) Clone() (rv Set[T]) {
rv = make(Unordered[T])
u.Iter(func(v T) bool {
rv.Add(v)
return true
})
return rv
}
// Pop implements Set interface.
func (u Unordered[T]) Pop() (v T, ok bool) {
if len(u) < 1 {
return v, false
}
for t := range u {
v = t
break
}
delete(u, v)
return v, true
}