diff options
Diffstat (limited to 'test/CodeGenCXX/inline-functions.cpp')
-rw-r--r-- | test/CodeGenCXX/inline-functions.cpp | 50 |
1 files changed, 31 insertions, 19 deletions
diff --git a/test/CodeGenCXX/inline-functions.cpp b/test/CodeGenCXX/inline-functions.cpp index 20da1f6..f1169f9 100644 --- a/test/CodeGenCXX/inline-functions.cpp +++ b/test/CodeGenCXX/inline-functions.cpp @@ -1,12 +1,13 @@ // RUN: %clang_cc1 %s -std=c++11 -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s --check-prefix=CHECK --check-prefix=NORMAL -// RUN: %clang_cc1 %s -std=c++11 -fms-compatibility -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s --check-prefix=CHECK --check-prefix=MSVCCOMPAT +// RUN: %clang_cc1 %s -std=c++11 -fms-compatibility -triple=x86_64-pc-win32 -emit-llvm -o - | FileCheck %s --check-prefix=CHECK --check-prefix=MSVCCOMPAT // CHECK: ; ModuleID struct A { inline void f(); }; -// CHECK-NOT: define void @_ZN1A1fEv +// NORMAL-NOT: define void @_ZN1A1fEv +// MSVCCOMPAT-NOT: define void @"\01?f@A@@QEAAXXZ" void A::f() { } template<typename> struct B { }; @@ -15,18 +16,21 @@ template<> struct B<char> { inline void f(); }; -// CHECK-NOT: _ZN1BIcE1fEv +// NORMAL-NOT: _ZN1BIcE1fEv +// MSVCCOMPAT-NOT: @"\01?f@?$B@D@@QEAAXXZ" void B<char>::f() { } // We need a final CHECK line here. -// CHECK-LABEL: define void @_Z1fv +// NORMAL-LABEL: define void @_Z1fv +// MSVCCOMPAT-LABEL: define void @"\01?f@@YAXXZ" void f() { } // <rdar://problem/8740363> inline void f1(int); -// CHECK-LABEL: define linkonce_odr void @_Z2f1i +// NORMAL-LABEL: define linkonce_odr void @_Z2f1i +// MSVCCOMPAT-LABEL: define linkonce_odr void @"\01?f1@@YAXH@Z" void f1(int) { } void test_f1() { f1(17); } @@ -39,7 +43,8 @@ namespace test1 { void g() {} }; - // CHECK-LABEL: define linkonce_odr void @_ZN5test11C4funcEv( + // NORMAL-LABEL: define linkonce_odr void @_ZN5test11C4funcEv( + // MSVCCOMPAT-LABEL: define linkonce_odr void @"\01?func@C@test1@@QEAAXXZ"( class C { public: @@ -66,59 +71,65 @@ namespace test2 { A a; f(a); } - // CHECK-LABEL: define linkonce_odr void @_ZN5test21fERKNS_1AE + // NORMAL-LABEL: define linkonce_odr void @_ZN5test21fERKNS_1AE + // MSVCCOMPAT-LABEL: define linkonce_odr void @"\01?f@test2@@YAXAEBUA@1@@Z" } -// MSVCCOMPAT-LABEL: define weak_odr void @_Z17ExternAndInlineFnv // NORMAL-NOT: _Z17ExternAndInlineFnv +// MSVCCOMPAT-LABEL: define weak_odr void @"\01?ExternAndInlineFn@@YAXXZ" extern inline void ExternAndInlineFn() {} -// MSVCCOMPAT-LABEL: define weak_odr void @_Z18InlineThenExternFnv // NORMAL-NOT: _Z18InlineThenExternFnv +// MSVCCOMPAT-LABEL: define weak_odr void @"\01?InlineThenExternFn@@YAXXZ" inline void InlineThenExternFn() {} extern void InlineThenExternFn(); -// CHECK-LABEL: define void @_Z18ExternThenInlineFnv +// NORMAL-LABEL: define void @_Z18ExternThenInlineFnv +// MSVCCOMPAT-LABEL: define void @"\01?ExternThenInlineFn@@YAXXZ" extern void ExternThenInlineFn() {} -// MSVCCOMPAT-LABEL: define weak_odr void @_Z25ExternThenInlineThenDefFnv // NORMAL-NOT: _Z25ExternThenInlineThenDefFnv +// MSVCCOMPAT-LABEL: define weak_odr void @"\01?ExternThenInlineThenDefFn@@YAXXZ" extern void ExternThenInlineThenDefFn(); inline void ExternThenInlineThenDefFn(); void ExternThenInlineThenDefFn() {} -// MSVCCOMPAT-LABEL: define weak_odr void @_Z25InlineThenExternThenDefFnv // NORMAL-NOT: _Z25InlineThenExternThenDefFnv +// MSVCCOMPAT-LABEL: define weak_odr void @"\01?InlineThenExternThenDefFn@@YAXXZ" inline void InlineThenExternThenDefFn(); extern void InlineThenExternThenDefFn(); void InlineThenExternThenDefFn() {} -// MSVCCOMPAT-LABEL: define weak_odr i32 @_Z20ExternAndConstexprFnv // NORMAL-NOT: _Z17ExternAndConstexprFnv +// MSVCCOMPAT-LABEL: define weak_odr i32 @"\01?ExternAndConstexprFn@@YAHXZ" extern constexpr int ExternAndConstexprFn() { return 0; } -// CHECK-NOT: _Z11ConstexprFnv +// NORMAL-NOT: _Z11ConstexprFnv +// MSVCCOMPAT-NOT: @"\01?ConstexprFn@@YAHXZ" constexpr int ConstexprFn() { return 0; } template <typename T> extern inline void ExternInlineOnPrimaryTemplate(T); -// CHECK-LABEL: define void @_Z29ExternInlineOnPrimaryTemplateIiEvT_ +// NORMAL-LABEL: define void @_Z29ExternInlineOnPrimaryTemplateIiEvT_ +// MSVCCOMPAT-LABEL: define void @"\01??$ExternInlineOnPrimaryTemplate@H@@YAXH@Z" template <> void ExternInlineOnPrimaryTemplate(int) {} template <typename T> extern inline void ExternInlineOnPrimaryTemplateAndSpecialization(T); -// MSVCCOMPAT-LABEL: define weak_odr void @_Z46ExternInlineOnPrimaryTemplateAndSpecializationIiEvT_ // NORMAL-NOT: _Z46ExternInlineOnPrimaryTemplateAndSpecializationIiEvT_ +// MSVCCOMPAT-LABEL: define weak_odr void @"\01??$ExternInlineOnPrimaryTemplateAndSpecialization@H@@YAXH@Z" template <> extern inline void ExternInlineOnPrimaryTemplateAndSpecialization(int) {} struct TypeWithInlineMethods { - // CHECK-NOT: _ZN21TypeWithInlineMethods9StaticFunEv + // NORMAL-NOT: _ZN21TypeWithInlineMethods9StaticFunEv + // MSVCCOMPAT-NOT: @"\01?StaticFun@TypeWithInlineMethods@@SAXXZ" static void StaticFun() {} - // CHECK-NOT: _ZN21TypeWithInlineMethods12NonStaticFunEv + // NORMAL-NOT: _ZN21TypeWithInlineMethods12NonStaticFunEv + // MSVCCOMPAT-NOT: @"\01?NonStaticFun@TypeWithInlineMethods@@QEAAXXZ" void NonStaticFun() { StaticFun(); } }; @@ -134,5 +145,6 @@ struct S { }; __attribute__((used)) inline S<int> Foo() { return S<int>(); } -// CHECK-LABEL: define linkonce_odr void @_ZN7PR229593FooEv( +// NORMAL-LABEL: define linkonce_odr void @_ZN7PR229593FooEv( +// MSVCCOMPAT-LABEL: define linkonce_odr i8 @"\01?Foo@PR22959@@YA?AU?$S@H@1@XZ"( } |