pub struct TokenId<M>where
M: ManagedTypeApi,{ /* private fields */ }Expand description
Specialized type for handling token identifiers (e.g. ABCDEF-123456).
Implementations§
Source§impl<M> TokenId<M>where
M: ManagedTypeApi,
impl<M> TokenId<M>where
M: ManagedTypeApi,
pub fn new(data: ManagedBuffer<M>) -> TokenId<M>
pub fn new_backwards_compatible(data: ManagedBuffer<M>) -> TokenId<M>
pub fn into_managed_buffer(self) -> ManagedBuffer<M>
pub fn as_managed_buffer(&self) -> &ManagedBuffer<M>
pub fn into_legacy(self) -> EgldOrEsdtTokenIdentifier<M>
pub fn as_legacy(&self) -> &EgldOrEsdtTokenIdentifier<M>
Sourcepub unsafe fn as_esdt_unchecked(&self) -> &EsdtTokenIdentifier<M>
pub unsafe fn as_esdt_unchecked(&self) -> &EsdtTokenIdentifier<M>
Converts to a specialized ESDT token identifier.
§Safety
Leads to inconsistencies if the token is EGLD.
Sourcepub unsafe fn into_esdt_unchecked(self) -> EsdtTokenIdentifier<M>
pub unsafe fn into_esdt_unchecked(self) -> EsdtTokenIdentifier<M>
Converts to a specialized ESDT token identifier.
§Safety
Leads to inconsistencies if the token is EGLD.
pub fn to_boxed_bytes(&self) -> BoxedBytes
Sourcepub fn is_native(&self) -> bool
pub fn is_native(&self) -> bool
Checks if a token is the native one on the chain. Currently only returns true for EGLD-000000.
Sourcepub fn is_valid(&self) -> bool
pub fn is_valid(&self) -> bool
Checks the ESDT token identifier for validity.
Will fail if it encodes an invalid ESDT token identifier.
Sourcepub fn is_valid_esdt_identifier(&self) -> bool
pub fn is_valid_esdt_identifier(&self) -> bool
Old method name. Kept for easier transition. Use is_valid instead.
Sourcepub fn ticker(&self) -> ManagedBuffer<M>
pub fn ticker(&self) -> ManagedBuffer<M>
Extracts the ticker from the token identifier.
E.g. for “ABCDEF-123456” it will return “ABCDEF”.
Trait Implementations§
Source§impl<M> AsRef<TokenId<M>> for EgldOrEsdtTokenIdentifier<M>where
M: ManagedTypeApi,
impl<M> AsRef<TokenId<M>> for EgldOrEsdtTokenIdentifier<M>where
M: ManagedTypeApi,
Source§impl<M> Debug for TokenId<M>where
M: ManagedTypeApi,
impl<M> Debug for TokenId<M>where
M: ManagedTypeApi,
Source§impl<M> Display for TokenId<M>where
M: ManagedTypeApi,
impl<M> Display for TokenId<M>where
M: ManagedTypeApi,
Source§impl<M> From<EgldOrEsdtTokenIdentifier<M>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> From<EgldOrEsdtTokenIdentifier<M>> for TokenId<M>where
M: ManagedTypeApi,
Source§fn from(token_id: EgldOrEsdtTokenIdentifier<M>) -> TokenId<M>
fn from(token_id: EgldOrEsdtTokenIdentifier<M>) -> TokenId<M>
Converts to this type from the input type.
Source§impl<M> From<ManagedBuffer<M>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> From<ManagedBuffer<M>> for TokenId<M>where
M: ManagedTypeApi,
Source§fn from(buffer: ManagedBuffer<M>) -> TokenId<M>
fn from(buffer: ManagedBuffer<M>) -> TokenId<M>
Converts to this type from the input type.
Source§impl<M> From<TokenId<M>> for EgldOrEsdtTokenIdentifier<M>where
M: ManagedTypeApi,
impl<M> From<TokenId<M>> for EgldOrEsdtTokenIdentifier<M>where
M: ManagedTypeApi,
Source§fn from(token_id: TokenId<M>) -> EgldOrEsdtTokenIdentifier<M>
fn from(token_id: TokenId<M>) -> EgldOrEsdtTokenIdentifier<M>
Converts to this type from the input type.
Source§impl<M> From<TokenId<M>> for EsdtTokenIdentifier<M>where
M: ManagedTypeApi,
impl<M> From<TokenId<M>> for EsdtTokenIdentifier<M>where
M: ManagedTypeApi,
Source§fn from(token_id: TokenId<M>) -> EsdtTokenIdentifier<M>
fn from(token_id: TokenId<M>) -> EsdtTokenIdentifier<M>
Converts to this type from the input type.
Source§impl<M> ManagedType<M> for TokenId<M>where
M: ManagedTypeApi,
impl<M> ManagedType<M> for TokenId<M>where
M: ManagedTypeApi,
type OwnHandle = <M as HandleTypeInfo>::ManagedBufferHandle
fn get_handle(&self) -> <M as HandleTypeInfo>::ManagedBufferHandle
Source§unsafe fn forget_into_handle(self) -> <TokenId<M> as ManagedType<M>>::OwnHandle
unsafe fn forget_into_handle(self) -> <TokenId<M> as ManagedType<M>>::OwnHandle
Forgets current object (does not run destructor), but extracts the handle. Read more
Source§fn transmute_from_handle_ref(
handle_ref: &<M as HandleTypeInfo>::ManagedBufferHandle,
) -> &TokenId<M>
fn transmute_from_handle_ref( handle_ref: &<M as HandleTypeInfo>::ManagedBufferHandle, ) -> &TokenId<M>
Implement carefully, since the underlying transmutation is an unsafe operation.
For types that wrap a handle to some VM-managed data,
make sure the type only contains the handle (plus ZSTs if necessary).
For types that just wrap another managed type it is easier, call for the wrapped object.
fn transmute_from_handle_ref_mut( handle_ref: &mut <M as HandleTypeInfo>::ManagedBufferHandle, ) -> &mut TokenId<M>
fn get_raw_handle(&self) -> i32
fn get_raw_handle_unchecked(&self) -> i32
fn as_ref(&self) -> ManagedRef<'_, M, Self>
Source§impl<M> ManagedVecItem for TokenId<M>where
M: ManagedTypeApi,
impl<M> ManagedVecItem for TokenId<M>where
M: ManagedTypeApi,
Source§const SKIPS_RESERIALIZATION: bool = false
const SKIPS_RESERIALIZATION: bool = false
If true, 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).
False for all managed types, but true for basic types (like
u32).Source§type PAYLOAD = ManagedVecItemPayloadBuffer<UInt<UInt<UInt<UTerm, B1>, B0>, B0>>
type PAYLOAD = ManagedVecItemPayloadBuffer<UInt<UInt<UInt<UTerm, B1>, B0>, B0>>
Type managing the underlying binary representation in a ManagedVec..
Source§type Ref<'a> = ManagedRef<'a, M, TokenId<M>>
type Ref<'a> = ManagedRef<'a, M, TokenId<M>>
Reference representation of the ManagedVec item. Read more
Source§fn read_from_payload(
payload: &<TokenId<M> as ManagedVecItem>::PAYLOAD,
) -> TokenId<M>
fn read_from_payload( payload: &<TokenId<M> as ManagedVecItem>::PAYLOAD, ) -> TokenId<M>
Parses given bytes as a an owned object.
Source§unsafe fn borrow_from_payload<'a>(
payload: &<TokenId<M> as ManagedVecItem>::PAYLOAD,
) -> <TokenId<M> as ManagedVecItem>::Ref<'a>
unsafe fn borrow_from_payload<'a>( payload: &<TokenId<M> as ManagedVecItem>::PAYLOAD, ) -> <TokenId<M> as ManagedVecItem>::Ref<'a>
Parses given bytes as a representation of the object, either owned, or a reference. Read more
Source§fn save_to_payload(self, payload: &mut <TokenId<M> as ManagedVecItem>::PAYLOAD)
fn save_to_payload(self, payload: &mut <TokenId<M> as ManagedVecItem>::PAYLOAD)
Converts the object into bytes. Read more
fn payload_size() -> usize
Source§impl<M> NestedDecode for TokenId<M>where
M: ManagedTypeApi,
impl<M> NestedDecode for TokenId<M>where
M: ManagedTypeApi,
Source§fn dep_decode_or_handle_err<I, H>(
input: &mut I,
h: H,
) -> Result<TokenId<M>, <H as DecodeErrorHandler>::HandledErr>where
I: NestedDecodeInput,
H: DecodeErrorHandler,
fn dep_decode_or_handle_err<I, H>(
input: &mut I,
h: H,
) -> Result<TokenId<M>, <H as DecodeErrorHandler>::HandledErr>where
I: NestedDecodeInput,
H: DecodeErrorHandler,
Version of
dep_decode 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 dep_decode<I>(input: &mut I) -> Result<Self, DecodeError>where
I: NestedDecodeInput,
fn dep_decode<I>(input: &mut I) -> Result<Self, DecodeError>where
I: NestedDecodeInput,
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§impl<M> NestedEncode for TokenId<M>where
M: ManagedTypeApi,
impl<M> NestedEncode for TokenId<M>where
M: ManagedTypeApi,
Source§fn dep_encode_or_handle_err<O, H>(
&self,
dest: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: NestedEncodeOutput,
H: EncodeErrorHandler,
fn dep_encode_or_handle_err<O, H>(
&self,
dest: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: NestedEncodeOutput,
H: EncodeErrorHandler,
Version of
dep_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 dep_encode<O>(&self, dest: &mut O) -> Result<(), EncodeError>where
O: NestedEncodeOutput,
fn dep_encode<O>(&self, dest: &mut O) -> Result<(), EncodeError>where
O: NestedEncodeOutput,
NestedEncode to output, using the format of an object nested inside another structure.
Does not provide compact version.
Source§impl<M> PartialEq for TokenId<M>where
M: ManagedTypeApi,
impl<M> PartialEq for TokenId<M>where
M: ManagedTypeApi,
Source§impl<M> SCDisplay for TokenId<M>where
M: ManagedTypeApi,
impl<M> SCDisplay for TokenId<M>where
M: ManagedTypeApi,
fn fmt<F>(&self, f: &mut F)where
F: FormatByteReceiver,
Source§impl<M> SCLowerHex for TokenId<M>where
M: ManagedTypeApi,
impl<M> SCLowerHex for TokenId<M>where
M: ManagedTypeApi,
fn fmt<F>(&self, f: &mut F)where
F: FormatByteReceiver,
Source§impl<M> TopDecode for TokenId<M>where
M: ManagedTypeApi,
impl<M> TopDecode for TokenId<M>where
M: ManagedTypeApi,
Source§fn top_decode_or_handle_err<I, H>(
input: I,
h: H,
) -> Result<TokenId<M>, <H as DecodeErrorHandler>::HandledErr>where
I: TopDecodeInput,
H: DecodeErrorHandler,
fn top_decode_or_handle_err<I, H>(
input: I,
h: H,
) -> Result<TokenId<M>, <H as DecodeErrorHandler>::HandledErr>where
I: TopDecodeInput,
H: DecodeErrorHandler,
Version of
top_decode that can handle errors as soon as they occur.
For instance it 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 top_decode<I>(input: I) -> Result<Self, DecodeError>where
I: TopDecodeInput,
fn top_decode<I>(input: I) -> Result<Self, DecodeError>where
I: TopDecodeInput,
Attempt to deserialize the value from input.
Source§impl<M> TopEncode for TokenId<M>where
M: ManagedTypeApi,
impl<M> TopEncode for TokenId<M>where
M: ManagedTypeApi,
Source§fn top_encode_or_handle_err<O, H>(
&self,
output: O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeOutput,
H: EncodeErrorHandler,
fn top_encode_or_handle_err<O, H>(
&self,
output: O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeOutput,
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 top_encode<O>(&self, output: O) -> Result<(), EncodeError>where
O: TopEncodeOutput,
fn top_encode<O>(&self, output: O) -> Result<(), EncodeError>where
O: TopEncodeOutput,
Attempt to serialize the value to output.
Source§impl<M> TypeAbi for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbi for TokenId<M>where
M: ManagedTypeApi,
type Unmanaged = TokenId<M>
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<M> Eq for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<&[u8]> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<&EsdtTokenIdentifier<M>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<&TestTokenIdentifier<'_>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<&TokenId<M>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<&str> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<EsdtTokenIdentifier<M>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<TestTokenIdentifier<'_>> for TokenId<M>where
M: ManagedTypeApi,
impl<M> TypeAbiFrom<TokenId<M>> for TokenId<M>where
M: ManagedTypeApi,
Auto Trait Implementations§
impl<M> Freeze for TokenId<M>
impl<M> RefUnwindSafe for TokenId<M>
impl<M> Send for TokenId<M>
impl<M> Sync for TokenId<M>
impl<M> Unpin for TokenId<M>
impl<M> UnwindSafe for TokenId<M>
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
🔬This is a nightly-only experimental API. (
clone_to_uninit)Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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 moreSource§impl<T> MultiValueConstLength for T
impl<T> MultiValueConstLength for T
Source§const MULTI_VALUE_CONST_LEN: usize = 1usize
const MULTI_VALUE_CONST_LEN: usize = 1usize
The fixed (constant) number of single items contained a multi-value. Read more
Source§impl<T> MultiValueLength for T
impl<T> MultiValueLength for T
Source§fn multi_value_len(&self) -> usize
fn multi_value_len(&self) -> usize
The number of single items contained a multi-value.
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> ReconstructableFrom<&T> for Twhere
T: Clone,
impl<T> ReconstructableFrom<&T> for Twhere
T: Clone,
fn reconstruct_from(from: &T, _builder: &ReconstructorContext) -> T
Source§impl<T> ReconstructableFrom<T> for T
impl<T> ReconstructableFrom<T> for T
fn reconstruct_from(from: T, _builder: &ReconstructorContext) -> T
Source§impl<T> SCCodec for Twhere
T: TopEncode,
impl<T> SCCodec for Twhere
T: TopEncode,
fn fmt<F>(&self, f: &mut F)where
F: FormatByteReceiver,
Source§impl<T> ToStringFallible for Twhere
T: Display,
impl<T> ToStringFallible for Twhere
T: Display,
Source§fn try_to_string(&self) -> Result<String, TryReserveError>
fn try_to_string(&self) -> Result<String, TryReserveError>
ToString::to_string, but without panic on OOM.
Source§impl<T> TopDecodeMulti for Twhere
T: TopDecode,
impl<T> TopDecodeMulti for Twhere
T: TopDecode,
Source§const IS_SINGLE_VALUE: bool = true
const IS_SINGLE_VALUE: bool = true
Used to optimize single value loading of endpoint arguments.
fn multi_decode_or_handle_err<I, H>(
input: &mut I,
h: H,
) -> Result<T, <H as DecodeErrorHandler>::HandledErr>where
I: TopDecodeMultiInput,
H: DecodeErrorHandler,
fn multi_decode<I>(input: &mut I) -> Result<Self, DecodeError>where
I: TopDecodeMultiInput,
Source§impl<T> TopEncodeMulti for Twhere
T: TopEncode,
impl<T> TopEncodeMulti for Twhere
T: TopEncode,
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 output.