pub struct RecoveredBlock<B: Block> { /* private fields */ }Expand description
A block with senders recovered from the block’s transactions.
This type represents a SealedBlock where all transaction senders have been
recovered and verified. Recovery is an expensive operation that extracts the
sender address from each transaction’s signature.
§Construction
RecoveredBlock::new/RecoveredBlock::new_unhashed- Create with pre-recovered senders (unchecked)RecoveredBlock::try_new/RecoveredBlock::try_new_unhashed- Create with validationRecoveredBlock::try_recover- Recover from a blockRecoveredBlock::try_recover_sealed- Recover from a sealed block
§Performance
Sender recovery is computationally expensive. Cache recovered blocks when possible to avoid repeated recovery operations.
§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 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_sealed 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.
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_sealed 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 num_hash(&self) -> BlockNumHash
pub fn num_hash(&self) -> BlockNumHash
Return the number hash tuple.
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 recovered_transaction(
&self,
idx: usize,
) -> Option<Recovered<&<B::Body as BlockBody>::Transaction>>
pub fn recovered_transaction( &self, idx: usize, ) -> Option<Recovered<&<B::Body as BlockBody>::Transaction>>
Returns the Recovered<&T> transaction at the given index.
Sourcepub fn find_indexed(&self, tx_hash: TxHash) -> Option<IndexedTx<'_, B>>
pub fn find_indexed(&self, tx_hash: TxHash) -> Option<IndexedTx<'_, B>>
Finds a transaction by hash and returns it with its index and block context.
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.
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 an error if any of the transactions fail to recover the sender.
Sourcepub fn num_hash(&self) -> BlockNumHash
pub fn num_hash(&self) -> BlockNumHash
Return the number hash tuple.
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.
Trait Implementations§
Source§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 number(&self) -> BlockNumber
fn number(&self) -> BlockNumber
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 block_access_list_hash(&self) -> Option<B256>
fn block_access_list_hash(&self) -> Option<B256>
Source§fn slot_number(&self) -> Option<u64>
fn slot_number(&self) -> Option<u64>
Source§fn extra_data(&self) -> &Bytes
fn extra_data(&self) -> &Bytes
Source§fn header_info(&self) -> HeaderInfo
fn header_info(&self) -> HeaderInfo
Source§fn header_roots(&self) -> HeaderRoots
fn header_roots(&self) -> HeaderRoots
Source§fn blob_fee(&self, blob_params: BlobParams) -> Option<u128>
fn blob_fee(&self, blob_params: BlobParams) -> Option<u128>
Source§fn next_block_excess_blob_gas(&self, blob_params: BlobParams) -> Option<u64>
fn next_block_excess_blob_gas(&self, blob_params: BlobParams) -> Option<u64>
Source§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 moreSource§fn next_block_blob_fee(&self, blob_params: BlobParams) -> Option<u128>
fn next_block_blob_fee(&self, blob_params: BlobParams) -> Option<u128>
Source§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>
Source§fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
Source§fn parent_num_hash(&self) -> NumHash
fn parent_num_hash(&self) -> NumHash
Source§fn is_empty(&self) -> bool
fn is_empty(&self) -> bool
Source§fn is_zero_difficulty(&self) -> bool
fn is_zero_difficulty(&self) -> bool
Source§fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool
fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool
Source§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<T, H> From<Block<Recovered<T>, H>> for RecoveredBlock<Block<T, H>>where
T: SignedTransaction,
H: BlockHeader,
Converts a block with recovered transactions into a RecoveredBlock.
impl<T, H> From<Block<Recovered<T>, H>> for RecoveredBlock<Block<T, H>>where
T: SignedTransaction,
H: BlockHeader,
Converts a block with recovered transactions into a RecoveredBlock.
This implementation takes an alloy_consensus::Block where transactions are of type
Recovered<T> (transactions with their recovered senders) and converts it into a
RecoveredBlock which stores transactions and senders separately for efficiency.
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>
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> UnsafeUnpin 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,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.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 moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§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 moreSource§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 moreSource§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
Source§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
Source§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.Source§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.Source§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.Source§impl<T> Tap for T
impl<T> Tap for T
Source§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.