-
Notifications
You must be signed in to change notification settings - Fork 0
/
orderedmap.go
66 lines (49 loc) · 1.01 KB
/
orderedmap.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
package common
import "golang.org/x/exp/slices"
type OrderedMap[K comparable, V any] struct {
m map[K]V
l []K
}
func NewOrderedMap[K comparable, V any]() *OrderedMap[K, V] {
return &OrderedMap[K, V]{
m: make(map[K]V),
l: nil,
}
}
func (om *OrderedMap[K, V]) Len() int {
return len(om.l)
}
func (om *OrderedMap[K, V]) Get(k K) V {
return om.m[k]
}
func (om *OrderedMap[K, V]) GetOk(k K) (V, bool) {
v, ok := om.m[k]
return v, ok
}
func (om *OrderedMap[K, V]) Add(k K, v V) *OrderedMap[K, V] {
om.m[k] = v
om.l = append(om.l, k)
return om
}
func (om *OrderedMap[K, V]) Remove(k K) *OrderedMap[K, V] {
delete(om.m, k)
p := slices.Index(om.l, k)
if p != -1 {
om.l = slices.Delete(om.l, p, p+1)
}
return om
}
func (om *OrderedMap[K, V]) Clear() *OrderedMap[K, V] {
om.m = make(map[K]V)
return om
}
func (om *OrderedMap[K, V]) Keys() []K {
lcopy := make([]K, len(om.l))
copy(lcopy, om.l)
return om.l
}
func (om *OrderedMap[K, V]) Range(fn func(K, V)) {
for _, k := range om.l {
fn(k, om.m[k])
}
}