From 084f06253a7c557a1a33f5ef9c404018c51ebbf4 Mon Sep 17 00:00:00 2001 From: James Reed Date: Tue, 12 Jan 2021 14:28:27 -0700 Subject: [PATCH] wm-launchd: Use a RWMutex for factory access --- wm-launchd.go | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/wm-launchd.go b/wm-launchd.go index 76861ff..0738c20 100644 --- a/wm-launchd.go +++ b/wm-launchd.go @@ -69,7 +69,7 @@ func (f *Factory) popID() (string, error) { } type FactMap struct { - mutex *sync.Mutex + mutex *sync.RWMutex facts map[string]*Factory } @@ -97,10 +97,9 @@ func (fm *FactMap) remove(name string) { } func (fm *FactMap) get(name string) *Factory { - fm.mutex.Lock() - f, ok := fm.facts[name] - fm.mutex.Unlock() - if ok { + fm.mutex.RLock() + defer fm.mutex.RUnlock() + if f, ok := fm.facts[name]; ok { return f } return nil @@ -122,16 +121,16 @@ func (fm *FactMap) check(name string) bool { func (fm *FactMap) getFactNames() []string { names := make([]string, 0, len(fm.facts)) - fm.mutex.Lock() + fm.mutex.RLock() + defer fm.mutex.RUnlock() for n := range fm.facts { names = append(names, n) } - fm.mutex.Unlock() return names } var factMap = FactMap{ - mutex: &sync.Mutex{}, + mutex: &sync.RWMutex{}, facts: make(map[string]*Factory), } var socketPath = getSocketPath()