1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
//! A crate to make time measurements that focuses on speed.
//!
//! This crate is a partial replacement for the `Time` and `Duration` structures from the
//! standard library, with the following differences:
//!
//! * Speed is privileged over accuracy. In particular, `CLOCK_MONOTONIC_COARSE` is used to
//! retrieve the clock value on Linux systems, and transformations avoid operations that can be
//! slow on non-Intel systems.
//! * The number of system calls can be kept to a minimum. The "most recent timestamp" is
//! always kept in memory. It can be read with just a load operation, and can be updated only as
//! frequently as necessary.
//!
//! # Installation
//!
//! `coarsetime` is available on [crates.io](https://crates.io/crates/coarsetime) and works on
//! Rust stable, beta, and nightly.
//!
//! Windows and Unix-like systems are supported.
//!
//! Available features:
//!
//! * `nightly`: rust-nightly is being used; only required to run benchmarks.

#![allow(clippy::trivially_copy_pass_by_ref)]
#![cfg_attr(feature = "nightly", feature(test))]

mod clock;
mod duration;
mod helpers;
mod instant;
#[cfg(not(any(target_arch = "wasm32", target_arch = "wasm64")))]
mod updater;

#[cfg(test)]
mod tests;

pub use self::clock::*;
pub use self::duration::*;
pub use self::instant::*;
#[cfg(not(any(target_arch = "wasm32", target_arch = "wasm64")))]
pub use self::updater::*;