pub struct HoprChannels<M>(/* private fields */);
Implementations§
Source§impl<M: Middleware> HoprChannels<M>
impl<M: Middleware> HoprChannels<M>
Sourcepub fn new<T: Into<Address>>(address: T, client: Arc<M>) -> Self
pub fn new<T: Into<Address>>(address: T, client: Arc<M>) -> Self
Creates a new contract instance with the specified ethers
client at
address
. The contract derefs to a ethers::Contract
object.
Sourcepub fn deploy<T: Tokenize>(
client: Arc<M>,
constructor_args: T,
) -> Result<ContractDeployer<M, Self>, ContractError<M>>
pub fn deploy<T: Tokenize>( client: Arc<M>, constructor_args: T, ) -> Result<ContractDeployer<M, Self>, ContractError<M>>
Constructs the general purpose Deployer
instance based on the provided constructor arguments and sends it.
Returns a new instance of a deployer that returns an instance of this contract after sending the transaction
Notes:
- If there are no constructor arguments, you should pass
()
as the argument. - The default poll duration is 7 seconds.
- The default number of confirmations is 1 block.
§Example
Generate contract bindings with abigen!
and deploy a new contract instance.
Note: this requires a bytecode
and abi
object in the greeter.json
artifact.
abigen!(Greeter, "../greeter.json");
let greeter_contract = Greeter::deploy(client, "Hello world!".to_string()).unwrap().send().await.unwrap();
let msg = greeter_contract.greet().call().await.unwrap();
Sourcepub fn erc777_hook_fund_channel_multi_size(&self) -> ContractCall<M, U256>
pub fn erc777_hook_fund_channel_multi_size(&self) -> ContractCall<M, U256>
Calls the contract’s ERC777_HOOK_FUND_CHANNEL_MULTI_SIZE
(0x78d8016d) function
Sourcepub fn erc777_hook_fund_channel_size(&self) -> ContractCall<M, U256>
pub fn erc777_hook_fund_channel_size(&self) -> ContractCall<M, U256>
Calls the contract’s ERC777_HOOK_FUND_CHANNEL_SIZE
(0x44dae6f8) function
Sourcepub fn ledger_version(&self) -> ContractCall<M, String>
pub fn ledger_version(&self) -> ContractCall<M, String>
Calls the contract’s LEDGER_VERSION
(0xddad1902) function
Sourcepub fn max_used_balance(&self) -> ContractCall<M, u128>
pub fn max_used_balance(&self) -> ContractCall<M, u128>
Calls the contract’s MAX_USED_BALANCE
(0x5d2f07c5) function
Sourcepub fn min_used_balance(&self) -> ContractCall<M, u128>
pub fn min_used_balance(&self) -> ContractCall<M, u128>
Calls the contract’s MIN_USED_BALANCE
(0x29392e32) function
Sourcepub fn tokens_recipient_interface_hash(&self) -> ContractCall<M, [u8; 32]>
pub fn tokens_recipient_interface_hash(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s TOKENS_RECIPIENT_INTERFACE_HASH
(0x72581cc0) function
Sourcepub fn version(&self) -> ContractCall<M, String>
pub fn version(&self) -> ContractCall<M, String>
Calls the contract’s VERSION
(0xffa1ad74) function
Sourcepub fn current_block_timestamp(&self) -> ContractCall<M, u32>
pub fn current_block_timestamp(&self) -> ContractCall<M, u32>
Calls the contract’s _currentBlockTimestamp
(0xb920deed) function
Sourcepub fn get_channel_id(
&self,
source: Address,
destination: Address,
) -> ContractCall<M, [u8; 32]>
pub fn get_channel_id( &self, source: Address, destination: Address, ) -> ContractCall<M, [u8; 32]>
Calls the contract’s _getChannelId
(0xbe9babdc) function
Sourcepub fn get_ticket_hash(
&self,
redeemable: RedeemableTicket,
) -> ContractCall<M, [u8; 32]>
pub fn get_ticket_hash( &self, redeemable: RedeemableTicket, ) -> ContractCall<M, [u8; 32]>
Calls the contract’s _getTicketHash
(0x24086cc2) function
Sourcepub fn is_winning_ticket(
&self,
ticket_hash: [u8; 32],
redeemable: RedeemableTicket,
params: Vrfparameters,
) -> ContractCall<M, bool>
pub fn is_winning_ticket( &self, ticket_hash: [u8; 32], redeemable: RedeemableTicket, params: Vrfparameters, ) -> ContractCall<M, bool>
Calls the contract’s _isWinningTicket
(0x8c3710c9) function
Sourcepub fn can_implement_interface_for_address(
&self,
interface_hash: [u8; 32],
account: Address,
) -> ContractCall<M, [u8; 32]>
pub fn can_implement_interface_for_address( &self, interface_hash: [u8; 32], account: Address, ) -> ContractCall<M, [u8; 32]>
Calls the contract’s canImplementInterfaceForAddress
(0x249cb3fa) function
Sourcepub fn channels(
&self,
p0: [u8; 32],
) -> ContractCall<M, (u128, u64, u32, u32, u8)>
pub fn channels( &self, p0: [u8; 32], ) -> ContractCall<M, (u128, u64, u32, u32, u8)>
Calls the contract’s channels
(0x7a7ebd7b) function
Sourcepub fn close_incoming_channel(&self, source: Address) -> ContractCall<M, ()>
pub fn close_incoming_channel(&self, source: Address) -> ContractCall<M, ()>
Calls the contract’s closeIncomingChannel
(0x1a7ffe7a) function
Sourcepub fn close_incoming_channel_safe(
&self,
self_: Address,
source: Address,
) -> ContractCall<M, ()>
pub fn close_incoming_channel_safe( &self, self_: Address, source: Address, ) -> ContractCall<M, ()>
Calls the contract’s closeIncomingChannelSafe
(0x54a2edf5) function
Sourcepub fn domain_separator(&self) -> ContractCall<M, [u8; 32]>
pub fn domain_separator(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s domainSeparator
(0xf698da25) function
Sourcepub fn finalize_outgoing_channel_closure(
&self,
destination: Address,
) -> ContractCall<M, ()>
pub fn finalize_outgoing_channel_closure( &self, destination: Address, ) -> ContractCall<M, ()>
Calls the contract’s finalizeOutgoingChannelClosure
(0x23cb3ac0) function
Sourcepub fn finalize_outgoing_channel_closure_safe(
&self,
self_: Address,
destination: Address,
) -> ContractCall<M, ()>
pub fn finalize_outgoing_channel_closure_safe( &self, self_: Address, destination: Address, ) -> ContractCall<M, ()>
Calls the contract’s finalizeOutgoingChannelClosureSafe
(0x651514bf) function
Sourcepub fn fund_channel(
&self,
account: Address,
amount: u128,
) -> ContractCall<M, ()>
pub fn fund_channel( &self, account: Address, amount: u128, ) -> ContractCall<M, ()>
Calls the contract’s fundChannel
(0xfc55309a) function
Sourcepub fn fund_channel_safe(
&self,
self_: Address,
account: Address,
amount: u128,
) -> ContractCall<M, ()>
pub fn fund_channel_safe( &self, self_: Address, account: Address, amount: u128, ) -> ContractCall<M, ()>
Calls the contract’s fundChannelSafe
(0x0abec58f) function
Sourcepub fn initiate_outgoing_channel_closure(
&self,
destination: Address,
) -> ContractCall<M, ()>
pub fn initiate_outgoing_channel_closure( &self, destination: Address, ) -> ContractCall<M, ()>
Calls the contract’s initiateOutgoingChannelClosure
(0x7c8e28da) function
Sourcepub fn initiate_outgoing_channel_closure_safe(
&self,
self_: Address,
destination: Address,
) -> ContractCall<M, ()>
pub fn initiate_outgoing_channel_closure_safe( &self, self_: Address, destination: Address, ) -> ContractCall<M, ()>
Calls the contract’s initiateOutgoingChannelClosureSafe
(0xbda65f45) function
Sourcepub fn ledger_domain_separator(&self) -> ContractCall<M, [u8; 32]>
pub fn ledger_domain_separator(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s ledgerDomainSeparator
(0xc966c4fe) function
Sourcepub fn multicall(&self, data: Vec<Bytes>) -> ContractCall<M, Vec<Bytes>>
pub fn multicall(&self, data: Vec<Bytes>) -> ContractCall<M, Vec<Bytes>>
Calls the contract’s multicall
(0xac9650d8) function
Sourcepub fn notice_period_channel_closure(&self) -> ContractCall<M, u32>
pub fn notice_period_channel_closure(&self) -> ContractCall<M, u32>
Calls the contract’s noticePeriodChannelClosure
(0x87352d65) function
Sourcepub fn redeem_ticket(
&self,
redeemable: RedeemableTicket,
params: Vrfparameters,
) -> ContractCall<M, ()>
pub fn redeem_ticket( &self, redeemable: RedeemableTicket, params: Vrfparameters, ) -> ContractCall<M, ()>
Calls the contract’s redeemTicket
(0xfcb7796f) function
Sourcepub fn redeem_ticket_safe(
&self,
self_: Address,
redeemable: RedeemableTicket,
params: Vrfparameters,
) -> ContractCall<M, ()>
pub fn redeem_ticket_safe( &self, self_: Address, redeemable: RedeemableTicket, params: Vrfparameters, ) -> ContractCall<M, ()>
Calls the contract’s redeemTicketSafe
(0x0cd88d72) function
Sourcepub fn token(&self) -> ContractCall<M, Address>
pub fn token(&self) -> ContractCall<M, Address>
Calls the contract’s token
(0xfc0c546a) function
Sourcepub fn tokens_received(
&self,
p0: Address,
from: Address,
to: Address,
amount: U256,
user_data: Bytes,
p5: Bytes,
) -> ContractCall<M, ()>
pub fn tokens_received( &self, p0: Address, from: Address, to: Address, amount: U256, user_data: Bytes, p5: Bytes, ) -> ContractCall<M, ()>
Calls the contract’s tokensReceived
(0x0023de29) function
Sourcepub fn update_domain_separator(&self) -> ContractCall<M, ()>
pub fn update_domain_separator(&self) -> ContractCall<M, ()>
Calls the contract’s updateDomainSeparator
(0x89ccfe89) function
Sourcepub fn update_ledger_domain_separator(&self) -> ContractCall<M, ()>
pub fn update_ledger_domain_separator(&self) -> ContractCall<M, ()>
Calls the contract’s updateLedgerDomainSeparator
(0xdc96fd50) function
Sourcepub fn channel_balance_decreased_filter(
&self,
) -> Event<Arc<M>, M, ChannelBalanceDecreasedFilter>
pub fn channel_balance_decreased_filter( &self, ) -> Event<Arc<M>, M, ChannelBalanceDecreasedFilter>
Gets the contract’s ChannelBalanceDecreased
event
Sourcepub fn channel_balance_increased_filter(
&self,
) -> Event<Arc<M>, M, ChannelBalanceIncreasedFilter>
pub fn channel_balance_increased_filter( &self, ) -> Event<Arc<M>, M, ChannelBalanceIncreasedFilter>
Gets the contract’s ChannelBalanceIncreased
event
Sourcepub fn channel_closed_filter(&self) -> Event<Arc<M>, M, ChannelClosedFilter>
pub fn channel_closed_filter(&self) -> Event<Arc<M>, M, ChannelClosedFilter>
Gets the contract’s ChannelClosed
event
Sourcepub fn channel_opened_filter(&self) -> Event<Arc<M>, M, ChannelOpenedFilter>
pub fn channel_opened_filter(&self) -> Event<Arc<M>, M, ChannelOpenedFilter>
Gets the contract’s ChannelOpened
event
Sourcepub fn domain_separator_updated_filter(
&self,
) -> Event<Arc<M>, M, DomainSeparatorUpdatedFilter>
pub fn domain_separator_updated_filter( &self, ) -> Event<Arc<M>, M, DomainSeparatorUpdatedFilter>
Gets the contract’s DomainSeparatorUpdated
event
Sourcepub fn ledger_domain_separator_updated_filter(
&self,
) -> Event<Arc<M>, M, LedgerDomainSeparatorUpdatedFilter>
pub fn ledger_domain_separator_updated_filter( &self, ) -> Event<Arc<M>, M, LedgerDomainSeparatorUpdatedFilter>
Gets the contract’s LedgerDomainSeparatorUpdated
event
Sourcepub fn outgoing_channel_closure_initiated_filter(
&self,
) -> Event<Arc<M>, M, OutgoingChannelClosureInitiatedFilter>
pub fn outgoing_channel_closure_initiated_filter( &self, ) -> Event<Arc<M>, M, OutgoingChannelClosureInitiatedFilter>
Gets the contract’s OutgoingChannelClosureInitiated
event
Sourcepub fn ticket_redeemed_filter(&self) -> Event<Arc<M>, M, TicketRedeemedFilter>
pub fn ticket_redeemed_filter(&self) -> Event<Arc<M>, M, TicketRedeemedFilter>
Gets the contract’s TicketRedeemed
event
Sourcepub fn events(&self) -> Event<Arc<M>, M, HoprChannelsEvents>
pub fn events(&self) -> Event<Arc<M>, M, HoprChannelsEvents>
Returns an Event
builder for all the events of this contract.
Methods from Deref<Target = Contract<M>>§
pub fn address(&self) -> H160
pub fn address(&self) -> H160
Returns the contract’s address
pub fn abi(&self) -> &Contract
pub fn abi(&self) -> &Contract
Returns a reference to the contract’s ABI.
pub fn client_ref(&self) -> &M
pub fn client_ref(&self) -> &M
Returns a reference to the contract’s client.
pub fn connect<N>(&self, client: Arc<N>) -> ContractInstance<Arc<N>, N>where
N: Middleware,
pub fn connect<N>(&self, client: Arc<N>) -> ContractInstance<Arc<N>, N>where
N: Middleware,
Returns a new contract instance using the provided client
Clones self
internally
pub fn connect_with<C, N>(&self, client: C) -> ContractInstance<C, N>where
C: Borrow<N>,
pub fn connect_with<C, N>(&self, client: C) -> ContractInstance<C, N>where
C: Borrow<N>,
Returns a new contract instance using the provided client
Clones self
internally
pub fn event_with_filter<D>(&self, filter: Filter) -> Event<B, M, D>
pub fn event_with_filter<D>(&self, filter: Filter) -> Event<B, M, D>
Returns an [Event
] builder with the provided filter.
pub fn event<D>(&self) -> Event<B, M, D>where
D: EthEvent,
pub fn event<D>(&self) -> Event<B, M, D>where
D: EthEvent,
Returns an [Event
] builder for the provided event.
pub fn event_for_name<D>(&self, name: &str) -> Result<Event<B, M, D>, Error>
pub fn event_for_name<D>(&self, name: &str) -> Result<Event<B, M, D>, Error>
Returns an [Event
] builder with the provided name.
pub fn method_hash<T, D>(
&self,
signature: [u8; 4],
args: T,
) -> Result<FunctionCall<B, M, D>, AbiError>where
T: Tokenize,
D: Detokenize,
pub fn method_hash<T, D>(
&self,
signature: [u8; 4],
args: T,
) -> Result<FunctionCall<B, M, D>, AbiError>where
T: Tokenize,
D: Detokenize,
Returns a transaction builder for the selected function signature. This should be preferred if there are overloaded functions in your smart contract
pub fn method<T, D>(
&self,
name: &str,
args: T,
) -> Result<FunctionCall<B, M, D>, AbiError>where
T: Tokenize,
D: Detokenize,
pub fn method<T, D>(
&self,
name: &str,
args: T,
) -> Result<FunctionCall<B, M, D>, AbiError>where
T: Tokenize,
D: Detokenize,
Returns a transaction builder for the provided function name. If there are
multiple functions with the same name due to overloading, consider using
the method_hash
method instead, since this will use the first match.
Methods from Deref<Target = BaseContract>§
pub fn encode<T>(&self, name: &str, args: T) -> Result<Bytes, AbiError>where
T: Tokenize,
pub fn encode<T>(&self, name: &str, args: T) -> Result<Bytes, AbiError>where
T: Tokenize,
Returns the ABI encoded data for the provided function and arguments
If the function exists multiple times and you want to use one of the overloaded
versions, consider using encode_with_selector
pub fn encode_with_selector<T>(
&self,
signature: [u8; 4],
args: T,
) -> Result<Bytes, AbiError>where
T: Tokenize,
pub fn encode_with_selector<T>(
&self,
signature: [u8; 4],
args: T,
) -> Result<Bytes, AbiError>where
T: Tokenize,
Returns the ABI encoded data for the provided function selector and arguments
pub fn decode<D, T>(&self, name: &str, bytes: T) -> Result<D, AbiError>
pub fn decode<D, T>(&self, name: &str, bytes: T) -> Result<D, AbiError>
Decodes the provided ABI encoded function arguments with the selected function name.
If the function exists multiple times and you want to use one of the overloaded
versions, consider using decode_with_selector
pub fn decode_raw<T>(
&self,
name: &str,
bytes: T,
) -> Result<Vec<Token>, AbiError>
pub fn decode_raw<T>( &self, name: &str, bytes: T, ) -> Result<Vec<Token>, AbiError>
Decodes the provided ABI encoded function arguments with the selected function name.
If the function exists multiple times and you want to use one of the overloaded
versions, consider using decode_with_selector
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn decode_output<D, T>(&self, name: &str, bytes: T) -> Result<D, AbiError>
pub fn decode_output<D, T>(&self, name: &str, bytes: T) -> Result<D, AbiError>
Decodes the provided ABI encoded function output with the selected function name.
If the function exists multiple times and you want to use one of the overloaded
versions, consider using decode_with_selector
pub fn decode_output_raw<T>(
&self,
name: &str,
bytes: T,
) -> Result<Vec<Token>, AbiError>
pub fn decode_output_raw<T>( &self, name: &str, bytes: T, ) -> Result<Vec<Token>, AbiError>
Decodes the provided ABI encoded function output with the selected function name.
If the function exists multiple times and you want to use one of the overloaded
versions, consider using decode_with_selector
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn decode_event<D>(
&self,
name: &str,
topics: Vec<H256>,
data: Bytes,
) -> Result<D, AbiError>where
D: Detokenize,
pub fn decode_event<D>(
&self,
name: &str,
topics: Vec<H256>,
data: Bytes,
) -> Result<D, AbiError>where
D: Detokenize,
Decodes for a given event name, given the log.topics
and
log.data
fields from the transaction receipt
pub fn decode_event_raw(
&self,
name: &str,
topics: Vec<H256>,
data: Bytes,
) -> Result<Vec<Token>, AbiError>
pub fn decode_event_raw( &self, name: &str, topics: Vec<H256>, data: Bytes, ) -> Result<Vec<Token>, AbiError>
Decodes for a given event name, given the log.topics
and
log.data
fields from the transaction receipt
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn decode_with_selector_raw<T>(
&self,
signature: [u8; 4],
bytes: T,
) -> Result<Vec<Token>, AbiError>
pub fn decode_with_selector_raw<T>( &self, signature: [u8; 4], bytes: T, ) -> Result<Vec<Token>, AbiError>
Decodes the provided ABI encoded bytes with the selected function selector
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn decode_with_selector<D, T>(
&self,
signature: [u8; 4],
bytes: T,
) -> Result<D, AbiError>
pub fn decode_with_selector<D, T>( &self, signature: [u8; 4], bytes: T, ) -> Result<D, AbiError>
Decodes the provided ABI encoded bytes with the selected function selector
pub fn decode_input_raw<T>(&self, bytes: T) -> Result<Vec<Token>, AbiError>
pub fn decode_input_raw<T>(&self, bytes: T) -> Result<Vec<Token>, AbiError>
Decodes the provided ABI encoded input bytes
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn decode_input<D, T>(&self, bytes: T) -> Result<D, AbiError>
pub fn decode_input<D, T>(&self, bytes: T) -> Result<D, AbiError>
Decodes the provided ABI encoded input bytes
pub fn decode_output_with_selector<D, T>(
&self,
signature: [u8; 4],
bytes: T,
) -> Result<D, AbiError>
pub fn decode_output_with_selector<D, T>( &self, signature: [u8; 4], bytes: T, ) -> Result<D, AbiError>
Decode the provided ABI encoded bytes as the output of the provided function selector
pub fn decode_output_with_selector_raw<T>(
&self,
signature: [u8; 4],
bytes: T,
) -> Result<Vec<Token>, AbiError>
pub fn decode_output_with_selector_raw<T>( &self, signature: [u8; 4], bytes: T, ) -> Result<Vec<Token>, AbiError>
Decodes the provided ABI encoded bytes with the selected function selector
Returns a [Token
] vector, which lets you decode function arguments dynamically
without knowing the return type.
pub fn abi(&self) -> &Contract
pub fn abi(&self) -> &Contract
Returns a reference to the contract’s ABI
Trait Implementations§
Source§impl<M> Clone for HoprChannels<M>
impl<M> Clone for HoprChannels<M>
Source§impl<M> Debug for HoprChannels<M>
impl<M> Debug for HoprChannels<M>
Source§impl<M> Deref for HoprChannels<M>
impl<M> Deref for HoprChannels<M>
Source§impl<M> DerefMut for HoprChannels<M>
impl<M> DerefMut for HoprChannels<M>
Auto Trait Implementations§
impl<M> Freeze for HoprChannels<M>
impl<M> RefUnwindSafe for HoprChannels<M>where
M: RefUnwindSafe,
impl<M> Send for HoprChannels<M>
impl<M> Sync for HoprChannels<M>
impl<M> Unpin for HoprChannels<M>where
M: Unpin,
impl<M> UnwindSafe for HoprChannels<M>where
M: RefUnwindSafe + UnwindSafe,
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<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> 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>
§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> 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.