summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-mangler/v2/cache.go
diff options
context:
space:
mode:
authorLibravatar Terin Stock <terinjokes@gmail.com>2025-03-09 17:47:56 +0100
committerLibravatar Terin Stock <terinjokes@gmail.com>2025-12-01 22:08:04 +0100
commitb1af8fd87760b34e3ff2fd3bda38f211815a0473 (patch)
tree9317fad1a7ec298d7a8d2678e4e422953bbc6f33 /vendor/codeberg.org/gruf/go-mangler/v2/cache.go
parent[chore] update URLs to forked source (diff)
downloadgotosocial-b1af8fd87760b34e3ff2fd3bda38f211815a0473.tar.xz
[chore] remove vendor
Diffstat (limited to 'vendor/codeberg.org/gruf/go-mangler/v2/cache.go')
-rw-r--r--vendor/codeberg.org/gruf/go-mangler/v2/cache.go62
1 files changed, 0 insertions, 62 deletions
diff --git a/vendor/codeberg.org/gruf/go-mangler/v2/cache.go b/vendor/codeberg.org/gruf/go-mangler/v2/cache.go
deleted file mode 100644
index 0f6f71cd0..000000000
--- a/vendor/codeberg.org/gruf/go-mangler/v2/cache.go
+++ /dev/null
@@ -1,62 +0,0 @@
-package mangler
-
-import (
- "sync/atomic"
- "unsafe"
-
- "codeberg.org/gruf/go-xunsafe"
-)
-
-var manglers cache
-
-// cache is a concurrency-safe map[xunsafe.TypeInfo]Mangler
-// cache, designed for heavy reads but with unfortunately expensive
-// writes. it is designed such that after some initial load period
-// in which functions are cached by types, all future ops are reads.
-type cache struct{ p unsafe.Pointer }
-
-// Get will check cache for mangler func under key.
-func (c *cache) Get(t xunsafe.TypeInfo) Mangler {
- if p := c.load(); p != nil {
- return (*p)[t]
- }
- return nil
-}
-
-// Put will place given mangler func in cache under key, if not already exists.
-func (c *cache) Put(t xunsafe.TypeInfo, fn Mangler) {
- for {
- p := c.load()
-
- var cache map[xunsafe.TypeInfo]Mangler
-
- if p != nil {
- if _, ok := (*p)[t]; ok {
- return
- }
-
- cache = make(map[xunsafe.TypeInfo]Mangler, len(*p)+1)
- for key, value := range *p {
- cache[key] = value
- }
- } else {
- cache = make(map[xunsafe.TypeInfo]Mangler, 1)
- }
-
- cache[t] = fn
-
- if c.cas(p, &cache) {
- return
- }
- }
-}
-
-// load is a typed wrapper around atomic.LoadPointer().
-func (c *cache) load() *map[xunsafe.TypeInfo]Mangler {
- return (*map[xunsafe.TypeInfo]Mangler)(atomic.LoadPointer(&c.p))
-}
-
-// cas is a typed wrapper around atomic.CompareAndSwapPointer().
-func (c *cache) cas(old, new *map[xunsafe.TypeInfo]Mangler) bool {
- return atomic.CompareAndSwapPointer(&c.p, unsafe.Pointer(old), unsafe.Pointer(new))
-}