Struct reth_ethereum_forks::ChainHardforks

source ·
pub struct ChainHardforks { /* private fields */ }
Expand description

Ordered list of a chain hardforks that implement Hardfork.

Implementations§

source§

impl ChainHardforks

source

pub fn new(forks: Vec<(Box<dyn Hardfork>, ForkCondition)>) -> Self

Creates a new ChainHardforks from a list which must be ordered by activation.

Equivalent Ethereum hardforks must be included as well.

source

pub fn len(&self) -> usize

Total number of hardforks.

source

pub fn is_empty(&self) -> bool

Checks if the fork list is empty.

source

pub fn fork<H: Hardfork>(&self, fork: H) -> ForkCondition

Retrieves ForkCondition from fork. If fork is not present, returns ForkCondition::Never.

source

pub fn get<H: Hardfork>(&self, fork: H) -> Option<ForkCondition>

Retrieves ForkCondition from fork if it exists, otherwise None.

source

pub fn fork_block<H: Hardfork>(&self, fork: H) -> Option<u64>

Retrieves the fork block number or timestamp from fork if it exists, otherwise None.

source

pub fn forks_iter(&self) -> impl Iterator<Item = (&dyn Hardfork, ForkCondition)>

Get an iterator of all hardforks with their respective activation conditions.

source

pub fn last(&self) -> Option<(Box<dyn Hardfork>, ForkCondition)>

Get last hardfork from the list.

source

pub fn is_fork_active_at_timestamp<H: Hardfork>( &self, fork: H, timestamp: u64, ) -> bool

Convenience method to check if a fork is active at a given timestamp.

source

pub fn is_fork_active_at_block<H: Hardfork>( &self, fork: H, block_number: u64, ) -> bool

Convenience method to check if a fork is active at a given block number.

source

pub fn insert<H: Hardfork>(&mut self, fork: H, condition: ForkCondition)

Inserts fork into list, updating with a new ForkCondition if it already exists.

source

pub fn remove<H: Hardfork>(&mut self, fork: H)

Removes fork from list.

Trait Implementations§

source§

impl Clone for ChainHardforks

source§

fn clone(&self) -> ChainHardforks

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ChainHardforks

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for ChainHardforks

source§

fn default() -> ChainHardforks

Returns the “default value” for a type. Read more
source§

impl EthereumHardforks for ChainHardforks

source§

fn is_shanghai_active_at_timestamp(&self, timestamp: u64) -> bool

Convenience method to check if EthereumHardfork::Shanghai is active at a given timestamp.
source§

fn is_cancun_active_at_timestamp(&self, timestamp: u64) -> bool

Convenience method to check if EthereumHardfork::Cancun is active at a given timestamp.
source§

fn is_prague_active_at_timestamp(&self, timestamp: u64) -> bool

Convenience method to check if EthereumHardfork::Prague is active at a given timestamp.
source§

fn is_byzantium_active_at_block(&self, block_number: u64) -> bool

Convenience method to check if EthereumHardfork::Byzantium is active at a given block number.
source§

fn is_spurious_dragon_active_at_block(&self, block_number: u64) -> bool

Convenience method to check if EthereumHardfork::SpuriousDragon is active at a given block number.
source§

fn is_homestead_active_at_block(&self, block_number: u64) -> bool

Convenience method to check if EthereumHardfork::Homestead is active at a given block number.
source§

fn is_paris_active_at_block(&self, block_number: u64) -> Option<bool>

The Paris hardfork (merge) is activated via block number. If we have knowledge of the block, this function will return true if the block number is greater than or equal to the Paris (merge) block.
source§

impl<const N: usize> From<[(EthereumHardfork, ForkCondition); N]> for ChainHardforks

source§

fn from(list: [(EthereumHardfork, ForkCondition); N]) -> Self

Converts to this type from the input type.
source§

impl Hardforks for ChainHardforks

source§

fn fork<H: Hardfork>(&self, fork: H) -> ForkCondition

Retrieves ForkCondition from fork. If fork is not present, returns ForkCondition::Never.
source§

fn forks_iter(&self) -> impl Iterator<Item = (&dyn Hardfork, ForkCondition)>

Get an iterator of all hardforks with their respective activation conditions.
source§

fn is_fork_active_at_timestamp<H: Hardfork>( &self, fork: H, timestamp: u64, ) -> bool

Convenience method to check if a fork is active at a given timestamp.
source§

fn is_fork_active_at_block<H: Hardfork>( &self, fork: H, block_number: u64, ) -> bool

Convenience method to check if a fork is active at a given block number.
source§

impl OptimismHardforks for ChainHardforks

source§

fn is_bedrock_active_at_block(&self, block_number: u64) -> bool

Convenience method to check if OptimismHardfork::Bedrock is active at a given block number.
source§

fn is_ecotone_active_at_timestamp(&self, timestamp: u64) -> bool

Returns true if Ecotone is active at given block timestamp.
source§

fn is_fjord_active_at_timestamp(&self, timestamp: u64) -> bool

Returns true if Ecotone is active at given block timestamp.
source§

fn is_granite_active_at_timestamp(&self, timestamp: u64) -> bool

Returns true if Granite is active at given block timestamp.
source§

impl PartialEq for ChainHardforks

source§

fn eq(&self, other: &ChainHardforks) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for ChainHardforks

source§

impl StructuralPartialEq for ChainHardforks

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit #126799)
Performs copy-assignment from self to dst. Read more
source§

impl<T> DynClone for T
where T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

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: 56 bytes