pub struct RecoveredBlock<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§
Source§impl<B: Block> RecoveredBlock<B>
impl<B: Block> RecoveredBlock<B>
Sourcepub fn new(block: B, senders: Vec<Address>, hash: BlockHash) -> Self
pub fn new(block: B, senders: Vec<Address>, hash: BlockHash) -> Self
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.
Sourcepub fn new_unhashed(block: B, senders: Vec<Address>) -> Self
pub fn new_unhashed(block: B, senders: Vec<Address>) -> Self
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.
Sourcepub fn senders_iter(&self) -> impl Iterator<Item = &Address>
pub fn senders_iter(&self) -> impl Iterator<Item = &Address>
Returns an iterator over the recovered senders.
Sourcepub fn into_block(self) -> B
pub fn into_block(self) -> B
Consumes the type and returns the inner block.
Sourcepub const fn sealed_block(&self) -> &SealedBlock<B>
pub const fn sealed_block(&self) -> &SealedBlock<B>
Returns a reference to the sealed block.
Sourcepub const fn new_sealed(block: SealedBlock<B>, senders: Vec<Address>) -> Self
pub const fn new_sealed(block: SealedBlock<B>, senders: Vec<Address>) -> Self
Creates a new recovered block instance with the given SealedBlock and senders as
provided
Sourcepub fn try_new(
block: B,
senders: Vec<Address>,
hash: BlockHash,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_new( block: B, senders: Vec<Address>, hash: BlockHash, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn try_new_unchecked(
block: B,
senders: Vec<Address>,
hash: BlockHash,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_new_unchecked( block: B, senders: Vec<Address>, hash: BlockHash, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn try_new_unhashed(
block: B,
senders: Vec<Address>,
) -> Result<Self, RecoveryError>
pub fn try_new_unhashed( block: B, senders: Vec<Address>, ) -> Result<Self, 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.
Sourcepub fn try_new_unhashed_unchecked(
block: B,
senders: Vec<Address>,
) -> Result<Self, RecoveryError>
pub fn try_new_unhashed_unchecked( block: B, senders: Vec<Address>, ) -> Result<Self, 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.
Sourcepub fn try_recover(block: B) -> Result<Self, RecoveryError>
pub fn try_recover(block: B) -> Result<Self, 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.
Sourcepub fn try_recover_unchecked(block: B) -> Result<Self, RecoveryError>
pub fn try_recover_unchecked(block: B) -> Result<Self, 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.
Sourcepub fn try_recover_sealed(
block: SealedBlock<B>,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_recover_sealed( block: SealedBlock<B>, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn try_recover_sealed_unchecked(
block: SealedBlock<B>,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_recover_sealed_unchecked( block: SealedBlock<B>, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn try_recover_sealed_with_senders(
block: SealedBlock<B>,
senders: Vec<Address>,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_recover_sealed_with_senders( block: SealedBlock<B>, senders: Vec<Address>, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn try_recover_sealed_with_senders_unchecked(
block: SealedBlock<B>,
senders: Vec<Address>,
) -> Result<Self, SealedBlockRecoveryError<B>>
pub fn try_recover_sealed_with_senders_unchecked( block: SealedBlock<B>, senders: Vec<Address>, ) -> Result<Self, SealedBlockRecoveryError<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.
Sourcepub fn block_with_parent(&self) -> BlockWithParent
pub fn block_with_parent(&self) -> BlockWithParent
Return a [BlockWithParent] for this header.
Sourcepub fn clone_header(&self) -> B::Header
pub fn clone_header(&self) -> B::Header
Clone the header.
Sourcepub fn clone_sealed_header(&self) -> SealedHeader<B::Header>
pub fn clone_sealed_header(&self) -> SealedHeader<B::Header>
Clones the internal header and returns a SealedHeader sealed with the hash.
Sourcepub 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.
Sourcepub fn into_header(self) -> B::Header
pub fn into_header(self) -> B::Header
Consumes the block and returns the block’s header.
Sourcepub 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.
Sourcepub fn split_sealed(self) -> (SealedBlock<B>, Vec<Address>)
pub fn split_sealed(self) -> (SealedBlock<B>, Vec<Address>)
Consumes the type and returns its components.
Sourcepub fn transactions_with_sender(
&self,
) -> impl Iterator<Item = (&Address, &<B::Body as BlockBody>::Transaction)> + '_
pub fn transactions_with_sender( &self, ) -> impl Iterator<Item = (&Address, &<B::Body as BlockBody>::Transaction)> + '_
Returns an iterator over all transactions and their sender.
Sourcepub fn clone_transactions_recovered(
&self,
) -> impl Iterator<Item = Recovered<<B::Body as BlockBody>::Transaction>> + '_
pub fn clone_transactions_recovered( &self, ) -> impl Iterator<Item = Recovered<<B::Body as BlockBody>::Transaction>> + '_
Returns an iterator over cloned Recovered<Transaction>
Sourcepub fn transactions_recovered(
&self,
) -> impl Iterator<Item = Recovered<&<B::Body as BlockBody>::Transaction>> + '_
pub fn transactions_recovered( &self, ) -> impl Iterator<Item = Recovered<&<B::Body as BlockBody>::Transaction>> + '_
Returns an iterator over Recovered<&Transaction>
Sourcepub fn into_transactions_recovered(
self,
) -> impl Iterator<Item = Recovered<<B::Body as BlockBody>::Transaction>>
pub fn into_transactions_recovered( self, ) -> impl Iterator<Item = Recovered<<B::Body as BlockBody>::Transaction>>
Consumes the type and returns an iterator over all Recovered transactions in the block.
Sourcepub fn into_transactions(self) -> Vec<<B::Body as BlockBody>::Transaction>
pub fn into_transactions(self) -> Vec<<B::Body as BlockBody>::Transaction>
Consumes the block and returns the transactions of the block.
Source§impl<B: Block> RecoveredBlock<B>
impl<B: Block> RecoveredBlock<B>
Sourcepub const fn senders_mut(&mut self) -> &mut Vec<Address>
Available on crate feature test-utils only.
pub const fn senders_mut(&mut self) -> &mut Vec<Address>
test-utils only.Returns a mutable reference to the recovered senders.
Sourcepub fn push_sender(&mut self, sender: Address)
Available on crate feature test-utils only.
pub fn push_sender(&mut self, sender: Address)
test-utils only.Appends the sender to the list of senders.
Source§impl<B: TestBlock> RecoveredBlock<B>
impl<B: TestBlock> RecoveredBlock<B>
Sourcepub fn set_header(&mut self, header: B::Header)
Available on crate feature test-utils only.
pub fn set_header(&mut self, header: B::Header)
test-utils only.Updates the block header.
Sourcepub fn set_hash(&mut self, hash: BlockHash)
Available on crate feature test-utils only.
pub fn set_hash(&mut self, hash: BlockHash)
test-utils only.Updates the block hash.
Sourcepub const fn header_mut(&mut self) -> &mut B::Header
Available on crate feature test-utils only.
pub const fn header_mut(&mut self) -> &mut B::Header
test-utils only.Returns a mutable reference to the header.
Sourcepub const fn block_mut(&mut self) -> &mut B::Body
Available on crate feature test-utils only.
pub const fn block_mut(&mut self) -> &mut B::Body
test-utils only.Returns a mutable reference to the header.
Sourcepub fn set_parent_hash(&mut self, hash: BlockHash)
Available on crate feature test-utils only.
pub fn set_parent_hash(&mut self, hash: BlockHash)
test-utils only.Updates the parent block hash.
Sourcepub fn set_block_number(&mut self, number: BlockNumber)
Available on crate feature test-utils only.
pub fn set_block_number(&mut self, number: BlockNumber)
test-utils only.Updates the block number.
Sourcepub fn set_state_root(&mut self, state_root: B256)
Available on crate feature test-utils only.
pub fn set_state_root(&mut self, state_root: B256)
test-utils only.Updates the block state root.
Sourcepub fn set_difficulty(&mut self, difficulty: U256)
Available on crate feature test-utils only.
pub fn set_difficulty(&mut self, difficulty: U256)
test-utils only.Updates the block difficulty.
Methods from Deref<Target = SealedBlock<B>>§
Sourcepub fn clone_block(&self) -> B
pub fn clone_block(&self) -> B
Clones the wrapped block.
Sourcepub fn rlp_length(&self) -> usize
pub fn rlp_length(&self) -> usize
Returns the length of the block.
Sourcepub 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.
Sourcepub fn block_with_parent(&self) -> BlockWithParent
pub fn block_with_parent(&self) -> BlockWithParent
Return a [BlockWithParent] for this header.
Sourcepub fn sealed_header(&self) -> &SealedHeader<B::Header>
pub fn sealed_header(&self) -> &SealedHeader<B::Header>
Returns the Sealed header.
Sourcepub fn sealed_header_ref(&self) -> SealedHeader<&B::Header>
pub fn sealed_header_ref(&self) -> SealedHeader<&B::Header>
Returns the wrapped SealedHeader<B::Header> as SealedHeader<&B::Header>.
Sourcepub fn clone_sealed_header(&self) -> SealedHeader<B::Header>
pub fn clone_sealed_header(&self) -> SealedHeader<B::Header>
Clones the wrapped header and returns a SealedHeader sealed with the hash.
Sourcepub fn blob_versioned_hashes_iter(&self) -> impl Iterator<Item = &B256> + '_
pub fn blob_versioned_hashes_iter(&self) -> impl Iterator<Item = &B256> + '_
Returns an iterator over all blob versioned hashes from the block body.
Sourcepub fn transaction_count(&self) -> usize
pub fn transaction_count(&self) -> usize
Returns the number of transactions in the block.
Sourcepub fn ensure_transaction_root_valid(&self) -> Result<(), GotExpected<B256>>
pub fn ensure_transaction_root_valid(&self) -> Result<(), GotExpected<B256>>
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.
Sourcepub fn header_mut(&mut self) -> &mut B::Header
Available on crate feature test-utils only.
pub fn header_mut(&mut self) -> &mut B::Header
test-utils only.Returns a mutable reference to the header.
Sourcepub fn set_hash(&mut self, hash: BlockHash)
Available on crate feature test-utils only.
pub fn set_hash(&mut self, hash: BlockHash)
test-utils only.Updates the block hash.
Sourcepub fn body_mut(&mut self) -> &mut B::Body
Available on crate feature test-utils only.
pub fn body_mut(&mut self) -> &mut B::Body
test-utils only.Returns a mutable reference to the header.
Sourcepub fn set_parent_hash(&mut self, hash: BlockHash)
Available on crate feature test-utils only.
pub fn set_parent_hash(&mut self, hash: BlockHash)
test-utils only.Updates the parent block hash.
Sourcepub fn set_block_number(&mut self, number: BlockNumber)
Available on crate feature test-utils only.
pub fn set_block_number(&mut self, number: BlockNumber)
test-utils only.Updates the block number.
Sourcepub fn set_state_root(&mut self, state_root: B256)
Available on crate feature test-utils only.
pub fn set_state_root(&mut self, state_root: B256)
test-utils only.Updates the block state root.
Sourcepub fn set_difficulty(&mut self, difficulty: U256)
Available on crate feature test-utils only.
pub fn set_difficulty(&mut self, difficulty: U256)
test-utils only.Updates the block difficulty.
Trait Implementations§
Source§impl<'a, B> Arbitrary<'a> for RecoveredBlock<B>where
B: Block + Arbitrary<'a>,
Available on crate feature arbitrary only.
impl<'a, B> Arbitrary<'a> for RecoveredBlock<B>where
B: Block + Arbitrary<'a>,
arbitrary only.Source§fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self>
fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self>
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 moreSource§impl<B: Block> BlockHeader for RecoveredBlock<B>
impl<B: Block> BlockHeader for RecoveredBlock<B>
Source§fn parent_hash(&self) -> B256
fn parent_hash(&self) -> B256
Source§fn ommers_hash(&self) -> B256
fn ommers_hash(&self) -> B256
Source§fn beneficiary(&self) -> Address
fn beneficiary(&self) -> Address
Source§fn state_root(&self) -> B256
fn state_root(&self) -> B256
Source§fn transactions_root(&self) -> B256
fn transactions_root(&self) -> B256
Source§fn receipts_root(&self) -> B256
fn receipts_root(&self) -> B256
Source§fn withdrawals_root(&self) -> Option<B256>
fn withdrawals_root(&self) -> Option<B256>
Source§fn logs_bloom(&self) -> Bloom
fn logs_bloom(&self) -> Bloom
Source§fn difficulty(&self) -> U256
fn difficulty(&self) -> U256
Source§fn base_fee_per_gas(&self) -> Option<u64>
fn base_fee_per_gas(&self) -> Option<u64>
Source§fn blob_gas_used(&self) -> Option<u64>
fn blob_gas_used(&self) -> Option<u64>
Source§fn excess_blob_gas(&self) -> Option<u64>
fn excess_blob_gas(&self) -> Option<u64>
Source§fn parent_beacon_block_root(&self) -> Option<B256>
fn parent_beacon_block_root(&self) -> Option<B256>
Source§fn requests_hash(&self) -> Option<B256>
fn requests_hash(&self) -> Option<B256>
Source§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
Source§impl<B: Clone + Block> Clone for RecoveredBlock<B>
impl<B: Clone + Block> Clone for RecoveredBlock<B>
Source§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 moreSource§impl<B: Block> Deref for RecoveredBlock<B>
impl<B: Block> Deref for RecoveredBlock<B>
Source§impl<B> DerefMut for RecoveredBlock<B>where
B: Block,
Available on crate feature test-utils only.
impl<B> DerefMut for RecoveredBlock<B>where
B: Block,
test-utils only.Source§impl<'de, B: Block> Deserialize<'de> for RecoveredBlock<B>
impl<'de, B: Block> Deserialize<'de> for RecoveredBlock<B>
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl<'de, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> DeserializeAs<'de, RecoveredBlock<T>> for RecoveredBlock<'de, T>
Available on crate feature serde-bincode-compat only.
impl<'de, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> DeserializeAs<'de, RecoveredBlock<T>> for RecoveredBlock<'de, T>
serde-bincode-compat only.Source§fn deserialize_as<D>(deserializer: D) -> Result<RecoveredBlock<T>, D::Error>where
D: Deserializer<'de>,
fn deserialize_as<D>(deserializer: D) -> Result<RecoveredBlock<T>, D::Error>where
D: Deserializer<'de>,
Source§impl<'a, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> From<&'a RecoveredBlock<T>> for RecoveredBlock<'a, T>
Available on crate feature serde-bincode-compat only.
impl<'a, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> From<&'a RecoveredBlock<T>> for RecoveredBlock<'a, T>
serde-bincode-compat only.Source§fn from(value: &'a RecoveredBlock<T>) -> Self
fn from(value: &'a RecoveredBlock<T>) -> Self
Source§impl<'a, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> From<RecoveredBlock<'a, T>> for RecoveredBlock<T>
Available on crate feature serde-bincode-compat only.
impl<'a, T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> From<RecoveredBlock<'a, T>> for RecoveredBlock<T>
serde-bincode-compat only.Source§fn from(value: RecoveredBlock<'a, T>) -> Self
fn from(value: RecoveredBlock<'a, T>) -> Self
Source§impl<B: Block> From<RecoveredBlock<B>> for Sealed<B>
impl<B: Block> From<RecoveredBlock<B>> for Sealed<B>
Source§fn from(value: RecoveredBlock<B>) -> Self
fn from(value: RecoveredBlock<B>) -> Self
Source§impl<B: Block> InMemorySize for RecoveredBlock<B>
impl<B: Block> InMemorySize for RecoveredBlock<B>
Source§impl<B: Block> PartialEq for RecoveredBlock<B>
impl<B: Block> PartialEq for RecoveredBlock<B>
Source§impl<T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> SerdeBincodeCompat for RecoveredBlock<T>
Available on crate feature serde-bincode-compat only.
impl<T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> SerdeBincodeCompat for RecoveredBlock<T>
serde-bincode-compat only.Source§type BincodeRepr<'a> = RecoveredBlock<'a, T>
type BincodeRepr<'a> = RecoveredBlock<'a, T>
Source§fn as_repr(&self) -> Self::BincodeRepr<'_>
fn as_repr(&self) -> Self::BincodeRepr<'_>
Source§fn from_repr(repr: Self::BincodeRepr<'_>) -> Self
fn from_repr(repr: Self::BincodeRepr<'_>) -> Self
Source§impl<B: Block> Serialize for RecoveredBlock<B>
impl<B: Block> Serialize for RecoveredBlock<B>
Source§impl<T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> SerializeAs<RecoveredBlock<T>> for RecoveredBlock<'_, T>
Available on crate feature serde-bincode-compat only.
impl<T: Block<Header: SerdeBincodeCompat, Body: SerdeBincodeCompat> + 'static> SerializeAs<RecoveredBlock<T>> for RecoveredBlock<'_, T>
serde-bincode-compat only.Source§fn serialize_as<S>(
source: &RecoveredBlock<T>,
serializer: S,
) -> Result<S::Ok, S::Error>where
S: Serializer,
fn serialize_as<S>(
source: &RecoveredBlock<T>,
serializer: S,
) -> Result<S::Ok, S::Error>where
S: Serializer,
impl<B: Block> Eq for RecoveredBlock<B>
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<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<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> MaybeSend for Twhere
T: Send,
impl<T> MaybeSerde for Twhere
T: Serialize + for<'de> Deserialize<'de>,
impl<T> MaybeSerdeBincodeCompat for Twhere
T: SerdeBincodeCompat,
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.