X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/41d7a5f24d5e69bdf6ce10c012d50b89ce1e3957..8b9c89fb65d758e99602c068e16bfbf109437e42:/src/main.c diff --git a/src/main.c b/src/main.c index d979bae8..9b472f1e 100644 --- a/src/main.c +++ b/src/main.c @@ -114,14 +114,16 @@ main (int argc, char *argv[]) declarations. */ timevar_push (TV_CONFLICTS); conflicts_solve (); - { - state_number *old_to_new = xnmalloc (nstates, sizeof *old_to_new); - state_number nstates_old = nstates; - state_remove_unreachable_states (old_to_new); - lalr_update_state_numbers (old_to_new, nstates_old); - conflicts_update_state_numbers (old_to_new, nstates_old); - free (old_to_new); - } + muscle_percent_define_default ("lr.keep_unreachable_states", "false"); + if (!muscle_percent_define_flag_if ("lr.keep_unreachable_states")) + { + state_number *old_to_new = xnmalloc (nstates, sizeof *old_to_new); + state_number nstates_old = nstates; + state_remove_unreachable_states (old_to_new); + lalr_update_state_numbers (old_to_new, nstates_old); + conflicts_update_state_numbers (old_to_new, nstates_old); + free (old_to_new); + } conflicts_print (); timevar_pop (TV_CONFLICTS); @@ -130,8 +132,8 @@ main (int argc, char *argv[]) tables_generate (); timevar_pop (TV_ACTIONS); - grammar_rules_never_reduced_report - (_("rule never reduced because of conflicts")); + grammar_rules_useless_report + (_("rule useless in parser due to conflicts")); /* Output file names. */ compute_output_file_names ();