From 50a51df0404ee4f057fbc19657672d1c7d3eef68 Mon Sep 17 00:00:00 2001 From: Cori Barker Date: Sat, 7 Mar 2026 18:33:21 +0000 Subject: removed implementations of symbol table related classes, need to fix the parser to use the new AST node classes then i can write the symbol table classes and refactor the lexer and parser to use the symbol table --- src/scope.cpp | 52 ---------------------------------------------------- 1 file changed, 52 deletions(-) delete mode 100644 src/scope.cpp (limited to 'src/scope.cpp') diff --git a/src/scope.cpp b/src/scope.cpp deleted file mode 100644 index 86e2668..0000000 --- a/src/scope.cpp +++ /dev/null @@ -1,52 +0,0 @@ -#include "scope.hpp" - -Scope::Scope(std::string name, int level, std::unique_ptr parent) : scope_name(name), scope_level(level), parent_scope(parent) {} - -std::string Scope::getScopeName() { - return scope_name; -} - -int Scope::getScopeLevel() { - return scope_level; -} - -std::unique_ptr Scope::getParentScope() { - return parent_scope; -} - -void Scope::define(Symbol symbol) { - if (isDeclared(symbol->getName())) { - // error - } - - else { - symobls.add(symbol->getName(), symbol); - } -} - -std::unique_ptr Scope::lookup(std::string name) { - auto it = symbols.find(name); - if (it != symbols.end()) { - return &(it->second); - } - - return nullptr; -} - -bool Scope::isDeclared(std::string name) { - return lookup(name) != nullptr; -} - -std::unordered_map Scope::getAllSymbols() { - return symbols; -} - -std::string Scope::toString() { - std::string result = "Scope: " + scope_name + "(level " + std::to_string(scope_level) + ") \n"; - - for (auto& pair : symbols) { - result += " " + pair.first + " : " + pair.second.getDataType() + "\n"; - } - - return result; -} -- cgit v1.2.3