From ae135bdf7bce6eb3d2d350d422e671cb043b3c36 Mon Sep 17 00:00:00 2001 From: Fuwn Date: Fri, 14 Apr 2023 18:48:02 -0700 Subject: fix(timing): push module (what ?) --- src/timing.rs | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 src/timing.rs (limited to 'src') diff --git a/src/timing.rs b/src/timing.rs new file mode 100644 index 0000000..40f7a13 --- /dev/null +++ b/src/timing.rs @@ -0,0 +1,42 @@ +// This file is part of Locus . +// Copyright (C) 2022-2022 Fuwn +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, version 3. +// +// This program is distributed in the hope that it will be useful, but +// WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . +// +// Copyright (C) 2022-2022 Fuwn +// SPDX-License-Identifier: GPL-3.0-only + +use tokio::time::Instant; + +pub fn time_mounts(context: &str, timer: &mut Instant, mut mounter: T) +where T: FnMut() { + mounter(); + + info!( + "{} mounts took {}ms", + context, + timer.elapsed().as_nanos() as f64 / 1_000_000.0 + ); + + *timer = Instant::now(); +} + +pub fn time_section(timer: &mut Instant, context: &str) { + info!( + "{} took {}ms", + context, + timer.elapsed().as_nanos() as f64 / 1_000_000.0 + ); + + *timer = Instant::now(); +} -- cgit v1.2.3