Struct messaging::conversation::Conversation
source · pub struct Conversation<M>(/* private fields */);
Implementations§
source§impl<M: Middleware> Conversation<M>
impl<M: Middleware> Conversation<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 default_admin_role(&self) -> ContractCall<M, [u8; 32]>
pub fn default_admin_role(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s DEFAULT_ADMIN_ROLE
(0xa217fddf) function
sourcepub fn inbox_admin_role(&self) -> ContractCall<M, [u8; 32]>
pub fn inbox_admin_role(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s INBOX_ADMIN_ROLE
(0x5c1e4016) function
sourcepub fn upgrade_interface_version(&self) -> ContractCall<M, String>
pub fn upgrade_interface_version(&self) -> ContractCall<M, String>
Calls the contract’s UPGRADE_INTERFACE_VERSION
(0xad3cb1cc) function
sourcepub fn get_role_admin(&self, role: [u8; 32]) -> ContractCall<M, [u8; 32]>
pub fn get_role_admin(&self, role: [u8; 32]) -> ContractCall<M, [u8; 32]>
Calls the contract’s getRoleAdmin
(0x248a9ca3) function
sourcepub fn grant_role(
&self,
role: [u8; 32],
account: Address
) -> ContractCall<M, ()>
pub fn grant_role( &self, role: [u8; 32], account: Address ) -> ContractCall<M, ()>
Calls the contract’s grantRole
(0x2f2ff15d) function
sourcepub fn has_role(
&self,
role: [u8; 32],
account: Address
) -> ContractCall<M, bool>
pub fn has_role( &self, role: [u8; 32], account: Address ) -> ContractCall<M, bool>
Calls the contract’s hasRole
(0x91d14854) function
sourcepub fn initialize(&self, role_admin: Address) -> ContractCall<M, ()>
pub fn initialize(&self, role_admin: Address) -> ContractCall<M, ()>
Calls the contract’s initialize
(0xc4d66de8) function
sourcepub fn last_message(&self, p0: [u8; 32]) -> ContractCall<M, U256>
pub fn last_message(&self, p0: [u8; 32]) -> ContractCall<M, U256>
Calls the contract’s lastMessage
(0xcca0a227) function
sourcepub fn nonce(&self, p0: Address) -> ContractCall<M, U256>
pub fn nonce(&self, p0: Address) -> ContractCall<M, U256>
Calls the contract’s nonce
(0x70ae92d2) function
sourcepub fn proxiable_uuid(&self) -> ContractCall<M, [u8; 32]>
pub fn proxiable_uuid(&self) -> ContractCall<M, [u8; 32]>
Calls the contract’s proxiableUUID
(0x52d1902d) function
sourcepub fn renounce_role(
&self,
role: [u8; 32],
caller_confirmation: Address
) -> ContractCall<M, ()>
pub fn renounce_role( &self, role: [u8; 32], caller_confirmation: Address ) -> ContractCall<M, ()>
Calls the contract’s renounceRole
(0x36568abe) function
sourcepub fn revoke_role(
&self,
role: [u8; 32],
account: Address
) -> ContractCall<M, ()>
pub fn revoke_role( &self, role: [u8; 32], account: Address ) -> ContractCall<M, ()>
Calls the contract’s revokeRole
(0xd547741f) function
sourcepub fn send_message(
&self,
conversation_id: [u8; 32],
payload: Bytes
) -> ContractCall<M, ()>
pub fn send_message( &self, conversation_id: [u8; 32], payload: Bytes ) -> ContractCall<M, ()>
Calls the contract’s sendMessage
(0x23c640e7) function
sourcepub fn send_message_signed(
&self,
conversation_id: [u8; 32],
payload: Bytes,
identity: Address,
sig_v: u8,
sig_r: [u8; 32],
sig_s: [u8; 32]
) -> ContractCall<M, ()>
pub fn send_message_signed( &self, conversation_id: [u8; 32], payload: Bytes, identity: Address, sig_v: u8, sig_r: [u8; 32], sig_s: [u8; 32] ) -> ContractCall<M, ()>
Calls the contract’s sendMessageSigned
(0x559efc88) function
sourcepub fn supports_interface(&self, interface_id: [u8; 4]) -> ContractCall<M, bool>
pub fn supports_interface(&self, interface_id: [u8; 4]) -> ContractCall<M, bool>
Calls the contract’s supportsInterface
(0x01ffc9a7) function
sourcepub fn upgrade_to_and_call(
&self,
new_implementation: Address,
data: Bytes
) -> ContractCall<M, ()>
pub fn upgrade_to_and_call( &self, new_implementation: Address, data: Bytes ) -> ContractCall<M, ()>
Calls the contract’s upgradeToAndCall
(0x4f1ef286) function
sourcepub fn initialized_filter(&self) -> Event<Arc<M>, M, InitializedFilter>
pub fn initialized_filter(&self) -> Event<Arc<M>, M, InitializedFilter>
Gets the contract’s Initialized
event
sourcepub fn payload_sent_filter(&self) -> Event<Arc<M>, M, PayloadSentFilter>
pub fn payload_sent_filter(&self) -> Event<Arc<M>, M, PayloadSentFilter>
Gets the contract’s PayloadSent
event
sourcepub fn role_admin_changed_filter(
&self
) -> Event<Arc<M>, M, RoleAdminChangedFilter>
pub fn role_admin_changed_filter( &self ) -> Event<Arc<M>, M, RoleAdminChangedFilter>
Gets the contract’s RoleAdminChanged
event
sourcepub fn role_granted_filter(&self) -> Event<Arc<M>, M, RoleGrantedFilter>
pub fn role_granted_filter(&self) -> Event<Arc<M>, M, RoleGrantedFilter>
Gets the contract’s RoleGranted
event
sourcepub fn role_revoked_filter(&self) -> Event<Arc<M>, M, RoleRevokedFilter>
pub fn role_revoked_filter(&self) -> Event<Arc<M>, M, RoleRevokedFilter>
Gets the contract’s RoleRevoked
event
sourcepub fn upgraded_filter(&self) -> Event<Arc<M>, M, UpgradedFilter>
pub fn upgraded_filter(&self) -> Event<Arc<M>, M, UpgradedFilter>
Gets the contract’s Upgraded
event
sourcepub fn events(&self) -> Event<Arc<M>, M, ConversationEvents>
pub fn events(&self) -> Event<Arc<M>, M, ConversationEvents>
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 Conversation<M>
impl<M> Clone for Conversation<M>
source§impl<M> Debug for Conversation<M>
impl<M> Debug for Conversation<M>
source§impl<M> Deref for Conversation<M>
impl<M> Deref for Conversation<M>
source§impl<M> DerefMut for Conversation<M>
impl<M> DerefMut for Conversation<M>
Auto Trait Implementations§
impl<M> RefUnwindSafe for Conversation<M>where
M: RefUnwindSafe,
impl<M> Send for Conversation<M>
impl<M> Sync for Conversation<M>
impl<M> Unpin for Conversation<M>where
M: Unpin,
impl<M> UnwindSafe for Conversation<M>where
M: UnwindSafe + RefUnwindSafe,
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
§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.