Enum substack::Substack

source ·
pub enum Substack<'a, T> {
    Frame(Stackframe<'a, T>),
    Bottom,
}
Expand description

A FILO stack that lives on the regular call stack as a linked list.

Variants§

§

Frame(Stackframe<'a, T>)

A level in the linked list

§

Bottom

The end of the list

Implementations§

source§

impl<'a, T> Substack<'a, T>

source

pub fn opt(&'a self) -> Option<&'a Stackframe<'a, T>>

Convert the substack into an option of stackframe

source

pub fn iter(&self) -> SubstackIterator<'_, T>

Construct an iterator starting from the top and moving down the stack

source

pub fn push(&'a self, item: T) -> Self

Add the item to this substack

source

pub fn new_frame(&'a self, item: T) -> Stackframe<'a, T>

Create a new frame on top of this substack

source

pub fn pop(&'a self, count: usize) -> &'a Self

obtain the previous stackframe if one exists.

Panics

if the index is greater than the number of stack frames

source

pub fn len(&self) -> usize

number of stackframes

source

pub fn is_empty(&self) -> bool

is this the bottom of the stack

source

pub fn value(&self) -> Option<&T>

Get a reference to the value held in this stackframe

source

pub fn unreverse(&self) -> Vec<T>where T: Clone,

Clones the elements into a vector starting at the bottom of the stack

source

pub fn rfold<'b, U, F: FnMut(U, &'b T) -> U>( &'b self, default: U, callback: F ) -> U

Visit all of the elements lowest first. This uses internal recursion, but since the iterator itself fits on the stack it’s very likely that the reversed slices to it also will. If the callback is pure, these stack frames should store a single reference to the corresponding item.

Trait Implementations§

source§

impl<'a, T: Clone> Clone for Substack<'a, T>

source§

fn clone(&self) -> Substack<'a, 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<'a, T: Debug> Debug for Substack<'a, T>

source§

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

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

impl<'a, T: Copy> Copy for Substack<'a, T>

Auto Trait Implementations§

§

impl<'a, T> RefUnwindSafe for Substack<'a, T>where T: RefUnwindSafe,

§

impl<'a, T> Send for Substack<'a, T>where T: Send + Sync,

§

impl<'a, T> Sync for Substack<'a, T>where T: Sync,

§

impl<'a, T> Unpin for Substack<'a, T>where T: Unpin,

§

impl<'a, T> UnwindSafe for Substack<'a, T>where T: UnwindSafe + RefUnwindSafe,

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.