#timer #elapsed-time #logging #duration #task #tea #human-readable

tea-timer

A simple and efficient Rust library for measuring and reporting the duration of tasks

3 releases

0.1.2 Sep 9, 2024
0.1.1 Sep 9, 2024
0.1.0 Sep 5, 2024

#2 in #tea

MIT license

13KB
172 lines

Tea Timer

Tea Timer is a simple and efficient Rust library for measuring and reporting the duration of tasks. It provides an easy-to-use API for creating timers, measuring elapsed time, and formatting durations.

Features

  • Create named timers
  • Measure elapsed time
  • Format durations in a human-readable format
  • Restart timers with new task names
  • Optional logging support using the log crate

Installation

Add this to your Cargo.toml:

tea-timer = "0.1.0"

Usage

Macro Usage

let result = tea_timer::took! {
    // ...any code
};
// this will print elapsed time and get result of thecode block

Function Usage

use tea_timer::took;

let result = took(|| {
    // ...any code
}, "task");
// this will print elapsed time and get result of the function

Basic Usage

use tea_timer::Timer;
use std::thread::sleep;
use std::time::Duration;

let mut timer = Timer::new("task");
// Simulate some work with a sleep
sleep(Duration::from_secs(2));
// this will print elapsed time
timer.elapsed();
// Restart the timer with a new task name
timer.restart("new_task");
// Simulate more work
sleep(Duration::from_millis(500));
// Measure elapsed time again
// consume timer and print elapsed time
timer.stop();

Logging Usage

use tea_timer::Timer;
use std::thread::sleep;
use std::time::Duration;

let mut timer = Timer::new("task");
timer.log();  // This will log the elapsed time using the log crate

Dependencies

~86KB