diff options
author | Wei-Ning Huang <w@dexon.org> | 2019-01-13 00:13:49 +0800 |
---|---|---|
committer | Wei-Ning Huang <w@dexon.org> | 2019-03-12 12:19:09 +0800 |
commit | cae038236416efd8a3436664024f9cadee741512 (patch) | |
tree | d759713ad3fc4aa4351c803593a6f9a2b9186f49 /core/genesis.go | |
parent | adb2f97457e766c3c43d6c6603f57c93225c041b (diff) | |
download | dexon-cae038236416efd8a3436664024f9cadee741512.tar dexon-cae038236416efd8a3436664024f9cadee741512.tar.gz dexon-cae038236416efd8a3436664024f9cadee741512.tar.bz2 dexon-cae038236416efd8a3436664024f9cadee741512.tar.lz dexon-cae038236416efd8a3436664024f9cadee741512.tar.xz dexon-cae038236416efd8a3436664024f9cadee741512.tar.zst dexon-cae038236416efd8a3436664024f9cadee741512.zip |
core: vm: add totalSupply and totalStaked in the governance contract (#144)
Add totalSupply and totalStaked in the governance contract for the
preperation of DEXON cryptoeconomics 4.0.
Also removed the unstaked variable in node info and improve tests for
delegate/undeleate.
Diffstat (limited to 'core/genesis.go')
-rw-r--r-- | core/genesis.go | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/core/genesis.go b/core/genesis.go index f07b7a270..622429214 100644 --- a/core/genesis.go +++ b/core/genesis.go @@ -265,6 +265,7 @@ func (g *Genesis) ToBlock(db ethdb.Database) *types.Block { statedb, _ := state.New(common.Hash{}, state.NewDatabase(db)) govStateHelper := vm.GovernanceStateHelper{StateDB: statedb} + totalSupply := big.NewInt(0) totalStaked := big.NewInt(0) for addr, account := range g.Alloc { @@ -281,6 +282,8 @@ func (g *Genesis) ToBlock(db ethdb.Database) *types.Block { for key, value := range account.Storage { statedb.SetState(addr, key, value) } + + totalSupply = new(big.Int).Add(totalSupply, account.Balance) } // For DEXON consensus genesis staking. @@ -316,6 +319,9 @@ func (g *Genesis) ToBlock(db ethdb.Database) *types.Block { // Governance configuration. govStateHelper.UpdateConfiguration(g.Config.Dexcon) + + // Set totalSupply. + govStateHelper.IncTotalSupply(totalSupply) } root := statedb.IntermediateRoot(false) |