Struct mesh_protobuf::oneof::OneofEncoder

source ·
pub struct OneofEncoder;
Expand description

An encoder type for oneof fields derived from Rust enums.

Encoding and decoding are implemented on types that implement OneofEncode and OneofDecode.

Trait Implementations§

source§

impl<T: DescribeOneof> DescribeField<T> for OneofEncoder

source§

const FIELD_TYPE: FieldType<'static> = _

The type of the field.
source§

const PACKED_TYPE: Option<&'static str> = None

The type name of the field in a packed context.
source§

impl<T: DescribeOneof> DescribeMessage<T> for OneofEncoder

source§

const DESCRIPTION: MessageDescription<'static> = T::DESCRIPTION

The message description.
source§

impl<'de, T: OneofDecode<'de, R>, R> FieldDecode<'de, T, R> for OneofEncoder

source§

fn read_field( item: &mut InplaceOption<'_, T>, reader: FieldReader<'de, '_, R>, ) -> Result<()>

Reads a field into item.
source§

fn default_field(_item: &mut InplaceOption<'_, T>) -> Result<()>

Instantiates item with its default value, if there is one. Read more
source§

fn packed<'p, C: CopyExtend<T>>() -> Option<&'p dyn PackedDecode<'a, T, C>>
where T: 'p,

Unless packed()::must_pack() is true, the sequence decoder must detect the encoding (packed or not) and call the appropriate method.
source§

fn wrap_in_sequence() -> bool

Returns whether this field is wrapped in a message when encoded nested in a sequence (such as a repeated field).
source§

fn read_field_in_sequence( item: &mut InplaceOption<'_, T>, reader: FieldReader<'a, '_, R>, ) -> Result<()>

Reads this field that was encoded as part of a sequence, unwrapping it from a message if necessary.
source§

const ENTRY: DecoderEntry<'a, T, R> = _

The table decoder entry for this type, used in types from table::decode. Read more
source§

impl<T: OneofEncode<R>, R> FieldEncode<T, R> for OneofEncoder

source§

fn write_field(item: T, writer: FieldWriter<'_, '_, R>)

Writes item as a field.
source§

fn compute_field_size(item: &mut T, sizer: FieldSizer<'_>)

Computes the size of item as a field. Read more
source§

fn packed<'a>() -> Option<&'a dyn PackedEncode<T>>
where T: 'a,

Returns the encoder for writing multiple instances of this field in a packed list, or None if there is no packed encoding for this type.
source§

fn wrap_in_sequence() -> bool

Returns whether this field should be wrapped in a message when encoded nested in a sequence (such as a repeated field). Read more
source§

fn write_field_in_sequence(item: T, writer: &mut SequenceWriter<'_, '_, R>)

Writes this field as part of a sequence, wrapping it in a message if necessary.
source§

fn compute_field_size_in_sequence(item: &mut T, sizer: &mut SequenceSizer<'_>)

Computes the size of this field as part of a sequence, including the size of a wrapping message.
source§

const ENTRY: EncoderEntry<T, R> = _

The table encoder entry for this type, used in types from table::encode. Read more
source§

impl<'de, T: OneofDecode<'de, R>, R> MessageDecode<'de, T, R> for OneofEncoder

source§

fn read_message( item: &mut InplaceOption<'_, T>, reader: MessageReader<'de, '_, R>, ) -> Result<()>

Reads a message into item.
source§

impl<T: OneofEncode<R>, R> MessageEncode<T, R> for OneofEncoder

source§

fn write_message(item: T, writer: MessageWriter<'_, '_, R>)

Writes item as a message.
source§

fn compute_message_size(item: &mut T, sizer: MessageSizer<'_>)

Computes the size of item as a message. Read more

Auto Trait Implementations§

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<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> 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<T, U> TryFrom<U> for T
where U: Into<T>,

source§

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>,

source§

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

impl<T, U> Upcast<U> for T
where U: Downcast<T>,