aboutsummaryrefslogtreecommitdiff
path: root/include/cru/parse
diff options
context:
space:
mode:
Diffstat (limited to 'include/cru/parse')
-rw-r--r--include/cru/parse/Nonterminal.hpp14
-rw-r--r--include/cru/parse/Symbol.hpp28
-rw-r--r--include/cru/parse/Terminal.hpp14
3 files changed, 56 insertions, 0 deletions
diff --git a/include/cru/parse/Nonterminal.hpp b/include/cru/parse/Nonterminal.hpp
index e69de29b..1bc6f9ff 100644
--- a/include/cru/parse/Nonterminal.hpp
+++ b/include/cru/parse/Nonterminal.hpp
@@ -0,0 +1,14 @@
+#pragma once
+#include "Symbol.hpp"
+
+namespace cru::parse {
+class Nonterminal : public Symbol {
+ public:
+ Nonterminal(Grammar* grammar, String name);
+
+ CRU_DELETE_COPY(Nonterminal)
+ CRU_DELETE_MOVE(Nonterminal)
+
+ ~Nonterminal() override;
+};
+} // namespace cru::parse
diff --git a/include/cru/parse/Symbol.hpp b/include/cru/parse/Symbol.hpp
index e69de29b..5c862c25 100644
--- a/include/cru/parse/Symbol.hpp
+++ b/include/cru/parse/Symbol.hpp
@@ -0,0 +1,28 @@
+#pragma once
+#include "cru/common/String.hpp"
+
+namespace cru::parse {
+class Grammar;
+
+// Base class of Terminal and Nonterminal.
+class Symbol : public Object {
+ public:
+ Symbol(Grammar* grammar, String name);
+
+ CRU_DELETE_COPY(Symbol)
+ CRU_DELETE_MOVE(Symbol)
+
+ ~Symbol() override;
+
+ public:
+ Grammar* GetGrammar() { return grammar_; }
+
+ String GetName() const { return name_; }
+ void SetName(String name) { name_ = std::move(name); }
+
+ private:
+ Grammar* grammar_;
+
+ String name_;
+};
+} // namespace cru::parse
diff --git a/include/cru/parse/Terminal.hpp b/include/cru/parse/Terminal.hpp
index e69de29b..b42ba1f9 100644
--- a/include/cru/parse/Terminal.hpp
+++ b/include/cru/parse/Terminal.hpp
@@ -0,0 +1,14 @@
+#pragma once
+#include "Symbol.hpp"
+
+namespace cru::parse {
+class Terminal : public Symbol {
+ public:
+ explicit Terminal(Grammar* grammar, String name);
+
+ CRU_DELETE_COPY(Terminal)
+ CRU_DELETE_MOVE(Terminal)
+
+ ~Terminal() override;
+};
+} // namespace cru::parse