Make check_single_global_entity use create_checker_context

This commit is contained in:
gingerBill
2021-03-15 14:05:38 +00:00
parent 85fd8aaf37
commit b94ab4dc05
+11 -6
View File
@@ -3419,6 +3419,11 @@ void check_collect_entities(CheckerContext *c, Slice<Ast *> const &nodes) {
}
}
CheckerContext *create_checker_context(Checker *c) {
CheckerContext *ctx = gb_alloc_item(heap_allocator(), CheckerContext);
*ctx = c->init_ctx;
return ctx;
}
void check_single_global_entity(Checker *c, Entity *e, DeclInfo *d) {
GB_ASSERT(e != nullptr);
@@ -3431,17 +3436,17 @@ void check_single_global_entity(Checker *c, Entity *e, DeclInfo *d) {
return;
}
CheckerContext ctx = c->init_ctx;
CheckerContext *ctx = create_checker_context(c);
GB_ASSERT(d->scope->flags&ScopeFlag_File);
AstFile *file = d->scope->file;
add_curr_ast_file(&ctx, file);
add_curr_ast_file(ctx, file);
AstPackage *pkg = file->pkg;
GB_ASSERT(ctx.pkg != nullptr);
GB_ASSERT(ctx->pkg != nullptr);
GB_ASSERT(e->pkg != nullptr);
ctx.decl = d;
ctx.scope = d->scope;
ctx->decl = d;
ctx->scope = d->scope;
if (!e->pkg->used) {
return;
@@ -3460,7 +3465,7 @@ void check_single_global_entity(Checker *c, Entity *e, DeclInfo *d) {
}
}
check_entity_decl(&ctx, e, d, nullptr);
check_entity_decl(ctx, e, d, nullptr);
}
void check_all_global_entities(Checker *c) {