summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-cache/v2/cache.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/codeberg.org/gruf/go-cache/v2/cache.go')
-rw-r--r--vendor/codeberg.org/gruf/go-cache/v2/cache.go67
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
+}