Ginger Bill 7 years ago
parent
commit
349a62121c
1 changed files with 13 additions and 7 deletions
  1. 13 7
      src/ir.cpp

+ 13 - 7
src/ir.cpp

@@ -7133,19 +7133,23 @@ void ir_build_stmt_internal(irProcedure *proc, AstNode *node) {
 
 
 	case_ast_node(pa, PushAllocator, node);
-		ir_emit_comment(proc, str_lit("PushAllocator"));
+		ir_emit_comment(proc, str_lit("push_allocator"));
+		irValue *new_allocator = ir_build_expr(proc, pa->expr);
+
 		ir_open_scope(proc);
 
 		irValue *prev = ir_find_or_generate_context_ptr(proc);
 		irValue *next = ir_add_local_generated(proc, t_context);
 		ir_emit_store(proc, next, ir_emit_load(proc, prev));
+
+		Selection sel = lookup_field(proc->module->allocator, t_context, str_lit("allocator"), false);
+		irValue *gep = ir_emit_deep_field_gep(proc, next, sel);
+		ir_emit_store(proc, gep, new_allocator);
+
 		array_add(&proc->context_stack, next);
 		defer (array_pop(&proc->context_stack));
 
 		// TODO(bill): is this too leaky?
-		Selection sel = lookup_field(proc->module->allocator, t_context, str_lit("allocator"), false);
-		irValue *gep = ir_emit_deep_field_gep(proc, next, sel);
-		ir_emit_store(proc, gep, ir_build_expr(proc, pa->expr));
 
 		ir_build_stmt(proc, pa->body);
 
@@ -7154,16 +7158,18 @@ void ir_build_stmt_internal(irProcedure *proc, AstNode *node) {
 
 
 	case_ast_node(pc, PushContext, node);
-		ir_emit_comment(proc, str_lit("PushContext"));
+		ir_emit_comment(proc, str_lit("push_context"));
+		irValue *new_context = ir_build_expr(proc, pc->expr);
+
 		ir_open_scope(proc);
 
 		irValue *prev = ir_find_or_generate_context_ptr(proc);
 		irValue *next = ir_add_local_generated(proc, t_context);
+		ir_emit_store(proc, next, new_context);
+
 		array_add(&proc->context_stack, next);
 		defer (array_pop(&proc->context_stack));
 
-		ir_emit_store(proc, next, ir_build_expr(proc, pc->expr));
-
 		ir_build_stmt(proc, pc->body);
 
 		ir_close_scope(proc, irDeferExit_Default, nullptr);