summaryrefslogtreecommitdiff
path: root/vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2021-09-12 10:10:24 +0100
committerLibravatar GitHub <noreply@github.com>2021-09-12 10:10:24 +0100
commitf6492d12d948507021bbe934de94e87e20464c01 (patch)
tree6705d6ef6f3c4d70f3b3ebc77c2960d8e508cf37 /vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go
parentMerge pull request #213 from superseriousbusiness/alpine+node_upstep (diff)
parentfix keys used to access storage items (diff)
downloadgotosocial-f6492d12d948507021bbe934de94e87e20464c01.tar.xz
Merge pull request #214 from NyaaaWhatsUpDoc/improvement/update-storage-library
add git.iim.gay/grufwub/go-store for storage backend, replacing blob.Storage
Diffstat (limited to 'vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go')
-rw-r--r--vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go39
1 files changed, 39 insertions, 0 deletions
diff --git a/vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go b/vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go
new file mode 100644
index 000000000..7a9747521
--- /dev/null
+++ b/vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go
@@ -0,0 +1,39 @@
+package mutexes
+
+import "sync"
+
+// WithSafety wrapps the supplied Mutex to protect unlock fns
+// from being called multiple times
+func WithSafety(mu Mutex) Mutex {
+ return &safeMutex{mu: mu}
+}
+
+// WithSafetyRW wrapps the supplied RWMutex to protect unlock
+// fns from being called multiple times
+func WithSafetyRW(mu RWMutex) RWMutex {
+ return &safeRWMutex{mu: mu}
+}
+
+// safeMutex simply wraps a Mutex to add multi-unlock safety
+type safeMutex struct{ mu Mutex }
+
+func (mu *safeMutex) Lock() func() {
+ unlock := mu.mu.Lock()
+ once := sync.Once{}
+ return func() { once.Do(unlock) }
+}
+
+// safeRWMutex simply wraps a RWMutex to add multi-unlock safety
+type safeRWMutex struct{ mu RWMutex }
+
+func (mu *safeRWMutex) Lock() func() {
+ unlock := mu.mu.Lock()
+ once := sync.Once{}
+ return func() { once.Do(unlock) }
+}
+
+func (mu *safeRWMutex) RLock() func() {
+ unlock := mu.mu.RLock()
+ once := sync.Once{}
+ return func() { once.Do(unlock) }
+}