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>, Args, RetType>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<Call>, Args, RetType>where
E: Environment,
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: U256) -> Self
pub fn storage_deposit_limit(self, storage_deposit_limit: U256) -> 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: U256) -> Self
pub fn transferred_value(self, transferred_value: U256) -> 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>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<Call>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, Call, Args, RetType>
pub fn params(self) -> CallParams<E, Call, Args, RetType>
Finalizes the call builder to call a function.
source§impl<E, RetType> CallBuilder<E, Set<Call>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
impl<E, RetType> CallBuilder<E, Set<Call>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, Call, EmptyArgumentList, ()>
pub fn params(self) -> CallParams<E, Call, EmptyArgumentList, ()>
Finalizes the call builder to call a function.
source§impl<E> CallBuilder<E, Set<Call>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
impl<E> CallBuilder<E, Set<Call>, 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>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
impl<E, Args, R> CallBuilder<E, Set<Call>, 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>, Args, RetType>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall>, Args, RetType>where
E: Environment,
sourcepub fn call_flags(self, call_flags: CallFlags) -> Self
pub fn call_flags(self, call_flags: CallFlags) -> Self
Sets the CallFlags
to perform a delegate call with.
source§impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> CallBuilder<E, Set<DelegateCall>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, DelegateCall, Args, RetType>
pub fn params(self) -> CallParams<E, DelegateCall, Args, RetType>
Finalizes the call builder to call a function.
source§impl<E, RetType> CallBuilder<E, Set<DelegateCall>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
impl<E, RetType> CallBuilder<E, Set<DelegateCall>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<RetType>>where
E: Environment,
sourcepub fn params(self) -> CallParams<E, DelegateCall, EmptyArgumentList, ()>
pub fn params(self) -> CallParams<E, DelegateCall, EmptyArgumentList, ()>
Finalizes the call builder to call a function.
source§impl<E> CallBuilder<E, Set<DelegateCall>, Unset<ExecutionInput<EmptyArgumentList>>, Unset<ReturnType<()>>>where
E: Environment,
impl<E> CallBuilder<E, Set<DelegateCall>, 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>, Set<ExecutionInput<Args>>, Set<ReturnType<R>>>where
E: Environment,
Args: Encode,
R: Decode,
impl<E, Args, R> CallBuilder<E, Set<DelegateCall>, 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(self, callee: H160) -> CallBuilder<E, Set<Call>, Args, RetType>
pub fn call(self, callee: H160) -> CallBuilder<E, Set<Call>, Args, RetType>
Prepares the CallBuilder
for a cross-contract Call
to the latest call_v2
host function.
sourcepub fn delegate(
self,
address: H160,
) -> CallBuilder<E, Set<DelegateCall>, Args, RetType>
pub fn delegate( self, address: H160, ) -> CallBuilder<E, Set<DelegateCall>, 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>, Set<ExecutionInput<Args>>, Set<ReturnType<RetType>>>where
E: Environment,
impl<E, Args, RetType> From<Execution<Args, RetType>> for CallBuilder<E, Unset<Call>, 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
§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
§fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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>
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>
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§impl<Src, Dest> IntoTuple<Dest> for Srcwhere
Dest: FromTuple<Src>,
impl<Src, Dest> IntoTuple<Dest> for Srcwhere
Dest: FromTuple<Src>,
fn into_tuple(self) -> Dest
§impl<T> IsType<T> for T
impl<T> IsType<T> for T
§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§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, U> TryIntoKey<U> for Twhere
U: TryFromKey<T>,
impl<T, U> TryIntoKey<U> for Twhere
U: TryFromKey<T>,
type Error = <U as TryFromKey<T>>::Error
fn try_into_key(self) -> Result<U, <U as TryFromKey<T>>::Error>
§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.§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
.