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
use super::*;

pub trait MeasureTime0<T> {
    fn run_and_measure_time(&mut self) -> (T, Duration);
    fn run_and_print_time(&mut self) -> T;
}

impl<T, Func: FnMut() -> T> MeasureTime0<T> for Func {
    fn run_and_measure_time(&mut self) -> (T, Duration) {
        let clock = Instant::now();
        (self(), clock.elapsed())
    }

    fn run_and_print_time(&mut self) -> T {
        let (res, time_taken) = self.run_and_measure_time();
        if GLOBAL_TIMECAT_STATE.is_in_console_mode() {
            println_wasm!();
        }
        println_info("Run Time", time_taken.stringify());
        res
    }
}

pub trait MeasureTime1<T, U> {
    fn run_and_measure_time(&mut self, item: &mut U) -> (T, Duration);
    fn run_and_print_time(&mut self, item: &mut U) -> T;
}

impl<T, Func: FnMut(&mut U) -> T, U> MeasureTime1<T, U> for Func {
    fn run_and_measure_time(&mut self, item: &mut U) -> (T, Duration) {
        let clock = Instant::now();
        (self(item), clock.elapsed())
    }

    fn run_and_print_time(&mut self, item: &mut U) -> T {
        let (res, time_taken) = self.run_and_measure_time(item);
        if GLOBAL_TIMECAT_STATE.is_in_console_mode() {
            println_wasm!();
        }
        println_info("Run Time", time_taken.stringify());
        res
    }
}