#stopwatch #timing #split #clear #original #rewrite #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

#369 in Date and time

Download history 166/week @ 2024-03-13 256/week @ 2024-03-20 205/week @ 2024-03-27 251/week @ 2024-04-03 259/week @ 2024-04-10 164/week @ 2024-04-17 185/week @ 2024-04-24 156/week @ 2024-05-01 142/week @ 2024-05-08 134/week @ 2024-05-15 136/week @ 2024-05-22 173/week @ 2024-05-29 117/week @ 2024-06-05 178/week @ 2024-06-12 169/week @ 2024-06-19 245/week @ 2024-06-26

724 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