diff options
Diffstat (limited to 'vendor/codeberg.org/gruf/go-cache/v2/cache.go')
-rw-r--r-- | vendor/codeberg.org/gruf/go-cache/v2/cache.go | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/vendor/codeberg.org/gruf/go-cache/v2/cache.go b/vendor/codeberg.org/gruf/go-cache/v2/cache.go new file mode 100644 index 000000000..89ad314ee --- /dev/null +++ b/vendor/codeberg.org/gruf/go-cache/v2/cache.go @@ -0,0 +1,67 @@ +package cache + +import "time" + +// Cache represents a TTL cache with customizable callbacks, it +// exists here to abstract away the "unsafe" methods in the case that +// you do not want your own implementation atop TTLCache{}. +type Cache[Key comparable, Value any] interface { + // Start will start the cache background eviction routine with given sweep frequency. + // If already running or a freq <= 0 provided, this is a no-op. This will block until + // the eviction routine has started + Start(freq time.Duration) bool + + // Stop will stop cache background eviction routine. If not running this is a no-op. This + // will block until the eviction routine has stopped + Stop() bool + + // SetEvictionCallback sets the eviction callback to the provided hook + SetEvictionCallback(hook Hook[Key, Value]) + + // SetInvalidateCallback sets the invalidate callback to the provided hook + SetInvalidateCallback(hook Hook[Key, Value]) + + // SetTTL sets the cache item TTL. Update can be specified to force updates of existing items in + // the cache, this will simply add the change in TTL to their current expiry time + SetTTL(ttl time.Duration, update bool) + + // Get fetches the value with key from the cache, extending its TTL + Get(key Key) (value Value, ok bool) + + // Put attempts to place the value at key in the cache, doing nothing if + // a value with this key already exists. Returned bool is success state + Put(key Key, value Value) bool + + // Set places the value at key in the cache. This will overwrite any + // existing value, and call the update callback so. Existing values + // will have their TTL extended upon update + Set(key Key, value Value) + + // CAS will attempt to perform a CAS operation on 'key', using provided + // comparison and swap values. Returned bool is success. + CAS(key Key, cmp, swp Value) bool + + // Swap will attempt to perform a swap on 'key', replacing the value there + // and returning the existing value. If no value exists for key, this will + // set the value and return the zero value for V. + Swap(key Key, swp Value) Value + + // Has checks the cache for a value with key, this will not update TTL + Has(key Key) bool + + // Invalidate deletes a value from the cache, calling the invalidate callback + Invalidate(key Key) bool + + // Clear empties the cache, calling the invalidate callback + Clear() + + // Size returns the current size of the cache + Size() int +} + +// New returns a new initialized Cache. +func New[K comparable, V any]() Cache[K, V] { + c := TTLCache[K, V]{} + c.Init() + return &c +} |