From a61131dfa7af28d48ad38c74a9ed7bcd3f6d72b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C3=A9ter=20Szil=C3=A1gyi?= Date: Tue, 21 Jul 2020 15:53:47 +0300 Subject: [PATCH] cmd/utils: reuse existing genesis in persistent dev mode # Conflicts: # cmd/utils/flags.go --- cmd/utils/flags.go | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/cmd/utils/flags.go b/cmd/utils/flags.go index 32f66bde9..75c064a16 100644 --- a/cmd/utils/flags.go +++ b/cmd/utils/flags.go @@ -1669,7 +1669,17 @@ func SetEthConfig(ctx *cli.Context, stack *node.Node, cfg *eth.Config) { } log.Info("Using developer account", "address", developer.Address) + // Create a new developer genesis block or reuse existing one cfg.Genesis = core.DeveloperGenesisBlock(uint64(ctx.GlobalInt(DeveloperPeriodFlag.Name)), developer.Address) + if ctx.GlobalIsSet(DataDirFlag.Name) { + // Check if we have an already initialized chain and fall back to + // that if so. Otherwise we need to generate a new genesis spec. + chaindb := MakeChainDatabase(ctx, stack) + if rawdb.ReadCanonicalHash(chaindb, 0) != (common.Hash{}) { + cfg.Genesis = nil // fallback to db content + } + chaindb.Close() + } if !ctx.GlobalIsSet(MinerGasPriceFlag.Name) && !ctx.GlobalIsSet(LegacyMinerGasPriceFlag.Name) { cfg.Miner.GasPrice = big.NewInt(1) }