pub struct RequestResponseProtocol<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> {
inner: RequestResponse<Sender, Receiver<Bytes>, Request, RecipientSource<I, V>, DataSource<I, V, N, P>, PubKey>,
config: RequestResponseConfig,
public_key: PubKey,
private_key: BLSPrivKey,
}
Expand description
A concrete type wrapper around RequestResponse
. We need this so that we can implement
local traits like StateCatchup
. It also helps with readability.
Fields§
§inner: RequestResponse<Sender, Receiver<Bytes>, Request, RecipientSource<I, V>, DataSource<I, V, N, P>, PubKey>
The actual inner request response protocol
config: RequestResponseConfig
The configuration we used for the above inner protocol. This is nice to have for estimating when we should make another request
public_key: PubKey
The public key of this node
private_key: BLSPrivKey
The private key of this node
Implementations§
Source§impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> RequestResponseProtocol<I, V, N, P>
impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> RequestResponseProtocol<I, V, N, P>
Sourcepub fn new(
config: RequestResponseConfig,
sender: Sender,
receiver: Receiver<Bytes>,
recipient_source: RecipientSource<I, V>,
data_source: DataSource<I, V, N, P>,
public_key: PubKey,
private_key: BLSPrivKey,
) -> Self
pub fn new( config: RequestResponseConfig, sender: Sender, receiver: Receiver<Bytes>, recipient_source: RecipientSource<I, V>, data_source: DataSource<I, V, N, P>, public_key: PubKey, private_key: BLSPrivKey, ) -> Self
Create a new RequestResponseProtocol from the inner
Source§impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> RequestResponseProtocol<I, V, N, P>
impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> RequestResponseProtocol<I, V, N, P>
pub async fn request_indefinitely<F, Fut, O>( &self, request: Request, request_type: RequestType, response_validation_fn: F, ) -> Result<O, RequestError>
Trait Implementations§
Source§impl<I: Clone + NodeImplementation<SeqTypes>, V: Clone + Versions, N: Clone + ConnectedNetwork<PubKey>, P: Clone + SequencerPersistence> Clone for RequestResponseProtocol<I, V, N, P>
impl<I: Clone + NodeImplementation<SeqTypes>, V: Clone + Versions, N: Clone + ConnectedNetwork<PubKey>, P: Clone + SequencerPersistence> Clone for RequestResponseProtocol<I, V, N, P>
Source§fn clone(&self) -> RequestResponseProtocol<I, V, N, P>
fn clone(&self) -> RequestResponseProtocol<I, V, N, P>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> Deref for RequestResponseProtocol<I, V, N, P>
impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> Deref for RequestResponseProtocol<I, V, N, P>
Source§type Target = RequestResponse<Sender, Receiver<Arc<Vec<u8>>>, Request, RecipientSource<I, V>, DataSource<I, V, N, P>, VerKey>
type Target = RequestResponse<Sender, Receiver<Arc<Vec<u8>>>, Request, RecipientSource<I, V>, DataSource<I, V, N, P>, VerKey>
The resulting type after dereferencing.
Source§impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> StateCatchup for RequestResponseProtocol<I, V, N, P>
impl<I: NodeImplementation<SeqTypes>, V: Versions, N: ConnectedNetwork<PubKey>, P: SequencerPersistence> StateCatchup for RequestResponseProtocol<I, V, N, P>
Source§fn try_fetch_leaf<'life0, 'async_trait>(
&'life0 self,
_retry: usize,
height: u64,
stake_table: HSStakeTable<SeqTypes>,
success_threshold: U256,
) -> Pin<Box<dyn Future<Output = Result<Leaf2>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn try_fetch_leaf<'life0, 'async_trait>(
&'life0 self,
_retry: usize,
height: u64,
stake_table: HSStakeTable<SeqTypes>,
success_threshold: U256,
) -> Pin<Box<dyn Future<Output = Result<Leaf2>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Fetch the leaf at the given height without retrying on transient errors.
Source§fn try_fetch_accounts<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
fee_merkle_tree_root: FeeMerkleCommitment,
accounts: &'life2 [FeeAccount],
) -> Pin<Box<dyn Future<Output = Result<Vec<FeeAccountProof>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn try_fetch_accounts<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
fee_merkle_tree_root: FeeMerkleCommitment,
accounts: &'life2 [FeeAccount],
) -> Pin<Box<dyn Future<Output = Result<Vec<FeeAccountProof>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Fetch the given list of accounts without retrying on transient errors.
Source§fn try_remember_blocks_merkle_tree<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
mt: &'life2 mut BlockMerkleTree,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn try_remember_blocks_merkle_tree<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
mt: &'life2 mut BlockMerkleTree,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Fetch and remember the blocks frontier without retrying on transient errors.
Source§fn try_fetch_chain_config<'life0, 'async_trait>(
&'life0 self,
_retry: usize,
commitment: Commitment<ChainConfig>,
) -> Pin<Box<dyn Future<Output = Result<ChainConfig>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn try_fetch_chain_config<'life0, 'async_trait>(
&'life0 self,
_retry: usize,
commitment: Commitment<ChainConfig>,
) -> Pin<Box<dyn Future<Output = Result<ChainConfig>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Fetch the chain config without retrying on transient errors.
Source§fn try_fetch_reward_accounts_v2<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV2,
accounts: &'life2 [RewardAccountV2],
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV2>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn try_fetch_reward_accounts_v2<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV2,
accounts: &'life2 [RewardAccountV2],
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV2>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Fetch the given list of reward accounts without retrying on transient errors.
Source§fn try_fetch_reward_accounts_v1<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV1,
accounts: &'life2 [RewardAccountV1],
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV1>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn try_fetch_reward_accounts_v1<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_retry: usize,
instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV1,
accounts: &'life2 [RewardAccountV1],
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV1>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Fetch the given list of reward accounts without retrying on transient errors.
Source§fn backoff(&self) -> &BackoffParams
fn backoff(&self) -> &BackoffParams
Returns the backoff parameters for the catchup provider.
Source§fn fetch_accounts<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
fee_merkle_tree_root: FeeMerkleCommitment,
accounts: Vec<FeeAccount>,
) -> Pin<Box<dyn Future<Output = Result<Vec<FeeAccountProof>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn fetch_accounts<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
fee_merkle_tree_root: FeeMerkleCommitment,
accounts: Vec<FeeAccount>,
) -> Pin<Box<dyn Future<Output = Result<Vec<FeeAccountProof>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Fetch the given list of accounts, retrying on transient errors.
Source§fn fetch_leaf<'life0, 'async_trait>(
&'life0 self,
height: u64,
stake_table: HSStakeTable<SeqTypes>,
success_threshold: U256,
) -> Pin<Box<dyn Future<Output = Result<Leaf2>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn fetch_leaf<'life0, 'async_trait>(
&'life0 self,
height: u64,
stake_table: HSStakeTable<SeqTypes>,
success_threshold: U256,
) -> Pin<Box<dyn Future<Output = Result<Leaf2>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Fetch the leaf at the given height, retrying on transient errors.
Source§fn fetch_chain_config<'life0, 'async_trait>(
&'life0 self,
commitment: Commitment<ChainConfig>,
) -> Pin<Box<dyn Future<Output = Result<ChainConfig>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn fetch_chain_config<'life0, 'async_trait>(
&'life0 self,
commitment: Commitment<ChainConfig>,
) -> Pin<Box<dyn Future<Output = Result<ChainConfig>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Fetch the chain config, retrying on transient errors.
Source§fn remember_blocks_merkle_tree<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
mt: &'life2 mut BlockMerkleTree,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn remember_blocks_merkle_tree<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
mt: &'life2 mut BlockMerkleTree,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Fetch and remember the blocks frontier, retrying on transient errors.
Source§fn fetch_reward_accounts_v2<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV2,
accounts: Vec<RewardAccountV2>,
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV2>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn fetch_reward_accounts_v2<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV2,
accounts: Vec<RewardAccountV2>,
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV2>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Fetch the given list of reward accounts, retrying on transient errors.
Source§fn fetch_reward_accounts_v1<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV1,
accounts: Vec<RewardAccountV1>,
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV1>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn fetch_reward_accounts_v1<'life0, 'life1, 'async_trait>(
&'life0 self,
_instance: &'life1 NodeState,
height: u64,
view: ViewNumber,
reward_merkle_tree_root: RewardMerkleCommitmentV1,
accounts: Vec<RewardAccountV1>,
) -> Pin<Box<dyn Future<Output = Result<Vec<RewardAccountProofV1>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Fetch the given list of reward accounts, retrying on transient errors.
Auto Trait Implementations§
impl<I, V, N, P> Freeze for RequestResponseProtocol<I, V, N, P>
impl<I, V, N, P> !RefUnwindSafe for RequestResponseProtocol<I, V, N, P>
impl<I, V, N, P> Send for RequestResponseProtocol<I, V, N, P>
impl<I, V, N, P> Sync for RequestResponseProtocol<I, V, N, P>
impl<I, V, N, P> Unpin for RequestResponseProtocol<I, V, N, P>
impl<I, V, N, P> !UnwindSafe for RequestResponseProtocol<I, V, N, P>
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
Mutably borrows from an owned value. Read more
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<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
§fn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
Deserializes using the given deserializer
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Formats each item in a sequence. Read more
§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>
Converts
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>
Converts
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> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Gets the layout of the type.
§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,
Pipes by value. This is generally the method you want to use. Read more
§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,
Borrows
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,
Mutably borrows
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
Borrows
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
Mutably borrows
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
Borrows
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§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
Immutable access to the
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
Mutable access to the
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
Immutable access to the
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
Mutable access to the
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
Immutable access to the
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
Mutable access to the
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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.tap_deref()
only in debug builds, and is erased in release
builds.