aboutsummaryrefslogtreecommitdiff
path: root/src/checker/checker.cpp
diff options
context:
space:
mode:
authorgingerBill <ginger.bill.22@gmail.com>2016-08-02 20:53:18 +0100
committergingerBill <ginger.bill.22@gmail.com>2016-08-02 20:53:18 +0100
commit41e7cadb8df4b9833bc3dd827cac32fd3b01ddbd (patch)
tree81272c3361a9f19e97caa8a760553b3e700b31bc /src/checker/checker.cpp
parentbf3283c889ce387fd252b48e12e090fab7446048 (diff)
ret, unreachable, param, deref
Diffstat (limited to 'src/checker/checker.cpp')
-rw-r--r--src/checker/checker.cpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/checker/checker.cpp b/src/checker/checker.cpp
index e6bf8b2ff..5a03baa76 100644
--- a/src/checker/checker.cpp
+++ b/src/checker/checker.cpp
@@ -101,6 +101,7 @@ struct Scope {
Scope *prev, *next;
Scope *first_child, *last_child;
Map<Entity *> elements; // Key: String
+ gbArray(AstNode *) deferred_stmts;
};
enum ExpressionKind {
@@ -154,13 +155,14 @@ struct CheckerContext {
DeclInfo *decl;
};
+// NOTE(bill): Symbol tables
struct CheckerInfo {
Map<TypeAndValue> types; // Key: AstNode * | Expression -> Type (and value)
Map<Entity *> definitions; // Key: AstNode * | Identifier -> Entity
Map<Entity *> uses; // Key: AstNode * | Identifier -> Entity
Map<Scope *> scopes; // Key: AstNode * | Node -> Scope
Map<ExpressionInfo> untyped; // Key: AstNode * | Expression -> ExpressionInfo
- Map<DeclInfo *> entities; // Key: Entity *
+ Map<DeclInfo *> entities; // Key: Entity *
};
struct Checker {
@@ -190,6 +192,7 @@ Scope *make_scope(Scope *parent, gbAllocator allocator) {
Scope *s = gb_alloc_item(allocator, Scope);
s->parent = parent;
map_init(&s->elements, gb_heap_allocator());
+ gb_array_init(s->deferred_stmts, gb_heap_allocator());
if (parent != NULL && parent != universal_scope) {
DLIST_APPEND(parent->first_child, parent->last_child, s);
}
@@ -504,6 +507,12 @@ void check_close_scope(Checker *c) {
c->context.scope = c->context.scope->parent;
}
+void check_add_deferred_stmt(Checker *c, AstNode *stmt) {
+ GB_ASSERT(stmt != NULL);
+ GB_ASSERT(is_ast_node_stmt(stmt));
+ gb_array_append(c->context.scope->deferred_stmts, stmt);
+}
+
void push_procedure(Checker *c, Type *procedure_type) {
gb_array_append(c->procedure_stack, procedure_type);
}
@@ -512,7 +521,6 @@ void pop_procedure(Checker *c) {
gb_array_pop(c->procedure_stack);
}
-
void add_curr_ast_file(Checker *c, AstFile *file) {
gb_zero_item(&c->error_collector);
c->curr_ast_file = file;