Struct scale_info::Variant

source ·
pub struct Variant<T: Form = MetaForm> {
    pub name: T::String,
    pub fields: Vec<Field<T>>,
    pub index: u8,
    pub docs: Vec<T::String>,
}
Expand description

A struct enum variant with either named (struct) or unnamed (tuple struct) fields.

Example

enum Operation {
    Zero,
//  ^^^^ this is a unit struct enum variant
    Add(i32, i32),
//  ^^^^^^^^^^^^^ this is a tuple-struct enum variant
    Minus { source: i32 }
//  ^^^^^^^^^^^^^^^^^^^^^ this is a struct enum variant
}

Fields§

§name: T::String

The name of the variant.

§fields: Vec<Field<T>>

The fields of the variant.

§index: u8

Index of the variant, used in parity-scale-codec.

The value of this will be, in order of precedence: 1. The explicit index defined by a #[codec(index = N)] attribute. 2. The implicit index from the position of the variant in the enum definition.

§docs: Vec<T::String>

Documentation

Implementations§

source§

impl<T> Variant<T>where T: Form,

source

pub fn new( name: T::String, fields: Vec<Field<T>>, index: u8, docs: Vec<T::String> ) -> Self

Creates a new variant.

source§

impl<T> Variant<T>where T: Form,

source

pub fn name(&self) -> &T::String

👎Deprecated since 2.5.0: Prefer to access the fields directly; this getter will be removed in the next major version

Returns the name of the variant.

source

pub fn fields(&self) -> &[Field<T>]

👎Deprecated since 2.5.0: Prefer to access the fields directly; this getter will be removed in the next major version

Returns the fields of the struct variant.

source

pub fn index(&self) -> u8

👎Deprecated since 2.5.0: Prefer to access the fields directly; this getter will be removed in the next major version

Returns the index of the variant.

source

pub fn docs(&self) -> &[T::String]

👎Deprecated since 2.5.0: Prefer to access the fields directly; this getter will be removed in the next major version

Returns the documentation of the variant.

Trait Implementations§

source§

impl<T: Clone + Form> Clone for Variant<T>where T::String: Clone,

source§

fn clone(&self) -> Variant<T>

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<T: Debug + Form> Debug for Variant<T>where T::String: Debug,

source§

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

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

impl<T: Form> Decode for Variant<T>where T::String: Decode, Vec<Field<T>>: Decode, Vec<T::String>: Decode,

source§

fn decode<__CodecInputEdqy: Input>( __codec_input_edqy: &mut __CodecInputEdqy ) -> Result<Self, Error>

Attempt to deserialise the value from input.
source§

fn skip<I>(input: &mut I) -> Result<(), Error>where I: Input,

Attempt to skip the encoded value from input. Read more
source§

fn encoded_fixed_size() -> Option<usize>

Returns the fixed encoded size of the type. Read more
source§

impl<T: Form> Encode for Variant<T>where T::String: Encode, Vec<Field<T>>: Encode, Vec<T::String>: Encode,

source§

fn encode_to<__CodecOutputEdqy: Output + ?Sized>( &self, __codec_dest_edqy: &mut __CodecOutputEdqy )

Convert self to a slice and append it to the destination.
source§

fn size_hint(&self) -> usize

If possible give a hint of expected size of the encoding. Read more
source§

fn encode(&self) -> Vec<u8, Global>

Convert self to an owned vector.
source§

fn using_encoded<R, F>(&self, f: F) -> Rwhere F: FnOnce(&[u8]) -> R,

Convert self to a slice and then invoke the given closure with it.
source§

fn encoded_size(&self) -> usize

Calculates the encoded size. Read more
source§

impl IntoPortable for Variant

§

type Output = Variant<PortableForm>

The portable version of Self.
source§

fn into_portable(self, registry: &mut Registry) -> Self::Output

Convert self to the portable form by using the registry for caching.
source§

impl<T: Ord + Form> Ord for Variant<T>where T::String: Ord,

source§

fn cmp(&self, other: &Variant<T>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Selfwhere Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Selfwhere Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Selfwhere Self: Sized + PartialOrd<Self>,

Restrict a value to a certain interval. Read more
source§

impl<T: PartialEq + Form> PartialEq<Variant<T>> for Variant<T>where T::String: PartialEq,

source§

fn eq(&self, other: &Variant<T>) -> 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<T: PartialOrd + Form> PartialOrd<Variant<T>> for Variant<T>where T::String: PartialOrd,

source§

fn partial_cmp(&self, other: &Variant<T>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

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

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

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

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

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

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

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

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl<T: Form> EncodeLike<Variant<T>> for Variant<T>where T::String: Encode, Vec<Field<T>>: Encode, Vec<T::String>: Encode,

source§

impl<T: Eq + Form> Eq for Variant<T>where T::String: Eq,

source§

impl<T: Form> StructuralEq for Variant<T>

source§

impl<T: Form> StructuralPartialEq for Variant<T>

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for Variant<T>where <T as Form>::String: RefUnwindSafe, <T as Form>::Type: RefUnwindSafe,

§

impl<T> Send for Variant<T>where <T as Form>::String: Send, <T as Form>::Type: Send,

§

impl<T> Sync for Variant<T>where <T as Form>::String: Sync, <T as Form>::Type: Sync,

§

impl<T> Unpin for Variant<T>where <T as Form>::String: Unpin, <T as Form>::Type: Unpin,

§

impl<T> UnwindSafe for Variant<T>where <T as Form>::String: UnwindSafe, <T as Form>::Type: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> DecodeAll for Twhere T: Decode,

source§

fn decode_all(input: &mut &[u8]) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

impl<T> DecodeLimit for Twhere T: Decode,

source§

fn decode_all_with_depth_limit( limit: u32, input: &mut &[u8] ) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

fn decode_with_depth_limit<I>(limit: u32, input: &mut I) -> Result<T, Error>where I: Input,

Decode Self with the given maximum recursion depth and advance input by the number of bytes consumed. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · 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<T> KeyedVec for Twhere T: Codec,

source§

fn to_keyed_vec(&self, prepend_key: &[u8]) -> Vec<u8, Global>

Return an encoding of Self prepended by given slice.
source§

impl<T> ToOwned for Twhere 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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<S> Codec for Swhere S: Decode + Encode,

source§

impl<T> EncodeLike<&&T> for Twhere T: Encode,

source§

impl<T> EncodeLike<&T> for Twhere T: Encode,

source§

impl<T> EncodeLike<&mut T> for Twhere T: Encode,

source§

impl<T> EncodeLike<Arc<T>> for Twhere T: Encode,

source§

impl<T> EncodeLike<Box<T, Global>> for Twhere T: Encode,

source§

impl<'a, T> EncodeLike<Cow<'a, T>> for Twhere T: ToOwned + Encode,

source§

impl<T> EncodeLike<Rc<T>> for Twhere T: Encode,

source§

impl<S> FullCodec for Swhere S: Decode + FullEncode,

source§

impl<S> FullEncode for Swhere S: Encode + EncodeLike<S>,