|
@@ -7028,6 +7028,8 @@ irAddr ir_build_addr(irProcedure *proc, Ast *expr) {
|
|
Type *fet = ir_type(field_expr);
|
|
Type *fet = ir_type(field_expr);
|
|
// HACK TODO(bill): THIS IS A MASSIVE HACK!!!!
|
|
// HACK TODO(bill): THIS IS A MASSIVE HACK!!!!
|
|
if (is_type_union(ft) && !are_types_identical(fet, ft) && !is_type_untyped(fet)) {
|
|
if (is_type_union(ft) && !are_types_identical(fet, ft) && !is_type_untyped(fet)) {
|
|
|
|
+ GB_ASSERT_MSG(union_variant_index(ft, fet) > 0, "%s", type_to_string(fet));
|
|
|
|
+
|
|
irValue *gep = ir_emit_struct_ep(proc, v, cast(i32)index);
|
|
irValue *gep = ir_emit_struct_ep(proc, v, cast(i32)index);
|
|
ir_emit_store_union_variant(proc, gep, field_expr, fet);
|
|
ir_emit_store_union_variant(proc, gep, field_expr, fet);
|
|
} else {
|
|
} else {
|