#recursion #iterator #proc-macro

macro reciter

Macro that allows converting a recursive function into an Iterator, which uses a cache

3 releases

0.1.2 Nov 10, 2018
0.1.1 Nov 10, 2018
0.1.0 Nov 10, 2018

#217 in #recursion

MIT license

14KB
262 lines

The #[reciter] attribute macro allows converting a recursive function into an Iterator, which uses a cache.

Example

#[reciter(cache = "auto", start = 1)]
fn factorial(n: usize) -> BigInt {
    if n == 1 {
        BigInt::from(1)
    } else {
        n * factorial(n - 1)
    }
}

fn main() {
    let fi = FactorialIterator::new();
    for (i, fac) in fi.enumerate().take(512) {
        println!("{}! = {}", i + 1, fac);
    }
}    

For more information look into the documentation or at the tests in the repository.

Dependencies

~2MB
~50K SLoC