Fix assertion on union assignment in compound literal

This commit is contained in:
gingerBill
2018-11-29 22:50:08 +00:00
parent 7ffcf34dca
commit 008d8f25c8

View File

@@ -7027,9 +7027,7 @@ irAddr ir_build_addr(irProcedure *proc, Ast *expr) {
Type *fet = ir_type(field_expr);
// HACK TODO(bill): THIS IS A MASSIVE HACK!!!!
if (is_type_union(ft) && !are_types_identical(fet, ft)) {
GB_ASSERT(union_variant_index(ft, fet) > 0);
if (is_type_union(ft) && !are_types_identical(fet, ft) && !is_type_untyped(fet)) {
irValue *gep = ir_emit_struct_ep(proc, v, cast(i32)index);
ir_emit_store_union_variant(proc, gep, field_expr, fet);
} else {