aboutsummaryrefslogtreecommitdiff
path: root/src/ir.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-02-23 10:55:41 +0000
committergingerBill <bill@gingerbill.org>2020-02-23 10:55:41 +0000
commit703404a54d2043a8e45ecb1efa6553e45cd516b9 (patch)
tree15d52860429d5f095a2420be6ad114ebeb2562d7 /src/ir.cpp
parente197af766d5ead2a1a67ead4c780848c6749a5b1 (diff)
parent15f5c8537942e85d25819c7799991fab73b2564a (diff)
Merge branch 'master' into llvm-integration
Diffstat (limited to 'src/ir.cpp')
-rw-r--r--src/ir.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/ir.cpp b/src/ir.cpp
index 982576a2b..5568861de 100644
--- a/src/ir.cpp
+++ b/src/ir.cpp
@@ -4405,6 +4405,12 @@ irValue *ir_emit_comp_against_nil(irProcedure *proc, TokenKind op_kind, irValue
} else if (is_type_union(t)) {
if (type_size_of(t) == 0) {
return ir_emit_comp(proc, op_kind, v_zero, v_zero);
+ } else if (is_type_union_maybe_pointer(t)) {
+ Type *bt = base_type(t);
+ irValue *ptr = ir_address_from_load_or_generate_local(proc, x);
+ ptr = ir_emit_bitcast(proc, ptr, alloc_type_pointer(bt->Union.variants[0]));
+ irValue *data = ir_emit_load(proc, ptr);
+ return ir_emit_comp_against_nil(proc, op_kind, data);
} else {
irValue *tag = ir_emit_union_tag_value(proc, x);
return ir_emit_comp(proc, op_kind, tag, v_zero);