Struct StablecoinDEX
pub struct StablecoinDEX {
pub books: <Mapping<FixedBytes<32>, Orderbook> as StorableType>::Handler,
pub orders: <Mapping<u128, Order> as StorableType>::Handler,
pub balances: <Mapping<Address, Mapping<Address, u128>> as StorableType>::Handler,
pub next_order_id: <u128 as StorableType>::Handler,
pub book_keys: <Vec<FixedBytes<32>> as StorableType>::Handler,
address: Address,
storage: StorageCtx,
}Fields§
§books: <Mapping<FixedBytes<32>, Orderbook> as StorableType>::Handler§orders: <Mapping<u128, Order> as StorableType>::Handler§balances: <Mapping<Address, Mapping<Address, u128>> as StorableType>::Handler§next_order_id: <u128 as StorableType>::Handler§book_keys: <Vec<FixedBytes<32>> as StorableType>::Handler§address: Address§storage: StorageCtxImplementations§
§impl StablecoinDEX
impl StablecoinDEX
pub fn new() -> StablecoinDEX
pub fn new() -> StablecoinDEX
Creates an instance of the precompile.
Caution: This does not initialize the account, see Self::initialize.
§impl StablecoinDEX
impl StablecoinDEX
pub fn address(&self) -> Address
pub fn address(&self) -> Address
Returns the StablecoinDEX address.
pub fn initialize(&mut self) -> Result<(), TempoPrecompileError>
pub fn initialize(&mut self) -> Result<(), TempoPrecompileError>
Initializes the stablecoin DEX precompile.
pub fn balance_of(
&self,
user: Address,
token: Address,
) -> Result<u128, TempoPrecompileError>
pub fn balance_of( &self, user: Address, token: Address, ) -> Result<u128, TempoPrecompileError>
Returns the user’s DEX balance for token.
pub fn get_order(&self, order_id: u128) -> Result<Order, TempoPrecompileError>
pub fn get_order(&self, order_id: u128) -> Result<Order, TempoPrecompileError>
Fetches an active [Order] from storage by ID.
§Errors
OrderDoesNotExist— order has a zero maker (already filled/deleted) or has not yet been assigned (ID ≥ next order ID)
pub fn quote_swap_exact_amount_out(
&self,
token_in: Address,
token_out: Address,
amount_out: u128,
) -> Result<u128, TempoPrecompileError>
pub fn quote_swap_exact_amount_out( &self, token_in: Address, token_out: Address, amount_out: u128, ) -> Result<u128, TempoPrecompileError>
Quotes the input amount required to receive exactly amount_out tokens, routing through
one or more orderbooks without executing trades.
§Errors
IdenticalTokens—token_inandtoken_outare the same addressInvalidToken— a token address does not have a valid TIP-20 prefixPairDoesNotExist— no orderbook exists for one of the hops in the routeInsufficientLiquidity— not enough resting orders to fillamount_out
pub fn quote_swap_exact_amount_in(
&self,
token_in: Address,
token_out: Address,
amount_in: u128,
) -> Result<u128, TempoPrecompileError>
pub fn quote_swap_exact_amount_in( &self, token_in: Address, token_out: Address, amount_in: u128, ) -> Result<u128, TempoPrecompileError>
Quotes the output amount received for exactly amount_in input tokens, routing through
one or more orderbooks without executing trades.
§Errors
IdenticalTokens—token_inandtoken_outare the same addressInvalidToken— a token address does not have a valid TIP-20 prefixPairDoesNotExist— no orderbook exists for one of the hops in the routeInsufficientLiquidity— not enough resting orders to fillamount_in
pub fn swap_exact_amount_in(
&mut self,
sender: Address,
token_in: Address,
token_out: Address,
amount_in: u128,
min_amount_out: u128,
) -> Result<u128, TempoPrecompileError>
pub fn swap_exact_amount_in( &mut self, sender: Address, token_in: Address, token_out: Address, amount_in: u128, min_amount_out: u128, ) -> Result<u128, TempoPrecompileError>
Swaps amount_in of token_in for token_out, routing through
one or more orderbooks. Deducts input via [TIP20Token] transfer
or DEX balance, then fills orders at best price per hop.
§Errors
InvalidBaseToken— token address does not have a valid TIP-20 prefixPairNotFound— no orderbook exists for the token pairInsufficientOutput— final output amount falls belowmin_amount_outInsufficientBalance— sender balance lower than required input
pub fn swap_exact_amount_out(
&mut self,
sender: Address,
token_in: Address,
token_out: Address,
amount_out: u128,
max_amount_in: u128,
) -> Result<u128, TempoPrecompileError>
pub fn swap_exact_amount_out( &mut self, sender: Address, token_in: Address, token_out: Address, amount_out: u128, max_amount_in: u128, ) -> Result<u128, TempoPrecompileError>
Swaps to receive exactly amount_out of token_out, routing
through one or more orderbooks. Works backwards from output to
compute input, then deducts via [TIP20Token] or DEX balance.
§Errors
InvalidBaseToken— token address does not have a valid TIP-20 prefixPairNotFound— no orderbook exists for the token pairMaxInputExceeded— required input exceedsmax_amount_inInsufficientBalance— sender balance lower than required input
pub fn get_price_level(
&self,
base: Address,
tick: i16,
is_bid: bool,
) -> Result<TickLevel, TempoPrecompileError>
pub fn get_price_level( &self, base: Address, tick: i16, is_bid: bool, ) -> Result<TickLevel, TempoPrecompileError>
Returns the [TickLevel] for a given base token, tick, and side. Looks up the
quote token via [TIP20Token] and derives the book key.
§Errors
InvalidBaseToken—baseaddress does not resolve to a valid [TIP20Token]
pub fn books(
&self,
pair_key: FixedBytes<32>,
) -> Result<Orderbook, TempoPrecompileError>
pub fn books( &self, pair_key: FixedBytes<32>, ) -> Result<Orderbook, TempoPrecompileError>
Returns the [Orderbook] for a given pair key.
pub fn get_book_keys(&self) -> Result<Vec<FixedBytes<32>>, TempoPrecompileError>
pub fn get_book_keys(&self) -> Result<Vec<FixedBytes<32>>, TempoPrecompileError>
Returns all registered orderbook keys.
pub fn tick_to_price(&self, tick: i16) -> Result<u32, TempoPrecompileError>
pub fn tick_to_price(&self, tick: i16) -> Result<u32, TempoPrecompileError>
Converts a relative tick to a scaled price. On T2+ validates [TICK_SPACING] alignment.
§Errors
InvalidTick— tick is not aligned to [TICK_SPACING] (T2+ only)
pub fn price_to_tick(&self, price: u32) -> Result<i16, TempoPrecompileError>
pub fn price_to_tick(&self, price: u32) -> Result<i16, TempoPrecompileError>
Converts a scaled price to a relative tick. On T2+ validates [TICK_SPACING] alignment.
§Errors
TickOutOfBounds— price is outside the[MIN_PRICE, MAX_PRICE]rangeInvalidTick— resulting tick is not aligned to [TICK_SPACING] (T2+ only)
pub fn create_pair(
&mut self,
base: Address,
) -> Result<FixedBytes<32>, TempoPrecompileError>
pub fn create_pair( &mut self, base: Address, ) -> Result<FixedBytes<32>, TempoPrecompileError>
Creates a new trading pair between base and its quote token.
Both must be USD-denominated tokens validated via
[TIP20Factory]. Reverts if the pair already exists.
§Errors
InvalidBaseToken— token address does not have a valid TIP-20 prefixInvalidCurrency— both tokens must be USD-denominated (validated via [TIP20Factory]).PairAlreadyExists— an orderbook for this pair is already initialized
pub fn place(
&mut self,
sender: Address,
token: Address,
amount: u128,
is_bid: bool,
tick: i16,
) -> Result<u128, TempoPrecompileError>
pub fn place( &mut self, sender: Address, token: Address, amount: u128, is_bid: bool, tick: i16, ) -> Result<u128, TempoPrecompileError>
Places a limit order on the orderbook for token against its quote token.
Escrows the appropriate amount via [TIP20Token] transfer or DEX balance and enforces
compliance via the [TIP403Registry]. Auto-creates the trading pair if needed.
§Errors
InvalidBaseToken— token address does not have a valid TIP-20 prefixTickOutOfBounds— tick is outside the allowed[MIN_TICK, MAX_TICK]rangeInvalidTick— tick is not aligned toTICK_SPACINGBelowMinimumOrderSize— order amount is belowMIN_ORDER_AMOUNTInsufficientBalance— sender balance lower than requiredPolicyForbids— TIP-403 policy rejects the token transfer
§Returns
The assigned order ID
pub fn place_flip(
&mut self,
sender: Address,
token: Address,
amount: u128,
is_bid: bool,
tick: i16,
flip_tick: i16,
internal_balance_only: bool,
) -> Result<u128, TempoPrecompileError>
pub fn place_flip( &mut self, sender: Address, token: Address, amount: u128, is_bid: bool, tick: i16, flip_tick: i16, internal_balance_only: bool, ) -> Result<u128, TempoPrecompileError>
Places a flip order that auto-reverses to the opposite side when
fully filled, acting as perpetual liquidity. Escrows tokens via
[TIP20Token] and enforces compliance via [TIP403Registry].
Pre-T5: for bids flip_tick must be > tick; for asks, < tick.
T5+ (TIP-1030): for bids flip_tick >= tick; for asks flip_tick <= tick.
§Errors
InvalidBaseToken— token address does not have a valid TIP-20 prefixTickOutOfBounds— tick or flip_tick outside[MIN_TICK, MAX_TICK]InvalidTick— tick is not aligned toTICK_SPACINGInvalidFlipTick— flip_tick on wrong side of tick for order directionBelowMinimumOrderSize— order amount is belowMIN_ORDER_AMOUNTInsufficientBalance— sender balance lower than required escrowPolicyForbids— TIP-403 policy rejects the token transfer
pub fn cancel(
&mut self,
sender: Address,
order_id: u128,
) -> Result<(), TempoPrecompileError>
pub fn cancel( &mut self, sender: Address, order_id: u128, ) -> Result<(), TempoPrecompileError>
Cancels an active order and refunds escrowed tokens to the maker. Only the order maker can cancel their own orders.
§Errors
OrderDoesNotExist— order ID not found or already fully filledUnauthorized— only the order maker can cancel their order
pub fn cancel_stale_order(
&mut self,
order_id: u128,
) -> Result<(), TempoPrecompileError>
pub fn cancel_stale_order( &mut self, order_id: u128, ) -> Result<(), TempoPrecompileError>
Cancels an order whose maker is blocked by [TIP403Registry] policy, allowing anyone to
clean up stale liquidity.
TIP-1015: T4+ checks sender authorization on the escrow token and recipient authorization on the payout token. An order is stale if the maker fails either check.
§Errors
OrderDoesNotExist— order ID not found or already fully filledOrderNotStale— order maker is still authorized by TIP-403 policy
§impl StablecoinDEX
impl StablecoinDEX
pub fn create_precompile(cfg: &CfgEnv<TempoHardfork>) -> DynPrecompile
pub fn create_precompile(cfg: &CfgEnv<TempoHardfork>) -> DynPrecompile
Creates the EVM precompile for this type.
Trait Implementations§
§impl ContractStorage for StablecoinDEX
impl ContractStorage for StablecoinDEX
§fn storage_mut(&mut self) -> &mut StorageCtx
fn storage_mut(&mut self) -> &mut StorageCtx
§fn is_initialized(&self) -> Result<bool, TempoPrecompileError>
fn is_initialized(&self) -> Result<bool, TempoPrecompileError>
§impl Default for StablecoinDEX
impl Default for StablecoinDEX
§fn default() -> StablecoinDEX
fn default() -> StablecoinDEX
Auto Trait Implementations§
impl !Freeze for StablecoinDEX
impl !RefUnwindSafe for StablecoinDEX
impl !Sync for StablecoinDEX
impl Send for StablecoinDEX
impl Unpin for StablecoinDEX
impl UnsafeUnpin for StablecoinDEX
impl UnwindSafe for StablecoinDEX
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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
§impl<T> Conv for T
impl<T> Conv for T
impl<T> ErasedDestructor for Twhere
T: 'static,
§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<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
impl<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
§fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
TxEnv] from a transaction and a sender address.§impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
§fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
TxEnv] from a transaction, its sender, and encoded transaction bytes.§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Layered].§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling [Attribute] value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi [Quirk] value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the [Condition] value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> Read<Exclusive, BecauseExclusive> 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
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 504 bytes