Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
CircularBuffer.h@0:787a5401f57e, 2012-08-05 (annotated)
- Committer:
- UCSBRobotics
- Date:
- Sun Aug 05 07:52:40 2012 +0000
- Revision:
- 0:787a5401f57e
- Child:
- 1:b24970e4c038
Initial commit.; Basic circular buffer template is implemented and compiles.
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| UCSBRobotics | 0:787a5401f57e | 1 | #ifndef CIRCULARBUFFER_H |
| UCSBRobotics | 0:787a5401f57e | 2 | #define CIRCULARBUFFER_H |
| UCSBRobotics | 0:787a5401f57e | 3 | |
| UCSBRobotics | 0:787a5401f57e | 4 | |
| UCSBRobotics | 0:787a5401f57e | 5 | |
| UCSBRobotics | 0:787a5401f57e | 6 | template <typename T, int S> |
| UCSBRobotics | 0:787a5401f57e | 7 | class CircularBuffer |
| UCSBRobotics | 0:787a5401f57e | 8 | { |
| UCSBRobotics | 0:787a5401f57e | 9 | public: |
| UCSBRobotics | 0:787a5401f57e | 10 | CircularBuffer() { index = 0; } |
| UCSBRobotics | 0:787a5401f57e | 11 | T value(int i); |
| UCSBRobotics | 0:787a5401f57e | 12 | void push(T value); |
| UCSBRobotics | 0:787a5401f57e | 13 | void revert(int amount); |
| UCSBRobotics | 0:787a5401f57e | 14 | |
| UCSBRobotics | 0:787a5401f57e | 15 | protected: |
| UCSBRobotics | 0:787a5401f57e | 16 | T data[S]; |
| UCSBRobotics | 0:787a5401f57e | 17 | int index; |
| UCSBRobotics | 0:787a5401f57e | 18 | }; |
| UCSBRobotics | 0:787a5401f57e | 19 | |
| UCSBRobotics | 0:787a5401f57e | 20 | |
| UCSBRobotics | 0:787a5401f57e | 21 | |
| UCSBRobotics | 0:787a5401f57e | 22 | template <typename T, int S> |
| UCSBRobotics | 0:787a5401f57e | 23 | inline T CircularBuffer<T, S>::value(int i) |
| UCSBRobotics | 0:787a5401f57e | 24 | { |
| UCSBRobotics | 0:787a5401f57e | 25 | int realIndex = (index - i) % S; |
| UCSBRobotics | 0:787a5401f57e | 26 | if (realIndex < 0) realIndex += S; |
| UCSBRobotics | 0:787a5401f57e | 27 | return data[realIndex]; |
| UCSBRobotics | 0:787a5401f57e | 28 | } |
| UCSBRobotics | 0:787a5401f57e | 29 | |
| UCSBRobotics | 0:787a5401f57e | 30 | |
| UCSBRobotics | 0:787a5401f57e | 31 | |
| UCSBRobotics | 0:787a5401f57e | 32 | template <typename T, int S> |
| UCSBRobotics | 0:787a5401f57e | 33 | inline void CircularBuffer<T, S>::push(T value) |
| UCSBRobotics | 0:787a5401f57e | 34 | { |
| UCSBRobotics | 0:787a5401f57e | 35 | index = ++index % S; |
| UCSBRobotics | 0:787a5401f57e | 36 | data[index] = value; |
| UCSBRobotics | 0:787a5401f57e | 37 | } |
| UCSBRobotics | 0:787a5401f57e | 38 | |
| UCSBRobotics | 0:787a5401f57e | 39 | |
| UCSBRobotics | 0:787a5401f57e | 40 | |
| UCSBRobotics | 0:787a5401f57e | 41 | template <typename T, int S> |
| UCSBRobotics | 0:787a5401f57e | 42 | inline void CircularBuffer<T, S>::revert(int amount) |
| UCSBRobotics | 0:787a5401f57e | 43 | { |
| UCSBRobotics | 0:787a5401f57e | 44 | index = index >= amount ? index - amount : index - amount + S; |
| UCSBRobotics | 0:787a5401f57e | 45 | } |
| UCSBRobotics | 0:787a5401f57e | 46 | |
| UCSBRobotics | 0:787a5401f57e | 47 | #endif // CIRCULARBUFFER_H |
