diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-05-03 14:22:40 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-05-03 14:22:40 +0000 |
| commit | 604f560c397fc7ea149dcf189c4aaa23f9218c21 (patch) | |
| tree | 04c0ce9d3d210b0e0bb0f0d8411bd94c045b5596 | |
| parent | bebee842819b4b511d974f54cecd835fc8084fea (diff) | |
| download | bcm5719-llvm-604f560c397fc7ea149dcf189c4aaa23f9218c21.tar.gz bcm5719-llvm-604f560c397fc7ea149dcf189c4aaa23f9218c21.zip | |
Add test case that I forgot to check in.
llvm-svn: 102905
| -rw-r--r-- | clang/test/CodeGenCXX/empty-classes.cpp | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/empty-classes.cpp b/clang/test/CodeGenCXX/empty-classes.cpp new file mode 100644 index 00000000000..59124e3d55b --- /dev/null +++ b/clang/test/CodeGenCXX/empty-classes.cpp @@ -0,0 +1,69 @@ +// RUN: %clang_cc1 %s -I%S -triple=x86_64-apple-darwin10 -emit-llvm -O3 -o - | FileCheck %s + +struct Empty { }; + +struct A { + explicit A(unsigned a = 0xffffffff) : a(a) { } + + unsigned a; +}; + +struct B : A, Empty { + B() : A(), Empty() { } +}; + +struct C : A, Empty { + C() : A(), Empty() { } + C(const C& other) : A(0x12345678), Empty(other) { } +}; + +struct D : A, Empty { + D& operator=(const D& other) { + a = 0x87654321; + Empty::operator=(other); + + return *this; + } +}; + +#define CHECK(x) if (!(x)) return __LINE__ + +// PR7012 +// CHECK: define i32 @_Z1fv() +int f() { + B b1; + + // Check that A::a is not overwritten by the Empty default constructor. + CHECK(b1.a == 0xffffffff); + + C c1; + C c2(c1); + + // Check that A::a has the value set in the C::C copy constructor. + CHECK(c2.a == 0x12345678); + + D d1, d2; + d2 = d1; + + // Check that A::as has the value set in the D copy assignment operator. + CHECK(d2.a == 0x87654321); + + // Success! + // CHECK: ret i32 0 + return 0; +} + +#ifdef HARNESS +extern "C" void printf(const char *, ...); + +int main() { + int result = f(); + + if (result == 0) + printf("success!\n"); + else + printf("test on line %d failed!\n", result); + + return result; +} +#endif |

