struct LazyArray<T> {
    position: NonZeroUsize,
    num_elems: usize,
    _marker: PhantomData<fn() -> T>,
}
Expand description

A list of lazily-decoded values.

Unlike LazyValue<Vec<T>>, the length is encoded next to the position, not at the position, which means that the length doesn’t need to be known before encoding all the elements.

If the length is 0, no position is encoded, but otherwise, the encoding is that of LazyArray, with the distinction that the minimal distance the length of the sequence, i.e. it’s assumed there’s no 0-byte element in the sequence.

Fields§

§position: NonZeroUsize§num_elems: usize§_marker: PhantomData<fn() -> T>

Implementations§

source§

impl<T: ParameterizedOverTcx> LazyArray<T>

source

fn decode<'a, 'tcx, M: Metadata<'a, 'tcx>>( self, metadata: M ) -> DecodeIterator<'a, 'tcx, T::Value<'tcx>> where T::Value<'tcx>: Decodable<DecodeContext<'a, 'tcx>>,

source§

impl<T> LazyArray<T>

source

fn write_to_bytes_impl(self, b: &mut [u8; 16])

source

fn from_bytes_impl(position: &[u8; 8], meta: &[u8; 8]) -> Option<LazyArray<T>>

source§

impl<T> LazyArray<T>

Trait Implementations§

source§

impl<T> Clone for LazyArray<T>

source§

fn clone(&self) -> Self

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<'a, 'tcx, T> Decodable<DecodeContext<'a, 'tcx>> for LazyArray<T>

source§

fn decode(decoder: &mut DecodeContext<'a, 'tcx>) -> Self

source§

impl<T> Default for LazyArray<T>

source§

fn default() -> LazyArray<T>

Returns the “default value” for a type. Read more
source§

impl<'a, 'tcx, T> Encodable<EncodeContext<'a, 'tcx>> for LazyArray<T>

source§

fn encode(&self, e: &mut EncodeContext<'a, 'tcx>)

source§

impl<T> FixedSizeEncoding for LazyArray<T>

§

type ByteArray = [u8; 16]

This should be [u8; BYTE_LEN]; Cannot use an associated const BYTE_LEN: usize instead due to const eval limitations.
source§

fn from_bytes(b: &[u8; 16]) -> Self

source§

fn write_to_bytes(self, b: &mut [u8; 16])

source§

impl<T> IsDefault for LazyArray<T>

source§

impl<T: ParameterizedOverTcx> ParameterizedOverTcx for LazyArray<T>

§

type Value<'tcx> = LazyArray<<T as ParameterizedOverTcx>::Value<'tcx>>

source§

impl<T> Copy for LazyArray<T>

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for LazyArray<T>

§

impl<T> Send for LazyArray<T>

§

impl<T> Sync for LazyArray<T>

§

impl<T> Unpin for LazyArray<T>

§

impl<T> UnwindSafe for LazyArray<T>

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,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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> 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.
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.
source§

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

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 16 bytes