summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGExprCXX.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-07-07 23:37:33 +0000
committerDouglas Gregor <dgregor@apple.com>2010-07-07 23:37:33 +0000
commite182370eda7c54ee2d02070e19993397b562f5a0 (patch)
tree2d63e0189d4d06eef9d14d758eb3ae23827cea6e /clang/lib/CodeGen/CGExprCXX.cpp
parent86851b8a7abd591d09180cce964f4246bfb2d376 (diff)
downloadbcm5719-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.cpp15
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;
}
OpenPOWER on IntegriCloud