34 template<
typename ResolutionType,
typename ClockType = std::chrono::steady_clock>
39 using point =
typename clock::time_point;
82 return clock::now() -
start_;
95 template<
typename... OpTimerArgs>
98 o << std::chrono::duration_cast<
typename optimer<OpTimerArgs...>::resolution>(tm.
elapsed()).count();
std::ostream & operator<<(std::ostream &s, const irdya_date &d)
Reports time elapsed at the end of an object scope.
~optimer()
Destructor, which invokes the report callback.
optimer(report_callback f=report_callback{})
Constructor, which starts the timer.
std::function< void(const optimer &)> report_callback
point start() const
Returns the start time point.
typename clock::duration interval
ResolutionType resolution
interval elapsed() const
Returns the elapsed time value.
void reset()
Resets the timer back to zero.