orx-iterable 1.3.0

Defines and implements Iterable, Collection and CollectionMut traits to represent types that can be iterated over multiple times.
Documentation
use orx_iterable::*;

fn test_it(values: Vec<usize>, col: impl Iterable<Item = usize>) {
    let sum = values.iter().sum::<usize>();
    let count = values.len();

    // tests
    assert_eq!(col.iter().count(), count);
    assert_eq!(col.iter().sum::<usize>(), sum);
}

#[test]
fn skipped() {
    let a = vec![1, 3, 7, 2, 8];
    test_it(vec![1, 3, 7, 2, 8], a.skipped(0).copied());

    let a = vec![1, 3, 7, 2, 8];
    test_it(vec![7, 2, 8], a.skipped(2).copied());

    let a = vec![1, 3, 7, 2, 8];
    test_it(vec![], a.skipped(5).copied());
}

#[test]
fn skipped_mut() {
    let mut a = vec![1, 3, 7, 2, 8];
    for x in a.skipped_mut(0).iter_mut() {
        *x += 10;
    }
    test_it(vec![11, 13, 17, 12, 18], a.copied());

    let mut a = vec![1, 3, 7, 2, 8];
    for x in a.skipped_mut(2).iter_mut() {
        *x += 10;
    }
    test_it(vec![1, 3, 17, 12, 18], a.copied());

    let mut a = vec![1, 3, 7, 2, 8];
    for x in a.skipped_mut(10).iter_mut() {
        *x += 10;
    }
    test_it(vec![1, 3, 7, 2, 8], a.copied());
}

#[test]
fn into_skipped() {
    let a = vec![1, 3, 7, 2, 8];
    let mut a = a.into_skipped(0);
    for x in a.iter_mut() {
        *x += 10;
    }
    test_it(vec![11, 13, 17, 12, 18], a.copied());

    let a = vec![1, 3, 7, 2, 8];
    let mut a = a.into_skipped(2);
    for x in a.iter_mut() {
        *x += 10;
    }
    test_it(vec![17, 12, 18], a.copied());

    let a = vec![1, 3, 7, 2, 8];
    let mut a = a.into_skipped(10);
    for x in a.iter_mut() {
        *x += 10;
    }
    test_it(vec![], a.copied());
}

#[cfg(feature = "std")]
mod object_safe {
    use orx_iterable::{obj_safe::*, *};

    fn obj_test_it(values: Vec<usize>, col: &dyn IterableObj<Item = usize>) {
        let sum = values.iter().sum::<usize>();
        let count = values.len();

        // tests
        assert_eq!(col.boxed_iter().count(), count);
        assert_eq!(col.boxed_iter().sum::<usize>(), sum);
    }

    #[test]
    fn obj_skipped() {
        let a = vec![1, 3, 7, 2, 8];
        obj_test_it(vec![1, 3, 7, 2, 8], &a.skipped(0).copied());

        let a = vec![1, 3, 7, 2, 8];
        obj_test_it(vec![7, 2, 8], &a.skipped(2).copied());

        let a = vec![1, 3, 7, 2, 8];
        obj_test_it(vec![], &a.skipped(5).copied());
    }

    #[test]
    fn obj_skipped_mut() {
        let mut a = vec![1, 3, 7, 2, 8];
        for x in a.skipped_mut(0).iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![11, 13, 17, 12, 18], &a.copied());

        let mut a = vec![1, 3, 7, 2, 8];
        for x in a.skipped_mut(2).iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![1, 3, 17, 12, 18], &a.copied());

        let mut a = vec![1, 3, 7, 2, 8];
        for x in a.skipped_mut(10).iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![1, 3, 7, 2, 8], &a.copied());
    }

    #[test]
    fn obj_into_skipped() {
        let a = vec![1, 3, 7, 2, 8];
        let mut a = a.into_skipped(0);
        for x in a.iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![11, 13, 17, 12, 18], &a.copied());

        let a = vec![1, 3, 7, 2, 8];
        let mut a = a.into_skipped(2);
        for x in a.iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![17, 12, 18], &a.copied());

        let a = vec![1, 3, 7, 2, 8];
        let mut a = a.into_skipped(10);
        for x in a.iter_mut() {
            *x += 10;
        }
        obj_test_it(vec![], &a.copied());
    }
}