mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-09 12:23:04 +00:00
news: update the yyreport_syntax_error example
* examples/c/bistromathic/parse.y, tests/local.at (yyreport_syntax_error): Fix use of YYSYMBOL_YYEMPTY. * NEWS: Update.
This commit is contained in:
32
NEWS
32
NEWS
@@ -39,20 +39,30 @@ GNU Bison NEWS
|
||||
int
|
||||
yyreport_syntax_error (const yypcontext_t *ctx)
|
||||
{
|
||||
enum { ARGMAX = 10 };
|
||||
int arg[ARGMAX];
|
||||
int n = yy_syntax_error_arguments (ctx, arg, ARGMAX);
|
||||
if (n == -2)
|
||||
return 2; // Memory exhausted.
|
||||
int res = 0;
|
||||
YY_LOCATION_PRINT (stderr, *yypcontext_location (ctx));
|
||||
fprintf (stderr, ": syntax error");
|
||||
for (int i = 1; i < n; ++i)
|
||||
fprintf (stderr, " %s %s",
|
||||
i == 1 ? "expected" : "or", yysymbol_name (arg[i]));
|
||||
if (n)
|
||||
fprintf (stderr, " before %s", yysymbol_name (arg[0]));
|
||||
// Report the tokens expected at this point.
|
||||
{
|
||||
enum { TOKENMAX = 10 };
|
||||
yysymbol_type_t expected[TOKENMAX];
|
||||
int n = yyexpected_tokens (ctx, expected, TOKENMAX);
|
||||
if (n < 0)
|
||||
// Forward errors to yyparse.
|
||||
res = n;
|
||||
else
|
||||
for (int i = 0; i < n; ++i)
|
||||
fprintf (stderr, "%s %s",
|
||||
i == 0 ? ": expected" : " or", yysymbol_name (expected[i]));
|
||||
}
|
||||
// Report the unexpected token.
|
||||
{
|
||||
yysymbol_type_t lookahead = yypcontext_token (ctx);
|
||||
if (lookahead != YYSYMBOL_YYEMPTY)
|
||||
fprintf (stderr, " before %s", yysymbol_name (lookahead));
|
||||
}
|
||||
fprintf (stderr, "\n");
|
||||
return 0;
|
||||
return res;
|
||||
}
|
||||
|
||||
**** Token aliases internationalization
|
||||
|
||||
@@ -287,6 +287,7 @@ yyreport_syntax_error (const yypcontext_t *ctx)
|
||||
int res = 0;
|
||||
YY_LOCATION_PRINT (stderr, *yypcontext_location (ctx));
|
||||
fprintf (stderr, ": syntax error");
|
||||
// Report the tokens expected at this point.
|
||||
{
|
||||
enum { TOKENMAX = 10 };
|
||||
yysymbol_type_t expected[TOKENMAX];
|
||||
@@ -299,9 +300,10 @@ yyreport_syntax_error (const yypcontext_t *ctx)
|
||||
fprintf (stderr, "%s %s",
|
||||
i == 0 ? ": expected" : " or", yysymbol_name (expected[i]));
|
||||
}
|
||||
// Report the unexpected token.
|
||||
{
|
||||
yysymbol_type_t lookahead = yypcontext_token (ctx);
|
||||
if (lookahead != YYEMPTY)
|
||||
if (lookahead != YYSYMBOL_YYEMPTY)
|
||||
fprintf (stderr, " before %s", yysymbol_name (lookahead));
|
||||
}
|
||||
fprintf (stderr, "\n");
|
||||
|
||||
@@ -634,7 +634,7 @@ yyreport_syntax_error (const yypcontext_t *ctx]AT_PARAM_IF([, AT_PARSE_PARAMS])[
|
||||
fprintf (stderr, "syntax error");
|
||||
{
|
||||
yysymbol_type_t la = yypcontext_token (ctx);
|
||||
if (la != YYEMPTY)
|
||||
if (la != YYSYMBOL_YYEMPTY)
|
||||
fprintf (stderr, " on token [%s]", yysymbol_name (la));
|
||||
}
|
||||
{
|
||||
@@ -642,9 +642,9 @@ yyreport_syntax_error (const yypcontext_t *ctx]AT_PARAM_IF([, AT_PARSE_PARAMS])[
|
||||
yysymbol_type_t expected[TOKENMAX];
|
||||
int n = yyexpected_tokens (ctx, expected, TOKENMAX);
|
||||
/* Forward errors to yyparse. */
|
||||
if (n < 0)
|
||||
if (n <= 0)
|
||||
res = n;
|
||||
else if (0 < n)
|
||||
else
|
||||
{
|
||||
fprintf (stderr, " (expected:");
|
||||
for (int i = 0; i < n; ++i)
|
||||
|
||||
Reference in New Issue
Block a user