diff options
| author | gingerBill <bill@gingerbill.org> | 2022-02-05 16:11:48 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2022-02-05 16:11:48 +0000 |
| commit | 445ca705210999e106b6aeb265cfb2979cbd857c (patch) | |
| tree | e84522945e73ae60f11976d017ac9722600ef017 /src/llvm_backend_expr.cpp | |
| parent | c6ab8f82c88f7d5470fa2fb0459d09ba8a67a287 (diff) | |
Correct implicit union cast
Diffstat (limited to 'src/llvm_backend_expr.cpp')
| -rw-r--r-- | src/llvm_backend_expr.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp index ea031ee56..715b7df78 100644 --- a/src/llvm_backend_expr.cpp +++ b/src/llvm_backend_expr.cpp @@ -1834,6 +1834,15 @@ lbValue lb_emit_conv(lbProcedure *p, lbValue value, Type *t) { return lb_addr_load(p, parent); } } + if (dst->Union.variants.count == 1) { + Type *vt = dst->Union.variants[0]; + if (internal_check_is_assignable_to(src, vt)) { + value = lb_emit_conv(p, value, vt); + lbAddr parent = lb_add_local_generated(p, t, true); + lb_emit_store_union_variant(p, parent.addr, value, vt); + return lb_addr_load(p, parent); + } + } } // NOTE(bill): This has to be done before 'Pointer <-> Pointer' as it's |