MSVC 2015 renamed the symbol found by name lookup for 'std::terminate' so we cannot rely on using '?terminate@@YAXXZ'. Furthermore, it seems that 2015 will be the first release of MSVC which permits inlining a function which is noexcept into a function which isn't. This is implemented by creating a cleanup for the invoker which jumps to __std_terminate. Clang's implementation of this aspect of the MSVC scheme is slightly less efficient in this respect because we use a catch handler configured as a catch-all handler instead. llvm-svn: 236961
16 lines
814 B
C++
16 lines
814 B
C++
// RUN: %clang_cc1 -std=c++11 -emit-llvm %s -o - -triple=x86_64-pc-windows-msvc -mconstructor-aliases -fexceptions -fcxx-exceptions -fms-compatibility-version=18.00 | FileCheck -check-prefix=MSVC2013 %s
|
|
// RUN: %clang_cc1 -std=c++11 -emit-llvm %s -o - -triple=x86_64-pc-windows-msvc -mconstructor-aliases -fexceptions -fcxx-exceptions -fms-compatibility-version=19.00 | FileCheck -check-prefix=MSVC2015 %s
|
|
|
|
void may_throw();
|
|
void never_throws() noexcept(true) {
|
|
may_throw();
|
|
}
|
|
|
|
// CHECK-LABEL: define void @"\01?never_throws@@YAXXZ"
|
|
// CHECK: invoke void @"\01?may_throw@@YAXXZ"()
|
|
|
|
// CHECK: landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__CxxFrameHandler3 to i8*)
|
|
// MSVC2013: call void @"\01?terminate@@YAXXZ"()
|
|
// MSVC2015: call void @__std_terminate()
|
|
// CHECK-NEXT: unreachable
|