diff options
Diffstat (limited to 'src/utility')
| -rw-r--r-- | src/utility/StaticStack.h | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/utility/StaticStack.h b/src/utility/StaticStack.h new file mode 100644 index 00000000..40df9354 --- /dev/null +++ b/src/utility/StaticStack.h @@ -0,0 +1,47 @@ +#include <array> +#include <cstddef> + +namespace Pinetime { + namespace Utility { + template <typename T, size_t N> + class StaticStack { + public: + T Pop(); + void Push(T element); + void Reset(); + T Top(); + + private: + std::array<T, N> elementArray; + // Number of elements in stack, points to the next empty slot + size_t stackPointer = 0; + }; + + // Returns random data when popping from empty array. + template <typename T, size_t N> + T StaticStack<T, N>::Pop() { + if (stackPointer > 0) { + stackPointer--; + } + return elementArray[stackPointer]; + } + + template <typename T, size_t N> + void StaticStack<T, N>::Push(T element) { + if (stackPointer < elementArray.size()) { + elementArray[stackPointer] = element; + stackPointer++; + } + } + + template <typename T, size_t N> + void StaticStack<T, N>::Reset() { + stackPointer = 0; + } + + template <typename T, size_t N> + T StaticStack<T, N>::Top() { + return elementArray[stackPointer - 1]; + } + } +} |
