pub struct Pallet<T>(_);
Expand description

Pallet for parachain staking

Implementations§

source§

impl<T: Config> Pallet<T>

source

pub fn set_total_selected( origin: OriginFor<T>, new: u32 ) -> DispatchResultWithPostInfo

Set the total number of collator candidates selected per round

  • changes are not applied until the start of the next round
source

pub fn set_collator_commission( origin: OriginFor<T>, new: Perbill ) -> DispatchResultWithPostInfo

Set the commission for all collators

source

pub fn join_candidates( origin: OriginFor<T>, bond: BalanceOf<T>, liquidity_token: CurrencyIdOf<T>, use_balance_from: Option<BondKind>, candidate_count: u32, liquidity_token_count: u32 ) -> DispatchResultWithPostInfo

Join the set of collator candidates

source

pub fn schedule_leave_candidates( origin: OriginFor<T>, candidate_count: u32 ) -> DispatchResultWithPostInfo

Request to leave the set of candidates. If successful, the account is immediately removed from the candidate pool to prevent selection as a collator.

source

pub fn execute_leave_candidates( origin: OriginFor<T>, candidate: T::AccountId, candidate_delegation_count: u32 ) -> DispatchResultWithPostInfo

Execute leave candidates request

source

pub fn cancel_leave_candidates( origin: OriginFor<T>, candidate_count: u32 ) -> DispatchResultWithPostInfo

Cancel open request to leave candidates

  • only callable by collator account
  • result upon successful call is the candidate is active in the candidate pool
source

pub fn go_offline(origin: OriginFor<T>) -> DispatchResultWithPostInfo

Temporarily leave the set of collator candidates without unbonding

source

pub fn go_online(origin: OriginFor<T>) -> DispatchResultWithPostInfo

Rejoin the set of collator candidates if previously had called go_offline

source

pub fn schedule_candidate_bond_more( origin: OriginFor<T>, more: BalanceOf<T>, use_balance_from: Option<BondKind> ) -> DispatchResultWithPostInfo

Request by collator candidate to increase self bond by more

source

pub fn schedule_candidate_bond_less( origin: OriginFor<T>, less: BalanceOf<T> ) -> DispatchResultWithPostInfo

Request by collator candidate to decrease self bond by less

source

pub fn execute_candidate_bond_request( origin: OriginFor<T>, candidate: T::AccountId, use_balance_from: Option<BondKind> ) -> DispatchResultWithPostInfo

Execute pending request to adjust the collator candidate self bond

source

pub fn cancel_candidate_bond_request( origin: OriginFor<T> ) -> DispatchResultWithPostInfo

Cancel pending request to adjust the collator candidate self bond

source

pub fn delegate( origin: OriginFor<T>, collator: T::AccountId, amount: BalanceOf<T>, use_balance_from: Option<BondKind>, candidate_delegation_count: u32, delegation_count: u32 ) -> DispatchResultWithPostInfo

If caller is not a delegator and not a collator, then join the set of delegators If caller is a delegator, then makes delegation to change their delegation state

source

pub fn schedule_leave_delegators( origin: OriginFor<T> ) -> DispatchResultWithPostInfo

Request to leave the set of delegators. If successful, the caller is scheduled to be allowed to exit. Success forbids future delegator actions until the request is invoked or cancelled.

source

pub fn execute_leave_delegators( origin: OriginFor<T>, delegator: T::AccountId, delegation_count: u32 ) -> DispatchResultWithPostInfo

Execute the right to exit the set of delegators and revoke all ongoing delegations.

source

pub fn cancel_leave_delegators( origin: OriginFor<T> ) -> DispatchResultWithPostInfo

Cancel a pending request to exit the set of delegators. Success clears the pending exit request (thereby resetting the delay upon another leave_delegators call).

source

pub fn schedule_revoke_delegation( origin: OriginFor<T>, collator: T::AccountId ) -> DispatchResultWithPostInfo

Request to revoke an existing delegation. If successful, the delegation is scheduled to be allowed to be revoked via the execute_delegation_request extrinsic.

source

pub fn schedule_delegator_bond_more( origin: OriginFor<T>, candidate: T::AccountId, more: BalanceOf<T>, use_balance_from: Option<BondKind> ) -> DispatchResultWithPostInfo

Request to bond more for delegators wrt a specific collator candidate.

source

pub fn schedule_delegator_bond_less( origin: OriginFor<T>, candidate: T::AccountId, less: BalanceOf<T> ) -> DispatchResultWithPostInfo

Request bond less for delegators wrt a specific collator candidate.

source

pub fn execute_delegation_request( origin: OriginFor<T>, delegator: T::AccountId, candidate: T::AccountId, use_balance_from: Option<BondKind> ) -> DispatchResultWithPostInfo

Execute pending request to change an existing delegation

source

pub fn cancel_delegation_request( origin: OriginFor<T>, candidate: T::AccountId ) -> DispatchResultWithPostInfo

Cancel request to change an existing delegation.

source

pub fn add_staking_liquidity_token( origin: OriginFor<T>, paired_or_liquidity_token: PairedOrLiquidityToken<CurrencyIdOf<T>>, current_liquidity_tokens: u32 ) -> DispatchResultWithPostInfo

Enables new staking token to be used for staking. Only tokens paired with MGX can be used. Caller can pass the id of token for which MGX paired pool already exists or liquidity token id itself. Root only

source

pub fn remove_staking_liquidity_token( origin: OriginFor<T>, paired_or_liquidity_token: PairedOrLiquidityToken<CurrencyIdOf<T>>, current_liquidity_tokens: u32 ) -> DispatchResultWithPostInfo

Removes previously added liquidity token

source

pub fn aggregator_update_metadata( origin: OriginFor<T>, collator_candidates: Vec<T::AccountId>, action: MetadataUpdateAction ) -> DispatchResultWithPostInfo

Modifies aggregator metadata by extending or reducing list of approved candidates Account may only become aggregator only if its not collator or delegator at the moment

source

pub fn update_candidate_aggregator( origin: OriginFor<T>, maybe_aggregator: Option<T::AccountId> ) -> DispatchResultWithPostInfo

Assigns/replaces the candidate that given collator wants to aggregate under

source

pub fn payout_collator_rewards( origin: OriginFor<T>, collator: T::AccountId, number_of_sesisons: Option<u32> ) -> DispatchResultWithPostInfo

This extrinsic should be used to distribute rewards for collator and assodiated delegators. As round rewards are processed in random order its impossible predict how many delegators (and assodiated transfer extrinsic calls) will be required so worst case scenario (delegators_count = MaxCollatorCandidates) is assumed.

params:

  • collator - account id
  • limit - number of rewards periods that should be processed within extrinsic. Note that limit assumes worst case scenario of (delegators_count = MaxCollatorCandidates) so as a result, limit or more session round rewards may be distributed
source

pub fn payout_delegator_reward( origin: OriginFor<T>, round: u32, collator: T::AccountId, delegator: T::AccountId ) -> DispatchResultWithPostInfo

Payout delegator rewards only for particular round. Collators should rather use Pallet::payout_collator_rewards but if collator is inresponsive one can claim particular delegator rewards manually.

source§

impl<T: Config> Pallet<T>

source

pub fn payout_reward( round: u32, to: T::AccountId, amt: BalanceOf<T>, kind: RewardKind<T::AccountId> ) -> DispatchResult

source

pub fn is_delegator(acc: &T::AccountId) -> bool

source

pub fn is_candidate(acc: &T::AccountId) -> bool

source

pub fn is_aggregator(acc: &T::AccountId) -> bool

source

pub fn is_selected_candidate(acc: &T::AccountId) -> bool

source

pub fn do_update_candidate_aggregator( candidate: &T::AccountId, maybe_aggregator: Option<T::AccountId> ) -> DispatchResult

source

pub fn calculate_collators_valuations<'a, I>( valuated_bond_it: I ) -> BTreeMap<T::AccountId, BalanceOf<T>>where I: Iterator<Item = (&'a Bond<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>, BalanceOf<T>)> + Clone,

source

pub fn calculate_aggregators_collator_info<'a, I>( valuated_bond_it: I ) -> BTreeMap<T::AccountId, BTreeMap<T::AccountId, BalanceOf<T>>>where I: Iterator<Item = (&'a Bond<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>, BalanceOf<T>)>,

source

pub fn calculate_valuations_and_aggregation_info( ) -> (BTreeMap<T::AccountId, BalanceOf<T>>, BTreeMap<T::AccountId, BTreeMap<T::AccountId, BalanceOf<T>>>)

source

pub fn compute_top_candidates( ) -> (Vec<(T::AccountId, BalanceOf<T>)>, Vec<(T::AccountId, BalanceOf<T>)>, BTreeMap<T::AccountId, BTreeMap<T::AccountId, BalanceOf<T>>>)

Compute the top TotalSelected candidates in the CandidatePool and return a vec of their AccountIds (in the order of selection)

source

pub fn staking_liquidity_tokens_snapshot()

source

pub fn select_top_candidates(now: u32) -> (u32, u32, BalanceOf<T>)

Best as in most cumulatively supported in terms of stake Returns [collator_count, delegation_count, total staked]

flowchart A[Start] --> B{for all candidates} B -- Is aggregating under Aggregator? --> C[increase Aggreagator valuation] B -- Is solo collator? --> D[increase collator valuation] C --> E[collect final valuations of solo collators and aggregators] D --> E E -- list of solo collators and aggregators only--> F[pick top N valuated accounts] F --> G{for every block author} G -- author --> Z[persist into SelectedCandidates runtime storage] G -- author --> Y{Is solo collator or Aggregator} Y -- is solo collator --> I[emit CollatorChosen event] Y -- is aggregator --> H{for every associated collator} H --> I
source§

impl<T: Config> Pallet<T>

source

pub fn collator_commission() -> Perbill

An auto-generated getter for CollatorCommission.

source§

impl<T: Config> Pallet<T>

source

pub fn total_selected() -> u32

An auto-generated getter for TotalSelected.

source§

impl<T: Config> Pallet<T>

source

pub fn round() -> RoundInfo<BlockNumberFor<T>>

An auto-generated getter for Round.

source§

impl<T: Config> Pallet<T>

source

pub fn delegator_state<KArg>( k: KArg ) -> Option<Delegator<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>>where KArg: EncodeLike<T::AccountId>,

An auto-generated getter for DelegatorState.

source§

impl<T: Config> Pallet<T>

source

pub fn candidate_state<KArg>( k: KArg ) -> Option<CollatorCandidate<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>>where KArg: EncodeLike<T::AccountId>,

An auto-generated getter for CandidateState.

source§

impl<T: Config> Pallet<T>

source

pub fn selected_candidates() -> Vec<T::AccountId>

An auto-generated getter for SelectedCandidates.

source§

impl<T: Config> Pallet<T>

source

pub fn total<KArg>(k: KArg) -> BalanceOf<T>where KArg: EncodeLike<CurrencyIdOf<T>>,

An auto-generated getter for Total.

source§

impl<T: Config> Pallet<T>

source

pub fn candidate_pool( ) -> OrderedSet<Bond<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>>

An auto-generated getter for CandidatePool.

source§

impl<T: Config> Pallet<T>

source

pub fn at_stake<KArg1, KArg2>( k1: KArg1, k2: KArg2 ) -> CollatorSnapshot<T::AccountId, BalanceOf<T>, CurrencyIdOf<T>>where KArg1: EncodeLike<u32>, KArg2: EncodeLike<T::AccountId>,

An auto-generated getter for AtStake.

source§

impl<T: Config> Pallet<T>

source

pub fn points<KArg>(k: KArg) -> u32where KArg: EncodeLike<u32>,

An auto-generated getter for Points.

source§

impl<T: Config> Pallet<T>

source

pub fn awarded_pts<KArg1, KArg2>(k1: KArg1, k2: KArg2) -> u32where KArg1: EncodeLike<u32>, KArg2: EncodeLike<T::AccountId>,

An auto-generated getter for AwardedPts.

source§

impl<T: Config> Pallet<T>

source

pub fn staking_liquidity_tokens( ) -> BTreeMap<CurrencyIdOf<T>, Option<(BalanceOf<T>, BalanceOf<T>)>>

An auto-generated getter for StakingLiquidityTokens.

source§

impl<T: Config> Pallet<T>

source

pub fn get_candidate_aggregator() -> BTreeMap<T::AccountId, T::AccountId>

An auto-generated getter for CandidateAggregator.

source§

impl<T: Config> Pallet<T>

source

pub fn get_aggregator_metadata<KArg>( k: KArg ) -> Option<AggregatorMetadataType<T::AccountId, CurrencyIdOf<T>>>where KArg: EncodeLike<T::AccountId>,

An auto-generated getter for AggregatorMetadata.

source§

impl<T: Config> Pallet<T>

source

pub fn get_round_aggregator_info<KArg>( k: KArg ) -> Option<BTreeMap<T::AccountId, BTreeMap<T::AccountId, BalanceOf<T>>>>where KArg: EncodeLike<u32>,

An auto-generated getter for RoundAggregatorInfo.

source§

impl<T: Config> Pallet<T>

source

pub fn get_round_collator_reward_info<KArg1, KArg2>( k1: KArg1, k2: KArg2 ) -> Option<RoundCollatorRewardInfoType<T::AccountId, BalanceOf<T>>>where KArg1: EncodeLike<T::AccountId>, KArg2: EncodeLike<u32>,

An auto-generated getter for RoundCollatorRewardInfo.

Trait Implementations§

source§

impl<T: Config> Callable<T> for Pallet<T>

source§

impl<T> Clone for Pallet<T>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T> Debug for Pallet<T>

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T: Config> EstimateNextSessionRotation<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn average_session_length() -> BlockNumberFor<T>

Return the average length of a session. Read more
source§

fn estimate_current_session_progress( now: BlockNumberFor<T> ) -> (Option<Permill>, Weight)

Return an estimate of the current session progress. Read more
source§

fn estimate_next_session_rotation( _now: BlockNumberFor<T> ) -> (Option<BlockNumberFor<T>>, Weight)

Return the block number at which the next session rotation is estimated to happen. Read more
source§

impl<T: Config> EventHandler<<T as Config>::AccountId, <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

Add reward points to block authors:

  • 20 points to the block producer for producing a block in the chain
source§

fn note_author(author: T::AccountId)

Note that the given account ID is the author of the current block.
source§

impl<T: Config> GetStorageVersion for Pallet<T>

§

type CurrentStorageVersion = NoStorageVersionSet

This will be filled out by the pallet macro. Read more
source§

fn current_storage_version() -> Self::CurrentStorageVersion

Returns the current storage version as supported by the pallet.
source§

fn on_chain_storage_version() -> StorageVersion

Returns the on-chain storage version of the pallet as stored in the storage.
source§

impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn on_idle(_now: BlockNumberFor<T>, remaining_weight: Weight) -> Weight

Hook to consume a block’s idle time. This will run when the block is being finalized (before Hooks::on_finalize). Read more
source§

fn on_initialize(_n: BlockNumber) -> Weight

Block initialization hook. This is called at the very beginning of block execution. Read more
source§

fn on_finalize(_n: BlockNumber)

Block finalization hook. This is called at the very end of block execution. Read more
source§

fn on_runtime_upgrade() -> Weight

Hook executed when a code change (aka. a “runtime upgrade”) is detected by FRAME. Read more
source§

fn offchain_worker(_n: BlockNumber)

Implementing this function on a pallet allows you to perform long-running tasks that are dispatched as separate threads, and entirely independent of the main wasm runtime. Read more
source§

fn integrity_test()

Check the integrity of this pallet’s configuration. Read more
source§

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>

source§

fn offchain_worker(n: BlockNumberFor<T>)

This function is being called after every block import (when fully synced). Read more
source§

impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

impl<T: Config> OnGenesis for Pallet<T>

source§

fn on_genesis()

Something that should happen at genesis.
source§

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

source§

impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

impl<T: Config> OnRuntimeUpgrade for Pallet<T>

source§

impl<T: Config> PalletInfoAccess for Pallet<T>

source§

fn index() -> usize

Index of the pallet as configured in the runtime.
source§

fn name() -> &'static str

Name of the pallet as configured in the runtime.
source§

fn module_name() -> &'static str

Name of the Rust module containing the pallet.
source§

fn crate_version() -> CrateVersion

Version of the crate containing the pallet.
source§

impl<T: Config> PalletsInfoAccess for Pallet<T>

source§

fn count() -> usize

The number of pallets’ information that this type represents. Read more
source§

fn infos() -> Vec<PalletInfoData>

All of the pallets’ information that this type represents.
source§

impl<T> PartialEq<Pallet<T>> for Pallet<T>

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<T: Config> SessionManager<<T as Config>::AccountId> for Pallet<T>

source§

fn new_session(_: SessionIndex) -> Option<Vec<T::AccountId>>

Plan a new session, and optionally provide the new validator set. Read more
source§

fn start_session(session_index: SessionIndex)

Start an already planned session. Read more
source§

fn end_session(_: SessionIndex)

End the session. Read more
source§

fn new_session_genesis(new_index: u32) -> Option<Vec<ValidatorId, Global>>

Same as new_session, but it this should only be called at genesis. Read more
source§

impl<T: Config> ShouldEndSession<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>

source§

fn should_end_session(now: BlockNumberFor<T>) -> bool

Return true if the session should be ended.
source§

impl<T: Config> StorageInfoTrait for Pallet<T>

source§

impl<T: Config> WhitelistedStorageKeys for Pallet<T>

source§

fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>

Returns a 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.
source§

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> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CheckedConversion for T

source§

fn checked_from<T>(t: T) -> Option<Self>where Self: TryFrom<T>,

Convert from a value of T into an equivalent instance of Option<Self>. Read more
source§

fn checked_into<T>(self) -> Option<T>where Self: TryInto<T>,

Consume self to return Some equivalent value of Option<T>. Read more
source§

impl<T> Conv for T

source§

fn conv<T>(self) -> Twhere Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> DynClone for Twhere T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<T> FmtForward for T

source§

fn fmt_binary(self) -> FmtBinary<Self>where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
source§

fn fmt_display(self) -> FmtDisplay<Self>where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
source§

fn fmt_octal(self) -> FmtOctal<Self>where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
source§

fn fmt_pointer(self) -> FmtPointer<Self>where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
source§

fn fmt_list(self) -> FmtList<Self>where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> Into2<U> for Twhere U: From2<T>,

source§

fn into2(self) -> U

source§

impl<T> IsType<T> for T

source§

fn from_ref(t: &T) -> &T

Cast reference.
source§

fn into_ref(&self) -> &T

Cast reference.
source§

fn from_mut(t: &mut T) -> &mut T

Cast mutable reference.
source§

fn into_mut(&mut self) -> &mut T

Cast mutable reference.
source§

impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

source§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

source§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

source§

impl<T> Pipe for Twhere T: ?Sized,

source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> Rwhere Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> Rwhere Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> Rwhere Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> Rwhere Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> Rwhere Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> Rwhere Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
source§

impl<T> Pointable for T

source§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> SaturatedConversion for T

source§

fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,

Convert from a value of T into an equivalent instance of Self. Read more
source§

fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,

Consume self to return an equivalent value of T. Read more
source§

impl<T> Tap for T

source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Selfwhere Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Selfwhere Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Selfwhere Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Selfwhere Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Selfwhere Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Selfwhere Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> TryConv for T

source§

fn try_conv<T>(self) -> Result<T, Self::Error>where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto2<U> for Twhere U: TryFrom2<T>,

§

type Error = <U as TryFrom2<T>>::Error

source§

fn try_into2(self) -> Result<U, <U as TryFrom2<T>>::Error>

source§

impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,

source§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
source§

impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,

source§

fn unique_saturated_into(self) -> T

Consume self to return an equivalent value of T.
source§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> JsonSchemaMaybe for T

source§

impl<T> MaybeDebug for Twhere T: Debug,

source§

impl<T> MaybeRefUnwindSafe for Twhere T: RefUnwindSafe,

source§

impl<T> Member for Twhere T: Send + Sync + Debug + Eq + PartialEq<T> + Clone + 'static,