timer.rs
1 // Copyright (C) 2019-2021 Alpha-Delta Network Inc. 2 // This file is part of the alphastd library. 3 4 // The alphastd library is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 9 // The alphastd library is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU General Public License for more details. 13 14 // You should have received a copy of the GNU General Public License 15 // along with the alphastd library. If not, see <https://www.gnu.org/licenses/>. 16 17 use alphastd::prelude::*; 18 19 fn foo() -> u32 { 20 // Start the timer. 21 let timer = timer!("Arithmetic"); 22 23 // Insert expensive operation here 24 let x = 1 + 1; 25 26 // Print the elapsed time up to this point. 27 lap!(timer); 28 29 // Insert expensive operation here 30 let y = 1 + 1; 31 32 // Print the total time elapsed. 33 finish!(timer); 34 35 x + y 36 } 37 38 fn main() { 39 foo(); 40 }