minor: simplify

This commit is contained in:
Aleksey Kladov 2021-04-26 19:30:50 +03:00
parent 363cef5c0e
commit f06e4b8e74

View file

@ -14,18 +14,8 @@ pub fn is_ci() -> bool {
#[must_use] #[must_use]
pub fn timeit(label: &'static str) -> impl Drop { pub fn timeit(label: &'static str) -> impl Drop {
struct Guard { let start = Instant::now();
label: &'static str, defer(move || eprintln!("{}: {:.2?}", label, start.elapsed()))
start: Instant,
}
impl Drop for Guard {
fn drop(&mut self) {
eprintln!("{}: {:.2?}", self.label, self.start.elapsed())
}
}
Guard { label, start: Instant::now() }
} }
/// Prints backtrace to stderr, useful for debugging. /// Prints backtrace to stderr, useful for debugging.
@ -179,6 +169,7 @@ where
start..start + len start..start + len
} }
#[must_use]
pub fn defer<F: FnOnce()>(f: F) -> impl Drop { pub fn defer<F: FnOnce()>(f: F) -> impl Drop {
struct D<F: FnOnce()>(Option<F>); struct D<F: FnOnce()>(Option<F>);
impl<F: FnOnce()> Drop for D<F> { impl<F: FnOnce()> Drop for D<F> {