llvm-project/clang/test/CodeGenCXX/builtins-eh-wasm.cpp
Matt Arsenault 4e26801ea9 clang: Add requires webassembly to a test
Prior to 6ab7e52dd80dc2ece12cc7f1924a71f1a58e2a8a the test got
away with out it because the error was not triggered if the
backend didn't run.
2025-07-03 08:15:42 +09:00

22 lines
700 B
C++

// REQUIRES: webassembly-registered-target
// RUN: %clang_cc1 -triple wasm32-unknown-unknown -fexceptions -fcxx-exceptions -target-feature +reference-types -target-feature +exception-handling -target-feature +multivalue -mllvm -wasm-enable-eh -exception-model=wasm -emit-llvm -o - %s | FileCheck %s
// Check if __builtin_wasm_throw and __builtin_wasm_rethrow are correctly
// invoked when placed in try-catch.
void throw_in_try(void *obj) {
try {
__builtin_wasm_throw(0, obj);
} catch (...) {
}
// CHECK: invoke void @llvm.wasm.throw(i32 0, ptr %{{.*}})
}
void rethrow_in_try() {
try {
__builtin_wasm_rethrow();
} catch (...) {
}
// CHECK: invoke void @llvm.wasm.rethrow()
}