aboutsummaryrefslogtreecommitdiffstats
path: root/consensus
diff options
context:
space:
mode:
authorWei-Ning Huang <w@dexon.org>2019-01-24 15:05:24 +0800
committerGitHub <noreply@github.com>2019-01-24 15:05:24 +0800
commitc7dd1a1b622eba3e28944f9d00827b7c5fe57c4a (patch)
tree846a0f56def1c9ce7855bc51a42d724192ecf7b7 /consensus
parentd60075505d75de052905caad3562ead280d83199 (diff)
downloaddexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar.gz
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar.bz2
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar.lz
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar.xz
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.tar.zst
dexon-c7dd1a1b622eba3e28944f9d00827b7c5fe57c4a.zip
consensus: dexcon: snapshot round height when finalizing block (#170)
Instead of having BP to send a tx to register the round height, just modify the state when finalizing block.
Diffstat (limited to 'consensus')
-rw-r--r--consensus/dexcon/dexcon.go9
1 files changed, 8 insertions, 1 deletions
diff --git a/consensus/dexcon/dexcon.go b/consensus/dexcon/dexcon.go
index 33f05f599..2e406f0b0 100644
--- a/consensus/dexcon/dexcon.go
+++ b/consensus/dexcon/dexcon.go
@@ -143,13 +143,20 @@ func (d *Dexcon) calculateBlockReward(round int64, state *state.StateDB) *big.In
// Finalize implements consensus.Engine, ensuring no uncles are set, nor block
// rewards given, and returns the final block.
func (d *Dexcon) Finalize(chain consensus.ChainReader, header *types.Header, state *state.StateDB, txs []*types.Transaction, uncles []*types.Header, receipts []*types.Receipt) (*types.Block, error) {
+ gs := vm.GovernanceStateHelper{state}
+
+ height := gs.RoundHeight(new(big.Int).SetUint64(header.Round))
+ if header.Round > 0 && height.Uint64() == 0 {
+ gs.PushRoundHeight(header.Number)
+ }
+
+ // Distribute block reward and halving condition.
if header.Coinbase == (common.Address{}) {
header.Reward = new(big.Int)
} else {
reward := d.calculateBlockReward(int64(header.Round), state)
state.AddBalance(header.Coinbase, reward)
- gs := vm.GovernanceStateHelper{state}
gs.IncTotalSupply(reward)
config := gs.Configuration()