// sprit-forth: A portable subroutine-threaded Forth. // Copyright (C) 2024 Clyne Sullivan // // This library is free software; you can redistribute it and/or modify it // under the terms of the GNU Library General Public License as published by // the Free Software Foundation; either version 2 of the License, or (at your // option) any later version. // // This library is distributed in the hope that it will be useful, but WITHOUT // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS // FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for // more details. // // You should have received a copy of the GNU Library General Public License // along with this library; if not, write to the Free Software Foundation, Inc., // 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. #ifndef STATE_HPP #define STATE_HPP #include "types.hpp" constexpr Addr DS = 16; /** Data stack size */ constexpr Addr RS = 16; /** Return stack size */ constexpr auto DictSize = 2048u; /** Dictionary size */ constexpr Addr DIdxBase = 0; constexpr Addr DIdxHere = 1; constexpr Addr DIdxLatest = 2; constexpr Addr DIdxState = 3; constexpr Addr DIdxCompXt = 4; constexpr Addr DIdxSource = 5; constexpr Addr DIdxSrcLen = 6; constexpr Addr DIdxInBuf = 7; constexpr Addr DIdxBegin = DIdxInBuf + 80 * sizeof(char); class State { /** * Memory chunk used to store the dictoinary and stacks. */ std::array dict; std::array ds; std::array rs; public: Cell *sp = ds.begin(); Cell *rp = rs.begin(); Cell& base = dict[DIdxBase]; Cell& here = dict[DIdxHere]; Word *& latest = *(Word **)&dict[DIdxLatest]; Cell& state = dict[DIdxState]; Cell& compxt = dict[DIdxCompXt]; Cell& source = dict[DIdxSource]; Cell& sourceu = dict[DIdxSrcLen]; unsigned char& sourcei = *(unsigned char *)&dict[DIdxInBuf]; State() { dict[DIdxBase] = 10; dict[DIdxHere] = (Cell)&dict[DIdxBegin]; dict[DIdxLatest] = 0;//(Cell)&wordset.back(); dict[DIdxState] = 0; } void add(Word& word) noexcept { word.link = latest; latest = &word; } auto dictdata() noexcept { return dict.data(); } void push(Cell); [[nodiscard]] Cell pop(); void rpush(Cell); [[nodiscard]] Cell rpop(); /** * Looks up the definition of the given word. * @param s The name of the word to find * @param len The character count of the word's name * @return Pointer to the word's definition or nullptr if not found */ [[nodiscard]] Word *find(const char *s, int len); }; extern State Forth; #endif // STATE_HPP