aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_utility.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-08-15 10:27:57 +0100
committergingerBill <bill@gingerbill.org>2022-08-15 10:27:57 +0100
commit5a9422b6bcda8ed7fe3f0e91db916764662397e5 (patch)
tree1c90a488b92b9185182f8f6a0fd1e6b05cf4f24c /src/llvm_backend_utility.cpp
parent0c8d59dd203bb766c92329dd81a8ed5359c324cb (diff)
parentd30198c99af7b3346ee6305e6306c379ddd2ffa2 (diff)
Merge branch 'master' of https://github.com/odin-lang/Odin
Diffstat (limited to 'src/llvm_backend_utility.cpp')
-rw-r--r--src/llvm_backend_utility.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index 35e69a1be..8be339ca7 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -351,6 +351,10 @@ lbValue lb_emit_try_has_value(lbProcedure *p, lbValue rhs) {
lbValue lb_emit_or_else(lbProcedure *p, Ast *arg, Ast *else_expr, TypeAndValue const &tv) {
+ if (arg->state_flags & StateFlag_DirectiveWasFalse) {
+ return lb_build_expr(p, else_expr);
+ }
+
lbValue lhs = {};
lbValue rhs = {};
lb_emit_try_lhs_rhs(p, arg, tv, &lhs, &rhs);