diff options
| -rw-r--r-- | include/semantic_analyzer.hpp | 6 | ||||
| -rw-r--r-- | src/semantic_analyzer.cpp | 24 |
2 files changed, 30 insertions, 0 deletions
diff --git a/include/semantic_analyzer.hpp b/include/semantic_analyzer.hpp index ec1e4a1..8db3d05 100644 --- a/include/semantic_analyzer.hpp +++ b/include/semantic_analyzer.hpp @@ -1,10 +1,16 @@ #pragma once #include "symbol_table.hpp" +#include "ast_node.hpp" class SemanticAnalyzer { public: explicit SemanticAnalyzer(); + SymbolTable analyze(ASTNode* node); + Symbol* analyzeVariable(ASTNode* node); + Symbol* analyzeFunction(ASTNode* node); + ASTNode* advance(); + ASTNode* peek(); private: SymbolTable symbol_table; diff --git a/src/semantic_analyzer.cpp b/src/semantic_analyzer.cpp new file mode 100644 index 0000000..48a9448 --- /dev/null +++ b/src/semantic_analyzer.cpp @@ -0,0 +1,24 @@ +#include "semantic_analyzer.hpp" + +SemanticAnalyzer::SemanticAnalyzer() : symbol_table(), current_scope(nullptr), current_scope_level(-1) { } + +SymbolTable SemanticAnalyzer::analyze(ASTNode* node) { + for (auto function : node->function_delcarations) { + analyzeFunction(function); + } +} + +ASTNode* SemanticAnalyzer::advance() { + if (dynamic_cast<ProgramNode*>(node)) { + + } +} + +ASTNode* SemanticAnalyzer::peek() { } + +Symbol* SemanticAnalyzer::analyzeVariable(ASTNode* node) { } + +Symbol* SemanticAnalyzer::analyzeFunctionDeclaration(ASTNode* node) { + std::string identifier = node->identifier; + symbol_type = SymbolType::FUNCTION_DECLARATION; +} |
