Skip to main content

SmallDeque

Struct SmallDeque 

Source
pub struct SmallDeque<T, const N: usize> { /* private fields */ }
Expand description

A double-ended queue that lives on the stack for up to N items, then spills to a heap-allocated VecDeque transparently.

§Stack representation

Items are stored in a ring buffer of [MaybeUninit<T>; N] with a head cursor and a len counter. Two helpers, wrap_add and wrap_sub, implement the modular arithmetic using a bitmask (requires N to be a power of two — enforced by a const assertion in new).

§Spill behaviour

When push_back or push_front causes len > capacity on the stack, the ring buffer is drained in logical order into a freshly heap-allocated VecDeque via spill_to_heap. After a spill, all subsequent mutations go directly to the VecDeque; the struct never returns to stack storage.

§Generic parameters

ParameterMeaning
TElement type
NStack capacity; must be a power of two

§Compile-time assertions

new() uses const { assert!(...) } to verify:

  • size_of::<Self>() <= 16 KiB — prevents accidental blowing of the stack frame.
  • N.is_power_of_two() — required for bitmask ring-buffer arithmetic.

Implementations§

Source§

impl<T, const N: usize> SmallDeque<T, N>

Source

pub fn new() -> Self

Creates a new empty deque backed by stack storage.

§Panics (compile-time)

Asserts that size_of::<Self>() <= 16 KiB and that N is a power of two.

Source

pub fn with_capacity(capacity: usize) -> Self

Creates a deque that starts on the heap if capacity > N, otherwise on the stack.

Useful when the caller already knows the required size will exceed N.

Source

pub fn is_on_stack(&self) -> bool

Returns true if the deque is currently using stack storage.

Source

pub fn len(&self) -> usize

Returns the number of elements currently in the deque.

Source

pub fn is_empty(&self) -> bool

Returns true if the deque contains no elements.

Source

pub fn capacity(&self) -> usize

Returns the current capacity (not necessarily N after a spill).

Source

pub fn get(&self, index: usize) -> Option<&T>

Returns a shared reference to the element at logical index, or None.

Logical index 0 is the front (oldest element).

Source

pub fn get_mut(&mut self, index: usize) -> Option<&mut T>

Returns an exclusive reference to the element at logical index, or None.

Source

pub fn reserve(&mut self, additional: usize)

Reserves capacity for at least additional more elements, spilling to the heap if necessary.

Source

pub fn push_back(&mut self, item: T)

Appends item to the back of the deque. Spills to heap if the stack is full.

Source

pub fn push_front(&mut self, item: T)

Prepends item to the front of the deque. Spills to heap if the stack is full.

Source

pub fn pop_back(&mut self) -> Option<T>

Removes and returns the last element, or None if empty.

Source

pub fn pop_front(&mut self) -> Option<T>

Removes and returns the first element, or None if empty.

Source

pub fn remove(&mut self, index: usize) -> Option<T>

Removes the element at logical index and returns it, or None if out of bounds.

Chooses whether to shift from the front or back depending on which is cheaper (shift the shorter half).

Source

pub fn clear(&mut self)

Shortens the deque to len, dropping all elements beyond that point.

If len >= self.len(), this is a no-op.

Source

pub fn truncate(&mut self, len: usize)

Shortens the deque to at most len elements, dropping those beyond.

Source

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

Returns a shared reference to the front element, or None if empty.

Source

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

Returns a shared reference to the back element, or None if empty.

Source

pub fn front_mut(&mut self) -> Option<&mut T>

Returns an exclusive reference to the front element, or None if empty.

Source

pub fn back_mut(&mut self) -> Option<&mut T>

Returns an exclusive reference to the back element, or None if empty.

Source

pub fn as_slices(&self) -> (&[T], &[T])

Returns up to two contiguous slices covering the logical range [0, len).

Returns (head_slice, &[]) when the ring buffer hasn’t wrapped, or (head_slice, tail_slice) when it has. On the heap path delegates to VecDeque::as_slices.

Source

pub fn as_mut_slices(&mut self) -> (&mut [T], &mut [T])

Mutable counterpart of as_slices.

Trait Implementations§

Source§

impl<T, const N: usize> AnyDeque<T> for SmallDeque<T, N>

Source§

fn len(&self) -> usize

Returns the number of elements in the deque.
Source§

fn push_back(&mut self, item: T)

Appends an element to the back.
Source§

fn push_front(&mut self, item: T)

Prepends an element to the front.
Source§

fn pop_back(&mut self) -> Option<T>

Removes and returns the element from the back, or None if empty.
Source§

fn pop_front(&mut self) -> Option<T>

Removes and returns the element from the front, or None if empty.
Source§

fn remove(&mut self, index: usize) -> Option<T>

Removes and returns the element at index, or None if out of bounds.
Source§

fn clear(&mut self)

Removes all elements.
Source§

fn front(&self) -> Option<&T>

Returns a shared reference to the front element, or None if empty.
Source§

fn back(&self) -> Option<&T>

Returns a shared reference to the back element, or None if empty.
Source§

fn front_mut(&mut self) -> Option<&mut T>

Returns an exclusive reference to the front element, or None if empty.
Source§

fn back_mut(&mut self) -> Option<&mut T>

Returns an exclusive reference to the back element, or None if empty.
Source§

fn is_empty(&self) -> bool

Returns true if the deque contains no elements.
Source§

impl<T: Clone, const N: usize> Clone for SmallDeque<T, N>

Source§

fn clone(&self) -> Self

Returns a duplicate 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<T: Debug, const N: usize> Debug for SmallDeque<T, N>

Source§

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

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

impl<T, const N: usize> Default for SmallDeque<T, N>

Source§

fn default() -> Self

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

impl<T, const N: usize> Drop for SmallDeque<T, N>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<T, const N: usize> Extend<T> for SmallDeque<T, N>

Source§

fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I)

Extends a collection with the contents of an iterator. Read more
Source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
Source§

impl<T, const N: usize> FromIterator<T> for SmallDeque<T, N>

Source§

fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self

Creates a value from an iterator. Read more
Source§

impl<T: Ord, const N: usize> Ord for SmallDeque<T, N>

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<T: PartialEq, const N: usize> PartialEq for SmallDeque<T, N>

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T: PartialOrd, const N: usize> PartialOrd for SmallDeque<T, N>

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<T: Eq, const N: usize> Eq for SmallDeque<T, N>

Auto Trait Implementations§

§

impl<T, const N: usize> Freeze for SmallDeque<T, N>
where T: Freeze,

§

impl<T, const N: usize> RefUnwindSafe for SmallDeque<T, N>
where T: RefUnwindSafe,

§

impl<T, const N: usize> Send for SmallDeque<T, N>
where T: Send,

§

impl<T, const N: usize> Sync for SmallDeque<T, N>
where T: Sync,

§

impl<T, const N: usize> Unpin for SmallDeque<T, N>
where T: Unpin,

§

impl<T, const N: usize> UnsafeUnpin for SmallDeque<T, N>
where T: UnsafeUnpin,

§

impl<T, const N: usize> UnwindSafe for SmallDeque<T, N>
where T: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. 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> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.