2009-12-25 07:33:34 +08:00
|
|
|
// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s
|
|
|
|
|
|
|
|
struct A { int x; A(int); ~A(); };
|
|
|
|
A f() { return A(0); }
|
|
|
|
// CHECK: define void @_Z1fv
|
2011-06-14 06:51:21 +08:00
|
|
|
// CHECK: call {{.*}} @_ZN1AC1Ei
|
2009-12-25 07:33:34 +08:00
|
|
|
// CHECK-NEXT: ret void
|
2010-08-23 02:27:02 +08:00
|
|
|
|
|
|
|
// Verify that we do not elide copies when constructing a base class.
|
|
|
|
namespace no_elide_base {
|
|
|
|
struct Base {
|
|
|
|
Base(const Base&);
|
|
|
|
~Base();
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Other {
|
|
|
|
operator Base() const;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Derived : public virtual Base {
|
|
|
|
Derived(const Other &O);
|
|
|
|
};
|
|
|
|
|
2011-07-10 01:41:47 +08:00
|
|
|
// CHECK: define {{.*}} @_ZN13no_elide_base7DerivedC1ERKNS_5OtherE(%"struct.no_elide_base::Derived"* %this, %"struct.no_elide_base::Other"* %O) unnamed_addr
|
2010-08-23 02:27:02 +08:00
|
|
|
Derived::Derived(const Other &O)
|
2011-06-14 06:51:21 +08:00
|
|
|
// CHECK: call {{.*}} @_ZNK13no_elide_base5OthercvNS_4BaseEEv
|
|
|
|
// CHECK: call {{.*}} @_ZN13no_elide_base4BaseC2ERKS0_
|
|
|
|
// CHECK: call {{.*}} @_ZN13no_elide_base4BaseD1Ev
|
2010-08-23 02:27:02 +08:00
|
|
|
: Base(O)
|
|
|
|
{
|
2011-06-14 06:51:21 +08:00
|
|
|
// CHECK: ret
|
2010-08-23 02:27:02 +08:00
|
|
|
}
|
|
|
|
}
|
2010-11-29 00:40:49 +08:00
|
|
|
|
|
|
|
// PR8683.
|
|
|
|
|
|
|
|
namespace PR8683 {
|
|
|
|
|
|
|
|
struct A {
|
|
|
|
A();
|
|
|
|
A(const A&);
|
|
|
|
A& operator=(const A&);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct B {
|
|
|
|
A a;
|
|
|
|
};
|
|
|
|
|
|
|
|
void f() {
|
|
|
|
// Verify that we don't mark the copy constructor in this expression as elidable.
|
2011-06-15 05:20:53 +08:00
|
|
|
// CHECK: call {{.*}} @_ZN6PR86831AC1ERKS0_
|
2010-11-29 00:40:49 +08:00
|
|
|
A a = (B().a);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|