diff options
author | Johannes Stoelp <johannes.stoelp@gmail.com> | 2023-07-03 22:17:34 +0200 |
---|---|---|
committer | Johannes Stoelp <johannes.stoelp@gmail.com> | 2023-07-03 22:17:34 +0200 |
commit | 005cd3b630fcf0f3870f426a0db5e54400a59ef9 (patch) | |
tree | 76bc9add7aa46a7ac61c072e5f1fe1b0d1551a01 /timer.h | |
parent | 6b062584e56fe395be723220324ea384bf447971 (diff) | |
download | cpp-utils-005cd3b630fcf0f3870f426a0db5e54400a59ef9.tar.gz cpp-utils-005cd3b630fcf0f3870f426a0db5e54400a59ef9.zip |
timer: add simple linux watchclock timer
Diffstat (limited to 'timer.h')
-rw-r--r-- | timer.h | 52 |
1 files changed, 52 insertions, 0 deletions
@@ -0,0 +1,52 @@ +#include <cstdint> +#include <ctime> + +namespace timer { +struct timer { + constexpr timer() = default; + + void start() { + clock_gettime(kClock, &m_start); + } + + void stop() { + timespec end; + clock_gettime(kClock, &end); + + m_nanos += ((end.tv_sec - m_start.tv_sec) * 1000000000ull) + + (end.tv_nsec - m_start.tv_nsec); + } + + constexpr double as_sec() const { + return as_msec() / 1000.0; + } + + constexpr double as_msec() const { + return as_usec() / 1000.0; + } + + constexpr double as_usec() const { + return static_cast<double>(m_nanos) / 1000.0; + } + + private: + static constexpr clockid_t kClock = CLOCK_MONOTONIC_RAW; + + timespec m_start{}; + std::uint64_t m_nanos{0}; +}; + +struct scoped_timer { + explicit scoped_timer(timer& t) : m_timer(t) { + m_timer.start(); + } + + ~scoped_timer() { + m_timer.stop(); + } + + private: + timer& m_timer; +}; + +} // namespace timer |