error.c (dump_type_suffix): Print the exception specs before recursing.
authorJason Merrill <jason@redhat.com>
Thu, 17 Jan 2002 12:54:36 +0000 (07:54 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Thu, 17 Jan 2002 12:54:36 +0000 (07:54 -0500)
        * error.c (dump_type_suffix): Print the exception specs before
        recursing.
        (dump_function_decl): Here, too.

        * cp-tree.h (TMPL_PARMS_DEPTH): Cast to signed HOST_WIDE_INT.

From-SVN: r48947

gcc/cp/ChangeLog
gcc/cp/cp-tree.h
gcc/cp/error.c
gcc/testsuite/g++.dg/other/error3.C [new file with mode: 0644]

index 3764b85c63b8cc33be5b942cf8448fd1152c9bf3..793af6d5367ef697c22f9329b1e2d49c5800bddd 100644 (file)
@@ -1,3 +1,11 @@
+2002-01-16  Jason Merrill  <jason@redhat.com>
+
+       * error.c (dump_type_suffix): Print the exception specs before
+       recursing.
+       (dump_function_decl): Here, too.
+
+       * cp-tree.h (TMPL_PARMS_DEPTH): Cast to signed HOST_WIDE_INT.
+
 2002-01-10  Ira Ruben  <ira@apple.com>
 
        * decl.c (start_method): Handle attrlist.
index c157466a5726dd38bc086fdf4660ffcddfd0fc21..88b4cdbfd5065add19066313d8d1f073182eeb39 100644 (file)
@@ -2286,7 +2286,7 @@ struct lang_decl
 
 /* The number of levels of template parameters given by NODE.  */
 #define TMPL_PARMS_DEPTH(NODE) \
-  (TREE_INT_CST_LOW (TREE_PURPOSE (NODE)))
+  ((HOST_WIDE_INT) TREE_INT_CST_LOW (TREE_PURPOSE (NODE)))
 
 /* The TEMPLATE_DECL instantiated or specialized by NODE.  This
    TEMPLATE_DECL will be the immediate parent, not the most general
index 21a171f874d15c25b7a662ffd9451b39b3be727b..de6221507ebf0b52545f46a7c590330f7b6cc7e7 100644 (file)
@@ -737,8 +737,8 @@ dump_type_suffix (t, flags)
        if (TREE_CODE (t) == METHOD_TYPE)
          dump_qualifiers
            (TREE_TYPE (TREE_VALUE (TYPE_ARG_TYPES (t))), before);
-       dump_type_suffix (TREE_TYPE (t), flags);
        dump_exception_spec (TYPE_RAISES_EXCEPTIONS (t), flags);
+       dump_type_suffix (TREE_TYPE (t), flags);
        break;
       }
 
@@ -1141,15 +1141,15 @@ dump_function_decl (t, flags)
     {
       dump_parameters (parmtypes, flags);
 
-      if (show_return)
-       dump_type_suffix (TREE_TYPE (fntype), flags);
-
       if (TREE_CODE (fntype) == METHOD_TYPE)
        dump_qualifiers (TREE_TYPE (TREE_VALUE (TYPE_ARG_TYPES (fntype))),
                         before);
 
       if (flags & TFF_EXCEPTION_SPECIFICATION)
        dump_exception_spec (TYPE_RAISES_EXCEPTIONS (fntype), flags);
+
+      if (show_return)
+       dump_type_suffix (TREE_TYPE (fntype), flags);
     }
 
   /* If T is a template instantiation, dump the parameter binding.  */
diff --git a/gcc/testsuite/g++.dg/other/error3.C b/gcc/testsuite/g++.dg/other/error3.C
new file mode 100644 (file)
index 0000000..bd5d701
--- /dev/null
@@ -0,0 +1,5 @@
+// Test for proper error message formatting; the throw() should go inside
+// the parens, as below.
+
+void (*g() throw())();         // { dg-error "g\\(\\) throw" "" }
+void (*g())();                 // { dg-error "" "" }