[−][src]Struct sized_chunks::ring_buffer::RingBuffer
Methods
impl<A, N> RingBuffer<A, N> where
N: ChunkLength<A>,
[src]
N: ChunkLength<A>,
pub const CAPACITY: usize
[src]
#[must_use]
pub fn new() -> Self
[src]
Construct an empty ring buffer.
#[must_use]
pub fn unit(value: A) -> Self
[src]
Construct a ring buffer with a single item.
#[must_use]
pub fn pair(value1: A, value2: A) -> Self
[src]
Construct a ring buffer with two items.
#[must_use]
pub fn drain_from(other: &mut Self) -> Self
[src]
Construct a new ring buffer and move every item from other
into the
new buffer.
Time: O(n)
#[must_use]
pub fn collect_from<I>(iter: &mut I, count: usize) -> Self where
I: Iterator<Item = A>,
[src]
I: Iterator<Item = A>,
Construct a new ring buffer and populate it by taking count
items from
the iterator iter
.
Panics if the iterator contains less than count
items.
Time: O(n)
#[must_use]
pub fn from_front(other: &mut Self, count: usize) -> Self
[src]
Construct a new ring buffer and populate it by taking count
items from
the front of other
.
Time: O(n) for the number of items moved
#[must_use]
pub fn from_back(other: &mut Self, count: usize) -> Self
[src]
Construct a new ring buffer and populate it by taking count
items from
the back of other
.
Time: O(n) for the number of items moved
#[must_use]
pub fn len(&self) -> usize
[src]
Get the length of the ring buffer.
#[must_use]
pub fn is_empty(&self) -> bool
[src]
Test if the ring buffer is empty.
#[must_use]
pub fn is_full(&self) -> bool
[src]
Test if the ring buffer is full.
ⓘImportant traits for Iter<'a, A, N>#[must_use]
pub fn iter(&self) -> Iter<A, N>
[src]
ⓘImportant traits for IterMut<'a, A, N>#[must_use]
pub fn iter_mut(&mut self) -> IterMut<A, N>
[src]
#[must_use]
pub fn slice<R: RangeBounds<usize>>(&self, range: R) -> Slice<A, N>
[src]
#[must_use]
pub fn slice_mut<R: RangeBounds<usize>>(&mut self, range: R) -> SliceMut<A, N>
[src]
#[must_use]
pub fn get(&self, index: usize) -> Option<&A>
[src]
Get the value at a given index.
#[must_use]
pub fn get_mut(&mut self, index: usize) -> Option<&mut A>
[src]
Get a mutable reference to the value at a given index.
#[must_use]
pub fn first(&self) -> Option<&A>
[src]
Get the first value in the buffer.
#[must_use]
pub fn first_mut(&mut self) -> Option<&mut A>
[src]
Get a mutable reference to the first value in the buffer.
#[must_use]
pub fn last(&self) -> Option<&A>
[src]
Get the last value in the buffer.
#[must_use]
pub fn last_mut(&mut self) -> Option<&mut A>
[src]
Get a mutable reference to the last value in the buffer.
pub fn push_back(&mut self, value: A)
[src]
Push a value to the back of the buffer.
Panics if the capacity of the buffer is exceeded.
Time: O(1)
pub fn push_front(&mut self, value: A)
[src]
Push a value to the front of the buffer.
Panics if the capacity of the buffer is exceeded.
Time: O(1)
pub fn pop_back(&mut self) -> Option<A>
[src]
Pop a value from the back of the buffer.
Returns None
if the buffer is empty.
Time: O(1)
pub fn pop_front(&mut self) -> Option<A>
[src]
Pop a value from the front of the buffer.
Returns None
if the buffer is empty.
Time: O(1)
pub fn drop_left(&mut self, index: usize)
[src]
Discard all items up to but not including index
.
Panics if index
is out of bounds.
Time: O(n) for the number of items dropped
pub fn drop_right(&mut self, index: usize)
[src]
Discard all items from index
onward.
Panics if index
is out of bounds.
Time: O(n) for the number of items dropped
#[must_use]
pub fn split_off(&mut self, index: usize) -> Self
[src]
Split a buffer into two, the original buffer containing
everything up to index
and the returned buffer containing
everything from index
onwards.
Panics if index
is out of bounds.
Time: O(n) for the number of items in the new buffer
pub fn append(&mut self, other: &mut Self)
[src]
Remove all items from other
and append them to the back of self
.
Panics if the capacity of self
is exceeded.
other
will be an empty buffer after this operation.
Time: O(n) for the number of items moved
pub fn drain_from_front(&mut self, other: &mut Self, count: usize)
[src]
Remove count
items from the front of other
and append them to the
back of self
.
Panics if self
doesn't have count
items left, or if other
has
fewer than count
items.
Time: O(n) for the number of items moved
pub fn drain_from_back(&mut self, other: &mut Self, count: usize)
[src]
Remove count
items from the back of other
and append them to the
front of self
.
Panics if self
doesn't have count
items left, or if other
has
fewer than count
items.
Time: O(n) for the number of items moved
pub fn set(&mut self, index: usize, value: A) -> A
[src]
Update the value at index index
, returning the old value.
Panics if index
is out of bounds.
Time: O(1)
pub fn insert(&mut self, index: usize, value: A)
[src]
Insert a new value at index index
, shifting all the following values
to the right.
Panics if the index is out of bounds.
Time: O(n) for the number of items shifted
pub fn remove(&mut self, index: usize) -> A
[src]
Remove the value at index index
, shifting all the following values to
the left.
Returns the removed value.
Panics if the index is out of bounds.
Time: O(n) for the number of items shifted
ⓘImportant traits for Drain<'a, A, N>pub fn drain(&mut self) -> Drain<A, N>
[src]
Construct an iterator that drains values from the front of the buffer.
pub fn clear(&mut self)
[src]
Discard the contents of the buffer.
Time: O(n)
Trait Implementations
impl<A: Clone, N: ChunkLength<A>> Clone for RingBuffer<A, N>
[src]
fn clone(&self) -> Self
[src]
default fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl<A: PartialEq, N: ChunkLength<A>> PartialEq<RingBuffer<A, N>> for RingBuffer<A, N>
[src]
#[must_use]
fn eq(&self, other: &Self) -> bool
[src]
#[must_use]
default fn ne(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests for !=
.
impl<A, N, Slice> PartialEq<Slice> for RingBuffer<A, N> where
Slice: Borrow<[A]>,
A: PartialEq,
N: ChunkLength<A>,
[src]
Slice: Borrow<[A]>,
A: PartialEq,
N: ChunkLength<A>,
#[must_use]
fn eq(&self, other: &Slice) -> bool
[src]
#[must_use]
default fn ne(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests for !=
.
impl<A: PartialOrd, N: ChunkLength<A>> PartialOrd<RingBuffer<A, N>> for RingBuffer<A, N>
[src]
#[must_use]
fn partial_cmp(&self, other: &Self) -> Option<Ordering>
[src]
#[must_use]
default fn lt(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests less than (for self
and other
) and is used by the <
operator. Read more
#[must_use]
default fn le(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
#[must_use]
default fn gt(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests greater than (for self
and other
) and is used by the >
operator. Read more
#[must_use]
default fn ge(&self, other: &Rhs) -> bool
1.0.0[src]
This method tests greater than or equal to (for self
and other
) and is used by the >=
operator. Read more
impl<A: Eq, N: ChunkLength<A>> Eq for RingBuffer<A, N>
[src]
impl<A, N: ChunkLength<A>> Extend<A> for RingBuffer<A, N>
[src]
fn extend<I: IntoIterator<Item = A>>(&mut self, iter: I)
[src]
impl<'a, A: Clone + 'a, N: ChunkLength<A>> Extend<&'a A> for RingBuffer<A, N>
[src]
fn extend<I: IntoIterator<Item = &'a A>>(&mut self, iter: I)
[src]
impl<A, N: ChunkLength<A>> Default for RingBuffer<A, N>
[src]
impl<A, N: ChunkLength<A>> Drop for RingBuffer<A, N>
[src]
impl<'a, A: 'a, N: ChunkLength<A> + 'a> From<&'a RingBuffer<A, N>> for Slice<'a, A, N>
[src]
#[must_use]
fn from(buffer: &'a RingBuffer<A, N>) -> Self
[src]
impl<'a, A: 'a, N: ChunkLength<A> + 'a> From<&'a mut RingBuffer<A, N>> for SliceMut<'a, A, N>
[src]
#[must_use]
fn from(buffer: &'a mut RingBuffer<A, N>) -> Self
[src]
impl<A: Ord, N: ChunkLength<A>> Ord for RingBuffer<A, N>
[src]
#[must_use]
fn cmp(&self, other: &Self) -> Ordering
[src]
default fn max(self, other: Self) -> Self
1.21.0[src]
Compares and returns the maximum of two values. Read more
default fn min(self, other: Self) -> Self
1.21.0[src]
Compares and returns the minimum of two values. Read more
default fn clamp(self, min: Self, max: Self) -> Self
[src]
clamp
)Restrict a value to a certain interval. Read more
impl<A, N: ChunkLength<A>> IntoIterator for RingBuffer<A, N>
[src]
type Item = A
The type of the elements being iterated over.
type IntoIter = OwnedIter<A, N>
Which kind of iterator are we turning this into?
#[must_use]
fn into_iter(self) -> Self::IntoIter
[src]
impl<'a, A, N: ChunkLength<A>> IntoIterator for &'a RingBuffer<A, N>
[src]
type Item = &'a A
The type of the elements being iterated over.
type IntoIter = Iter<'a, A, N>
Which kind of iterator are we turning this into?
#[must_use]
fn into_iter(self) -> Self::IntoIter
[src]
impl<'a, A, N: ChunkLength<A>> IntoIterator for &'a mut RingBuffer<A, N>
[src]
type Item = &'a mut A
The type of the elements being iterated over.
type IntoIter = IterMut<'a, A, N>
Which kind of iterator are we turning this into?
#[must_use]
fn into_iter(self) -> Self::IntoIter
[src]
impl<A: Hash, N: ChunkLength<A>> Hash for RingBuffer<A, N>
[src]
fn hash<H: Hasher>(&self, hasher: &mut H)
[src]
default fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
Feeds a slice of this type into the given [Hasher
]. Read more
impl<A, N> Index<usize> for RingBuffer<A, N> where
N: ChunkLength<A>,
[src]
N: ChunkLength<A>,
type Output = A
The returned type after indexing.
#[must_use]
fn index(&self, index: usize) -> &Self::Output
[src]
impl<A, N> IndexMut<usize> for RingBuffer<A, N> where
N: ChunkLength<A>,
[src]
N: ChunkLength<A>,
impl<A, N: ChunkLength<A>> FromIterator<A> for RingBuffer<A, N>
[src]
#[must_use]
fn from_iter<I: IntoIterator<Item = A>>(iter: I) -> Self
[src]
impl<A: Debug, N: ChunkLength<A>> Debug for RingBuffer<A, N>
[src]
impl<N: ChunkLength<u8>> Write for RingBuffer<u8, N>
[src]
fn write(&mut self, buf: &[u8]) -> Result<usize>
[src]
fn flush(&mut self) -> Result<()>
[src]
default fn write_vectored(&mut self, bufs: &[IoVec]) -> Result<usize, Error>
[src]
iovec
)Like write
, except that it writes from a slice of buffers. Read more
default fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
1.0.0[src]
Attempts to write an entire buffer into this writer. Read more
default fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>
1.0.0[src]
Writes a formatted string into this writer, returning any error encountered. Read more
default fn by_ref(&mut self) -> &mut Self
1.0.0[src]
Creates a "by reference" adaptor for this instance of Write
. Read more
Auto Trait Implementations
impl<A, N> Send for RingBuffer<A, N> where
A: Send,
N: Send,
<N as ChunkLength<A>>::SizedType: Send,
A: Send,
N: Send,
<N as ChunkLength<A>>::SizedType: Send,
impl<A, N> Sync for RingBuffer<A, N> where
A: Sync,
N: Sync,
<N as ChunkLength<A>>::SizedType: Sync,
A: Sync,
N: Sync,
<N as ChunkLength<A>>::SizedType: Sync,
Blanket Implementations
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
impl<T, U> Into for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From for T
[src]
impl<I> IntoIterator for I where
I: Iterator,
[src]
I: Iterator,
type Item = <I as Iterator>::Item
The type of the elements being iterated over.
type IntoIter = I
Which kind of iterator are we turning this into?
fn into_iter(self) -> I
[src]
impl<T, U> TryFrom for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T> Borrow for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Same for T
[src]
type Output = T
Should always be Self