#[cfg(test)]
mod tests;
use {
crate::{
linear_storage::LinearStorage,
pos_vec::pos::{InUse, Pos},
},
core::{
fmt::{Debug, Formatter},
iter::FusedIterator,
},
hashbrown::hash_map,
};
pub struct IntoIter<K, V> {
pub(crate) iter: hash_map::IntoIter<K, Pos<InUse>>,
pub(crate) storage: LinearStorage<V>,
}
impl<K, V> Iterator for IntoIter<K, V> {
type Item = (K, V);
fn next(&mut self) -> Option<Self::Item> {
let (k, pos) = self.iter.next()?;
let v = unsafe {
self.storage.take_unchecked(pos)
};
Some((k, v))
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.iter.size_hint()
}
}
impl<K, V> Debug for IntoIter<K, V> {
fn fmt(&self, f: &mut Formatter<'_>) -> core::fmt::Result {
f.debug_struct("IntoIter").finish_non_exhaustive()
}
}
impl<K, V> FusedIterator for IntoIter<K, V> {}
impl<K, V> ExactSizeIterator for IntoIter<K, V> {
fn len(&self) -> usize {
self.iter.len()
}
}
impl<K, V> Default for IntoIter<K, V> {
fn default() -> Self {
Self {
iter: Default::default(),
storage: LinearStorage::with_capacity(0),
}
}
}
unsafe impl<K, V> Send for IntoIter<K, V>
where
K: Send,
V: Send,
{
}
unsafe impl<K, V> Sync for IntoIter<K, V>
where
K: Sync,
V: Sync,
{
}