1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// Copyright 2017-2021 Lukas Pustina <lukas@pustina.de> // // Licensed under the Apache License, Version 2.0, <LICENSE-APACHE or // http://apache.org/licenses/LICENSE-2.0> or the MIT license <LICENSE-MIT or // http://opensource.org/licenses/MIT>, at your option. This file may not be // copied, modified, or distributed except according to those terms. use std::future::Future; use std::time::{Duration, Instant}; pub async fn time<T, F, E>(f: F) -> Result<(T, Duration), E> where F: Future<Output = Result<T, E>>, { let start_time = Instant::now(); let res = f.await?; let run_time = Instant::now() - start_time; Ok((res, run_time)) }