3 releases

0.1.2 Oct 13, 2019
0.1.1 Sep 30, 2019
0.1.0 Sep 30, 2019

#401 in Command-line interface

Download history 1684/week @ 2024-03-17 1823/week @ 2024-03-24 1706/week @ 2024-03-31 1591/week @ 2024-04-07 2166/week @ 2024-04-14 2627/week @ 2024-04-21 1941/week @ 2024-04-28 1806/week @ 2024-05-05 1865/week @ 2024-05-12 2222/week @ 2024-05-19 2536/week @ 2024-05-26 1345/week @ 2024-06-02 2128/week @ 2024-06-09 2514/week @ 2024-06-16 2339/week @ 2024-06-23 1100/week @ 2024-06-30

8,150 downloads per month
Used in 2 crates

MIT license

8KB
82 lines

Build status on GitLab CI Newest release on crates.io Documentation Number of downloads on crates.io Project license

took: easily measure & report elapsed time

I always find measuring and reporting run time of code it in a human readable format troublesome.

This crate provides a few simple interfaces to do just that.

Examples

  • Measure & report manually using Timer stopwatch:

    use took::Timer;
    
    let timer = Timer::new();
    // Run heavy task
    println!("Done! Took {}", timer.took());
    
    // Prints:
    // Done! Took 1.00 s
    
  • Measure a function, report manually:

    use took::took;
    
    let (took, result) = took(|| {
        // Run heavy task
    });
    println!("Done, took {}", took);
    
    // Prints:
    // Done! Took 1.00 s
    
  • Measure & report a function automatically using attribute:

    #[macro_use]
    extern crate took_macro;
    
    my_function();
    other_function();
    
    #[took]
    pub fn my_function() {
        // Run heavy task
    }
    
    #[took(description = "Render finished,")]
    pub fn other_function() {
        // Run heavy task
    }
    
    // Prints:
    // my_function() took 1.00 s
    // Render finished, took 1.00 s
    

Requirements

  • Rust 1.33 or newer (with std)

Usage

Add the dependencies in your Cargo.toml. The took-macro dependency is only required if you'll be using the #[took] attribute macro.

[dependencies]
took = "0.1"
took-macro = "0.1" # if using macros

Import and start using:

use took::{Timer, took};

let timer = Timer::new();
println!("Done! Took {}", timer.took());

let (took, result) = took(|| {
    // Run heavy task
});
println!("Done, took {}", took);

If you'll be using #[took] attribute macro, explicitly import it:

#[macro_use]
extern crate took_macro;

#[took]
pub fn function_one() {}

#[took(description = "Some heavy logic finished,")]
pub fn function_two() {}

TODO

  • Support #[took] attribute for almost anything (function call, blocks, if-statements, ...)
  • Time formatting configurability
  • Use more precise timers
  • Print elapsed time to more than just stderr

License

This project is released under the MIT license. Check out the LICENSE file for more information.

No runtime deps