lender 0.6.2

A lending-iterator trait based on higher-rank trait bounds, with full std::iter::Iterator functionality
Documentation
use crate::*;

/// The [`Lender`] version of [`core::iter::ExactSizeIterator`].
pub trait ExactSizeLender: Lender {
    /// Returns the exact remaining length of the lender.
    ///
    /// See [`ExactSizeIterator::len`].
    #[inline(always)]
    fn len(&self) -> usize {
        let (lower, upper) = self.size_hint();
        assert_eq!(upper, Some(lower));
        lower
    }

    /// Returns `true` if the lender has no more elements.
    #[inline(always)]
    fn is_empty(&self) -> bool {
        self.len() == 0
    }
}

impl<I: ExactSizeLender> ExactSizeLender for &mut I {
    #[inline(always)]
    fn len(&self) -> usize {
        (**self).len()
    }

    #[inline(always)]
    fn is_empty(&self) -> bool {
        (**self).is_empty()
    }
}

/// The [`FallibleLender`] version of [`core::iter::ExactSizeIterator`].
pub trait ExactSizeFallibleLender: FallibleLender {
    /// Returns the exact remaining length of the lender.
    ///
    /// See [`ExactSizeLender::len`].
    #[inline(always)]
    fn len(&self) -> usize {
        let (lower, upper) = self.size_hint();
        assert_eq!(upper, Some(lower));
        lower
    }

    /// Returns `true` if the lender has no more elements.
    #[inline(always)]
    fn is_empty(&self) -> bool {
        self.len() == 0
    }
}

impl<I: ExactSizeFallibleLender> ExactSizeFallibleLender for &mut I {
    #[inline(always)]
    fn len(&self) -> usize {
        (**self).len()
    }

    #[inline(always)]
    fn is_empty(&self) -> bool {
        (**self).is_empty()
    }
}