arrayset 3.1.1

An array-backed ordered set type.
Documentation
use core::{iter::FusedIterator, slice};

#[derive(Clone, Debug)]
pub struct Values<'a, V>(slice::Iter<'a, V>);

impl<'a, V> Values<'a, V>
where
    V: 'a,
{
    pub(super) fn new(values: &'a [V]) -> Self {
        Self(values.iter())
    }
}

impl<'a, V> Iterator for Values<'a, V>
where
    V: 'a,
{
    type Item = &'a V;

    fn next(&mut self) -> Option<Self::Item> {
        self.0.next()
    }

    fn size_hint(&self) -> (usize, Option<usize>) {
        self.0.size_hint()
    }
}

impl<'a, V> DoubleEndedIterator for Values<'a, V>
where
    V: 'a,
{
    fn next_back(&mut self) -> Option<Self::Item> {
        self.0.next_back()
    }
}

impl<'a, V> ExactSizeIterator for Values<'a, V> {}
impl<'a, V> FusedIterator for Values<'a, V> {}