aboutsummaryrefslogtreecommitdiffstats
path: root/libalee/corewords.hpp
diff options
context:
space:
mode:
authorClyne Sullivan <clyne@bitgloo.com>2023-11-08 07:37:43 -0500
committerClyne Sullivan <clyne@bitgloo.com>2023-11-08 07:37:43 -0500
commit6496152f573d6b1e2e93d0a9b546403d8b183f8e (patch)
treeb51b6804c4988e2be7450a7dcff4db626c460f99 /libalee/corewords.hpp
parentd6ee894c134c456612e78be08006087a50fbdd35 (diff)
add doxygen support
Diffstat (limited to 'libalee/corewords.hpp')
-rw-r--r--libalee/corewords.hpp81
1 files changed, 58 insertions, 23 deletions
diff --git a/libalee/corewords.hpp b/libalee/corewords.hpp
index 25f6a6e..d134bbb 100644
--- a/libalee/corewords.hpp
+++ b/libalee/corewords.hpp
@@ -1,20 +1,22 @@
-/**
- * Alee Forth: A portable and concise Forth implementation in modern C++.
- * Copyright (C) 2023 Clyne Sullivan <clyne@bitgloo.com>
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
+//
+/// @file corewords.hpp
+/// @brief Manages the fundamental word-set and its execution.
+//
+// Alee Forth: A portable and concise Forth implementation in modern C++.
+// Copyright (C) 2023 Clyne Sullivan <clyne@bitgloo.com>
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU Lesser General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program 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 Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with this program. If not, see <https://www.gnu.org/licenses/>.
#ifndef ALEEFORTH_COREWORDS_HPP
#define ALEEFORTH_COREWORDS_HPP
@@ -27,29 +29,56 @@
/**
* To be implemented by the user, this function is called when the `sys` word
* is executed.
+ * @param state Current execution state object.
*/
-void user_sys(State&);
+void user_sys(State& state);
+/**
+ * @class CoreWords
+ * @brief Provides the fundamental word-set and manages its execution.
+ */
class CoreWords
{
public:
+ /**
+ * Count of total fundamental words.
+ */
constexpr static Cell WordCount = 37;
+
+ /**
+ * Token/index of the semicolon word (";").
+ */
constexpr static Cell Semicolon = 26;
/**
- * Finds execution token that corresponds to the given word.
- * Returns -1 if not found.
+ * Searches for the token/index of the given word if it is part of the
+ * fundamental word-set.
+ * @param state Current execution state object.
+ * @param word Word (stored in state's dictionary memory) to look up.
+ * @return The token/index of the word or -1 if not found.
+ */
+ static Cell findi(State& state, Word word);
+
+ /**
+ * Looks up the token/index of the given fundamental word.
+ * Can evaluate at compile-time.
+ * @param word The word to look up.
+ * @return The token/index of the word or -1 if not found.
*/
- static Cell findi(State&, Word);
consteval static Cell findi(const char *word) {
return findi(word, std::strlen(word));
}
/**
- * Executes the given CoreWord execution token using the given state.
+ * Executes the given execution token using the given state.
+ * @param token Any valid execution token (word, fundamental, constant...).
+ * @param state The state object to execute with.
*/
- static void run(Cell, State&);
+ static void run(Cell token, State& state);
+ /**
+ * String lookup table for the fundamental word-set.
+ */
constexpr static char wordsarr[] =
"_lit\0drop\0dup\0swap\0pick\0sys\0"
"+\0-\0m*\0_/\0_%\0"
@@ -61,6 +90,12 @@ public:
"_uma\0u<\0um/mod\0";
private:
+ /**
+ * Generic implementation of findi(). Private; use public implementations.
+ * @param it Beginning iterator of the word to search for.
+ * @param size Size of the searched-for word i.e. end == it + size.
+ * @return The token/index of the word or -1 if not found.
+ */
template<typename Iter>
constexpr static Cell findi(Iter it, std::size_t size)
{