43 : m_buffer{buffer}, m_index{
index} {}
80 : m_buffer{buffer}, m_index{
index} {}
188 constexpr size_t size()
const {
return m_length; }
193 constexpr T&
front() {
return (*
this)[0]; }
198 constexpr const T&
front()
const {
return (*
this)[0]; }
207 return m_data[(m_front + m_length - 1) % m_data.size()];
216 constexpr const T&
back()
const {
217 return m_data[(m_front + m_length - 1) % m_data.size()];
226 if (m_data.size() == 0) {
230 m_front = ModuloDec(m_front);
232 m_data[m_front] = value;
234 if (m_length < m_data.size()) {
245 if (m_data.size() == 0) {
249 m_data[(m_front + m_length) % m_data.size()] = value;
251 if (m_length < m_data.size()) {
255 m_front = ModuloInc(m_front);
265 template <
class... Args>
267 if (m_data.size() == 0) {
271 m_front = ModuloDec(m_front);
273 m_data[m_front] = T{args...};
275 if (m_length < m_data.size()) {
286 template <
class... Args>
288 if (m_data.size() == 0) {
292 m_data[(m_front + m_length) % m_data.size()] = T{args...};
294 if (m_length < m_data.size()) {
298 m_front = ModuloInc(m_front);
309 T& temp = m_data[m_front];
310 m_front = ModuloInc(m_front);
323 return m_data[(m_front + m_length) % m_data.size()];
330 if (
size > m_data.size()) {
332 size_t insertLocation = (m_front + m_length) % m_data.size();
335 if (insertLocation <= m_front) {
336 m_front +=
size - m_data.size();
340 m_data.insert(m_data.begin() + insertLocation,
size - m_data.size(), 0);
341 }
else if (
size < m_data.size()) {
347 size_t elemsToRemove = m_data.size() -
size;
348 auto frontIter = m_data.begin() + m_front;
349 if (m_front < elemsToRemove) {
353 m_data.erase(frontIter +
size, m_data.end());
356 m_data.erase(m_data.begin(), frontIter);
362 m_data.erase(frontIter - elemsToRemove, frontIter);
365 m_front -= elemsToRemove;
372 if (m_length >
size) {
390 return m_data[(m_front +
index) % m_data.size()];
397 return m_data[(m_front +
index) % m_data.size()];
401 std::vector<T> m_data;
415 constexpr size_t ModuloInc(
size_t index) {
416 return (
index + 1) % m_data.size();
425 constexpr size_t ModuloDec(
size_t index) {
427 return m_data.size() - 1;
@ index
Definition base.h:690
Definition circular_buffer.hpp:71
std::bidirectional_iterator_tag iterator_category
Definition circular_buffer.hpp:73
constexpr const_iterator(const circular_buffer *buffer, size_t index)
Definition circular_buffer.hpp:79
T * pointer
Definition circular_buffer.hpp:76
constexpr const_iterator operator++(int)
Definition circular_buffer.hpp:86
const T & const_reference
Definition circular_buffer.hpp:77
std::ptrdiff_t difference_type
Definition circular_buffer.hpp:75
constexpr const_reference operator*() const
Definition circular_buffer.hpp:101
constexpr const_iterator operator--(int)
Definition circular_buffer.hpp:95
constexpr const_iterator & operator++()
Definition circular_buffer.hpp:82
constexpr const_iterator & operator--()
Definition circular_buffer.hpp:91
constexpr bool operator==(const const_iterator &) const =default
T value_type
Definition circular_buffer.hpp:74
Definition circular_buffer.hpp:34
T value_type
Definition circular_buffer.hpp:37
constexpr iterator & operator++()
Definition circular_buffer.hpp:45
constexpr iterator operator++(int)
Definition circular_buffer.hpp:49
constexpr iterator & operator--()
Definition circular_buffer.hpp:54
constexpr iterator(circular_buffer *buffer, size_t index)
Definition circular_buffer.hpp:42
constexpr iterator operator--(int)
Definition circular_buffer.hpp:58
std::ptrdiff_t difference_type
Definition circular_buffer.hpp:38
constexpr bool operator==(const iterator &) const =default
T & reference
Definition circular_buffer.hpp:40
constexpr reference operator*()
Definition circular_buffer.hpp:64
std::bidirectional_iterator_tag iterator_category
Definition circular_buffer.hpp:36
T * pointer
Definition circular_buffer.hpp:39
constexpr const_reverse_iterator crbegin() const
Returns const reverse begin iterator.
Definition circular_buffer.hpp:174
constexpr const_reverse_iterator crend() const
Returns const reverse end iterator.
Definition circular_buffer.hpp:181
constexpr void resize(size_t size)
Resizes internal buffer to given size.
Definition circular_buffer.hpp:329
constexpr T & front()
Returns value at front of buffer.
Definition circular_buffer.hpp:193
constexpr const_iterator begin() const
Returns const begin iterator.
Definition circular_buffer.hpp:126
constexpr const_reverse_iterator rbegin() const
Returns const reverse begin iterator.
Definition circular_buffer.hpp:160
constexpr void push_back(T value)
Push a new value onto the back of the buffer.
Definition circular_buffer.hpp:244
constexpr T & operator[](size_t index)
Definition circular_buffer.hpp:389
constexpr iterator begin()
Returns begin iterator.
Definition circular_buffer.hpp:114
constexpr const_iterator cbegin() const
Returns const begin iterator.
Definition circular_buffer.hpp:138
constexpr T pop_back()
Pop value at back of buffer.
Definition circular_buffer.hpp:321
constexpr void push_front(T value)
Push a new value onto the front of the buffer.
Definition circular_buffer.hpp:225
constexpr reverse_iterator rbegin()
Returns reverse begin iterator.
Definition circular_buffer.hpp:150
constexpr circular_buffer(circular_buffer &&)=default
constexpr T & back()
Returns value at back of buffer.
Definition circular_buffer.hpp:206
constexpr const_iterator cend() const
Returns const end iterator.
Definition circular_buffer.hpp:143
constexpr void reset()
Empties internal buffer.
Definition circular_buffer.hpp:381
constexpr circular_buffer(size_t size)
Constructs a circular buffer.
Definition circular_buffer.hpp:27
constexpr size_t size() const
Returns number of elements in buffer.
Definition circular_buffer.hpp:188
constexpr const_iterator end() const
Returns const end iterator.
Definition circular_buffer.hpp:131
constexpr circular_buffer & operator=(circular_buffer &&)=default
constexpr void emplace_front(Args &&... args)
Push a new value onto the front of the buffer that is constructed with the provided constructor argum...
Definition circular_buffer.hpp:266
constexpr reverse_iterator rend()
Returns reverse end iterator.
Definition circular_buffer.hpp:155
std::reverse_iterator< const_iterator > const_reverse_iterator
Definition circular_buffer.hpp:109
constexpr const T & back() const
Returns value at back of buffer.
Definition circular_buffer.hpp:216
constexpr iterator end()
Returns end iterator.
Definition circular_buffer.hpp:119
constexpr const T & operator[](size_t index) const
Definition circular_buffer.hpp:396
constexpr const_reverse_iterator rend() const
Returns const reverse end iterator.
Definition circular_buffer.hpp:167
constexpr circular_buffer(const circular_buffer &)=default
constexpr void emplace_back(Args &&... args)
Push a new value onto the back of the buffer that is constructed with the provided constructor argume...
Definition circular_buffer.hpp:287
constexpr circular_buffer & operator=(const circular_buffer &)=default
std::reverse_iterator< iterator > reverse_iterator
Definition circular_buffer.hpp:108
constexpr T pop_front()
Pop value at front of buffer.
Definition circular_buffer.hpp:308
constexpr const T & front() const
Returns value at front of buffer.
Definition circular_buffer.hpp:198
Definition raw_os_ostream.hpp:19