diff options
author | obscuren <geffobscura@gmail.com> | 2014-10-10 22:58:26 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-10-10 22:58:26 +0800 |
commit | 9b494c68698cbcaa4d8d6e0f2b964d29db815da5 (patch) | |
tree | 4002f7d9b7fb34b3e1994cf320ae56417af4f3e6 /ethereum.go | |
parent | 6877660fe247f758d06fe95d020a29ac3f0357cc (diff) | |
parent | 3db6a8e92d7929bafa2d66e753ed365cf0822187 (diff) | |
download | dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar.gz dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar.bz2 dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar.lz dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar.xz dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.tar.zst dexon-9b494c68698cbcaa4d8d6e0f2b964d29db815da5.zip |
Merge branch 'develop' of github.com-obscure:ethereum/eth-go into develop
Diffstat (limited to 'ethereum.go')
-rw-r--r-- | ethereum.go | 33 |
1 files changed, 23 insertions, 10 deletions
diff --git a/ethereum.go b/ethereum.go index b83ceb12f..204f30bec 100644 --- a/ethereum.go +++ b/ethereum.go @@ -95,7 +95,9 @@ type Ethereum struct { isUpToDate bool - filters map[int]*ethchain.Filter + filterMu sync.RWMutex + filterId int + filters map[int]*ethchain.Filter } func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager *ethcrypto.KeyManager, caps Caps, usePnp bool) (*Ethereum, error) { @@ -594,22 +596,29 @@ out: } } -var filterId = 0 - -func (self *Ethereum) InstallFilter(object map[string]interface{}) (*ethchain.Filter, int) { - defer func() { filterId++ }() - - filter := ethchain.NewFilterFromMap(object, self) - self.filters[filterId] = filter - - return filter, filterId +// InstallFilter adds filter for blockchain events. +// The filter's callbacks will run for matching blocks and messages. +// The filter should not be modified after it has been installed. +func (self *Ethereum) InstallFilter(filter *ethchain.Filter) (id int) { + self.filterMu.Lock() + id = self.filterId + self.filters[id] = filter + self.filterId++ + self.filterMu.Unlock() + return id } func (self *Ethereum) UninstallFilter(id int) { + self.filterMu.Lock() delete(self.filters, id) + self.filterMu.Unlock() } +// GetFilter retrieves a filter installed using InstallFilter. +// The filter may not be modified. func (self *Ethereum) GetFilter(id int) *ethchain.Filter { + self.filterMu.RLock() + defer self.filterMu.RUnlock() return self.filters[id] } @@ -627,14 +636,17 @@ out: break out case block := <-blockChan: if block, ok := block.Resource.(*ethchain.Block); ok { + self.filterMu.RLock() for _, filter := range self.filters { if filter.BlockCallback != nil { filter.BlockCallback(block) } } + self.filterMu.RUnlock() } case msg := <-messageChan: if messages, ok := msg.Resource.(ethstate.Messages); ok { + self.filterMu.RLock() for _, filter := range self.filters { if filter.MessageCallback != nil { msgs := filter.FilterMessages(messages) @@ -643,6 +655,7 @@ out: } } } + self.filterMu.RUnlock() } } } |