pub struct Arena<T, K> { /* private fields */ }
Implementations§
Source§impl<T, K> Arena<T, K>where
K: PartialEq,
impl<T, K> Arena<T, K>where
K: PartialEq,
pub fn new() -> Self
pub fn insert(&mut self, data: T, key: K, parent: Option<usize>) -> usize
pub fn root(&self) -> Option<usize>
pub fn set_root(&mut self, new_root: Option<usize>)
pub fn nodes(&self) -> &Vec<Node<T, K>>
pub fn find_inner(&self, key: K) -> Option<&T>
pub fn get_inner(&self, index: usize) -> Option<&T>
pub fn get_inner_mut(&mut self, index: usize) -> Option<&mut T>
pub fn get(&self, index: usize) -> Option<&Node<T, K>>
pub fn get_mut(&mut self, index: usize) -> Option<&mut Node<T, K>>
pub fn find(&self, key: K) -> Option<&Node<T, K>>
pub fn get_parent(&self, index: usize) -> Option<&Node<T, K>>
pub fn is_empty(&self) -> bool
pub fn count(&self) -> usize
Trait Implementations§
Source§impl<'de, T, K> Deserialize<'de> for Arena<T, K>where
T: Deserialize<'de>,
K: Deserialize<'de>,
impl<'de, T, K> Deserialize<'de> for Arena<T, K>where
T: Deserialize<'de>,
K: Deserialize<'de>,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl<T, K> Freeze for Arena<T, K>
impl<T, K> RefUnwindSafe for Arena<T, K>where
K: RefUnwindSafe,
T: RefUnwindSafe,
impl<T, K> Send for Arena<T, K>
impl<T, K> Sync for Arena<T, K>
impl<T, K> Unpin for Arena<T, K>
impl<T, K> UnwindSafe for Arena<T, K>where
K: UnwindSafe,
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
Mutably borrows from an owned value. Read more