pub struct TokenIdentifier<M: ManagedTypeApi> { /* private fields */ }
Expand description

Specialized type for handling token identifiers. It wraps a BoxedBytes with the full ASCII name of the token. MOAX is stored as an empty name.

Not yet implemented, but we might add additional restrictions when deserializing as argument.

Implementations§

source§

impl<M: ManagedTypeApi> TokenIdentifier<M>

source

pub const MOAX_REPRESENTATION: &'static [u8; 4] = _

This special representation is interpreted as the MOAX token.

source

pub const TICKER_MIN_LENGTH: usize = 3usize

source

pub const TICKER_MAX_LENGTH: usize = 10usize

source

pub const ADDITIONAL_RANDOM_CHARS_LENGTH: usize = 6usize

source

pub const IDENTIFIER_MIN_LENGTH: usize = 10usize

source

pub const IDENTIFIER_MAX_LENGTH: usize = 17usize

source

pub const DASH_CHARACTER: u8 = 45u8

source

pub fn from_dct_bytes<B: ManagedInto<M, ManagedBuffer<M>>>( api: M, bytes: B ) -> Self

source

pub fn moax(api: M) -> Self

New instance of the special MOAX token representation.

source

pub fn is_moax(&self) -> bool

source

pub fn is_dct(&self) -> bool

source

pub fn len(&self) -> usize

source

pub fn is_empty(&self) -> bool

source

pub fn into_managed_buffer(self) -> ManagedBuffer<M>

source

pub fn as_managed_buffer(&self) -> &ManagedBuffer<M>

source

pub fn to_dct_identifier(&self) -> BoxedBytes

source

pub fn as_name(&self) -> BoxedBytes

source

pub fn is_valid_dct_identifier(&self) -> bool

Trait Implementations§

source§

impl<M: Clone + ManagedTypeApi> Clone for TokenIdentifier<M>

source§

fn clone(&self) -> TokenIdentifier<M>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<M: Debug + ManagedTypeApi> Debug for TokenIdentifier<M>

source§

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

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

impl<M: ManagedTypeApi> From<ManagedBuffer<M>> for TokenIdentifier<M>

source§

fn from(buffer: ManagedBuffer<M>) -> Self

Converts to this type from the input type.
source§

impl<M: ManagedTypeApi> ManagedFrom<M, &[u8]> for TokenIdentifier<M>

source§

fn managed_from(api: M, bytes: &[u8]) -> Self

source§

impl<M: ManagedTypeApi> ManagedFrom<M, ManagedBuffer<M>> for TokenIdentifier<M>

source§

fn managed_from(_: M, buffer: ManagedBuffer<M>) -> Self

source§

impl<M: ManagedTypeApi> ManagedType<M> for TokenIdentifier<M>

source§

fn type_manager(&self) -> M

source§

impl<M: ManagedTypeApi> ManagedVecItem<M> for TokenIdentifier<M>

source§

const PAYLOAD_SIZE: usize = 4usize

Size of the data stored in the underlying ManagedBuffer.
source§

const NEEDS_RESERIALIZATION: bool = true

If false, then the encoding of the item is identical to the payload, and no further conversion is necessary (the underlying buffer can be used as-is during serialization). True for all managed types, but false for basic types (like u32).
source§

fn from_byte_reader<Reader: FnMut(&mut [u8])>(api: M, reader: Reader) -> Self

source§

fn to_byte_writer<R, Writer: FnMut(&[u8]) -> R>(&self, writer: Writer) -> R

source§

impl<M: ManagedTypeApi> NestedDecode for TokenIdentifier<M>

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: NestedDecodeInput, ExitCtx: Clone>( input: &mut I, c: ExitCtx, exit: fn(_: ExitCtx, _: DecodeError) -> ! ) -> Self

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: ManagedTypeApi> NestedEncode for TokenIdentifier<M>

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: ManagedTypeApi> PartialEq for TokenIdentifier<M>

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<M: ManagedTypeApi> TopDecode for TokenIdentifier<M>

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: TopDecodeInput, ExitCtx: Clone>( input: I, c: ExitCtx, exit: fn(_: ExitCtx, _: DecodeError) -> ! ) -> Self

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: ManagedTypeApi> TopEncode for TokenIdentifier<M>

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

impl<M: ManagedTypeApi> TypeAbi for TokenIdentifier<M>

source§

fn type_name() -> String

source§

fn provide_type_descriptions<TDC: TypeDescriptionContainer>( accumulator: &mut TDC )

A type can provide more than its own description. 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.
source§

impl<M: ManagedTypeApi> Eq for TokenIdentifier<M>

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

impl<M> UnwindSafe for TokenIdentifier<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> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.