mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-09 20:33:03 +00:00
Disable unset/unused mid-rule value warnings by default, and recognize
--warnings=midrule-values to enable them. Discussed starting at <http://lists.gnu.org/archive/html/help-bison/2006-10/msg00030.html>. * NEWS (2.3a+): Mention. * src/getargs.c, src/getargs.h (warnings_args, warnings_types, enum warnings): Add entry for midrule-values subargument. * src/reader.c (symbol_should_be_used): Don't return true just because the value is a set/used mid-rule value unless --warnings=midrule-values was specified. * tests/input.at (Unused values, Unused values before symbol declarations): Run tests with and without --warnings=midrule-values. * src/reader.c (check_and_convert_grammar): Use symbol_list_free rather than LIST_FREE directly.
This commit is contained in:
23
src/reader.c
23
src/reader.c
@@ -243,19 +243,24 @@ grammar_current_rule_begin (symbol *lhs, location loc)
|
||||
|
||||
|
||||
/*----------------------------------------------------------------------.
|
||||
| A symbol should be used if it has a destructor, or if it is a |
|
||||
| mid-rule symbol (i.e., the generated LHS replacing a mid-rule |
|
||||
| action) that was assigned to, as in "exp: { $$ = 1; } { $$ = $1; }". |
|
||||
| A symbol should be used if either: |
|
||||
| 1. It has a destructor. |
|
||||
| 2. --warnings=midrule-values and the symbol is a mid-rule symbol |
|
||||
| (i.e., the generated LHS replacing a mid-rule action) that was |
|
||||
| assigned to or used, as in "exp: { $$ = 1; } { $$ = $1; }". |
|
||||
`----------------------------------------------------------------------*/
|
||||
|
||||
static bool
|
||||
symbol_should_be_used (symbol_list const *s)
|
||||
{
|
||||
return (symbol_destructor_get (s->content.sym)
|
||||
|| (s->midrule && s->midrule->used)
|
||||
|| (s->midrule_parent_rule
|
||||
&& symbol_list_n_get (s->midrule_parent_rule,
|
||||
s->midrule_parent_rhs_index)->used));
|
||||
if (symbol_destructor_get (s->content.sym))
|
||||
return true;
|
||||
if (warnings_flag & warnings_midrule_values)
|
||||
return ((s->midrule && s->midrule->used)
|
||||
|| (s->midrule_parent_rule
|
||||
&& symbol_list_n_get (s->midrule_parent_rule,
|
||||
s->midrule_parent_rhs_index)->used));
|
||||
return false;
|
||||
}
|
||||
|
||||
/*----------------------------------------------------------------.
|
||||
@@ -666,5 +671,5 @@ check_and_convert_grammar (void)
|
||||
packgram ();
|
||||
|
||||
/* The grammar as a symbol_list is no longer needed. */
|
||||
LIST_FREE (symbol_list, grammar);
|
||||
symbol_list_free (grammar);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user