From: Neil Booth Date: Wed, 22 Nov 2000 20:36:10 +0000 (+0000) Subject: cpplex.c (trigraph_ok): Ensure we don't warn twice. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=4a5b68a2f743ff0742b64c97bb75e6ee0c3c1471;p=gcc.git cpplex.c (trigraph_ok): Ensure we don't warn twice. * cpplex.c (trigraph_ok): Ensure we don't warn twice. * cpplib.h (struct cpp_buffer): New member last_Wtrigraphs. From-SVN: r37669 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c8bde8c640c..0966d8fa237 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-11-22 Neil Booth + + * cpplex.c (trigraph_ok): Ensure we don't warn twice. + * cpplib.h (struct cpp_buffer): New member last_Wtrigraphs. + 2000-11-22 Richard Henderson * haifa-sched.c (sched_analyze_1): Don't special-case calls diff --git a/gcc/cpplex.c b/gcc/cpplex.c index 96e2454316a..bec14e76042 100644 --- a/gcc/cpplex.c +++ b/gcc/cpplex.c @@ -159,9 +159,13 @@ trigraph_ok (pfile, from_char) "trigraph ??%c converted to %c", (int) from_char, (int) _cpp_trigraph_map[from_char]); - else - cpp_warning_with_line (pfile, buffer->lineno, CPP_BUF_COL (buffer) - 2, - "trigraph ??%c ignored", (int) from_char); + else if (buffer->cur != buffer->last_Wtrigraphs) + { + buffer->last_Wtrigraphs = buffer->cur; + cpp_warning_with_line (pfile, buffer->lineno, + CPP_BUF_COL (buffer) - 2, + "trigraph ??%c ignored", (int) from_char); + } } return accept; diff --git a/gcc/cpplib.h b/gcc/cpplib.h index 5922f94290f..91cca900733 100644 --- a/gcc/cpplib.h +++ b/gcc/cpplib.h @@ -282,6 +282,10 @@ struct cpp_buffer /* Line number at line_base (above). */ unsigned int lineno; + /* Because of the way the lexer works, -Wtrigraphs can sometimes + warn twice for the same trigraph. This helps prevent that. */ + const unsigned char *last_Wtrigraphs; + /* True if we have already warned about C++ comments in this file. The warning happens only for C89 extended mode with -pedantic on, or for -Wtraditional, and only once per file (otherwise it would