From 110eaaceddcec790f7e6a5e3bf1261c9aa1e73ab Mon Sep 17 00:00:00 2001 From: dim Date: Mon, 2 May 2011 19:39:53 +0000 Subject: Vendor import of clang trunk r130700: http://llvm.org/svn/llvm-project/cfe/trunk@130700 --- test/CodeGenCXX/cxx0x-delegating-ctors.cpp | 48 ++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 test/CodeGenCXX/cxx0x-delegating-ctors.cpp (limited to 'test/CodeGenCXX/cxx0x-delegating-ctors.cpp') diff --git a/test/CodeGenCXX/cxx0x-delegating-ctors.cpp b/test/CodeGenCXX/cxx0x-delegating-ctors.cpp new file mode 100644 index 0000000..5b432c7 --- /dev/null +++ b/test/CodeGenCXX/cxx0x-delegating-ctors.cpp @@ -0,0 +1,48 @@ +// RUN: %clang_cc1 -emit-llvm -fexceptions -fcxx-exceptions -std=c++0x -o - %s | FileCheck %s + +struct non_trivial { + non_trivial(); + ~non_trivial(); +}; +non_trivial::non_trivial() {} +non_trivial::~non_trivial() {} + +// We use a virtual base to ensure that the constructor +// delegation optimization (complete->base) can't be +// performed. +struct delegator { + non_trivial n; + delegator(); + delegator(int); + delegator(char); + delegator(bool); +}; + +delegator::delegator() { + throw 0; +} + +// CHECK: define void @_ZN9delegatorC1Ei +// CHECK: call void @_ZN9delegatorC1Ev +// CHECK-NOT: lpad +// CHECK: ret +// CHECK-NOT: lpad +// CHECK: define void @_ZN9delegatorC2Ei +// CHECK: call void @_ZN9delegatorC2Ev +// CHECK-NOT: lpad +// CHECK: ret +// CHECK-NOT: lpad +delegator::delegator(int) + : delegator() +{} + +delegator::delegator(bool) +{} + +// CHECK: define void @_ZN9delegatorC2Ec +// CHECK: call void @_ZN9delegatorC2Eb +// CHECK: call void @__cxa_throw +delegator::delegator(char) + : delegator(true) { + throw 0; +} -- cgit v1.1