mesh_protobuf::encoding

Struct MapField

Source
pub struct MapField<K, V, EK, EV>(/* private fields */);
Expand description

A field encoder for maps from K to V, using encoders EK and EV.

Trait Implementations§

Source§

impl<T, K, V, EK: DescribeField<K>, EV: DescribeField<V>> DescribeField<T> for MapField<K, V, EK, EV>

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<'a, K, V, T, EK, EV, R> FieldDecode<'a, T, R> for MapField<K, V, EK, EV>
where T: Default + Extend<(K, V)>, EK: FieldDecode<'a, K, R>, EV: FieldDecode<'a, V, R>,

Source§

fn read_field( item: &mut InplaceOption<'_, T>, reader: FieldReader<'a, '_, 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 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 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 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<K, V, T, EK, EV, R> FieldEncode<T, R> for MapField<K, V, EK, EV>
where T: IntoIterator<Item = (K, V)>, for<'a> &'a mut T: IntoIterator<Item = (&'a K, &'a mut V)>, for<'a> EK: FieldEncode<&'a K, R>, EV: FieldEncode<V, R>,

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

Auto Trait Implementations§

§

impl<K, V, EK, EV> Freeze for MapField<K, V, EK, EV>
where EK: Freeze, EV: Freeze,

§

impl<K, V, EK, EV> RefUnwindSafe for MapField<K, V, EK, EV>

§

impl<K, V, EK, EV> Send for MapField<K, V, EK, EV>
where EK: Send, EV: Send,

§

impl<K, V, EK, EV> Sync for MapField<K, V, EK, EV>
where EK: Sync, EV: Sync,

§

impl<K, V, EK, EV> Unpin for MapField<K, V, EK, EV>
where EK: Unpin, EV: Unpin,

§

impl<K, V, EK, EV> UnwindSafe for MapField<K, V, EK, EV>
where EK: UnwindSafe, EV: 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<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.