veloren/common/src/clock.rs
Tanner Donovan d9f179b980 update Duration method calls
Former-commit-id: 4343e30583f74094a73365465a1d1ca912b693e6
2019-03-18 16:46:37 -07:00

51 lines
1.3 KiB
Rust

// Standard
use std::{
thread,
time::{Duration, SystemTime},
};
const CLOCK_SMOOTHING: f64 = 0.9;
pub struct Clock {
last_sys_time: SystemTime,
last_delta: Option<Duration>,
running_tps_average: f64,
}
impl Clock {
pub fn new() -> Self {
Self {
last_sys_time: SystemTime::now(),
last_delta: None,
running_tps_average: 0.0,
}
}
pub fn get_tps(&self) -> f64 { self.running_tps_average }
pub fn get_last_delta(&self) -> Duration { self.last_delta.unwrap_or(Duration::new(0, 0)) }
pub fn get_avg_delta(&self) -> Duration { Duration::from_secs_f64(self.running_tps_average) }
pub fn tick(&mut self, tgt: Duration) {
let delta = SystemTime::now()
.duration_since(self.last_sys_time)
.expect("Time went backwards!");
// Attempt to sleep to fill the gap
if let Some(sleep_dur) = tgt.checked_sub(delta) {
thread::sleep(sleep_dur);
}
let delta = SystemTime::now()
.duration_since(self.last_sys_time)
.expect("Time went backwards!");
self.last_sys_time = SystemTime::now();
self.last_delta = Some(delta);
self.running_tps_average =
CLOCK_SMOOTHING * self.running_tps_average +
(1.0 - CLOCK_SMOOTHING) * delta.as_secs_f64();
}
}