Struct multiversx_sc_snippets::imports::FunctionCall  
source · pub struct FunctionCall<Api>where
    Api: ManagedTypeApi,{
    pub function_name: ManagedBuffer<Api>,
    pub arg_buffer: ManagedArgBuffer<Api>,
}Expand description
Encodes a function call on the blockchain, composed of a function name and its encoded arguments.
Can be used as a multi-argument, to embed a call within a call.
Fields§
§function_name: ManagedBuffer<Api>§arg_buffer: ManagedArgBuffer<Api>Implementations§
source§impl<Api> FunctionCall<Api>where
    Api: ManagedTypeApi,
 
impl<Api> FunctionCall<Api>where
    Api: ManagedTypeApi,
sourcepub fn new<N>(function_name: N) -> FunctionCall<Api>where
    N: Into<ManagedBuffer<Api>>,
 
pub fn new<N>(function_name: N) -> FunctionCall<Api>where
    N: Into<ManagedBuffer<Api>>,
Initializes a new function call with a function call name.
The arguments will need to be added afterwards.
sourcepub fn empty() -> FunctionCall<Api>
 
pub fn empty() -> FunctionCall<Api>
Initializes a new empty function call, this means no function name and no arguments.
sourcepub fn is_empty(&self) -> bool
 
pub fn is_empty(&self) -> bool
Empty function calls have empty function names.
There should be no function call with empty function call but with arguments.
sourcepub fn argument<T>(self, arg: &T) -> FunctionCall<Api>where
    T: TopEncodeMulti,
 
pub fn argument<T>(self, arg: &T) -> FunctionCall<Api>where
    T: TopEncodeMulti,
Adds an argument of any serializable type.
Multi-values are accepted. No type checking performed.
pub fn arguments_raw(self, raw: ManagedArgBuffer<Api>) -> FunctionCall<Api>
pub fn typed_result<R>(self) -> TypedFunctionCall<Api, R>where
    R: TopEncodeMulti + TopDecodeMulti,
Trait Implementations§
source§impl<Api> Clone for FunctionCall<Api>where
    Api: Clone + ManagedTypeApi,
 
impl<Api> Clone for FunctionCall<Api>where
    Api: Clone + ManagedTypeApi,
source§fn clone(&self) -> FunctionCall<Api>
 
fn clone(&self) -> FunctionCall<Api>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from 
source. Read moresource§impl<Api> From<()> for FunctionCall<Api>where
    Api: ManagedTypeApi,
 
impl<Api> From<()> for FunctionCall<Api>where
    Api: ManagedTypeApi,
source§fn from(_: ()) -> FunctionCall<Api>
 
fn from(_: ()) -> FunctionCall<Api>
Converts to this type from the input type.
source§impl<Api, R> From<ContractCallNoPayment<Api, R>> for FunctionCall<Api>where
    Api: CallTypeApi,
 
impl<Api, R> From<ContractCallNoPayment<Api, R>> for FunctionCall<Api>where
    Api: CallTypeApi,
source§fn from(ccnp: ContractCallNoPayment<Api, R>) -> FunctionCall<Api>
 
fn from(ccnp: ContractCallNoPayment<Api, R>) -> FunctionCall<Api>
Converts to this type from the input type.
source§impl<Api, OriginalResult> From<FunctionCall<Api>> for TypedFunctionCall<Api, OriginalResult>where
    Api: ManagedTypeApi,
 
impl<Api, OriginalResult> From<FunctionCall<Api>> for TypedFunctionCall<Api, OriginalResult>where
    Api: ManagedTypeApi,
source§fn from(
    function_call: FunctionCall<Api>,
) -> TypedFunctionCall<Api, OriginalResult>
 
fn from( function_call: FunctionCall<Api>, ) -> TypedFunctionCall<Api, OriginalResult>
Converts to this type from the input type.
source§impl<Api> TopDecodeMulti for FunctionCall<Api>where
    Api: ManagedTypeApi,
 
impl<Api> TopDecodeMulti for FunctionCall<Api>where
    Api: ManagedTypeApi,
fn multi_decode_or_handle_err<I, H>(
    input: &mut I,
    h: H,
) -> Result<FunctionCall<Api>, <H as DecodeErrorHandler>::HandledErr>where
    I: TopDecodeMultiInput,
    H: DecodeErrorHandler,
source§const IS_SINGLE_VALUE: bool = false
 
const IS_SINGLE_VALUE: bool = false
Used to optimize single value loading of endpoint arguments.
fn multi_decode<I>(input: &mut I) -> Result<Self, DecodeError>where
    I: TopDecodeMultiInput,
source§impl<Api> TopEncodeMulti for FunctionCall<Api>where
    Api: ManagedTypeApi,
 
impl<Api> TopEncodeMulti for FunctionCall<Api>where
    Api: ManagedTypeApi,
source§fn multi_encode_or_handle_err<O, H>(
    &self,
    output: &mut O,
    h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
    O: TopEncodeMultiOutput,
    H: EncodeErrorHandler,
 
fn multi_encode_or_handle_err<O, H>(
    &self,
    output: &mut O,
    h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
    O: TopEncodeMultiOutput,
    H: EncodeErrorHandler,
Version of 
top_encode that can handle errors as soon as they occur.
For instance in can exit immediately and make sure that if it returns, it is a success.
By not deferring error handling, this can lead to somewhat smaller bytecode.source§fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
    O: TopEncodeMultiOutput,
 
fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
    O: TopEncodeMultiOutput,
Attempt to serialize the value to ouput.
source§impl<Env> TxData<Env> for FunctionCall<<Env as TxEnv>::Api>where
    Env: TxEnv,
 
impl<Env> TxData<Env> for FunctionCall<<Env as TxEnv>::Api>where
    Env: TxEnv,
fn is_no_call(&self) -> bool
fn to_call_data_string(&self) -> ManagedBuffer<<Env as TxEnv>::Api>
source§impl<Api> TypeAbi for FunctionCall<Api>where
    Api: ManagedTypeApi,
 
impl<Api> TypeAbi for FunctionCall<Api>where
    Api: ManagedTypeApi,
type Unmanaged = FunctionCall<Api>
fn type_name() -> String
fn type_name_rust() -> String
fn type_names() -> TypeNames
source§fn provide_type_descriptions<TDC>(accumulator: &mut TDC)where
    TDC: TypeDescriptionContainer,
 
fn provide_type_descriptions<TDC>(accumulator: &mut TDC)where
    TDC: TypeDescriptionContainer,
A type can provide more than its own name.
For instance, a struct can also provide the descriptions of the type of its fields.
TypeAbi doesn’t care for the exact accumulator type,
which is abstracted by the TypeDescriptionContainer trait.
impl<Env> TxDataFunctionCall<Env> for FunctionCall<<Env as TxEnv>::Api>where
    Env: TxEnv,
impl<Api> TypeAbiFrom<FunctionCall<Api>> for FunctionCall<Api>where
    Api: ManagedTypeApi,
Auto Trait Implementations§
impl<Api> Freeze for FunctionCall<Api>
impl<Api> RefUnwindSafe for FunctionCall<Api>
impl<Api> Send for FunctionCall<Api>
impl<Api> Sync for FunctionCall<Api>
impl<Api> Unpin for FunctionCall<Api>
impl<Api> UnwindSafe for FunctionCall<Api>
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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
 
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)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> InterpretableFrom<&T> for Twhere
    T: Clone,
 
impl<T> InterpretableFrom<&T> for Twhere
    T: Clone,
fn interpret_from(from: &T, _context: &InterpreterContext) -> T
source§impl<T> InterpretableFrom<T> for T
 
impl<T> InterpretableFrom<T> for T
fn interpret_from(from: T, _context: &InterpreterContext) -> T
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>
Converts 
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>
Converts 
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