optimization for abstract classes; there was a misunderstanding, and
it turns out that there are no kexts which rely on this.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@131489
91177308-0d34-0410-b5e6-
96231b3b80d8
void CodeGenModule::EmitCXXConstructors(const CXXConstructorDecl *D) {
// The constructor used for constructing this as a complete class;
// constucts the virtual bases, then calls the base constructor.
- if (!D->getParent()->isAbstract() || getLangOptions().AppleKext) {
+ if (!D->getParent()->isAbstract()) {
// We don't need to emit the complete ctor if the class is abstract.
- // But kexts somehow manage to violate this assumption.
EmitGlobal(GlobalDecl(D, Ctor_Complete));
}
+++ /dev/null
-// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fapple-kext -emit-llvm -o - %s | FileCheck %s
-
-// rdar://problem/9429976
-namespace test0 {
- struct A {
- A();
- virtual ~A();
- virtual void foo() = 0;
- };
-
- // CHECK: define void @_ZN5test01AC1Ev(
- // CHECK: define void @_ZN5test01AC2Ev(
- A::A() {}
-
- // CHECK: define void @_ZN5test01AD0Ev(
- // CHECK: define void @_ZN5test01AD1Ev(
- // CHECK: define void @_ZN5test01AD2Ev(
- A::~A() {}
-}
-