aboutsummaryrefslogtreecommitdiffstats
path: root/libalee
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2023-03-09 09:16:12 -0500
committerClyne Sullivan <clyne@bitgloo.com>2023-03-09 09:16:12 -0500
commit970bbb473c81975d3c7366260c8228fd4fcc8c4d (patch)
tree518c5e7290ffe66e84ba1c8e7df0c42f849d0857 /libalee
parentdcd5e792b1d84afd1bea9780781674b6e6ad8dc3 (diff)
linting; reduce msp430 binary size
Diffstat (limited to 'libalee')
-rw-r--r--libalee/dictionary.hpp2
-rw-r--r--libalee/state.cpp4
-rw-r--r--libalee/state.hpp39
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