forked from cerc-io/plugeth
Included total difficulty with new head callback
This commit is contained in:
parent
4f6c8eacb3
commit
9249a67e45
@ -1566,7 +1566,7 @@ func (bc *BlockChain) writeBlockWithState(block *types.Block, receipts []*types.
|
|||||||
bc.futureBlocks.Remove(block.Hash())
|
bc.futureBlocks.Remove(block.Hash())
|
||||||
|
|
||||||
if status == CanonStatTy {
|
if status == CanonStatTy {
|
||||||
pluginNewHead(block, block.Hash(), logs)
|
pluginNewHead(block, block.Hash(), logs, externTd)
|
||||||
bc.chainFeed.Send(ChainEvent{Block: block, Hash: block.Hash(), Logs: logs})
|
bc.chainFeed.Send(ChainEvent{Block: block, Hash: block.Hash(), Logs: logs})
|
||||||
if len(logs) > 0 {
|
if len(logs) > 0 {
|
||||||
bc.logsFeed.Send(logs)
|
bc.logsFeed.Send(logs)
|
||||||
|
@ -2,6 +2,7 @@ package core
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"math/big"
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
"github.com/ethereum/go-ethereum/plugins"
|
"github.com/ethereum/go-ethereum/plugins"
|
||||||
@ -105,9 +106,9 @@ func pluginPostProcessBlock(block *types.Block) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
func PluginNewHead(pl *plugins.PluginLoader, block *types.Block, hash common.Hash, logs []*types.Log) {
|
func PluginNewHead(pl *plugins.PluginLoader, block *types.Block, hash common.Hash, logs []*types.Log, td *big.Int) {
|
||||||
fnList := pl.Lookup("NewHead", func(item interface{}) bool {
|
fnList := pl.Lookup("NewHead", func(item interface{}) bool {
|
||||||
_, ok := item.(func([]byte, core.Hash, [][]byte))
|
_, ok := item.(func([]byte, core.Hash, [][]byte, *big.Int))
|
||||||
return ok
|
return ok
|
||||||
})
|
})
|
||||||
blockBytes, _ := rlp.EncodeToBytes(block)
|
blockBytes, _ := rlp.EncodeToBytes(block)
|
||||||
@ -116,17 +117,17 @@ func PluginNewHead(pl *plugins.PluginLoader, block *types.Block, hash common.Has
|
|||||||
logBytes[i], _ = rlp.EncodeToBytes(l)
|
logBytes[i], _ = rlp.EncodeToBytes(l)
|
||||||
}
|
}
|
||||||
for _, fni := range fnList {
|
for _, fni := range fnList {
|
||||||
if fn, ok := fni.(func([]byte, core.Hash, [][]byte)); ok {
|
if fn, ok := fni.(func([]byte, core.Hash, [][]byte, *big.Int)); ok {
|
||||||
fn(blockBytes, core.Hash(hash), logBytes)
|
fn(blockBytes, core.Hash(hash), logBytes, td)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
func pluginNewHead(block *types.Block, hash common.Hash, logs []*types.Log) {
|
func pluginNewHead(block *types.Block, hash common.Hash, logs []*types.Log, td *big.Int) {
|
||||||
if plugins.DefaultPluginLoader == nil {
|
if plugins.DefaultPluginLoader == nil {
|
||||||
log.Warn("Attempting NewHead, but default PluginLoader has not been initialized")
|
log.Warn("Attempting NewHead, but default PluginLoader has not been initialized")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
PluginNewHead(plugins.DefaultPluginLoader, block, hash, logs)
|
PluginNewHead(plugins.DefaultPluginLoader, block, hash, logs, td)
|
||||||
}
|
}
|
||||||
|
|
||||||
func PluginNewSideBlock(pl *plugins.PluginLoader, block *types.Block, hash common.Hash, logs []*types.Log) {
|
func PluginNewSideBlock(pl *plugins.PluginLoader, block *types.Block, hash common.Hash, logs []*types.Log) {
|
||||||
|
Loading…
Reference in New Issue
Block a user