use super::bfs_enumeration::BreadthFirstEnumeration;
use super::iter_ptr::BfsIterPtr;
use super::queue::Item;
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::collections::VecDeque;
use core::marker::PhantomData;
use orx_self_or::SoM;
pub struct BfsIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: BreadthFirstEnumeration,
S: SoM<VecDeque<Item<V, E>>>,
D: NodeItemMut<'a, V, M, P>,
{
col: &'a Col<V, M, P>,
iter: BfsIterPtr<V, E, S>,
phantom: PhantomData<D>,
}
impl<'a, V, M, P, E, S, D> BfsIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: BreadthFirstEnumeration,
S: SoM<VecDeque<Item<V, E>>>,
D: NodeItemMut<'a, V, M, P>,
{
pub(crate) unsafe fn from((col, iter): (&'a Col<V, M, P>, BfsIterPtr<V, E, S>)) -> Self {
Self {
col,
iter,
phantom: PhantomData,
}
}
}
impl<'a, V, M, P, E, S, D> Iterator for BfsIterMut<'a, V, M, P, E, S, D>
where
V: TreeVariant,
M: MemoryPolicy,
P: PinnedStorage,
E: BreadthFirstEnumeration,
S: SoM<VecDeque<Item<V, E>>>,
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))
}
}