From 41e7cadb8df4b9833bc3dd827cac32fd3b01ddbd Mon Sep 17 00:00:00 2001 From: gingerBill Date: Tue, 2 Aug 2016 20:53:18 +0100 Subject: ret, unreachable, param, deref --- src/checker/checker.cpp | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'src/checker/checker.cpp') 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 elements; // Key: String + gbArray(AstNode *) deferred_stmts; }; enum ExpressionKind { @@ -154,13 +155,14 @@ struct CheckerContext { DeclInfo *decl; }; +// NOTE(bill): Symbol tables struct CheckerInfo { Map types; // Key: AstNode * | Expression -> Type (and value) Map definitions; // Key: AstNode * | Identifier -> Entity Map uses; // Key: AstNode * | Identifier -> Entity Map scopes; // Key: AstNode * | Node -> Scope Map untyped; // Key: AstNode * | Expression -> ExpressionInfo - Map entities; // Key: Entity * + Map 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; -- cgit v1.2.3