aboutsummaryrefslogtreecommitdiffstats
path: root/ethereum.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-10-10 22:58:26 +0800
committerobscuren <geffobscura@gmail.com>2014-10-10 22:58:26 +0800
commit9b494c68698cbcaa4d8d6e0f2b964d29db815da5 (patch)
tree4002f7d9b7fb34b3e1994cf320ae56417af4f3e6 /ethereum.go
parent6877660fe247f758d06fe95d020a29ac3f0357cc (diff)
parent3db6a8e92d7929bafa2d66e753ed365cf0822187 (diff)
downloaddexon-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.go33
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()
}
}
}