Struct pallet_pool_system::pallet::Pallet
source · pub struct Pallet<T>(/* private fields */);
Expand description
The Pallet
struct, the main type that implements traits and standalone
functions within the pallet.
Implementations§
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn set_max_reserve(
origin: OriginFor<T>,
pool_id: T::PoolId,
max_reserve: T::Balance
) -> DispatchResult
pub fn set_max_reserve( origin: OriginFor<T>, pool_id: T::PoolId, max_reserve: T::Balance ) -> DispatchResult
Sets the maximum reserve for a pool
The caller must have the LiquidityAdmin
role in
order to invoke this extrinsic. This role is not
given to the pool creator by default, and must be
added with the Permissions pallet before this
extrinsic can be called.
sourcepub fn close_epoch(
origin: OriginFor<T>,
pool_id: T::PoolId
) -> DispatchResultWithPostInfo
pub fn close_epoch( origin: OriginFor<T>, pool_id: T::PoolId ) -> DispatchResultWithPostInfo
Close the current epoch
Closing an epoch locks in all invest and redeem orders placed during the epoch, and causes all further invest and redeem orders to be set for the next epoch.
If all orders can be executed without violating any
pool constraints - which include maximum reserve and
the tranche risk buffers - the execution will also be
done. See execute_epoch
for details on epoch
execution.
If pool constraints would be violated by executing all
orders, the pool enters a submission period. During a
submission period, partial executions can be submitted
to be scored, and the best-scoring solution will
eventually be executed. See submit_solution
.
sourcepub fn submit_solution(
origin: OriginFor<T>,
pool_id: T::PoolId,
solution: Vec<TrancheSolution>
) -> DispatchResultWithPostInfo
pub fn submit_solution( origin: OriginFor<T>, pool_id: T::PoolId, solution: Vec<TrancheSolution> ) -> DispatchResultWithPostInfo
Submit a partial execution solution for a closed epoch
If the submitted solution is “better” than the previous best solution, it will replace it. Solutions are ordered such that solutions which do not violate constraints are better than those that do.
Once a valid solution has been submitted, the challenge time begins. The pool can be executed once the challenge time has expired.
sourcepub fn execute_epoch(
origin: OriginFor<T>,
pool_id: T::PoolId
) -> DispatchResultWithPostInfo
pub fn execute_epoch( origin: OriginFor<T>, pool_id: T::PoolId ) -> DispatchResultWithPostInfo
Execute an epoch for which a valid solution has been submitted.
- Mints or burns tranche tokens based on investments and redemptions
- Updates the portion of the reserve and loan balance assigned to each tranche, based on the investments and redemptions to those tranches.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn score_solution(
pool_id: &PoolDetailsOf<T>,
epoch: &EpochExecutionInfo<<T as Config>::Balance, <T as Config>::BalanceRatio, <T as Config>::EpochId, <T as Config>::TrancheWeight, BlockNumberFor<T>, <T as Config>::TrancheCurrency, <T as Config>::MaxTranches>,
solution: &[TrancheSolution]
) -> Result<EpochSolution<T::Balance, T::MaxTranches>, DispatchError>
pub fn score_solution( pool_id: &PoolDetailsOf<T>, epoch: &EpochExecutionInfo<<T as Config>::Balance, <T as Config>::BalanceRatio, <T as Config>::EpochId, <T as Config>::TrancheWeight, BlockNumberFor<T>, <T as Config>::TrancheCurrency, <T as Config>::MaxTranches>, solution: &[TrancheSolution] ) -> Result<EpochSolution<T::Balance, T::MaxTranches>, DispatchError>
Scores a solution.
This function checks the state a pool would be in when applying a solution to an epoch. Depending on the state, the correct scoring function is chosen.
pub fn is_valid_tranche_change( old_tranches: Option<&TranchesOf<T>>, new_tranches: &[TrancheUpdate<T::Rate>] ) -> DispatchResult
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn scheduled_update<KArg>(
k: KArg
) -> Option<ScheduledUpdateDetails<<T as Config>::Rate, <T as Config>::StringLimit, <T as Config>::MaxTranches>>where
KArg: EncodeLike<T::PoolId>,
pub fn scheduled_update<KArg>(
k: KArg
) -> Option<ScheduledUpdateDetails<<T as Config>::Rate, <T as Config>::StringLimit, <T as Config>::MaxTranches>>where
KArg: EncodeLike<T::PoolId>,
An auto-generated getter for ScheduledUpdate
.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn epoch_targets<KArg>(
k: KArg
) -> Option<EpochExecutionInfo<<T as Config>::Balance, <T as Config>::BalanceRatio, <T as Config>::EpochId, <T as Config>::TrancheWeight, BlockNumberFor<T>, <T as Config>::TrancheCurrency, <T as Config>::MaxTranches>>where
KArg: EncodeLike<T::PoolId>,
pub fn epoch_targets<KArg>(
k: KArg
) -> Option<EpochExecutionInfo<<T as Config>::Balance, <T as Config>::BalanceRatio, <T as Config>::EpochId, <T as Config>::TrancheWeight, BlockNumberFor<T>, <T as Config>::TrancheCurrency, <T as Config>::MaxTranches>>where
KArg: EncodeLike<T::PoolId>,
An auto-generated getter for EpochExecution
.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn account_deposits<KArg>(k: KArg) -> T::Balancewhere
KArg: EncodeLike<T::AccountId>,
pub fn account_deposits<KArg>(k: KArg) -> T::Balancewhere
KArg: EncodeLike<T::AccountId>,
An auto-generated getter for AccountDeposit
.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn pool_deposits<KArg>(
k: KArg
) -> Option<PoolDepositInfo<<T as Config>::AccountId, <T as Config>::Balance>>where
KArg: EncodeLike<T::PoolId>,
pub fn pool_deposits<KArg>(
k: KArg
) -> Option<PoolDepositInfo<<T as Config>::AccountId, <T as Config>::Balance>>where
KArg: EncodeLike<T::PoolId>,
An auto-generated getter for PoolDeposit
.
Trait Implementations§
source§impl<T: Config> BeforeAllRuntimeMigrations for Pallet<T>
impl<T: Config> BeforeAllRuntimeMigrations for Pallet<T>
source§fn before_all_runtime_migrations() -> Weight
fn before_all_runtime_migrations() -> Weight
source§impl<T: Config> ChangeGuard for Pallet<T>
impl<T: Config> ChangeGuard for Pallet<T>
§type Change = <T as Config>::RuntimeChange
type Change = <T as Config>::RuntimeChange
source§fn note(
pool_id: Self::PoolId,
change: Self::Change
) -> Result<Self::ChangeId, DispatchError>
fn note( pool_id: Self::PoolId, change: Self::Change ) -> Result<Self::ChangeId, DispatchError>
change
related to a pool_id
.
The caller to this method ask for feedback for the implementation of
this trait in order be able to semantically proceed successful with that
change. The change intention will be noted by this method and identified
by the returned ChangeId.source§impl<T: Config> GetStorageVersion for Pallet<T>
impl<T: Config> GetStorageVersion for Pallet<T>
§type CurrentStorageVersion = StorageVersion
type CurrentStorageVersion = StorageVersion
source§fn current_storage_version() -> Self::CurrentStorageVersion
fn current_storage_version() -> Self::CurrentStorageVersion
source§fn on_chain_storage_version() -> StorageVersion
fn on_chain_storage_version() -> StorageVersion
source§impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
§fn on_initialize(_n: BlockNumber) -> Weight
fn on_initialize(_n: BlockNumber) -> Weight
§fn on_finalize(_n: BlockNumber)
fn on_finalize(_n: BlockNumber)
§fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
Hooks::on_finalize
]). Read more§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
§fn offchain_worker(_n: BlockNumber)
fn offchain_worker(_n: BlockNumber)
§fn integrity_test()
fn integrity_test()
source§impl<T: Config> IntegrityTest for Pallet<T>
impl<T: Config> IntegrityTest for Pallet<T>
source§fn integrity_test()
fn integrity_test()
Hooks::integrity_test
].source§impl<T: Config> InvestmentAccountant<<T as Config>::AccountId> for Pallet<T>
impl<T: Config> InvestmentAccountant<<T as Config>::AccountId> for Pallet<T>
type Amount = <T as Config>::Balance
type Error = DispatchError
type InvestmentId = <T as Config>::TrancheCurrency
type InvestmentInfo = InvestmentInfo<<T as Config>::AccountId, <T as Config>::CurrencyId, <Pallet<T> as InvestmentAccountant<<T as Config>::AccountId>>::InvestmentId>
source§fn info(id: Self::InvestmentId) -> Result<Self::InvestmentInfo, Self::Error>
fn info(id: Self::InvestmentId) -> Result<Self::InvestmentInfo, Self::Error>
source§fn balance(id: Self::InvestmentId, who: &T::AccountId) -> Self::Amount
fn balance(id: Self::InvestmentId, who: &T::AccountId) -> Self::Amount
source§fn transfer(
id: Self::InvestmentId,
source: &T::AccountId,
dest: &T::AccountId,
amount: Self::Amount
) -> Result<(), Self::Error>
fn transfer( id: Self::InvestmentId, source: &T::AccountId, dest: &T::AccountId, amount: Self::Amount ) -> Result<(), Self::Error>
source§impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn offchain_worker(n: BlockNumberFor<T>)
fn offchain_worker(n: BlockNumberFor<T>)
source§impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_finalize(n: BlockNumberFor<T>)
fn on_finalize(n: BlockNumberFor<T>)
Hooks::on_finalize
].source§impl<T: Config> OnGenesis for Pallet<T>
impl<T: Config> OnGenesis for Pallet<T>
source§fn on_genesis()
fn on_genesis()
source§impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_initialize(n: BlockNumberFor<T>) -> Weight
fn on_initialize(n: BlockNumberFor<T>) -> Weight
Hooks::on_initialize
].source§impl<T: Config> OnRuntimeUpgrade for Pallet<T>
impl<T: Config> OnRuntimeUpgrade for Pallet<T>
source§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Hooks::on_runtime_upgrade
].source§impl<T: Config> PalletInfoAccess for Pallet<T>
impl<T: Config> PalletInfoAccess for Pallet<T>
source§fn module_name() -> &'static str
fn module_name() -> &'static str
source§fn crate_version() -> CrateVersion
fn crate_version() -> CrateVersion
source§impl<T> PartialEq for Pallet<T>
impl<T> PartialEq for Pallet<T>
source§impl<T: Config> PoolInspect<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
impl<T: Config> PoolInspect<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
type Moment = u64
type PoolId = <T as Config>::PoolId
type TrancheId = <T as Config>::TrancheId
source§fn pool_exists(pool_id: Self::PoolId) -> bool
fn pool_exists(pool_id: Self::PoolId) -> bool
source§fn tranche_exists(pool_id: Self::PoolId, tranche_id: Self::TrancheId) -> bool
fn tranche_exists(pool_id: Self::PoolId, tranche_id: Self::TrancheId) -> bool
source§fn account_for(pool_id: Self::PoolId) -> T::AccountId
fn account_for(pool_id: Self::PoolId) -> T::AccountId
pool_id
.source§fn currency_for(pool_id: Self::PoolId) -> Option<T::CurrencyId>
fn currency_for(pool_id: Self::PoolId) -> Option<T::CurrencyId>
pool_id
.source§impl<T: Config> PoolMutate<<T as Config>::AccountId, <T as Config>::PoolId> for Pallet<T>
impl<T: Config> PoolMutate<<T as Config>::AccountId, <T as Config>::PoolId> for Pallet<T>
type Balance = <T as Config>::Balance
type CurrencyId = <T as Config>::CurrencyId
type PoolChanges = PoolChanges<<T as Config>::Rate, <T as Config>::StringLimit, <T as Config>::MaxTranches>
type PoolFeeInput = (PoolFeeBucket, PoolFeeInfo<<T as Config>::AccountId, <T as Config>::Balance, <T as Config>::Rate>)
type TrancheInput = TrancheInput<<T as Config>::Rate, <T as Config>::StringLimit>
fn create( admin: T::AccountId, depositor: T::AccountId, pool_id: T::PoolId, tranche_inputs: Vec<TrancheInput<T::Rate, T::StringLimit>>, currency: T::CurrencyId, max_reserve: T::Balance, pool_fees: Vec<Self::PoolFeeInput> ) -> DispatchResult
fn update( pool_id: T::PoolId, changes: PoolChangesOf<T> ) -> Result<UpdateState, DispatchError>
fn execute_update(pool_id: T::PoolId) -> Result<u32, DispatchError>
source§impl<T: Config> PoolReserve<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
impl<T: Config> PoolReserve<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
source§impl<T: Config> TrancheTokenPrice<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
impl<T: Config> TrancheTokenPrice<<T as Config>::AccountId, <T as Config>::CurrencyId> for Pallet<T>
source§impl<T: Config> WhitelistedStorageKeys for Pallet<T>
impl<T: Config> WhitelistedStorageKeys for Pallet<T>
source§fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
Vec<TrackedStorageKey>
indicating the storage keys that
should be whitelisted during benchmarking. This means that those keys
will be excluded from the benchmarking performance calculation.impl<T> Eq for Pallet<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for Pallet<T>where
T: RefUnwindSafe,
impl<T> Send for Pallet<T>where
T: Send,
impl<T> Sync for Pallet<T>where
T: Sync,
impl<T> Unpin for Pallet<T>where
T: Unpin,
impl<T> UnwindSafe for Pallet<T>where
T: 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
§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
§fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
§impl<T> Conv for T
impl<T> Conv for T
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§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> 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> IsType<T> for T
impl<T> IsType<T> for T
§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§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> SaturatedConversion for T
impl<T> SaturatedConversion for T
§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
T
. Read more§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, U> TryInto2<U> for Twhere
U: TryFrom2<T>,
impl<T, U> TryInto2<U> for Twhere
U: TryFrom2<T>,
§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.