mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-27 04:26:07 +00:00
74253c88e3
Add the new [Arrow Glacier fork](https://eips.ethereum.org/EIPS/eip-4345). Only the difficulty calculation is changed, but as a new fork it still affects a number of places in the code. To the best of my knowledge the change is only scheduled on Mainnet. In addition: - The fork date comments in `chain_config.nim` have been checked against the real networks, set consistently in UTC instead of random timezones, and made neater. Maybe we'll keep these when transferring config to a file someday. - It's added to forkid hash tests (EIP-2124/EIP-2364), of course. Signed-off-by: Jamie Lokier <jamie@shareable.org>
81 lines
2.8 KiB
Nim
81 lines
2.8 KiB
Nim
# Nimbus
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
# Licensed under either of
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
# http://opensource.org/licenses/MIT)
|
|
# at your option. This file may not be copied, modified, or distributed except
|
|
# according to those terms.
|
|
|
|
import
|
|
../../chain_config,
|
|
../../db/db_chain,
|
|
./chain_desc,
|
|
chronicles,
|
|
eth/common,
|
|
stew/endians2,
|
|
stint
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# Helpers
|
|
# ------------------------------------------------------------------------------
|
|
|
|
func toChainFork(c: ChainConfig, number: BlockNumber): ChainFork =
|
|
if number >= c.arrowGlacierBlock: ArrowGlacier
|
|
elif number >= c.londonBlock: London
|
|
elif number >= c.berlinBlock: Berlin
|
|
elif number >= c.muirGlacierBlock: MuirGlacier
|
|
elif number >= c.istanbulBlock: Istanbul
|
|
elif number >= c.petersburgBlock: Petersburg
|
|
elif number >= c.constantinopleBlock: Constantinople
|
|
elif number >= c.byzantiumBlock: Byzantium
|
|
elif number >= c.eip158Block: Spurious
|
|
elif number >= c.eip150Block: Tangerine
|
|
elif number >= c.daoForkBlock: DAOFork
|
|
elif number >= c.homesteadBlock: Homestead
|
|
else: Frontier
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# Public `AbstractChainDB` overload methods
|
|
# ------------------------------------------------------------------------------
|
|
|
|
method getBlockHeader*(c: Chain, b: HashOrNum, output: var BlockHeader): bool
|
|
{.gcsafe, raises: [Defect,RlpError].} =
|
|
case b.isHash
|
|
of true:
|
|
c.db.getBlockHeader(b.hash, output)
|
|
else:
|
|
c.db.getBlockHeader(b.number, output)
|
|
|
|
|
|
method getSuccessorHeader*(c: Chain, h: BlockHeader, output: var BlockHeader,
|
|
skip = 0'u): bool {.gcsafe, raises: [Defect,RlpError].} =
|
|
let offset = 1 + skip.toBlockNumber
|
|
if h.blockNumber <= (not 0.toBlockNumber) - offset:
|
|
result = c.db.getBlockHeader(h.blockNumber + offset, output)
|
|
|
|
|
|
method getAncestorHeader*(c: Chain, h: BlockHeader, output: var BlockHeader,
|
|
skip = 0'u): bool {.gcsafe, raises: [Defect,RlpError].} =
|
|
let offset = 1 + skip.toBlockNumber
|
|
if h.blockNumber >= offset:
|
|
result = c.db.getBlockHeader(h.blockNumber - offset, output)
|
|
|
|
|
|
method getBlockBody*(c: Chain, blockHash: KeccakHash): BlockBodyRef =
|
|
## Always `nil`
|
|
result = nil
|
|
|
|
|
|
method getForkId*(c: Chain, n: BlockNumber): ForkID {.gcsafe.} =
|
|
## EIP 2364/2124
|
|
let fork = c.db.config.toChainFork(n)
|
|
c.forkIds[fork]
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# End
|
|
# ------------------------------------------------------------------------------
|