Skip to main content

Stack

Struct Stack 

Source
pub(crate) struct Stack {
    types: PackedTypes,
    amounts: [NonZero<usize>; 102],
    depth: u8,
}
Expand description

A non-allocating Vec.

This has a maximum depth premised on the bound for an EPEE’s object depth.

Fields§

§types: PackedTypes

The type of the item being read.

§amounts: [NonZero<usize>; 102]

The amount remaining for the item being read.

§depth: u8

The current depth of the stack.

This is analogous to the length of a Vec, yet we use the term depth to distinguish how it tracks the depth of an object, not the amount of items present (which would be a function of depth and width, as noted above).

Implementations§

Source§

impl Stack

Source

pub(crate) fn root_object() -> Self

Create a new stack to use with decoding the root object.

Source

pub(crate) fn depth(&self) -> usize

The current stack depth.

Source

pub(crate) fn peek(&self) -> Option<(TypeOrEntry, NonZero<usize>)>

Peek the current item on the stack.

Source

pub(crate) fn pop(&mut self) -> Option<TypeOrEntry>

Pop the next item from the stack.

Source

pub(crate) fn push( &mut self, kind: TypeOrEntry, amount: usize, ) -> Result<(), EpeeError>

Push an item onto the stack.

Source§

impl Stack

Source

pub(crate) fn single_step<'encoding, B: BytesLike<'encoding>>( &mut self, encoding: &mut B, ) -> Result<Option<SingleStepResult<'encoding, B>>, EpeeError>

Execute a single step of the decoding algorithm.

Returns Some((key, kind, len)) if an entry was read, or None otherwise. This also returns None if the stack is empty.

Source

pub(crate) fn step<'encoding, B: BytesLike<'encoding>>( &mut self, encoding: &mut B, ) -> Result<Option<()>, EpeeError>

Step through the entirety of the next item.

Returns None if the stack is empty.

Auto Trait Implementations§

§

impl Freeze for Stack

§

impl RefUnwindSafe for Stack

§

impl Send for Stack

§

impl Sync for Stack

§

impl Unpin for Stack

§

impl UnsafeUnpin for Stack

§

impl UnwindSafe for Stack

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> SizedTypeProperties for T

Source§

#[doc(hidden)]
const SIZE: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGNMENT: Alignment = _

🔬This is a nightly-only experimental API. (ptr_alignment_type)
Source§

#[doc(hidden)]
const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
Source§

#[doc(hidden)]
const LAYOUT: Layout = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const MAX_SLICE_LEN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
The largest safe length for a [Self]. Read more
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.