diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-07-07 23:37:33 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-07-07 23:37:33 +0000 |
commit | e182370eda7c54ee2d02070e19993397b562f5a0 (patch) | |
tree | 2d63e0189d4d06eef9d14d758eb3ae23827cea6e /clang/lib/CodeGen/CGExprCXX.cpp | |
parent | 86851b8a7abd591d09180cce964f4246bfb2d376 (diff) | |
download | bcm5719-llvm-e182370eda7c54ee2d02070e19993397b562f5a0.tar.gz bcm5719-llvm-e182370eda7c54ee2d02070e19993397b562f5a0.zip |
Revert r107828 and r107827, the fix for PR7556, which seems to be
breaking bootstrap on Linux.
llvm-svn: 107837
Diffstat (limited to 'clang/lib/CodeGen/CGExprCXX.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGExprCXX.cpp | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/clang/lib/CodeGen/CGExprCXX.cpp b/clang/lib/CodeGen/CGExprCXX.cpp index ea1753bbc17..f2e6a11292b 100644 --- a/clang/lib/CodeGen/CGExprCXX.cpp +++ b/clang/lib/CodeGen/CGExprCXX.cpp @@ -572,18 +572,9 @@ static void EmitNewInitializer(CodeGenFunction &CGF, const CXXNewExpr *E, } if (CXXConstructorDecl *Ctor = E->getConstructor()) { - // Per C++ [expr.new]p15, if we have an initializer, then we're performing - // direct initialization. C++ [dcl.init]p5 requires that we - // zero-initialize storage if there are no user-declared constructors. - if (E->hasInitializer() && - !Ctor->getParent()->hasUserDeclaredConstructor() && - !Ctor->getParent()->isEmpty()) - CGF.EmitNullInitialization(NewPtr, E->getAllocatedType()); - - if (!Ctor->isTrivial()) - CGF.EmitCXXConstructorCall(Ctor, Ctor_Complete, /*ForVirtualBase=*/false, - NewPtr, E->constructor_arg_begin(), - E->constructor_arg_end()); + CGF.EmitCXXConstructorCall(Ctor, Ctor_Complete, /*ForVirtualBase=*/false, + NewPtr, E->constructor_arg_begin(), + E->constructor_arg_end()); return; } |