pub struct ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,
{ /* private fields */ }

Implementations§

source§

impl<M> ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,

source

pub fn new_empty(api: M) -> Self

source§

impl<M> ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,

source

pub fn len(&self) -> usize

source

pub fn is_empty(&self) -> bool

source

pub fn push_arg_raw(&mut self, raw_arg: ManagedBuffer<M>)

source

pub fn push_arg<T: TopEncode>(&mut self, arg: T)

source

pub fn concat(self, other: ManagedArgBuffer<M>) -> Self

Concatenates 2 managed arg buffers. Consumes both arguments in the process.

source

pub fn to_raw_args_vec(&self) -> Vec<Vec<u8>>

source§

impl<M> ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,

source§

impl<M> ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,

Trait Implementations§

source§

impl<M> Debug for ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static + Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<M: ManagedTypeApi> DynArgOutput for ManagedArgBuffer<M>

source§

fn push_single_arg<T: TopEncode>(&mut self, arg: T)

source§

impl<M> From<ManagedVec<M, ManagedBuffer<M>>> for ManagedArgBuffer<M>
where M: ManagedTypeApi,

source§

fn from(data: ManagedVec<M, ManagedBuffer<M>>) -> Self

Converts to this type from the input type.
source§

impl<M, I> ManagedFrom<M, Vec<I>> for ManagedArgBuffer<M>

source§

fn managed_from(api: M, v: Vec<I>) -> Self

source§

impl<M> ManagedType<M> for ManagedArgBuffer<M>
where M: ManagedTypeApi + ErrorApi + 'static,

source§

fn type_manager(&self) -> M

source§

impl<M> NestedDecode for ManagedArgBuffer<M>
where M: ManagedTypeApi,

source§

fn dep_decode<I: NestedDecodeInput>(input: &mut I) -> Result<Self, DecodeError>

Attempt to deserialise the value from input, using the format of an object nested inside another structure. In case of success returns the deserialized value and the number of bytes consumed during the operation.
source§

fn dep_decode_or_exit<I, ExitCtx>( input: &mut I, c: ExitCtx, exit: fn(_: ExitCtx, _: DecodeError) -> ! ) -> Self
where I: NestedDecodeInput, ExitCtx: Clone,

Version of top_decode that exits quickly in case of error. Its purpose is to create smaller implementations in cases where the application is supposed to exit directly on decode error.
source§

impl<M> NestedEncode for ManagedArgBuffer<M>
where M: ManagedTypeApi,

source§

fn dep_encode<O: NestedEncodeOutput>( &self, dest: &mut O ) -> Result<(), EncodeError>

NestedEncode to output, using the format of an object nested inside another structure. Does not provide compact version.
source§

fn dep_encode_or_exit<O, ExitCtx>( &self, dest: &mut O, c: ExitCtx, exit: fn(_: ExitCtx, _: EncodeError) -> ! )
where O: NestedEncodeOutput, ExitCtx: Clone,

Version of top_decode that exits quickly in case of error. Its purpose is to create smaller implementations in cases where the application is supposed to exit directly on decode error.
source§

impl<M> TopDecode for ManagedArgBuffer<M>
where M: ManagedTypeApi,

source§

fn top_decode<I: TopDecodeInput>(input: I) -> Result<Self, DecodeError>

Attempt to deserialize the value from input.
source§

fn top_decode_or_exit<I, ExitCtx>( input: I, c: ExitCtx, exit: fn(_: ExitCtx, _: DecodeError) -> ! ) -> Self
where I: TopDecodeInput, ExitCtx: Clone,

Version of top_decode that exits quickly in case of error. Its purpose is to create smaller implementations in cases where the application is supposed to exit directly on decode error.
source§

impl<M> TopEncode for ManagedArgBuffer<M>
where M: ManagedTypeApi,

source§

fn top_encode<O: TopEncodeOutput>(&self, output: O) -> Result<(), EncodeError>

Attempt to serialize the value to ouput.
source§

fn top_encode_or_exit<O, ExitCtx>( &self, output: O, c: ExitCtx, exit: fn(_: ExitCtx, _: EncodeError) -> ! )
where O: TopEncodeOutput, ExitCtx: Clone,

Version of top_decode that exits quickly in case of error. Its purpose is to create smaller bytecode implementations in cases where the application is supposed to exit directly on decode error.

Auto Trait Implementations§

§

impl<M> RefUnwindSafe for ManagedArgBuffer<M>
where M: RefUnwindSafe,

§

impl<M> Send for ManagedArgBuffer<M>
where M: Send,

§

impl<M> Sync for ManagedArgBuffer<M>
where M: Sync,

§

impl<M> Unpin for ManagedArgBuffer<M>
where M: Unpin,

§

impl<M> UnwindSafe for ManagedArgBuffer<M>
where M: 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<M, T> AsManagedRef<M, T> for T
where M: ManagedTypeApi, T: ManagedType<M>,

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> ContractCallArg for T
where T: TopEncode,

source§

fn push_dyn_arg<O>(&self, output: &mut O)
where O: DynArgOutput,

source§

impl<T> DynArg for T
where T: TopEncode + TopDecode,

source§

fn dyn_load<I>(loader: &mut I, arg_id: ArgId) -> T
where I: DynArgInput,

source§

impl<T> EndpointResult for T
where T: TopEncode,

§

type DecodeAs = T

Indicates how the result of the endpoint can be interpreted when called via proxy. Self for most types.
source§

fn finish<FA>(&self, api: FA)
where FA: ManagedTypeApi + EndpointFinishApi + Clone + 'static,

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<M, F> ManagedFrom<M, F> for F
where M: ManagedTypeApi,

source§

fn managed_from(_: M, t: F) -> F

source§

impl<M, F, T> ManagedInto<M, T> for F
where T: ManagedFrom<M, F>, M: ManagedTypeApi,

source§

fn managed_into(self, api: M) -> T

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.