Struct NodePool

Source
pub struct NodePool<'a> {
    pub inner_vec: Vec<Node<'a>>,
    pub counter: u32,
}
Expand description

Arena-based container storing Nodes

A NodePool is essentially just a Vec<Node> that is indexed by NodeIDs. Each parsing construct stores NodeIDs which refer to indices within the NodePool. It acts like a flattened version of the AST where each node can be easily iterated over and tracked.

NodePool::iter and NodePool::iter_mut can be used for iterating over the contents of the pool.

§Safety

Removing or inserting an element at a position other than the end might invalidate every other NodeID and therefore the AST. Removing and de-allocating an individual Node is not possible due to this effect. However, the result can be feigned in the tree by “deleting” the node from its parent. See NodePool::delete_node.

Fields§

§inner_vec: Vec<Node<'a>>§counter: u32

Implementations§

Source§

impl<'a> NodePool<'a>

Source

pub fn get(&self, id: NodeID) -> Option<&'a Node<'_>>

Source

pub fn get_mut(&mut self, id: NodeID) -> Option<&'a mut Node<'_>>

Source

pub fn iter( &self, ) -> impl Iterator<Item = &Node<'a>> + DoubleEndedIterator<Item = &Node<'a>>

Source

pub fn iter_mut( &mut self, ) -> impl Iterator<Item = &mut Node<'a>> + DoubleEndedIterator<Item = &mut Node<'a>>

Source

pub fn print_tree(&self)

Outputs a (somewhat) legible representation of the tree to stdout.

Source

pub fn root_id(&self) -> NodeID

Returns the NodeID of the first element in the pool.

Source

pub fn delete_node(&mut self, index_id: NodeID)

Removes a Node from its parents’ “children”.

This action mimicks the effect of a deletion, but does not actually deallocate or remove the node from the pool.

Trait Implementations§

Source§

impl<'a> Debug for NodePool<'a>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<'a> Index<NodeID> for NodePool<'a>

Source§

type Output = Node<'a>

The returned type after indexing.
Source§

fn index(&self, index: NodeID) -> &Self::Output

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

impl<'a> IndexMut<NodeID> for NodePool<'a>

Source§

fn index_mut(&mut self, index: NodeID) -> &mut Self::Output

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

Auto Trait Implementations§

§

impl<'a> Freeze for NodePool<'a>

§

impl<'a> RefUnwindSafe for NodePool<'a>

§

impl<'a> !Send for NodePool<'a>

§

impl<'a> !Sync for NodePool<'a>

§

impl<'a> Unpin for NodePool<'a>

§

impl<'a> UnwindSafe for NodePool<'a>

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
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.

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, 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.