You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
45 lines
1.2 KiB
45 lines
1.2 KiB
//! stopwatch is a simple CLI stopwatch
|
|
|
|
use crossbeam_channel::tick;
|
|
use std::io::{stdout, Write};
|
|
use std::time::Instant;
|
|
use stopwatch::duration::FmtDuration;
|
|
use stopwatch::*;
|
|
|
|
#[macro_use]
|
|
extern crate crossbeam_channel;
|
|
|
|
fn main() {
|
|
// 30 fps should be enough
|
|
let step_duration = std::time::Duration::from_millis(1000 / 30);
|
|
let start = Instant::now();
|
|
let ticker = tick(step_duration);
|
|
|
|
let signals = match signal_handler() {
|
|
Ok(r) => r,
|
|
Err(err) => {
|
|
println!("{}", err);
|
|
return;
|
|
}
|
|
};
|
|
|
|
let out = stdout();
|
|
let mut out = out.lock();
|
|
let mut elapsed = FmtDuration::from(start.elapsed());
|
|
|
|
loop {
|
|
select! {
|
|
recv(ticker) -> now => {
|
|
elapsed = FmtDuration::from(now.unwrap().duration_since(start));
|
|
reset_line(&mut out).unwrap();
|
|
write!(out, "{}",elapsed).unwrap();
|
|
out.flush().unwrap();
|
|
}
|
|
recv(signals) -> _ => {
|
|
reset_line(&mut out).unwrap();
|
|
writeln!(out, "Total time: {}", elapsed).unwrap();
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|