aboutsummaryrefslogtreecommitdiff
path: root/gcc/c-parser.c
diff options
context:
space:
mode:
authorManuel López-Ibáñez <manu@gcc.gnu.org>2009-04-22 15:32:18 +0000
committerManuel López-Ibáñez <manu@gcc.gnu.org>2009-04-22 15:32:18 +0000
commitcfc935327585254eabd5c18f298b1b4bc28a2b02 (patch)
tree51e37b610f5f0eae957aa2a3cee06eec9ab65abb /gcc/c-parser.c
parent8632d02a43457ecbcef85175e7575e5da6784646 (diff)
downloadgcc-cfc935327585254eabd5c18f298b1b4bc28a2b02.zip
gcc-cfc935327585254eabd5c18f298b1b4bc28a2b02.tar.gz
gcc-cfc935327585254eabd5c18f298b1b4bc28a2b02.tar.bz2
re PR c++/14875 (When using 'or' keyword, the error message speaks of a '||' token)
2009-04-22 Manuel Lopez-Ibanez <manu@gcc.gnu.org> PR c++/14875 * c-common.c (c_parse_error): Take a token_flags parameter. Use token_type for the token type instead. Pass token_flags to cpp_type2name. * c-common.h (c_parse_error): Update declaration. * c-parser.c (c_parser_error): Pass 0 as token flags. libcpp/ * lex.c (cpp_type2name): Take a flags parameter. Call cpp_named_operator2name for named operators and cpp_digraph2name for digraphs. (cpp_digraph2name): New. (cpp_spell_token): Use it. (cpp_output_token): Likewise. * include/cpplib.h (cpp_type2name): Update declaration. * init.c (cpp_named_operator2name): New. * internal.h (cpp_named_operator2name): Declare. cp/ * parser.c (cp_parser_error): Pass token->flags to c_parse_error. testsuite/ * g++.dg/parse/parser-pr14875.C: New. * g++.dg/parse/parser-pr14875-2.C: New. * g++.dg/parse/error6.C: Update match string. From-SVN: r146589
Diffstat (limited to 'gcc/c-parser.c')
-rw-r--r--gcc/c-parser.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/c-parser.c b/gcc/c-parser.c
index 676c709..ed77098 100644
--- a/gcc/c-parser.c
+++ b/gcc/c-parser.c
@@ -573,7 +573,11 @@ c_parser_error (c_parser *parser, const char *gmsgid)
CPP_KEYWORD, keywords are treated like
identifiers. */
(token->type == CPP_KEYWORD ? CPP_NAME : token->type),
- token->value);
+ /* ??? The C parser does not save the cpp flags of a
+ token, we need to pass 0 here and we will not get
+ the source spelling of some tokens but rather the
+ canonical spelling. */
+ token->value, /*flags=*/0);
}
/* If the next token is of the indicated TYPE, consume it. Otherwise,