commit cb6702f42d1325d3c751a74bd7e5398d404c07f4 (tree)
parent 0958ea339129f9ed8c9c07c2c3fbb34fc758b62f
Author: Andrew Kelley <andrew@ziglang.org>
Date: Mon, 21 Jul 2025 15:56:52 -0700
Sema: fix missed union init OPV
Diffstat:
1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/src/Sema.zig b/src/Sema.zig
@@ -5000,9 +5000,11 @@ fn validateUnionInit(
}
if (init_ref) |v| try sema.validateRuntimeValue(block, block.nodeOffset(field_ptr_data.src_node), v);
- const new_tag = Air.internedToRef(tag_val.toIntern());
- const set_tag_inst = try block.addBinOp(.set_union_tag, union_ptr, new_tag);
- try sema.checkComptimeKnownStore(block, set_tag_inst, LazySrcLoc.unneeded); // `unneeded` since this isn't a "proper" store
+ if ((try sema.typeHasOnePossibleValue(tag_ty)) == null) {
+ const new_tag = Air.internedToRef(tag_val.toIntern());
+ const set_tag_inst = try block.addBinOp(.set_union_tag, union_ptr, new_tag);
+ try sema.checkComptimeKnownStore(block, set_tag_inst, LazySrcLoc.unneeded); // `unneeded` since this isn't a "proper" store
+ }
}
fn validateStructInit(
@@ -19690,8 +19692,10 @@ fn zirStructInit(
const base_ptr = try sema.optEuBasePtrInit(block, alloc, src);
const field_ptr = try sema.unionFieldPtr(block, field_src, base_ptr, field_name, field_src, resolved_ty, true);
try sema.storePtr(block, src, field_ptr, init_inst);
- const new_tag = Air.internedToRef(tag_val.toIntern());
- _ = try block.addBinOp(.set_union_tag, base_ptr, new_tag);
+ if ((try sema.typeHasOnePossibleValue(tag_ty)) == null) {
+ const new_tag = Air.internedToRef(tag_val.toIntern());
+ _ = try block.addBinOp(.set_union_tag, base_ptr, new_tag);
+ }
return sema.makePtrConst(block, alloc);
}