2019-02-25 14:48:22 +01:00
|
|
|
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
|
2012-07-09 20:32:02 +02:00
|
|
|
|
2012-06-28 15:43:49 +02:00
|
|
|
#ifndef RINGBUFFER_H
|
|
|
|
#define RINGBUFFER_H
|
|
|
|
|
2014-05-25 16:23:35 +02:00
|
|
|
#include "base/i2-base.hpp"
|
|
|
|
#include "base/object.hpp"
|
2013-03-16 21:18:53 +01:00
|
|
|
#include <vector>
|
2021-02-02 10:16:04 +01:00
|
|
|
#include <mutex>
|
2013-03-16 21:18:53 +01:00
|
|
|
|
2012-06-28 15:43:49 +02:00
|
|
|
namespace icinga
|
|
|
|
{
|
|
|
|
|
2012-09-17 13:35:55 +02:00
|
|
|
/**
|
|
|
|
* A ring buffer that holds a pre-defined number of integers.
|
|
|
|
*
|
|
|
|
* @ingroup base
|
|
|
|
*/
|
2018-01-10 16:44:48 +01:00
|
|
|
class RingBuffer final
|
2012-06-28 15:43:49 +02:00
|
|
|
{
|
|
|
|
public:
|
2014-11-07 12:32:25 +01:00
|
|
|
DECLARE_PTR_TYPEDEFS(RingBuffer);
|
2013-03-01 12:07:52 +01:00
|
|
|
|
2013-03-16 21:18:53 +01:00
|
|
|
typedef std::vector<int>::size_type SizeType;
|
2012-06-28 15:43:49 +02:00
|
|
|
|
2012-08-07 21:02:12 +02:00
|
|
|
RingBuffer(SizeType slots);
|
|
|
|
|
2018-01-04 04:25:35 +01:00
|
|
|
SizeType GetLength() const;
|
2012-08-07 21:02:12 +02:00
|
|
|
void InsertValue(SizeType tv, int num);
|
2017-11-13 16:17:59 +01:00
|
|
|
int UpdateAndGetValues(SizeType tv, SizeType span);
|
2017-11-14 11:03:05 +01:00
|
|
|
double CalculateRate(SizeType tv, SizeType span);
|
2012-06-28 15:43:49 +02:00
|
|
|
|
|
|
|
private:
|
2021-02-02 10:16:04 +01:00
|
|
|
mutable std::mutex m_Mutex;
|
2013-03-16 21:18:53 +01:00
|
|
|
std::vector<int> m_Slots;
|
2013-03-06 11:03:50 +01:00
|
|
|
SizeType m_TimeValue;
|
2017-11-14 11:03:05 +01:00
|
|
|
SizeType m_InsertedValues;
|
2018-01-10 16:44:48 +01:00
|
|
|
|
|
|
|
void InsertValueUnlocked(SizeType tv, int num);
|
|
|
|
int UpdateAndGetValuesUnlocked(SizeType tv, SizeType span);
|
2012-06-28 15:43:49 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* RINGBUFFER_H */
|