Skip to content

Commit

Permalink
fixed merge
Browse files Browse the repository at this point in the history
  • Loading branch information
obscuren committed Feb 20, 2015
2 parents ea9a549 + a59cd94 commit 7562580
Show file tree
Hide file tree
Showing 6 changed files with 130 additions and 9 deletions.
9 changes: 3 additions & 6 deletions core/chain_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -396,8 +396,9 @@ func (self *ChainManager) InsertChain(chain types.Blocks) error {
self.mu.Unlock()

if chain {
//self.setTransState(state.New(block.Root(), self.db))
//self.eventMux.Post(ChainEvent{block, td})
fmt.Println("POST START")
self.eventMux.Post(ChainEvent{block, td})
fmt.Println("POST END")
}

if split {
Expand All @@ -413,7 +414,3 @@ func (self *ChainManager) InsertChain(chain types.Blocks) error {
func (self *ChainManager) GetAccount(addr []byte) *state.StateObject {
return self.State().GetAccount(addr)
}

func (self *ChainManager) TransMut() *sync.RWMutex {
return &self.tsmu
}
10 changes: 7 additions & 3 deletions event/filter/eth_filter.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package filter
// TODO make use of the generic filtering system

import (
"fmt"
"sync"

"github.com/ethereum/go-ethereum/core"
Expand Down Expand Up @@ -37,17 +38,18 @@ func (self *FilterManager) Stop() {

func (self *FilterManager) InstallFilter(filter *core.Filter) (id int) {
self.filterMu.Lock()
defer self.filterMu.Unlock()
id = self.filterId
self.filters[id] = filter
self.filterId++
self.filterMu.Unlock()

return id
}

func (self *FilterManager) UninstallFilter(id int) {
self.filterMu.Lock()
defer self.filterMu.Unlock()
delete(self.filters, id)
self.filterMu.Unlock()
}

// GetFilter retrieves a filter installed using InstallFilter.
Expand All @@ -62,7 +64,7 @@ func (self *FilterManager) filterLoop() {
// Subscribe to events
events := self.eventMux.Subscribe(
core.PendingBlockEvent{},
core.ChainEvent{},
//core.ChainEvent{},
state.Logs(nil))

out:
Expand All @@ -73,13 +75,15 @@ out:
case event := <-events.Chan():
switch event := event.(type) {
case core.ChainEvent:
fmt.Println("filter start")
self.filterMu.RLock()
for _, filter := range self.filters {
if filter.BlockCallback != nil {
filter.BlockCallback(event.Block)
}
}
self.filterMu.RUnlock()
fmt.Println("filter stop")

case core.PendingBlockEvent:
self.filterMu.RLock()
Expand Down
2 changes: 2 additions & 0 deletions miner/worker.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,9 +117,11 @@ out:
case event := <-events.Chan():
switch ev := event.(type) {
case core.ChainEvent:
println("miner start")
if self.current.block != ev.Block {
self.commitNewWork()
}
println("miner end")
case core.NewMinedBlockEvent:
self.commitNewWork()
}
Expand Down
60 changes: 60 additions & 0 deletions rpc/message.go
Original file line number Diff line number Diff line change
Expand Up @@ -201,6 +201,36 @@ func (req *RpcRequest) ToGetCodeAtArgs() (*GetCodeAtArgs, error) {
return args, nil
}

func (req *RpcRequest) ToBoolArgs() (bool, error) {
if len(req.Params) < 1 {
return false, NewErrorResponse(ErrorArguments)
}

var args bool
err := json.Unmarshal(req.Params[0], &args)
if err != nil {
return false, NewErrorResponse(ErrorDecodeArgs)
}

rpclogger.DebugDetailf("%T %v", args, args)
return args, nil
}

func (req *RpcRequest) ToCompileArgs() (string, error) {
if len(req.Params) < 1 {
return "", NewErrorResponse(ErrorArguments)
}

var args string
err := json.Unmarshal(req.Params[0], &args)
if err != nil {
return "", NewErrorResponse(ErrorDecodeArgs)
}

rpclogger.DebugDetailf("%T %v", args, args)
return args, nil
}

func (req *RpcRequest) ToFilterArgs() (*FilterOptions, error) {
if len(req.Params) < 1 {
return nil, NewErrorResponse(ErrorArguments)
Expand Down Expand Up @@ -231,6 +261,36 @@ func (req *RpcRequest) ToFilterStringArgs() (string, error) {
return args, nil
}

func (req *RpcRequest) ToUninstallFilterArgs() (int, error) {
if len(req.Params) < 1 {
return 0, NewErrorResponse(ErrorArguments)
}

var args int
err := json.Unmarshal(req.Params[0], &args)
if err != nil {
return 0, NewErrorResponse(ErrorDecodeArgs)
}

rpclogger.DebugDetailf("%T %v", args, args)
return args, nil
}

func (req *RpcRequest) ToFilterChangedArgs() (int, error) {
if len(req.Params) < 1 {
return 0, NewErrorResponse(ErrorArguments)
}

var id int
r := bytes.NewReader(req.Params[0])
err := json.NewDecoder(r).Decode(&id)
if err != nil {
return 0, NewErrorResponse(ErrorDecodeArgs)
}
rpclogger.DebugDetailf("%T %v", id, id)
return id, nil
}

func (req *RpcRequest) ToDbPutArgs() (*DbArgs, error) {
if len(req.Params) < 3 {
return nil, NewErrorResponse(ErrorArguments)
Expand Down
47 changes: 47 additions & 0 deletions rpc/packages.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,13 @@ func (self *EthereumApi) NewFilter(args *FilterOptions, reply *interface{}) erro
return nil
}

func (self *EthereumApi) UninstallFilter(id int, reply *interface{}) error {
delete(self.logs, id)
self.filterManager.UninstallFilter(id)
*reply = true
return nil
}

func (self *EthereumApi) NewFilterString(args string, reply *interface{}) error {
var id int
filter := core.NewFilter(self.xeth.Backend())
Expand Down Expand Up @@ -273,6 +280,11 @@ func (p *EthereumApi) GetIsMining(reply *interface{}) error {
return nil
}

func (p *EthereumApi) SetMining(shouldmine bool, reply *interface{}) error {
*reply = p.xeth.SetMining(shouldmine)
return nil
}

func (p *EthereumApi) BlockNumber(reply *interface{}) error {
*reply = p.xeth.Backend().ChainManager().CurrentBlock().Number()
return nil
Expand Down Expand Up @@ -306,6 +318,21 @@ func (p *EthereumApi) GetCodeAt(args *GetCodeAtArgs, reply *interface{}) error {
return nil
}

func (p *EthereumApi) GetCompilers(reply *interface{}) error {
c := []string{"serpent"}
*reply = c
return nil
}

func (p *EthereumApi) CompileSerpent(script string, reply *interface{}) error {
res, err := ethutil.Compile(script, false)
if err != nil {
return err
}
*reply = res
return nil
}

func (p *EthereumApi) Sha3(args *Sha3Args, reply *interface{}) error {
*reply = toHex(crypto.Sha3(fromHex(args.Data)))
return nil
Expand Down Expand Up @@ -394,6 +421,12 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
return p.GetIsListening(reply)
case "eth_mining":
return p.GetIsMining(reply)
case "eth_setMining":
args, err := req.ToBoolArgs()
if err != nil {
return err
}
return p.SetMining(args, reply)
case "eth_peerCount":
return p.GetPeerCount(reply)
case "eth_number":
Expand Down Expand Up @@ -460,6 +493,12 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
return err
}
return p.NewFilterString(args, reply)
case "eth_uninstallFilter":
args, err := req.ToUninstallFilterArgs()
if err != nil {
return err
}
return p.UninstallFilter(args, reply)
case "eth_changed":
args, err := req.ToIdArgs()
if err != nil {
Expand Down Expand Up @@ -493,6 +532,14 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
return err
}
return p.WatchTx(args, reply)
case "eth_compilers":
return p.GetCompilers(reply)
case "eth_serpent":
args, err := req.ToCompileArgs()
if err != nil {
return err
}
return p.CompileSerpent(args, reply)
case "web3_sha3":
args, err := req.ToSha3Args()
if err != nil {
Expand Down
11 changes: 11 additions & 0 deletions xeth/xeth.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,17 @@ func (self *XEth) IsMining() bool {
return self.miner.Mining()
}

func (self *XEth) SetMining(shouldmine bool) bool {
ismining := self.miner.Mining()
if shouldmine && !ismining {
self.miner.Start()
}
if ismining && !shouldmine {
self.miner.Stop()
}
return self.miner.Mining()
}

func (self *XEth) IsListening() bool {
return self.eth.IsListening()
}
Expand Down

0 comments on commit 7562580

Please sign in to comment.