diff options
author | Jake McGinty <me@jake.su> | 2018-05-03 14:29:59 -0700 |
---|---|---|
committer | Jake McGinty <me@jake.su> | 2018-05-03 14:29:59 -0700 |
commit | 6aa9d9e08f41306f878b7e584dad211a7d4b901a (patch) | |
tree | 29923feaa01f26a2663deb29f5e33e55428b869a /src/time.rs | |
parent | config: refactor to send more specific messages to peer_server on change (diff) | |
download | wireguard-rs-6aa9d9e08f41306f878b7e584dad211a7d4b901a.tar.xz wireguard-rs-6aa9d9e08f41306f878b7e584dad211a7d4b901a.zip |
global: time.rs -> timestamp.rs
Diffstat (limited to 'src/time.rs')
-rw-r--r-- | src/time.rs | 81 |
1 files changed, 0 insertions, 81 deletions
diff --git a/src/time.rs b/src/time.rs deleted file mode 100644 index 0f1322c..0000000 --- a/src/time.rs +++ /dev/null @@ -1,81 +0,0 @@ -use byteorder::{ByteOrder, BigEndian}; -use std::ops::Deref; -use std::time::{Duration, Instant, SystemTime, UNIX_EPOCH}; - -const TAI64N_BASE: i64 = 4611686018427387914; - -#[derive(PartialEq, PartialOrd)] -pub struct Tai64n { - tai64n: [u8; 12] -} - -impl Tai64n { - pub fn now() -> Tai64n { - let mut tai64n = [0u8; 12]; - let now = SystemTime::now().duration_since(UNIX_EPOCH).unwrap(); - BigEndian::write_i64(&mut tai64n[0..], TAI64N_BASE + now.as_secs() as i64); - BigEndian::write_i32(&mut tai64n[8..], now.subsec_nanos() as i32); - - Tai64n { tai64n } - } -} - -impl Deref for Tai64n { - type Target = [u8; 12]; - - fn deref(&self) -> &[u8; 12] { - &self.tai64n - } -} - -impl From<[u8; 12]> for Tai64n { - fn from(tai64n: [u8; 12]) -> Self { - Tai64n { tai64n } - } -} - -// TODO I don't like this. -lazy_static! { - pub static ref FOREVER: Duration = Duration::from_secs(0xffffffff); - pub static ref FOREVER_AGO: Instant = Instant::now() - Duration::from_secs(0xffffffff); -} - -pub struct Timestamp(Option<Instant>); - -impl Default for Timestamp { - fn default() -> Self { - Timestamp(None) - } -} - -impl Deref for Timestamp { - type Target = Instant; - - fn deref(&self) -> &Self::Target { - match self.0 { - Some(ref time) => time, - None => &*FOREVER_AGO, - } - } -} - -impl Timestamp { - pub fn now() -> Self { - Timestamp(Some(Instant::now())) - } - - pub fn unset() -> Self { - Timestamp(None) - } - - pub fn is_set(&self) -> bool { - self.0.is_some() - } - - pub fn elapsed(&self) -> Duration { - match self.0 { - Some(ref time) => Instant::now().duration_since(*time), - None => *FOREVER, - } - } -} |