3 releases

0.1.2 Mar 1, 2023
0.1.1 Jan 10, 2023
0.1.0 Jan 10, 2023

#493 in GUI

Download history 521/week @ 2024-03-13 385/week @ 2024-03-20 223/week @ 2024-03-27 247/week @ 2024-04-03 807/week @ 2024-04-10 1015/week @ 2024-04-17 816/week @ 2024-04-24 1087/week @ 2024-05-01 576/week @ 2024-05-08 1281/week @ 2024-05-15 385/week @ 2024-05-22 303/week @ 2024-05-29 716/week @ 2024-06-05 933/week @ 2024-06-12 696/week @ 2024-06-19 473/week @ 2024-06-26

2,967 downloads per month
Used in 4 crates

MIT license

44KB
966 lines

how-u-doin

Progress reporting abstraction for Rust

howudoin intends to make producing and consuming progress reports simple and ergonomic. Importantly, it separates the progress producers from the consumer, allowing progress reports to be generated from disparate sections in a system.

// initialise a consumer loop
howudoin::init(howudoin::consumers::Noop::default());

let rpt = howudoin::new().label("Progress").set_len(10);

for _ in 0..10 {
    rpt.inc(); // increment the progress
    // check for cancellation
    if rpt.cancelled() {
        break;
    }
}

rpt.finish(); // finalise progress

// fetch the tree of progress
let progress = howudoin::fetch();

Features:

  • Lightweight
  • Unobtrusive interface
  • Nestable reports
  • Automatic timers
  • Message accumulation
  • Cancellation

Take a look at the examples for example consumers.

Example terminal consumer

term-line

Support

Please help support this project by sponsoring 💗

Dependencies

~0.6–8.5MB
~64K SLoC