randge 1.1.0

Generate unique random numbers
Documentation
use crate::*;

#[derive(Debug, Clone)]
pub struct RangesLinear<T> {
    size: Range<T>,
    rs: Vec<Range<T>>,
}

impl<T> RangesLinear<T>
where
    T: PrimInt,
{
    #[inline]
    pub fn new(min: T, max: T) -> Self {
        Self {
            size: min..max,
            rs: vec![min..max],
        }
    }
}

impl<T> RandgeTake<T> for RangesLinear<T>
where
    T: PrimInt,
{
    fn range(&self) -> Range<T> {
        self.size.clone()
    }

    #[inline]
    fn take(&mut self, mut num: T) -> T {
        self.size.end = self.size.end - one();
        num = num + self.rs[0].start - self.size.start;
        for i in 0..self.rs.len() {
            let v = unsafe { self.rs.get_unchecked_mut(i) };
            let start = v.start;
            debug_assert!(num >= start);
            let end = v.end;
            if num >= end {
                num = num + self.rs[i + 1].start - end;
                continue;
            }
            let nstart = num + one();
            let nend = num;
            if nstart == end {
                if nend == start {
                    self.rs.remove(i);
                } else {
                    v.end = nend;
                }
            } else {
                v.start = nstart;
                if nend != start {
                    self.rs.insert(i, start..nend);
                }
            }
            return num;
        }
        panic!("never")
    }
}

#[test]
fn test() {
    println!("");
    let mut t = RangesLinear::new(5, 35);
    let v = t.take(33);
    println!("{}\n{:?}\n", v, t);
    let v = t.take(31);
    println!("{}\n{:?}\n", v, t);
    let v = t.take(29);
    println!("{}\n{:?}\n", v, t);
    let v = t.take(27);
    println!("{}\n{:?}\n", v, t);
    let v = t.take(25);
    println!("{}\n{:?}\n", v, t);
}