| /*----------------------------------------------------------------------------*/ |
| /* Copyright (c) FIRST 2015-2016. All Rights Reserved. */ |
| /* Open Source Software - may be modified and shared by FRC teams. The code */ |
| /* must be accompanied by the FIRST BSD license file in the root directory of */ |
| /* the project. */ |
| /*----------------------------------------------------------------------------*/ |
| |
| #pragma once |
| |
| #include <vector> |
| #include <cstddef> |
| |
| /** |
| * This is a simple circular buffer so we don't need to "bucket brigade" copy |
| * old values. |
| */ |
| template <class T> |
| class CircularBuffer { |
| public: |
| CircularBuffer(size_t size); |
| |
| void PushFront(T value); |
| void PushBack(T value); |
| T PopFront(); |
| T PopBack(); |
| void Reset(); |
| |
| T& operator[](size_t index); |
| const T& operator[](size_t index) const; |
| |
| private: |
| std::vector<T> m_data; |
| |
| // Index of element at front of buffer |
| size_t m_front = 0; |
| |
| // Number of elements used in buffer |
| size_t m_length = 0; |
| |
| size_t ModuloInc(size_t index); |
| size_t ModuloDec(size_t index); |
| }; |
| |
| #include "CircularBuffer.inc" |