#iterator #recursion #structures #suitable #dag #node #navigating

transiter

An Iterator suitable for navigating recursive structures and DAGs

2 unstable releases

0.2.0 Oct 31, 2021
0.1.0 Jun 20, 2021

#1580 in Data structures

MIT license

20KB
225 lines

TransIter -- transitive iterator and utilities

This small rust crate provides TransIter, an iterator suitable for navigating recursive structures and DAGs. The iterator allows for multiple modes of iteration. For structures in which the nodes implement Ord, this crate also provides a TransPrioQueue.

In addition to the iterators themselves, this crate provides some convenience traits for creating instances of those iterators.

Example

use transiter::IntoTransIter;

let names: Vec<_> = String::new()
    .trans_iter_with(|s| { let s = s.clone(); ["a", "b", "c"].iter().map(move |c| s.clone() + c)})
    .take(10)
    .collect();
assert_eq!(names, vec!["", "a", "b", "c", "aa", "ab", "ac", "ba", "bb", "bc"]);

Similar crates

The following crates serve a similar purpose:

  • reciter provides a macro for creating an iterator from a recursive function.

License

This work is provided under the MIT license. See LICENSE for more details.

No runtime deps