iter-progress

Build Status Crates.io Documentation

Wrap an iterator, and get progress data as it's executed. A more advanced .enumerate()

Documentation

Wrap an iterator, and get progress data as it's executed. A more advanced .enumerate()

Usage

Call .progress() on any Iterator, and get a new iterator that yields (ProgressRecord, T), where T is the original value. A ProgressRecord has many helpful methods to query the current state of the iterator

At every iteration, the current time is calculated. For iterators generating lots of items per second, this might be a noticable performance hit. Use .optional_progress(N) to generate a new iterator that yields (Option<ProgressRecord>, T). Every N items, the result will be (Some(ProgressRecord), T), otherwise (None, T) is returned and no call to get the current time is made.

Example

```rust use iterprogress::ProgressableIter; // Create an iterator that goes from 0 to 1,000 let myiter = 0..1000; let mut progressor = myiter.progress();

// This new iterator returns a struct with the current state, and the inner object returned by // the iterator let (state, number) = progressor.next().unwrap(); assert_eq!(number, 0);

// We can now use methods on state to find out about this object

// If we know the size of the iterator, we can query how far we are through it // How far through the iterator are we. 0 to 1 assert_eq!(state.fraction(), Some(0.001));

// We are 0.1% the way through assert_eq!(state.percent(), Some(0.1)); ```

Another usage:

```rust use iterprogress::ProgressableIter; let mybig_vec = vec![false; 100];

for (state, val) in mybigvec.iter().progress() { // Every 1 second, execute this function with the the state state.doeveryn_sec(1., |state| { println!("{}% the way though, and doing {} per sec.", state.percent().unwrap(), state.rate()); });

// Do something to process `val`

} ```

.do_every_n_sec is a "best effort" attempt. It's single threaded, so will be called if the last time that was called was more than N sec ago. .do_every_n_items is called every N items.