diff options
| author | gingerBill <ginger.bill.22@gmail.com> | 2016-08-02 20:53:18 +0100 |
|---|---|---|
| committer | gingerBill <ginger.bill.22@gmail.com> | 2016-08-02 20:53:18 +0100 |
| commit | 41e7cadb8df4b9833bc3dd827cac32fd3b01ddbd (patch) | |
| tree | 81272c3361a9f19e97caa8a760553b3e700b31bc /src/checker/checker.cpp | |
| parent | bf3283c889ce387fd252b48e12e090fab7446048 (diff) | |
ret, unreachable, param, deref
Diffstat (limited to 'src/checker/checker.cpp')
| -rw-r--r-- | src/checker/checker.cpp | 12 |
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; |