mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-20 17:53:02 +00:00
Add %option nounput, since we no longer use unput.
(unexpected_eof): Renamed from unexpected_end_of_file, for brevity. Do not insert the expected token via unput, as this runs afoul of a POSIX-compatibility bug in flex 2.5.31. All uses changed to BEGIN the parent state, since we no longer insert the expected token via unput.
This commit is contained in:
@@ -20,7 +20,7 @@
|
|||||||
02111-1307 USA
|
02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
%option debug nodefault noyywrap never-interactive
|
%option debug nodefault nounput noyywrap never-interactive
|
||||||
%option prefix="gram_" outfile="lex.yy.c"
|
%option prefix="gram_" outfile="lex.yy.c"
|
||||||
|
|
||||||
%{
|
%{
|
||||||
@@ -102,7 +102,7 @@ static void handle_dollar (int token_type, char *cp, location loc);
|
|||||||
static void handle_at (int token_type, char *cp, location loc);
|
static void handle_at (int token_type, char *cp, location loc);
|
||||||
static void handle_syncline (char *args);
|
static void handle_syncline (char *args);
|
||||||
static int convert_ucn_to_byte (char const *hex_text);
|
static int convert_ucn_to_byte (char const *hex_text);
|
||||||
static void unexpected_end_of_file (boundary, char const *);
|
static void unexpected_eof (boundary, char const *);
|
||||||
|
|
||||||
%}
|
%}
|
||||||
%x SC_COMMENT SC_LINE_COMMENT SC_YACC_COMMENT
|
%x SC_COMMENT SC_LINE_COMMENT SC_YACC_COMMENT
|
||||||
@@ -323,7 +323,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
{
|
{
|
||||||
"*/" BEGIN context_state;
|
"*/" BEGIN context_state;
|
||||||
.|\n ;
|
.|\n ;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "*/");
|
<<EOF>> unexpected_eof (token_start, "*/"); BEGIN context_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -334,7 +334,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
<SC_COMMENT>
|
<SC_COMMENT>
|
||||||
{
|
{
|
||||||
"*"{splice}"/" STRING_GROW; BEGIN context_state;
|
"*"{splice}"/" STRING_GROW; BEGIN context_state;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "*/");
|
<<EOF>> unexpected_eof (token_start, "*/"); BEGIN context_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -368,7 +368,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
}
|
}
|
||||||
|
|
||||||
.|\n STRING_GROW;
|
.|\n STRING_GROW;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "\"");
|
<<EOF>> unexpected_eof (token_start, "\""); BEGIN INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*---------------------------------------------------------------.
|
/*---------------------------------------------------------------.
|
||||||
@@ -394,7 +394,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
}
|
}
|
||||||
|
|
||||||
.|\n STRING_GROW;
|
.|\n STRING_GROW;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "'");
|
<<EOF>> unexpected_eof (token_start, "'"); BEGIN INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -456,7 +456,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
{
|
{
|
||||||
"'" STRING_GROW; BEGIN context_state;
|
"'" STRING_GROW; BEGIN context_state;
|
||||||
\\{splice}[^$@\[\]] STRING_GROW;
|
\\{splice}[^$@\[\]] STRING_GROW;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "'");
|
<<EOF>> unexpected_eof (token_start, "'"); BEGIN context_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -469,7 +469,10 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
{
|
{
|
||||||
"\"" STRING_GROW; BEGIN context_state;
|
"\"" STRING_GROW; BEGIN context_state;
|
||||||
\\{splice}[^$@\[\]] STRING_GROW;
|
\\{splice}[^$@\[\]] STRING_GROW;
|
||||||
<<EOF>> unexpected_end_of_file (token_start, "\"");
|
<<EOF>> {
|
||||||
|
unexpected_eof (token_start, "\"");
|
||||||
|
BEGIN context_state;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -536,7 +539,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
<<EOF>> unexpected_end_of_file (scanner_cursor, "{}");
|
<<EOF>> unexpected_eof (scanner_cursor, "{}"); BEGIN INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -589,7 +592,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
"$"("<"{tag}">")?(-?[0-9]+|"$") handle_dollar (token_type, yytext, *loc);
|
"$"("<"{tag}">")?(-?[0-9]+|"$") handle_dollar (token_type, yytext, *loc);
|
||||||
"@"(-?[0-9]+|"$") handle_at (token_type, yytext, *loc);
|
"@"(-?[0-9]+|"$") handle_at (token_type, yytext, *loc);
|
||||||
|
|
||||||
<<EOF>> unexpected_end_of_file (code_start, "}");
|
<<EOF>> unexpected_eof (code_start, "}"); BEGIN INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -607,7 +610,7 @@ splice (\\[ \f\t\v]*\n)*
|
|||||||
return PROLOGUE;
|
return PROLOGUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
<<EOF>> unexpected_end_of_file (code_start, "%}");
|
<<EOF>> unexpected_eof (code_start, "%}"); BEGIN INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -971,25 +974,15 @@ handle_syncline (char *args)
|
|||||||
/*------------------------------------------------------------------------.
|
/*------------------------------------------------------------------------.
|
||||||
| Report an unexpected EOF in a token or comment starting at START. |
|
| Report an unexpected EOF in a token or comment starting at START. |
|
||||||
| An end of file was encountered and the expected TOKEN_END was missing. |
|
| An end of file was encountered and the expected TOKEN_END was missing. |
|
||||||
| After reporting the problem, pretend that TOKEN_END was found. |
|
|
||||||
`------------------------------------------------------------------------*/
|
`------------------------------------------------------------------------*/
|
||||||
|
|
||||||
static void
|
static void
|
||||||
unexpected_end_of_file (boundary start, char const *token_end)
|
unexpected_eof (boundary start, char const *token_end)
|
||||||
{
|
{
|
||||||
size_t i = strlen (token_end);
|
|
||||||
|
|
||||||
location loc;
|
location loc;
|
||||||
loc.start = start;
|
loc.start = start;
|
||||||
loc.end = scanner_cursor;
|
loc.end = scanner_cursor;
|
||||||
complain_at (loc, _("missing `%s' at end of file"), token_end);
|
complain_at (loc, _("missing `%s' at end of file"), token_end);
|
||||||
|
|
||||||
/* Adjust scanner cursor so that any later message does not count
|
|
||||||
the characters about to be inserted. */
|
|
||||||
scanner_cursor.column -= i;
|
|
||||||
|
|
||||||
while (i != 0)
|
|
||||||
unput (token_end[--i]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user