indexical 0.6.0

Utilities for indexed collections
Documentation
use crate::{bitset::BitSet, define_index_type};

define_index_type! {
  pub struct StrIdx for String = u32;
}

pub type TestIndexSet<T> = crate::bitset::bitvec::IndexSet<T>;
pub type TestIndexMatrix<R, C> = crate::bitset::bitvec::IndexMatrix<R, C>;

pub fn impl_test<T: BitSet>() {
    let mut bv = T::empty(10);
    assert!(!bv.contains(0));

    bv.insert(0);
    bv.insert(5);
    assert!(bv.contains(0));
    assert!(bv.contains(5));
    assert!(!bv.contains(1));
    assert_eq!(bv.iter().collect::<Vec<_>>(), vec![0, 5]);
    assert_eq!(bv.len(), 2);

    let mut bv2 = T::empty(10);
    bv2.insert(5);
    assert!(bv.superset(&bv2));
    bv2.insert(1);
    assert!(!bv.superset(&bv2));

    assert!(bv.intersect_changed(&bv2));
    assert!(!bv.intersect_changed(&bv2));
    assert_eq!(bv.iter().collect::<Vec<_>>(), vec![5]);

    let mut bv = T::empty(64 * 4 + 1);
    bv.insert(64 * 4);
    assert!(!bv.contains(64 * 4 - 1));
    assert!(bv.contains(64 * 4));

    let mut bv = T::empty(10);
    bv.insert(0);
    bv.insert(1);
    let mut bv2 = T::empty(10);
    bv2.insert(0);
    bv.subtract(&bv2);
    assert_eq!(bv.iter().collect::<Vec<_>>(), vec![1]);

    bv.invert();
    assert_eq!(
        bv.iter().collect::<Vec<_>>(),
        vec![0, 2, 3, 4, 5, 6, 7, 8, 9]
    );

    bv.clear();
    assert_eq!(bv.iter().collect::<Vec<_>>(), Vec::<usize>::new());
}