]> granicus.if.org Git - clang/commitdiff
[Objective-C++ IRGen] do not generate .cxx_construct
authorFariborz Jahanian <fjahanian@apple.com>
Wed, 12 Nov 2014 22:37:43 +0000 (22:37 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Wed, 12 Nov 2014 22:37:43 +0000 (22:37 +0000)
for class that contains trivially-constructible struct ivar.
rdar://18950072

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@221823 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CodeGenModule.cpp
test/CodeGenObjCXX/arc-cxx11-member-init.mm

index 17b0a4b62845cff50a4f8d1edb9502eeceef13c7..fe565523fd9cd5d1a4dcb92b07f0a445812ca8df 100644 (file)
@@ -3005,6 +3005,19 @@ static bool needsDestructMethod(ObjCImplementationDecl *impl) {
   return false;
 }
 
+static bool AllTrivialInitializers(CodeGenModule &CGM,
+                                   ObjCImplementationDecl *D) {
+  CodeGenFunction CGF(CGM);
+  for (ObjCImplementationDecl::init_iterator B = D->init_begin(),
+       E = D->init_end(); B != E; ++B) {
+    CXXCtorInitializer *CtorInitExp = *B;
+    Expr *Init = CtorInitExp->getInit();
+    if (!CGF.isTrivialInitializer(Init))
+      return false;
+  }
+  return true;
+}
+
 /// EmitObjCIvarInitializations - Emit information for ivar initialization
 /// for an implementation.
 void CodeGenModule::EmitObjCIvarInitializations(ObjCImplementationDecl *D) {
@@ -3025,7 +3038,8 @@ void CodeGenModule::EmitObjCIvarInitializations(ObjCImplementationDecl *D) {
 
   // If the implementation doesn't have any ivar initializers, we don't need
   // a .cxx_construct.
-  if (D->getNumIvarInitializers() == 0)
+  if (D->getNumIvarInitializers() == 0 ||
+      AllTrivialInitializers(*this, D))
     return;
   
   IdentifierInfo *II = &getContext().Idents.get(".cxx_construct");
index 85fa5f49c0f7ed042b389ffb0a2bbf4f79fc77af..9c673cfbebcd473fb17390bdd978875bc202255f 100644 (file)
@@ -30,3 +30,16 @@ class XClipboardDataSet
 // CHECK: [[THREE:%.*]] = bitcast i8* [[CALL]] to [[T:%.*]]*
 // CHECK: store [[T]]* [[THREE]], [[T]]** [[mClipData]], align 8
 
+// rdar://18950072
+struct Butt { };
+
+__attribute__((objc_root_class))
+@interface Foo {
+  Butt x;
+  Butt y;
+  Butt z;
+}
+@end
+@implementation Foo
+@end
+// CHECK-NOTE: define internal i8* @"\01-[Foo .cxx_construct