aboutsummaryrefslogtreecommitdiff
path: root/core/gen_genesis.go
diff options
context:
space:
mode:
authorDeterminant <[email protected]>2020-07-30 14:18:44 -0400
committerDeterminant <[email protected]>2020-07-30 14:18:44 -0400
commit0444e66f640999c15496066637841efcc0433934 (patch)
treec19aec2dced2e9129c880c19c52ca0f87b3d62f6 /core/gen_genesis.go
parentcffa0954bbdb43821d1b71d00f99fb705cecd25b (diff)
parent1f49826de2bb8bb4f5f99f69fd2beb039b1172d9 (diff)
Merge branch 'multi-coin'
Diffstat (limited to 'core/gen_genesis.go')
-rw-r--r--core/gen_genesis.go118
1 files changed, 118 insertions, 0 deletions
diff --git a/core/gen_genesis.go b/core/gen_genesis.go
new file mode 100644
index 0000000..97175f7
--- /dev/null
+++ b/core/gen_genesis.go
@@ -0,0 +1,118 @@
+// Code generated by github.com/fjl/gencodec. DO NOT EDIT.
+
+package core
+
+import (
+ "encoding/json"
+ "errors"
+ "math/big"
+
+ "github.com/ava-labs/coreth/params"
+ "github.com/ava-labs/go-ethereum/common"
+ "github.com/ava-labs/go-ethereum/common/hexutil"
+ "github.com/ava-labs/go-ethereum/common/math"
+)
+
+var _ = (*genesisSpecMarshaling)(nil)
+
+// MarshalJSON marshals as JSON.
+func (g Genesis) MarshalJSON() ([]byte, error) {
+ type Genesis struct {
+ Config *params.ChainConfig `json:"config"`
+ Nonce math.HexOrDecimal64 `json:"nonce"`
+ Timestamp math.HexOrDecimal64 `json:"timestamp"`
+ ExtraData hexutil.Bytes `json:"extraData"`
+ GasLimit math.HexOrDecimal64 `json:"gasLimit" gencodec:"required"`
+ Difficulty *math.HexOrDecimal256 `json:"difficulty" gencodec:"required"`
+ Mixhash common.Hash `json:"mixHash"`
+ Coinbase common.Address `json:"coinbase"`
+ Alloc map[common.UnprefixedAddress]GenesisAccount `json:"alloc" gencodec:"required"`
+ Number math.HexOrDecimal64 `json:"number"`
+ GasUsed math.HexOrDecimal64 `json:"gasUsed"`
+ ParentHash common.Hash `json:"parentHash"`
+ }
+ var enc Genesis
+ enc.Config = g.Config
+ enc.Nonce = math.HexOrDecimal64(g.Nonce)
+ enc.Timestamp = math.HexOrDecimal64(g.Timestamp)
+ enc.ExtraData = g.ExtraData
+ enc.GasLimit = math.HexOrDecimal64(g.GasLimit)
+ enc.Difficulty = (*math.HexOrDecimal256)(g.Difficulty)
+ enc.Mixhash = g.Mixhash
+ enc.Coinbase = g.Coinbase
+ if g.Alloc != nil {
+ enc.Alloc = make(map[common.UnprefixedAddress]GenesisAccount, len(g.Alloc))
+ for k, v := range g.Alloc {
+ enc.Alloc[common.UnprefixedAddress(k)] = v
+ }
+ }
+ enc.Number = math.HexOrDecimal64(g.Number)
+ enc.GasUsed = math.HexOrDecimal64(g.GasUsed)
+ enc.ParentHash = g.ParentHash
+ return json.Marshal(&enc)
+}
+
+// UnmarshalJSON unmarshals from JSON.
+func (g *Genesis) UnmarshalJSON(input []byte) error {
+ type Genesis struct {
+ Config *params.ChainConfig `json:"config"`
+ Nonce *math.HexOrDecimal64 `json:"nonce"`
+ Timestamp *math.HexOrDecimal64 `json:"timestamp"`
+ ExtraData *hexutil.Bytes `json:"extraData"`
+ GasLimit *math.HexOrDecimal64 `json:"gasLimit" gencodec:"required"`
+ Difficulty *math.HexOrDecimal256 `json:"difficulty" gencodec:"required"`
+ Mixhash *common.Hash `json:"mixHash"`
+ Coinbase *common.Address `json:"coinbase"`
+ Alloc map[common.UnprefixedAddress]GenesisAccount `json:"alloc" gencodec:"required"`
+ Number *math.HexOrDecimal64 `json:"number"`
+ GasUsed *math.HexOrDecimal64 `json:"gasUsed"`
+ ParentHash *common.Hash `json:"parentHash"`
+ }
+ var dec Genesis
+ if err := json.Unmarshal(input, &dec); err != nil {
+ return err
+ }
+ if dec.Config != nil {
+ g.Config = dec.Config
+ }
+ if dec.Nonce != nil {
+ g.Nonce = uint64(*dec.Nonce)
+ }
+ if dec.Timestamp != nil {
+ g.Timestamp = uint64(*dec.Timestamp)
+ }
+ if dec.ExtraData != nil {
+ g.ExtraData = *dec.ExtraData
+ }
+ if dec.GasLimit == nil {
+ return errors.New("missing required field 'gasLimit' for Genesis")
+ }
+ g.GasLimit = uint64(*dec.GasLimit)
+ if dec.Difficulty == nil {
+ return errors.New("missing required field 'difficulty' for Genesis")
+ }
+ g.Difficulty = (*big.Int)(dec.Difficulty)
+ if dec.Mixhash != nil {
+ g.Mixhash = *dec.Mixhash
+ }
+ if dec.Coinbase != nil {
+ g.Coinbase = *dec.Coinbase
+ }
+ if dec.Alloc == nil {
+ return errors.New("missing required field 'alloc' for Genesis")
+ }
+ g.Alloc = make(GenesisAlloc, len(dec.Alloc))
+ for k, v := range dec.Alloc {
+ g.Alloc[common.Address(k)] = v
+ }
+ if dec.Number != nil {
+ g.Number = uint64(*dec.Number)
+ }
+ if dec.GasUsed != nil {
+ g.GasUsed = uint64(*dec.GasUsed)
+ }
+ if dec.ParentHash != nil {
+ g.ParentHash = *dec.ParentHash
+ }
+ return nil
+}