Struct comfy_core::Arena 
source · pub struct Arena<T> { /* private fields */ }Expand description
Container that can have elements inserted into it and removed from it.
Indices use the Index type, created by inserting values with Arena::insert.
Implementations§
source§impl<T> Arena<T>
 
impl<T> Arena<T>
sourcepub fn with_capacity(capacity: usize) -> Arena<T>
 
pub fn with_capacity(capacity: usize) -> Arena<T>
Construct an empty arena with space to hold exactly capacity elements
without reallocating.
sourcepub fn capacity(&self) -> usize
 
pub fn capacity(&self) -> usize
Return the number of elements the arena can hold without allocating, including the elements currently in the arena.
sourcepub fn insert(&mut self, value: T) -> Index
 
pub fn insert(&mut self, value: T) -> Index
Insert a new value into the arena, returning an index that can be used to later retrieve the value.
sourcepub fn insert_at(&mut self, index: Index, value: T) -> Option<T>
 
pub fn insert_at(&mut self, index: Index, value: T) -> Option<T>
Insert a new value at a given index, returning the old value if present. The entry’s generation is set to the given index’s generation.
Caveats
This method is capable of “resurrecting” an old Index. This is unavoidable; if we already
have an occupied entry (or had) at this index of some generation M, and then insert_at
that same slot but with a generation N < M, eventually after some number of insertions and
removals it is possible we could end up with an index matching that old index. There are few
cases where this is likely to be a problem, but it is still possible.
sourcepub fn insert_at_slot(&mut self, slot: u32, value: T) -> (Index, Option<T>)
 
pub fn insert_at_slot(&mut self, slot: u32, value: T) -> (Index, Option<T>)
Insert a new value at a given slot, returning the old value if present. If the slot is already occupied, this will increment the generation of the slot, and invalidate any previous indices pointing to it.
sourcepub fn contains(&self, index: Index) -> bool
 
pub fn contains(&self, index: Index) -> bool
Returns true if the given index is valid for the arena.
sourcepub fn contains_slot(&self, slot: u32) -> Option<Index>
 
pub fn contains_slot(&self, slot: u32) -> Option<Index>
Checks to see whether a slot is occupied in the arena, and if it is,
returns Some with the true Index of that slot (slot plus generation.)
Otherwise, returns None.
sourcepub fn get(&self, index: Index) -> Option<&T>
 
pub fn get(&self, index: Index) -> Option<&T>
Get an immutable reference to a value inside the arena by
Index, returning None if the index is not contained in the arena.
sourcepub fn get_mut(&mut self, index: Index) -> Option<&mut T>
 
pub fn get_mut(&mut self, index: Index) -> Option<&mut T>
Get a mutable reference to a value inside the arena by Index,
returning None if the index is not contained in the arena.
sourcepub fn get2_mut(
    &mut self,
    index1: Index,
    index2: Index
) -> (Option<&mut T>, Option<&mut T>)
 
pub fn get2_mut( &mut self, index1: Index, index2: Index ) -> (Option<&mut T>, Option<&mut T>)
sourcepub fn remove(&mut self, index: Index) -> Option<T>
 
pub fn remove(&mut self, index: Index) -> Option<T>
Remove the value contained at the given index from the arena, returning it if it was present.
sourcepub fn invalidate(&mut self, index: Index) -> Option<Index>
 
pub fn invalidate(&mut self, index: Index) -> Option<Index>
Invalidate the given index and return a new index to the same value. This
is roughly equivalent to remove followed by insert, but much faster.
If the old index is already invalid, this method returns None.
sourcepub fn get_by_slot(&self, slot: u32) -> Option<(Index, &T)>
 
pub fn get_by_slot(&self, slot: u32) -> Option<(Index, &T)>
Attempt to look up the given slot in the arena, disregarding any generational
information, and retrieve an immutable reference to it. Returns None if the
slot is empty.
sourcepub fn get_by_slot_mut(&mut self, slot: u32) -> Option<(Index, &mut T)>
 
pub fn get_by_slot_mut(&mut self, slot: u32) -> Option<(Index, &mut T)>
Attempt to look up the given slot in the arena, disregarding any generational
information, and retrieve a mutable reference to it. Returns None if the
slot is empty.
sourcepub fn remove_by_slot(&mut self, slot: u32) -> Option<(Index, T)>
 
pub fn remove_by_slot(&mut self, slot: u32) -> Option<(Index, T)>
Remove an entry in the arena by its slot, disregarding any generational info.
Returns None if the slot was already empty.
sourcepub fn iter(&self) -> Iter<'_, T>
 
pub fn iter(&self) -> Iter<'_, T>
Iterate over all of the indexes and values contained in the arena.
Iteration order is not defined.
sourcepub fn iter_mut(&mut self) -> IterMut<'_, T>
 
pub fn iter_mut(&mut self) -> IterMut<'_, T>
Iterate over all of the indexes and values contained in the arena, with mutable access to each value.
Iteration order is not defined.
sourcepub fn drain(&mut self) -> Drain<'_, T>
 
pub fn drain(&mut self) -> Drain<'_, T>
Returns an iterator that removes each element from the arena.
Iteration order is not defined.
If the iterator is dropped before it is fully consumed, any uniterated items will be dropped from the arena, and the arena will be empty. The arena’s capacity will not be changed.
Trait Implementations§
source§impl<'a, T> IntoIterator for &'a Arena<T>
 
impl<'a, T> IntoIterator for &'a Arena<T>
source§impl<'a, T> IntoIterator for &'a mut Arena<T>
 
impl<'a, T> IntoIterator for &'a mut Arena<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for Arena<T>where
    T: RefUnwindSafe,
impl<T> Send for Arena<T>where
    T: Send,
impl<T> Sync for Arena<T>where
    T: Sync,
impl<T> Unpin for Arena<T>where
    T: Unpin,
impl<T> UnwindSafe for Arena<T>where
    T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
§impl<S> FromSample<S> for S
 
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
§impl<F, T> IntoSample<T> for Fwhere
    T: FromSample<F>,
 
impl<F, T> IntoSample<T> for Fwhere
    T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> Pointable for T
 
impl<T> Pointable for T
source§impl<R, P> ReadPrimitive<R> for P
 
impl<R, P> ReadPrimitive<R> for P
source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
 
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
ReadEndian::read_from_little_endian().