Struct ink_env::call::CallBuilder
source · pub struct CallBuilder<E, CallType, Args, RetType>where
E: Environment,{ /* private fields */ }
Expand description
Builds up a cross contract call.
Implementations§
source§impl<E, Args, RetType> CallBuilder<E, Set<Call<E>>, Args, RetType>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<Call<E>>, Args, RetType>where
E: Environment,
sourcepub fn call_v1(self) -> CallBuilder<E, Set<CallV1<E>>, Args, RetType>
pub fn call_v1(self) -> CallBuilder<E, Set<CallV1<E>>, Args, RetType>
Switch to the original call
host function API, which only allows the gas_limit
limit parameter (equivalent to the ref_time_limit
in the latest call_v2
).
This method instance is used to allow usage of the generated call builder methods
for messages which initialize the builder with the new Call
type.
sourcepub fn ref_time_limit(self, ref_time_limit: Gas) -> Self
pub fn ref_time_limit(self, ref_time_limit: Gas) -> Self
Sets the ref_time_limit
part of the weight limit for the current cross-contract
call.
ref_time
refers to the amount of computational time that can be
used for execution, in picoseconds. You can find more info
here.
sourcepub fn proof_size_limit(self, proof_size_limit: Gas) -> Self
pub fn proof_size_limit(self, proof_size_limit: Gas) -> Self
Sets the proof_size_limit
part of the weight limit for the current
cross-contract call.
proof_size
refers to the amount of storage in bytes that a transaction
is allowed to read. You can find more info
here.
Note
This limit is only relevant for parachains, not for standalone chains which do not require sending a Proof-of-validity to the relay chain.
sourcepub fn storage_deposit_limit(self, storage_deposit_limit: E::Balance) -> Self
pub fn storage_deposit_limit(self, storage_deposit_limit: E::Balance) -> Self
Sets the storage_deposit_limit
for the current cross-contract call.
The storage_deposit_limit
specifies the amount of user funds that
can be charged for creating storage. You can find more info
here.
sourcepub fn transferred_value(self, transferred_value: E::Balance) -> Self
pub fn transferred_value(self, transferred_value: E::Balance) -> Self
Sets the transferred_value
for the current cross-contract call.
This value specifies the amount of user funds that are transferred to the other contract with this call.
sourcepub fn call_flags(self, call_flags: CallFlags) -> Self
pub fn call_flags(self, call_flags: CallFlags) -> Self
Sets the call_flags
for the current cross-contract call.
These flags are used to change the behavior of the contract call.
source§impl<E, Args, RetType> CallBuilder<E, Set<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, Call<E>, Args, RetType>
pub fn params(self) -> CallParams<E, Call<E>, Args, RetType>
Finalizes the call builder to call a function.
source§impl<E, RetType> CallBuilder<E, Set<Call<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
impl<E, RetType> CallBuilder<E, Set<Call<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, Call<E>, EmptyArgumentList, ()>
pub fn params(self) -> CallParams<E, Call<E>, EmptyArgumentList, ()>
Finalizes the call builder to call a function.
source§impl<E> CallBuilder<E, Set<Call<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
impl<E> CallBuilder<E, Set<Call<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
sourcepub fn invoke(self)
pub fn invoke(self)
Invokes the cross-chain function call.
§Panics
This method panics if it encounters an ink::env::Error
or an
[ink::primitives::LangError
][ink_primitives::LangError
]. If you want to handle
those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<()>, Error>
pub fn try_invoke(self) -> Result<MessageResult<()>, Error>
Invokes the cross-chain function call.
§Note
On failure this returns an outer ink::env::Error
or inner
[ink::primitives::LangError
][ink_primitives::LangError
], both of which can be
handled by the caller.
source§impl<E, Args, R> CallBuilder<E, Set<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
impl<E, Args, R> CallBuilder<E, Set<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
sourcepub fn invoke(self) -> R
pub fn invoke(self) -> R
Invokes the cross-chain function call and returns the result.
§Panics
This method panics if it encounters an ink::env::Error
or an
[ink::primitives::LangError
][ink_primitives::LangError
]. If you want to handle
those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<R>, Error>
pub fn try_invoke(self) -> Result<MessageResult<R>, Error>
Invokes the cross-chain function call and returns the result.
§Note
On failure this returns an outer ink::env::Error
or inner
[ink::primitives::LangError
][ink_primitives::LangError
], both of which can be
handled by the caller.
source§impl<E, Args, RetType> CallBuilder<E, Set<CallV1<E>>, Args, RetType>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<CallV1<E>>, Args, RetType>where
E: Environment,
sourcepub fn gas_limit(self, gas_limit: Gas) -> Self
pub fn gas_limit(self, gas_limit: Gas) -> Self
Sets the gas_limit
for the current cross-contract call.
sourcepub fn transferred_value(self, transferred_value: E::Balance) -> Self
pub fn transferred_value(self, transferred_value: E::Balance) -> Self
Sets the transferred_value
for the current cross-contract call.
sourcepub fn call_flags(self, call_flags: CallFlags) -> Self
pub fn call_flags(self, call_flags: CallFlags) -> Self
Sets the flags used to change the behavior of the contract call.
source§impl<E, Args, RetType> CallBuilder<E, Set<CallV1<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<CallV1<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, CallV1<E>, Args, RetType>
pub fn params(self) -> CallParams<E, CallV1<E>, Args, RetType>
Finalizes the call builder to call a function.
source§impl<E, RetType> CallBuilder<E, Set<CallV1<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
impl<E, RetType> CallBuilder<E, Set<CallV1<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, CallV1<E>, EmptyArgumentList, ()>
pub fn params(self) -> CallParams<E, CallV1<E>, EmptyArgumentList, ()>
Finalizes the call builder to call a function.
source§impl<E> CallBuilder<E, Set<CallV1<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
impl<E> CallBuilder<E, Set<CallV1<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
sourcepub fn invoke(self)
pub fn invoke(self)
Invokes the cross-chain function call.
§Panics
This method panics if it encounters an ink::env::Error
or an
[ink::primitives::LangError
][ink_primitives::LangError
]. If you want to handle
those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<()>, Error>
pub fn try_invoke(self) -> Result<MessageResult<()>, Error>
Invokes the cross-chain function call.
§Note
On failure this returns an outer ink::env::Error
or inner
[ink::primitives::LangError
][ink_primitives::LangError
], both of which can be
handled by the caller.
source§impl<E, Args, R> CallBuilder<E, Set<CallV1<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
impl<E, Args, R> CallBuilder<E, Set<CallV1<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
sourcepub fn invoke(self) -> R
pub fn invoke(self) -> R
Invokes the cross-chain function call and returns the result.
§Panics
This method panics if it encounters an ink::env::Error
or an
[ink::primitives::LangError
][ink_primitives::LangError
]. If you want to handle
those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<R>, Error>
pub fn try_invoke(self) -> Result<MessageResult<R>, Error>
Invokes the cross-chain function call and returns the result.
§Note
On failure this returns an outer ink::env::Error
or inner
[ink::primitives::LangError
][ink_primitives::LangError
], both of which can be
handled by the caller.
source§impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall<E>>, Args, RetType>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall<E>>, Args, RetType>where
E: Environment,
source§impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, DelegateCall<E>, Args, RetType>
pub fn params(self) -> CallParams<E, DelegateCall<E>, Args, RetType>
Finalizes the call builder to call a function.
source§impl<E, RetType> CallBuilder<E, Set<DelegateCall<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
impl<E, RetType> CallBuilder<E, Set<DelegateCall<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, DelegateCall<E>, EmptyArgumentList, ()>
pub fn params(self) -> CallParams<E, DelegateCall<E>, EmptyArgumentList, ()>
Finalizes the call builder to call a function.
source§impl<E> CallBuilder<E, Set<DelegateCall<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
impl<E> CallBuilder<E, Set<DelegateCall<E>>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
sourcepub fn invoke(self)
pub fn invoke(self)
Invokes the cross-chain function call using Delegate Call semantics.
§Panics
This method panics if it encounters an ink::env::Error
If you want to handle those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<()>, Error>
pub fn try_invoke(self) -> Result<MessageResult<()>, Error>
Invokes the cross-chain function call using Delegate Call semantics.
§Note
On failure this an ink::env::Error
which can be handled by the
caller.
source§impl<E, Args, R> CallBuilder<E, Set<DelegateCall<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
impl<E, Args, R> CallBuilder<E, Set<DelegateCall<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
sourcepub fn invoke(self) -> R
pub fn invoke(self) -> R
Invokes the cross-chain function call using Delegate Call semantics and returns the result.
§Panics
This method panics if it encounters an ink::env::Error
or an
[ink::primitives::LangError
][ink_primitives::LangError
]. If you want to handle
those use the try_invoke
method instead.
sourcepub fn try_invoke(self) -> Result<MessageResult<R>, Error>
pub fn try_invoke(self) -> Result<MessageResult<R>, Error>
Invokes the cross-chain function call using Delegate Call semantics and returns the result.
§Note
On failure this returns an outer ink::env::Error
or inner
[ink::primitives::LangError
][ink_primitives::LangError
], both of which can be
handled by the caller.
source§impl<E, CallType, Args, RetType> CallBuilder<E, Unset<CallType>, Args, RetType>where
E: Environment,
impl<E, CallType, Args, RetType> CallBuilder<E, Unset<CallType>, Args, RetType>where
E: Environment,
sourcepub fn call_type<NewCallType>(
self,
call_type: NewCallType,
) -> CallBuilder<E, Set<NewCallType>, Args, RetType>
pub fn call_type<NewCallType>( self, call_type: NewCallType, ) -> CallBuilder<E, Set<NewCallType>, Args, RetType>
The type of the call.
source§impl<E, CallType, Args> CallBuilder<E, CallType, Args, Unset<ReturnType<()>>>where
E: Environment,
impl<E, CallType, Args> CallBuilder<E, CallType, Args, Unset<ReturnType<()>>>where
E: Environment,
sourcepub fn returns<R>(self) -> CallBuilder<E, CallType, Args, Set<ReturnType<R>>>
pub fn returns<R>(self) -> CallBuilder<E, CallType, Args, Set<ReturnType<R>>>
Sets the type of the returned value upon the execution of the call.
§Note
Either use .returns::<()>
to signal that the call does not return a value
or use .returns::<T>
to signal that the call returns a value of type T
.
source§impl<E, CallType, RetType> CallBuilder<E, CallType, Unset<ExecutionInput<EmptyArgumentList>>, RetType>where
E: Environment,
impl<E, CallType, RetType> CallBuilder<E, CallType, Unset<ExecutionInput<EmptyArgumentList>>, RetType>where
E: Environment,
sourcepub fn exec_input<Args>(
self,
exec_input: ExecutionInput<Args>,
) -> CallBuilder<E, CallType, Set<ExecutionInput<Args>>, RetType>
pub fn exec_input<Args>( self, exec_input: ExecutionInput<Args>, ) -> CallBuilder<E, CallType, Set<ExecutionInput<Args>>, RetType>
Sets the execution input to the given value.
source§impl<E, CallType, Args, RetType> CallBuilder<E, Unset<CallType>, Args, RetType>where
E: Environment,
impl<E, CallType, Args, RetType> CallBuilder<E, Unset<CallType>, Args, RetType>where
E: Environment,
sourcepub fn call_v1(
self,
callee: E::AccountId,
) -> CallBuilder<E, Set<CallV1<E>>, Args, RetType>
pub fn call_v1( self, callee: E::AccountId, ) -> CallBuilder<E, Set<CallV1<E>>, Args, RetType>
Prepares the CallBuilder
for a cross-contract CallV1
, calling into the
original call
host function.
sourcepub fn call(
self,
callee: E::AccountId,
) -> CallBuilder<E, Set<Call<E>>, Args, RetType>
pub fn call( self, callee: E::AccountId, ) -> CallBuilder<E, Set<Call<E>>, Args, RetType>
Prepares the CallBuilder
for a cross-contract Call
to the latest call_v2
host function.
sourcepub fn delegate(
self,
code_hash: E::Hash,
) -> CallBuilder<E, Set<DelegateCall<E>>, Args, RetType>
pub fn delegate( self, code_hash: E::Hash, ) -> CallBuilder<E, Set<DelegateCall<E>>, Args, RetType>
Prepares the CallBuilder
for a cross-contract DelegateCall
.
Trait Implementations§
source§impl<E, CallType: Clone, Args: Clone, RetType: Clone> Clone for CallBuilder<E, CallType, Args, RetType>where
E: Environment + Clone,
impl<E, CallType: Clone, Args: Clone, RetType: Clone> Clone for CallBuilder<E, CallType, Args, RetType>where
E: Environment + Clone,
source§fn clone(&self) -> CallBuilder<E, CallType, Args, RetType>
fn clone(&self) -> CallBuilder<E, CallType, Args, RetType>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<E, Args, RetType> From<Execution<Args, RetType>> for CallBuilder<E, Unset<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> From<Execution<Args, RetType>> for CallBuilder<E, Unset<Call<E>>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
Auto Trait Implementations§
impl<E, CallType, Args, RetType> Freeze for CallBuilder<E, CallType, Args, RetType>
impl<E, CallType, Args, RetType> RefUnwindSafe for CallBuilder<E, CallType, Args, RetType>
impl<E, CallType, Args, RetType> Send for CallBuilder<E, CallType, Args, RetType>
impl<E, CallType, Args, RetType> Sync for CallBuilder<E, CallType, Args, RetType>
impl<E, CallType, Args, RetType> Unpin for CallBuilder<E, CallType, Args, RetType>
impl<E, CallType, Args, RetType> UnwindSafe for CallBuilder<E, CallType, Args, RetType>
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
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)
clone_to_uninit
)§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
T
. Read more§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.