diff options
author | obscuren <geffobscura@gmail.com> | 2014-09-14 06:13:47 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-09-14 06:13:47 +0800 |
commit | 91ca5d724e1c65a7d9725b65ea0f003161301f63 (patch) | |
tree | 6d96b68fea31b9add6cc58a97dd09c0d6f3d55b5 /ethereal/ui_lib.go | |
parent | 893e9256a0f48b8fd45f29717145a4df23a3a799 (diff) | |
download | dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar.gz dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar.bz2 dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar.lz dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar.xz dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.tar.zst dexon-91ca5d724e1c65a7d9725b65ea0f003161301f63.zip |
Reworked filters
Diffstat (limited to 'ethereal/ui_lib.go')
-rw-r--r-- | ethereal/ui_lib.go | 53 |
1 files changed, 22 insertions, 31 deletions
diff --git a/ethereal/ui_lib.go b/ethereal/ui_lib.go index 80e711aa7..4e1f7f45c 100644 --- a/ethereal/ui_lib.go +++ b/ethereal/ui_lib.go @@ -37,15 +37,15 @@ type UiLib struct { jsEngine *javascript.JSRE filterCallbacks map[int][]int - filters map[int]*GuiFilter + //filters map[int]*ethpipe.JSFilter } func NewUiLib(engine *qml.Engine, eth *eth.Ethereum, assetPath string) *UiLib { - return &UiLib{JSPipe: ethpipe.NewJSPipe(eth), engine: engine, eth: eth, assetPath: assetPath, jsEngine: javascript.NewJSRE(eth), filterCallbacks: make(map[int][]int), filters: make(map[int]*GuiFilter)} + return &UiLib{JSPipe: ethpipe.NewJSPipe(eth), engine: engine, eth: eth, assetPath: assetPath, jsEngine: javascript.NewJSRE(eth), filterCallbacks: make(map[int][]int)} //, filters: make(map[int]*ethpipe.JSFilter)} } -func (self *UiLib) Note(msg string) { - logger.Infoln(msg) +func (self *UiLib) Notef(args []interface{}) { + logger.Infoln(args...) } func (self *UiLib) LookupDomain(domain string) string { @@ -164,46 +164,37 @@ func (self *UiLib) StartDebugger() { dbWindow.Show() } -func (self *UiLib) RegisterFilter(object map[string]interface{}, seed int) { - filter := &GuiFilter{ethpipe.NewJSFilterFromMap(object, self.eth), seed} - self.filters[seed] = filter - +func (self *UiLib) NewFilter(object map[string]interface{}) int { + filter, id := self.eth.InstallFilter(object) filter.MessageCallback = func(messages ethstate.Messages) { - for _, callbackSeed := range self.filterCallbacks[seed] { - self.win.Root().Call("invokeFilterCallback", filter.MessagesToJson(messages), seed, callbackSeed) - } + self.win.Root().Call("invokeFilterCallback", ethpipe.ToJSMessages(messages), id) } + return id } -func (self *UiLib) RegisterFilterString(typ string, seed int) { - filter := &GuiFilter{ethpipe.NewJSFilterFromMap(nil, self.eth), seed} - self.filters[seed] = filter - - if typ == "chain" { - filter.BlockCallback = func(block *ethchain.Block) { - for _, callbackSeed := range self.filterCallbacks[seed] { - self.win.Root().Call("invokeFilterCallback", "{}", seed, callbackSeed) - } - } +func (self *UiLib) NewFilterString(typ string) int { + filter, id := self.eth.InstallFilter(nil) + filter.BlockCallback = func(block *ethchain.Block) { + self.win.Root().Call("invokeFilterCallback", "{}", id) } -} -func (self *UiLib) RegisterFilterCallback(seed, cbSeed int) { - self.filterCallbacks[seed] = append(self.filterCallbacks[seed], cbSeed) + return id } -func (self *UiLib) UninstallFilter(seed int) { - filter := self.filters[seed] +func (self *UiLib) Messages(id int) *ethutil.List { + filter := self.eth.GetFilter(id) if filter != nil { - filter.Uninstall() - delete(self.filters, seed) + messages := filter.Find() + + return ethpipe.ToJSMessages(messages) } + + return ethutil.EmptyList() } -type GuiFilter struct { - *ethpipe.JSFilter - seed int +func (self *UiLib) UninstallFilter(id int) { + self.eth.UninstallFilter(id) } func (self *UiLib) Transact(object map[string]interface{}) (*ethpipe.JSReceipt, error) { |