2018-07-12 16:29:32 +02:00
|
|
|
#ifndef FRAMEWORK_CONTAINER_SIMPLERINGBUFFER_H_
|
|
|
|
#define FRAMEWORK_CONTAINER_SIMPLERINGBUFFER_H_
|
|
|
|
|
|
|
|
#include <framework/container/RingBufferBase.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
2019-10-29 19:31:18 +01:00
|
|
|
/**
|
2020-01-12 14:18:12 +01:00
|
|
|
* @brief Circular buffer implementation, useful for buffering into data streams.
|
|
|
|
* @details Note that the deleteData() has to be called to increment the read pointer
|
|
|
|
* @ingroup containers
|
2019-10-29 19:31:18 +01:00
|
|
|
*/
|
2018-07-12 16:29:32 +02:00
|
|
|
class SimpleRingBuffer: public RingBufferBase<> {
|
|
|
|
public:
|
|
|
|
SimpleRingBuffer(uint32_t size, bool overwriteOld);
|
|
|
|
virtual ~SimpleRingBuffer();
|
2019-10-29 19:31:18 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Write to circular buffer and increment write pointer by amount
|
|
|
|
* @param data
|
|
|
|
* @param amount
|
|
|
|
* @return
|
|
|
|
*/
|
2018-07-12 16:29:32 +02:00
|
|
|
ReturnValue_t writeData(const uint8_t* data, uint32_t amount);
|
2019-10-29 19:31:18 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read from circular buffer at read pointer
|
|
|
|
* @param data
|
|
|
|
* @param amount
|
|
|
|
* @param readRemaining
|
|
|
|
* @param trueAmount
|
|
|
|
* @return
|
|
|
|
*/
|
2018-07-12 16:29:32 +02:00
|
|
|
ReturnValue_t readData(uint8_t* data, uint32_t amount, bool readRemaining = false, uint32_t* trueAmount = NULL);
|
2019-10-29 19:31:18 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete data starting by incrementing read pointer
|
|
|
|
* @param amount
|
|
|
|
* @param deleteRemaining
|
|
|
|
* @param trueAmount
|
|
|
|
* @return
|
|
|
|
*/
|
2018-07-12 16:29:32 +02:00
|
|
|
ReturnValue_t deleteData(uint32_t amount, bool deleteRemaining = false, uint32_t* trueAmount = NULL);
|
|
|
|
private:
|
|
|
|
// static const uint8_t TEMP_READ_PTR = 1;
|
|
|
|
static const uint8_t READ_PTR = 0;
|
|
|
|
uint8_t* buffer;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* FRAMEWORK_CONTAINER_SIMPLERINGBUFFER_H_ */
|
|
|
|
|