From 993dc2ae77514e61235f0920755fdb1ccc77c2f7 Mon Sep 17 00:00:00 2001 From: Martin Wickham Date: Thu, 30 Sep 2021 21:42:34 -0500 Subject: [PATCH] Fix ownership of array type and elements --- src/Sema.zig | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/Sema.zig b/src/Sema.zig index 995dc84303..7fb12bf27c 100644 --- a/src/Sema.zig +++ b/src/Sema.zig @@ -8244,10 +8244,13 @@ fn zirArrayInit(sema: *Sema, block: *Scope.Block, inst: Zir.Inst.Index, is_ref: var anon_decl = try block.startAnonDecl(); defer anon_decl.deinit(); assert(!(resolved_args.len == 0)); - const final_ty = try Type.Tag.array.create(anon_decl.arena(), .{ .len = resolved_args.len, .elem_type = sema.typeOf(resolved_args[0]) }); + const final_ty = try Type.Tag.array.create(anon_decl.arena(), .{ + .len = resolved_args.len, + .elem_type = try sema.typeOf(resolved_args[0]).copy(anon_decl.arena()), + }); const buf = try anon_decl.arena().alloc(Value, resolved_args.len); for (resolved_args) |arg, i| { - buf[i] = (try sema.resolveMaybeUndefVal(block, src, arg)).?; + buf[i] = try (try sema.resolveMaybeUndefVal(block, src, arg)).?.copy(anon_decl.arena()); } const val = try Value.Tag.array.create(anon_decl.arena(), buf);