pub enum Node<T: Default> {
Branch {
data: T,
children: Vec<Node<T>>,
},
Root(Vec<Node<T>>),
Leaf(T),
}Variants§
Implementations§
Source§impl<T: Default> Node<T>
impl<T: Default> Node<T>
pub fn branch<C: IntoIterator<Item = Node<T>>>(data: T, children: C) -> Self
pub fn empty_root() -> Self
pub fn empty_branch(data: T) -> Self
pub fn leaf(data: T) -> Self
pub fn data(&self) -> Option<&T>
pub fn data_mut(&mut self) -> Option<&mut T>
pub fn into_data(self) -> Option<T>
Sourcepub fn insert(&mut self, node: Node<T>) -> bool
pub fn insert(&mut self, node: Node<T>) -> bool
Inserts a node if this node is capable of containing children
Sourcepub fn create_leaves(self) -> Self
pub fn create_leaves(self) -> Self
Turns all (sub)branches with no children into leaves
pub fn find<P: Find<T>>(&self, predicate: &P) -> Option<&Self>
pub fn find_mut<P: Find<T>>(&mut self, predicate: &P) -> Option<&mut Self>
pub fn into_find<P: Find<T>>(self, predicate: &P) -> Option<Self>
Trait Implementations§
Source§impl<'de, T> Deserialize<'de> for Node<T>where
T: Deserialize<'de> + Default,
impl<'de, T> Deserialize<'de> for Node<T>where
T: Deserialize<'de> + Default,
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
impl<T: Default> StructuralPartialEq for Node<T>
Auto Trait Implementations§
impl<T> Freeze for Node<T>where
T: Freeze,
impl<T> RefUnwindSafe for Node<T>where
T: RefUnwindSafe,
impl<T> Send for Node<T>where
T: Send,
impl<T> Sync for Node<T>where
T: Sync,
impl<T> Unpin for Node<T>where
T: Unpin,
impl<T> UnwindSafe for Node<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
Mutably borrows from an owned value. Read more