#stopwatch #timing #split #clear #rewrite #original #time

stopwatch2

A stopwatch library for timing things. A rewrite and simplification of the original stopwatch crate.

1 stable release

2.0.0 Apr 30, 2021

#336 in Date and time

Download history 109/week @ 2023-12-12 90/week @ 2023-12-19 58/week @ 2023-12-26 191/week @ 2024-01-02 164/week @ 2024-01-09 265/week @ 2024-01-16 151/week @ 2024-01-23 143/week @ 2024-01-30 113/week @ 2024-02-06 143/week @ 2024-02-13 269/week @ 2024-02-20 214/week @ 2024-02-27 185/week @ 2024-03-05 174/week @ 2024-03-12 253/week @ 2024-03-19 148/week @ 2024-03-26

791 downloads per month
Used in 6 crates (5 directly)

MIT license

10KB
159 lines

Stopwatch2

Stopwatch V2

Support an Open Source Developer! ♥️
Become a patron

Read the documentation.

This crate is a simplified version of the work of ellisonch.

Features

  • Adds a simple stopwatch.
  • Can use multiple splits, even with pauses between them!
  • Simple to use with clear documentation.

Usage

Add the following to you Cargo.toml file:

stopwatch2 = "*"

Use the stopwatch like so:

use stopwatch2::*;

fn main() {
    let mut s = Stopwatch::default();
    s.start(); // Starts the stopwatch.
    s.start(); // Creates a new time span, which are commonly called "splits".
    s.stop(); // Stops the stopwatch.
    println!("{}", s); // Prints the total time.
    println!("{:?}", s); // Prints the different time spans as debug information.
    let total_time = s.elapsed(); // returns the total time as a Duration.
    for span in &s.spans {
        // Prints all contained time spans.
        println!("{:?} -> {:?}", span.start, span.stop);
    }
    s.spans.clear(); // Reset the stopwatch.
    println!("{}", s); // Prints the total time.
    println!("{:?}", s); // Prints the different time spans as debug information.
}

Maintainer Information

  • Maintainer: Jojolepro
  • Contact: jojolepro [at] jojolepro [dot] com
  • Website: jojolepro.com
  • Patreon: patreon

No runtime deps