diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-05-26 07:10:06 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-05-26 07:10:06 +0000 |
| commit | 1b30b3c9fa130473df85c4d548e5de9ccd7e459c (patch) | |
| tree | cd044bfe6859941f5f102dcb78b511c535fc9fb6 /clang/lib/Sema/TreeTransform.h | |
| parent | 870e5759e7af8eefafa93332a279e1ef25c27eed (diff) | |
| download | bcm5719-llvm-1b30b3c9fa130473df85c4d548e5de9ccd7e459c.tar.gz bcm5719-llvm-1b30b3c9fa130473df85c4d548e5de9ccd7e459c.zip | |
When transforming a C++ "new" expression's constructor arguments, drop
any arguments that are default-argument expressions. The can show up
when we have a new expression whose constructor arguments are not
type-dependent and whose allocated type is not dependent and has a
constructor with default arguments. Fixes PR7202.
llvm-svn: 104690
Diffstat (limited to 'clang/lib/Sema/TreeTransform.h')
| -rw-r--r-- | clang/lib/Sema/TreeTransform.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index 7ef23290d8a..9b8031b7fdf 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -5210,6 +5210,9 @@ TreeTransform<Derived>::TransformCXXNewExpr(CXXNewExpr *E) { // transform the constructor arguments (if any). ASTOwningVector<&ActionBase::DeleteExpr> ConstructorArgs(SemaRef); for (unsigned I = 0, N = E->getNumConstructorArgs(); I != N; ++I) { + if (getDerived().DropCallArgument(E->getConstructorArg(I))) + break; + OwningExprResult Arg = getDerived().TransformExpr(E->getConstructorArg(I)); if (Arg.isInvalid()) return SemaRef.ExprError(); |

