re PR c++/26785 ("extra qualification" error gives line number of end of declaration)

2008-08-06  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>

	PR 26785
	* diagnostic.c (permerror_at): New.
	* toplev.h (permerror_at): Declare.
cp/
	* decl.c (grokdeclarator): Use explicit location with
        permerror_at.
testsuite/
	* g++.dg/warn/pr26785.C: New.

From-SVN: r138816
parent 4eee6569
2008-08-06 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
PR 26785
* diagnostic.c (permerror_at): New.
* toplev.h (permerror_at): Declare.
2008-08-06 Victor Kaplansky <victork@il.ibm.com>
Ira Rosen <irar@il.ibm.com>
......
2008-08-06 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
PR 26785
* decl.c (grokdeclarator): Use explicit location with permerror_at.
2008-08-06 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
PR 8715
* typeck.c (cp_build_binary_op): Move code to c-common.c.
......
......@@ -8437,8 +8437,9 @@ grokdeclarator (const cp_declarator *declarator,
friendp = 0;
}
else
permerror ("extra qualification %<%T::%> on member %qs",
ctype, name);
permerror_at (declarator->id_loc,
"extra qualification %<%T::%> on member %qs",
ctype, name);
}
else if (/* If the qualifying type is already complete, then we
can skip the following checks. */
......
......@@ -554,10 +554,26 @@ pedwarn0 (const char *gmsgid, ...)
va_end (ap);
}
/* A "permissive" error: issues an error unless -fpermissive was given
on the command line, in which case it issues a warning. Use this
for things that really should be errors but we want to support
legacy code. */
/* A "permissive" error at LOCATION: issues an error unless
-fpermissive was given on the command line, in which case it issues
a warning. Use this for things that really should be errors but we
want to support legacy code. */
void
permerror_at (location_t location, const char *gmsgid, ...)
{
diagnostic_info diagnostic;
va_list ap;
va_start (ap, gmsgid);
diagnostic_set_info (&diagnostic, gmsgid, &ap, location,
permissive_error_kind ());
diagnostic.option_index = OPT_fpermissive;
report_diagnostic (&diagnostic);
va_end (ap);
}
/* Equivalent to permerror_at (input_location, ...). */
void
permerror (const char *gmsgid, ...)
......
2008-08-06 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
PR 26785
* g++.dg/warn/pr26785.C: New.
2008-08-06 Victor Kaplansky <victork@il.ibm.com>
* gcc.dg/vect/costmodel/ppc/costmodel-slp-34.c: New test.
......
// PR 26785
// { dg-do compile }
// { dg-options "-fshow-column" }
class foo {
foo::foo // { dg-error "3: error: extra qualification" }
(int a,
int b,
int c);
};
......@@ -68,6 +68,8 @@ extern void pedwarn0 (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
/* Pass one of the OPT_W* from options.h as the first parameter. */
extern void pedwarn (int, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
extern void permerror (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
extern void permerror_at (location_t, const char *, ...)
ATTRIBUTE_GCC_DIAG(2,3);
extern void sorry (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
extern void inform (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
extern void verbatim (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment