diff options
author | dim <dim@FreeBSD.org> | 2013-04-08 18:45:10 +0000 |
---|---|---|
committer | dim <dim@FreeBSD.org> | 2013-04-08 18:45:10 +0000 |
commit | c72c57c9e9b69944e3e009cd5e209634839581d3 (patch) | |
tree | 4fc2f184c499d106f29a386c452b49e5197bf63d /test/CodeGenCXX/member-functions.cpp | |
parent | 5b20025c30d23d521e12c1f33ec8fa6b821952cd (diff) | |
download | FreeBSD-src-c72c57c9e9b69944e3e009cd5e209634839581d3.zip FreeBSD-src-c72c57c9e9b69944e3e009cd5e209634839581d3.tar.gz |
Vendor import of clang trunk r178860:
http://llvm.org/svn/llvm-project/cfe/trunk@178860
Diffstat (limited to 'test/CodeGenCXX/member-functions.cpp')
-rw-r--r-- | test/CodeGenCXX/member-functions.cpp | 63 |
1 files changed, 41 insertions, 22 deletions
diff --git a/test/CodeGenCXX/member-functions.cpp b/test/CodeGenCXX/member-functions.cpp index 1310eb0..75b354c 100644 --- a/test/CodeGenCXX/member-functions.cpp +++ b/test/CodeGenCXX/member-functions.cpp @@ -1,66 +1,85 @@ -// RUN: %clang_cc1 -emit-llvm %s -triple x86_64-apple-darwin9 -o %t +// RUN: %clang_cc1 -emit-llvm -triple x86_64-apple-darwin9 -o - %s | FileCheck %s + struct C { void f(); void g(int, ...); }; -// RUN: grep "define void @_ZN1C1fEv" %t | count 1 +// CHECK: define void @_ZN1C1fEv void C::f() { } +// CHECK: define void @_Z5test1v void test1() { C c; - -// RUN: grep "call void @_ZN1C1fEv" %t | count 1 + + // CHECK: call void @_ZN1C1fEv c.f(); - -// RUN: grep "call void (.struct.C\*, i32, ...)\* @_ZN1C1gEiz" %t | count 1 + + // CHECK: call void (%struct.C*, i32, ...)* @_ZN1C1gEiz c.g(1, 2, 3); } struct S { - // RUN: grep "define linkonce_odr void @_ZN1SC1Ev.*unnamed_addr" %t inline S() { } - // RUN: grep "define linkonce_odr void @_ZN1SC1Ev.*unnamed_addr" %t inline ~S() { } - - - // RUN: grep "define linkonce_odr void @_ZN1S9f_inline1Ev" %t + void f_inline1() { } - // RUN: grep "define linkonce_odr void @_ZN1S9f_inline2Ev" %t inline void f_inline2() { } - - // RUN: grep "define linkonce_odr void @_ZN1S1gEv" %t + static void g() { } - static void f(); - // RUN: grep "define linkonce_odr void @_ZN1S1vEv.*unnamed_addr" %t virtual void v() {} }; -// RUN: grep "define void @_ZN1S1fEv" %t +// CHECK: define void @_ZN1S1fEv void S::f() { } void test2() { S s; - + s.f_inline1(); s.f_inline2(); - + S::g(); - } +// S::S() +// CHECK: define linkonce_odr void @_ZN1SC1Ev{{.*}} unnamed_addr + +// S::f_inline1() +// CHECK: define linkonce_odr void @_ZN1S9f_inline1Ev + +// S::f_inline2() +// CHECK: define linkonce_odr void @_ZN1S9f_inline2Ev + +// S::g() +// CHECK: define linkonce_odr void @_ZN1S1gEv + +// S::~S() +// CHECK: define linkonce_odr void @_ZN1SD1Ev{{.*}} unnamed_addr + struct T { T operator+(const T&); }; +// CHECK: define void @_Z5test3v void test3() { T t1, t2; - - // RUN: grep "call void @_ZN1TplERKS_" %t + + // CHECK: call void @_ZN1TplERKS_ T result = t1 + t2; } + +// S::~S() +// CHECK: define linkonce_odr void @_ZN1SD2Ev{{.*}} unnamed_addr + +// S::S() +// CHECK: define linkonce_odr void @_ZN1SC2Ev{{.*}} unnamed_addr + +// S::v() +// CHECK: define linkonce_odr void @_ZN1S1vEv{{.*}}unnamed_addr + |