Struct pallet_asset_conversion::pallet::Pallet  
source · pub struct Pallet<T>(_);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>
Pallet’s callable functions.
sourcepub fn create_pool(
    origin: OriginFor<T>,
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId
) -> DispatchResult
 
pub fn create_pool( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId ) -> DispatchResult
Creates an empty liquidity pool and an associated new lp_token asset
(the id of which is returned in the Event::PoolCreated event).
Once a pool is created, someone may Pallet::add_liquidity to it.
sourcepub fn add_liquidity(
    origin: OriginFor<T>,
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId,
    amount1_desired: T::AssetBalance,
    amount2_desired: T::AssetBalance,
    amount1_min: T::AssetBalance,
    amount2_min: T::AssetBalance,
    mint_to: T::AccountId
) -> DispatchResult
 
pub fn add_liquidity( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount1_desired: T::AssetBalance, amount2_desired: T::AssetBalance, amount1_min: T::AssetBalance, amount2_min: T::AssetBalance, mint_to: T::AccountId ) -> DispatchResult
Provide liquidity into the pool of asset1 and asset2.
NOTE: an optimal amount of asset1 and asset2 will be calculated and
might be different than the provided amount1_desired/amount2_desired
thus you should provide the min amount you’re happy to provide.
Params amount1_min/amount2_min represent that.
mint_to will be sent the liquidity tokens that represent this share of the pool.
Once liquidity is added, someone may successfully call
Pallet::swap_exact_tokens_for_tokens successfully.
sourcepub fn remove_liquidity(
    origin: OriginFor<T>,
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId,
    lp_token_burn: T::AssetBalance,
    amount1_min_receive: T::AssetBalance,
    amount2_min_receive: T::AssetBalance,
    withdraw_to: T::AccountId
) -> DispatchResult
 
pub fn remove_liquidity( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId, lp_token_burn: T::AssetBalance, amount1_min_receive: T::AssetBalance, amount2_min_receive: T::AssetBalance, withdraw_to: T::AccountId ) -> DispatchResult
Allows you to remove liquidity by providing the lp_token_burn tokens that will be
burned in the process. With the usage of amount1_min_receive/amount2_min_receive
it’s possible to control the min amount of returned tokens you’re happy with.
sourcepub fn swap_exact_tokens_for_tokens(
    origin: OriginFor<T>,
    path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
    amount_in: T::AssetBalance,
    amount_out_min: T::AssetBalance,
    send_to: T::AccountId,
    keep_alive: bool
) -> DispatchResult
 
pub fn swap_exact_tokens_for_tokens( origin: OriginFor<T>, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_in: T::AssetBalance, amount_out_min: T::AssetBalance, send_to: T::AccountId, keep_alive: bool ) -> DispatchResult
Swap the exact amount of asset1 into asset2.
amount_out_min param allows you to specify the min amount of the asset2
you’re happy to receive.
AssetConversionApi::quote_price_exact_tokens_for_tokens runtime call can be called
for a quote.
sourcepub fn swap_tokens_for_exact_tokens(
    origin: OriginFor<T>,
    path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
    amount_out: T::AssetBalance,
    amount_in_max: T::AssetBalance,
    send_to: T::AccountId,
    keep_alive: bool
) -> DispatchResult
 
pub fn swap_tokens_for_exact_tokens( origin: OriginFor<T>, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_out: T::AssetBalance, amount_in_max: T::AssetBalance, send_to: T::AccountId, keep_alive: bool ) -> DispatchResult
Swap any amount of asset1 to get the exact amount of asset2.
amount_in_max param allows to specify the max amount of the asset1
you’re happy to provide.
AssetConversionApi::quote_price_tokens_for_exact_tokens runtime call can be called
for a quote.
source§impl<T: Config> Pallet<T>
 
impl<T: Config> Pallet<T>
sourcepub fn do_swap_exact_tokens_for_tokens(
    sender: T::AccountId,
    path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
    amount_in: T::AssetBalance,
    amount_out_min: Option<T::AssetBalance>,
    send_to: T::AccountId,
    keep_alive: bool
) -> Result<T::AssetBalance, DispatchError>
 
pub fn do_swap_exact_tokens_for_tokens( sender: T::AccountId, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_in: T::AssetBalance, amount_out_min: Option<T::AssetBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::AssetBalance, DispatchError>
Swap exactly amount_in of asset path[0] for asset path[1].
If an amount_out_min is specified, it will return an error if it is unable to acquire
the amount desired.
Withdraws the path[0] asset from sender, deposits the path[1] asset to send_to,
respecting keep_alive.
If successful, returns the amount of path[1] acquired for the amount_in.
sourcepub fn do_swap_tokens_for_exact_tokens(
    sender: T::AccountId,
    path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
    amount_out: T::AssetBalance,
    amount_in_max: Option<T::AssetBalance>,
    send_to: T::AccountId,
    keep_alive: bool
) -> Result<T::AssetBalance, DispatchError>
 
pub fn do_swap_tokens_for_exact_tokens( sender: T::AccountId, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_out: T::AssetBalance, amount_in_max: Option<T::AssetBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::AssetBalance, DispatchError>
Take the path[0] asset and swap some amount for amount_out of the path[1]. If an
amount_in_max is specified, it will return an error if acquiring amount_out would be
too costly.
Withdraws path[0] asset from sender, deposits the path[1] asset to send_to,
respecting keep_alive.
If successful returns the amount of the path[0] taken to provide path[1].
sourcepub fn get_pool_account(
    pool_id: &(<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
) -> T::AccountId
 
pub fn get_pool_account( pool_id: &(<T as Config>::MultiAssetId, <T as Config>::MultiAssetId) ) -> T::AccountId
The account ID of the pool.
This actually does computation. If you need to keep using it, then make sure you cache the value and only call this once.
sourcepub fn get_pool_id(
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId
) -> (<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
 
pub fn get_pool_id( asset1: T::MultiAssetId, asset2: T::MultiAssetId ) -> (<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
Returns a pool id constructed from 2 assets.
- Native asset should be lower than the other asset ids.
 - Two native or two non-native assets are compared by their 
Ordimplementation. 
We expect deterministic order, so (asset1, asset2) or (asset2, asset1) returns the same result.
sourcepub fn get_reserves(
    asset1: &T::MultiAssetId,
    asset2: &T::MultiAssetId
) -> Result<(T::AssetBalance, T::AssetBalance), Error<T>>
 
pub fn get_reserves( asset1: &T::MultiAssetId, asset2: &T::MultiAssetId ) -> Result<(T::AssetBalance, T::AssetBalance), Error<T>>
Returns the balance of each asset in the pool. The tuple result is in the order requested (not necessarily the same as pool order).
sourcepub fn quote_price_exact_tokens_for_tokens(
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId,
    amount: T::AssetBalance,
    include_fee: bool
) -> Option<T::AssetBalance>
 
pub fn quote_price_exact_tokens_for_tokens( asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount: T::AssetBalance, include_fee: bool ) -> Option<T::AssetBalance>
Used by the RPC service to provide current prices.
sourcepub fn quote_price_tokens_for_exact_tokens(
    asset1: T::MultiAssetId,
    asset2: T::MultiAssetId,
    amount: T::AssetBalance,
    include_fee: bool
) -> Option<T::AssetBalance>
 
pub fn quote_price_tokens_for_exact_tokens( asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount: T::AssetBalance, include_fee: bool ) -> Option<T::AssetBalance>
Used by the RPC service to provide current prices.
sourcepub fn quote(
    amount: &T::AssetBalance,
    reserve1: &T::AssetBalance,
    reserve2: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
 
pub fn quote( amount: &T::AssetBalance, reserve1: &T::AssetBalance, reserve2: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates the optimal amount from the reserves.
sourcepub fn get_amount_out(
    amount_in: &T::AssetBalance,
    reserve_in: &T::AssetBalance,
    reserve_out: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
 
pub fn get_amount_out( amount_in: &T::AssetBalance, reserve_in: &T::AssetBalance, reserve_out: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates amount out.
Given an input amount of an asset and pair reserves, returns the maximum output amount of the other asset.
sourcepub fn get_amount_in(
    amount_out: &T::AssetBalance,
    reserve_in: &T::AssetBalance,
    reserve_out: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
 
pub fn get_amount_in( amount_out: &T::AssetBalance, reserve_in: &T::AssetBalance, reserve_out: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates amount in.
Given an output amount of an asset and pair reserves, returns a required input amount of the other asset.
sourcepub fn get_next_pool_asset_id() -> T::PoolAssetId
 
pub fn get_next_pool_asset_id() -> T::PoolAssetId
Returns the next pool asset id for benchmark purposes only.
Trait Implementations§
source§impl<T> Benchmarking for Pallet<T>where
    T: Config + Config,
    T::AssetBalance: From<u128> + Into<u128>,
    T::Currency: Unbalanced<T::AccountId>,
    T::Balance: From<u128> + Into<u128>,
    T::Assets: Create<T::AccountId> + Mutate<T::AccountId>,
    T::PoolAssetId: Into<u32>,
 
impl<T> Benchmarking for Pallet<T>where T: Config + Config, T::AssetBalance: From<u128> + Into<u128>, T::Currency: Unbalanced<T::AccountId>, T::Balance: From<u128> + Into<u128>, T::Assets: Create<T::AccountId> + Mutate<T::AccountId>, T::PoolAssetId: Into<u32>,
source§fn benchmarks(extra: bool) -> Vec<BenchmarkMetadata>
 
fn benchmarks(extra: bool) -> Vec<BenchmarkMetadata>
source§fn run_benchmark(
    extrinsic: &[u8],
    c: &[(BenchmarkParameter, u32)],
    whitelist: &[TrackedStorageKey],
    verify: bool,
    internal_repeats: u32
) -> Result<Vec<BenchmarkResult>, BenchmarkError>
 
fn run_benchmark( extrinsic: &[u8], c: &[(BenchmarkParameter, u32)], whitelist: &[TrackedStorageKey], verify: bool, internal_repeats: u32 ) -> Result<Vec<BenchmarkResult>, BenchmarkError>
source§impl<T: Config> GetStorageVersion for Pallet<T>
 
impl<T: Config> GetStorageVersion for Pallet<T>
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>
source§fn integrity_test()
 
fn integrity_test()
source§fn on_initialize(_n: BlockNumber) -> Weight
 
fn on_initialize(_n: BlockNumber) -> Weight
source§fn on_finalize(_n: BlockNumber)
 
fn on_finalize(_n: BlockNumber)
source§fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
 
fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
Hooks::on_finalize). Read moresource§fn on_runtime_upgrade() -> Weight
 
fn on_runtime_upgrade() -> Weight
source§fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
 
fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
source§fn pre_upgrade() -> Result<Vec<u8, Global>, DispatchError>
 
fn pre_upgrade() -> Result<Vec<u8, Global>, DispatchError>
source§fn post_upgrade(_state: Vec<u8, Global>) -> Result<(), DispatchError>
 
fn post_upgrade(_state: Vec<u8, Global>) -> Result<(), DispatchError>
source§fn offchain_worker(_n: BlockNumber)
 
fn offchain_worker(_n: BlockNumber)
source§impl<T: Config> IntegrityTest for Pallet<T>
 
impl<T: Config> IntegrityTest for Pallet<T>
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§fn on_idle(n: BlockNumberFor<T>, remaining_weight: Weight) -> Weight
 
fn on_idle(n: BlockNumberFor<T>, remaining_weight: Weight) -> Weight
Hooks::on_idle.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
source§fn pre_upgrade() -> Result<Vec<u8>, TryRuntimeError>
 
fn pre_upgrade() -> Result<Vec<u8>, TryRuntimeError>
Hooks::pre_upgrade.source§fn post_upgrade(state: Vec<u8>) -> Result<(), TryRuntimeError>
 
fn post_upgrade(state: Vec<u8>) -> Result<(), TryRuntimeError>
Hooks::post_upgrade.source§fn try_on_runtime_upgrade(checks: bool) -> Result<Weight, DispatchError>
 
fn try_on_runtime_upgrade(checks: bool) -> Result<Weight, DispatchError>
pre_upgrade ->
on_runtime_upgrade -> post_upgrade hooks for a migration. Read moresource§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: Config> PalletsInfoAccess for Pallet<T>
 
impl<T: Config> PalletsInfoAccess for Pallet<T>
source§impl<T> PartialEq<Pallet<T>> for Pallet<T>
 
impl<T> PartialEq<Pallet<T>> for Pallet<T>
source§impl<T: Config> StorageInfoTrait for Pallet<T>
 
impl<T: Config> StorageInfoTrait for Pallet<T>
fn storage_info() -> Vec<StorageInfo>
source§impl<T: Config> Swap<<T as Config>::AccountId, <T as Config>::HigherPrecisionBalance, <T as Config>::MultiAssetId> for Pallet<T>
 
impl<T: Config> Swap<<T as Config>::AccountId, <T as Config>::HigherPrecisionBalance, <T as Config>::MultiAssetId> for Pallet<T>
source§fn swap_exact_tokens_for_tokens(
    sender: T::AccountId,
    path: Vec<T::MultiAssetId>,
    amount_in: T::HigherPrecisionBalance,
    amount_out_min: Option<T::HigherPrecisionBalance>,
    send_to: T::AccountId,
    keep_alive: bool
) -> Result<T::HigherPrecisionBalance, DispatchError>
 
fn swap_exact_tokens_for_tokens( sender: T::AccountId, path: Vec<T::MultiAssetId>, amount_in: T::HigherPrecisionBalance, amount_out_min: Option<T::HigherPrecisionBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::HigherPrecisionBalance, DispatchError>
amount_in of asset path[0] for asset path[1].
If an amount_out_min is specified, it will return an error if it is unable to acquire
the amount desired. Read moresource§fn swap_tokens_for_exact_tokens(
    sender: T::AccountId,
    path: Vec<T::MultiAssetId>,
    amount_out: T::HigherPrecisionBalance,
    amount_in_max: Option<T::HigherPrecisionBalance>,
    send_to: T::AccountId,
    keep_alive: bool
) -> Result<T::HigherPrecisionBalance, DispatchError>
 
fn swap_tokens_for_exact_tokens( sender: T::AccountId, path: Vec<T::MultiAssetId>, amount_out: T::HigherPrecisionBalance, amount_in_max: Option<T::HigherPrecisionBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::HigherPrecisionBalance, DispatchError>
path[0] asset and swap some amount for amount_out of the path[1]. If an
amount_in_max is specified, it will return an error if acquiring amount_out would be
too costly. Read moresource§impl<T: Config> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
 
impl<T: Config> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn try_state(
    n: BlockNumberFor<T>,
    _s: TryStateSelect
) -> Result<(), TryRuntimeError>
 
fn try_state( n: BlockNumberFor<T>, _s: TryStateSelect ) -> Result<(), TryRuntimeError>
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> CheckedConversion for T
 
impl<T> CheckedConversion for T
source§impl<Q, K> Equivalent<K> for Qwhere
    Q: Eq + ?Sized,
    K: Borrow<Q> + ?Sized,
 
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
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 Qwhere
    Q: Eq + ?Sized,
    K: Borrow<Q> + ?Sized,
 
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
source§impl<T> Instrument for T
 
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for Twhere
    Outer: AsRef<T> + AsMut<T> + From<T>,
    T: From<Outer>,
 
impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,
§impl<T> Pointable for T
 
impl<T> Pointable for T
source§impl<T> SaturatedConversion for T
 
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
    Self: UniqueSaturatedFrom<T>,
 
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
    Self: UniqueSaturatedInto<T>,
 
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
T. Read more§impl<SS, SP> SupersetOf<SS> for SPwhere
    SS: SubsetOf<SP>,
 
impl<SS, SP> SupersetOf<SS> for SPwhere SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
 
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
 
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
 
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
 
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.source§impl<S, T> UncheckedInto<T> for Swhere
    T: UncheckedFrom<S>,
 
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
 
fn unchecked_into(self) -> T
unchecked_from.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
    T: Bounded,
    S: TryInto<T>,
 
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
 
fn unique_saturated_into(self) -> T
T.