Skip to main content

AppendOnlyVec

Struct AppendOnlyVec 

pub struct AppendOnlyVec<T, const AMOUNT_OF_BINS: usize = 32, const BIN_OFFSET: u32 = 3> { /* private fields */ }
Expand description

Append only vec of items T.

This vec will never re-allocate and never remove items. This means that as long as this vec is around, we can have valid references to all the data it stores. This also means that we can add items to the vec without having a mutable reference to it.

AMOUNT_OF_BINS is total amount of item bins (=arrays). Each bin has double the capacity then the one before, so even with a low number here, we should be able to store a huge amount of items.

BIN_OFFSET calculates the offset of the first bin. Effectively this mean our first bin will have 2^BIN_OFFSET size.

Implementations§

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

pub fn new() -> AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

Create a new AppendOnlyVec of T items

use rama_utils::collections::AppendOnlyVec;
// This should fail because this overflow INITIAL_BIN_SIZE
let _ = AppendOnlyVec::<usize, 300, 100>::new();
use rama_utils::collections::AppendOnlyVec;
// This should fail because the total size exceeds isize::MAX
let _ = AppendOnlyVec::<u64, 60, 10>::new();

pub fn push(&self, element: T) -> usize

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

pub fn is_empty(&self) -> bool

pub fn len(&self) -> usize

pub const fn capacity() -> usize

Returns the maximum number of elements this configuration can hold. Total capacity = initial_bin_size * (2^AMOUNT_OF_BINS - 1)

pub fn iter(&self) -> Iter<'_, T, AMOUNT_OF_BINS, BIN_OFFSET>

Returns an iterator over the elements currently in the vector. The iterator snapshots the length at creation time.

pub unsafe fn get_unchecked(&self, idx: usize) -> &T

Get item with idx from this vec

§Safety

This function is safe if idx < self.len()

Trait Implementations§

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Debug for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>
where T: Debug,

§

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

Formats the value using the given formatter. Read more
§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Default for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

fn default() -> AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

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

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Drop for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

fn drop(&mut self)

Executes the destructor for this type. Read more
§

impl<T, const BINS: usize, const OFFSET: u32> Extend<T> for &AppendOnlyVec<T, BINS, OFFSET>

§

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

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
§

impl<T, const BINS: usize, const OFFSET: u32> Extend<T> for AppendOnlyVec<T, BINS, OFFSET>

§

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

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
§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> FromIterator<T> for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

fn from_iter<I>(iter: I) -> AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>
where I: IntoIterator<Item = T>,

Creates a value from an iterator. Read more
§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Index<usize> for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

type Output = T

The returned type after indexing.
§

fn index( &self, idx: usize, ) -> &<AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET> as Index<usize>>::Output

Performs the indexing (container[index]) operation. Read more
§

impl<'a, T, const BINS: usize, const OFFSET: u32> IntoIterator for &'a AppendOnlyVec<T, BINS, OFFSET>

§

type Item = &'a T

The type of the elements being iterated over.
§

type IntoIter = Iter<'a, T, BINS, OFFSET>

Which kind of iterator are we turning this into?
§

fn into_iter( self, ) -> <&'a AppendOnlyVec<T, BINS, OFFSET> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<T, const BINS: usize, const OFFSET: u32> IntoIterator for AppendOnlyVec<T, BINS, OFFSET>

§

type Item = T

The type of the elements being iterated over.
§

type IntoIter = IntoIterOwned<T, BINS, OFFSET>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <AppendOnlyVec<T, BINS, OFFSET> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Send for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>
where T: Send,

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Sync for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>
where T: Send + Sync,

Auto Trait Implementations§

§

impl<T, const AMOUNT_OF_BINS: usize = 32, const BIN_OFFSET: u32 = 3> !Freeze for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> RefUnwindSafe for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> Unpin for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>

§

impl<T, const AMOUNT_OF_BINS: usize, const BIN_OFFSET: u32> UnwindSafe for AppendOnlyVec<T, AMOUNT_OF_BINS, BIN_OFFSET>
where T: RefUnwindSafe,

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
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FutureExt for T

§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a rama_grpc::Request
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
§

impl<T, U> RamaFrom<T> for U
where U: From<T>,

§

fn rama_from(value: T) -> U

§

impl<T, U, CrateMarker> RamaInto<U, CrateMarker> for T
where U: RamaFrom<T, CrateMarker>,

§

fn rama_into(self) -> U

§

impl<T, U> RamaTryFrom<T> for U
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

§

fn rama_try_from(value: T) -> Result<U, <U as RamaTryFrom<T>>::Error>

§

impl<T, U, CrateMarker> RamaTryInto<U, CrateMarker> for T
where U: RamaTryFrom<T, CrateMarker>,

§

type Error = <U as RamaTryFrom<T, CrateMarker>>::Error

§

fn rama_try_into(self) -> Result<U, <U as RamaTryFrom<T, CrateMarker>>::Error>

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
§

impl<T> Extension for T
where T: Any + Send + Sync + Debug + 'static,