]> granicus.if.org Git - clang/commitdiff
Fix AST pretty-printing for C++ new expressions with placement arguments with default...
authorEli Friedman <eli.friedman@gmail.com>
Thu, 18 Oct 2012 20:54:37 +0000 (20:54 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Thu, 18 Oct 2012 20:54:37 +0000 (20:54 +0000)
Based on patch by Grzegorz Jablonski.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@166226 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/StmtPrinter.cpp
test/SemaCXX/ast-print.cpp

index 892442ea3bff9475e2a2f73e4e2804e74b88ad86..d7392af808ea26a69e2f9d852ac1e477934ea2de 100644 (file)
@@ -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));
     }
index 44b34aa12cfa9e82c7ad0b7ab3cb2ac9896734e2..46b99e0d6100530f497134620e1f0cd42ce0c70a 100644 (file)
@@ -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; }