OSDN Git Service

PR c++/30854
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 12 Jul 2007 12:05:39 +0000 (12:05 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 12 Jul 2007 12:05:39 +0000 (12:05 +0000)
* error.c (dump_expr) <case AGGR_INIT_EXPR>: Pass true as last
argument to dump_aggr_init_expr_args instead of false.

* g++.dg/parse/error30.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@126582 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/error.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/error30.C [new file with mode: 0644]

index 8165176..61c614f 100644 (file)
@@ -1,3 +1,9 @@
+2007-07-12  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/30854
+       * error.c (dump_expr) <case AGGR_INIT_EXPR>: Pass true as last
+       argument to dump_aggr_init_expr_args instead of false.
+
 2007-07-11  Douglas Gregor  <doug.gregor@gmail.com>
 
        * typeck.c (comptypes): When USE_CANONICAL_TYPES, use the
index 512944b..7e4828c 100644 (file)
@@ -1520,7 +1520,7 @@ dump_expr (tree t, int flags)
        else
          dump_expr (AGGR_INIT_EXPR_FN (t), 0);
       }
-      dump_aggr_init_expr_args (t, flags, false);
+      dump_aggr_init_expr_args (t, flags, true);
       break;
 
     case CALL_EXPR:
index 9f4a390..22fc219 100644 (file)
@@ -1,3 +1,8 @@
+2007-07-12  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/30854
+       * g++.dg/parse/error30.C: New test.
+
 2007-07-12  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
 
        PR fortran/29804
diff --git a/gcc/testsuite/g++.dg/parse/error30.C b/gcc/testsuite/g++.dg/parse/error30.C
new file mode 100644 (file)
index 0000000..734a255
--- /dev/null
@@ -0,0 +1,11 @@
+// PR c++/30854
+// { dg-do compile }
+
+struct A
+{
+  A();
+  A(int);
+};
+
+A a = -A();    // { dg-error "no match for.*operator-.*in.*-A\\(\\)" }
+A b = -A(5);   // { dg-error "no match for.*operator-.*in.*-A\\(5\\)" }