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 | |
parent | dcd5e792b1d84afd1bea9780781674b6e6ad8dc3 (diff) |
linting; reduce msp430 binary size
Diffstat (limited to 'libalee')
-rw-r--r-- | libalee/dictionary.hpp | 2 | ||||
-rw-r--r-- | libalee/state.cpp | 4 | ||||
-rw-r--r-- | libalee/state.hpp | 39 |
3 files changed, 25 insertions, 20 deletions
diff --git a/libalee/dictionary.hpp b/libalee/dictionary.hpp index 4dcae77..0a2e4d3 100644 --- a/libalee/dictionary.hpp +++ b/libalee/dictionary.hpp @@ -73,6 +73,8 @@ public: bool equal(Word, const char *, unsigned) const noexcept; bool equal(Word, Word) const noexcept; + + virtual ~Dictionary() = default; }; #endif // ALEEFORTH_DICTIONARY_HPP diff --git a/libalee/state.cpp b/libalee/state.cpp index ea6c601..b3c98b1 100644 --- a/libalee/state.cpp +++ b/libalee/state.cpp @@ -55,11 +55,11 @@ State::Error State::execute(Addr addr) std::size_t State::size() const noexcept { - return std::distance(dstack, static_cast<const Cell *>(dsp)) + 1; + return std::distance(dstack, static_cast<const Cell *>(dsp)); } std::size_t State::rsize() const noexcept { - return std::distance(rstack, static_cast<const Cell *>(rsp)) + 1; + return std::distance(rstack, static_cast<const Cell *>(rsp)); } 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 |