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 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
//! This module fits the requirement of `rtic-monotonic`, but has uses beyond that.
use core::{
self,
cmp::{Ord, Ordering, PartialOrd},
ops::{Add, Sub},
time::Duration,
};
/// A time instant, from the start of a timer, for use with `rtic-monotonic`. Currently only
/// has microsecond precision.
#[derive(Eq, PartialEq, PartialOrd, Copy, Clone, Default)]
pub struct Instant {
/// Total count, in microseconds.
/// todo: Do you need ns resolution?
// pub count_us: i64, // todo: u64 or i64? x128?
pub count_ns: i64, // todo: u64 or i64? x128?
}
impl Instant {
/// The time, in seconds.
pub fn as_secs(&self) -> f32 {
// self.count_us as f32 / 1_000_000.
self.count_ns as f32 / 1_000_000_000.
}
/// The time, in milliseconds.
pub fn as_ms(&self) -> f32 {
// self.count_us as f32 / 1_000.
self.count_ns as f32 / 1_000_000.
}
/// The time, in microseconds
pub fn as_us(&self) -> f32 {
// self.count_us as f32
self.count_ns as f32 / 1_000.
}
/// The time, in nanoseconds
pub fn as_ns(&self) -> f32 {
self.count_ns as f32
}
}
impl Ord for Instant {
fn cmp(&self, other: &Self) -> Ordering {
// self.count_us.cmp(&other.count_us)
self.count_ns.cmp(&other.count_ns)
}
}
impl Add<Duration> for Instant {
type Output = Self;
fn add(self, rhs: Duration) -> Self::Output {
Self {
// count_us: self.count_us + rhs.as_micros() as i64,
count_ns: self.count_ns + rhs.as_nanos() as i64,
}
}
}
impl Sub<Duration> for Instant {
type Output = Self;
fn sub(self, rhs: Duration) -> Self::Output {
Self {
// count_us: self.count_us - rhs.as_micros() as i64,
count_ns: self.count_ns - rhs.as_nanos() as i64,
}
}
}
impl Sub<Self> for Instant {
type Output = Duration;
fn sub(self, rhs: Self) -> Self::Output {
// todo: Handle negative overflow!
// Duration::from_micros((self.count_us - rhs.count_us) as u64)
Duration::from_nanos((self.count_ns - rhs.count_ns) as u64)
}
}