diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-08-19 03:53:26 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-08-19 03:53:26 +0800 |
commit | d0dc1b4a60d533a9fb0d8df83eb570e827fc281f (patch) | |
tree | 230fbe4f02e1cc8900ed88f83629b878f842baf8 | |
parent | e1da1244157741b9aa17c67ef48f37d07484e905 (diff) | |
parent | b4369e10150f4c1211ae1bf2de6cf0567e9a7dd2 (diff) | |
download | go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar.gz go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar.bz2 go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar.lz go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar.xz go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.tar.zst go-tangerine-d0dc1b4a60d533a9fb0d8df83eb570e827fc281f.zip |
Merge pull request #1681 from obscuren/miner-receipt-fix
core, miner: write miner receipts
-rw-r--r-- | core/block_processor.go | 8 | ||||
-rw-r--r-- | core/chain_manager.go | 4 | ||||
-rw-r--r-- | core/filter.go | 4 | ||||
-rw-r--r-- | miner/worker.go | 7 |
4 files changed, 14 insertions, 9 deletions
diff --git a/core/block_processor.go b/core/block_processor.go index 829e4314c..dd7fe8962 100644 --- a/core/block_processor.go +++ b/core/block_processor.go @@ -349,11 +349,9 @@ func (sm *BlockProcessor) GetBlockReceipts(bhash common.Hash) types.Receipts { // the depricated way by re-processing the block. func (sm *BlockProcessor) GetLogs(block *types.Block) (logs state.Logs, err error) { receipts := GetBlockReceipts(sm.chainDb, block.Hash()) - if len(receipts) > 0 { - // coalesce logs - for _, receipt := range receipts { - logs = append(logs, receipt.Logs()...) - } + // coalesce logs + for _, receipt := range receipts { + logs = append(logs, receipt.Logs()...) } return logs, nil } diff --git a/core/chain_manager.go b/core/chain_manager.go index 1647031b1..cf5b8bd78 100644 --- a/core/chain_manager.go +++ b/core/chain_manager.go @@ -647,7 +647,9 @@ func (self *ChainManager) InsertChain(chain types.Blocks) (int, error) { queue[i] = ChainSplitEvent{block, logs} queueEvent.splitCount++ } - PutBlockReceipts(self.chainDb, block, receipts) + if err := PutBlockReceipts(self.chainDb, block, receipts); err != nil { + glog.V(logger.Warn).Infoln("error writing block receipts:", err) + } stats.processed++ } diff --git a/core/filter.go b/core/filter.go index 8a876396b..c34d6ff6c 100644 --- a/core/filter.go +++ b/core/filter.go @@ -22,6 +22,8 @@ import ( "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/core/state" "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/logger" + "github.com/ethereum/go-ethereum/logger/glog" ) type AccountChange struct { @@ -111,7 +113,7 @@ done: // Get the logs of the block unfiltered, err := self.eth.BlockProcessor().GetLogs(block) if err != nil { - chainlogger.Warnln("err: filter get logs ", err) + glog.V(logger.Warn).Infoln("err: filter get logs ", err) break } diff --git a/miner/worker.go b/miner/worker.go index df3681470..aa2132a51 100644 --- a/miner/worker.go +++ b/miner/worker.go @@ -297,14 +297,17 @@ func (self *worker) wait() { } // broadcast before waiting for validation - go func(block *types.Block, logs state.Logs) { + go func(block *types.Block, logs state.Logs, receipts []*types.Receipt) { self.mux.Post(core.NewMinedBlockEvent{block}) self.mux.Post(core.ChainEvent{block, block.Hash(), logs}) if stat == core.CanonStatTy { self.mux.Post(core.ChainHeadEvent{block}) self.mux.Post(logs) } - }(block, work.state.Logs()) + if err := core.PutBlockReceipts(self.chainDb, block, receipts); err != nil { + glog.V(logger.Warn).Infoln("error writing block receipts:", err) + } + }(block, work.state.Logs(), work.receipts) } // check staleness and display confirmation |