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
This commit is contained in:
parent
4eee656926
commit
7e99f74bbb
@ -1,3 +1,9 @@
|
|||||||
|
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>
|
2008-08-06 Victor Kaplansky <victork@il.ibm.com>
|
||||||
Ira Rosen <irar@il.ibm.com>
|
Ira Rosen <irar@il.ibm.com>
|
||||||
|
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
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>
|
2008-08-06 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
|
||||||
|
|
||||||
PR 8715
|
PR 8715
|
||||||
|
@ -8437,8 +8437,9 @@ grokdeclarator (const cp_declarator *declarator,
|
|||||||
friendp = 0;
|
friendp = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
permerror ("extra qualification %<%T::%> on member %qs",
|
permerror_at (declarator->id_loc,
|
||||||
ctype, name);
|
"extra qualification %<%T::%> on member %qs",
|
||||||
|
ctype, name);
|
||||||
}
|
}
|
||||||
else if (/* If the qualifying type is already complete, then we
|
else if (/* If the qualifying type is already complete, then we
|
||||||
can skip the following checks. */
|
can skip the following checks. */
|
||||||
|
@ -554,10 +554,26 @@ pedwarn0 (const char *gmsgid, ...)
|
|||||||
va_end (ap);
|
va_end (ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* A "permissive" error: issues an error unless -fpermissive was given
|
/* A "permissive" error at LOCATION: issues an error unless
|
||||||
on the command line, in which case it issues a warning. Use this
|
-fpermissive was given on the command line, in which case it issues
|
||||||
for things that really should be errors but we want to support
|
a warning. Use this for things that really should be errors but we
|
||||||
legacy code. */
|
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
|
void
|
||||||
permerror (const char *gmsgid, ...)
|
permerror (const char *gmsgid, ...)
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
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>
|
2008-08-06 Victor Kaplansky <victork@il.ibm.com>
|
||||||
|
|
||||||
* gcc.dg/vect/costmodel/ppc/costmodel-slp-34.c: New test.
|
* gcc.dg/vect/costmodel/ppc/costmodel-slp-34.c: New test.
|
||||||
|
10
gcc/testsuite/g++.dg/warn/pr26785.C
Normal file
10
gcc/testsuite/g++.dg/warn/pr26785.C
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
// 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. */
|
/* 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 pedwarn (int, const char *, ...) ATTRIBUTE_GCC_DIAG(2,3);
|
||||||
extern void permerror (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
|
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 sorry (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
|
||||||
extern void inform (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);
|
extern void verbatim (const char *, ...) ATTRIBUTE_GCC_DIAG(1,2);
|
||||||
|
Loading…
Reference in New Issue
Block a user