aboutsummaryrefslogtreecommitdiffstats
path: root/parser.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'parser.hpp')
-rw-r--r--parser.hpp86
1 files changed, 4 insertions, 82 deletions
diff --git a/parser.hpp b/parser.hpp
index c136990..b45a5d0 100644
--- a/parser.hpp
+++ b/parser.hpp
@@ -19,92 +19,14 @@
#ifndef ALEEFORTH_PARSER_HPP
#define ALEEFORTH_PARSER_HPP
-#include "executor.hpp"
+#include "types.hpp"
+
+#include <string_view>
class Parser
{
public:
- ParseStatus parse(State& state, std::string_view& str) {
- const auto end = str.find_first_of(" \t\n\r");
- const auto sub = str.substr(0, end);
- if (sub.empty())
- return ParseStatus::Finished;
-
- if (state.pass != Pass::None) {
- switch (state.pass) {
- case Pass::Comment:
- if (str.front() == ')')
- state.pass = Pass::None;
-
- str = str.substr(1);
- break;
- case Pass::Colon:
- state.pass = Pass::None;
- state.compiling = true;
- state.dict.addDefinition(sub);
- break;
- case Pass::Constant:
- state.pass = Pass::None;
- state.compiling = true;
- state.dict.addDefinition(sub);
- state.dict.add(CoreWords::HiddenWordLiteral);
- state.dict.add(state.pop());
- state.dict.add(CoreWords::findi(";"));
- CoreWords::run(CoreWords::findi(";"), state);
- break;
- default:
- break;
- }
- } else {
- if (auto i = CoreWords::findi(sub); i >= 0) {
- if (state.compiling)
- state.dict.add(i);
- if (!state.compiling || sub.front() == ';')
- CoreWords::run(i, state);
- } else if (auto j = state.dict.find(sub); j > 0) {
- auto e = state.dict.getexec(j);
-
- if (state.compiling) {
- if (state.dict.read(j) & CoreWords::Immediate) {
- state.compiling = false;
- Executor::fullexec(state, e);
- state.compiling = true;
- } else {
- state.dict.add(CoreWords::HiddenWordJump);
- state.dict.add(e);
- }
- } else {
- Executor::fullexec(state, e);
- }
- } else {
- char *p;
- const auto l = static_cast<Cell>(std::strtol(sub.data(), &p, 10));
-
- if (p != sub.data()) {
- if (state.compiling) {
- state.dict.add(CoreWords::HiddenWordLiteral);
- state.dict.add(l);
- } else {
- state.push(l);
- }
- } else {
- return ParseStatus::Error;
- }
- }
-
- if (end == std::string_view::npos)
- return ParseStatus::Finished;
- }
-
- const auto next = str.find_first_not_of(" \t\n\r", end);
-
- if (next == std::string_view::npos) {
- return ParseStatus::Finished;
- } else {
- str = str.substr(next);
- return ParseStatus::Continue;
- }
- }
+ ParseStatus parse(State&, std::string_view&);
};
#endif // ALEEFORTH_PARSER_HPP