use super::iter_ptr::PostOrderIterPtr;
use super::states::State;
use super::{iter_ptr::Item, post_enumeration::PostOrderEnumeration};
use crate::TreeVariant;
use crate::aliases::Col;
use crate::memory::MemoryPolicy;
use crate::pinned_storage::PinnedStorage;
use crate::traversal::node_item_mut::NodeItemMut;
use alloc::vec::Vec;
use core::marker::PhantomData;
use orx_self_or::SoM;
pub struct PostOrderIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: PostOrderEnumeration,
S: SoM<Vec<State<V>>>,
D: NodeItemMut<'a, V, M, P>,
{
col: &'a Col<V, M, P>,
iter: PostOrderIterPtr<V, E, S>,
phantom: PhantomData<D>,
}
impl<'a, V, M, P, E, S, D> PostOrderIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: PostOrderEnumeration,
S: SoM<Vec<State<V>>>,
D: NodeItemMut<'a, V, M, P>,
{
pub(crate) unsafe fn from((col, iter): (&'a Col<V, M, P>, PostOrderIterPtr<V, E, S>)) -> Self {
Self {
col,
iter,
phantom: PhantomData,
}
}
}
impl<'a, V, M, P, E, S, D> Iterator for PostOrderIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: PostOrderEnumeration,
S: SoM<Vec<State<V>>>,
D: NodeItemMut<'a, V, M, P>,
{
type Item = E::Item<D>;
fn next(&mut self) -> Option<Self::Item> {
self.iter
.next()
.map(move |element: Item<V, E>| E::from_element_ptr_mut(self.col, element))
}
}