+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/state.h, src/state.c (shifts_to): New.
+ * src/lalr.c (build_relations): Use it.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
+ (item_number_of_rule_number, rule_number_of_item_number): New.
+ * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
+ * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
+ * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
+ Propagate their use.
+ Much remains to be done, in particular wrt `shorts' from types.h.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/symtab.c (symbol_new): Initialize the `printer' member.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/LR0.c (save_reductions): Remove, replaced by...
+ * src/state.h, src/state.c (state_reductions_set): New.
+ (reductions, errs): Rename as...
+ (reductions_t, errs_t): these.
+ Adjust all dependencies.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/LR0.c (state_list_t, state_list_append): New.
+ (first_state, last_state): Now symbol_list_t.
+ (this_state): Remove.
+ (new_itemsets, append_states, save_reductions): Take a state_t as
+ argument.
+ (set_states, generate_states): Adjust.
+ (save_shifts): Remove, replaced by...
+ * src/state.h, src/state.c (state_shifts_set): New.
+ (shifts): Rename as...
+ (shifts_t): this.
+ Adjust all dependencies.
+ * src/state.h (state_t): Remove the `next' member.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
+ escaped in slot 0.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ Use hash.h for the state hash table.
+
+ * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
+ (allocate_storage): Use state_hash_new.
+ (free_storage): Use state_hash_free.
+ (new_state, get_state): Adjust.
+ * src/lalr.h, src/lalr.c (states): Move to...
+ * src/states.h (state_t): Remove the `link' member, no longer
+ used.
+ * src/states.h, src/states.c: here.
+ (state_hash_new, state_hash_free, state_hash_lookup)
+ (state_hash_insert, states_free): New.
+ * src/states.c (state_table, state_compare, state_hash): New.
+ * src/output.c (output_actions): Do not free states now, since we
+ still need to know the final_state number in `prepare', called
+ afterwards. Do it...
+ * src/main.c (main): here: call states_free after `output'.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ Use hash.h for the state hash table.
+
+ * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
+ (allocate_storage): Use state_hash_new.
+ (free_storage): Use state_hash_free.
+ (new_state, get_state): Adjust.
+ * src/lalr.h, src/lalr.c (states): Move to...
+ * src/states.h (state_t): Remove the `link' member, no longer
+ used.
+ * src/states.h, src/states.c: here.
+ (state_hash_new, state_hash_free, state_hash_lookup)
+ (state_hash_insert, states_free): New.
+ * src/states.c (state_table, state_compare, state_hash): New.
+ * src/output.c (output_actions): Do not free states now, since we
+ still need to know the final_state number in `prepare', called
+ afterwards. Do it...
+ * src/main.c (main): here: call states_free after `output'.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/state.h, src/state.c (state_new): New, extracted from...
+ * src/LR0.c (new_state): here.
+ * src/state.h (STATE_ALLOC): Move to...
+ * src/state.c: here.
+ * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
+ * src/state.h, src/state.c: here.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/reader.c (gensym): Rename as...
+ * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
+ (getsym): Rename as...
+ (symbol_get): this.
+
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
+ * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
+ * src/output.c, src/print.c, src/print_graph.c: Propagate.
+ * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
+
+2002-06-30 Akim Demaille <akim@epita.fr>
+
+ Make the test suite pass with warnings checked.
+
+ * tests/actions.at (Printers and Destructors): Improve.
+ Avoid unsigned vs. signed issues.
+ * tests/calc.at: Don't exercise the scanner here, do it...
+ * tests/input.at (Torturing the Scanner): here.
+
+
+2002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * data/glr.c: Correct typo in Emacs-mode directive. Slightly
+ reorganize first lines parallel to yacc.c.
+
+2002-06-28 Akim Demaille <akim@epita.fr>
+
+ * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
+ (b4_token_enum, b4_token_defines): New, factored from...
+ * data/lalr1.cc, data/yacc.c, glr.c: here.
+
+2002-06-28 Akim Demaille <akim@epita.fr>
+
+ * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
+ unused variables.
+ * src/output.c (merger_output): static.
+
+2002-06-28 Akim Demaille <akim@epita.fr>
+
+ * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
+ * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
+ pacify GCC.
+ * src/output.c (save_row): Initialize all the variables to pacify GCC.
+
+2002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ Accumulated changelog for new GLR parsing features.
+
+ * src/conflicts.c (count_total_conflicts): Change name to
+ conflicts_total_count.
+ * src/conflicts.h: Ditto.
+ * src/output.c (token_actions): Use the new name.
+ (output_conflicts): Change conflp => conflict_list_heads, and
+ confl => conflict_list for better readability.
+ * data/glr.c: Use the new names.
+ * NEWS: Add self to GLR announcement.
+
+ * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
+
+ * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
+ Akim Demaille.
+
+ * data/bison.glr: Change name to glr.c
+ * data/glr.c: Renamed from bison.glr.
+ * data/Makefile.am: Add glr.c
+
+ * src/getargs.c:
+
+ * src/symlist.h: Add dprec and merger fields to symbol_list_s.
+ * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
+
+ Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * data/bison.glr: Be sure to restore the
+ current #line when returning to the skeleton contents after having
+ exposed the input file's #line.
+
+ Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * data/bison.glr: Bring up to date with changes to bison.simple.
+
+ Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * data/bison.glr: Correct definitions that use b4_prefix.
+ Various reformatting.
+ (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
+ (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
+ yytokenp argument; now part of stack.
+ (yychar): Define to behave as documented.
+ (yyclearin): Ditto.
+
+ Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
+
+ * src/reader.h: Add declaration for free_merger_functions.
+
+ * src/reader.c (merge_functions): New variable.
+ (get_merge_function): New function.
+ (free_merger_functions): New function.
+ (readgram): Check for %prec that is not followed by a symbol.
+ Handle %dprec and %merge declarations.
+ (packgram): Initialize dprec and merger fields in rules array.
+
+ * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
+ conflict_list_cnt, conflict_list_free): New variables.
+ (table_grow): Also grow conflict_table.
+ (prepare_rules): Output dprec and merger tables.
+ (conflict_row): New function.
+ (action_row): Output conflict lists for GLR parser. Don't use
+ default reduction in conflicted states for GLR parser so that there
+ are spaces for the conflict lists.
+ (save_row): Also save conflict information.
+ (token_actions): Allocate conflict list.
+ (merger_output): New function.
+ (pack_vector): Pack conflict table, too.
+ (output_conflicts): New function to output yyconflp and yyconfl.
+ (output_check): Allocate conflict_tos.
+ (output_actions): Output conflict tables, also.
+ (output_skeleton): Output b4_mergers definition.
+ (prepare): Output b4_max_rhs_length definition.
+ Use 'bison.glr' as default skeleton for GLR parsers.
+
+ * src/gram.c (glr_parser): New flag.
+ (grammar_free): Call free_merger_functions.
+
+ * src/conflicts.c (count_rr_conflicts): Augment to optionally count
+ all pairs of conflicting reductions, rather than just all tokens
+ causing conflicts. Needed to size conflict tables.
+ (conflicts_output): Modify call to count_rr_conflicts for new
+ interface.
+ (conflicts_print): Ditto.
+ (count_total_conflicts): New function.
+
+ * src/reader.h (merger_list): New type.
+ (merge_functions): New variable.
+
+ * src/lex.h (tok_dprec, tok_merge): New token types.
+
+ * src/gram.h (rule_s): Add dprec and merger fields.
+ (glr_parser): New flag.
+
+ * src/conflicts.h (count_total_conflicts): New function.
+
+ * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
+
+ * doc/bison.texinfo (Generalized LR Parsing): New section.
+ (GLR Parsers): New section.
+ (Language and Grammar): Mention GLR parsing.
+ (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
+ Correct typo ("tge" -> "the").
+
+ * data/bison.glr: New skeleton for GLR parsing.
+
+ * tests/cxx-gram.at: New tests for GLR parsing.
+
+ * tests/testsuite.at: Include cxx-gram.at.
+
+ * tests/Makefile.am: Add cxx-gram.at.
+
+ * src/parse-gram.y:
+
+ * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
+
+ * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
+
+2002-06-27 Akim Demaille <akim@epita.fr>
+
+ * src/options.h, src/options.c: Remove.
+ * src/getargs.c (short_options, long_options): New.
+
+2002-06-27 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple, data/bison.c++: Rename as...
+ * data/yacc.c, data/lalr1.cc: these.
+ * doc/bison.texinfo (Environment Variables): Remove.
+
+2002-06-25 Raja R Harinath <harinath@cs.umn.edu>
+
+ * src/getargs.c (report_argmatch): Initialize strtok().
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (b4_symbol_actions): New, replaces...
+ (b4_symbol_destructor, b4_symbol_printer): these.
+ (yysymprint): Be sure to call YYPRINT only for tokens, and using
+ user token numbers.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (yydestructor): Rename as...
+ (yydestruct): this.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * src/symtab.h, src/symtab.c (symbol_type_set)
+ (symbol_destructor_set, symbol_precedence_set): The location is
+ the last argument.
+ Adjust all callers.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
+ internals.
+ * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
+ Takes a location.
+ * src/symtab.h, src/symtab.c (symbol_class_set)
+ (symbol_user_token_number_set): Likewise.
+ Adjust all callers.
+ Promote complain_at.
+ * tests/input.at (Type Clashes): Adjust.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (YYLEX): Fix the declaration when
+ %pure-parser.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (yysymprint): Don't print the token number,
+ just its name.
+ * tests/actions.at (Destructors): Rename as...
+ (Printers and Destructors): this.
+ Also exercise %printer.
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (YYDSYMPRINT): New.
+ Use it to remove many of the #if YYDEBUG/if (yydebug).
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * src/symtab.h, src/symtab.c (symbol_t): printer and
+ printer_location are new members.
+ (symbol_printer_set): New.
+ * src/parse-gram.y (PERCENT_PRINTER): New token.
+ Handle its associated rule.
+ * src/scan-gram.l: Adjust.
+ (handle_destructor_at, handle_destructor_dollar): Rename as...
+ (handle_symbol_code_at, handle_symbol_code_dollar): these.
+ * src/output.c (symbol_printers_output): New.
+ (output_skeleton): Call it.
+ * data/bison.simple (yysymprint): New. Cannot be named yyprint
+ since there are already many grammar files with a user `yyprint'.
+ Replace the calls to YYPRINT to calls to yysymprint.
+ * tests/calc.at: Adjust.
+ * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
+ taking advantage of parser very internal details (stack size!).
+
+2002-06-20 Akim Demaille <akim@epita.fr>
+
+ * src/scan-gram.l: Complete the scanner with the missing patterns
+ to pacify Flex.
+ Use `quote' and `symbol_tag_get' where appropriate.
+
+2002-06-19 Akim Demaille <akim@epita.fr>
+
+ * tests/actions.at (Destructors): Augment to test locations.
+ * data/bison.simple (yydestructor): Pass it the current location
+ if locations are enabled.
+ Prototype only when __STDC__ or C++.
+ Change the argument names to move into the yy name space: there is
+ user code here.
+
+2002-06-19 Akim Demaille <akim@epita.fr>
+
+ * data/bison.simple (b4_pure_if): New.
+ Use it instead of #ifdef YYPURE.
+