diff options
| author | gingerBill <bill@gingerbill.org> | 2019-07-09 10:28:13 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2019-07-09 10:28:13 +0100 |
| commit | 4ab9edeb53559f6ab6ef39a5ad9b45564d22aa8e (patch) | |
| tree | 02ece312f83cfb4e5b3873d88b64950369c883e0 /src/ir.cpp | |
| parent | c5b3d7a73640b3d3cbf3309cc2e61790a4901da6 (diff) | |
union #no_nil
Diffstat (limited to 'src/ir.cpp')
| -rw-r--r-- | src/ir.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/ir.cpp b/src/ir.cpp index 30ad9d0fa..481114d80 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -9991,6 +9991,7 @@ void ir_setup_type_info_data(irProcedure *proc) { // NOTE(bill): Setup type_info irValue *tag_offset_ptr = ir_emit_struct_ep(proc, tag, 1); irValue *tag_type_ptr = ir_emit_struct_ep(proc, tag, 2); irValue *custom_align_ptr = ir_emit_struct_ep(proc, tag, 3); + irValue *no_nil_ptr = ir_emit_struct_ep(proc, tag, 4); isize variant_count = gb_max(0, t->Union.variants.count); irValue *memory_types = ir_type_info_member_types_offset(proc, variant_count); @@ -10018,6 +10019,8 @@ void ir_setup_type_info_data(irProcedure *proc) { // NOTE(bill): Setup type_info irValue *is_custom_align = ir_const_bool(t->Union.custom_align != 0); ir_emit_store(proc, custom_align_ptr, is_custom_align); + + ir_emit_store(proc, no_nil_ptr, ir_const_bool(t->Union.no_nil)); } break; |