mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-19 09:13:04 +00:00
diagnostics: modernize the display of submessages
Since Bison 2.7, output was indented four spaces for explanatory
statements. For example:
input.y:2.7-13: error: %type redeclaration for exp
input.y:1.7-11: previous declaration
Since the introduction of caret-diagnostics, it became less clear.
Remove the indentation and display submessages as in GCC:
input.y:2.7-13: error: %type redeclaration for exp
2 | %type <float> exp
| ^~~~~~~
input.y:1.7-11: note: previous declaration
1 | %type <int> exp
| ^~~~~
* src/complain.h (SUB_INDENT): Remove.
(warnings): Add "note" to the enum.
* src/complain.h, src/complain.c (complain_indent): Replace by...
(subcomplain): this.
Adjust all dependencies.
* tests/actions.at, tests/diagnostics.at, tests/glr-regression.at,
* tests/input.at, tests/named-refs.at, tests/regression.at:
Adjust expectations.
This commit is contained in:
committed by
Akim Demaille
parent
a09d0ae4d1
commit
e09a72eeb0
21
NEWS
21
NEWS
@@ -75,6 +75,27 @@ GNU Bison NEWS
|
|||||||
the translated symbol (i.e., it returns '_("variable")' rather that
|
the translated symbol (i.e., it returns '_("variable")' rather that
|
||||||
'"variable"').
|
'"variable"').
|
||||||
|
|
||||||
|
*** Modernize display of explanatory statements in diagnostics
|
||||||
|
|
||||||
|
Since Bison 2.7, output was indented four spaces for explanatory
|
||||||
|
statements. For example:
|
||||||
|
|
||||||
|
input.y:2.7-13: error: %type redeclaration for exp
|
||||||
|
input.y:1.7-11: previous declaration
|
||||||
|
|
||||||
|
Since the introduction of caret-diagnostics, it became less clear. This
|
||||||
|
indentation has been removed and submessages are displayed similarly as in
|
||||||
|
GCC:
|
||||||
|
|
||||||
|
input.y:2.7-13: error: %type redeclaration for exp
|
||||||
|
2 | %type <float> exp
|
||||||
|
| ^~~~~~~
|
||||||
|
input.y:1.7-11: note: previous declaration
|
||||||
|
1 | %type <int> exp
|
||||||
|
| ^~~~~
|
||||||
|
|
||||||
|
Contributed by Victor Morales Cayuela.
|
||||||
|
|
||||||
** Documentation
|
** Documentation
|
||||||
|
|
||||||
There are now two examples in examples/java: a very simple calculator, and
|
There are now two examples in examples/java: a very simple calculator, and
|
||||||
|
|||||||
46
TODO
46
TODO
@@ -95,52 +95,6 @@ and https://research.swtch.com/yyerror.
|
|||||||
** consistency
|
** consistency
|
||||||
token vs terminal, variable vs non terminal.
|
token vs terminal, variable vs non terminal.
|
||||||
|
|
||||||
** Stop indentation in diagnostics
|
|
||||||
Before Bison 2.7, we printed "flatly" the dependencies in long diagnostics:
|
|
||||||
|
|
||||||
input.y:2.7-12: %type redeclaration for exp
|
|
||||||
input.y:1.7-12: previous declaration
|
|
||||||
|
|
||||||
In Bison 2.7, we indented them
|
|
||||||
|
|
||||||
input.y:2.7-12: error: %type redeclaration for exp
|
|
||||||
input.y:1.7-12: previous declaration
|
|
||||||
|
|
||||||
Later we quoted the source in the diagnostics, and today we have:
|
|
||||||
|
|
||||||
/tmp/foo.y:1.12-14: warning: symbol FOO redeclared [-Wother]
|
|
||||||
1 | %token FOO FOO
|
|
||||||
| ^~~
|
|
||||||
/tmp/foo.y:1.8-10: previous declaration
|
|
||||||
1 | %token FOO FOO
|
|
||||||
| ^~~
|
|
||||||
|
|
||||||
The indentation is no longer helping. We should probably get rid of it, or
|
|
||||||
maybe keep it only when -fno-caret. GCC displays this as a "note":
|
|
||||||
|
|
||||||
$ g++-mp-9 -Wall /tmp/foo.c -c
|
|
||||||
/tmp/foo.c:1:10: error: redefinition of 'int foo'
|
|
||||||
1 | int foo, foo;
|
|
||||||
| ^~~
|
|
||||||
/tmp/foo.c:1:5: note: 'int foo' previously declared here
|
|
||||||
1 | int foo, foo;
|
|
||||||
| ^~~
|
|
||||||
|
|
||||||
Likewise for Clang, contrary to what I believed (because "note:" is written
|
|
||||||
in black, so it doesn't show in my terminal :-)
|
|
||||||
|
|
||||||
$ clang++-mp-8.0 -Wall /tmp/foo.c -c
|
|
||||||
clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
|
|
||||||
/tmp/foo.c:1:10: error: redefinition of 'foo'
|
|
||||||
int foo, foo;
|
|
||||||
^
|
|
||||||
/tmp/foo.c:1:5: note: previous definition is here
|
|
||||||
int foo, foo;
|
|
||||||
^
|
|
||||||
1 error generated.
|
|
||||||
|
|
||||||
See also the item "Complaint submessage indentation" below.
|
|
||||||
|
|
||||||
** api.token.raw
|
** api.token.raw
|
||||||
Maybe we should exhibit the YYUNDEFTOK token. It could also be assigned a
|
Maybe we should exhibit the YYUNDEFTOK token. It could also be assigned a
|
||||||
semantic value so that yyerror could be used to report invalid lexemes.
|
semantic value so that yyerror could be used to report invalid lexemes.
|
||||||
|
|||||||
@@ -424,7 +424,6 @@ warnings_print_categories (warnings warn_flags, FILE *out)
|
|||||||
*
|
*
|
||||||
* \param loc the location, defaulting to the current file,
|
* \param loc the location, defaulting to the current file,
|
||||||
* or the program name.
|
* or the program name.
|
||||||
* \param indent optional indentation for the error message.
|
|
||||||
* \param flags the category for this message.
|
* \param flags the category for this message.
|
||||||
* \param sever to decide the prefix to put before the message
|
* \param sever to decide the prefix to put before the message
|
||||||
* (e.g., "warning").
|
* (e.g., "warning").
|
||||||
@@ -436,51 +435,46 @@ warnings_print_categories (warnings warn_flags, FILE *out)
|
|||||||
*/
|
*/
|
||||||
static
|
static
|
||||||
void
|
void
|
||||||
error_message (const location *loc, int *indent, warnings flags,
|
error_message (const location *loc, warnings flags,
|
||||||
severity sever, const char *message, va_list args)
|
severity sever, const char *message, va_list args)
|
||||||
{
|
{
|
||||||
int pos = 0;
|
const char* style = flags & note ? "note" : severity_style (sever);
|
||||||
|
|
||||||
if (loc)
|
if (loc)
|
||||||
pos += location_print (*loc, stderr);
|
location_print (*loc, stderr);
|
||||||
else
|
else
|
||||||
pos += fprintf (stderr, "%s", grammar_file ? grammar_file : program_name);
|
fprintf (stderr, "%s", grammar_file ? grammar_file : program_name);
|
||||||
pos += fprintf (stderr, ": ");
|
fprintf (stderr, ": ");
|
||||||
|
|
||||||
if (indent)
|
if (sever != severity_disabled)
|
||||||
{
|
{
|
||||||
if (*indent)
|
begin_use_class (style, stderr);
|
||||||
sever = severity_disabled;
|
fprintf (stderr, "%s:", flags & note ? _("note") : severity_prefix (sever));
|
||||||
if (!*indent)
|
end_use_class (style, stderr);
|
||||||
*indent = pos;
|
fputc (' ', stderr);
|
||||||
else if (*indent > pos)
|
|
||||||
fprintf (stderr, "%*s", *indent - pos, "");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
severity_print (sever, stderr);
|
|
||||||
vfprintf (stderr, message, args);
|
vfprintf (stderr, message, args);
|
||||||
/* Print the type of warning, only if this is not a sub message
|
/* Print the type of warning, only if this is not a sub message
|
||||||
(in which case the prefix is null). */
|
(in which case the prefix is null). */
|
||||||
if (! (flags & silent) && sever != severity_disabled)
|
if (! (flags & silent) && sever != severity_disabled)
|
||||||
warnings_print_categories (flags, stderr);
|
warnings_print_categories (flags, stderr);
|
||||||
|
|
||||||
{
|
size_t l = strlen (message);
|
||||||
size_t l = strlen (message);
|
if (l < 2 || message[l - 2] != ':' || message[l - 1] != ' ')
|
||||||
if (l < 2 || message[l - 2] != ':' || message[l - 1] != ' ')
|
{
|
||||||
{
|
putc ('\n', stderr);
|
||||||
putc ('\n', stderr);
|
flush (stderr);
|
||||||
flush (stderr);
|
if (loc && !(flags & no_caret))
|
||||||
if (loc && !(flags & no_caret))
|
location_caret (*loc, style, stderr);
|
||||||
location_caret (*loc, severity_style (sever), stderr);
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
flush (stderr);
|
flush (stderr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Raise a complaint (fatal error, error or just warning). */
|
/** Raise a complaint (fatal error, error or just warning). */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
complains (const location *loc, int *indent, warnings flags,
|
complains (const location *loc, warnings flags,
|
||||||
const char *message, va_list args)
|
const char *message, va_list args)
|
||||||
{
|
{
|
||||||
if ((flags & complaint) && complaint_status < status_complaint)
|
if ((flags & complaint) && complaint_status < status_complaint)
|
||||||
@@ -491,7 +485,7 @@ complains (const location *loc, int *indent, warnings flags,
|
|||||||
{
|
{
|
||||||
if (severity_error <= s && ! complaint_status)
|
if (severity_error <= s && ! complaint_status)
|
||||||
complaint_status = status_warning_as_error;
|
complaint_status = status_warning_as_error;
|
||||||
error_message (loc, indent, flags, s, message, args);
|
error_message (loc, flags, s, message, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & fatal)
|
if (flags & fatal)
|
||||||
@@ -503,41 +497,39 @@ complain (location const *loc, warnings flags, const char *message, ...)
|
|||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start (args, message);
|
va_start (args, message);
|
||||||
complains (loc, NULL, flags, message, args);
|
complains (loc, flags, message, args);
|
||||||
va_end (args);
|
va_end (args);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
complain_indent (location const *loc, warnings flags, int *indent,
|
subcomplain (location const *loc, warnings flags, const char *message, ...)
|
||||||
const char *message, ...)
|
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start (args, message);
|
va_start (args, message);
|
||||||
complains (loc, indent, flags, message, args);
|
complains (loc, flags | note | silent, message, args);
|
||||||
va_end (args);
|
va_end (args);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
complain_args (location const *loc, warnings w, int *indent,
|
complain_args (location const *loc, warnings w,
|
||||||
int argc, char *argv[])
|
int argc, char *argv[])
|
||||||
{
|
{
|
||||||
switch (argc)
|
switch (argc)
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
complain_indent (loc, w, indent, "%s", _(argv[0]));
|
complain (loc, w, "%s", _(argv[0]));
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
complain_indent (loc, w, indent, _(argv[0]), argv[1]);
|
complain (loc, w, _(argv[0]), argv[1]);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
complain_indent (loc, w, indent, _(argv[0]), argv[1], argv[2]);
|
complain (loc, w, _(argv[0]), argv[1], argv[2]);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
complain_indent (loc, w, indent, _(argv[0]), argv[1], argv[2], argv[3]);
|
complain (loc, w, _(argv[0]), argv[1], argv[2], argv[3]);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
complain_indent (loc, w, indent, _(argv[0]), argv[1], argv[2], argv[3],
|
complain (loc, w, _(argv[0]), argv[1], argv[2], argv[3], argv[4]);
|
||||||
argv[4]);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
complain (loc, fatal, "too many arguments for complains");
|
complain (loc, fatal, "too many arguments for complains");
|
||||||
@@ -571,13 +563,11 @@ void
|
|||||||
duplicate_directive (char const *directive,
|
duplicate_directive (char const *directive,
|
||||||
location first, location second)
|
location first, location second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
|
||||||
if (feature_flag & feature_caret)
|
if (feature_flag & feature_caret)
|
||||||
complain_indent (&second, Wother, &i, _("duplicate directive"));
|
complain (&second, Wother, _("duplicate directive"));
|
||||||
else
|
else
|
||||||
complain_indent (&second, Wother, &i, _("duplicate directive: %s"), quote (directive));
|
complain (&second, Wother, _("duplicate directive: %s"), quote (directive));
|
||||||
i += SUB_INDENT;
|
subcomplain (&first, Wother, _("previous declaration"));
|
||||||
complain_indent (&first, Wother, &i, _("previous declaration"));
|
|
||||||
fixits_register (&second, "");
|
fixits_register (&second, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -585,12 +575,8 @@ void
|
|||||||
duplicate_rule_directive (char const *directive,
|
duplicate_rule_directive (char const *directive,
|
||||||
location first, location second)
|
location first, location second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
complain (&second, complaint, _("only one %s allowed per rule"), directive);
|
||||||
complain_indent (&second, complaint, &i,
|
subcomplain (&first, complaint, _("previous declaration"));
|
||||||
_("only one %s allowed per rule"), directive);
|
|
||||||
i += SUB_INDENT;
|
|
||||||
complain_indent (&first, complaint, &i,
|
|
||||||
_("previous declaration"));
|
|
||||||
fixits_register (&second, "");
|
fixits_register (&second, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -21,9 +21,6 @@
|
|||||||
|
|
||||||
# include "location.h"
|
# include "location.h"
|
||||||
|
|
||||||
/* Sub-messages indent. */
|
|
||||||
# define SUB_INDENT (4)
|
|
||||||
|
|
||||||
/*---------------.
|
/*---------------.
|
||||||
| Error stream. |
|
| Error stream. |
|
||||||
`---------------*/
|
`---------------*/
|
||||||
@@ -119,6 +116,7 @@ typedef enum
|
|||||||
fatal = 1 << 12, /**< All fatal errors. */
|
fatal = 1 << 12, /**< All fatal errors. */
|
||||||
silent = 1 << 13, /**< Do not display the warning type. */
|
silent = 1 << 13, /**< Do not display the warning type. */
|
||||||
no_caret = 1 << 14, /**< Do not display caret location. */
|
no_caret = 1 << 14, /**< Do not display caret location. */
|
||||||
|
note = 1 << 15, /**< Display as a note. */
|
||||||
|
|
||||||
/**< All above warnings. */
|
/**< All above warnings. */
|
||||||
Weverything = ~complaint & ~fatal & ~silent,
|
Weverything = ~complaint & ~fatal & ~silent,
|
||||||
@@ -137,13 +135,13 @@ void complain (location const *loc, warnings flags, char const *message, ...)
|
|||||||
__attribute__ ((__format__ (__printf__, 3, 4)));
|
__attribute__ ((__format__ (__printf__, 3, 4)));
|
||||||
|
|
||||||
/** Likewise, but with an \a argc/argv interface. */
|
/** Likewise, but with an \a argc/argv interface. */
|
||||||
void complain_args (location const *loc, warnings w, int *indent,
|
void complain_args (location const *loc, warnings w,
|
||||||
int argc, char *arg[]);
|
int argc, char *arg[]);
|
||||||
|
|
||||||
/** Make a complaint with location and some indentation. */
|
/** Make a subcomplain with location and note. */
|
||||||
void complain_indent (location const *loc, warnings flags, int *indent,
|
void subcomplain (location const *loc, warnings flags,
|
||||||
char const *message, ...)
|
char const *message, ...)
|
||||||
__attribute__ ((__format__ (__printf__, 4, 5)));
|
__attribute__ ((__format__ (__printf__, 3, 4)));
|
||||||
|
|
||||||
|
|
||||||
/** GNU Bison extension not valid with POSIX Yacc. */
|
/** GNU Bison extension not valid with POSIX Yacc. */
|
||||||
|
|||||||
@@ -525,15 +525,13 @@ muscle_percent_define_insert (char const *var, location variable_loc,
|
|||||||
= atoi (muscle_find_const (how_name));
|
= atoi (muscle_find_const (how_name));
|
||||||
if (how_old == MUSCLE_PERCENT_DEFINE_F)
|
if (how_old == MUSCLE_PERCENT_DEFINE_F)
|
||||||
goto end;
|
goto end;
|
||||||
int i = 0;
|
|
||||||
/* If assigning the same value, make it a warning. */
|
/* If assigning the same value, make it a warning. */
|
||||||
warnings warn = STREQ (value, current_value) ? Wother : complaint;
|
warnings warn = STREQ (value, current_value) ? Wother : complaint;
|
||||||
complain_indent (&variable_loc, warn, &i,
|
complain (&variable_loc, warn,
|
||||||
_("%%define variable %s redefined"),
|
_("%%define variable %s redefined"),
|
||||||
quote (variable));
|
quote (variable));
|
||||||
i += SUB_INDENT;
|
|
||||||
location loc = muscle_percent_define_get_loc (variable);
|
location loc = muscle_percent_define_get_loc (variable);
|
||||||
complain_indent (&loc, warn, &i, _("previous definition"));
|
subcomplain (&loc, warn, _("previous definition"));
|
||||||
fixits_register (&variable_loc, "");
|
fixits_register (&variable_loc, "");
|
||||||
warned = true;
|
warned = true;
|
||||||
}
|
}
|
||||||
@@ -739,14 +737,12 @@ muscle_percent_define_check_values (char const * const *values)
|
|||||||
if (!*values)
|
if (!*values)
|
||||||
{
|
{
|
||||||
location loc = muscle_percent_define_get_loc (*variablep);
|
location loc = muscle_percent_define_get_loc (*variablep);
|
||||||
int i = 0;
|
complain (&loc, complaint,
|
||||||
complain_indent (&loc, complaint, &i,
|
_("invalid value for %%define variable %s: %s"),
|
||||||
_("invalid value for %%define variable %s: %s"),
|
quote (*variablep), quote_n (1, value));
|
||||||
quote (*variablep), quote_n (1, value));
|
|
||||||
i += SUB_INDENT;
|
|
||||||
for (values = variablep + 1; *values; ++values)
|
for (values = variablep + 1; *values; ++values)
|
||||||
complain_indent (&loc, complaint | no_caret | silent, &i,
|
subcomplain (&loc, complaint | no_caret | silent,
|
||||||
_("accepted value: %s"), quote (*values));
|
_("accepted value: %s"), quote (*values));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
while (*values)
|
while (*values)
|
||||||
|
|||||||
@@ -756,14 +756,11 @@ id:
|
|||||||
}
|
}
|
||||||
if (muscle_percent_define_ifdef (var))
|
if (muscle_percent_define_ifdef (var))
|
||||||
{
|
{
|
||||||
int indent = 0;
|
complain (&@1, complaint,
|
||||||
complain_indent (&@1, complaint, &indent,
|
_("character literals cannot be used together"
|
||||||
_("character literals cannot be used together"
|
" with %s"), var);
|
||||||
" with %s"), var);
|
|
||||||
indent += SUB_INDENT;
|
|
||||||
location loc = muscle_percent_define_get_loc (var);
|
location loc = muscle_percent_define_get_loc (var);
|
||||||
complain_indent (&loc, complaint, &indent,
|
subcomplain (&loc, complaint, _("definition of %s"), var);
|
||||||
_("definition of %s"), var);
|
|
||||||
}
|
}
|
||||||
$$ = symbol_get (char_name ($1), @1);
|
$$ = symbol_get (char_name ($1), @1);
|
||||||
symbol_class_set ($$, token_sym, @1, false);
|
symbol_class_set ($$, token_sym, @1, false);
|
||||||
|
|||||||
17
src/reader.c
17
src/reader.c
@@ -124,16 +124,13 @@ record_merge_function_type (int merger, uniqstr type, location declaration_loc)
|
|||||||
aver (merge_function != NULL && merger_find == merger);
|
aver (merge_function != NULL && merger_find == merger);
|
||||||
if (merge_function->type != NULL && !UNIQSTR_EQ (merge_function->type, type))
|
if (merge_function->type != NULL && !UNIQSTR_EQ (merge_function->type, type))
|
||||||
{
|
{
|
||||||
int indent = 0;
|
complain (&declaration_loc, complaint,
|
||||||
complain_indent (&declaration_loc, complaint, &indent,
|
_("result type clash on merge function %s: "
|
||||||
_("result type clash on merge function %s: "
|
"<%s> != <%s>"),
|
||||||
"<%s> != <%s>"),
|
quote (merge_function->name), type,
|
||||||
quote (merge_function->name), type,
|
merge_function->type);
|
||||||
merge_function->type);
|
subcomplain (&merge_function->type_declaration_loc, complaint,
|
||||||
indent += SUB_INDENT;
|
_("previous declaration"));
|
||||||
complain_indent (&merge_function->type_declaration_loc, complaint,
|
|
||||||
&indent,
|
|
||||||
_("previous declaration"));
|
|
||||||
}
|
}
|
||||||
merge_function->type = uniqstr_new (type);
|
merge_function->type = uniqstr_new (type);
|
||||||
merge_function->type_declaration_loc = declaration_loc;
|
merge_function->type_declaration_loc = declaration_loc;
|
||||||
|
|||||||
@@ -321,14 +321,14 @@ static void
|
|||||||
show_sub_message (warnings warning,
|
show_sub_message (warnings warning,
|
||||||
const char* cp, bool explicit_bracketing,
|
const char* cp, bool explicit_bracketing,
|
||||||
int midrule_rhs_index, char dollar_or_at,
|
int midrule_rhs_index, char dollar_or_at,
|
||||||
int indent, const variant *var)
|
const variant *var)
|
||||||
{
|
{
|
||||||
const char *at_spec = get_at_spec (var->symbol_index);
|
const char *at_spec = get_at_spec (var->symbol_index);
|
||||||
|
|
||||||
if (var->err == 0)
|
if (var->err == 0)
|
||||||
complain_indent (&var->loc, warning, &indent,
|
subcomplain (&var->loc, warning,
|
||||||
_("refers to: %c%s at %s"), dollar_or_at,
|
_("refers to: %c%s at %s"), dollar_or_at,
|
||||||
var->id, at_spec);
|
var->id, at_spec);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const char *id;
|
const char *id;
|
||||||
@@ -375,8 +375,8 @@ show_sub_message (warnings warning,
|
|||||||
_(", cannot be accessed from midrule action at $%d"),
|
_(", cannot be accessed from midrule action at $%d"),
|
||||||
midrule_rhs_index);
|
midrule_rhs_index);
|
||||||
|
|
||||||
complain_indent (&id_loc, warning, &indent, "%s",
|
subcomplain (&id_loc, warning, "%s",
|
||||||
obstack_finish0 (&msg_buf));
|
obstack_finish0 (&msg_buf));
|
||||||
obstack_free (&msg_buf, 0);
|
obstack_free (&msg_buf, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -384,14 +384,13 @@ show_sub_message (warnings warning,
|
|||||||
static void
|
static void
|
||||||
show_sub_messages (warnings warning,
|
show_sub_messages (warnings warning,
|
||||||
const char* cp, bool explicit_bracketing,
|
const char* cp, bool explicit_bracketing,
|
||||||
int midrule_rhs_index, char dollar_or_at,
|
int midrule_rhs_index, char dollar_or_at)
|
||||||
int indent)
|
|
||||||
{
|
{
|
||||||
for (int i = 0; i < variant_count; ++i)
|
for (int i = 0; i < variant_count; ++i)
|
||||||
show_sub_message (warning | silent,
|
show_sub_message (warning | silent,
|
||||||
cp, explicit_bracketing,
|
cp, explicit_bracketing,
|
||||||
midrule_rhs_index, dollar_or_at,
|
midrule_rhs_index, dollar_or_at,
|
||||||
indent, &variant_table[i]);
|
&variant_table[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Returned from "parse_ref" when the reference
|
/* Returned from "parse_ref" when the reference
|
||||||
@@ -492,47 +491,44 @@ parse_ref (char *cp, symbol_list *rule, int rule_length,
|
|||||||
{
|
{
|
||||||
int len = (explicit_bracketing || !ref_tail_fields) ?
|
int len = (explicit_bracketing || !ref_tail_fields) ?
|
||||||
cp_end - cp : ref_tail_fields - cp;
|
cp_end - cp : ref_tail_fields - cp;
|
||||||
int indent = 0;
|
|
||||||
|
|
||||||
complain_indent (text_loc, complaint, &indent,
|
complain (text_loc, complaint,
|
||||||
_("invalid reference: %s"), quote (text));
|
_("invalid reference: %s"), quote (text));
|
||||||
indent += SUB_INDENT;
|
|
||||||
if (len == 0)
|
if (len == 0)
|
||||||
{
|
{
|
||||||
location sym_loc = *text_loc;
|
location sym_loc = *text_loc;
|
||||||
sym_loc.start.column += 1;
|
sym_loc.start.column += 1;
|
||||||
sym_loc.end = sym_loc.start;
|
sym_loc.end = sym_loc.start;
|
||||||
complain_indent (&sym_loc, complaint, &indent,
|
subcomplain (&sym_loc, complaint,
|
||||||
_("syntax error after '%c', expecting integer, "
|
_("syntax error after '%c', expecting integer, "
|
||||||
"letter, '_', '[', or '$'"),
|
"letter, '_', '[', or '$'"),
|
||||||
dollar_or_at);
|
dollar_or_at);
|
||||||
}
|
}
|
||||||
else if (midrule_rhs_index)
|
else if (midrule_rhs_index)
|
||||||
complain_indent (&rule->rhs_loc, complaint, &indent,
|
subcomplain (&rule->rhs_loc, complaint,
|
||||||
_("symbol not found in production before $%d: "
|
_("symbol not found in production before $%d: "
|
||||||
"%.*s"),
|
"%.*s"),
|
||||||
midrule_rhs_index, len, cp);
|
midrule_rhs_index, len, cp);
|
||||||
else
|
else
|
||||||
complain_indent (&rule->rhs_loc, complaint, &indent,
|
subcomplain (&rule->rhs_loc, complaint,
|
||||||
_("symbol not found in production: %.*s"),
|
_("symbol not found in production: %.*s"),
|
||||||
len, cp);
|
len, cp);
|
||||||
|
|
||||||
if (variant_count > 0)
|
if (variant_count > 0)
|
||||||
show_sub_messages (complaint,
|
show_sub_messages (complaint,
|
||||||
cp, explicit_bracketing, midrule_rhs_index,
|
cp, explicit_bracketing, midrule_rhs_index,
|
||||||
dollar_or_at, indent);
|
dollar_or_at);
|
||||||
return INVALID_REF;
|
return INVALID_REF;
|
||||||
}
|
}
|
||||||
case 1:
|
case 1:
|
||||||
{
|
{
|
||||||
int indent = 0;
|
|
||||||
if (variant_count > 1)
|
if (variant_count > 1)
|
||||||
{
|
{
|
||||||
complain_indent (text_loc, Wother, &indent,
|
complain (text_loc, Wother,
|
||||||
_("misleading reference: %s"), quote (text));
|
_("misleading reference: %s"), quote (text));
|
||||||
show_sub_messages (Wother,
|
show_sub_messages (Wother,
|
||||||
cp, explicit_bracketing, midrule_rhs_index,
|
cp, explicit_bracketing, midrule_rhs_index,
|
||||||
dollar_or_at, indent + SUB_INDENT);
|
dollar_or_at);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
int symbol_index =
|
int symbol_index =
|
||||||
@@ -543,12 +539,11 @@ parse_ref (char *cp, symbol_list *rule, int rule_length,
|
|||||||
case 2:
|
case 2:
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
int indent = 0;
|
complain (text_loc, complaint,
|
||||||
complain_indent (text_loc, complaint, &indent,
|
_("ambiguous reference: %s"), quote (text));
|
||||||
_("ambiguous reference: %s"), quote (text));
|
|
||||||
show_sub_messages (complaint,
|
show_sub_messages (complaint,
|
||||||
cp, explicit_bracketing, midrule_rhs_index,
|
cp, explicit_bracketing, midrule_rhs_index,
|
||||||
dollar_or_at, indent + SUB_INDENT);
|
dollar_or_at);
|
||||||
return INVALID_REF;
|
return INVALID_REF;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -189,7 +189,7 @@ flag (const char *arg)
|
|||||||
else if (STREQ (arg, "fatal"))
|
else if (STREQ (arg, "fatal"))
|
||||||
return fatal;
|
return fatal;
|
||||||
else if (STREQ (arg, "note"))
|
else if (STREQ (arg, "note"))
|
||||||
return silent | complaint | no_caret;
|
return silent | complaint | no_caret | note;
|
||||||
else if (STREQ (arg, "warn"))
|
else if (STREQ (arg, "warn"))
|
||||||
return Wother;
|
return Wother;
|
||||||
else
|
else
|
||||||
@@ -225,14 +225,7 @@ at_complain (int argc, char *argv[], char **out_namep, int *out_linenop)
|
|||||||
boundary_set_from_string (&loc.end, argv[3]);
|
boundary_set_from_string (&loc.end, argv[3]);
|
||||||
locp = &loc;
|
locp = &loc;
|
||||||
}
|
}
|
||||||
static int indent;
|
complain_args (locp, w, argc - 4, argv + 4);
|
||||||
if (w & silent)
|
|
||||||
indent += SUB_INDENT;
|
|
||||||
else
|
|
||||||
indent = 0;
|
|
||||||
complain_args (locp, w, &indent, argc - 4, argv + 4);
|
|
||||||
if (w & silent)
|
|
||||||
indent -= SUB_INDENT;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|||||||
55
src/symtab.c
55
src/symtab.c
@@ -295,42 +295,29 @@ static void
|
|||||||
complain_symbol_redeclared (symbol *s, const char *what, location first,
|
complain_symbol_redeclared (symbol *s, const char *what, location first,
|
||||||
location second)
|
location second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
|
||||||
locations_sort (&first, &second);
|
locations_sort (&first, &second);
|
||||||
complain_indent (&second, complaint, &i,
|
complain (&second, complaint, _("%s redeclaration for %s"), what, s->tag);
|
||||||
_("%s redeclaration for %s"), what, s->tag);
|
subcomplain (&first, complaint, _("previous declaration"));
|
||||||
i += SUB_INDENT;
|
|
||||||
complain_indent (&first, complaint, &i,
|
|
||||||
_("previous declaration"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
complain_semantic_type_redeclared (semantic_type *s, const char *what, location first,
|
complain_semantic_type_redeclared (semantic_type *s, const char *what, location first,
|
||||||
location second)
|
location second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
|
||||||
locations_sort (&first, &second);
|
locations_sort (&first, &second);
|
||||||
complain_indent (&second, complaint, &i,
|
complain (&second, complaint, _("%s redeclaration for <%s>"), what, s->tag);
|
||||||
_("%s redeclaration for <%s>"), what, s->tag);
|
subcomplain (&first, complaint, _("previous declaration"));
|
||||||
i += SUB_INDENT;
|
|
||||||
complain_indent (&first, complaint, &i,
|
|
||||||
_("previous declaration"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
complain_class_redeclared (symbol *sym, symbol_class class, location second)
|
complain_class_redeclared (symbol *sym, symbol_class class, location second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
complain (&second, complaint,
|
||||||
complain_indent (&second, complaint, &i,
|
class == token_sym
|
||||||
class == token_sym
|
? _("symbol %s redeclared as a token")
|
||||||
? _("symbol %s redeclared as a token")
|
: _("symbol %s redeclared as a nonterminal"), sym->tag);
|
||||||
: _("symbol %s redeclared as a nonterminal"), sym->tag);
|
|
||||||
if (!location_empty (sym->location))
|
if (!location_empty (sym->location))
|
||||||
{
|
subcomplain (&sym->location, complaint, _("previous definition"));
|
||||||
i += SUB_INDENT;
|
|
||||||
complain_indent (&sym->location, complaint, &i,
|
|
||||||
_("previous definition"));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const symbol *
|
static const symbol *
|
||||||
@@ -546,12 +533,10 @@ symbol_class_set (symbol *sym, symbol_class class, location loc, bool declaring)
|
|||||||
{
|
{
|
||||||
if (s->status == declared)
|
if (s->status == declared)
|
||||||
{
|
{
|
||||||
int i = 0;
|
complain (&loc, Wother,
|
||||||
complain_indent (&loc, Wother, &i,
|
_("symbol %s redeclared"), sym->tag);
|
||||||
_("symbol %s redeclared"), sym->tag);
|
subcomplain (&sym->location, Wother,
|
||||||
i += SUB_INDENT;
|
_("previous declaration"));
|
||||||
complain_indent (&sym->location, Wother, &i,
|
|
||||||
_("previous declaration"));
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
s->status = declared;
|
s->status = declared;
|
||||||
@@ -731,15 +716,13 @@ symbol_pack (symbol *this)
|
|||||||
static void
|
static void
|
||||||
complain_user_token_number_redeclared (int num, symbol *first, symbol *second)
|
complain_user_token_number_redeclared (int num, symbol *first, symbol *second)
|
||||||
{
|
{
|
||||||
int i = 0;
|
|
||||||
symbols_sort (&first, &second);
|
symbols_sort (&first, &second);
|
||||||
complain_indent (&second->location, complaint, &i,
|
complain (&second->location, complaint,
|
||||||
_("user token number %d redeclaration for %s"),
|
_("user token number %d redeclaration for %s"),
|
||||||
num, second->tag);
|
num, second->tag);
|
||||||
i += SUB_INDENT;
|
subcomplain (&first->location, complaint,
|
||||||
complain_indent (&first->location, complaint, &i,
|
_("previous declaration for %s"),
|
||||||
_("previous declaration for %s"),
|
first->tag);
|
||||||
first->tag);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*--------------------------------------------------.
|
/*--------------------------------------------------.
|
||||||
|
|||||||
@@ -183,7 +183,7 @@ AT_BISON_CHECK([-fcaret one.y], [1], [],
|
|||||||
[[one.y:11.13-18: error: only one %empty allowed per rule
|
[[one.y:11.13-18: error: only one %empty allowed per rule
|
||||||
11 | %empty {} %empty
|
11 | %empty {} %empty
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
one.y:11.3-8: previous declaration
|
one.y:11.3-8: note: previous declaration
|
||||||
11 | %empty {} %empty
|
11 | %empty {} %empty
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
one.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
one.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
@@ -193,7 +193,7 @@ AT_BISON_CHECK([-fcaret -u one.y], [1], [],
|
|||||||
[[one.y:11.13-18: error: only one %empty allowed per rule
|
[[one.y:11.13-18: error: only one %empty allowed per rule
|
||||||
11 | %empty {} %empty
|
11 | %empty {} %empty
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
one.y:11.3-8: previous declaration
|
one.y:11.3-8: note: previous declaration
|
||||||
11 | %empty {} %empty
|
11 | %empty {} %empty
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
bison: file 'one.y' was updated (backup: 'one.y~')
|
bison: file 'one.y' was updated (backup: 'one.y~')
|
||||||
|
|||||||
@@ -77,31 +77,31 @@ exp: %empty;
|
|||||||
[[input.y:9.12-14: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
[[input.y:9.12-14: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token FOO <warning>FOO</warning> FOO
|
9 | %token FOO <warning>FOO</warning> FOO
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:9.8-10: previous declaration
|
input.y:9.8-10: <note>note:</note> previous declaration
|
||||||
9 | %token <note>FOO</note> FOO FOO
|
9 | %token <note>FOO</note> FOO FOO
|
||||||
| <note>^~~</note>
|
| <note>^~~</note>
|
||||||
input.y:9.16-18: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
input.y:9.16-18: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token FOO FOO <warning>FOO</warning>
|
9 | %token FOO FOO <warning>FOO</warning>
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:9.8-10: previous declaration
|
input.y:9.8-10: <note>note:</note> previous declaration
|
||||||
9 | %token <note>FOO</note> FOO FOO
|
9 | %token <note>FOO</note> FOO FOO
|
||||||
| <note>^~~</note>
|
| <note>^~~</note>
|
||||||
input.y:10.8-10: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
input.y:10.8-10: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
10 | %token <warning>FOO</warning> FOO FOO
|
10 | %token <warning>FOO</warning> FOO FOO
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:9.8-10: previous declaration
|
input.y:9.8-10: <note>note:</note> previous declaration
|
||||||
9 | %token <note>FOO</note> FOO FOO
|
9 | %token <note>FOO</note> FOO FOO
|
||||||
| <note>^~~</note>
|
| <note>^~~</note>
|
||||||
input.y:10.13-15: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
input.y:10.13-15: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
10 | %token FOO <warning>FOO</warning> FOO
|
10 | %token FOO <warning>FOO</warning> FOO
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:9.8-10: previous declaration
|
input.y:9.8-10: <note>note:</note> previous declaration
|
||||||
9 | %token <note>FOO</note> FOO FOO
|
9 | %token <note>FOO</note> FOO FOO
|
||||||
| <note>^~~</note>
|
| <note>^~~</note>
|
||||||
input.y:10.18-20: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
input.y:10.18-20: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
10 | %token FOO FOO <warning>FOO</warning>
|
10 | %token FOO FOO <warning>FOO</warning>
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:9.8-10: previous declaration
|
input.y:9.8-10: <note>note:</note> previous declaration
|
||||||
9 | %token <note>FOO</note> FOO FOO
|
9 | %token <note>FOO</note> FOO FOO
|
||||||
| <note>^~~</note>
|
| <note>^~~</note>
|
||||||
]])
|
]])
|
||||||
@@ -296,7 +296,7 @@ exp:^M
|
|||||||
[[input.y:11.9-11: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
[[input.y:11.9-11: <warning>warning:</warning> symbol FOO redeclared [<warning>-Wother</warning>]
|
||||||
11 | %token
|
11 | %token
|
||||||
<warning>FOO</warning>
|
<warning>FOO</warning>
|
||||||
| <warning>^~~</warning>
|
| <warning>^~~</warning>
|
||||||
input.y:10.9-11: <note>note:</note> previous declaration
|
input.y:10.9-11: <note>note:</note> previous declaration
|
||||||
10 | %token
|
10 | %token
|
||||||
<note>FOO</note>
|
<note>FOO</note>
|
||||||
@@ -322,19 +322,19 @@ exp: ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|||||||
]],
|
]],
|
||||||
[0],
|
[0],
|
||||||
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
@@ -355,19 +355,19 @@ exp: ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|||||||
]],
|
]],
|
||||||
[0],
|
[0],
|
||||||
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEF...
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEF...
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEF</warning>...
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEF</warning>...
|
||||||
| <warning>^~~~~~</warning>
|
| <warning>^~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMNOPQRSTUVWXYZ ABCDEF...
|
||||||
@@ -388,19 +388,19 @@ exp: ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|||||||
]],
|
]],
|
||||||
[0],
|
[0],
|
||||||
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
[[input.y:9.36-61: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMN</warning>...
|
9 | %token ABCDEFGHIJKLMNOPQRSTUVWXYZ <warning>ABCDEFGHIJKLMN</warning>...
|
||||||
| <warning>^~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.64-89: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHI...
|
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning> ABCDEFGHI...
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
||||||
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
| <note>^~~~~~~~~~~~~~~~~~~~~~~~~~</note>
|
||||||
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
input.y:9.92-117: <warning>warning:</warning> symbol ABCDEFGHIJKLMNOPQRSTUVWXYZ redeclared [<warning>-Wother</warning>]
|
||||||
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
9 | ...TUVWXYZ <warning>ABCDEFGHIJKLMNOPQRSTUVWXYZ</warning>
|
||||||
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
| <warning>^~~~~~~~~~~~~~~~~~~~~~~~~~</warning>
|
||||||
input.y:9.8-33: <note>note:</note> previous declaration
|
input.y:9.8-33: <note>note:</note> previous declaration
|
||||||
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
9 | %token <note>ABCDEFGHIJKLMNOPQRSTUVWXYZ</note> ABCDEFGHIJKLMN...
|
||||||
|
|||||||
@@ -1661,9 +1661,9 @@ AT_BISON_OPTION_POPDEFS
|
|||||||
|
|
||||||
AT_BISON_CHECK([[-o glr-regr18.c -rall glr-regr18.y]], 1, [],
|
AT_BISON_CHECK([[-o glr-regr18.c -rall glr-regr18.y]], 1, [],
|
||||||
[[glr-regr18.y:28.18-24: error: result type clash on merge function 'merge': <type2> != <type1>
|
[[glr-regr18.y:28.18-24: error: result type clash on merge function 'merge': <type2> != <type1>
|
||||||
glr-regr18.y:27.18-24: previous declaration
|
glr-regr18.y:27.18-24: note: previous declaration
|
||||||
glr-regr18.y:29.13-19: error: result type clash on merge function 'merge': <type3> != <type2>
|
glr-regr18.y:29.13-19: error: result type clash on merge function 'merge': <type3> != <type2>
|
||||||
glr-regr18.y:28.18-24: previous declaration
|
glr-regr18.y:28.18-24: note: previous declaration
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
|
|||||||
106
tests/input.at
106
tests/input.at
@@ -707,19 +707,19 @@ AT_BISON_CHECK([-fcaret input.y], [0], [],
|
|||||||
[[input.y:1.12-14: warning: symbol FOO redeclared [-Wother]
|
[[input.y:1.12-14: warning: symbol FOO redeclared [-Wother]
|
||||||
1 | %token FOO FOO
|
1 | %token FOO FOO
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:1.8-10: previous declaration
|
input.y:1.8-10: note: previous declaration
|
||||||
1 | %token FOO FOO
|
1 | %token FOO FOO
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:2.15-17: warning: symbol BAR redeclared [-Wother]
|
input.y:2.15-17: warning: symbol BAR redeclared [-Wother]
|
||||||
2 | %token BAR 12 BAR 12
|
2 | %token BAR 12 BAR 12
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:2.8-10: previous declaration
|
input.y:2.8-10: note: previous declaration
|
||||||
2 | %token BAR 12 BAR 12
|
2 | %token BAR 12 BAR 12
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:3.14-16: warning: symbol EOF redeclared [-Wother]
|
input.y:3.14-16: warning: symbol EOF redeclared [-Wother]
|
||||||
3 | %token EOF 0 EOF 0
|
3 | %token EOF 0 EOF 0
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:3.8-10: previous declaration
|
input.y:3.8-10: note: previous declaration
|
||||||
3 | %token EOF 0 EOF 0
|
3 | %token EOF 0 EOF 0
|
||||||
| ^~~
|
| ^~~
|
||||||
]])
|
]])
|
||||||
@@ -747,13 +747,13 @@ AT_BISON_CHECK([-fcaret input.y], [1], [],
|
|||||||
[[input.y:2.8-10: error: symbol FOO redeclared as a nonterminal
|
[[input.y:2.8-10: error: symbol FOO redeclared as a nonterminal
|
||||||
2 | %nterm FOO BAR
|
2 | %nterm FOO BAR
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:1.8-10: previous definition
|
input.y:1.8-10: note: previous definition
|
||||||
1 | %token FOO
|
1 | %token FOO
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:3.8-10: error: symbol BAR redeclared as a token
|
input.y:3.8-10: error: symbol BAR redeclared as a token
|
||||||
3 | %token BAR
|
3 | %token BAR
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:2.12-14: previous definition
|
input.y:2.12-14: note: previous definition
|
||||||
2 | %nterm FOO BAR
|
2 | %nterm FOO BAR
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:4.8-12: error: symbol error redeclared as a nonterminal
|
input.y:4.8-12: error: symbol error redeclared as a nonterminal
|
||||||
@@ -795,37 +795,37 @@ AT_BISON_CHECK([-fcaret input.y], [1], [],
|
|||||||
[[input.y:1.13-29: error: %destructor redeclaration for <>
|
[[input.y:1.13-29: error: %destructor redeclaration for <>
|
||||||
1 | %destructor { destroy ($$); } <> <>
|
1 | %destructor { destroy ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
1 | %destructor { destroy ($$); } <> <>
|
1 | %destructor { destroy ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:2.10-24: error: %printer redeclaration for <>
|
input.y:2.10-24: error: %printer redeclaration for <>
|
||||||
2 | %printer { print ($$); } <> <>
|
2 | %printer { print ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
2 | %printer { print ($$); } <> <>
|
2 | %printer { print ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
input.y:4.13-29: error: %destructor redeclaration for <>
|
input.y:4.13-29: error: %destructor redeclaration for <>
|
||||||
4 | %destructor { destroy ($$); } <>
|
4 | %destructor { destroy ($$); } <>
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
1 | %destructor { destroy ($$); } <> <>
|
1 | %destructor { destroy ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:5.10-24: error: %printer redeclaration for <>
|
input.y:5.10-24: error: %printer redeclaration for <>
|
||||||
5 | %printer { print ($$); } <>
|
5 | %printer { print ($$); } <>
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
2 | %printer { print ($$); } <> <>
|
2 | %printer { print ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
input.y:11.13-29: error: %destructor redeclaration for <>
|
input.y:11.13-29: error: %destructor redeclaration for <>
|
||||||
11 | %destructor { destroy ($$); } <>;
|
11 | %destructor { destroy ($$); } <>;
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
1 | %destructor { destroy ($$); } <> <>
|
1 | %destructor { destroy ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~
|
||||||
input.y:12.10-24: error: %printer redeclaration for <>
|
input.y:12.10-24: error: %printer redeclaration for <>
|
||||||
12 | %printer { print ($$); } <>;
|
12 | %printer { print ($$); } <>;
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
2 | %printer { print ($$); } <> <>
|
2 | %printer { print ($$); } <> <>
|
||||||
| ^~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~
|
||||||
]])
|
]])
|
||||||
@@ -861,21 +861,21 @@ start: %empty;
|
|||||||
|
|
||||||
AT_BISON_CHECK([input.y], [1], [],
|
AT_BISON_CHECK([input.y], [1], [],
|
||||||
[[input.y:4.13-29: error: %destructor redeclaration for <field1>
|
[[input.y:4.13-29: error: %destructor redeclaration for <field1>
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
input.y:4.13-29: error: %destructor redeclaration for <field1>
|
input.y:4.13-29: error: %destructor redeclaration for <field1>
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
input.y:5.10-24: error: %printer redeclaration for <field2>
|
input.y:5.10-24: error: %printer redeclaration for <field2>
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
input.y:5.10-24: error: %printer redeclaration for <field2>
|
input.y:5.10-24: error: %printer redeclaration for <field2>
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
input.y:11.13-29: error: %destructor redeclaration for <field2>
|
input.y:11.13-29: error: %destructor redeclaration for <field2>
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
input.y:11.13-29: error: %destructor redeclaration for <field1>
|
input.y:11.13-29: error: %destructor redeclaration for <field1>
|
||||||
input.y:1.13-29: previous declaration
|
input.y:1.13-29: note: previous declaration
|
||||||
input.y:12.10-24: error: %printer redeclaration for <field2>
|
input.y:12.10-24: error: %printer redeclaration for <field2>
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
input.y:12.10-24: error: %printer redeclaration for <field1>
|
input.y:12.10-24: error: %printer redeclaration for <field1>
|
||||||
input.y:2.10-24: previous declaration
|
input.y:2.10-24: note: previous declaration
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
@@ -1135,7 +1135,7 @@ AT_BISON_CHECK([-fcaret input.y], [1], [],
|
|||||||
input.y:2.10-12: error: user token number 42 redeclaration for BAR
|
input.y:2.10-12: error: user token number 42 redeclaration for BAR
|
||||||
2 | BAR 42 "foo"
|
2 | BAR 42 "foo"
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:1.15-19: previous declaration for "foo"
|
input.y:1.15-19: note: previous declaration for "foo"
|
||||||
1 | %token FOO 42 "foo"
|
1 | %token FOO 42 "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1166,7 +1166,7 @@ exp: foo;
|
|||||||
[[input.y:3.7-11: error: %type redeclaration for foo
|
[[input.y:3.7-11: error: %type redeclaration for foo
|
||||||
3 | %type <baz> foo
|
3 | %type <baz> foo
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
input.y:2.7-11: previous declaration
|
input.y:2.7-11: note: previous declaration
|
||||||
2 | %type <bar> "foo"
|
2 | %type <bar> "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1180,7 +1180,7 @@ exp: foo;
|
|||||||
[[input.y:3.10-14: error: %printer redeclaration for foo
|
[[input.y:3.10-14: error: %printer redeclaration for foo
|
||||||
3 | %printer {baz} foo
|
3 | %printer {baz} foo
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
input.y:2.10-14: previous declaration
|
input.y:2.10-14: note: previous declaration
|
||||||
2 | %printer {bar} "foo"
|
2 | %printer {bar} "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1194,7 +1194,7 @@ exp: foo;
|
|||||||
[[input.y:3.13-17: error: %destructor redeclaration for foo
|
[[input.y:3.13-17: error: %destructor redeclaration for foo
|
||||||
3 | %destructor {baz} foo
|
3 | %destructor {baz} foo
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
input.y:2.13-17: previous declaration
|
input.y:2.13-17: note: previous declaration
|
||||||
2 | %destructor {bar} "foo"
|
2 | %destructor {bar} "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1208,7 +1208,7 @@ exp: foo;
|
|||||||
[[input.y:3.1-5: error: %left redeclaration for foo
|
[[input.y:3.1-5: error: %left redeclaration for foo
|
||||||
3 | %left foo
|
3 | %left foo
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
input.y:2.1-5: previous declaration
|
input.y:2.1-5: note: previous declaration
|
||||||
2 | %left "foo"
|
2 | %left "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1225,7 +1225,7 @@ exp: foo;
|
|||||||
[[input.y:2.1-5: error: %left redeclaration for foo
|
[[input.y:2.1-5: error: %left redeclaration for foo
|
||||||
2 | %left foo
|
2 | %left foo
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
input.y:1.1-5: previous declaration
|
input.y:1.1-5: note: previous declaration
|
||||||
1 | %left "foo"
|
1 | %left "foo"
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
]])
|
]])
|
||||||
@@ -1240,7 +1240,7 @@ exp: foo;
|
|||||||
[[input.y:2.10-11: error: %printer redeclaration for foo
|
[[input.y:2.10-11: error: %printer redeclaration for foo
|
||||||
2 | %printer {} foo
|
2 | %printer {} foo
|
||||||
| ^~
|
| ^~
|
||||||
input.y:1.10-11: previous declaration
|
input.y:1.10-11: note: previous declaration
|
||||||
1 | %printer {} "foo"
|
1 | %printer {} "foo"
|
||||||
| ^~
|
| ^~
|
||||||
]])
|
]])
|
||||||
@@ -1255,7 +1255,7 @@ exp: foo;
|
|||||||
[[input.y:2.13-14: error: %destructor redeclaration for foo
|
[[input.y:2.13-14: error: %destructor redeclaration for foo
|
||||||
2 | %destructor {} foo
|
2 | %destructor {} foo
|
||||||
| ^~
|
| ^~
|
||||||
input.y:1.13-14: previous declaration
|
input.y:1.13-14: note: previous declaration
|
||||||
1 | %destructor {} "foo"
|
1 | %destructor {} "foo"
|
||||||
| ^~
|
| ^~
|
||||||
]])
|
]])
|
||||||
@@ -1582,9 +1582,9 @@ start: DECIMAL_1 HEXADECIMAL_2;
|
|||||||
|
|
||||||
AT_BISON_CHECK([redecl.y], [1], [],
|
AT_BISON_CHECK([redecl.y], [1], [],
|
||||||
[[redecl.y:10.10-22: error: user token number 11259375 redeclaration for HEXADECIMAL_1
|
[[redecl.y:10.10-22: error: user token number 11259375 redeclaration for HEXADECIMAL_1
|
||||||
redecl.y:9.8-16: previous declaration for DECIMAL_1
|
redecl.y:9.8-16: note: previous declaration for DECIMAL_1
|
||||||
redecl.y:12.10-18: error: user token number 16702650 redeclaration for DECIMAL_2
|
redecl.y:12.10-18: error: user token number 16702650 redeclaration for DECIMAL_2
|
||||||
redecl.y:11.10-22: previous declaration for HEXADECIMAL_2
|
redecl.y:11.10-22: note: previous declaration for HEXADECIMAL_2
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_DATA_GRAMMAR([too-large.y],
|
AT_DATA_GRAMMAR([too-large.y],
|
||||||
@@ -1870,9 +1870,9 @@ start: %empty;
|
|||||||
|
|
||||||
AT_BISON_CHECK([[input-redefined.y]], [[1]], [],
|
AT_BISON_CHECK([[input-redefined.y]], [[1]], [],
|
||||||
[[input-redefined.y:2.1-20: warning: %define variable 'var' redefined [-Wother]
|
[[input-redefined.y:2.1-20: warning: %define variable 'var' redefined [-Wother]
|
||||||
input-redefined.y:1.1-20: previous definition
|
input-redefined.y:1.1-20: note: previous definition
|
||||||
input-redefined.y:3.2-21: error: %define variable 'var' redefined
|
input-redefined.y:3.2-21: error: %define variable 'var' redefined
|
||||||
input-redefined.y:2.1-20: previous definition
|
input-redefined.y:2.1-20: note: previous definition
|
||||||
input-redefined.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input-redefined.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
|
|
||||||
@@ -1928,7 +1928,7 @@ start: %empty;
|
|||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([[-Dvar=cmd-d input-dg.y]], [[1]], [],
|
AT_BISON_CHECK([[-Dvar=cmd-d input-dg.y]], [[1]], [],
|
||||||
[[input-dg.y:1.1-18: error: %define variable 'var' redefined
|
[[input-dg.y:1.1-18: error: %define variable 'var' redefined
|
||||||
<command line>:3: previous definition
|
<command line>:3: note: previous definition
|
||||||
input-dg.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input-dg.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
|
|
||||||
@@ -1941,7 +1941,7 @@ AT_BISON_CHECK([[-fcaret -Dvar=cmd-d input-dg.y]], [[1]], [],
|
|||||||
[[input-dg.y:1.1-18: error: %define variable 'var' redefined
|
[[input-dg.y:1.1-18: error: %define variable 'var' redefined
|
||||||
1 | %define var "gram"
|
1 | %define var "gram"
|
||||||
| ^~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~
|
||||||
<command line>:4: previous definition
|
<command line>:4: note: previous definition
|
||||||
input-dg.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input-dg.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
|
|
||||||
@@ -2064,9 +2064,9 @@ AT_BISON_CHECK([[-fcaret input.y]], [[1]], [[]],
|
|||||||
[[input.y:1.1-34: error: invalid value for %define variable 'lr.default-reduction': 'bogus'
|
[[input.y:1.1-34: error: invalid value for %define variable 'lr.default-reduction': 'bogus'
|
||||||
1 | %define lr.default-reduction bogus
|
1 | %define lr.default-reduction bogus
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
input.y:1.1-34: accepted value: 'most'
|
input.y:1.1-34: note: accepted value: 'most'
|
||||||
input.y:1.1-34: accepted value: 'consistent'
|
input.y:1.1-34: note: accepted value: 'consistent'
|
||||||
input.y:1.1-34: accepted value: 'accepting'
|
input.y:1.1-34: note: accepted value: 'accepting'
|
||||||
]])
|
]])
|
||||||
|
|
||||||
# Back-end.
|
# Back-end.
|
||||||
@@ -2079,9 +2079,9 @@ AT_BISON_CHECK([[-fcaret input.y]], [[1]], [[]],
|
|||||||
[[input.y:1.1-29: error: invalid value for %define variable 'api.push-pull': 'neither'
|
[[input.y:1.1-29: error: invalid value for %define variable 'api.push-pull': 'neither'
|
||||||
1 | %define api.push-pull neither
|
1 | %define api.push-pull neither
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
input.y:1.1-29: accepted value: 'pull'
|
input.y:1.1-29: note: accepted value: 'pull'
|
||||||
input.y:1.1-29: accepted value: 'push'
|
input.y:1.1-29: note: accepted value: 'push'
|
||||||
input.y:1.1-29: accepted value: 'both'
|
input.y:1.1-29: note: accepted value: 'both'
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
@@ -2376,14 +2376,14 @@ AT_BISON_CHECK([[-Dparse.lac=full -L c++ input.y]])
|
|||||||
AT_BISON_CHECK([[-Dparse.lac=unsupported input.y]],
|
AT_BISON_CHECK([[-Dparse.lac=unsupported input.y]],
|
||||||
[[1]], [],
|
[[1]], [],
|
||||||
[[<command line>:3: error: invalid value for %define variable 'parse.lac': 'unsupported'
|
[[<command line>:3: error: invalid value for %define variable 'parse.lac': 'unsupported'
|
||||||
<command line>:3: accepted value: 'full'
|
<command line>:3: note: accepted value: 'full'
|
||||||
<command line>:3: accepted value: 'none'
|
<command line>:3: note: accepted value: 'none'
|
||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([[-Dparse.lac=unsupported -L c++ input.y]],
|
AT_BISON_CHECK([[-Dparse.lac=unsupported -L c++ input.y]],
|
||||||
[[1]], [],
|
[[1]], [],
|
||||||
[[<command line>:3: error: invalid value for %define variable 'parse.lac': 'unsupported'
|
[[<command line>:3: error: invalid value for %define variable 'parse.lac': 'unsupported'
|
||||||
<command line>:3: accepted value: 'full'
|
<command line>:3: note: accepted value: 'full'
|
||||||
<command line>:3: accepted value: 'none'
|
<command line>:3: note: accepted value: 'none'
|
||||||
]])
|
]])
|
||||||
|
|
||||||
# parse.lac.* options are useless if LAC isn't actually activated.
|
# parse.lac.* options are useless if LAC isn't actually activated.
|
||||||
@@ -2508,9 +2508,9 @@ AT_TEST([[%union foo {};
|
|||||||
%define api.value.union.name foo]],
|
%define api.value.union.name foo]],
|
||||||
[0],
|
[0],
|
||||||
[[input.y:3.8-10: warning: %define variable 'api.value.union.name' redefined [-Wother]
|
[[input.y:3.8-10: warning: %define variable 'api.value.union.name' redefined [-Wother]
|
||||||
input.y:1.8-10: previous definition
|
input.y:1.8-10: note: previous definition
|
||||||
input.y:4.1-32: warning: %define variable 'api.value.union.name' redefined [-Wother]
|
input.y:4.1-32: warning: %define variable 'api.value.union.name' redefined [-Wother]
|
||||||
input.y:3.8-10: previous definition
|
input.y:3.8-10: note: previous definition
|
||||||
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
|
|
||||||
@@ -2679,7 +2679,7 @@ fix-it:"input.y":{12:1-12:11}:"%expect-rr"
|
|||||||
input.y:13.1-14: warning: deprecated directive: '%file-prefix =', use '%file-prefix' [-Wdeprecated]
|
input.y:13.1-14: warning: deprecated directive: '%file-prefix =', use '%file-prefix' [-Wdeprecated]
|
||||||
fix-it:"input.y":{13:1-13:15}:"%file-prefix"
|
fix-it:"input.y":{13:1-13:15}:"%file-prefix"
|
||||||
input.y:14.1-16.5: warning: duplicate directive: '%file-prefix\n =' [-Wother]
|
input.y:14.1-16.5: warning: duplicate directive: '%file-prefix\n =' [-Wother]
|
||||||
input.y:13.1-20: previous declaration
|
input.y:13.1-20: note: previous declaration
|
||||||
fix-it:"input.y":{14:1-16:6}:""
|
fix-it:"input.y":{14:1-16:6}:""
|
||||||
input.y:17.9-27: warning: deprecated directive: '%fixed-output_files', use '%output "y.tab.c"' [-Wdeprecated]
|
input.y:17.9-27: warning: deprecated directive: '%fixed-output_files', use '%output "y.tab.c"' [-Wdeprecated]
|
||||||
fix-it:"input.y":{17:2-17:21}:"%output \"y.tab.c\""
|
fix-it:"input.y":{17:2-17:21}:"%output \"y.tab.c\""
|
||||||
@@ -2702,10 +2702,10 @@ fix-it:"input.y":{25:1-25:13}:"%define api.pure"
|
|||||||
input.y:26.1-12: warning: deprecated directive: '%token_table', use '%token-table' [-Wdeprecated]
|
input.y:26.1-12: warning: deprecated directive: '%token_table', use '%token-table' [-Wdeprecated]
|
||||||
fix-it:"input.y":{26:1-26:13}:"%token-table"
|
fix-it:"input.y":{26:1-26:13}:"%token-table"
|
||||||
input.y:27.1-14: warning: %define variable 'parse.error' redefined [-Wother]
|
input.y:27.1-14: warning: %define variable 'parse.error' redefined [-Wother]
|
||||||
input.y:11.1-14: previous definition
|
input.y:11.1-14: note: previous definition
|
||||||
fix-it:"input.y":{27:1-27:15}:""
|
fix-it:"input.y":{27:1-27:15}:""
|
||||||
input.y:29.1-18: warning: duplicate directive: '%name-prefix "bar"' [-Wother]
|
input.y:29.1-18: warning: duplicate directive: '%name-prefix "bar"' [-Wother]
|
||||||
input.y:13.1-20: previous declaration
|
input.y:13.1-20: note: previous declaration
|
||||||
fix-it:"input.y":{29:1-29:19}:""
|
fix-it:"input.y":{29:1-29:19}:""
|
||||||
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
@@ -2788,9 +2788,9 @@ input.y:11.15-24: warning: deprecated directive: '%expect_rr', use '%expect-rr'
|
|||||||
input.y:12.15-24: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
|
input.y:12.15-24: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
|
||||||
input.y:13.1-14: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
|
input.y:13.1-14: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
|
||||||
input.y:13.16-29: warning: %define variable 'parse.error' redefined [-Wother]
|
input.y:13.16-29: warning: %define variable 'parse.error' redefined [-Wother]
|
||||||
input.y:13.1-14: previous definition
|
input.y:13.1-14: note: previous definition
|
||||||
input.y:14.16-29: warning: %define variable 'parse.error' redefined [-Wother]
|
input.y:14.16-29: warning: %define variable 'parse.error' redefined [-Wother]
|
||||||
input.y:13.16-29: previous definition
|
input.y:13.16-29: note: previous definition
|
||||||
input.y: error: reduce/reduce conflicts: 0 found, 42 expected
|
input.y: error: reduce/reduce conflicts: 0 found, 42 expected
|
||||||
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
@@ -2825,7 +2825,7 @@ AT_DATA_GRAMMAR([[input.y]],
|
|||||||
|
|
||||||
AT_BISON_CHECK([[input.y]], [[0]], [[]],
|
AT_BISON_CHECK([[input.y]], [[0]], [[]],
|
||||||
[[input.y:14.1-15.5: warning: duplicate directive: '%file-prefix' [-Wother]
|
[[input.y:14.1-15.5: warning: duplicate directive: '%file-prefix' [-Wother]
|
||||||
input.y:13.1-18: previous declaration
|
input.y:13.1-18: note: previous declaration
|
||||||
input.y: warning: %expect-rr applies only to GLR parsers [-Wother]
|
input.y: warning: %expect-rr applies only to GLR parsers [-Wother]
|
||||||
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
input.y: warning: fix-its can be applied. Rerun with option '--update'. [-Wother]
|
||||||
]])
|
]])
|
||||||
@@ -2875,13 +2875,13 @@ AT_BISON_CHECK([[-fcaret input.y]], [[1]], [[]],
|
|||||||
[[input.y:10.8-10: error: character literals cannot be used together with api.token.raw
|
[[input.y:10.8-10: error: character literals cannot be used together with api.token.raw
|
||||||
10 | %token 'a'
|
10 | %token 'a'
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:9.1-21: definition of api.token.raw
|
input.y:9.1-21: note: definition of api.token.raw
|
||||||
9 | %define api.token.raw
|
9 | %define api.token.raw
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~
|
||||||
input.y:12.6-8: error: character literals cannot be used together with api.token.raw
|
input.y:12.6-8: error: character literals cannot be used together with api.token.raw
|
||||||
12 | exp: 'b' "c" {}
|
12 | exp: 'b' "c" {}
|
||||||
| ^~~
|
| ^~~
|
||||||
input.y:9.1-21: definition of api.token.raw
|
input.y:9.1-21: note: definition of api.token.raw
|
||||||
9 | %define api.token.raw
|
9 | %define api.token.raw
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~
|
||||||
]])
|
]])
|
||||||
|
|||||||
@@ -255,19 +255,19 @@ AT_BISON_CHECK([-fcaret -o test.c test.y], 1, [],
|
|||||||
[[test.y:52.51-60: error: invalid reference: '$<ival>lo9'
|
[[test.y:52.51-60: error: invalid reference: '$<ival>lo9'
|
||||||
52 | | exp[x] '+' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>lo9 + $r; }
|
52 | | exp[x] '+' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>lo9 + $r; }
|
||||||
| ^~~~~~~~~~
|
| ^~~~~~~~~~
|
||||||
test.y:52.3-68: symbol not found in production: lo9
|
test.y:52.3-68: note: symbol not found in production: lo9
|
||||||
52 | | exp[x] '+' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>lo9 + $r; }
|
52 | | exp[x] '+' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>lo9 + $r; }
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:53.51-60: warning: misleading reference: '$<ival>exp' [-Wother]
|
test.y:53.51-60: warning: misleading reference: '$<ival>exp' [-Wother]
|
||||||
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
||||||
| ^~~~~~~~~~
|
| ^~~~~~~~~~
|
||||||
test.y:44.1-3: refers to: $exp at $$
|
test.y:44.1-3: note: refers to: $exp at $$
|
||||||
44 | exp:
|
44 | exp:
|
||||||
| ^~~
|
| ^~~
|
||||||
test.y:53.7: possibly meant: $x, hiding $exp at $1
|
test.y:53.7: note: possibly meant: $x, hiding $exp at $1
|
||||||
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
||||||
| ^
|
| ^
|
||||||
test.y:53.41: possibly meant: $r, hiding $exp at $4
|
test.y:53.41: note: possibly meant: $r, hiding $exp at $4
|
||||||
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
53 | | exp[x] '-' { $<ival>$ = $x; } [l] exp[r] { $$ = $<ival>exp - $r; }
|
||||||
| ^
|
| ^
|
||||||
test.y:54.51-52: error: $l of 'exp' has no declared type
|
test.y:54.51-52: error: $l of 'exp' has no declared type
|
||||||
@@ -276,13 +276,13 @@ test.y:54.51-52: error: $l of 'exp' has no declared type
|
|||||||
test.y:57.40-43: error: invalid reference: '$r12'
|
test.y:57.40-43: error: invalid reference: '$r12'
|
||||||
57 | | exp[l] '^' exp[r] { $$ = power ($l, $r12); }
|
57 | | exp[l] '^' exp[r] { $$ = power ($l, $r12); }
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:57.3-47: symbol not found in production: r12
|
test.y:57.3-47: note: symbol not found in production: r12
|
||||||
57 | | exp[l] '^' exp[r] { $$ = power ($l, $r12); }
|
57 | | exp[l] '^' exp[r] { $$ = power ($l, $r12); }
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:58.29-33: error: invalid reference: '$expo'
|
test.y:58.29-33: error: invalid reference: '$expo'
|
||||||
58 | | '(' exp ')' { $$ = $expo; }
|
58 | | '(' exp ')' { $$ = $expo; }
|
||||||
| ^~~~~
|
| ^~~~~
|
||||||
test.y:58.3-46: symbol not found in production: expo
|
test.y:58.3-46: note: symbol not found in production: expo
|
||||||
58 | | '(' exp ')' { $$ = $expo; }
|
58 | | '(' exp ')' { $$ = $expo; }
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
]])
|
]])
|
||||||
@@ -305,8 +305,8 @@ foo.bar: '2'
|
|||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([-o test.c test.y], 0, [],
|
AT_BISON_CHECK([-o test.c test.y], 0, [],
|
||||||
[[test.y:11.22-29: warning: misleading reference: '$foo.bar' [-Wother]
|
[[test.y:11.22-29: warning: misleading reference: '$foo.bar' [-Wother]
|
||||||
test.y:11.8-10: refers to: $foo at $1
|
test.y:11.8-10: note: refers to: $foo at $1
|
||||||
test.y:11.12-18: possibly meant: $[foo.bar] at $2
|
test.y:11.12-18: note: possibly meant: $[foo.bar] at $2
|
||||||
]])
|
]])
|
||||||
AT_BISON_OPTION_POPDEFS
|
AT_BISON_OPTION_POPDEFS
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
@@ -383,162 +383,162 @@ factor: '(' expr ')' { $$ = $2; }
|
|||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([-o test.c test.y], 1, [],
|
AT_BISON_CHECK([-o test.c test.y], 1, [],
|
||||||
[[test.y:24.36-41: error: invalid reference: '$cond1'
|
[[test.y:24.36-41: error: invalid reference: '$cond1'
|
||||||
test.y:23.11-24.62: symbol not found in production: cond1
|
test.y:23.11-24.62: note: symbol not found in production: cond1
|
||||||
test.y:26.43-53: error: invalid reference: '$stmt.field'
|
test.y:26.43-53: error: invalid reference: '$stmt.field'
|
||||||
test.y:25.11-26.60: symbol not found in production: stmt
|
test.y:25.11-26.60: note: symbol not found in production: stmt
|
||||||
test.y:25.35-38: possibly meant: $then.field, hiding $stmt.field at $4
|
test.y:25.35-38: note: possibly meant: $then.field, hiding $stmt.field at $4
|
||||||
test.y:28.43-52: error: invalid reference: '$stmt.list'
|
test.y:28.43-52: error: invalid reference: '$stmt.list'
|
||||||
test.y:27.11-28.59: symbol not found in production: stmt
|
test.y:27.11-28.59: note: symbol not found in production: stmt
|
||||||
test.y:27.30-38: possibly meant: $[stmt.list] at $4
|
test.y:27.30-38: note: possibly meant: $[stmt.list] at $4
|
||||||
test.y:30.43-46: error: ambiguous reference: '$xyz'
|
test.y:30.43-46: error: ambiguous reference: '$xyz'
|
||||||
test.y:29.35-37: refers to: $xyz at $4
|
test.y:29.35-37: note: refers to: $xyz at $4
|
||||||
test.y:29.50-52: refers to: $xyz at $6
|
test.y:29.50-52: note: refers to: $xyz at $6
|
||||||
test.y:32.43-52: error: invalid reference: '$stmt.list'
|
test.y:32.43-52: error: invalid reference: '$stmt.list'
|
||||||
test.y:31.11-32.63: symbol not found in production: stmt
|
test.y:31.11-32.63: note: symbol not found in production: stmt
|
||||||
test.y:31.40-43: possibly meant: $then, hiding $[stmt.list] at $4
|
test.y:31.40-43: note: possibly meant: $then, hiding $[stmt.list] at $4
|
||||||
test.y:31.61-64: possibly meant: $else, hiding $[stmt.list] at $6
|
test.y:31.61-64: note: possibly meant: $else, hiding $[stmt.list] at $6
|
||||||
test.y:34.43-58: error: invalid reference: '$stmt.list.field'
|
test.y:34.43-58: error: invalid reference: '$stmt.list.field'
|
||||||
test.y:33.11-34.69: symbol not found in production: stmt
|
test.y:33.11-34.69: note: symbol not found in production: stmt
|
||||||
test.y:33.40-43: possibly meant: $then.field, hiding $[stmt.list].field at $4
|
test.y:33.40-43: note: possibly meant: $then.field, hiding $[stmt.list].field at $4
|
||||||
test.y:33.61-64: possibly meant: $else.field, hiding $[stmt.list].field at $6
|
test.y:33.61-64: note: possibly meant: $else.field, hiding $[stmt.list].field at $6
|
||||||
test.y:36.43-54: error: invalid reference: '$[stmt.list]'
|
test.y:36.43-54: error: invalid reference: '$[stmt.list]'
|
||||||
test.y:35.11-36.71: symbol not found in production: stmt.list
|
test.y:35.11-36.71: note: symbol not found in production: stmt.list
|
||||||
test.y:35.40-43: possibly meant: $then, hiding $[stmt.list] at $4
|
test.y:35.40-43: note: possibly meant: $then, hiding $[stmt.list] at $4
|
||||||
test.y:35.61-64: possibly meant: $else, hiding $[stmt.list] at $6
|
test.y:35.61-64: note: possibly meant: $else, hiding $[stmt.list] at $6
|
||||||
test.y:38.43-49: error: invalid reference: '$then.1'
|
test.y:38.43-49: error: invalid reference: '$then.1'
|
||||||
test.y:37.11-38.60: symbol not found in production: then
|
test.y:37.11-38.60: note: symbol not found in production: then
|
||||||
test.y:37.40-45: possibly meant: $[then.1] at $4
|
test.y:37.40-45: note: possibly meant: $[then.1] at $4
|
||||||
test.y:40.43-55: error: invalid reference: '$then.1.field'
|
test.y:40.43-55: error: invalid reference: '$then.1.field'
|
||||||
test.y:39.11-40.66: symbol not found in production: then
|
test.y:39.11-40.66: note: symbol not found in production: then
|
||||||
test.y:39.40-45: possibly meant: $[then.1].field at $4
|
test.y:39.40-45: note: possibly meant: $[then.1].field at $4
|
||||||
test.y:42.44-50: error: invalid reference: '$stmt.x'
|
test.y:42.44-50: error: invalid reference: '$stmt.x'
|
||||||
test.y:41.12-42.57: symbol not found in production: stmt
|
test.y:41.12-42.57: note: symbol not found in production: stmt
|
||||||
test.y:41.36-41: possibly meant: $[stmt.x].x, hiding $stmt.x at $4
|
test.y:41.36-41: note: possibly meant: $[stmt.x].x, hiding $stmt.x at $4
|
||||||
test.y:41.36-41: possibly meant: $[stmt.x] at $4
|
test.y:41.36-41: note: possibly meant: $[stmt.x] at $4
|
||||||
test.y:44.13-22: error: invalid reference: '$if-stmt-a'
|
test.y:44.13-22: error: invalid reference: '$if-stmt-a'
|
||||||
test.y:43.12-44.59: symbol not found in production: if
|
test.y:43.12-44.59: note: symbol not found in production: if
|
||||||
test.y:43.1-9: possibly meant: $[if-stmt-a] at $$
|
test.y:43.1-9: note: possibly meant: $[if-stmt-a] at $$
|
||||||
test.y:46.46-54: error: invalid reference: '$then-a.f'
|
test.y:46.46-54: error: invalid reference: '$then-a.f'
|
||||||
test.y:45.12-46.65: symbol not found in production: then
|
test.y:45.12-46.65: note: symbol not found in production: then
|
||||||
test.y:45.41-46: possibly meant: $[then-a].f at $4
|
test.y:45.41-46: note: possibly meant: $[then-a].f at $4
|
||||||
]])
|
]])
|
||||||
|
|
||||||
AT_BISON_CHECK([-fcaret -o test.c test.y], 1, [],
|
AT_BISON_CHECK([-fcaret -o test.c test.y], 1, [],
|
||||||
[[test.y:24.36-41: error: invalid reference: '$cond1'
|
[[test.y:24.36-41: error: invalid reference: '$cond1'
|
||||||
24 | { $if_stmt1 = new IfStmt($cond1, $then.f1, $else); };
|
24 | { $if_stmt1 = new IfStmt($cond1, $then.f1, $else); };
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
test.y:23.11-24.62: symbol not found in production: cond1
|
test.y:23.11-24.62: note: symbol not found in production: cond1
|
||||||
23 | if_stmt1: IF expr[cond] THEN stmt[then] ELSE stmt.list[else] FI
|
23 | if_stmt1: IF expr[cond] THEN stmt[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:26.43-53: error: invalid reference: '$stmt.field'
|
test.y:26.43-53: error: invalid reference: '$stmt.field'
|
||||||
26 | { $if_stmt2 = new IfStmt($cond, $stmt.field, 0); };
|
26 | { $if_stmt2 = new IfStmt($cond, $stmt.field, 0); };
|
||||||
| ^~~~~~~~~~~
|
| ^~~~~~~~~~~
|
||||||
test.y:25.11-26.60: symbol not found in production: stmt
|
test.y:25.11-26.60: note: symbol not found in production: stmt
|
||||||
25 | if_stmt2: IF expr[cond] THEN stmt[then] FI
|
25 | if_stmt2: IF expr[cond] THEN stmt[then] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:25.35-38: possibly meant: $then.field, hiding $stmt.field at $4
|
test.y:25.35-38: note: possibly meant: $then.field, hiding $stmt.field at $4
|
||||||
25 | if_stmt2: IF expr[cond] THEN stmt[then] FI
|
25 | if_stmt2: IF expr[cond] THEN stmt[then] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:28.43-52: error: invalid reference: '$stmt.list'
|
test.y:28.43-52: error: invalid reference: '$stmt.list'
|
||||||
28 | { $if_stmt3 = new IfStmt($cond, $stmt.list, 0); };
|
28 | { $if_stmt3 = new IfStmt($cond, $stmt.list, 0); };
|
||||||
| ^~~~~~~~~~
|
| ^~~~~~~~~~
|
||||||
test.y:27.11-28.59: symbol not found in production: stmt
|
test.y:27.11-28.59: note: symbol not found in production: stmt
|
||||||
27 | if_stmt3: IF expr[cond] THEN stmt.list FI
|
27 | if_stmt3: IF expr[cond] THEN stmt.list FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:27.30-38: possibly meant: $[stmt.list] at $4
|
test.y:27.30-38: note: possibly meant: $[stmt.list] at $4
|
||||||
27 | if_stmt3: IF expr[cond] THEN stmt.list FI
|
27 | if_stmt3: IF expr[cond] THEN stmt.list FI
|
||||||
| ^~~~~~~~~
|
| ^~~~~~~~~
|
||||||
test.y:30.43-46: error: ambiguous reference: '$xyz'
|
test.y:30.43-46: error: ambiguous reference: '$xyz'
|
||||||
30 | { $if_stmt4 = new IfStmt($cond, $xyz, $cond); };
|
30 | { $if_stmt4 = new IfStmt($cond, $xyz, $cond); };
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:29.35-37: refers to: $xyz at $4
|
test.y:29.35-37: note: refers to: $xyz at $4
|
||||||
29 | if_stmt4: IF expr[cond] THEN stmt[xyz] ELSE stmt[xyz] FI
|
29 | if_stmt4: IF expr[cond] THEN stmt[xyz] ELSE stmt[xyz] FI
|
||||||
| ^~~
|
| ^~~
|
||||||
test.y:29.50-52: refers to: $xyz at $6
|
test.y:29.50-52: note: refers to: $xyz at $6
|
||||||
29 | if_stmt4: IF expr[cond] THEN stmt[xyz] ELSE stmt[xyz] FI
|
29 | if_stmt4: IF expr[cond] THEN stmt[xyz] ELSE stmt[xyz] FI
|
||||||
| ^~~
|
| ^~~
|
||||||
test.y:32.43-52: error: invalid reference: '$stmt.list'
|
test.y:32.43-52: error: invalid reference: '$stmt.list'
|
||||||
32 | { $if_stmt5 = new IfStmt($cond, $stmt.list, $else); };
|
32 | { $if_stmt5 = new IfStmt($cond, $stmt.list, $else); };
|
||||||
| ^~~~~~~~~~
|
| ^~~~~~~~~~
|
||||||
test.y:31.11-32.63: symbol not found in production: stmt
|
test.y:31.11-32.63: note: symbol not found in production: stmt
|
||||||
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:31.40-43: possibly meant: $then, hiding $[stmt.list] at $4
|
test.y:31.40-43: note: possibly meant: $then, hiding $[stmt.list] at $4
|
||||||
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:31.61-64: possibly meant: $else, hiding $[stmt.list] at $6
|
test.y:31.61-64: note: possibly meant: $else, hiding $[stmt.list] at $6
|
||||||
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
31 | if_stmt5: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:34.43-58: error: invalid reference: '$stmt.list.field'
|
test.y:34.43-58: error: invalid reference: '$stmt.list.field'
|
||||||
34 | { $if_stmt6 = new IfStmt($cond, $stmt.list.field, $else); };
|
34 | { $if_stmt6 = new IfStmt($cond, $stmt.list.field, $else); };
|
||||||
| ^~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~
|
||||||
test.y:33.11-34.69: symbol not found in production: stmt
|
test.y:33.11-34.69: note: symbol not found in production: stmt
|
||||||
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:33.40-43: possibly meant: $then.field, hiding $[stmt.list].field at $4
|
test.y:33.40-43: note: possibly meant: $then.field, hiding $[stmt.list].field at $4
|
||||||
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:33.61-64: possibly meant: $else.field, hiding $[stmt.list].field at $6
|
test.y:33.61-64: note: possibly meant: $else.field, hiding $[stmt.list].field at $6
|
||||||
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
33 | if_stmt6: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:36.43-54: error: invalid reference: '$[stmt.list]'
|
test.y:36.43-54: error: invalid reference: '$[stmt.list]'
|
||||||
36 | { $if_stmt7 = new IfStmt($cond, $[stmt.list].field, $else); };
|
36 | { $if_stmt7 = new IfStmt($cond, $[stmt.list].field, $else); };
|
||||||
| ^~~~~~~~~~~~
|
| ^~~~~~~~~~~~
|
||||||
test.y:35.11-36.71: symbol not found in production: stmt.list
|
test.y:35.11-36.71: note: symbol not found in production: stmt.list
|
||||||
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:35.40-43: possibly meant: $then, hiding $[stmt.list] at $4
|
test.y:35.40-43: note: possibly meant: $then, hiding $[stmt.list] at $4
|
||||||
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:35.61-64: possibly meant: $else, hiding $[stmt.list] at $6
|
test.y:35.61-64: note: possibly meant: $else, hiding $[stmt.list] at $6
|
||||||
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
35 | if_stmt7: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~
|
| ^~~~
|
||||||
test.y:38.43-49: error: invalid reference: '$then.1'
|
test.y:38.43-49: error: invalid reference: '$then.1'
|
||||||
38 | { $if_stmt8 = new IfStmt($cond, $then.1, $else); };
|
38 | { $if_stmt8 = new IfStmt($cond, $then.1, $else); };
|
||||||
| ^~~~~~~
|
| ^~~~~~~
|
||||||
test.y:37.11-38.60: symbol not found in production: then
|
test.y:37.11-38.60: note: symbol not found in production: then
|
||||||
37 | if_stmt8: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
37 | if_stmt8: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:37.40-45: possibly meant: $[then.1] at $4
|
test.y:37.40-45: note: possibly meant: $[then.1] at $4
|
||||||
37 | if_stmt8: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
37 | if_stmt8: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
test.y:40.43-55: error: invalid reference: '$then.1.field'
|
test.y:40.43-55: error: invalid reference: '$then.1.field'
|
||||||
40 | { $if_stmt9 = new IfStmt($cond, $then.1.field, $else); };
|
40 | { $if_stmt9 = new IfStmt($cond, $then.1.field, $else); };
|
||||||
| ^~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~
|
||||||
test.y:39.11-40.66: symbol not found in production: then
|
test.y:39.11-40.66: note: symbol not found in production: then
|
||||||
39 | if_stmt9: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
39 | if_stmt9: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:39.40-45: possibly meant: $[then.1].field at $4
|
test.y:39.40-45: note: possibly meant: $[then.1].field at $4
|
||||||
39 | if_stmt9: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
39 | if_stmt9: IF expr[cond] THEN stmt.list[then.1] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
test.y:42.44-50: error: invalid reference: '$stmt.x'
|
test.y:42.44-50: error: invalid reference: '$stmt.x'
|
||||||
42 | { $if_stmt10 = new IfStmt($cond, $stmt.x, 0); };
|
42 | { $if_stmt10 = new IfStmt($cond, $stmt.x, 0); };
|
||||||
| ^~~~~~~
|
| ^~~~~~~
|
||||||
test.y:41.12-42.57: symbol not found in production: stmt
|
test.y:41.12-42.57: note: symbol not found in production: stmt
|
||||||
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:41.36-41: possibly meant: $[stmt.x].x, hiding $stmt.x at $4
|
test.y:41.36-41: note: possibly meant: $[stmt.x].x, hiding $stmt.x at $4
|
||||||
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
test.y:41.36-41: possibly meant: $[stmt.x] at $4
|
test.y:41.36-41: note: possibly meant: $[stmt.x] at $4
|
||||||
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
41 | if_stmt10: IF expr[cond] THEN stmt[stmt.x] FI
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
test.y:44.13-22: error: invalid reference: '$if-stmt-a'
|
test.y:44.13-22: error: invalid reference: '$if-stmt-a'
|
||||||
44 | { $if-stmt-a = new IfStmt($cond, $then, $else); };
|
44 | { $if-stmt-a = new IfStmt($cond, $then, $else); };
|
||||||
| ^~~~~~~~~~
|
| ^~~~~~~~~~
|
||||||
test.y:43.12-44.59: symbol not found in production: if
|
test.y:43.12-44.59: note: symbol not found in production: if
|
||||||
43 | if-stmt-a: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
43 | if-stmt-a: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:43.1-9: possibly meant: $[if-stmt-a] at $$
|
test.y:43.1-9: note: possibly meant: $[if-stmt-a] at $$
|
||||||
43 | if-stmt-a: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
43 | if-stmt-a: IF expr[cond] THEN stmt.list[then] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~
|
| ^~~~~~~~~
|
||||||
test.y:46.46-54: error: invalid reference: '$then-a.f'
|
test.y:46.46-54: error: invalid reference: '$then-a.f'
|
||||||
46 | { $[if-stmt-b] = new IfStmt($cond, $then-a.f, $else); };
|
46 | { $[if-stmt-b] = new IfStmt($cond, $then-a.f, $else); };
|
||||||
| ^~~~~~~~~
|
| ^~~~~~~~~
|
||||||
test.y:45.12-46.65: symbol not found in production: then
|
test.y:45.12-46.65: note: symbol not found in production: then
|
||||||
45 | if-stmt-b: IF expr[cond] THEN if-stmt-a[then-a] ELSE stmt.list[else] FI
|
45 | if-stmt-b: IF expr[cond] THEN if-stmt-a[then-a] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
test.y:45.41-46: possibly meant: $[then-a].f at $4
|
test.y:45.41-46: note: possibly meant: $[then-a].f at $4
|
||||||
45 | if-stmt-b: IF expr[cond] THEN if-stmt-a[then-a] ELSE stmt.list[else] FI
|
45 | if-stmt-b: IF expr[cond] THEN if-stmt-a[then-a] ELSE stmt.list[else] FI
|
||||||
| ^~~~~~
|
| ^~~~~~
|
||||||
]])
|
]])
|
||||||
@@ -675,37 +675,37 @@ sym_b: 'b';
|
|||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([-o test.c test.y], 1, [],
|
AT_BISON_CHECK([-o test.c test.y], 1, [],
|
||||||
[[test.y:12.22-31: error: invalid reference: '$sym.field'
|
[[test.y:12.22-31: error: invalid reference: '$sym.field'
|
||||||
test.y:12.3-35: symbol not found in production: sym
|
test.y:12.3-35: note: symbol not found in production: sym
|
||||||
test.y:13.22-35: error: invalid reference: '$<aa>sym.field'
|
test.y:13.22-35: error: invalid reference: '$<aa>sym.field'
|
||||||
test.y:13.3-39: symbol not found in production: sym
|
test.y:13.3-39: note: symbol not found in production: sym
|
||||||
test.y:14.22-33: error: invalid reference: '$[sym.field]'
|
test.y:14.22-33: error: invalid reference: '$[sym.field]'
|
||||||
test.y:14.3-37: symbol not found in production: sym.field
|
test.y:14.3-37: note: symbol not found in production: sym.field
|
||||||
test.y:15.22-37: error: invalid reference: '$<aa>[sym.field]'
|
test.y:15.22-37: error: invalid reference: '$<aa>[sym.field]'
|
||||||
test.y:15.3-41: symbol not found in production: sym.field
|
test.y:15.3-41: note: symbol not found in production: sym.field
|
||||||
test.y:16.22-25: error: invalid reference: '$sym'
|
test.y:16.22-25: error: invalid reference: '$sym'
|
||||||
test.y:16.3-29: symbol not found in production: sym
|
test.y:16.3-29: note: symbol not found in production: sym
|
||||||
test.y:17.22-29: error: invalid reference: '$<aa>sym'
|
test.y:17.22-29: error: invalid reference: '$<aa>sym'
|
||||||
test.y:17.3-33: symbol not found in production: sym
|
test.y:17.3-33: note: symbol not found in production: sym
|
||||||
test.y:18.22-27: error: invalid reference: '$[sym]'
|
test.y:18.22-27: error: invalid reference: '$[sym]'
|
||||||
test.y:18.3-65: symbol not found in production before $3: sym
|
test.y:18.3-65: note: symbol not found in production before $3: sym
|
||||||
test.y:18.52-61: error: invalid reference: '$<aa>[sym]'
|
test.y:18.52-61: error: invalid reference: '$<aa>[sym]'
|
||||||
test.y:18.3-65: symbol not found in production: sym
|
test.y:18.3-65: note: symbol not found in production: sym
|
||||||
test.y:22.22-31: error: invalid reference: '$sym-field'
|
test.y:22.22-31: error: invalid reference: '$sym-field'
|
||||||
test.y:22.3-35: symbol not found in production: sym
|
test.y:22.3-35: note: symbol not found in production: sym
|
||||||
test.y:23.22-35: error: invalid reference: '$<aa>sym-field'
|
test.y:23.22-35: error: invalid reference: '$<aa>sym-field'
|
||||||
test.y:23.3-39: symbol not found in production: sym
|
test.y:23.3-39: note: symbol not found in production: sym
|
||||||
test.y:24.22-33: error: invalid reference: '$[sym-field]'
|
test.y:24.22-33: error: invalid reference: '$[sym-field]'
|
||||||
test.y:24.3-37: symbol not found in production: sym-field
|
test.y:24.3-37: note: symbol not found in production: sym-field
|
||||||
test.y:25.22-37: error: invalid reference: '$<aa>[sym-field]'
|
test.y:25.22-37: error: invalid reference: '$<aa>[sym-field]'
|
||||||
test.y:25.3-41: symbol not found in production: sym-field
|
test.y:25.3-41: note: symbol not found in production: sym-field
|
||||||
test.y:26.22-25: error: invalid reference: '$sym'
|
test.y:26.22-25: error: invalid reference: '$sym'
|
||||||
test.y:26.3-29: symbol not found in production: sym
|
test.y:26.3-29: note: symbol not found in production: sym
|
||||||
test.y:27.22-29: error: invalid reference: '$<aa>sym'
|
test.y:27.22-29: error: invalid reference: '$<aa>sym'
|
||||||
test.y:27.3-33: symbol not found in production: sym
|
test.y:27.3-33: note: symbol not found in production: sym
|
||||||
test.y:28.22-27: error: invalid reference: '$[sym]'
|
test.y:28.22-27: error: invalid reference: '$[sym]'
|
||||||
test.y:28.3-65: symbol not found in production before $3: sym
|
test.y:28.3-65: note: symbol not found in production before $3: sym
|
||||||
test.y:28.52-61: error: invalid reference: '$<aa>[sym]'
|
test.y:28.52-61: error: invalid reference: '$<aa>[sym]'
|
||||||
test.y:28.3-65: symbol not found in production: sym
|
test.y:28.3-65: note: symbol not found in production: sym
|
||||||
]])
|
]])
|
||||||
AT_BISON_OPTION_POPDEFS
|
AT_BISON_OPTION_POPDEFS
|
||||||
AT_CLEANUP
|
AT_CLEANUP
|
||||||
@@ -724,10 +724,10 @@ start:
|
|||||||
]])
|
]])
|
||||||
AT_BISON_CHECK([[test.y]], [[1]], [],
|
AT_BISON_CHECK([[test.y]], [[1]], [],
|
||||||
[[test.y:4.12-18: error: invalid reference: '$.field'
|
[[test.y:4.12-18: error: invalid reference: '$.field'
|
||||||
test.y:4.13: syntax error after '$', expecting integer, letter, '_', '@<:@', or '$'
|
test.y:4.13: note: syntax error after '$', expecting integer, letter, '_', '@<:@', or '$'
|
||||||
test.y:4.3-8: possibly meant: $[.field] at $1
|
test.y:4.3-8: note: possibly meant: $[.field] at $1
|
||||||
test.y:5.12-18: error: invalid reference: '@.field'
|
test.y:5.12-18: error: invalid reference: '@.field'
|
||||||
test.y:5.13: syntax error after '@', expecting integer, letter, '_', '@<:@', or '$'
|
test.y:5.13: note: syntax error after '@', expecting integer, letter, '_', '@<:@', or '$'
|
||||||
]])
|
]])
|
||||||
AT_DATA([[test.y]],
|
AT_DATA([[test.y]],
|
||||||
[[
|
[[
|
||||||
|
|||||||
@@ -400,7 +400,7 @@ AT_BISON_CHECK([-fcaret -o input.c input.y], [[0]], [[]],
|
|||||||
[[input.y:22.8-14: warning: symbol SPECIAL redeclared [-Wother]
|
[[input.y:22.8-14: warning: symbol SPECIAL redeclared [-Wother]
|
||||||
22 | %token SPECIAL "\\\'\?\"\a\b\f\n\r\t\v\001\201\x001\x000081??!"
|
22 | %token SPECIAL "\\\'\?\"\a\b\f\n\r\t\v\001\201\x001\x000081??!"
|
||||||
| ^~~~~~~
|
| ^~~~~~~
|
||||||
input.y:21.8-14: previous declaration
|
input.y:21.8-14: note: previous declaration
|
||||||
21 | %token SPECIAL "\\\'\?\"\a\b\f\n\r\t\v\001\201\x001\x000081??!"
|
21 | %token SPECIAL "\\\'\?\"\a\b\f\n\r\t\v\001\201\x001\x000081??!"
|
||||||
| ^~~~~~~
|
| ^~~~~~~
|
||||||
input.y:22.16-63: warning: symbol "\\'?\"\a\b\f\n\r\t\v\001\201\001\201??!" used more than once as a literal string [-Wother]
|
input.y:22.16-63: warning: symbol "\\'?\"\a\b\f\n\r\t\v\001\201\001\201??!" used more than once as a literal string [-Wother]
|
||||||
|
|||||||
Reference in New Issue
Block a user