use EnumMap;
use Internal;
use core::iter::Enumerate;
use core::marker::PhantomData;
use core::slice;
pub struct Iter<'a, K, V: 'a> {
_phantom: PhantomData<K>,
iterator: Enumerate<slice::Iter<'a, V>>,
}
impl<'a, K: Internal<V>, V> Iterator for Iter<'a, K, V> {
type Item = (K, &'a V);
fn next(&mut self) -> Option<Self::Item> {
self.iterator
.next()
.map(|(index, item)| (K::from_usize(index), item))
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.iterator.size_hint()
}
}
impl<'a, K: Internal<V>, V> DoubleEndedIterator for Iter<'a, K, V> {
fn next_back(&mut self) -> Option<Self::Item> {
self.iterator
.next_back()
.map(|(index, item)| (K::from_usize(index), item))
}
}
impl<'a, K: Internal<V>, V> ExactSizeIterator for Iter<'a, K, V> {}
impl<'a, K: Internal<V>, V> IntoIterator for &'a EnumMap<K, V> {
type Item = (K, &'a V);
type IntoIter = Iter<'a, K, V>;
fn into_iter(self) -> Self::IntoIter {
Iter {
_phantom: PhantomData,
iterator: K::slice(&self.array).iter().enumerate(),
}
}
}
pub struct IterMut<'a, K, V: 'a> {
_phantom: PhantomData<K>,
iterator: Enumerate<slice::IterMut<'a, V>>,
}
impl<'a, K: Internal<V>, V> Iterator for IterMut<'a, K, V> {
type Item = (K, &'a mut V);
fn next(&mut self) -> Option<Self::Item> {
self.iterator
.next()
.map(|(index, item)| (K::from_usize(index), item))
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.iterator.size_hint()
}
}
impl<'a, K: Internal<V>, V> DoubleEndedIterator for IterMut<'a, K, V> {
fn next_back(&mut self) -> Option<Self::Item> {
self.iterator
.next_back()
.map(|(index, item)| (K::from_usize(index), item))
}
}
impl<'a, K: Internal<V>, V> ExactSizeIterator for IterMut<'a, K, V> {}
impl<'a, K: Internal<V>, V> IntoIterator for &'a mut EnumMap<K, V> {
type Item = (K, &'a mut V);
type IntoIter = IterMut<'a, K, V>;
fn into_iter(self) -> Self::IntoIter {
IterMut {
_phantom: PhantomData,
iterator: K::slice_mut(&mut self.array).iter_mut().enumerate(),
}
}
}