pub struct DynStack { /* private fields */ }
Expand description
Stack wrapper around a buffer of uninitialized bytes.
Implementations§
source§impl DynStack
impl DynStack
sourcepub fn new(buffer: &mut [MaybeUninit<u8>]) -> &mut Self
pub fn new(buffer: &mut [MaybeUninit<u8>]) -> &mut Self
Returns a new DynStack
from the provided memory buffer.
sourcepub fn new_any<T>(buffer: &mut [MaybeUninit<T>]) -> &mut Self
pub fn new_any<T>(buffer: &mut [MaybeUninit<T>]) -> &mut Self
Returns a new DynStack
from the provided memory buffer.
sourcepub fn can_hold(&self, alloc_req: StackReq) -> bool
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.
sourcepub fn as_ptr(&self) -> *const u8
pub fn as_ptr(&self) -> *const u8
Returns a pointer to the (possibly uninitialized) stack memory.
sourcepub fn make_aligned_uninit<T>(
&mut self,
size: usize,
align: usize,
) -> (DynArray<'_, MaybeUninit<T>>, &mut Self)
pub fn make_aligned_uninit<T>( &mut self, size: usize, align: usize, ) -> (DynArray<'_, MaybeUninit<T>>, &mut Self)
sourcepub fn make_aligned_with<T>(
&mut self,
size: usize,
align: usize,
f: impl FnMut(usize) -> T,
) -> (DynArray<'_, T>, &mut Self)
pub fn make_aligned_with<T>( &mut self, size: usize, align: usize, f: impl FnMut(usize) -> T, ) -> (DynArray<'_, T>, &mut Self)
sourcepub fn make_uninit<T>(
&mut self,
size: usize,
) -> (DynArray<'_, MaybeUninit<T>>, &mut Self)
pub fn make_uninit<T>( &mut self, size: usize, ) -> (DynArray<'_, MaybeUninit<T>>, &mut Self)
sourcepub fn make_with<T>(
&mut self,
size: usize,
f: impl FnMut(usize) -> T,
) -> (DynArray<'_, T>, &mut Self)
pub fn make_with<T>( &mut self, size: usize, f: impl FnMut(usize) -> T, ) -> (DynArray<'_, T>, &mut Self)
sourcepub fn collect_aligned<I: IntoIterator>(
&mut self,
align: usize,
iter: I,
) -> (DynArray<'_, I::Item>, &mut Self)
pub fn collect_aligned<I: IntoIterator>( &mut self, align: usize, iter: I, ) -> (DynArray<'_, I::Item>, &mut Self)
Returns a new aligned DynArray
, 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.