r221823 - [Objective-C++ IRGen] do not generate .cxx_construct

David Majnemer david.majnemer at gmail.com
Wed Nov 12 16:10:52 PST 2014


On Wed, Nov 12, 2014 at 2:37 PM, Fariborz Jahanian <fjahanian at apple.com>
wrote:

> Author: fjahanian
> Date: Wed Nov 12 16:37:43 2014
> New Revision: 221823
>
> URL: http://llvm.org/viewvc/llvm-project?rev=221823&view=rev
> Log:
> [Objective-C++ IRGen] do not generate .cxx_construct
> for class that contains trivially-constructible struct ivar.
> rdar://18950072
>
> Modified:
>     cfe/trunk/lib/CodeGen/CodeGenModule.cpp
>     cfe/trunk/test/CodeGenObjCXX/arc-cxx11-member-init.mm
>
> Modified: cfe/trunk/lib/CodeGen/CodeGenModule.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CodeGenModule.cpp?rev=221823&r1=221822&r2=221823&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/CodeGen/CodeGenModule.cpp (original)
> +++ cfe/trunk/lib/CodeGen/CodeGenModule.cpp Wed Nov 12 16:37:43 2014
> @@ -3005,6 +3005,19 @@ static bool needsDestructMethod(ObjCImpl
>    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::EmitObjCIvarInitiali
>
>    // 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");
>
> Modified: cfe/trunk/test/CodeGenObjCXX/arc-cxx11-member-init.mm
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenObjCXX/arc-cxx11-member-init.mm?rev=221823&r1=221822&r2=221823&view=diff
>
> ==============================================================================
> --- cfe/trunk/test/CodeGenObjCXX/arc-cxx11-member-init.mm (original)
> +++ cfe/trunk/test/CodeGenObjCXX/arc-cxx11-member-init.mm Wed Nov 12
> 16:37:43 2014
> @@ -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))
> + at interface Foo {
> +  Butt x;
> +  Butt y;
> +  Butt z;
> +}
> + at end
> + at implementation Foo
> + at end
> +// CHECK-NOTE: define internal i8* @"\01-[Foo .cxx_construct
>

Is this supposed to be `CHECK-NOT` ?


>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20141112/23fcd1d6/attachment.html>


More information about the cfe-commits mailing list