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§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