X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftimer.h;h=6435155c6c88d774d87f0bb67385a9e9065d2c30;hb=7245e46453a82886739a45bd78fcdf9e8401367c;hp=8ec392aa63a212dc708356d819f58d1676393e2e;hpb=097a1fb413bbbb89182161d4c1a31daa5419ec96;p=dcpomatic.git diff --git a/src/lib/timer.h b/src/lib/timer.h index 8ec392aa6..6435155c6 100644 --- a/src/lib/timer.h +++ b/src/lib/timer.h @@ -1,45 +1,50 @@ /* - Copyright (C) 2012 Carl Hetherington - Copyright (C) 2000-2007 Paul Davis + Copyright (C) 2012-2021 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic 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; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic 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, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ + /** @file src/timer.h * @brief Some timing classes for debugging and profiling. */ + #ifndef DCPOMATIC_TIMER_H #define DCPOMATIC_TIMER_H + +#include +#include #include #include -#include -/** @class PeriodDCPTimer + +/** @class PeriodTimer * @brief A class to allow timing of a period within the caller. * * On destruction, it will output the time since its construction. */ -class PeriodDCPTimer +class PeriodTimer { public: - PeriodDCPTimer (std::string n); - ~PeriodDCPTimer (); - + explicit PeriodTimer (std::string n); + ~PeriodTimer (); + private: /** name to use when giving output */ @@ -48,31 +53,56 @@ private: struct timeval _start; }; -/** @class StateDCPTimer + +/** @class StateTimer * @brief A class to allow measurement of the amount of time a program * spends in one of a set of states. * * Once constructed, the caller can call set_state() whenever - * its state changes. When StateDCPTimer is destroyed, it will + * its state changes. When StateTimer is destroyed, it will * output (to cout) a summary of the time spent in each state. */ -class StateDCPTimer +class StateTimer { public: - StateDCPTimer (std::string n, std::string s); - ~StateDCPTimer (); + explicit StateTimer (std::string n); + /** @param n Name to use when giving output. + * @param s Initial state. + */ + StateTimer (std::string n, std::string s); + ~StateTimer (); + + /** @param s New state that the caller is in */ + void set (std::string s); + void unset (); + + std::string name () const { + return _name; + } - void set_state (std::string s); + class Counts + { + public: + double total_time = 0; + int number = 0; + }; + + std::map counts () const { + return _counts; + } private: + void set_internal (boost::optional s); + /** name to add to the output */ std::string _name; /** current state */ - std::string _state; + boost::optional _state; /** time that _state was entered */ double _time; - /** time that has been spent in each state so far */ - std::map _totals; + /** total time and number of entries for each state */ + std::map _counts; }; + #endif