Struct reth_primitives::genesis::ChainConfig
pub struct ChainConfig {Show 27 fields
pub chain_id: u64,
pub homestead_block: Option<u64>,
pub dao_fork_block: Option<u64>,
pub dao_fork_support: bool,
pub eip150_block: Option<u64>,
pub eip155_block: Option<u64>,
pub eip158_block: Option<u64>,
pub byzantium_block: Option<u64>,
pub constantinople_block: Option<u64>,
pub petersburg_block: Option<u64>,
pub istanbul_block: Option<u64>,
pub muir_glacier_block: Option<u64>,
pub berlin_block: Option<u64>,
pub london_block: Option<u64>,
pub arrow_glacier_block: Option<u64>,
pub gray_glacier_block: Option<u64>,
pub merge_netsplit_block: Option<u64>,
pub shanghai_time: Option<u64>,
pub cancun_time: Option<u64>,
pub prague_time: Option<u64>,
pub terminal_total_difficulty: Option<Uint<256, 4>>,
pub terminal_total_difficulty_passed: bool,
pub ethash: Option<EthashConfig>,
pub clique: Option<CliqueConfig>,
pub parlia: Option<ParliaConfig>,
pub extra_fields: OtherFields,
pub deposit_contract_address: Option<Address>,
}
Expand description
Defines core blockchain settings per block.
Tailors unique settings for each network based on its genesis block.
Governs crucial blockchain behavior and adaptability.
Encapsulates parameters shaping network evolution and behavior.
See geth’s ChainConfig
struct
for the source of each field.
Fields§
§chain_id: u64
The network’s chain ID.
homestead_block: Option<u64>
The homestead switch block (None = no fork, 0 = already homestead).
dao_fork_block: Option<u64>
The DAO fork switch block (None = no fork).
dao_fork_support: bool
Whether or not the node supports the DAO hard-fork.
eip150_block: Option<u64>
The EIP-150 hard fork block (None = no fork).
eip155_block: Option<u64>
The EIP-155 hard fork block.
eip158_block: Option<u64>
The EIP-158 hard fork block.
byzantium_block: Option<u64>
The Byzantium hard fork block (None = no fork, 0 = already on byzantium).
constantinople_block: Option<u64>
The Constantinople hard fork block (None = no fork, 0 = already on constantinople).
petersburg_block: Option<u64>
The Petersburg hard fork block (None = no fork, 0 = already on petersburg).
istanbul_block: Option<u64>
The Istanbul hard fork block (None = no fork, 0 = already on istanbul).
muir_glacier_block: Option<u64>
The Muir Glacier hard fork block (None = no fork, 0 = already on muir glacier).
berlin_block: Option<u64>
The Berlin hard fork block (None = no fork, 0 = already on berlin).
london_block: Option<u64>
The London hard fork block (None = no fork, 0 = already on london).
arrow_glacier_block: Option<u64>
The Arrow Glacier hard fork block (None = no fork, 0 = already on arrow glacier).
gray_glacier_block: Option<u64>
The Gray Glacier hard fork block (None = no fork, 0 = already on gray glacier).
merge_netsplit_block: Option<u64>
Virtual fork after the merge to use as a network splitter.
shanghai_time: Option<u64>
Shanghai switch time (None = no fork, 0 = already on shanghai).
cancun_time: Option<u64>
Cancun switch time (None = no fork, 0 = already on cancun).
prague_time: Option<u64>
Prague switch time (None = no fork, 0 = already on prague).
terminal_total_difficulty: Option<Uint<256, 4>>
Total difficulty reached that triggers the merge consensus upgrade.
terminal_total_difficulty_passed: bool
A flag specifying that the network already passed the terminal total difficulty. Its purpose is to disable legacy sync without having seen the TTD locally.
ethash: Option<EthashConfig>
Ethash parameters.
clique: Option<CliqueConfig>
Clique parameters.
parlia: Option<ParliaConfig>
Parlia parameters.
extra_fields: OtherFields
Additional fields specific to each chain.
deposit_contract_address: Option<Address>
The deposit contract address
Implementations§
§impl ChainConfig
impl ChainConfig
pub fn is_homestead_active_at_block(&self, block: u64) -> bool
pub fn is_homestead_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Homestead fork block.
pub fn is_eip150_active_at_block(&self, block: u64) -> bool
pub fn is_eip150_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the EIP150 fork block.
pub fn is_eip155_active_at_block(&self, block: u64) -> bool
pub fn is_eip155_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the EIP155 fork block.
pub fn is_eip158_active_at_block(&self, block: u64) -> bool
pub fn is_eip158_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the EIP158 fork block.
pub fn is_byzantium_active_at_block(&self, block: u64) -> bool
pub fn is_byzantium_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Byzantium fork block.
pub fn is_constantinople_active_at_block(&self, block: u64) -> bool
pub fn is_constantinople_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Constantinople fork block.
pub fn is_muir_glacier_active_at_block(&self, block: u64) -> bool
pub fn is_muir_glacier_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Muir Glacier (EIP-2384) fork block.
pub fn is_petersburg_active_at_block(&self, block: u64) -> bool
pub fn is_petersburg_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Petersburg fork block.
pub fn is_istanbul_active_at_block(&self, block: u64) -> bool
pub fn is_istanbul_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Istanbul fork block.
pub fn is_berlin_active_at_block(&self, block: u64) -> bool
pub fn is_berlin_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Berlin fork block.
pub fn is_london_active_at_block(&self, block: u64) -> bool
pub fn is_london_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the London fork block.
pub fn is_arrow_glacier_active_at_block(&self, block: u64) -> bool
pub fn is_arrow_glacier_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Arrow Glacier (EIP-4345) fork block.
pub fn is_gray_glacier_active_at_block(&self, block: u64) -> bool
pub fn is_gray_glacier_active_at_block(&self, block: u64) -> bool
Checks if the blockchain is active at or after the Gray Glacier (EIP-5133) fork block.
pub fn is_shanghai_active_at_block_and_timestamp(
&self,
block: u64,
timestamp: u64,
) -> bool
pub fn is_shanghai_active_at_block_and_timestamp( &self, block: u64, timestamp: u64, ) -> bool
Checks if the blockchain is active at or after the Shanghai fork block and the specified timestamp.
pub fn is_cancun_active_at_block_and_timestamp(
&self,
block: u64,
timestamp: u64,
) -> bool
pub fn is_cancun_active_at_block_and_timestamp( &self, block: u64, timestamp: u64, ) -> bool
Checks if the blockchain is active at or after the Cancun fork block and the specified timestamp.
Trait Implementations§
§impl Clone for ChainConfig
impl Clone for ChainConfig
§fn clone(&self) -> ChainConfig
fn clone(&self) -> ChainConfig
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl Debug for ChainConfig
impl Debug for ChainConfig
§impl Default for ChainConfig
impl Default for ChainConfig
§fn default() -> ChainConfig
fn default() -> ChainConfig
§impl<'de> Deserialize<'de> for ChainConfigwhere
ChainConfig: Default,
impl<'de> Deserialize<'de> for ChainConfigwhere
ChainConfig: Default,
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<ChainConfig, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<ChainConfig, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
§impl PartialEq for ChainConfig
impl PartialEq for ChainConfig
§impl Serialize for ChainConfig
impl Serialize for ChainConfig
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
impl Eq for ChainConfig
impl StructuralPartialEq for ChainConfig
Auto Trait Implementations§
impl Freeze for ChainConfig
impl RefUnwindSafe for ChainConfig
impl Send for ChainConfig
impl Sync for ChainConfig
impl Unpin for ChainConfig
impl UnwindSafe for ChainConfig
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
impl<T> MaybeDebug for Twhere
T: Debug,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 448 bytes