2023-07-09 11:39:35 +03:00
|
|
|
package mapx
|
|
|
|
|
|
|
|
// The type makes the underlying map ordered,
|
|
|
|
// so every time you pass through all the values
|
|
|
|
// they will be in the same order.
|
|
|
|
type OrderedMap[K comparable, V any] struct {
|
|
|
|
store map[K] V
|
|
|
|
keys []K
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the new empty ordered map.
|
|
|
|
func NewOrdered[K comparable, V any]() *OrderedMap[K, V] {
|
|
|
|
return &OrderedMap[K, V]{
|
|
|
|
store: make(map[K] V),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set or reset the value in the map.
|
|
|
|
func (m *OrderedMap[K, V]) Set(k K, v V) {
|
|
|
|
_, ok := m.store[k]
|
|
|
|
if !ok {
|
2023-07-11 20:01:04 +03:00
|
|
|
m.keys = append(m.keys, k)
|
2023-07-09 11:39:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
m.store[k] = v
|
|
|
|
}
|
|
|
|
|
2023-07-11 20:01:04 +03:00
|
|
|
func (m *OrderedMap[K, V]) Has(k K) bool {
|
|
|
|
_, ok := m.store[k]
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
2023-07-09 11:39:35 +03:00
|
|
|
// Get the value from the map.
|
2023-07-11 20:01:04 +03:00
|
|
|
func (m *OrderedMap[K, V]) Get(k K) (V) {
|
|
|
|
v := m.store[k]
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
2023-08-31 07:24:23 +03:00
|
|
|
func (m *OrderedMap[K, V]) Del(k K) {
|
|
|
|
delete(m.store, k)
|
|
|
|
for i, v := range m.keys {
|
|
|
|
if v == k {
|
|
|
|
m.keys = append(m.keys[:i], m.keys[i+1:]...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get map keys slice.
|
2023-07-11 20:01:04 +03:00
|
|
|
func (m *OrderedMap[K, V]) Keys() []K {
|
|
|
|
return m.keys
|
2023-07-09 11:39:35 +03:00
|
|
|
}
|
|
|
|
|
2023-08-31 07:24:23 +03:00
|
|
|
func (m *OrderedMap[K, V]) KeyChan() chan K {
|
|
|
|
chn := make(chan K)
|
|
|
|
go func() {
|
|
|
|
for _, v := range m.keys {
|
|
|
|
chn <- v
|
|
|
|
}
|
|
|
|
close(chn)
|
|
|
|
}()
|
|
|
|
return chn
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return channel of ordered values.
|
|
|
|
func (m *OrderedMap[K, V]) Chan() chan V {
|
|
|
|
chn := make(chan V)
|
2023-07-11 20:01:04 +03:00
|
|
|
go func(){
|
|
|
|
for _, k := range m.keys {
|
2023-08-31 07:24:23 +03:00
|
|
|
chn <- m.Get(k)
|
2023-07-11 20:01:04 +03:00
|
|
|
}
|
|
|
|
close(chn)
|
|
|
|
}()
|
|
|
|
|
|
|
|
return chn
|
|
|
|
}
|
2023-07-09 11:39:35 +03:00
|
|
|
|