Files
polaris/vendor/github.com/gobuffalo/syncx/int_map.go
Bobby Brennan 54a4f92695 Pack static assets into packr box for portability
copy config.yaml to docker image

enable external usage of dashboard package

gofmt

fix comment

use packr for assets

add gobuffalo/packr dependency

add dependencies

fix pointer issues

add output-file option
2019-04-18 18:25:16 +00:00

74 lines
1.5 KiB
Go

//go:generate mapgen -name "Int" -zero "0" -go-type "int" -pkg "" -a "0" -b "1" -c "2" -bb "-1" -destination "syncx"
// Code generated by github.com/gobuffalo/mapgen. DO NOT EDIT.
package syncx
import (
"sort"
"sync"
)
// IntMap wraps sync.Map and uses the following types:
// key: string
// value: int
type IntMap struct {
data sync.Map
}
// Delete the key from the map
func (m *IntMap) Delete(key string) {
m.data.Delete(key)
}
// Load the key from the map.
// Returns int or bool.
// A false return indicates either the key was not found
// or the value is not of type int
func (m *IntMap) Load(key string) (int, bool) {
i, ok := m.data.Load(key)
if !ok {
return 0, false
}
s, ok := i.(int)
return s, ok
}
// LoadOrStore will return an existing key or
// store the value if not already in the map
func (m *IntMap) LoadOrStore(key string, value int) (int, bool) {
i, _ := m.data.LoadOrStore(key, value)
s, ok := i.(int)
return s, ok
}
// Range over the int values in the map
func (m *IntMap) Range(f func(key string, value int) bool) {
m.data.Range(func(k, v interface{}) bool {
key, ok := k.(string)
if !ok {
return false
}
value, ok := v.(int)
if !ok {
return false
}
return f(key, value)
})
}
// Store a int in the map
func (m *IntMap) Store(key string, value int) {
m.data.Store(key, value)
}
// Keys returns a list of keys in the map
func (m *IntMap) Keys() []string {
var keys []string
m.Range(func(key string, value int) bool {
keys = append(keys, key)
return true
})
sort.Strings(keys)
return keys
}