diff options
author | Felix Lange <fjl@twurst.com> | 2014-10-08 22:26:14 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2014-10-08 22:31:08 +0800 |
commit | 44674cb96c64ddf9a8b3345f14329c030ecd4ed6 (patch) | |
tree | 75269be1c098d1346fcb6460747969372b5f4cf3 | |
parent | d4512699775497abd5392aa4c617350491021630 (diff) | |
download | go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar.gz go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar.bz2 go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar.lz go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar.xz go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.tar.zst go-tangerine-44674cb96c64ddf9a8b3345f14329c030ecd4ed6.zip |
eventer: fix data race
-rw-r--r-- | eventer/eventer.go | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/eventer/eventer.go b/eventer/eventer.go index fb2f299a3..6e5ee2ec5 100644 --- a/eventer/eventer.go +++ b/eventer/eventer.go @@ -1,5 +1,7 @@ package eventer +import "sync" + // Basic receiver interface. type Receiver interface { Send(Event) @@ -27,17 +29,18 @@ type Event struct { type Channels map[string][]Receiver type EventMachine struct { + mu sync.RWMutex channels Channels } func New() *EventMachine { - return &EventMachine{ - channels: make(Channels), - } + return &EventMachine{channels: make(Channels)} } func (self *EventMachine) add(typ string, r Receiver) { + self.mu.Lock() self.channels[typ] = append(self.channels[typ], r) + self.mu.Unlock() } // Generalised methods for the known receiver types @@ -64,11 +67,11 @@ func (self *EventMachine) RegisterFunc(typ string, f Function) { func (self *EventMachine) Register(typ string) Channel { c := make(Channel, 1) self.add(typ, c) - return c } func (self *EventMachine) Post(typ string, data interface{}) { + self.mu.RLock() if self.channels[typ] != nil { ev := Event{typ, data} for _, receiver := range self.channels[typ] { @@ -76,4 +79,5 @@ func (self *EventMachine) Post(typ string, data interface{}) { receiver.Send(ev) } } + self.mu.RUnlock() } |