decl.c (grokdeclarator): Use id_loc and EXPR_LOCATION in a few error messages.
authorPaolo Carlini <paolo.carlini@oracle.com>
Thu, 8 Aug 2019 22:15:40 +0000 (22:15 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Thu, 8 Aug 2019 22:15:40 +0000 (22:15 +0000)
/cp
2019-08-08  Paolo Carlini  <paolo.carlini@oracle.com>

* decl.c (grokdeclarator): Use id_loc and EXPR_LOCATION in
a few error messages.

/testsuite
2019-08-08  Paolo Carlini  <paolo.carlini@oracle.com>

* g++.dg/cpp0x/enum20.C: Test location(s) too.
* g++.dg/other/friend3.C: Likewise.
* g++.dg/parse/dtor5.C: Likewise.
* g++.dg/parse/friend7.C: Likewise.
* g++.dg/template/error22.C: Likewise.
* g++.old-deja/g++.brendan/err-msg5.C: Likewise.

From-SVN: r274220

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/enum20.C
gcc/testsuite/g++.dg/other/friend3.C
gcc/testsuite/g++.dg/parse/dtor5.C
gcc/testsuite/g++.dg/parse/friend7.C
gcc/testsuite/g++.dg/template/error22.C
gcc/testsuite/g++.old-deja/g++.brendan/err-msg5.C

index 4d78888f38ba2750d9e85c30ef1f84df694993fa..5b0bf2b62b8cd8c13f56b99e2a8bc793bc17c318 100644 (file)
@@ -1,3 +1,8 @@
+2019-08-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       * decl.c (grokdeclarator): Use id_loc and EXPR_LOCATION in
+       a few error messages.
+
 2019-08-08  Marek Polacek  <polacek@redhat.com>
 
        PR c++/87519 - bogus warning with -Wsign-conversion.
index 83f086d75aea7c390147c9284c8bdf8a5d2c3b0d..b8806e4628d92e1b0b458699497b63c153a32b29 100644 (file)
@@ -10579,7 +10579,8 @@ grokdeclarator (const cp_declarator *declarator,
                    ctype = qualifying_scope;
                    if (!MAYBE_CLASS_TYPE_P (ctype))
                      {
-                       error ("%q#T is not a class or a namespace", ctype);
+                       error_at (id_declarator->id_loc,
+                                 "%q#T is not a class or namespace", ctype);
                        ctype = NULL_TREE;
                      }
                    else if (innermost_code != cdk_function
@@ -10601,13 +10602,15 @@ grokdeclarator (const cp_declarator *declarator,
                {
                  if (innermost_code != cdk_function)
                    {
-                     error ("declaration of %qD as non-function", decl);
+                     error_at (EXPR_LOCATION (decl),
+                               "declaration of %qE as non-function", decl);
                      return error_mark_node;
                    }
                  else if (!qualifying_scope
                           && !(current_class_type && at_class_scope_p ()))
                    {
-                     error ("declaration of %qD as non-member", decl);
+                     error_at (EXPR_LOCATION (decl),
+                               "declaration of %qE as non-member", decl);
                      return error_mark_node;
                    }
 
@@ -12510,7 +12513,7 @@ grokdeclarator (const cp_declarator *declarator,
        else if (in_namespace && !friendp)
          {
            /* Something like struct S { int N::j; };  */
-           error ("invalid use of %<::%>");
+           error_at (id_loc, "invalid use of %<::%>");
            return error_mark_node;
          }
        else if (FUNC_OR_METHOD_TYPE_P (type) && unqualified_id)
@@ -12565,15 +12568,15 @@ grokdeclarator (const cp_declarator *declarator,
                if (!ctype)
                  {
                    gcc_assert (friendp);
-                   error ("expected qualified name in friend declaration "
-                          "for destructor %qD", uqname);
+                   error_at (id_loc, "expected qualified name in friend "
+                             "declaration for destructor %qD", uqname);
                    return error_mark_node;
                  }
 
                if (!check_dtor_name (ctype, TREE_OPERAND (uqname, 0)))
                  {
-                   error ("declaration of %qD as member of %qT",
-                          uqname, ctype);
+                   error_at (id_loc, "declaration of %qD as member of %qT",
+                             uqname, ctype);
                    return error_mark_node;
                  }
                 if (concept_p)
index 94b8852d7a6962fdf07624d12ee903ee629db752..6d49b6d61cb1295ca6d2919b553b8a24d772d04c 100644 (file)
@@ -1,3 +1,12 @@
+2019-08-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       * g++.dg/cpp0x/enum20.C: Test location(s) too.
+       * g++.dg/other/friend3.C: Likewise.
+       * g++.dg/parse/dtor5.C: Likewise.
+       * g++.dg/parse/friend7.C: Likewise.
+       * g++.dg/template/error22.C: Likewise.
+       * g++.old-deja/g++.brendan/err-msg5.C: Likewise.
+
 2019-08-08  Jim Wilson  <jimw@sifive.com>
 
        PR target/91229
index 8937cc7a3d319fff14515d8addd55f4c4d60fe9e..f39933ac4eadc00c184d88d80ac1b33b771bed10 100644 (file)
@@ -2,4 +2,4 @@
 // { dg-do compile { target c++11 } }
 
 enum A { };
-void A::f() { }                        // { dg-error "not a class" }
+void A::f() { }                        // { dg-error "6:.enum A. is not a class" }
index ce872e555ff87bb1ec884dbdf70765a79a9d0433..cf746062a6b3be31f0d03205a2c0b4d0392081cc 100644 (file)
@@ -4,10 +4,10 @@
 
 struct A
 {
-  friend ~A();  // { dg-error "qualified name" }
+  friend ~A();  // { dg-error "10:expected qualified name" }
 };
 
 struct B
 {
-  friend ~A();  // { dg-error "qualified name" }
+  friend ~A();  // { dg-error "10:expected qualified name" }
 };
index 297a0e73714591830564fc49e9ae1b3fe27efd55..3cb569accf4d1fd49ae3d985e28b463667ccaa67 100644 (file)
@@ -1,12 +1,12 @@
 // PR c++/19732
 
 struct A;
-typedef int ~A; // { dg-error "non-function" }
+typedef int ~A; // { dg-error "13:declaration of .~ A. as non-function" }
 struct B { 
-  ~A(); // { dg-error "" }
-  typedef int ~A; // { dg-error "non-function" }
+  ~A(); // { dg-error "3:declaration of .~A. as member of .B." }
+  typedef int ~A; // { dg-error "15:declaration of .~ A. as non-function" }
   void f() {
-    extern ~B(); // { dg-error "non-member" }
+    extern ~B(); // { dg-error "12:declaration of .~ B. as non-member" }
   }
 };
-void ~A(); // { dg-error "non-member" }
+void ~A(); // { dg-error "6:declaration of .~ A. as non-member" }
index 7fc480f3ea0cc76e2e2c07dab3652a3c7bfd7257..19e31795c247d9d74a4326556a4163689503fb22 100644 (file)
@@ -19,14 +19,16 @@ struct B
 struct C
 {
   friend int C ();
-  friend int ~C ();            // { dg-error "return type|in friend decl" }
+  friend int ~C ();            // { dg-error "10:return type" }
+  // { dg-error "14:expected qualified name in friend decl" "" { target *-*-* } .-1 }
   friend int C (const C &);
 };
 
 struct D
 {
   friend int D () {}
-  friend int ~D () {}          // { dg-error "return type|in friend decl" }
+  friend int ~D () {}          // { dg-error "10:return type" }
+  // { dg-error "14:expected qualified name in friend decl" "" { target *-*-* } .-1 }
   friend int D (const D &) {}
 };
 
index d793fe4df89ccef29d5f980d3afd60360a01a5e7..a7e6172111351381c79b9838830db052f8e088e3 100644 (file)
@@ -3,7 +3,7 @@
 struct A
 {
     template<void (A::*)()> struct B {};
-    void ::foo(); // { dg-error "invalid use" }
+    void ::foo(); // { dg-error "10:invalid use" }
     B<&A::foo> b; // { dg-error "incomplete type|template argument" }
 };
  
index 1837e2fc71faf8898148264554b9b2f454ba1f17..460d65c0e21fea04e0c6e17a139e00e544341683 100644 (file)
@@ -1,4 +1,4 @@
 // { dg-do assemble  }
 // GROUPS passed error-messages
 class foo {};
-~foo () {}// { dg-error "" }  destructors must be member functions.*
+~foo () {}// { dg-error "1:declaration of .~ foo. as non-member" }  destructors must be member functions.*