libcruft-util/time.hpp

119 lines
3.0 KiB
C++
Raw Normal View History

2011-08-29 15:28:11 +10:00
/*
2018-08-04 15:14:06 +10:00
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
2011-08-29 15:28:11 +10:00
*
2022-03-22 13:18:01 +10:00
* Copyright 2010-2016, 2022 Danny Robson <danny@nerdcruft.net>
2011-08-29 15:28:11 +10:00
*/
#pragma once
2011-08-29 15:28:11 +10:00
2022-03-22 13:18:01 +10:00
#include "./std.hpp"
#include "./stats.hpp"
#include <chrono>
2011-08-29 15:28:11 +10:00
#include <cstdint>
#include <string>
2011-08-29 15:28:11 +10:00
namespace cruft {
///////////////////////////////////////////////////////////////////////////
uintmax_t nanoseconds (void);
//-------------------------------------------------------------------------
template <typename T>
void sleep (std::chrono::duration<T,std::nano> dt)
{
auto nano = std::chrono::duration_cast<std::chrono::nanoseconds> (dt);
sleep (nano.count ());
}
//-------------------------------------------------------------------------
void sleep (uint64_t ns);
///////////////////////////////////////////////////////////////////////////
class delta_clock {
public:
delta_clock ();
std::chrono::nanoseconds dt(void);
protected:
struct {
uint64_t prev;
uint64_t curr;
} time;
};
///////////////////////////////////////////////////////////////////////////
2013-09-20 17:33:08 +10:00
class period_query {
public:
2017-05-23 12:50:51 +10:00
explicit period_query (float seconds);
2013-09-20 17:33:08 +10:00
bool poll (void);
protected:
struct {
uint64_t start;
uint64_t period;
} m_time;
};
///////////////////////////////////////////////////////////////////////////
2013-08-08 10:48:44 +10:00
class rate_limiter {
public:
2017-05-23 12:50:51 +10:00
explicit rate_limiter (unsigned rate);
2013-08-08 10:48:44 +10:00
void poll (void);
protected:
uint64_t m_last;
unsigned m_target;
};
2022-03-22 13:18:01 +10:00
///////////////////////////////////////////////////////////////////////////
2022-03-30 13:29:33 +10:00
/// Ensured to ensure a minimum period has elapsed since a previous
/// invocation.
2022-03-22 13:18:01 +10:00
class period_limiter {
public:
explicit period_limiter (std::chrono::nanoseconds _period);
explicit period_limiter (u64);
2022-03-30 13:29:33 +10:00
/// Wait until the period has elapsed and reset the last activation
/// time.
2022-03-22 13:18:01 +10:00
void poll (void);
2022-03-30 13:29:33 +10:00
/// Wait until the period has elapsed. Does not reset the last
/// activation time.
void wait (void) const;
/// Reset the last activated time. Does not block.
void reset (void);
2022-03-22 13:18:01 +10:00
private:
u64 m_period;
u64 m_prev;
};
///////////////////////////////////////////////////////////////////////////
class polled_duration {
public:
polled_duration (std::string name, uint64_t interval);
void start (void);
void stop (void);
protected:
std::string m_name;
uint64_t m_last;
uint64_t m_interval;
uint64_t m_next;
stats::accumulator<uint64_t> m_series;
};
2011-08-29 15:28:11 +10:00
}