Struct RecoveredBlock
pub struct RecoveredBlock<B>where
B: Block,{ /* private fields */ }Expand description
A block with senders recovered from the block’s transactions.
This type is a SealedBlock with a list of senders that match the transactions in the block.
§Sealing
This type uses lazy sealing to avoid hashing the header until it is needed:
RecoveredBlock::new_unhashed creates a recovered block without hashing the header.
RecoveredBlock::new creates a recovered block with the corresponding block hash.
§Recovery
Sender recovery is fallible and can fail if any of the transactions fail to recover the sender.
A SealedBlock can be upgraded to a RecoveredBlock using the
RecoveredBlock::try_recover or SealedBlock::try_recover method.
Implementations§
§impl<B> RecoveredBlock<B>where
B: Block,
impl<B> RecoveredBlock<B>where
B: Block,
pub fn new(
block: B,
senders: Vec<Address>,
hash: FixedBytes<32>,
) -> RecoveredBlock<B>
pub fn new( block: B, senders: Vec<Address>, hash: FixedBytes<32>, ) -> RecoveredBlock<B>
Creates a new recovered block instance with the given senders as provided and the block hash.
Note: This expects that the given senders match the transactions in the block.
pub fn new_unhashed(block: B, senders: Vec<Address>) -> RecoveredBlock<B>
pub fn new_unhashed(block: B, senders: Vec<Address>) -> RecoveredBlock<B>
Creates a new recovered block instance with the given senders as provided.
Note: This expects that the given senders match the transactions in the block.
pub fn senders(&self) -> &[Address]
pub fn senders(&self) -> &[Address]
Returns the recovered senders.
pub fn senders_iter(&self) -> impl Iterator<Item = &Address>
pub fn senders_iter(&self) -> impl Iterator<Item = &Address>
Returns an iterator over the recovered senders.
pub fn into_block(self) -> B
pub fn into_block(self) -> B
Consumes the type and returns the inner block.
pub const fn sealed_block(&self) -> &SealedBlock<B>
pub const fn sealed_block(&self) -> &SealedBlock<B>
Returns a reference to the sealed block.
pub const fn new_sealed(
block: SealedBlock<B>,
senders: Vec<Address>,
) -> RecoveredBlock<B>
pub const fn new_sealed( block: SealedBlock<B>, senders: Vec<Address>, ) -> RecoveredBlock<B>
Creates a new recovered block instance with the given SealedBlock and senders as
provided
pub fn try_new(
block: B,
senders: Vec<Address>,
hash: FixedBytes<32>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_new( block: B, senders: Vec<Address>, hash: FixedBytes<32>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
A safer variant of Self::new_unhashed that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer
to recover the senders.
pub fn try_new_unchecked(
block: B,
senders: Vec<Address>,
hash: FixedBytes<32>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_new_unchecked( block: B, senders: Vec<Address>, hash: FixedBytes<32>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
A safer variant of Self::new that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer_unchecked
to recover the senders.
pub fn try_new_unhashed(
block: B,
senders: Vec<Address>,
) -> Result<RecoveredBlock<B>, RecoveryError>
pub fn try_new_unhashed( block: B, senders: Vec<Address>, ) -> Result<RecoveredBlock<B>, RecoveryError>
A safer variant of Self::new_unhashed that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer
to recover the senders.
pub fn try_new_unhashed_unchecked(
block: B,
senders: Vec<Address>,
) -> Result<RecoveredBlock<B>, RecoveryError>
pub fn try_new_unhashed_unchecked( block: B, senders: Vec<Address>, ) -> Result<RecoveredBlock<B>, RecoveryError>
A safer variant of Self::new_unhashed that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer_unchecked
to recover the senders.
pub fn try_recover(block: B) -> Result<RecoveredBlock<B>, RecoveryError>
pub fn try_recover(block: B) -> Result<RecoveredBlock<B>, RecoveryError>
Recovers the senders from the transactions in the block using
SignedTransaction::recover_signer.
Returns an error if any of the transactions fail to recover the sender.
pub fn try_recover_unchecked(
block: B,
) -> Result<RecoveredBlock<B>, RecoveryError>
pub fn try_recover_unchecked( block: B, ) -> Result<RecoveredBlock<B>, RecoveryError>
Recovers the senders from the transactions in the block using
SignedTransaction::recover_signer_unchecked.
Returns an error if any of the transactions fail to recover the sender.
pub fn try_recover_sealed(
block: SealedBlock<B>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_recover_sealed( block: SealedBlock<B>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
Recovers the senders from the transactions in the block using
SignedTransaction::recover_signer.
Returns an error if any of the transactions fail to recover the sender.
pub fn try_recover_sealed_unchecked(
block: SealedBlock<B>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_recover_sealed_unchecked( block: SealedBlock<B>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
Recovers the senders from the transactions in the sealed block using
SignedTransaction::recover_signer_unchecked.
Returns an error if any of the transactions fail to recover the sender.
pub fn try_recover_sealed_with_senders(
block: SealedBlock<B>,
senders: Vec<Address>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_recover_sealed_with_senders( block: SealedBlock<B>, senders: Vec<Address>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
A safer variant of Self::new_unhashed that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer_unchecked
to recover the senders.
Returns an error if any of the transactions fail to recover the sender.
pub fn try_recover_sealed_with_senders_unchecked(
block: SealedBlock<B>,
senders: Vec<Address>,
) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
pub fn try_recover_sealed_with_senders_unchecked( block: SealedBlock<B>, senders: Vec<Address>, ) -> Result<RecoveredBlock<B>, BlockRecoveryError<SealedBlock<B>>>
A safer variant of Self::new that checks if the number of senders is equal to
the number of transactions in the block and recovers the senders from the transactions, if
not using SignedTransaction::recover_signer_unchecked
to recover the senders.
pub fn hash_ref(&self) -> &FixedBytes<32>
pub fn hash_ref(&self) -> &FixedBytes<32>
Returns the block hash.
pub fn hash(&self) -> FixedBytes<32>
pub fn hash(&self) -> FixedBytes<32>
Returns a copy of the block hash.
pub fn num_hash(&self) -> NumHash
pub fn num_hash(&self) -> NumHash
Return the number hash tuple.
pub fn block_with_parent(&self) -> BlockWithParent
pub fn block_with_parent(&self) -> BlockWithParent
Return a [BlockWithParent] for this header.
pub fn clone_header(&self) -> <B as Block>::Header
pub fn clone_header(&self) -> <B as Block>::Header
Clone the header.
pub fn clone_sealed_header(&self) -> SealedHeader<<B as Block>::Header>
pub fn clone_sealed_header(&self) -> SealedHeader<<B as Block>::Header>
Clones the internal header and returns a SealedHeader sealed with the hash.
pub fn clone_sealed_block(&self) -> SealedBlock<B>
pub fn clone_sealed_block(&self) -> SealedBlock<B>
Clones the wrapped block and returns the SealedBlock sealed with the hash.
pub fn into_header(self) -> <B as Block>::Header
pub fn into_header(self) -> <B as Block>::Header
Consumes the block and returns the block’s header.
pub fn into_sealed_block(self) -> SealedBlock<B>
pub fn into_sealed_block(self) -> SealedBlock<B>
Consumes the block and returns the SealedBlock and drops the recovered senders.
pub fn split_sealed(self) -> (SealedBlock<B>, Vec<Address>)
pub fn split_sealed(self) -> (SealedBlock<B>, Vec<Address>)
Consumes the type and returns its components.
pub fn transactions_with_sender(
&self,
) -> impl Iterator<Item = (&Address, &<<B as Block>::Body as BlockBody>::Transaction)>
pub fn transactions_with_sender( &self, ) -> impl Iterator<Item = (&Address, &<<B as Block>::Body as BlockBody>::Transaction)>
Returns an iterator over all transactions and their sender.
pub fn clone_transactions_recovered(
&self,
) -> impl Iterator<Item = Recovered<<<B as Block>::Body as BlockBody>::Transaction>>
pub fn clone_transactions_recovered( &self, ) -> impl Iterator<Item = Recovered<<<B as Block>::Body as BlockBody>::Transaction>>
Returns an iterator over cloned Recovered<Transaction>
pub fn transactions_recovered(
&self,
) -> impl Iterator<Item = Recovered<&<<B as Block>::Body as BlockBody>::Transaction>>
pub fn transactions_recovered( &self, ) -> impl Iterator<Item = Recovered<&<<B as Block>::Body as BlockBody>::Transaction>>
Returns an iterator over Recovered<&Transaction>
pub fn into_transactions_recovered(
self,
) -> impl Iterator<Item = Recovered<<<B as Block>::Body as BlockBody>::Transaction>>
pub fn into_transactions_recovered( self, ) -> impl Iterator<Item = Recovered<<<B as Block>::Body as BlockBody>::Transaction>>
Consumes the type and returns an iterator over all Recovered transactions in the block.
pub fn into_transactions(
self,
) -> Vec<<<B as Block>::Body as BlockBody>::Transaction>
pub fn into_transactions( self, ) -> Vec<<<B as Block>::Body as BlockBody>::Transaction>
Consumes the block and returns the transactions of the block.
§impl<B> RecoveredBlock<B>where
B: Block,
impl<B> RecoveredBlock<B>where
B: Block,
pub const fn senders_mut(&mut self) -> &mut Vec<Address>
pub const fn senders_mut(&mut self) -> &mut Vec<Address>
Returns a mutable reference to the recovered senders.
pub fn push_sender(&mut self, sender: Address)
pub fn push_sender(&mut self, sender: Address)
Appends the sender to the list of senders.
§impl<B> RecoveredBlock<B>where
B: TestBlock,
impl<B> RecoveredBlock<B>where
B: TestBlock,
pub fn set_header(&mut self, header: <B as Block>::Header)
pub fn set_header(&mut self, header: <B as Block>::Header)
Updates the block header.
pub fn set_hash(&mut self, hash: FixedBytes<32>)
pub fn set_hash(&mut self, hash: FixedBytes<32>)
Updates the block hash.
pub const fn header_mut(&mut self) -> &mut <B as Block>::Header
pub const fn header_mut(&mut self) -> &mut <B as Block>::Header
Returns a mutable reference to the header.
pub const fn block_mut(&mut self) -> &mut <B as Block>::Body
pub const fn block_mut(&mut self) -> &mut <B as Block>::Body
Returns a mutable reference to the header.
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
Updates the parent block hash.
pub fn set_block_number(&mut self, number: u64)
pub fn set_block_number(&mut self, number: u64)
Updates the block number.
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
Updates the block state root.
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
Updates the block difficulty.
Methods from Deref<Target = SealedBlock<B>>§
pub fn hash_ref(&self) -> &FixedBytes<32>
pub fn hash_ref(&self) -> &FixedBytes<32>
Returns a reference to the block hash.
pub fn hash(&self) -> FixedBytes<32>
pub fn hash(&self) -> FixedBytes<32>
Returns the block hash.
pub fn clone_block(&self) -> B
pub fn clone_block(&self) -> B
Clones the wrapped block.
pub fn rlp_length(&self) -> usize
pub fn rlp_length(&self) -> usize
Returns the length of the block.
pub fn senders(&self) -> Result<Vec<Address>, RecoveryError>
pub fn senders(&self) -> Result<Vec<Address>, RecoveryError>
Recovers all senders from the transactions in the block.
Returns None if any of the transactions fail to recover the sender.
pub fn num_hash(&self) -> NumHash
pub fn num_hash(&self) -> NumHash
Return the number hash tuple.
pub fn block_with_parent(&self) -> BlockWithParent
pub fn block_with_parent(&self) -> BlockWithParent
Return a [BlockWithParent] for this header.
pub fn sealed_header(&self) -> &SealedHeader<<B as Block>::Header>
pub fn sealed_header(&self) -> &SealedHeader<<B as Block>::Header>
Returns the Sealed header.
pub fn sealed_header_ref(&self) -> SealedHeader<&<B as Block>::Header>
pub fn sealed_header_ref(&self) -> SealedHeader<&<B as Block>::Header>
Returns the wrapped SealedHeader<B::Header> as SealedHeader<&B::Header>.
pub fn clone_sealed_header(&self) -> SealedHeader<<B as Block>::Header>
pub fn clone_sealed_header(&self) -> SealedHeader<<B as Block>::Header>
Clones the wrapped header and returns a SealedHeader sealed with the hash.
pub fn blob_versioned_hashes_iter(
&self,
) -> impl Iterator<Item = &FixedBytes<32>>
pub fn blob_versioned_hashes_iter( &self, ) -> impl Iterator<Item = &FixedBytes<32>>
Returns an iterator over all blob versioned hashes from the block body.
pub fn transaction_count(&self) -> usize
pub fn transaction_count(&self) -> usize
Returns the number of transactions in the block.
pub fn ensure_transaction_root_valid(
&self,
) -> Result<(), GotExpected<FixedBytes<32>>>
pub fn ensure_transaction_root_valid( &self, ) -> Result<(), GotExpected<FixedBytes<32>>>
Ensures that the transaction root in the block header is valid.
The transaction root is the Keccak 256-bit hash of the root node of the trie structure populated with each transaction in the transactions list portion of the block.
§Returns
Returns Ok(()) if the calculated transaction root matches the one stored in the header,
indicating that the transactions in the block are correctly represented in the trie.
Returns Err(error) if the transaction root validation fails, providing a GotExpected
error containing the calculated and expected roots.
pub fn header_mut(&mut self) -> &mut <B as Block>::Header
pub fn header_mut(&mut self) -> &mut <B as Block>::Header
Returns a mutable reference to the header.
pub fn set_hash(&mut self, hash: FixedBytes<32>)
pub fn set_hash(&mut self, hash: FixedBytes<32>)
Updates the block hash.
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
Updates the parent block hash.
pub fn set_block_number(&mut self, number: u64)
pub fn set_block_number(&mut self, number: u64)
Updates the block number.
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
Updates the block state root.
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
Updates the block difficulty.
Trait Implementations§
§impl<'a, B> Arbitrary<'a> for RecoveredBlock<B>where
B: Block + Arbitrary<'a>,
impl<'a, B> Arbitrary<'a> for RecoveredBlock<B>where
B: Block + Arbitrary<'a>,
§fn arbitrary(u: &mut Unstructured<'a>) -> Result<RecoveredBlock<B>, Error>
fn arbitrary(u: &mut Unstructured<'a>) -> Result<RecoveredBlock<B>, Error>
Self from the given unstructured data. Read more§fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
Self from the entirety of the given
unstructured data. Read more§impl<B> BlockHeader for RecoveredBlock<B>where
B: Block,
impl<B> BlockHeader for RecoveredBlock<B>where
B: Block,
§fn parent_hash(&self) -> FixedBytes<32>
fn parent_hash(&self) -> FixedBytes<32>
§fn ommers_hash(&self) -> FixedBytes<32>
fn ommers_hash(&self) -> FixedBytes<32>
§fn beneficiary(&self) -> Address
fn beneficiary(&self) -> Address
§fn state_root(&self) -> FixedBytes<32>
fn state_root(&self) -> FixedBytes<32>
§fn transactions_root(&self) -> FixedBytes<32>
fn transactions_root(&self) -> FixedBytes<32>
§fn receipts_root(&self) -> FixedBytes<32>
fn receipts_root(&self) -> FixedBytes<32>
§fn withdrawals_root(&self) -> Option<FixedBytes<32>>
fn withdrawals_root(&self) -> Option<FixedBytes<32>>
§fn logs_bloom(&self) -> Bloom
fn logs_bloom(&self) -> Bloom
§fn difficulty(&self) -> Uint<256, 4>
fn difficulty(&self) -> Uint<256, 4>
§fn base_fee_per_gas(&self) -> Option<u64>
fn base_fee_per_gas(&self) -> Option<u64>
§fn blob_gas_used(&self) -> Option<u64>
fn blob_gas_used(&self) -> Option<u64>
§fn excess_blob_gas(&self) -> Option<u64>
fn excess_blob_gas(&self) -> Option<u64>
§fn parent_beacon_block_root(&self) -> Option<FixedBytes<32>>
fn parent_beacon_block_root(&self) -> Option<FixedBytes<32>>
§fn requests_hash(&self) -> Option<FixedBytes<32>>
fn requests_hash(&self) -> Option<FixedBytes<32>>
§fn extra_data(&self) -> &Bytes
fn extra_data(&self) -> &Bytes
§fn blob_fee(&self, blob_params: BlobParams) -> Option<u128>
fn blob_fee(&self, blob_params: BlobParams) -> Option<u128>
§fn next_block_excess_blob_gas(&self, blob_params: BlobParams) -> Option<u64>
fn next_block_excess_blob_gas(&self, blob_params: BlobParams) -> Option<u64>
§fn maybe_next_block_excess_blob_gas(
&self,
blob_params: Option<BlobParams>,
) -> Option<u64>
fn maybe_next_block_excess_blob_gas( &self, blob_params: Option<BlobParams>, ) -> Option<u64>
Self::next_block_excess_blob_gas with an optional
[BlobParams] argument. Read more§fn next_block_blob_fee(&self, blob_params: BlobParams) -> Option<u128>
fn next_block_blob_fee(&self, blob_params: BlobParams) -> Option<u128>
§fn maybe_next_block_blob_fee(
&self,
blob_params: Option<BlobParams>,
) -> Option<u128>
fn maybe_next_block_blob_fee( &self, blob_params: Option<BlobParams>, ) -> Option<u128>
Self::next_block_blob_fee with an optional [BlobParams]
argument. Read more§fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
§fn parent_num_hash(&self) -> NumHash
fn parent_num_hash(&self) -> NumHash
§fn is_empty(&self) -> bool
fn is_empty(&self) -> bool
§fn is_zero_difficulty(&self) -> bool
fn is_zero_difficulty(&self) -> bool
§fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool
fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool
§fn is_nonce_zero(&self) -> bool
fn is_nonce_zero(&self) -> bool
§impl<B> Clone for RecoveredBlock<B>
impl<B> Clone for RecoveredBlock<B>
§fn clone(&self) -> RecoveredBlock<B>
fn clone(&self) -> RecoveredBlock<B>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl<B> Debug for RecoveredBlock<B>
impl<B> Debug for RecoveredBlock<B>
§impl<B> Default for RecoveredBlock<B>
impl<B> Default for RecoveredBlock<B>
§fn default() -> RecoveredBlock<B>
fn default() -> RecoveredBlock<B>
§impl<B> Deref for RecoveredBlock<B>where
B: Block,
impl<B> Deref for RecoveredBlock<B>where
B: Block,
§type Target = SealedBlock<B>
type Target = SealedBlock<B>
§fn deref(&self) -> &<RecoveredBlock<B> as Deref>::Target
fn deref(&self) -> &<RecoveredBlock<B> as Deref>::Target
§impl<B> DerefMut for RecoveredBlock<B>where
B: Block,
impl<B> DerefMut for RecoveredBlock<B>where
B: Block,
§fn deref_mut(&mut self) -> &mut <RecoveredBlock<B> as Deref>::Target
fn deref_mut(&mut self) -> &mut <RecoveredBlock<B> as Deref>::Target
§impl<'de, B> Deserialize<'de> for RecoveredBlock<B>
impl<'de, B> Deserialize<'de> for RecoveredBlock<B>
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<RecoveredBlock<B>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<RecoveredBlock<B>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
§impl<'de, T> DeserializeAs<'de, RecoveredBlock<T>> for RecoveredBlock<'de, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
impl<'de, T> DeserializeAs<'de, RecoveredBlock<T>> for RecoveredBlock<'de, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
§fn deserialize_as<D>(
deserializer: D,
) -> Result<RecoveredBlock<T>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize_as<D>(
deserializer: D,
) -> Result<RecoveredBlock<T>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
§impl<'a, T> From<&'a RecoveredBlock<T>> for RecoveredBlock<'a, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
impl<'a, T> From<&'a RecoveredBlock<T>> for RecoveredBlock<'a, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
§fn from(value: &'a RecoveredBlock<T>) -> RecoveredBlock<'a, T>
fn from(value: &'a RecoveredBlock<T>) -> RecoveredBlock<'a, T>
§impl<'a, T> From<RecoveredBlock<'a, T>> for RecoveredBlock<T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
impl<'a, T> From<RecoveredBlock<'a, T>> for RecoveredBlock<T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
§fn from(value: RecoveredBlock<'a, T>) -> RecoveredBlock<T>
fn from(value: RecoveredBlock<'a, T>) -> RecoveredBlock<T>
§impl<B> InMemorySize for RecoveredBlock<B>where
B: Block,
impl<B> InMemorySize for RecoveredBlock<B>where
B: Block,
§impl<B> PartialEq for RecoveredBlock<B>where
B: Block,
impl<B> PartialEq for RecoveredBlock<B>where
B: Block,
§impl<T> SerdeBincodeCompat for RecoveredBlock<T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
impl<T> SerdeBincodeCompat for RecoveredBlock<T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
§type BincodeRepr<'a> = RecoveredBlock<'a, T>
type BincodeRepr<'a> = RecoveredBlock<'a, T>
§fn as_repr(&self) -> <RecoveredBlock<T> as SerdeBincodeCompat>::BincodeRepr<'_>
fn as_repr(&self) -> <RecoveredBlock<T> as SerdeBincodeCompat>::BincodeRepr<'_>
§fn from_repr(
repr: <RecoveredBlock<T> as SerdeBincodeCompat>::BincodeRepr<'_>,
) -> RecoveredBlock<T>
fn from_repr( repr: <RecoveredBlock<T> as SerdeBincodeCompat>::BincodeRepr<'_>, ) -> RecoveredBlock<T>
§impl<B> Serialize for RecoveredBlock<B>
impl<B> Serialize for RecoveredBlock<B>
§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<T> SerializeAs<RecoveredBlock<T>> for RecoveredBlock<'_, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
impl<T> SerializeAs<RecoveredBlock<T>> for RecoveredBlock<'_, T>where
T: Block + 'static,
<T as Block>::Header: SerdeBincodeCompat,
<T as Block>::Body: SerdeBincodeCompat,
§fn serialize_as<S>(
source: &RecoveredBlock<T>,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize_as<S>(
source: &RecoveredBlock<T>,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
impl<B> Eq for RecoveredBlock<B>where
B: Block,
Auto Trait Implementations§
impl<B> !Freeze for RecoveredBlock<B>
impl<B> RefUnwindSafe for RecoveredBlock<B>
impl<B> Send for RecoveredBlock<B>
impl<B> Sync for RecoveredBlock<B>
impl<B> Unpin for RecoveredBlock<B>
impl<B> UnwindSafe for RecoveredBlock<B>
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
key and return true if they are equal.§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<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<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
impl<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
§fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
TxEnv from a transaction and a sender address.§impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
§fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
TxEnv from a transaction, its sender, and encoded transaction bytes.§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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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>
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§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>,
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<A> ArbInterop for A
impl<'de, T> BorrowedRpcObject<'de> for Twhere
T: RpcBorrow<'de> + RpcSend,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> Formattable for T
impl<T> MaybeDebug for Twhere
T: Debug,
impl<T> MaybeSend for Twhere
T: Send,
impl<T> MaybeSend for Twhere
T: Send,
impl<T> MaybeSendSync for T
impl<T> MaybeSerde for Twhere
T: Serialize + for<'de> Deserialize<'de>,
impl<T> MaybeSerdeBincodeCompat for Twhere
T: SerdeBincodeCompat,
impl<T> NippyJarHeader for T
impl<T> Parsable for T
impl<'de, T> RpcBorrow<'de> for T
impl<T> RpcObject for Twhere
T: RpcSend + RpcRecv,
impl<T> RpcRecv for T
impl<T> RpcSend for T
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.