diff options
author | Clyne Sullivan <clyne@bitgloo.com> | 2023-03-09 09:16:12 -0500 |
---|---|---|
committer | Clyne Sullivan <clyne@bitgloo.com> | 2023-03-09 09:16:12 -0500 |
commit | 970bbb473c81975d3c7366260c8228fd4fcc8c4d (patch) | |
tree | 518c5e7290ffe66e84ba1c8e7df0c42f849d0857 /libalee/state.hpp | |
parent | dcd5e792b1d84afd1bea9780781674b6e6ad8dc3 (diff) |
linting; reduce msp430 binary size
Diffstat (limited to 'libalee/state.hpp')
-rw-r--r-- | libalee/state.hpp | 39 |
1 files changed, 21 insertions, 18 deletions
diff --git a/libalee/state.hpp b/libalee/state.hpp index 28396dc..648b868 100644 --- a/libalee/state.hpp +++ b/libalee/state.hpp @@ -28,8 +28,9 @@ constexpr unsigned DataStackSize = 16; constexpr unsigned ReturnStackSize = 16; -struct State +class State { +public: enum class Error : int { none = 0, push, @@ -45,11 +46,6 @@ struct State Dictionary& dict; void (*input)(State&); - Cell dstack[DataStackSize] = {}; - Cell rstack[ReturnStackSize] = {}; - Cell *dsp = dstack - 1; - Cell *rsp = rstack - 1; - std::jmp_buf jmpbuf = {}; constexpr State(Dictionary& d, void (*i)(State&)): @@ -64,15 +60,15 @@ struct State std::size_t rsize() const noexcept; inline void push(Cell value) { - if (dsp == dstack + DataStackSize - 1) + if (dsp == dstack + DataStackSize) std::longjmp(jmpbuf, static_cast<int>(Error::push)); - *++dsp = value; + *dsp++ = value; } inline Cell pop() { - if (dsp < dstack) + if (dsp == dstack) std::longjmp(jmpbuf, static_cast<int>(Error::pop)); - return *dsp--; + return *--dsp; } inline Cell beyondip() { @@ -81,28 +77,35 @@ struct State } inline void pushr(Cell value) { - if (rsp == rstack + ReturnStackSize - 1) + if (rsp == rstack + ReturnStackSize) std::longjmp(jmpbuf, static_cast<int>(Error::pushr)); - *++rsp = value; + *rsp++ = value; } inline Cell popr() { - if (rsp < rstack) + if (rsp == rstack) std::longjmp(jmpbuf, static_cast<int>(Error::popr)); - return *rsp--; + return *--rsp; } inline Cell& top() { - if (dsp < dstack) + if (dsp == dstack) std::longjmp(jmpbuf, static_cast<int>(Error::top)); - return *dsp; + return *(dsp - 1); } inline Cell& pick(std::size_t i) { - if (dsp - i < dstack) + if (dsp - i == dstack) std::longjmp(jmpbuf, static_cast<int>(Error::pick)); - return *(dsp - i); + return *(dsp - i - 1); } + +private: + Cell dstack[DataStackSize] = {}; + Cell rstack[ReturnStackSize] = {}; + Cell *dsp = dstack; + Cell *rsp = rstack; + }; #endif // ALEEFORTH_STATE_HPP |