pub struct CallValueWrapper<A>{ /* private fields */ }

Implementations§

source§

impl<A> CallValueWrapper<A>

source

pub fn new() -> Self

source

pub fn moax_value(&self) -> BigUint<A>

Retrieves the MOAX call value from the VM. Will return 0 in case of an DCT transfer (cannot have both MOAX and DCT transfer simultaneously).

source

pub fn all_dct_transfers(&self) -> ManagedVec<A, DctTokenPayment<A>>

Returns all DCT transfers that accompany this SC call. Will return 0 results if nothing was transfered, or just MOAX. Fully managed underlying types, very efficient.

source

pub fn multi_dct<const N: usize>(&self) -> [DctTokenPayment<A>; N]

Verify and casts the received multi DCT transfer in to an array.

Can be used to extract all payments in one line like this:

let [payment_a, payment_b, payment_c] = self.call_value().multi_dct();.

source

pub fn single_dct(&self) -> DctTokenPayment<A>

Expects precisely one DCT token transfer, fungible or not.

Will return the received DCT payment.

The amount cannot be 0, since that would not qualify as an DCT transfer.

source

pub fn single_fungible_dct(&self) -> (TokenIdentifier<A>, BigUint<A>)

Expects precisely one fungible DCT token transfer.

Returns the token ID and the amount for fungible DCT transfers.

The amount cannot be 0, since that would not qualify as an DCT transfer.

source

pub fn dct_value(&self) -> BigUint<A>

Retrieves the DCT call value from the VM. Will return 0 in case of an MOAX transfer (cannot have both MOAX and DCT transfer simultaneously).

source

pub fn moax_or_single_dct(&self) -> MoaxOrDctTokenPayment<A>

Accepts and returns either an MOAX payment, or a single DCT token.

Will halt execution if more than one DCT transfer was received.

In case no transfer of value happen, it will return a payment of 0 MOAX.

source

pub fn moax_or_single_fungible_dct( &self ) -> (MoaxOrDctTokenIdentifier<A>, BigUint<A>)

Accepts and returns either an MOAX payment, or a single fungible DCT token.

Will halt execution if more than one DCT transfer was received, or if the received DCT is non- or semi-fungible.

Works similar to moax_or_single_dct, but checks the nonce to be 0 and returns a tuple of just token identifier and amount, for convenience.

In case no transfer of value happen, it will return a payment of 0 MOAX.

Trait Implementations§

source§

impl<A> Default for CallValueWrapper<A>

source§

fn default() -> CallValueWrapper<A>

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<A> CodecFromSelf for CallValueWrapper<A>
where A: CodecFromSelf,

§

impl<A> RefUnwindSafe for CallValueWrapper<A>
where A: RefUnwindSafe,

§

impl<A> Send for CallValueWrapper<A>
where A: Send,

§

impl<A> Sync for CallValueWrapper<A>
where A: Sync,

§

impl<A> Unpin for CallValueWrapper<A>
where A: Unpin,

§

impl<A> UnwindSafe for CallValueWrapper<A>
where A: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where 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> TryFrom<U> for T
where 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 T
where 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.