aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_utility.cpp
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2026-01-26 18:23:29 +0000
committergingerBill <gingerBill@users.noreply.github.com>2026-01-26 18:23:29 +0000
commit3586bda6ae80b1dca1984ae54b023d5fec69067e (patch)
treed1b8bba874b42fae91e12f095f10ad017bef9b34 /src/llvm_backend_utility.cpp
parent467954bc7baed8061348b6dc5ddda1a742ea69f4 (diff)
Use `context.assertion_failure_proc` with type assertions when the `context` is available, otherwise use a trivial trap.
Diffstat (limited to 'src/llvm_backend_utility.cpp')
-rw-r--r--src/llvm_backend_utility.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/llvm_backend_utility.cpp b/src/llvm_backend_utility.cpp
index 43cac70c1..929239486 100644
--- a/src/llvm_backend_utility.cpp
+++ b/src/llvm_backend_utility.cpp
@@ -803,7 +803,12 @@ gb_internal lbValue lb_emit_union_cast(lbProcedure *p, lbValue value, Type *type
args[5] = lb_typeid(m, dst_type);
args[6] = lb_emit_conv(p, value_, t_rawptr);
}
- lb_emit_runtime_call(p, "type_assertion_check2", args);
+
+ char const *name = "type_assertion_check2_contextless";
+ if (p->context_stack.count > 0) {
+ name = "type_assertion_check2_with_context";
+ }
+ lb_emit_runtime_call(p, name, args);
}
return lb_emit_load(p, lb_emit_struct_ep(p, v.addr, 0));
@@ -877,7 +882,11 @@ gb_internal lbAddr lb_emit_any_cast_addr(lbProcedure *p, lbValue value, Type *ty
args[5] = dst_typeid;
args[6] = lb_emit_struct_ev(p, value, 0);
}
- lb_emit_runtime_call(p, "type_assertion_check2", args);
+ char const *name = "type_assertion_check2_contextless";
+ if (p->context_stack.count > 0) {
+ name = "type_assertion_check2_with_context";
+ }
+ lb_emit_runtime_call(p, name, args);
}
return lb_addr(lb_emit_struct_ep(p, v.addr, 0));