diff options
author | 2021-09-12 10:10:24 +0100 | |
---|---|---|
committer | 2021-09-12 10:10:24 +0100 | |
commit | f6492d12d948507021bbe934de94e87e20464c01 (patch) | |
tree | 6705d6ef6f3c4d70f3b3ebc77c2960d8e508cf37 /vendor/git.iim.gay/grufwub/go-mutexes/mutex_safe.go | |
parent | Merge pull request #213 from superseriousbusiness/alpine+node_upstep (diff) | |
parent | fix keys used to access storage items (diff) | |
download | gotosocial-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.go | 39 |
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) } +} |