Struct dyn_stack::PodStack

source ·
pub struct PodStack<'a> { /* private fields */ }
Expand description

Stack wrapper around a buffer of bytes.

Implementations§

source§

impl<'a> PodStack<'a>

source

pub fn new(buffer: &'a mut [u8]) -> Self

Returns a new PodStack from the provided memory buffer.

source

pub fn can_hold(&self, alloc_req: StackReq) -> bool

Returns true if the stack can hold an allocation with the given size and alignment requirements.

source

pub fn len_bytes(&self) -> usize

Returns the number of bytes that this stack can hold.

source

pub fn as_ptr(&self) -> *const u8

Returns a pointer to the stack memory.

source

pub fn make_aligned_raw<T: Pod>( self, size: usize, align: usize ) -> (&'a mut [T], Self)

Returns a new aligned and uninitialized slice and a stack over the remainder of the buffer.

Panics

Panics if the stack isn’t large enough to allocate the array.

source

pub fn make_aligned_with<T: Pod, F: FnMut(usize) -> T>( self, size: usize, align: usize, f: F ) -> (&'a mut [T], Self)

Returns a new aligned slice, initialized with the provided function, and a stack over the remainder of the buffer.

Panics

Panics if the stack isn’t large enough to allocate the array, or if the provided function panics.

source

pub fn make_raw<T: Pod>(self, size: usize) -> (&'a mut [T], Self)

Returns a new uninitialized slice and a stack over the remainder of the buffer.

Panics

Panics if the stack isn’t large enough to allocate the array.

source

pub fn make_with<T: Pod, F: FnMut(usize) -> T>( self, size: usize, f: F ) -> (&'a mut [T], Self)

Returns a new slice, initialized with the provided function, and a stack over the remainder of the buffer.

Panics

Panics if the stack isn’t large enough to allocate the array, or if the provided function panics.

source

pub fn collect_aligned<I: IntoIterator>( self, align: usize, iter: I ) -> (&'a mut [I::Item], Self)where I::Item: Pod,

Returns a new aligned slice, initialized with the provided iterator, and a stack over the remainder of the buffer.
If there isn’t enough space for all the iterator items, then the returned array only contains the first elements that fit into the stack.

Panics

Panics if the provided iterator panics.

source

pub fn collect<I: IntoIterator>(self, iter: I) -> (&'a mut [I::Item], Self)where I::Item: Pod,

Returns a new slice, initialized with the provided iterator, and a stack over the remainder of the buffer.
If there isn’t enough space for all the iterator items, then the returned array only contains the first elements that fit into the stack.

Panics

Panics if the provided iterator panics.

Trait Implementations§

source§

impl<'a, 'b> ReborrowMut<'b> for PodStack<'a>where 'a: 'b,

§

type Target = PodStack<'b>

source§

fn rb_mut(&'b mut self) -> Self::Target

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for PodStack<'a>

§

impl<'a> Send for PodStack<'a>

§

impl<'a> Sync for PodStack<'a>

§

impl<'a> Unpin for PodStack<'a>

§

impl<'a> !UnwindSafe for PodStack<'a>

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