aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp26
1 files changed, 4 insertions, 22 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 6a4046d8d..90716dde0 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -1827,30 +1827,12 @@ gb_internal lbProcedure *lb_create_main_procedure(lbModule *m, lbProcedure *star
args[0] = lb_addr_load(p, all_tests_slice);
lbValue result = lb_emit_call(p, runner, args);
- lbBlock *block_success = lb_create_block(p, "success");
- lbBlock *block_failure = lb_create_block(p, "failure");
-
- lbValue result_success = lb_emit_comp(p, Token_CmpEq, result, lb_const_bool(m, t_bool, true));
- lb_emit_if(p, result_success, block_success, block_failure);
-
lbValue exit_runner = lb_find_package_value(m, str_lit("os"), str_lit("exit"));
-
- lb_start_block(p, block_success);
- {
- auto exit_args = array_make<lbValue>(temporary_allocator(), 1);
- exit_args[0] = lb_const_int(m, t_int, 0);
- lb_emit_call(p, exit_runner, exit_args);
- }
-
- lb_start_block(p, block_failure);
- {
- auto exit_args = array_make<lbValue>(temporary_allocator(), 1);
- exit_args[0] = lb_const_int(m, t_int, 1);
- lb_emit_call(p, exit_runner, exit_args);
- }
+ auto exit_args = array_make<lbValue>(temporary_allocator(), 1);
+ exit_args[0] = lb_emit_select(p, result, lb_const_int(m, t_int, 0), lb_const_int(m, t_int, 1));
+ lb_emit_call(p, exit_runner, exit_args, ProcInlining_none);
} else {
- if (m->info->entry_point != nullptr) {
- lbValue entry_point = lb_find_procedure_value_from_entity(m, m->info->entry_point);
+ if (m->info->entry_point != nullptr) { lbValue entry_point = lb_find_procedure_value_from_entity(m, m->info->entry_point);
lb_emit_call(p, entry_point, {}, ProcInlining_no_inline);
}