diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-10-18 20:54:37 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-10-18 20:54:37 +0000 |
commit | a6fdfaa595ec41ed4800d447b8669c69fb696ba8 (patch) | |
tree | 2db6afbb352ab1b5ad43ca0c568ffc3711c1d907 | |
parent | 99094151811bbbabadc2f9991d270b54c76083d6 (diff) | |
download | bcm5719-llvm-a6fdfaa595ec41ed4800d447b8669c69fb696ba8.tar.gz bcm5719-llvm-a6fdfaa595ec41ed4800d447b8669c69fb696ba8.zip |
Fix AST pretty-printing for C++ new expressions with placement arguments with default values.
Based on patch by Grzegorz Jablonski.
llvm-svn: 166226
-rw-r--r-- | clang/lib/AST/StmtPrinter.cpp | 4 | ||||
-rw-r--r-- | clang/test/SemaCXX/ast-print.cpp | 11 |
2 files changed, 14 insertions, 1 deletions
diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp index 892442ea3bf..d7392af808e 100644 --- a/clang/lib/AST/StmtPrinter.cpp +++ b/clang/lib/AST/StmtPrinter.cpp @@ -1415,10 +1415,12 @@ void StmtPrinter::VisitCXXNewExpr(CXXNewExpr *E) { OS << "::"; OS << "new "; unsigned NumPlace = E->getNumPlacementArgs(); - if (NumPlace > 0) { + if (NumPlace > 0 && !isa<CXXDefaultArgExpr>(E->getPlacementArg(0))) { OS << "("; PrintExpr(E->getPlacementArg(0)); for (unsigned i = 1; i < NumPlace; ++i) { + if (isa<CXXDefaultArgExpr>(E->getPlacementArg(i))) + break; OS << ", "; PrintExpr(E->getPlacementArg(i)); } diff --git a/clang/test/SemaCXX/ast-print.cpp b/clang/test/SemaCXX/ast-print.cpp index 44b34aa12cf..46b99e0d610 100644 --- a/clang/test/SemaCXX/ast-print.cpp +++ b/clang/test/SemaCXX/ast-print.cpp @@ -30,3 +30,14 @@ void f() switch (int a = 1) { } } +// CHECK: new (1) int; +void *operator new (typeof(sizeof(1)), int, int = 2); +void f2() { + new (1) int; +} + +// CHECK: new X; +struct X { + void *operator new (typeof(sizeof(1)), int = 2); +}; +void f2() { new X; } |