]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
(G_CMAX): Now INT_MAX.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-12-09 Paul Eggert <eggert@twinsun.com>
2
3 Change identifier spellings to avoid collisions with names
4 that are reserved by POSIX.
5
6 Don't use names ending in _t, since POSIX reserves them.
7 For consistency, remove _e and _s endings -- they're weren't
8 needed to remove ambiguity. All uses changed.
9 * src/uniqstr.h (uniqstr): Renamed from uniqstr_t, which in
10 turn was just renamed from struniq_t.
11 * src/uniqstr.c (uniqstr_processor): Renamed from struniq_processor,
12 which in turn was just renamed from struniq_processor_t.
13 (hash_compare_uniqstr): Renamed from hash_compare_struniq, which
14 in turn was renamed from hash_compare_struniq_t.
15 * src/LR0.c (struct state_list): Renamed from struct state_list_s.
16 (state_list): Renamed from state_list_t.
17 * src/assoc.h (assoc): Renamed from assoc_t.
18 * src/conflicts.c (enum conflict_resolution): Renamed from
19 enum conflict_resolution_e.
20 * src/derives.c (struct rule_list): Renamed from struct rule_list_s.
21 (rule_list): Renamed from rule_list_t.
22 * src/getargs.h (enum trace): Renamed from enum trace_e.
23 (enum report): Renamed from enum report_e.
24 * src/gram.h (item_number): Renamed from item_number_t.
25 (rule_number): Renamed from rule_number_t.
26 (struct rule_s): Remove the "rule_s" part; not used.
27 (rule): Renamed from rule_t.
28 (rule_filter): Renamed from rule_filter_t.
29 * src/lalr.c (struct goto_list): Renamed from struct goto_list_s.
30 (goto_list): Renamed from goto_list_t.
31 * src/lalr.h (goto_number): Renamed from goto_number_t.
32 * src/location.h (location): Renamed from location_t.
33 * src/muscle_tab.c (muscle_entry): Renamed from muscle_entry_t,
34 and moved here from:
35 * src/muscle_tab.h (muscle_entry_t): here.
36 * src/nullable.c (struct rule_list): Renamed from struct rule_list_s.
37 (rule_list): Renamed from rule_list_t.
38 * src/print_graph.c (static_graph): Renamed from graph.
39 * src/reader.h (braced_code): Renamed from braced_code_t.
40 Remove brace_code_e tag.
41 * src/relation.h (relation_node): Renamed from relation_node_t.
42 (relation_nodes): Renamed from relation_nodes_t.
43 (relation): Renamed from relation_t.
44 * src/state.h (state_number): Renamed from state_number_t.
45 (struct state): Renamed from struct state_s.
46 (state): Renamed from state_t.
47 (transitions): Renamed from transitions_t. Unused (and
48 misspelled) transtion_s tag removed.
49 (errs): Renamed from errs_t. Unused errs_s tag removed.
50 (reductions): Renamed from reductions_t. Unused tag
51 reductions_s removed.
52 * src/symlist.h (symbol_list): Renamed from symbol_list_t.
53 (struct symbol_list): Renamed from struct symbol_list_s.
54 * src/symtab.h (symbol_number): Renamed from symbol_number_t.
55 (struct symbol): Renamed from struct symbol_s.
56 (symbol): Renamed from symbol_t.
57 * src/tables.c (vector_number): Renamed from vector_number_t.
58 (action_number): Renamed from action_t.
59 * src/tables.h (base_number): Renamed from base_t.
60 * src/vcg.h (enum color): Renamed from enum color_e.
61 (enum textmode): Renamed from enum textmode_e.
62 (enum shape): Renamed from enum shape_e.
63 (struct colorentry): Renamed from struct colorentry_s.
64 (struct classname): Renamed from struct classname_s.
65 (struct infoname): Renamed from struct infoname_s.
66 (enum layoutalgorithm): Renamed from enum layoutalgorithm_e.
67 (enum decision): Renamed from enum decision_e.
68 (enum orientation): Renamed from enum orientation_e.
69 (enum alignment): Renamed from enum alignment_e.
70 (enum arrow_mode): Renamed from enum arrow_mode_e.
71 (enum crossing_type): Renamed from enum crossing_type_e.
72 (enum view): Renamed from enum view_e.
73 (struct node): Renamed from struct node_s.
74 (node): Renamed from node_t.
75 (enum linestyle): Renamed from enum linestyle_e.
76 (enum arrowstyle): Renamed from enum arrowstyle_e.
77 (struct edge): Renamed from struct edge.
78 (edge): Renamed from edge_t.
79 (struct graph): Renamed from struct graph_s.
80 (graph): Renamed from graph_t.
81 * tests/calc.at (_AT_DATA_CALC_Y, Simple LALR Calculator):
82 Rename value_t -> value.
83 * tests/input.at (Torturing the Scanner): Rename value_t -> value,
84 value_t_as_yystype -> value_as_yystype.
85
86 Don't include <errno.h> in the mainstream code, since it
87 reserves E[A-Z0-9]* and we want to use symbols like 'EQUALS'.
88 * lib/get-errno.c, lib/get-errno.h: New files.
89 * lib/Makefile.am (libbison_a_SOURCES): Add get-errno.h,
90 get-errno.c.
91 * src/files.c (xfopen, xfclose): Use get_errno instead of errno.
92 * src/output.c (output_skeleton): Likewise.
93 * src/scan-gram.l (<INITIAL>{int}): Use set_errno and get_errno
94 instead of errno.
95 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>\\x[0-9abcdefABCDEF]+):
96 Likewise.
97 (handle_action_dollar, handle_action_at): Likewise.
98 * src/system.h: Do not include <errno.h>.
99 (TAB_EXT): Renamed from EXT_TAB.
100 (OUTPUT_EXT): Renamed from EXT_OUTPUT.
101
102 Avoid str[a-z]*, since <string.h> reserves that name space.
103 Change all instances of "struniq" in names to "uniqstr", and
104 likewise for "STRUNIQ" and "UNIQSTR".
105 * src/uniqstr.c: Renamed from src/struniq.c.
106 * src/uniqstr.h: Renamed from src/struniq.h.
107 * src/Makefile.am (bison_SOURCES): Adjust to these renamings.
108 * src/files.c (strsuffix): Remove; unused.
109 (concat2): Renamed from stringappend. Now static.
110 * src/files.h (strsuffix, stringappend): Remove; unused.
111 * src/parse-gram.y (<chars>): Renamed from <string>.
112 (<uniqstr>): Renamed from <struniq>.
113 * src/scan-gram.l (obstack_for_string): Renamed from string_obstack.
114 * src/vcg.h (struct node_s.expand): Renamed from struct node_s.stretch.
115 (struct graph_s.expand): Renamed from struct graph_s.stretch.
116 * src/vcg_defaults.h (G_EXPAND): Renamed from G_STRETCH.
117 (G_LONG_STRAIGHT_PHASE): Renamed from G_STRAIGHT_PHASE.
118 (N_EXPAND): Renamed from N_STRETCH.
119
120 Avoid *_MAX and *_MIN, since <limits.h> reserves that name space.
121 * data/yacc.c (YYSTACK_GAP_MAXIMUM): Renamed from YYSTACK_GAP_MAX.
122 * src/gram.h (ITEM_NUMBER_MAX, ITEM_NUMBER_MIN, RULE_NUMBER_MAX):
123 Remove; unused.
124 * src/lalr.h (GOTO_NUMBER_MAXIMUM): Renamed from GOTO_NUMBER_MAX.
125 * src/state.h (STATE_NUMBER_MAXIMUM): Renamed from STATE_NUMBER_MAX.
126 * src/symtab.h (SYMBOL_NUMBER_MAXIMUM): Renamed from SYMBOL_NUMBER_MAX.
127 * src/tables.c (VECTOR_NUMBER_MAX, VECTOR_NUMBER_MIN): Remove; unused.
128 (BASE_MAXIMUM): Renamed from BASE_MAX.
129 (BASE_MINIMUM): Renamed from BASE_MIN.
130 (ACTION_MAX): Remove; unused.
131 (ACTION_NUMBER_MINIMUM): Renamed from ACTION_MIN.
132 Unnecessary casts removed from above defines.
133
134
135 Fix misspelling in names.
136 * src/vcg.h (enum_alignment_e): Renamed from enum_alignement_e.
137 * src/vcg_defaults.h (G_NODE_ALIGNMENT): Renamed from
138 G_NODE_ALIGNEMENT.
139
140
141 * lib/timevar.c (timevar_report): Renamed from time_report,
142 for consistency with other names.
143 * lib/timevar.h (timevar_report): New decl.
144 * src/system.h (time_report): Remove; decl is now in lib/timevar.h.
145
146
147 Sort include-file uses.
148
149 Reorder all include files under src to be in the order "system.h".
150 then the ../lib include files in angle brackets (alphabetized),
151 then the . include files in double-quotes (alphabetized). Fix
152 dependency breakages encountered in this process, as follows:
153 * src/closure.h, src/derives.h, src/state.h: Include "gram.h".
154 * src/complain.c: Don't include stdlib.h, string.h _LIBC stuff.
155 * src/state.h: Include "symtab.h".
156
1572002-12-08 Paul Eggert <eggert@twinsun.com>
158
159 * data/glr.c, data/lalr1.cc, data/yacc.c: Do not use __file__,
160 since this causes problems when __file__ contains character
161 sequences like "@" that are treated specially by src/scan-skel.l.
162 Instead, just use the file's basename. This fixes the bug
163 reported by Martin Mokrejs in
164 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001945.html>.
165
1662002-12-06 Paul Eggert <eggert@twinsun.com>
167
168 Add support for rules that do not have trailing semicolons, as
169 POSIX requires. Improve the quality of locations in Bison
170 diagnostics.
171
172 * src/location.c: Include <quotearg.h>.
173 (empty_location): Now const.
174 (location_print): New function. Follow the recommendation of the
175 GNU Coding Standards for locations that span file boundaries.
176 * src/location.h: Do not include <quotearg.h>; no longer needed.
177 (boundary): New type.
178 (location_t): Use it. This allows locations to span file boundaries.
179 All member uses changed: file -> start.file or end.file (as needed),
180 first_line -> start.line, first_column -> start.column,
181 last_line -> end.line, last_column -> end.column.
182 (equal_boundaries): New function.
183 (LOCATION_RESET, LOCATION_STEP): Remove.
184 (LOCATION_PRINT): Remove. All callers changed to use location_print.
185 (empty_location): Now const.
186 (location_print): New decl.
187 * src/parse-gram.y (lloc_default): New function, which handles
188 empty locations more accurately.
189 (YYLLOC_DEFAULT): Use it.
190 (%token COLON): Remove.
191 (%token ID_COLON): New token.
192 (rules): Use it.
193 (declarations, rules): Remove trailing semicolon.
194 (declaration, rules_or_grammar_declaration):
195 Allow empty (";") declaration.
196 (symbol_def): Remove empty actions; no longer needed.
197 (rules_or_grammar_declaration): Remove trailing semicolon.
198 (semi_colon.opt): Remove.
199 * src/reader.h: Include location.h.
200 (scanner_cursor): New decl.
201 * src/reduce.c (nonterminals_reduce): Use warn_at rather than
202 rolling our own.
203 * src/scan-gram.l (YY_USER_INIT): Initialize scanner_cursor instead
204 of *loc.
205 (STEP): Remove. No longer needed, now that adjust_location does
206 the work. All uses removed.
207 (scanner_cursor): New var.
208 (adjust_location): Renamed from extend_location. It now sets
209 *loc and adjusts the scanner cursor. All uses changed.
210 Don't bother testing for CR.
211 (handle_syncline): Remove location arg; now updates scanner cursor.
212 All callers changed.
213 (unexpected_end_of_file): Now accepts start boundary of token or
214 comment, not location. All callers changed. Update scanner cursor,
215 not the location.
216 (SC_AFTER_IDENTIFIER): New state.
217 (context_state): Renamed from c_context. All uses changed.
218 (id_loc, code_start, token_start): New local vars.
219 (<INITIAL,SC_AFTER_IDENTIFIER>): New initial context. Move all
220 processing of Yacc white space and equivalents here.
221 (<INITIAL>{id}): Save id_loc. Begin state SC_AFTER_IDENTIFIER
222 instead of returning ID immediately, since we need to search for
223 a subsequent colon.
224 (<INITIAL>"'", "\""): Save token_start.
225 (<INITIAL>"%{", "{", "%%"): Save code_start.
226 (<SC_AFTER_IDENTIFIER>): New state, looking for a colon.
227 (<SC_YACC_COMMENT>, <SC_COMMENT>, <SC_LINE_COMMENT>):
228 BEGIN context_state at end, not INITIAL.
229 (<SC_ESCAPED_STRING>"\"", <SC_ESCAPED_CHARACTER>"'",
230 <SC_BRACED_CODE>"}", <SC_PROLOGUE>"%}", <SC_EPILOGUE><<EOF>>):
231 Return correct token start.
232 (<SC_BRACED_CODE,SC_PROLOGUE,SC_EPILOGUE>): Save start boundary when
233 the start of a character, string or multiline comment is found.
234 * tests/conflicts.at (S/R in initial, Defaulted Conflicted
235 Reduction): Adjust reported locations to match the more-precise
236 results now expected.
237 * tests/input.at (Invalid $n, Invalid @n, Type Clashes): Likewise.
238 * tests/reduce.at (Useless Rules, Reduced Automaton,
239 Underivable Rules): Likewise.
240 * tests/regression.at (Invalid inputs): No longer `expecting ";"
241 or "|"' now that so many other tokens are allowed by the new grammar.
242
243 * src/complain.h (current_file): Remove duplicate decl;
244 current_file is now owned by files.h.
245 * src/complain.c, src/scan-gram.l: Include files.h.
246
2472002-12-06 Paul Eggert <eggert@twinsun.com>
248
249 * data/glr.c (yy_reduce_print): Don't assume that yyrline[yyrule]
250 promotes to int; it might be unsigned int.
251 * data/yacc.c (yy_reduce_print): Likewise.
252
253 * doc/bison.texinfo (Table of Symbols): YYERROR_VERBOSE should
254 be #defined in the prologue, not in the Bison declarations.
255 This fixes Debian Bug 102878, reported by Shaul Karl.
256
2572002-12-02 Paul Eggert <eggert@twinsun.com>
258
259 * configure.ac (AC_REPLACE_FUNCS): Add strtoul.
260 * lib/strtoul.c: New file, from gnulib.
261 This fixes a porting bug reported by Peter Klein in
262 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001944.html>.
263
2642002-11-30 Paul Eggert <eggert@twinsun.com>
265
266 * src/scan-gram.l (no_cr_read, extend_location): Move to epilogue,
267 and put only a forward declaration in the prologue. This is for
268 consistency with the other scanner helper functions.
269
270 Type clashes now generate warnings, not errors, since it
271 appears that POSIX may allow some grammars with type clashes.
272 * src/reader.c (grammar_current_rule_check): Warn about
273 type clashes instead of complaining.
274 * tests/input.at (Type Clashes): Expect warnings, not complaints.
275
276 Add Yacc library, since POSIX requires it.
277 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
278 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
279 * lib/main.c, lib/yyerror.c: New files.
280
281 gram_error can be static; it need not be extern.
282 * src/reader.h (gram_error): Remove decl.
283 * src/parse-gram.y (gram_error): Now static. Add static decl.
284 (print_token_value): Omit parameter names from forward decl,
285 for consistency.
286
2872002-11-29 Paul Eggert <eggert@twinsun.com>
288
289 * doc/bison.texinfo: Emphasize that yylex and yyerror must
290 be declared before being used. E.g., one should typically
291 declare them in the prologue. Use GNU coding style in examples.
292 Put "const" consistently after the type it modifies. Mention
293 that C99 supports "inline". Mention that yyerror traditionally
294 returns "int".
295
296 %parse-param and %lex-param now take just one argument, the
297 declaration; the argument name is deduced from the declaration.
298
299 * doc/bison.texinfo (Parser Function, Pure Calling, Error
300 Reporting, Table of Symbols): Document this.
301 * src/parse-gram.y (add_param): New function.
302 (COMMA): Remove.
303 (declaration): Implement new rule for %parse-param and %lex-param.
304 * src/scan-gram.l: "," now elicits a warning, rather than being
305 a token; this is more compatible with byacc.
306 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
307
3082002-11-27 Paul Eggert <eggert@twinsun.com>
309
310 Rename identifiers to avoid real and potential collisions.
311
312 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
313 to avoid collision with lex macro described by Bruce Lilly in
314 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
315 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
316 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
317 * src/parse-gram.y (print_token_value): Renamed from yyprint.
318 All uses changed.
319 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
320 The name "yycontrol" violates the name space rules, and this stuff
321 wasn't being used anyway.
322 (input): Remove action; this stuff wasn't being used.
323 (gram_error): Rename local variable yylloc -> loc.
324 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
325 (YY_DECL): Don't use "yy" at start of local variables.
326 All uses changed, e.g., yylloc -> loc.
327 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
328 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
329 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
330 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
331
332 * src/parse-gram.y (gram_error): loc is now const *.
333 * src/reader.h (gram_error): Likewise.
334
3352002-11-24 Paul Eggert <eggert@twinsun.com>
336
337 Version 1.75c.
338
339 * tests/actions.at (Actions after errors): Use an output format
340 more similar to that of the Printers and Destructors test.
341 Test the position of the ';' token too.
342 (Printers and Destructors): Likewise.
343 (Printers and Destructors: %glr-parser): Remove for now, to avoid
344 unnecessarily alarming people when the test fails.
345
346 * data/yacc.c (yyerrlab1): Move this label down, so that the
347 parser does not discard the lookahead token if the user code
348 invokes YYERROR. This change is required for POSIX conformance.
349
350 * lib/error.c: Sync with gnulib.
351
3522002-11-22 Paul Eggert <eggert@twinsun.com>
353
354 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
355 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
356 * lib/xmalloc.c: Likewise.
357
3582002-11-20 Paul Eggert <eggert@twinsun.com>
359
360 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
361
3622002-11-20 Paul Eggert <eggert@twinsun.com>
363
364 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
365 should use `if (! x) abort ();' rather than `assert (x);', and
366 anyway it's one less thing to worry about configuring.
367
368 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
369 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
370 and replace all instances of assert with abort.
371 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
372 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
373
374 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
375 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
376 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
377 hash_find_entry, hash_rehash, hash_insert): Likewise.
378 * src/conflicts.c (resolve_sr_conflict): Likewise.
379 * src/lalr.c (set_goto_map, map_goto): Likewise.
380 * src/nullable.c (nullable_compute): Likewise.
381 * src/output.c (prepare_rules, token_definitions_output): Likewise.
382 * src/reader.c (packgram, reader): Likewise.
383 * src/state.c (state_new, state_free, state_transitions_set,
384 state_reduction_find): Likewise.
385 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
386 symbol_pack): Likewise.
387 * src/tables.c (conflict_row, pack_vector): Likewise.
388 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
389 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
390 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
391 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
392
393 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
394 (ARGMATCH_CONSTRAINT): New macro.
395 (ARGMATCH_ASSERT): Use it.
396
397 * src/system.h (verify): New macro.
398 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
399 rather than assert.
400 * src/tables.c (tables_generate): Likewise.
401
402 * src/struniq.c (struniq_assert): Now returns void, and aborts
403 if the assertion is false.
404 (struniq_assert_p): Remove.
405 * src/struniq.h: Likewise.
406
4072002-11-18 Paul Eggert <eggert@twinsun.com>
408
409 * data/glr.c (yygetLRActions): Replace `yyindex' with
410 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
411 This fixes the regression with Sun ONE Studio 7 cc that I reported in
412 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001892.html>.
413
4142002-11-18 Akim Demaille <akim@epita.fr>
415
416 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
417 space.
418 From Tim Van Holder.
419
4202002-11-17 Paul Eggert <eggert@twinsun.com>
421
422 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
423 to "SyntaxError" for consistency with my 2002-11-15 change.
424
425 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
426 not define to {}, since this breaks the common use of `YYDPRINTF
427 ((...));' if a single statement is desired (e.g. before `else').
428 Work around GCC warnings by surrounding corresponding calls with
429 {} if needed.
430 (yyhasResolvedValue): Remove unused function.
431 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
432 loop body.
433 (yyreportSyntaxError): Renamed from yyreportParseError.
434 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
435 All uses changed.
436 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
437 extern when possible. Remove unused initializations.
438
4392002-11-16 Akim Demaille <akim@epita.fr>
440
441 Augment the similarity between GLR and LALR traces.
442
443 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
444 (YY_REDUCE_PRINT): New.
445 (yyparse): Use them.
446 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
447 YYDPRINT here.
448 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
449 state reached after the reduction/recovery, since...
450 (yyparse, yyprocessOneStack): Report the state we are entering in.
451
4522002-11-16 Akim Demaille <akim@epita.fr>
453
454 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
455 Add support for --trace=skeleton.
456 * src/scan-skel.l: %option debug.
457 Scan strings of non-@ or \n instead of character by character.
458 (scan_skel): Handle trace_skeleton.
459 (QPUTS): New.
460 (@output_parser_name@, @output_header_name@): ``Restore'' their
461 support (used to be M4 macros).
462 * data/yacc.c: Quote larger chunks, a la glr.c.
463 * data/lalr1.cc: Likewise.
464 The header guards are no longer available, so use some other
465 string than `YYLSP_NEEDED'.
466
4672002-11-16 Akim Demaille <akim@epita.fr>
468
469 Make the ``Printers and Destructors'' test more verbose, taking
470 `yacc.c''s behavior as (possibly wrong) reference.
471
472 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
473 instead of fprint on stdout.
474 Set and report the last_line of the symbols.
475 Consistently display values and locations.
476
4772002-11-16 Paul Eggert <eggert@twinsun.com>
478
479 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
480
4812002-11-15 Paul Eggert <eggert@twinsun.com>
482
483 * tests/actions.at (Actions after errors): New test case.
484
485 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
486 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
487 tests/action.at, tests/calc.at, tests/conflicts.at,
488 tests/cxx-type.at, tests/regression.at:
489 "parse error" -> "syntax error" for POSIX compatibility.
490 "parsing stack overflow..." -> "parser stack overflow" so
491 that code matches Bison documentation.
492
4932002-11-15 Akim Demaille <akim@epita.fr>
494
495 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
496 take two BRACED_CODE, not two string_content.
497 Free the scanner's obstack when we are done.
498 (code_content): New.
499 * tests/calc.at: Adjust.
500 * doc/bison.texinfo: Adjust.
501 Also, make sure to include the `,' for these declarations.
502
5032002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
504
505 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
506 definition; avoids potential autoreconf problems.
507
5082002-11-15 Akim Demaille <akim@epita.fr>
509
510 Always check the value returned by yyparse.
511
512 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
513 returned by yyparse.
514 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
515 Adjust calls.
516 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
517 returned by yyparse.
518
5192002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
520
521 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
522 on input.at test.
523
5242002-11-14 Paul Eggert <eggert@twinsun.com>
525
526 * src/output.c (output_skeleton): Call xfopen instead of
527 duplicating xfopen's body.
528
529 Fix bugs reported by Nelson H. F. Beebe in
530 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
531
532 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
533 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
534 Group compiler. Instead, use "$CC -E bar.c". Include the .h
535 file twice in the grammar, as an extra check.
536
537 * tests/input.at (Torturing the Scanner): Surround the
538 backslash-newline tests with "#if 0", to make it less likely that
539 we'll run into compiler bugs. Bring back solitary \ inside
540 comment, but add a closing comment to work around HP C bug. Don't
541 test backslash-newline in C character constant. This should fix
542 the input.at bug reported by Nelson H. F. Beebe in
543 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
544
5452002-11-14 Akim Demaille <akim@epita.fr>
546
547 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
548 status of the compiler.
549 Calling `exit 1' is no longer needed.
550 Reported by Nelson H. F. Beebe.
551
5522002-11-14 Akim Demaille <akim@epita.fr>
553
554 * tests/atlocal.in (CPPFLAGS): We have config.h.
555 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
556 New.
557 * tests/actions.at, tests/calc.at, tests/conflicts.at,
558 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
559 * tests/regression.at, tests/torture.at: Use them for all the
560 grammars that are to be compiled.
561 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
562 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
563 * doc/bison.texinfo (GLR Parsers): Document `inline'.
564
5652002-11-14 Akim Demaille <akim@epita.fr>
566
567 * doc/bison.texinfo: Various formatting changes (alignments in
568 samples, additional @group/@end group, GCS in samples.
569 Use @deffn instead of simple @table to define the directives,
570 macros, variables etc.
571
5722002-11-13 Paul Eggert <eggert@twinsun.com>
573
574 Fix some bugs reported by Albert Chin-A-Young in
575 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
576
577 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
578 -o c"; the HP C compiler chatters during compilation.
579 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
580 * tests/headers.at (export YYLTYPE): Likewise.
581
582 * tests/input.at (Torturing the Scanner): Remove lines containing
583 solitary backslashes, as they tickle a bug in the HP C compiler.
584
585 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
586 comments, since they're not portable. Use GNU coding style.
587
5882002-11-13 Akim Demaille <akim@epita.fr>
589
590 * data/yacc.c: Leave bigger chunks of quoted text.
591 (YYDSYMPRINTF): New.
592 Use it to report symbol activities.
593 * data/glr.c (YYDSYMPRINTF): New.
594 Use it.
595
5962002-11-12 Paul Eggert <eggert@twinsun.com>
597
598 Version 1.75b.
599
600 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
601 (yyglrReduce): Return yyok, not 0.
602 This should avoid the enumerated-type warnings reported
603 by Nelson H.F. Beebe in
604 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
605
606 * lib/bbitset.h (BITSET_INLINE): Remove.
607 * lib/bitset.h [! BITSET_INLINE]: Remove.
608 (bitset_set, bitset_reset, bitset_test): Rename local vars
609 to avoid shadowing warnings by GCC.
610
611 * data/glr.c (inline): Remove #define. It's the user's
612 responsibility to #define it away, just like 'const'.
613 This fixes one of the bugs reported by Nelson H.F. Beebe in
614 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
615
616 * Makefile.maint (po-check): Scan .l and .y files instead of the
617 .c and the .h files that they generate. This fixes the bug
618 reported by Tim Van Holder in:
619 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
620 Look for N_ as well as for _. Try to avoid matching #define for
621 N_ and _.
622 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
623 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
624 * src/scan-gram.l: Revamp regular expressions so that " and '
625 do not confuse xgettext.
626
627 * src/struniq.h (struniq_new): Do not declare the return type
628 to be 'const'; this violates the C standard.
629 * src/struniq.c (struniq_new): Likewise.
630
6312002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
632
633 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
634 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
635 linker.
636
6372002-11-12 Akim Demaille <akim@epita.fr>
638
639 * Makefile.maint: Sync with Autoconf:
640 (local_updates): New.
641
6422002-11-12 Akim Demaille <akim@epita.fr>
643
644 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
645
6462002-11-12 Akim Demaille <akim@epita.fr>
647
648 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
649 locations.
650
6512002-11-12 Akim Demaille <akim@epita.fr>
652
653 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
654 not yyvalue.
655
6562002-11-12 Akim Demaille <akim@epita.fr>
657
658 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
659 Use it to test the GLR parser.
660
6612002-11-12 Akim Demaille <akim@epita.fr>
662
663 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
664 defines it.
665 * data/glr.c (yystos): New.
666 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
667 (YYDSYMPRINT): New.
668 (yyval): Don't define it, it is handled via M4.
669 (yyrecoverParseError): Free verbosely the discarded symbols.
670 * data/yacc.c (yysymprint): Remove, rather...
671 (b4_yysymprint_generate): invoke.
672 * data/c.m4 (b4_yysymprint_generate): New.
673 Accept pointers as arguments, as opposed to the version from
674 yacc.c.
675 (b4_yydestruct_generate): Likewise.
676 * tests/cations.at (Printers and Destructors): Use Bison directives
677 instead of CPP macros.
678 Don't rely on internal details.
679
6802002-11-12 Akim Demaille <akim@epita.fr>
681
682 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
683 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
684 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
685 it against YYEMPTY and so forth), work on yytoken (i.e., set
686 it to YYEMPTY etc.).
687 (yydestruct): Replace with a b4_yydestruct_generate invocation.
688 (b4_symbol_actions): Remove.
689 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
690 for 0, end-of-input.
691
6922002-11-12 Akim Demaille <akim@epita.fr>
693
694 * doc/bison.texinfo (Destructor Decl): New.
695
6962002-11-12 Akim Demaille <akim@epita.fr>
697
698 * src/tables.c (tables_generate): Use free for pointers that
699 cannot be NULL, not XFREE.
700 (pack_vector): Use assert, not fatal, for bound violations.
701 * src/state.c (state_new): Likewise.
702 * src/reader.c (reader): Likewise.
703 * src/lalr.c (set_goto_map): Likewise.
704 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
705 the file name.
706
7072002-11-12 Akim Demaille <akim@epita.fr>
708
709 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
710 Restore.
711 * src/scan-gram.l (last_string): Is global to the file, not to
712 yylex.
713 * src/parse-gram.y (input): Don't append the epilogue here,
714 (epilogue.opt): do it here, and free the scanner's obstack.
715 * src/reader.c (epilogue_set): Rename as...
716 (epilogue_augment): this.
717 * data/c.m4 (b4_epilogue): Defaults to empty.
718
7192002-11-12 Akim Demaille <akim@epita.fr>
720
721 * src/getargs.c (long_options): Remove duplicates.
722 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
723 Remove.
724 * doc/bison.rnh: Remove.
725 * doc/bison.texinfo (VMS Invocation): Remove.
726
7272002-11-12 Akim Demaille <akim@epita.fr>
728
729 * src/struniq.h, src/struniq.c (struniq_t): Is const.
730 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
731
732 Use struniq for symbols.
733
734 * src/symtab.h (symbol_t): The tag member is a struniq.
735 (symbol_type_set): Adjust.
736 * src/symtab.c (symbol_new): Takes a struniq.
737 (symbol_free): Don't free the tag member.
738 (hash_compare_symbol_t, hash_symbol_t): Rename as...
739 (hash_compare_symbol, hash_symbol): these.
740 Use the fact that tags as struniqs.
741 (symbol_get): Use struniq_new.
742 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
743 Returns a strniq.
744 * src/reader.h (merger_list, grammar_currentmerge_set): The name
745 and type members are struniqs.
746 * src/reader.c (get_merge_function)
747 (grammar_current_rule_merge_set): Adjust.
748 (TYPE, current_type): Are struniq.
749
750 Use struniq for file names.
751
752 * src/files.h, src/files.c (infile): Split into...
753 (grammar_file, current_file): these.
754 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
755 * src/reduce.c (reduce_print): Likewise.
756 * src/getargs.c (getargs): Likewise.
757 * src/complain.h, src/complain.c: Likewise.
758 * src/main.c (main): Call struniqs_new early enough to use it for
759 file names.
760 Don't free the input file name.
761
7622002-11-12 Akim Demaille <akim@epita.fr>
763
764 * src/symtab.c (symbol_free): Remove dead deactivated code:
765 type_name are properly removed.
766 Don't use XFREE to free items that cannot be NULL.
767 * src/struniq.h, src/struniq.c: New.
768 * src/main.c (main): Initialize/free struniqs.
769 * src/parse-gram.y (%union): Add astruniq member.
770 (yyprint): Adjust.
771 * src/scan-gram.l (<{tag}>): Return a struniq.
772 Free the obstack bit that used to store it.
773 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
774
7752002-11-11 Paul Eggert <eggert@twinsun.com>
776
777 Revamp to fix many (but not all) of the C- and M4-related quoting
778 problems. Among other things, this fixes the Bison bug reported
779 by Jan Hubicka when processing the Bash grammar; see:
780 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
781
782 Use new @ escapes consistently. Represent brackets with @{ and @}
783 rather than @<:@ and @:>@, since this works a bit better with dumb
784 editors like vi. Represent @ with @@, since @ is now consistently
785 an escape. Use @oline@ and @ofile@ rather than __oline__ and
786 __ofile__, to avoid unexpected expansions. Similarly, use @output
787 rather than #output.
788
789 * data/c.m4 (b4_copyright): Omit file name from comment, since
790 the file name could contain "*/".
791 (b4_synclines_flag): Don't quote the 2nd argument; it should already
792 be quoted. All uses changed.
793
794 * data/glr.c: Use new @ escapes consistently.
795 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
796 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
797 Remove, since they couldn't handle arbitrary characters in file
798 names.
799 * data/lalr1.cc: Likewise.
800 * data/yacc.c: Likewise.
801
802 * src/files.c (output_infix): Remove; all uses removed.
803 * src/files.h: Likewise.
804
805 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
806 mishandled funny characters in file names, and anyway it isn't
807 needed any more.
808 * data/yacc.c: Likewise.
809 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
810
811 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
812 * data/yacc.c: Likewise.
813
814 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
815 strings now.
816 (muscle_init): Quote filename as a C string.
817 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
818 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
819 * src/output.c (escaped_file_name_output): New function.
820 (prepare_symbols): Quote tokens for M4.
821 (prepare): Don't insert output_infix, output_prefix,
822 output_parser_name, output_header_name; this is now down by scan-skel.
823 Insert skeleton as a C string.
824
825 * src/output.c (user_actions_output, symbol_destructors_output,
826 symbol_printers_output): Quote filenames for C and M4.
827 * src/reader.c (prologue_augment, epilogue_set): Likewise.
828
829 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
830 escapes other than \\ and \'; this simplifies the code.
831 (<SC_STRING>): Likewise, for \\ and \".
832 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
833 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
834 Use new escapes @{ and @} for [ and ].
835
836 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
837 them with auto vars.
838 Switch to new escape scheme, where @ is the escape character uniformly.
839 Abort if a stray escape character is found. Avoid unbounded input
840 buffer when parsing non-escaped text.
841
842 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
843 __oline__, #output, $@, and @{ do not have unintended meanings.
844
8452002-11-09 Paul Eggert <eggert@twinsun.com>
846
847 Fix the test failure due to GCC warnings described in
848 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
849 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
850 evaluate to 0 if it's impossible for NINF to be in the respective
851 table.
852 (yygetLRActions, yyrecoverParseError): Use them.
853
854 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
855 counted in the token inserted at end of file. Now takes
856 location_t *, not location_t, so that the location can be
857 adjusted. All uses changed.
858
859 * tests/regression.at (Invalid inputs): Adjust wording in
860 diagnostic to match the new behavior.
861
862 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
863 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
864 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
865 abort ();'. This reduces the runtime of the "Many lookaheads"
866 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
867 GCC 3.2.
868
8692002-11-07 Paul Eggert <eggert@twinsun.com>
870
871 * src/parse-gram.y (CHARACTER): Remove unused token.
872 All uses removed.
873
874 * src/scan-gram.l: Remove stack option. We no longer use the
875 stack, since the stack was never deeper than 1; instead, use the
876 new auto var c_context to record the stacked value.
877
878 Remove nounput option. At an unexpected end of file, we now unput
879 the minimal input necessary to end cleanly; this simplifies the
880 code.
881
882 Avoid unbounded token sizes where this is easy.
883
884 (unexpected_end_of_file): New function.
885 Use it to systematize the error message on unexpected EOF.
886 (last-string): Now auto, not static.
887 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
888 (scanner_last_string_free): Remove; not used.
889 (percent_percent_count): Move decl to just before use.
890 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
891 not the (never otherwised-used) CHARACTER.
892
8932002-11-07 Akim Demaille <akim@epita.fr>
894
895 Let yyerror always receive the msg as last argument, so that
896 yyerror can be variadic.
897
898 * data/yacc.c (b4_yyerror_args): New.
899 Use it when calling yyerror.
900 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
901 Use it when calling yyerror.
902 * doc/bison.texinfo (Error Reporting): Adjust.
903 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
904 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
905
9062002-11-06 Akim Demaille <akim@epita.fr>
907
908 #line should have quoted strings.
909 Ideally, this should be done by m4_quotearg.
910
911 * src/scan-skel.l: Include quotearg.h.
912 Quote __ofile__.
913 * src/output.c (symbol_printers_output)
914 (symbol_destructors_output): Quote the file name.
915
9162002-11-06 Akim Demaille <akim@epita.fr>
917
918 * tests/regression.at (Invalid inputs): Adjust to the recent
919 messages.
920
9212002-11-06 Akim Demaille <akim@epita.fr>
922
923 Restore --no-lines.
924 Reported by Jim Kent.
925
926 * data/c.m4 (b4_syncline): New.
927 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
928 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
929 * src/output.c (user_actions_output): Likewise.
930 (prepare): Define 'b4_synclines_flag'.
931 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
932
9332002-11-06 Akim Demaille <akim@epita.fr>
934
935 * src/main.c (main): Free `infile'.
936 * src/scan-gram.l (handle_syncline): New.
937 Recognize `#line'.
938 * src/output.c (user_actions_output, symbol_destructors_output)
939 (symbol_printers_output): Use the location's file name, not
940 infile.
941 * src/reader.c (prologue_augment, epilogue_set): Likewise.
942
9432002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
944
945 * src/tables.c (matching_state): Don't allow states to match if
946 either has GLR conflict entries.
947
9482002-11-05 Paul Eggert <eggert@twinsun.com>
949
950 * src/scan-gram.l: Use more accurate diagnostics, e.g.
951 "integer out of range" rather than "invalid value".
952 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
953 accordingly.
954
955 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
956 Also, remove one static variable in the scanner.
957
958 * src/scan-gram.l (braces_level): Now auto, not static.
959 Initialize to zero if the compiler is being picky.
960 (INITIAL): Clear braces_level instead of incrementing it.
961 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
962 as POSIX 1003.1-2001 requires.
963 * src/system.h (IF_LINT): New macro, taken from coreutils.
964 * configure.ac: Define "lint" if --enable-gcc-warnings.
965
9662002-11-05 Akim Demaille <akim@epita.fr>
967
968 * src/scan-gram.l: When it starts with `%', complain about the
969 whole directive, not just that `invalid character: %'.
970
9712002-11-04 Akim Demaille <akim@epita.fr>
972
973 * Makefile.maint: Update from Autoconf.
974 (update, cvs-update, po-update, do-po-update): New.
975
9762002-11-04 Akim Demaille <akim@epita.fr>
977
978 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
979 and yyerror.
980 Have yyerror `use' its arguments.
981 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
982 returns true when location & yacc & pure & parse-param.
983 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
984
9852002-11-04 Akim Demaille <akim@epita.fr>
986
987 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
988 clashes.
989 * src/scan-gram.l: Use [\'] instead of ['] to pacify
990 font-lock-mode.
991 Use complain_at.
992 Use quote, not quote_n since LOCATION_PRINT no longer uses the
993 slot 0.
994
9952002-11-03 Paul Eggert <eggert@twinsun.com>
996
997 * src/reader.c (get_merge_function, grammar_current_rule_check):
998 Use consistent diagnostics for reporting type name clashes.
999 Quote the types with <>, for consistency with Yacc.
1000 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
1001
10022002-11-03 Akim Demaille <akim@epita.fr>
1003
1004 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
1005 New.
1006 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
1007 (b4_parse_param): Remove.
1008 Use b4_identification.
1009 Propagate b4_pure_args where needed to pass them to yyerror.
1010 * data/glr.m4 (b4_parse_param): Remove.
1011 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
1012 (b4_lpure_formals): New.
1013 Use b4_identification.
1014 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
1015 b4_user_formals and b4_user_args.
1016 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
1017 (yyreportAmbiguity): When using a pure parser, also need
1018 the location, and the parse-params.
1019 Adjust callers.
1020 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
1021 When using a pure parser, also need the parse-params.
1022 Adjust callers.
1023 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
1024 (%pure-parser + %parse-param) LALR and GLR parsers.
1025 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
1026 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
1027 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
1028 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
1029 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
1030 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
1031 * doc/bison.texinfo: Untabify the whole file.
1032 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
1033 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
1034 (Error Reporting): Adjust to these new directives.
1035 Document %error-verbose, deprecate YYERROR_VERBOSE.
1036
10372002-11-03 Akim Demaille <akim@epita.fr>
1038
1039 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
1040 AT_CHECK_CALC_GLR invocations to use % directives, instead of
1041 command line options.
1042 * tests/cxx-type.at: Formatting changes.
1043
10442002-11-03 Paul Eggert <eggert@twinsun.com>
1045
1046 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
1047 to count columns correctly, and to check for invalid inputs.
1048
1049 Use mbsnwidth to count columns correctly. Account for tabs, too.
1050 Include mbswidth.h.
1051 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
1052 (extend_location): New function.
1053 (YY_LINES): Remove.
1054
1055 Handle CRLF in C code rather than in Lex code.
1056 (YY_INPUT): New macro.
1057 (no_cr_read): New function.
1058
1059 Scan UCNs, even though we don't fully handle them yet.
1060 (convert_ucn_to_byte): New function.
1061
1062 Handle backslash-newline correctly in C code.
1063 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
1064 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
1065 all uses changed.
1066 (tag, splice): New EREs. Do not allow NUL or newline in tags.
1067 Use {splice} wherever C allows backslash-newline.
1068 YY_STEP after space, newline, vertical-tab.
1069 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
1070
1071 (letter, id): Don't assume ASCII; e.g., spell out a-z.
1072
1073 ({int}, handle_action_dollar, handle_action_at): Check for integer
1074 overflow.
1075
1076 (YY_STEP): Omit trailing semicolon, so that it's more like C.
1077
1078 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
1079 as well as \000. Check for UCHAR_MAX, not 255.
1080 Allow \x with an arbitrary positive number of digits, as in C.
1081 Check for overflow here.
1082 Allow \? and UCNs, for compatibility with C.
1083
1084 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
1085 with quote slot used by complain_at.
1086
1087 * tests/input.at: Add tests for backslash-newline, m4 quotes
1088 in symbols, long literals, and funny escapes in strings.
1089
1090 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
1091 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
1092 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
1093 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
1094 * m4/mbswidth.m4: New file, from GNU coreutils.
1095
1096 * doc/bison.texinfo (Grammar Outline): Document // comments.
1097 (Symbols): Document that trigraphs have no special meaning in Bison,
1098 nor is backslash-newline allowed.
1099 (Actions): Document that trigraphs have no special meaning.
1100
1101 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
1102 no longer used.
1103
11042002-11-02 Paul Eggert <eggert@twinsun.com>
1105
1106 * src/reader.c: Don't include quote.h; not needed.
1107 (get_merge_function): Reword warning to be consistent with
1108 type clash diagnostic in grammar_current_rule_check.
1109
1110 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
1111 bug in trigraph handling.
1112
1113 * src/output.c (prepare_symbols): When printing token names,
1114 escape "[" as "@<:@" and likewise for "]".
1115
1116 * src/system.h (errno): Remove declaration, as we are now
1117 assuming C89 or better, and C89 guarantees errno.
1118
11192002-10-30 Paul Eggert <eggert@twinsun.com>
1120
1121 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
1122 Check for close failures.
1123 * src/files.h (xfclose): Return void, not int, since it always
1124 returned zero.
1125 * src/files.c (xfclose): Likewise. Report I/O error if ferror
1126 indicates one.
1127 * src/output.c (output_skeleton): Use xfclose rather than fclose
1128 and ferror. xfclose now checks ferror.
1129
1130 * data/glr.c (YYLEFTMOST_STATE): Remove.
1131 (yyreportTree): Use a stack-based leftmost state. This avoids
1132 our continuing battles with bogus warnings about initializers.
1133
11342002-10-30 Akim Demaille <akim@epita.fr>
1135
1136 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
1137 #if.
1138
11392002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1140
1141 * tests/glr-regr1.at: New test for reported regressions.
1142 * tests/testsuite.at: Add glr-regr1.at test.
1143 * tests/Makefile.am: Add glr-regr1.at test.
1144
11452002-10-24 Paul Eggert <eggert@twinsun.com>
1146
1147 Version 1.75a.
1148
1149 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
1150 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
1151 we use malloc. Don't assume 'A' through 'Z' are contiguous.
1152 Don't assume strdup exists; POSIX says its an XSI extension.
1153 Check for buffer overflow on input.
1154
11552002-10-24 Akim Demaille <akim@epita.fr>
1156
1157 * src/output.c (output_skeleton): Don't disable M4sugar comments
1158 too soon: it results in comments being expanded.
1159 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
1160 first output.
1161
11622002-10-24 Akim Demaille <akim@epita.fr>
1163
1164 * data/yacc.c (m4_int_type): New.
1165 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
1166 char' as only yacc.c wants K&R portability.
1167 * data/glr.c (yysigned_char): Remove.
1168 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
1169 Reported by Quoc Peyrot.
1170
11712002-10-23 Paul Eggert <eggert@twinsun.com>
1172
1173 * src/main.c (main): With --trace=time, report times even if a
1174 non-fatal error occurs. Formerly, the times were reported in some
1175 such cases but not in others.
1176 * src/reader.c (reader): Just return if a complaint has been issued,
1177 instead of exiting, so that 'main' can report times.
1178
11792002-10-22 Akim Demaille <akim@epita.fr>
1180
1181 * src/system.h: Include sys/types.
1182 Reported by Bert Deknuydt.
1183
11842002-10-23 Paul Eggert <eggert@twinsun.com>
1185
1186 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
1187 Suggested by Art Haas.
1188
11892002-10-22 Paul Eggert <eggert@twinsun.com>
1190
1191 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
1192 decl; not needed any more.
1193 * src/main.c (main): Use return to exit, undoing yesterday's change.
1194 The last OS that we could find where this wouldn't work is
1195 SunOS 3.5, and that's too old to worry about now.
1196
1197 * data/glr.c (struct yyltype): Define members even when not
1198 doing locations. This is more consistent with yacc.c, and it
1199 works around the following bug reports:
1200 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
1201 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
1202 and I hope it also fixes this bug report:
1203 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
1204
1205 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
1206 @acronym consistently. Standardize on "Yacc" instead of "YACC",
1207 "Algol" instead of "ALGOL". Give a bit more history about BNF.
1208
12092002-10-22 Akim Demaille <akim@epita.fr>
1210
1211 * data/README: New.
1212
12132002-10-21 Paul Eggert <eggert@twinsun.com>
1214
1215 Be consistent about 'bool'; the old code used an enum in one
1216 module and an int in another, and this violates the C standard.
1217 * m4/stdbool.m4: New file, from coreutils 4.5.3.
1218 * configure.ac (AC_HEADER_STDBOOL): Add.
1219 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
1220 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
1221 * src/symtab.c (hash_compare_symbol_t): Likewise.
1222 * src/system.h (bool, false, true): Use a definition consistent
1223 with ../lib/hash.c. All uses changed.
1224
1225 * src/complain.c (warning_issued): Renamed from warn_message_count,
1226 so that we needn't worry about integer overflow (!).
1227 Now of type bool. All uses changed.
1228 (complaint_issued): Renamed from complain_message_count; likewise.
1229
1230 * src/main.c (main): Use exit to exit with failure.
1231
1232 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
1233 rather than 1 and 0.
1234 * src/main.c (main): Likewise.
1235 * src/getargs.c (getargs): Likewise.
1236 * src/reader.c (reader): Likewise.
1237
1238 * src/getarg.c (getargs): Remove duplicate code for
1239 "Try `bison --help'".
1240
1241 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
1242 What was that "2" for?
1243
1244 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
1245 * src/getargs.c (usage): Likewise.
1246
1247 * src/getargs.c (getargs): When there are too few operands, report
1248 the last one. When there are too many, report the first extra
1249 one. This is how diffutils does it.
1250
12512002-10-20 Paul Eggert <eggert@twinsun.com>
1252
1253 Remove K&R vestiges.
1254 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
1255 * src/complain.c (VA_START): Remove. Assume prototypes.
1256 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
1257 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
1258 fatal): Assume prototypes.
1259 * src/complain.h: Assume prototypes.
1260 * src/system.h (PARAMS): Remove.
1261 Include <limits.h> unconditionally, since it's guaranteeed even
1262 for a freestanding C89 compiler.
1263 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
1264 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
1265
12662002-10-20 Akim Demaille <akim@epita.fr>
1267
1268 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1269 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1270 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1271 (yyresolveStates, yyresolveAction, yyresolveStack)
1272 (yyprocessOneStack): Use them.
1273 (yy_reduce_print): New.
1274 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1275
12762002-10-20 Akim Demaille <akim@epita.fr>
1277
1278 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1279 arguments and output `void'.
1280 (b4_c_function): Rename as...
1281 (b4_c_function_def): this.
1282 (b4_c_function_decl, b4_c_ansi_function_def)
1283 (b4_c_ansi_function_decl): New.
1284 Change the interpretation of the arguments: before `int, foo', now
1285 `int foo, foo'.
1286 * data/yacc.c (yyparse): Prototype and define thanks to these.
1287 Adjust b4_c_function_def uses.
1288 * data/glr.c (yyparse): Likewise, but ANSI only.
1289
12902002-10-20 Akim Demaille <akim@epita.fr>
1291
1292 * src/output.c (prepare): Move the definition of `tokens_number',
1293 `nterms_number', `undef_token_number', `user_token_number_max'
1294 to...
1295 (prepare_tokens): Here.
1296 (prepare_tokens): Rename as...
1297 (prepare_symbols): this.
1298 (prepare): Move the definition of `rules_number' to...
1299 (prepare_rules): here.
1300 (prepare): Move the definition of `last', `final_state_number',
1301 `states_number' to...
1302 (prepare_states): here.
1303 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1304
13052002-10-20 Akim Demaille <akim@epita.fr>
1306
1307 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1308
13092002-10-20 Akim Demaille <akim@epita.fr>
1310
1311 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1312 * data/c.m4: here.
1313
13142002-10-20 Akim Demaille <akim@epita.fr>
1315
1316 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1317 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1318 `pair'.
1319 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1320 `name' to...
1321 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1322 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1323 These.
1324
13252002-10-19 Paul Eggert <eggert@twinsun.com>
1326
1327 Do not create a temporary file, as that involves security and
1328 cleanup headaches. Instead, use a pair of pipes.
1329 Derived from a suggestion by Florian Krohm.
1330 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1331 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1332 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1333 (BISON_PREREQ_SUBPIPE): Add.
1334 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1335 Add subpipe.h, subpipe.c.
1336 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1337 * po/POTFILES.in: Add lib/subpipe.c.
1338 * src/output.c: Include "subpipe.h".
1339 (m4_invoke): Remove decl.
1340 (scan_skel): New decl.
1341 (output_skeleton): Use pipe rather than temporary file for m4 input.
1342 Check that m4sugar.m4 is readable, to avoid deadlock.
1343 Check for pipe I/O error.
1344 * src/scan-skel.l (readpipe): Remove decl.
1345 (scan_skel): New function, to be used in place of m4_invoke.
1346 Read from stream rather than file.
1347
1348 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1349 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1350 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1351 this generates a more-accurate value anyway.
1352
1353 * lib/timevar.c (timervar_accumulate): Rename locals to
1354 avoid confusion with similarly-named more-global.
1355 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1356
1357 * src/output.c (prepare): Use xstrdup to convert char const *
1358 to char *, to avoid GCC warning.
1359
13602002-10-19 Akim Demaille <akim@epita.fr>
1361
1362 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1363 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1364 Use them to have `calc.y' ready for %pure-parser.
1365 * data/yacc.c (YYLEX): Pass a yylex return type to
1366 b4_c_function_call.
1367
13682002-10-19 Akim Demaille <akim@epita.fr>
1369
1370 Prototype support of %lex-param and %parse-param.
1371
1372 * src/parse-gram.y: Add the definition of the %lex-param and
1373 %parse-param tokens, plus their rules.
1374 Drop the `_' version of %glr-parser.
1375 Add the "," token.
1376 * src/scan-gram.l (INITIAL): Scan them.
1377 * src/muscle_tab.c: Comment changes.
1378 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1379 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1380 (muscle_entry_s): The `value' member is no longer const.
1381 Adjust all dependencies.
1382 * src/muscle_tab.c (muscle_init): Adjust: use
1383 MUSCLE_INSERT_STRING.
1384 Initialize the obstack earlier.
1385 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1386 (muscle_pair_list_grow): New.
1387 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1388 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1389 * tests/calc.at: Use %locations, not --locations.
1390 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1391
13922002-10-19 Akim Demaille <akim@epita.fr>
1393
1394 * src/getargs.c (usage): Take status as argument and exit
1395 accordingly.
1396 Report the traditional `Try ... --help' message when status != 0.
1397 (usage, version): Don't take a FILE * as arg, it is pointless.
1398 (getargs): When there is an incorrect number of arguments, make it
1399 an error, and report it GNUlically thanks to `usage ()'.
1400
14012002-10-18 Paul Eggert <eggert@twinsun.com>
1402
1403 * data/glr.c (yyreportParseError): Don't assume that sprintf
1404 yields the length of the printed string, as this is not true
1405 on SunOS 4.1.4. Reported by Peter Klein.
1406
1407 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1408 * tests/conflicts.at (%nonassoc and eof): Likewise.
1409 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1410
14112002-10-17 Akim Demaille <akim@epita.fr>
1412
1413 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1414 * src/getargs.c (trace_types, trace_args): Adjust.
1415 * src/reader.c (grammar_current_rule_prec_set)
1416 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1417 Standardize error messages.
1418 And s/@prec/%prec/!
1419 (reader): Use trace_flag to enable scanner/parser debugging,
1420 instead of an adhoc scheme.
1421 * src/scan-gram.l: Remove trailing debugging code.
1422
14232002-10-16 Paul Eggert <eggert@twinsun.com>
1424
1425 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1426 MUSCLE_TAB_H.
1427
1428 * NEWS: Officially drop support for building Bison with K&R C,
1429 since it didn't work anyway and it's not worth worrying about.
1430 * Makefile.maint (wget_files): Remove ansi2knr.c.
1431 (ansi2knr.c-url_prefix): Remove.
1432 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1433 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1434 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1435
14362002-10-15 Paul Eggert <eggert@twinsun.com>
1437
1438 Stop using the "enum_" trick for K&R-style function definitions;
1439 it confused me, and I was the author! Instead, assume that people
1440 who want to use K&R C compilers (when using these modules in GCC,
1441 perhaps?) will run ansi2knr.
1442
1443 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1444 All uses of "enum_" changed to "enum ".
1445 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1446 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1447
1448 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1449 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1450 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1451 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1452 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1453 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1454 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1455 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1456 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1457 Use function prototypes; this removes the need for declaring
1458 static functions simply to provide their prototypes.
1459 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1460 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1461 bitset_count_, bitset_create, bitset_dump, bitset_first,
1462 bitset_free, bitset_init, bitset_last, bitset_next,
1463 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1464 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1465 bitset_print, bitset_release_memory, bitset_toggle_,
1466 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1467 debug_bitset): Likewise.
1468 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1469 * lib/bitset_stats.c (bitset_log_histogram_print,
1470 bitset_percent_histogram_print, bitset_stats_and,
1471 bitset_stats_and_cmp, bitset_stats_and_or,
1472 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1473 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1474 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1475 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1476 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1477 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1478 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1479 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1480 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1481 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1482 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1483 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1484 bitset_stats_zero): Likewise.
1485 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1486 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1487 bitsetv_dump, debug_bitsetv): Likewise.
1488 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1489 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1490 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1491 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1492 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1493 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1494 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1495 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1496 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1497 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1498 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1499 Likewise.
1500 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1501 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1502 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1503 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1504 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1505 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1506 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1507 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1508 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1509 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1510 lbitset_xor_cmp, lbitset_zero): Likewise.
1511
15122002-10-14 Akim Demaille <akim@epita.fr>
1513
1514 Version 1.75.
1515
15162002-10-14 Akim Demaille <akim@epita.fr>
1517
1518 * tests/Makefile.am (maintainer-check-posix): New.
1519
15202002-10-14 Akim Demaille <akim@epita.fr>
1521
1522 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1523 member.
1524
15252002-10-14 Akim Demaille <akim@epita.fr>
1526
1527 * src/tables.c (table_ninf_remap): base -> tab.
1528 Reported by Matt Rosing.
1529
15302002-10-14 Paul Eggert <eggert@twinsun.com>
1531
1532 * tests/action.at, tests/calc.at, tests/conflicts.at,
1533 tests/cxx-type.at, tests/headers.at, tests/input.at,
1534 tests/regression.at, tests/synclines.at, tests/torture.at:
1535 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1536 so that the tests still work even if POSIXLY_CORRECT is set.
1537 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
1538
1539 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1540 for portability to K&R hosts. Fix typo: signed char is guaranteed
1541 only to 127, not to 128.
1542 * data/glr.c (yysigned_char): New type.
1543 * data/yacc.c (yysigned_char): Likewise.
1544 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1545
15462002-10-13 Paul Eggert <eggert@twinsun.com>
1547
1548 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1549 true due to limited range of data type" warning from GCC.
1550
1551 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1552 by wrapping enum yytokentype's definition inside #ifndef
1553 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1554
15552002-10-13 Akim Demaille <akim@epita.fr>
1556
1557 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1558 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1559
15602002-10-13 Akim Demaille <akim@epita.fr>
1561
1562 * Makefile.maint: Update from Autoconf 2.54.
1563 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1564
15652002-10-13 Akim Demaille <akim@epita.fr>
1566
1567 * src/print.c (print_state): Separate the list of solved conflicts
1568 from the other items.
1569 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1570
15712002-10-13 Akim Demaille <akim@epita.fr>
1572
1573 Let nondeterministic skeletons be usable with deterministic
1574 tables.
1575
1576 With the patch, GAWK compiled by GCC without -O2 passes its test
1577 suite using a GLR parser driven by LALR tables. It fails with -O2
1578 because `struct stat' gives two different answers on my machine:
1579 88 (definition of an auto var) and later 96 (memset on this var).
1580 Hence the stack is badly corrumpted. The headers inclusion is to
1581 blame: if I move the awk.h inclusion before GLR's system header
1582 inclusion, the two struct stat have the same size.
1583
1584 * src/tables.c (pack_table): Always create conflict_table.
1585 (token_actions): Always create conflict_list.
1586 * data/glr.c (YYFLAG): Remove, unused.
1587
15882002-10-13 Akim Demaille <akim@epita.fr>
1589
1590 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1591 (O0FLAGS): New.
1592 (VALGRIND, GXX): New.
1593 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1594 * tests/bison.in: Run $PREBISON a pre-command.
1595 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1596 (maintainer-check-g++): New.
1597 * Makefile.am (maintainer-check): New.
1598
15992002-10-13 Akim Demaille <akim@epita.fr>
1600
1601 * data/glr.c: Formatting changes.
1602 Tweak some trace messages to match yacc.c's.
1603
16042002-10-13 Akim Demaille <akim@epita.fr>
1605
1606 GLR parsers sometimes raise parse errors instead of performing the
1607 default reduction.
1608 Reported by Charles-Henry de Boysson.
1609
1610 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1611 check the length of the traces when %glr.
1612 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1613 GLR's traces.
1614 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1615 Test GLR parsers.
1616 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1617 (yyltype): Remove the yy prefix from the member names.
1618 (yytable): Complete its comment.
1619 (yygetLRActions): Map error action number from YYTABLE from
1620 YYTABLE_NINF to 0.
1621 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1622 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1623 not satisfying as we could compare an YYACTION computed from
1624 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1625 only value for error actions.
1626 (yyreportParseError): In verbose parse error messages, don't issue
1627 `error' in the list of expected tokens.
1628 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1629 next action to perform to match glr.c's decoding.
1630 (yytable): Complete its comment.
1631
16322002-10-13 Paul Eggert <eggert@twinsun.com>
1633
1634 Fix problem reported by Henrik Grubbstroem in
1635 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1636 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1637 because the Bison parser reads the second action before reducing
1638 the first one.
1639 * src/scan-gram.l (rule_length): New static var.
1640 Use it to keep track of the rule length in the scanner, since
1641 we can't expect the parser to be in lock-step sync with the scanner.
1642 (handle_action_dollar, handle_action_at): Use this var.
1643 * tests/actions.at (Exotic Dollars): Test for the problem.
1644
16452002-10-12 Paul Eggert <eggert@twinsun.com>
1646
1647 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1648 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1649 Include <sys/time.h> when checking for clock_t and struct tms.
1650 Use same include order as source.
1651 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1652 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
1653
1654 * lib/timevar.c: Update copyright date and clarify comments.
1655 (get_time) [IN_GCC]: Keep the GCC version for reference.
1656
1657 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1658 GCC version as of today, then merge Bison's changes.
1659 Change "GCC" to "Bison" in copyright notice. timevar.def's
1660 author is Akim, so change that too.
1661
1662 * src/reader.c (grammar_current_rule_check):
1663 Don't worry about the default action if $$ is untyped.
1664 Prevents bogus warnings reported by Jim Gifford in
1665 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1666
1667 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1668 * data/glr.c, data/lalr1.cc, data/yacc.c:
1669 Output token definitions before the first part of user declarations.
1670 Fixes compatibility problem reported by Jim Gifford for kbd in
1671 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1672
16732002-10-11 Paul Eggert <eggert@twinsun.com>
1674
1675 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1676 (yyparse): here. This undoes some of the 2002-07-25 change.
1677 Compatibility problem reported by Ralf S. Engelschall with
1678 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1679
16802002-10-11 Akim Demaille <akim@epita.fr>
1681
1682 * tests/regression.at Characters Escapes): New.
1683 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1684 characters.
1685 Reported by Jan Nieuwenhuizen.
1686
16872002-10-11 Akim Demaille <akim@epita.fr>
1688
1689 * po/id.po: New.
1690
16912002-10-10 Paul Eggert <eggert@twinsun.com>
1692
1693 Portability fixes for bitsets; this also avoids several GCC
1694 warnings.
1695
1696 * lib/abitset.c: Include <stddef.h>, for offsetof.
1697 * lib/lbitset.c: Likewise.
1698
1699 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1700 properly for vectors of objects. Do not assume that adding a
1701 header size to a multiple of a word size yields a value that is
1702 properly aligned for the whole union.
1703 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1704
1705 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1706 unique names for structures.
1707 * lib/ebitset.c (ebitset_bytes): Likewise.
1708 * lib/lbitset.c (lbitset_bytes): Likewise.
1709
1710 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1711 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1712 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1713 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1714 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1715 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1716 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1717 to improve the type-checking that GCC can do.
1718 * lib/bitset.c (bitset_op4_cmp): Likewise.
1719 * lib/bitset_stats.c (bitset_stats_count,
1720 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1721 bitset_stats_copy, bitset_stats_disjoint_p,
1722 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1723 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1724 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1725 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1726 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1727 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1728 bitset_stats_or_and_cmp): Likewise.
1729 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1730 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1731 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1732 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1733
1734 * lib/abitset.h: Include bitset.h, not bbitset.h.
1735 * lib/ebitset.h: Likewise.
1736 * lib/lbitset.h: Likewise.
1737
1738 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1739 All instances of parameters of type enum bitset_opts are now of
1740 type enum_bitset_opts, to conform to the C Standard, and similarly
1741 for enum_bitset_type.
1742 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1743 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1744
1745 Do not use "struct bitset_struct" to mean different things in
1746 different modules. Not only is this confusing, it violates
1747 the C Standard, which requires that structure types in different
1748 modules must be compatible if one is to be passed to the other.
1749 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1750 All instances of "struct bitset_struct *" replaced with "bitset".
1751 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1752 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1753 struct lbitset_struct, struct bitset_stats_struct): New types.
1754 All uses of struct bitset_struct changed to union bitset_union,
1755 etc.
1756 * lib/abitset.c (struct abitset_struct, abitset,
1757 struct bitset_struct): Remove.
1758 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1759 struct bitset_struct): Remove.
1760 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1761 bitset_struct): Remove.
1762 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1763 Likewise.
1764
1765 Do not call a function of type T using a call that assumes the
1766 function is of a different type U. Standard C requires that a
1767 function must be called with a type that is compatible with its
1768 definition.
1769 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1770 New decls.
1771 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1772 New functions.
1773 * lib/ebitset.c (PFV): Remove.
1774 * lib/lbitset.c (PFV): Likewise.
1775 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
1776 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
1777 decls.
1778 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
1779 (ebitset_vtable): Use them.
1780 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
1781 lbitset_xor): New functions.
1782 (lbitset_vtable): Use them.
1783
1784 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
1785 Declare.
1786
1787 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
1788 GCC warning.
1789 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
1790 Use offsetof, for simplicity.
1791
17922002-10-06 Paul Eggert <eggert@twinsun.com>
1793
1794 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
1795 the same width as int. This reapplies a hunk of the 2002-08-12 patch
1796 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
1797 which was inadvertently undone by the 2002-09-30 patch.
1798 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
1799 the same width as int.
1800
18012002-10-04 Paul Eggert <eggert@twinsun.com>
1802
1803 Version 1.50.
1804
1805 * configure.ac (AC_INIT), NEWS: Increment version number.
1806
1807 * doc/bison.texinfo: Minor spelling, grammar, and white space
1808 fixes.
1809 (Symbols): Mention that any negative value returned from yylex
1810 signifies end-of-input. Warn about negative chars. Mention
1811 the portable Standard C character set.
1812
1813 The GNU coding standard says CFLAGS and YFLAGS are reserved
1814 for the installer to set.
1815 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
1816 * src/Makefile.am (AM_CFLAGS): Likewise.
1817 (AM_YFLAGS): Renamed from YFLAGS.
1818
1819 Fix some MAX and MIN problems.
1820 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
1821 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
1822 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
1823 * src/reader.c (reader): Use it.
1824
1825 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
1826 POSIX 1003.1-2001 has removed fgrep.
1827
18282002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
1829
1830 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
1831 interpreted as signed.
1832 * lib/ebitset.c (ebitset_list): Fix bug.
1833
18342002-10-01 Paul Eggert <eggert@twinsun.com>
1835
1836 More fixes for 64-bit hosts and large bitsets.
1837
1838 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
1839 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
1840 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
1841 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
1842 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
1843 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
1844 bitset_count_): Likewise.
1845 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
1846 bitset_first, bitset_last): Likewise.
1847 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
1848 bitset_stats_list_reverse, bitset_stats_size,
1849 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
1850 Likewise.
1851 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1852 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1853 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1854 bitsetv_reflexive_transitive_closure): Likewise.
1855 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
1856 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
1857 Likewise.
1858 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
1859 Likewise.
1860
1861 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
1862 Use size_t, not unsigned int, to count bytes.
1863 * lib/abitset.h (abitset_bytes): Likewise.
1864 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
1865 Likewise.
1866 * lib/bitset.h (bitset_bytes): Likewise.
1867 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
1868 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
1869 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1870 * lib/ebitset.c (ebitset_bytes): Likewise.
1871 * lib/ebitset.h (ebitset_bytes): Likewise.
1872 * lib/lbitset.c (lbitset_bytes): Likewise.
1873 * lib/lbitset.h (lbitset_bytes): Likewise.
1874
1875 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
1876 abitset_subset_p, abitset_disjoint_p, abitset_and,
1877 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
1878 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
1879 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
1880 abitset_or_and, abitset_or_and_cmp):
1881 Use bitset_windex instead of unsigned int.
1882 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1883 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
1884 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
1885 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
1886 Likewise.
1887 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
1888
1889 * lib/bitset.c (bitset_print):
1890 Use proper printf formats for widths of integer types.
1891 * lib/bitset_stats.c (bitset_percent_histogram_print,
1892 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
1893 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1894 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1895 * lib/lbitset.c (lbitset_bytes): Likewise.
1896
1897 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
1898 BITSET_SIZE_MAX): New macros.
1899 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
1900 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
1901 to BITSET_WINDEX_MAX.
1902
1903 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
1904 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
1905 since we now return the bitset_bindex type (not int).
1906
1907 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
1908 when computing sizes.
1909 * lib/ebitset.c (ebitset_elts_grow): Likewise.
1910
1911 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
1912 and avoid cast to unsigned.
1913
19142002-09-30 Akim Demaille <akim@epita.fr>
1915
1916 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
1917 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
1918 Updates from Michael Hayes.
1919
19202002-09-30 Art Haas <ahaas@neosoft.com>
1921
1922 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
1923 invocations.
1924 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
1925 defined.
1926
19272002-09-27 Akim Demaille <akim@epita.fr>
1928
1929 Version 1.49c.
1930
19312002-09-27 Akim Demaille <akim@epita.fr>
1932
1933 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
1934 (Because of AC_LIBSOURCE).
1935
19362002-09-27 Akim Demaille <akim@epita.fr>
1937
1938 Playing with Autoscan.
1939
1940 * configure.ac: Remove the old LIBOBJ tweaks.
1941 (AC_REPLACE_FUNCS): Add strrchr and strtol.
1942 * lib/strrchr.c: New.
1943 * lib/strtol.c: New, from the Coreutils 4.5.1.
1944
19452002-09-27 Akim Demaille <akim@epita.fr>
1946
1947 Playing with Autoscan.
1948
1949 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
1950 * lib/Makefile.am (libbison_a_SOURCES): No longer include
1951 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
1952 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
1953 Coreutils 4.5.1.
1954
19552002-09-24 Akim Demaille <akim@epita.fr>
1956
1957 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
1958 (Frequently Asked Questions, Parser Stack Overflow): New.
1959
19602002-09-13 Akim Demaille <akim@epita.fr>
1961
1962 Playing with autoscan.
1963
1964 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
1965 * src/files.c (skeleton_find): Remove, unused.
1966 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
1967 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
1968
19692002-09-13 Akim Demaille <akim@epita.fr>
1970
1971 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
1972 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
1973
19742002-09-13 Akim Demaille <akim@epita.fr>
1975
1976 * configure.ac: Require 2.54.
1977 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
1978 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
1979 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
1980 Remove, provided by Autoconf macros.
1981
19822002-09-12 Akim Demaille <akim@epita.fr>
1983
1984 * m4/prereq.m4: Update, from Coreutils 4.5.1.
1985
19862002-09-12 Akim Demaille <akim@epita.fr>
1987
1988 * m4/prereq.m4: Update, from Fileutils 4.1.5.
1989 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
1990 Reported by Martin Mokrejs.
1991
19922002-09-10 Akim Demaille <akim@epita.fr>
1993
1994 * src/parse-gram.y: Associate a human readable string to each
1995 token type.
1996 * tests/regression.at (Invalid inputs): Adjust.
1997
19982002-09-10 Gary V. Vaughan <gary@gnu.org>
1999
2000 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
2001 with an Autoconf-2.5x style configure.ac.
2002
20032002-09-06 Paul Eggert <eggert@twinsun.com>
2004
2005 * doc/bison.texinfo (Conditions): Make explicit that the GPL
2006 exception applies only to yacc.c. This is a modification of a
2007 patch originally suggested by Akim Demaille.
2008
20092002-09-06 Akim Demaille <akim@epita.fr>
2010
2011 * data/c.m4 (b4_copyright): Move the GPL exception comment from
2012 here to...
2013 * data/yacc.c: here.
2014
2015 * data/lalr1.cc (struct yyltype): Don't define it, since we use
2016 LocationType.
2017 (b4_ltype): Default to yy::Location from location.hh.
2018
20192002-09-04 Jim Meyering <jim@meyering.net>
2020
2021 * data/yacc.c: Guard the declaration of yytoknum also with
2022 `#ifdef YYPRINT', so it is declared only when used.
2023
20242002-09-04 Akim Demaille <akim@epita.fr>
2025
2026 * configure.in: Rename as...
2027 * configure.ac: this.
2028 Bump to 1.49c.
2029
20302002-09-04 Akim Demaille <akim@epita.fr>
2031
2032 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
2033 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
2034 translate maintainer only messages.
2035
20362002-08-12 Paul Eggert <eggert@twinsun.com>
2037
2038 Version 1.49b.
2039
2040 * Makefile.am (SUBDIRS): Remove intl.
2041 (DISTCLEANFILES): Remove.
2042 * NEWS: Mention that GNU M4 is now required. Clarify what is
2043 meant by "larger grammars". Mention the pt_BR translation.
2044 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
2045 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
2046 Bump version from 0.11.2 to 0.11.5.
2047 (BISON_PREREQ_STAGE): Remove.
2048 (AM_GNU_GETTEXT): Use external gettext.
2049 (AC_OUTPUT): Remove intl/Makefile.
2050
2051 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
2052
2053 * data/glr.c: Include string.h, for strlen.
2054 (yyreportParseError): Use size_t for yysize.
2055 (yy_yypstack): No longer nested inside yypstates, as nested
2056 functions are not portable. Do not assume size_t is the
2057 same width as int.
2058 (yypstates): Do not assume that ptrdiff_t is the same width
2059 as int, and similarly for yyposn and YYINDEX.
2060
2061 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
2062
2063 * lib/Makefile.am (INCLUDES): Do not include from the intl
2064 directory, which has been removed.
2065 * src/Makefile.am (INCLUDES): Likewise.
2066
2067 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
2068 (bitsets_sources, additional_bitsets_sources, timevars_sources):
2069 New vars.
2070
2071 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
2072 * tests/Makefile.am (EXTRA_DIST): Likewise.
2073
2074 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
2075 Do not assume that bitset_windex is the same width as unsigned.
2076
2077 * lib/abitset.c (abitset_unused_clear): Do not assume that
2078 bitset_word is the same width as int.
2079 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
2080 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
2081 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
2082 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
2083 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
2084
2085 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
2086 portability to one's complement hosts!).
2087 * lib/ebitset.c (ebitset_op1): Likewise.
2088 * lib/lbitset.c (lbitset_op1): Likewise.
2089
2090 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
2091 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
2092 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
2093 Sync with fileutils.
2094 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
2095 lib/gettext.h: Sync with diffutils.
2096
2097 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
2098 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
2099
2100 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
2101 PROTOTYPES to check for prototypes, and "defined __STDC__" to
2102 check for void *.
2103
2104 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
2105 size_t; the old version tried to do this but casted improperly.
2106 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
2107 (bitset_test): Now returns int, not unsigned long.
2108
2109 * lib/bitset_stats.c: Include "gettext.h".
2110 (_): New macro.
2111 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
2112 name locals "index", as it generates unnecessary warnings on some
2113 hosts that have an "index" function.
2114
2115 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
2116 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
2117 they need translation.
2118 * src/LR0.c (state_list_append, new_itemsets, get_state,
2119 append_states, generate_states): Likewise.
2120 * src/assoc.c (assoc_to_string): Likewise.
2121 * src/closure.c (print_closure, set_firsts, closure): Likewise.
2122 * src/gram.c (grammar_dump): Likewise.
2123 * src/injections.c (injections_compute): Likewise.
2124 * src/lalr.c (lookaheads_print): Likewise.
2125 * src/relation.c (relation_transpose): Likewise.
2126 * src/scan-gram.l: Likewise.
2127 * src/tables.c (table_grow, pack_vector): Likewise.
2128
2129 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
2130 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
2131 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
2132 * m4/mbstate_t.m4: Sync with fileutils.
2133 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
2134
2135 * po/LINGUAS: Add pt_BR.
2136 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
2137 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
2138 lib/timevar.c.
2139 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
2140 manual recommends.
2141 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
2142
2143 * src/complain.c (strerror_r): Remove decl; not needed.
2144 (strerror): Use same pattern as ../lib/error.c.
2145
2146 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
2147
2148 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
2149
2150 * src/main.c (main): Cast result of bindtextdomain and textdomain
2151 to void, to avoid a GCC warning when --disable-nls is in effect.
2152
2153 * src/scan-gram.l: Use strings rather than escapes when possible,
2154 to minimize the number of warnings from xgettext.
2155 (handle_action_dollar, handle_action_at): Don't use isdigit,
2156 as it mishandles negative chars and it may not work as expected
2157 outside the C locale.
2158
2159 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
2160 this is a GCC extension and is not portable to other compilers.
2161
2162 * src/system.h (alloca): Use same pattern as ../lib/error.c.
2163 Do not include <ctype.h>; no longer needed.
2164 Do not include <malloc.h>; no longer needed (and generates
2165 warnings on OpenBSD 3.0).
2166
2167 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
2168 it's not portable.
2169
2170 * tests/regression.at: Do not use 'cc -c input.c -o input';
2171 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
2172
2173 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
2174 exit status as failure, not just exit status 1. Sun C exits
2175 with status 2 sometimes.
2176
2177 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
2178 Use it for the two large tests.
2179
21802002-08-02 Akim Demaille <akim@epita.fr>
2181
2182 * src/conflicts.c (conflicts_output): Don't output rules never
2183 reduced here, since anyway that computation doesn't work.
2184 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
2185 (rule_useless_p, rule_never_reduced_p): New.
2186 (grammar_rules_partial_print): Use a filter instead of a range.
2187 Display the title only if needed.
2188 (grammar_rules_print): Adjust.
2189 (grammar_rules_never_reduced_report): New.
2190 * src/tables.c (action_row): Move the computation of rules never
2191 reduced to...
2192 (token_actions): here.
2193 * src/main.c (main): Make the parser before making the report, so
2194 that rules never reduced are computed.
2195 Call grammar_rules_never_reduced_report.
2196 * src/print.c (print_results): Report rules never reduced.
2197 * tests/conflicts.at, tests/reduce.at: Adjust.
2198
21992002-08-01 Akim Demaille <akim@epita.fr>
2200
2201 Instead of attaching lookaheads and duplicating the rules being
2202 reduced by a state, attach the lookaheads to the reductions.
2203
2204 * src/state.h (state_t): Remove the `lookaheads',
2205 `lookaheads_rule' member.
2206 (reductions_t): Add a `lookaheads' member.
2207 Use a regular array for the `rules'.
2208 * src/state.c (reductions_new): Initialize the lookaheads member
2209 to 0.
2210 (state_rule_lookaheads_print): Adjust.
2211 * src/state.h, src/state.c (state_reductions_find): New.
2212 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
2213 (count_rr_conflicts): Adjust.
2214 * src/lalr.c (LArule): Remove.
2215 (add_lookback_edge): Adjust.
2216 (state_lookaheads_count): New.
2217 (states_lookaheads_initialize): Merge into...
2218 (initialize_LA): this.
2219 (lalr_free): Adjust.
2220 * src/main.c (main): Don't free nullable and derives too early: it
2221 is used by --verbose.
2222 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
2223
22242002-08-01 Akim Demaille <akim@epita.fr>
2225
2226 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
2227 `rule_number_t**'.
2228 (set_derives, free_derives): Rename as...
2229 (derives_compute, derives_free): this.
2230 Adjust all dependencies.
2231 * src/nullable.c (set_nullable, free_nullable): Rename as...
2232 (nullable_compute, nullable_free): these.
2233 (rule_list_t): Store rule_t *, not rule_number_t.
2234 * src/state.c (state_rule_lookaheads_print): Directly compare rule
2235 pointers, instead of their numbers.
2236 * src/main.c (main): Call nullable_free, and derives_free earlier,
2237 as they were lo longer used.
2238
22392002-08-01 Akim Demaille <akim@epita.fr>
2240
2241 * lib/timevar.c (get_time): Include children time.
2242 * src/lalr.h (LA, LArule): Don't export them: used with the
2243 state_t.
2244 * src/lalr.c (LA, LArule): Static.
2245 * src/lalr.h, src/lalr.c (lalr_free): New.
2246 * src/main.c (main): Call it.
2247 * src/tables.c (pack_vector): Check whether loc is >= to the
2248 table_size, not >.
2249 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
2250 (tables_generate): do it, since that's also it which allocates
2251 them.
2252 Don't free LA and LArule, main does.
2253
22542002-07-31 Akim Demaille <akim@epita.fr>
2255
2256 Separate parser tables computation and output.
2257
2258 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
2259 (conflict_list, conflict_list_cnt, table, check, table_ninf)
2260 (yydefgoto, yydefact, high): Move to...
2261 * src/tables.h, src/tables.c: here.
2262 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2263 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2264 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
2265 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
2266 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2267 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2268 (action_row, save_row, token_actions, save_column, default_goto)
2269 (goto_actions, sort_actions, matching_state, pack_vector)
2270 (table_ninf_remap, pack_table, prepare_actions): Move to...
2271 * src/tables.c: here.
2272 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2273 * src/output.c (token_actions, output_base, output_conflicts)
2274 (output_check): Merge into...
2275 (prepare_actions): this.
2276 (actions_output): Rename as...
2277 (user_actions_output): this.
2278 * src/main.c (main): Call tables_generate and tables_free.
2279
22802002-07-31 Akim Demaille <akim@epita.fr>
2281
2282 Steal GCC's --time-report support.
2283
2284 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2285 stolen/adjusted from GCC.
2286 * m4/stage.m4: Remove time related checks.
2287 * m4/timevar.m4: New.
2288 * configure.in: Adjust.
2289 * src/system.h: Adjust to using timevar.h.
2290 * src/getargs.h, src/getargs.c: Support trace_time for
2291 --trace=time.
2292 * src/main.c (stage): Remove.
2293 (main): Replace `stage' invocations with timevar calls.
2294 * src/output.c: Insert pertinent timevar calls.
2295
22962002-07-31 Akim Demaille <akim@epita.fr>
2297
2298 Let --trace have arguments.
2299
2300 * src/getargs.h (enum trace_e): New.
2301 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2302 (long_options, short_options): --trace/-T takes an optional
2303 argument.
2304 Change all the uses of trace_flag to reflect the new flags.
2305 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2306
2307 Strengthen `stage' portability.
2308
2309 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2310 * configure.in: Use it.
2311 Don't check for malloc.h and sys/times.h.
2312 * src/system.h: Include them when appropriate.
2313 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2314 times and struct tms are available.
2315
23162002-07-30 Akim Demaille <akim@epita.fr>
2317
2318 In verbose parse error message, don't report `error' as an
2319 expected token.
2320 * tests/actions.at (Printers and Destructors): Adjust.
2321 * tests/calc.at (Calculator $1): Adjust.
2322 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2323 error message, do not report the parser accepts the error token in
2324 that state.
2325
23262002-07-30 Akim Demaille <akim@epita.fr>
2327
2328 Normalize conflict related messages.
2329
2330 * src/complain.h, src/complain.c (warn, complain): New.
2331 * src/conflicts.c (conflicts_print): Use them.
2332 (conflict_report_yacc): New, extracted from...
2333 (conflicts_print): here.
2334 * tests/conflicts.at, tests/existing.at: Adjust.
2335
23362002-07-30 Akim Demaille <akim@epita.fr>
2337
2338 Report rules which are never reduced by the parser: those hidden
2339 by conflicts.
2340
2341 * src/LR0.c (save_reductions): Don't make the final state too
2342 different: save its reduction (accept) instead of having a state
2343 without any action (no shift or goto, no reduce).
2344 Note: the final state is now a ``regular'' state, i.e., the
2345 parsers now contain `reduce 0' as default reduction.
2346 Nevertheless, since they decide to `accept' when yystate =
2347 final_state, they still will not reduce rule 0.
2348 * src/print.c (print_actions, print_reduction): Adjust.
2349 * src/output.c (action_row): Track reduced rules.
2350 (token_actions): Report rules never reduced.
2351 * tests/conflicts.at, tests/regression.at: Adjust.
2352
23532002-07-30 Akim Demaille <akim@epita.fr>
2354
2355 `stage' was accidently included in a previous patch.
2356 Initiate its autoconfiscation.
2357
2358 * configure.in: Look for malloc.h and sys/times.h.
2359 * src/main.c (stage): Adjust.
2360 Report only when trace_flag.
2361
23622002-07-29 Akim Demaille <akim@epita.fr>
2363
2364 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2365 state_number_t.
2366 (errs_t): symbol_t*, not symbol_number_t.
2367 (reductions_t): rule_t*, not rule_number_t.
2368 (FOR_EACH_SHIFT): New.
2369 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2370 * src/print.c, src/print_graph.c: Adjust.
2371
23722002-07-29 Akim Demaille <akim@epita.fr>
2373
2374 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2375
2376 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2377 (endtoken, accept): these.
2378 * src/reader.c (reader): Set endtoken's default tag to "$end".
2379 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2380 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2381 Adjust.
2382
23832002-07-29 Akim Demaille <akim@epita.fr>
2384
2385 * src/reduce.c (reduce_grammar): When the language is empty,
2386 complain about the start symbol, not the axiom.
2387 Use its location.
2388 * tests/reduce.at (Empty Language): New.
2389
23902002-07-26 Akim Demaille <akim@epita.fr>
2391
2392 * src/reader.h, src/reader.c (gram_error): ... can't get
2393 yycontrol without making too strong assumptions on the parser
2394 itself.
2395 * src/output.c (prepare_tokens): Use the real 0th value of
2396 token_translations instead of `0'.
2397 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2398 visible here.
2399 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2400 for the time being: %locations ought to provide it to yyerror.
2401
24022002-07-25 Akim Demaille <akim@epita.fr>
2403
2404 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2405 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2406 * tests/regression.at (Web2c Actions): Adjust.
2407
24082002-07-25 Akim Demaille <akim@epita.fr>
2409
2410 Stop storing rules from 1 to nrules + 1.
2411
2412 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2413 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2414 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2415 Iterate from 0 to nrules.
2416 Use rule_number_as_item_number and item_number_as_rule_number.
2417 Adjust to `derive' now containing possibly 0.
2418 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2419 Handle the `- 1' part in rule numbers from/to item numbers.
2420 * src/conflicts.c (log_resolution): Fix the message which reversed
2421 shift and reduce.
2422 * src/output.c (action_row): Initialize default_rule to -1.
2423 (token_actions): Adjust.
2424 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2425 expected output.
2426 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2427
24282002-07-25 Akim Demaille <akim@epita.fr>
2429
2430 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2431 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2432 (b4_c_knr_arg_decl): New.
2433 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2434 yyreport_parse_error.
2435
24362002-07-25 Akim Demaille <akim@epita.fr>
2437
2438 * data/yacc.c (yyreport_parse_error): New, extracted from...
2439 (yyparse): here.
2440 (yydestruct, yysymprint): Move above yyparse.
2441 Be K&R compliant.
2442
24432002-07-25 Akim Demaille <akim@epita.fr>
2444
2445 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2446 replace...
2447 (b4_sint_type, b4_uint_type): these.
2448 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2449 * tests/regression.at (Web2c Actions): Adjust.
2450
24512002-07-25 Akim Demaille <akim@epita.fr>
2452
2453 * src/gram.h (TIEM_NUMBER_MAX): New.
2454 (item_number_of_rule_number, rule_number_of_item_number): Rename
2455 as...
2456 (rule_number_as_item_number, item_number_as_rule_number): these.
2457 Adjust dependencies.
2458 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2459 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2460 (symbol_number_to_vector_number): New.
2461 (order): Of vector_number_t* type.
2462 (base_t, BASE_MAX, BASE_MIN): New.
2463 (froms, tos, width, pos, check): Of base_t type.
2464 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2465 (actrow): Of action_number_t type.
2466 (conflrow): Of unsigned int type.
2467 (table_ninf, base_ninf): New.
2468 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2469 (muscle_insert_int_table, muscle_insert_base_table)
2470 (muscle_insert_rule_number_table): New.
2471 (prepare_tokens): Output `toknum' as int_table.
2472 (action_row): Returns a rule_number_t.
2473 Use ACTION_MIN, not SHRT_MIN.
2474 (token_actions): yydefact is rule_number_t*.
2475 (table_ninf_remap): New.
2476 (pack_table): Use it for `base' and `table'.
2477 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2478 replaced with...
2479 (YYPACT_NINF, YYTABLE_NINF): these.
2480 (yypact, yytable): Compute their types instead of hard-coded
2481 `short'.
2482 * tests/regression.at (Web2c Actions): Adjust.
2483
24842002-07-19 Akim Demaille <akim@epita.fr>
2485
2486 * src/scan-gram.l (id): Can start with an underscore.
2487
24882002-07-16 Akim Demaille <akim@epita.fr>
2489
2490 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2491 Adjust all former `associativity' dependencies.
2492 * src/symtab.c (symbol_new): Default associativity is `undef', not
2493 `right'.
2494 (symbol_check_alias_consistence): Adjust.
2495
24962002-07-09 Akim Demaille <akim@epita.fr>
2497
2498 * doc/bison.texinfo: Properly set the ``header'' part.
2499 Use @dircategory ``GNU programming tools'' as per Texinfo's
2500 documentation.
2501 Use @copying.
2502
25032002-07-09 Akim Demaille <akim@epita.fr>
2504
2505 * lib/quotearg.h: Protect against multiple inclusions.
2506 * src/location.h (location_t): Add a `file' member.
2507 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2508 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2509 `error_one_per_line' support.
2510
25112002-07-09 Akim Demaille <akim@epita.fr>
2512
2513 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2514 * src/reader.c (lineno): Remove.
2515 Adjust all dependencies.
2516 (get_merge_function): Take a location and use complain_at.
2517 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2518 * tests/regression.at (Invalid inputs, Mixing %token styles):
2519 Adjust.
2520
25212002-07-09 Akim Demaille <akim@epita.fr>
2522
2523 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2524 recovery rule, and forbid extensions when --yacc.
2525 (gram_error): Use complain_at.
2526 * src/reader.c (reader): Exit if there were parse errors.
2527
25282002-07-09 Akim Demaille <akim@epita.fr>
2529
2530 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2531 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2532 Reported by R Blake <blakers@mac.com>.
2533
25342002-07-09 Akim Demaille <akim@epita.fr>
2535
2536 * data/yacc.c: Output the copyright notive in the header.
2537
25382002-07-03 Akim Demaille <akim@epita.fr>
2539
2540 * src/output.c (froms, tos): Are state_number_t.
2541 (save_column): sp, sp1, and sp2 are state_number_t.
2542 (prepare): Rename `final' as `final_state_number', `nnts' as
2543 `nterms_number', `nrules' as `rules_number', `nstates' as
2544 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2545 unused.
2546 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2547 * data/lalr1.cc (nsym_): Remove, unused.
2548
25492002-07-03 Akim Demaille <akim@epita.fr>
2550
2551 * src/lalr.h, src/lalr.c (goto_number_t): New.
2552 * src/lalr.c (goto_list_t): New.
2553 Propagate them.
2554 * src/nullable.c (rule_list_t): New.
2555 Propagate.
2556 * src/types.h: Remove.
2557
25582002-07-03 Akim Demaille <akim@epita.fr>
2559
2560 * src/closure.c (print_fderives): Use rule_rhs_print.
2561 * src/derives.c (print_derives): Use rule_rhs_print.
2562 (rule_list_t): New, replaces `shorts'.
2563 (set_derives): Add comments.
2564 * tests/sets.at (Nullable, Firsts): Adjust.
2565
25662002-07-03 Akim Demaille <akim@epita.fr>
2567
2568 * src/output.c (prepare_actions): Free `tally' and `width'.
2569 (prepare_actions): Allocate and free `order'.
2570 * src/symtab.c (symbols_free): Free `symbols'.
2571 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2572 * src/output.c (m4_invoke): Move to...
2573 * src/scan-skel.l: here.
2574 (<<EOF>>): Close yyout, and free its name.
2575
25762002-07-03 Akim Demaille <akim@epita.fr>
2577
2578 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2579
2580 * src/LR0.c (new_state): Merge into...
2581 (state_list_append): this.
2582 (new_states): Merge into...
2583 (generate_states): here.
2584 (set_states): Don't ensure a proper `errs' state member here, do it...
2585 * src/conflicts.c (conflicts_solve): here.
2586 * src/state.h, src/state.c: Comment changes.
2587 (state_t): Rename member `shifts' as `transitions'.
2588 Adjust all dependencies.
2589 (errs_new): For consistency, also take the values as argument.
2590 (errs_dup): Remove.
2591 (state_errs_set): New.
2592 (state_reductions_set, state_transitions_set): Assert that no
2593 previous value was assigned.
2594 (state_free): New.
2595 (states_free): Use it.
2596 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2597 temporary storage: use `errs' and `nerrs' as elsewhere.
2598 (set_conflicts): Allocate and free this `errs'.
2599
26002002-07-02 Akim Demaille <akim@epita.fr>
2601
2602 * lib/libiberty.h: New.
2603 * lib: Update the bitset implementation from upstream.
2604 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2605 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2606 * src/main.c: Adjust bitset stats calls.
2607
26082002-07-01 Paul Eggert <eggert@twinsun.com>
2609
2610 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2611 char, so that negative chars don't collide with $.
2612
26132002-06-30 Akim Demaille <akim@epita.fr>
2614
2615 Have the GLR tests be `warning' checked, and fix the warnings.
2616
2617 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2618 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2619 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2620 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2621 (yyaddDeferredAction): static.
2622 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2623 (yyreportParseError): yyprefix is const.
2624 yytokenp is used only when verbose.
2625 (yy__GNUC__): Replace with __GNUC__.
2626 (yypdumpstack): yyi is size_t.
2627 (yypreference): Un-yy local variables and arguments, to avoid
2628 clashes with `yyr1'. Anyway, we are not in the user name space.
2629 (yytname_size): be an int, as is compared with ints.
2630 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2631 Use them.
2632 * tests/cxx-gram.at: Use quotation to protect $1.
2633 Use AT_COMPILE to enable warnings hunts.
2634 Prototype yylex and yyerror.
2635 `Use' argc.
2636 Include `string.h', not `strings.h'.
2637 Produce and prototype stmtMerge only when used.
2638 yylex takes a location.
2639
26402002-06-30 Akim Demaille <akim@epita.fr>
2641
2642 We spend a lot of time in quotearg, in particular when --verbose.
2643
2644 * src/symtab.c (symbol_get): Store a quoted version of the key.
2645 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2646 Adjust all callers.
2647
26482002-06-30 Akim Demaille <akim@epita.fr>
2649
2650 * src/state.h (reductions_t): Rename member `nreds' as num.
2651 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2652 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2653
26542002-06-30 Akim Demaille <akim@epita.fr>
2655
2656 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2657 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2658 (shifts_to): Rename as...
2659 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2660 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2661 (TRANSITION_IS_DISABLED, transitions_to): these.
2662
26632002-06-30 Akim Demaille <akim@epita.fr>
2664
2665 * src/print.c (print_shifts, print_gotos): Merge into...
2666 (print_transitions): this.
2667 (print_transitions, print_errs, print_reductions): Align the
2668 lookaheads columns.
2669 (print_core, print_transitions, print_errs, print_state,
2670 print_grammar): Output empty lines separator before, not after.
2671 (state_default_rule_compute): Rename as...
2672 (state_default_rule): this.
2673 * tests/conflicts.at (Defaulted Conflicted Reduction),
2674 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2675 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2676
26772002-06-30 Akim Demaille <akim@epita.fr>
2678
2679 Display items as we display rules.
2680
2681 * src/gram.h, src/gram.c (rule_lhs_print): New.
2682 * src/gram.c (grammar_rules_partial_print): Use it.
2683 * src/print.c (print_core): Likewise.
2684 * tests/conflicts.at (Defaulted Conflicted Reduction),
2685 (Unresolved SR Conflicts): Adjust.
2686 (Unresolved SR Conflicts): Adjust and rename as...
2687 (Resolved SR Conflicts): this, as was meant.
2688 * tests/regression.at (Web2c Report): Adjust.
2689
26902002-06-30 Akim Demaille <akim@epita.fr>
2691
2692 * src/print.c (state_default_rule_compute): New, extracted from...
2693 (print_reductions): here.
2694 Pessimize, but clarify the code.
2695 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2696
26972002-06-30 Akim Demaille <akim@epita.fr>
2698
2699 * src/output.c (action_row): Let default_rule be always a rule
2700 number.
2701
27022002-06-30 Akim Demaille <akim@epita.fr>
2703
2704 * src/closure.c (print_firsts, print_fderives, closure):
2705 Use BITSET_EXECUTE.
2706 * src/lalr.c (lookaheads_print): Likewise.
2707 * src/state.c (state_rule_lookaheads_print): Likewise.
2708 * src/print_graph.c (print_core): Likewise.
2709 * src/print.c (print_reductions): Likewise.
2710 * src/output.c (action_row): Likewise.
2711 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2712
27132002-06-30 Akim Demaille <akim@epita.fr>
2714
2715 * src/print_graph.c: Use report_flag.
2716
27172002-06-30 Akim Demaille <akim@epita.fr>
2718
2719 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2720 to...
2721 * src/relation.h, src/relation.c (traverse, relation_digraph)
2722 (relation_print, relation_transpose): New.
2723
27242002-06-30 Akim Demaille <akim@epita.fr>
2725
2726 * src/state.h, src/state.c (shifts_to): New.
2727 * src/lalr.c (build_relations): Use it.
2728
27292002-06-30 Akim Demaille <akim@epita.fr>
2730
2731 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2732 (item_number_of_rule_number, rule_number_of_item_number): New.
2733 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2734 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2735 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2736 Propagate their use.
2737 Much remains to be done, in particular wrt `shorts' from types.h.
2738
27392002-06-30 Akim Demaille <akim@epita.fr>
2740
2741 * src/symtab.c (symbol_new): Initialize the `printer' member.
2742
27432002-06-30 Akim Demaille <akim@epita.fr>
2744
2745 * src/LR0.c (save_reductions): Remove, replaced by...
2746 * src/state.h, src/state.c (state_reductions_set): New.
2747 (reductions, errs): Rename as...
2748 (reductions_t, errs_t): these.
2749 Adjust all dependencies.
2750
27512002-06-30 Akim Demaille <akim@epita.fr>
2752
2753 * src/LR0.c (state_list_t, state_list_append): New.
2754 (first_state, last_state): Now symbol_list_t.
2755 (this_state): Remove.
2756 (new_itemsets, append_states, save_reductions): Take a state_t as
2757 argument.
2758 (set_states, generate_states): Adjust.
2759 (save_shifts): Remove, replaced by...
2760 * src/state.h, src/state.c (state_shifts_set): New.
2761 (shifts): Rename as...
2762 (shifts_t): this.
2763 Adjust all dependencies.
2764 * src/state.h (state_t): Remove the `next' member.
2765
27662002-06-30 Akim Demaille <akim@epita.fr>
2767
2768 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2769 escaped in slot 0.
2770
27712002-06-30 Akim Demaille <akim@epita.fr>
2772
2773 Use hash.h for the state hash table.
2774
2775 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
2776 (allocate_storage): Use state_hash_new.
2777 (free_storage): Use state_hash_free.
2778 (new_state, get_state): Adjust.
2779 * src/lalr.h, src/lalr.c (states): Move to...
2780 * src/states.h (state_t): Remove the `link' member, no longer
2781 used.
2782 * src/states.h, src/states.c: here.
2783 (state_hash_new, state_hash_free, state_hash_lookup)
2784 (state_hash_insert, states_free): New.
2785 * src/states.c (state_table, state_compare, state_hash): New.
2786 * src/output.c (output_actions): Do not free states now, since we
2787 still need to know the final_state number in `prepare', called
2788 afterwards. Do it...
2789 * src/main.c (main): here: call states_free after `output'.
2790
27912002-06-30 Akim Demaille <akim@epita.fr>
2792
2793 * src/state.h, src/state.c (state_new): New, extracted from...
2794 * src/LR0.c (new_state): here.
2795 * src/state.h (STATE_ALLOC): Move to...
2796 * src/state.c: here.
2797 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
2798 * src/state.h, src/state.c: here.
2799
28002002-06-30 Akim Demaille <akim@epita.fr>
2801
2802 * src/reader.c (gensym): Rename as...
2803 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
2804 (getsym): Rename as...
2805 (symbol_get): this.
2806
28072002-06-30 Akim Demaille <akim@epita.fr>
2808
2809 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
2810 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
2811 * src/output.c, src/print.c, src/print_graph.c: Propagate.
2812 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
2813
28142002-06-30 Akim Demaille <akim@epita.fr>
2815
2816 Make the test suite pass with warnings checked.
2817
2818 * tests/actions.at (Printers and Destructors): Improve.
2819 Avoid unsigned vs. signed issues.
2820 * tests/calc.at: Don't exercise the scanner here, do it...
2821 * tests/input.at (Torturing the Scanner): here.
2822
28232002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2824
2825 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
2826 reorganize first lines parallel to yacc.c.
2827
28282002-06-28 Akim Demaille <akim@epita.fr>
2829
2830 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
2831 (b4_token_enum, b4_token_defines): New, factored from...
2832 * data/lalr1.cc, data/yacc.c, glr.c: here.
2833
28342002-06-28 Akim Demaille <akim@epita.fr>
2835
2836 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
2837 unused variables.
2838 * src/output.c (merger_output): static.
2839
28402002-06-28 Akim Demaille <akim@epita.fr>
2841
2842 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
2843 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
2844 pacify GCC.
2845 * src/output.c (save_row): Initialize all the variables to pacify GCC.
2846
28472002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2848
2849 Accumulated changelog for new GLR parsing features.
2850
2851 * src/conflicts.c (count_total_conflicts): Change name to
2852 conflicts_total_count.
2853 * src/conflicts.h: Ditto.
2854 * src/output.c (token_actions): Use the new name.
2855 (output_conflicts): Change conflp => conflict_list_heads, and
2856 confl => conflict_list for better readability.
2857 * data/glr.c: Use the new names.
2858 * NEWS: Add self to GLR announcement.
2859
2860 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
2861
2862 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
2863 Akim Demaille.
2864
2865 * data/bison.glr: Change name to glr.c
2866 * data/glr.c: Renamed from bison.glr.
2867 * data/Makefile.am: Add glr.c
2868
2869 * src/getargs.c:
2870
2871 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
2872 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
2873
2874 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2875
2876 * data/bison.glr: Be sure to restore the
2877 current #line when returning to the skeleton contents after having
2878 exposed the input file's #line.
2879
2880 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2881
2882 * data/bison.glr: Bring up to date with changes to bison.simple.
2883
2884 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2885
2886 * data/bison.glr: Correct definitions that use b4_prefix.
2887 Various reformatting.
2888 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
2889 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
2890 yytokenp argument; now part of stack.
2891 (yychar): Define to behave as documented.
2892 (yyclearin): Ditto.
2893
2894 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2895
2896 * src/reader.h: Add declaration for free_merger_functions.
2897
2898 * src/reader.c (merge_functions): New variable.
2899 (get_merge_function): New function.
2900 (free_merger_functions): New function.
2901 (readgram): Check for %prec that is not followed by a symbol.
2902 Handle %dprec and %merge declarations.
2903 (packgram): Initialize dprec and merger fields in rules array.
2904
2905 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
2906 conflict_list_cnt, conflict_list_free): New variables.
2907 (table_grow): Also grow conflict_table.
2908 (prepare_rules): Output dprec and merger tables.
2909 (conflict_row): New function.
2910 (action_row): Output conflict lists for GLR parser. Don't use
2911 default reduction in conflicted states for GLR parser so that there
2912 are spaces for the conflict lists.
2913 (save_row): Also save conflict information.
2914 (token_actions): Allocate conflict list.
2915 (merger_output): New function.
2916 (pack_vector): Pack conflict table, too.
2917 (output_conflicts): New function to output yyconflp and yyconfl.
2918 (output_check): Allocate conflict_tos.
2919 (output_actions): Output conflict tables, also.
2920 (output_skeleton): Output b4_mergers definition.
2921 (prepare): Output b4_max_rhs_length definition.
2922 Use 'bison.glr' as default skeleton for GLR parsers.
2923
2924 * src/gram.c (glr_parser): New flag.
2925 (grammar_free): Call free_merger_functions.
2926
2927 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
2928 all pairs of conflicting reductions, rather than just all tokens
2929 causing conflicts. Needed to size conflict tables.
2930 (conflicts_output): Modify call to count_rr_conflicts for new
2931 interface.
2932 (conflicts_print): Ditto.
2933 (count_total_conflicts): New function.
2934
2935 * src/reader.h (merger_list): New type.
2936 (merge_functions): New variable.
2937
2938 * src/lex.h (tok_dprec, tok_merge): New token types.
2939
2940 * src/gram.h (rule_s): Add dprec and merger fields.
2941 (glr_parser): New flag.
2942
2943 * src/conflicts.h (count_total_conflicts): New function.
2944
2945 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
2946
2947 * doc/bison.texinfo (Generalized LR Parsing): New section.
2948 (GLR Parsers): New section.
2949 (Language and Grammar): Mention GLR parsing.
2950 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
2951 Correct typo ("tge" -> "the").
2952
2953 * data/bison.glr: New skeleton for GLR parsing.
2954
2955 * tests/cxx-gram.at: New tests for GLR parsing.
2956
2957 * tests/testsuite.at: Include cxx-gram.at.
2958
2959 * tests/Makefile.am: Add cxx-gram.at.
2960
2961 * src/parse-gram.y:
2962
2963 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
2964
2965 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
2966
29672002-06-27 Akim Demaille <akim@epita.fr>
2968
2969 * src/options.h, src/options.c: Remove.
2970 * src/getargs.c (short_options, long_options): New.
2971
29722002-06-27 Akim Demaille <akim@epita.fr>
2973
2974 * data/bison.simple, data/bison.c++: Rename as...
2975 * data/yacc.c, data/lalr1.cc: these.
2976 * doc/bison.texinfo (Environment Variables): Remove.
2977
29782002-06-25 Raja R Harinath <harinath@cs.umn.edu>
2979
2980 * src/getargs.c (report_argmatch): Initialize strtok().
2981
29822002-06-20 Akim Demaille <akim@epita.fr>
2983
2984 * data/bison.simple (b4_symbol_actions): New, replaces...
2985 (b4_symbol_destructor, b4_symbol_printer): these.
2986 (yysymprint): Be sure to call YYPRINT only for tokens, and using
2987 user token numbers.
2988
29892002-06-20 Akim Demaille <akim@epita.fr>
2990
2991 * data/bison.simple (yydestructor): Rename as...
2992 (yydestruct): this.
2993
29942002-06-20 Akim Demaille <akim@epita.fr>
2995
2996 * src/symtab.h, src/symtab.c (symbol_type_set)
2997 (symbol_destructor_set, symbol_precedence_set): The location is
2998 the last argument.
2999 Adjust all callers.
3000
30012002-06-20 Akim Demaille <akim@epita.fr>
3002
3003 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
3004 internals.
3005 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
3006 Takes a location.
3007 * src/symtab.h, src/symtab.c (symbol_class_set)
3008 (symbol_user_token_number_set): Likewise.
3009 Adjust all callers.
3010 Promote complain_at.
3011 * tests/input.at (Type Clashes): Adjust.
3012
30132002-06-20 Akim Demaille <akim@epita.fr>
3014
3015 * data/bison.simple (YYLEX): Fix the declaration when
3016 %pure-parser.
3017
30182002-06-20 Akim Demaille <akim@epita.fr>
3019
3020 * data/bison.simple (yysymprint): Don't print the token number,
3021 just its name.
3022 * tests/actions.at (Destructors): Rename as...
3023 (Printers and Destructors): this.
3024 Also exercise %printer.
3025
30262002-06-20 Akim Demaille <akim@epita.fr>
3027
3028 * data/bison.simple (YYDSYMPRINT): New.
3029 Use it to remove many of the #if YYDEBUG/if (yydebug).
3030
30312002-06-20 Akim Demaille <akim@epita.fr>
3032
3033 * src/symtab.h, src/symtab.c (symbol_t): printer and
3034 printer_location are new members.
3035 (symbol_printer_set): New.
3036 * src/parse-gram.y (PERCENT_PRINTER): New token.
3037 Handle its associated rule.
3038 * src/scan-gram.l: Adjust.
3039 (handle_destructor_at, handle_destructor_dollar): Rename as...
3040 (handle_symbol_code_at, handle_symbol_code_dollar): these.
3041 * src/output.c (symbol_printers_output): New.
3042 (output_skeleton): Call it.
3043 * data/bison.simple (yysymprint): New. Cannot be named yyprint
3044 since there are already many grammar files with a user `yyprint'.
3045 Replace the calls to YYPRINT to calls to yysymprint.
3046 * tests/calc.at: Adjust.
3047 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
3048 taking advantage of parser very internal details (stack size!).
3049
30502002-06-20 Akim Demaille <akim@epita.fr>
3051
3052 * src/scan-gram.l: Complete the scanner with the missing patterns
3053 to pacify Flex.
3054 Use `quote' and `symbol_tag_get' where appropriate.
3055
30562002-06-19 Akim Demaille <akim@epita.fr>
3057
3058 * tests/actions.at (Destructors): Augment to test locations.
3059 * data/bison.simple (yydestructor): Pass it the current location
3060 if locations are enabled.
3061 Prototype only when __STDC__ or C++.
3062 Change the argument names to move into the yy name space: there is
3063 user code here.
3064
30652002-06-19 Akim Demaille <akim@epita.fr>
3066
3067 * data/bison.simple (b4_pure_if): New.
3068 Use it instead of #ifdef YYPURE.
3069
30702002-06-19 Akim Demaille <akim@epita.fr>
3071
3072 * data/bison.simple (b4_location_if): New.
3073 Use it instead of #ifdef YYLSP_NEEDED.
3074
30752002-06-19 Akim Demaille <akim@epita.fr>
3076
3077 Prepare @$ in %destructor, but currently don't bind it in the
3078 skeleton, as %location use is not cleaned up yet.
3079
3080 * src/scan-gram.l (handle_dollar, handle_destructor_at)
3081 (handle_action_at): New.
3082 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
3083 a braced_code_t and a location as additional arguments.
3084 (handle_destructor_dollar): Instead of requiring `b4_eval', just
3085 unquote one when outputting `b4_dollar_dollar'.
3086 Adjust callers.
3087 * data/bison.simple (b4_eval): Remove.
3088 (b4_symbol_destructor): Adjust.
3089 * tests/input.at (Invalid @n): Adjust.
3090
30912002-06-19 Zack Weinberg <zack@codesourcery.com>
3092
3093 * doc/bison.texinfo: Document ability to have multiple
3094 prologue sections.
3095
30962002-06-18 Akim Demaille <akim@epita.fr>
3097
3098 * src/files.c (compute_base_names): When computing the output file
3099 names from the input file name, strip the directory part.
3100
31012002-06-18 Akim Demaille <akim@epita.fr>
3102
3103 * data/bison.simple.new: Comment changes.
3104 Reported by Andreas Schwab.
3105
31062002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
3107
3108 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
3109 there are no `label `yyoverflowlab' defined but not used' warnings
3110 when yyoverflow is defined.
3111
31122002-06-18 Akim Demaille <akim@epita.fr>
3113
3114 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
3115 new member.
3116 (symbol_destructor_set): Adjust.
3117 * src/output.c (symbol_destructors_output): Output the destructor
3118 locations.
3119 Output the symbol name.
3120 * data/bison.simple (b4_symbol_destructor): Adjust.
3121
31222002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
3123 and Akim Demaille <akim@epita.fr>
3124
3125 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
3126 what's left on the stack when the error recovery hits EOF.
3127 * tests/actions.at (Destructors): Complete to exercise this case.
3128
31292002-06-17 Akim Demaille <akim@epita.fr>
3130
3131 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
3132 arguments is really empty, not only equal to `[]'.
3133 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
3134 member.
3135 (symbol_destructor_set): New.
3136 * src/output.c (symbol_destructors_output): New.
3137 * src/reader.h (brace_code_t, current_braced_code): New.
3138 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
3139 (handle_dollar): Rename as...
3140 (handle_action_dollar): this.
3141 (handle_destructor_dollar): New.
3142 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
3143 (grammar_declaration): Use it.
3144 * data/bison.simple (yystos): Is always defined.
3145 (yydestructor): New.
3146 * tests/actions.at (Destructors): New.
3147 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
3148
31492002-06-17 Akim Demaille <akim@epita.fr>
3150
3151 * src/symlist.h, src/symlist.c (symbol_list_length): New.
3152 * src/scan-gram.l (handle_dollar, handle_at): Compute the
3153 rule_length only when needed.
3154 * src/output.c (actions_output, token_definitions_output): Output
3155 the full M4 block.
3156 * src/symtab.c: Don't access directly to the symbol tag, use
3157 symbol_tag_get.
3158 * src/parse-gram.y: Use symbol_list_free.
3159
31602002-06-17 Akim Demaille <akim@epita.fr>
3161
3162 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
3163 (symbol_list_prepend, get_type_name): Move to...
3164 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
3165 (symbol_list_prepend, symbol_list_n_type_name_get): here.
3166 Adjust all callers.
3167 (symbol_list_free): New.
3168 * src/scan-gram.l (handle_dollar): Takes a location.
3169 * tests/input.at (Invalid $n): Adjust.
3170
31712002-06-17 Akim Demaille <akim@epita.fr>
3172
3173 * src/reader.h, src/reader.c (symbol_list_new): Export it.
3174 (symbol_list_prepend): New.
3175 * src/parse-gram.y (%union): `list' is a new member.
3176 (symbols.1): New, replaces...
3177 (terms_to_prec.1, nterms_to_type.1): these.
3178 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
3179 Take a location as additional argument.
3180 Adjust all callers.
3181
31822002-06-15 Akim Demaille <akim@epita.fr>
3183
3184 * src/parse-gram.y: Move %token in the declaration section so that
3185 we don't depend upon CVS Bison.
3186
31872002-06-15 Akim Demaille <akim@epita.fr>
3188
3189 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
3190 * src/print.c (print_core): Use it.
3191
31922002-06-15 Akim Demaille <akim@epita.fr>
3193
3194 * src/conflicts.c (log_resolution): Accept the rule involved in
3195 the sr conflicts instead of the lookahead number that points to
3196 that rule.
3197 (flush_reduce): Accept the current lookahead vector as argument,
3198 instead of the index in LA.
3199 (resolve_sr_conflict): Accept the current number of lookahead
3200 bitset to consider for the STATE, instead of the index in LA.
3201 (set_conflicts): Adjust.
3202 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
3203
32042002-06-15 Akim Demaille <akim@epita.fr>
3205
3206 * src/state.h (state_t): Replace the `lookaheadsp' member, a
3207 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
3208 Adjust all dependencies.
3209 * src/lalr.c (initialize_lookaheads): Split into...
3210 (states_lookaheads_count, states_lookaheads_initialize): these.
3211 (lalr): Adjust.
3212
32132002-06-15 Akim Demaille <akim@epita.fr>
3214
3215 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
3216 out of...
3217 (grammar_rules_print): here.
3218 * src/reduce.c (reduce_output): Use it.
3219 * tests/reduce.at (Useless Rules, Reduced Automaton)
3220 (Underivable Rules): Adjust.
3221
32222002-06-15 Akim Demaille <akim@epita.fr>
3223
3224 Copy BYacc's nice way to report the grammar.
3225
3226 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
3227 New.
3228 Don't print the rules' location, it is confusing and useless.
3229 (rule_print): Use grammar_rhs_print.
3230 * src/print.c (print_grammar): Use grammar_rules_print.
3231
32322002-06-15 Akim Demaille <akim@epita.fr>
3233
3234 Complete and rationalize `useless thing' warnings.
3235
3236 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
3237 (symbol_tag_print): New.
3238 Use them everywhere in place of accessing directly the tag member.
3239 * src/gram.h, src/gram.c (rule_print): New.
3240 Use it where a rule used to be printed `by hand'.
3241 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
3242 (reduce_grammar_tables): Report the useless rules.
3243 (reduce_print): Useless things are a warning, not an error.
3244 Report it as such.
3245 * tests/reduce.at (Useless Nonterminals, Useless Rules):
3246 (Reduced Automaton, Underivable Rules): Adjust.
3247 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
3248 * tests/conflicts.at (Unresolved SR Conflicts)
3249 (Solved SR Conflicts): Adjust.
3250
32512002-06-15 Akim Demaille <akim@epita.fr>
3252
3253 Let symbols have a location.
3254
3255 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
3256 (getsym): Adjust.
3257 Adjust all callers.
3258 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
3259 Use location_t, not int.
3260 * src/symtab.c (symbol_check_defined): Take advantage of the
3261 location.
3262 * tests/regression.at (Invalid inputs): Adjust.
3263
32642002-06-15 Akim Demaille <akim@epita.fr>
3265
3266 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3267 (input): Don't try to initialize yylloc here, do it in the
3268 scanner.
3269 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3270 * src/gram.h (rule_t): Change line and action_line into location
3271 and action_location, of location_t type.
3272 Adjust all dependencies.
3273 * src/location.h, src/location.c (empty_location): New.
3274 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3275 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3276 (grammar_current_rule_symbol_append)
3277 (grammar_current_rule_action_append): Expect a location as argument.
3278 * src/reader.c (grammar_midrule_action): Adjust to attach an
3279 action's location as dummy symbol location.
3280 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3281 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3282 the line numbers.
3283
32842002-06-14 Akim Demaille <akim@epita.fr>
3285
3286 Grammar declarations may be found in the grammar section.
3287
3288 * src/parse-gram.y (rules_or_grammar_declaration): New.
3289 (declarations): Each declaration may end with a semicolon, not
3290 just...
3291 (grammar_declaration): `"%union"'.
3292 (grammar): Branch to rules_or_grammar_declaration.
3293
32942002-06-14 Akim Demaille <akim@epita.fr>
3295
3296 * src/main.c (main): Invoke scanner_free.
3297
32982002-06-14 Akim Demaille <akim@epita.fr>
3299
3300 * src/output.c (m4_invoke): Extracted from...
3301 (output_skeleton): here.
3302 Free tempfile.
3303
33042002-06-14 Akim Demaille <akim@epita.fr>
3305
3306 * src/parse-gram.y (directives, directive, gram)
3307 (grammar_directives, precedence_directives, precedence_directive):
3308 Rename as...
3309 (declarations, declaration, grammar, grammar_declaration)
3310 (precedence_declaration, precedence_declarator): these.
3311 (symbol_declaration): New.
3312
33132002-06-14 Akim Demaille <akim@epita.fr>
3314
3315 * src/files.c (action_obstack): Remove, unused.
3316 (output_obstack): Remove it, and all its dependencies, as it is no
3317 longer needed.
3318 * src/reader.c (epilogue_set): Build the epilogue in the
3319 muscle_obstack.
3320 * src/output.h, src/output.c (muscle_obstack): Move to...
3321 * src/muscle_tab.h, src/muscle_tab.h: here.
3322 (muscle_init): Initialize muscle_obstack.
3323 (muscle_free): New.
3324 * src/main.c (main): Call it.
3325
33262002-06-14 Akim Demaille <akim@epita.fr>
3327
3328 * src/location.h: New, extracted from...
3329 * src/reader.h: here.
3330 * src/Makefile.am (noinst_HEADERS): Merge into
3331 (bison_SOURCES): this.
3332 Add location.h.
3333 * src/parse-gram.y: Use location_t instead of Bison's.
3334 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3335 Use location_t instead of ints.
3336
33372002-06-14 Akim Demaille <akim@epita.fr>
3338
3339 * data/bison.simple, data/bison.c++: Be sure to restore the
3340 current #line when returning to the skeleton contents after having
3341 exposed the input file's #line.
3342
33432002-06-12 Akim Demaille <akim@epita.fr>
3344
3345 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3346 eager.
3347 * tests/actions.at (Exotic Dollars): New.
3348
33492002-06-12 Akim Demaille <akim@epita.fr>
3350
3351 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3352 ['"/] too eagerly.
3353 * tests/input.at (Torturing the Scanner): New.
3354
33552002-06-11 Akim Demaille <akim@epita.fr>
3356
3357 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3358 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3359 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3360 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3361 * src/reader.c (reader): Use it.
3362
33632002-06-11 Akim Demaille <akim@epita.fr>
3364
3365 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3366 Adjust all callers.
3367 (scanner_last_string_free): New.
3368
33692002-06-11 Akim Demaille <akim@epita.fr>
3370
3371 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3372 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3373 (last_string, YY_OBS_FREE): New.
3374 Use them when returning an ID.
3375
33762002-06-11 Akim Demaille <akim@epita.fr>
3377
3378 Have Bison grammars parsed by a Bison grammar.
3379
3380 * src/reader.c, src/reader.h (prologue_augment): New.
3381 * src/reader.c (copy_definition): Remove.
3382
3383 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3384 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3385 (grammar_current_rule_prec_set, grammar_current_rule_check)
3386 (grammar_current_rule_symbol_append)
3387 (grammar_current_rule_action_append): Export.
3388 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3389 (symbol_list_action_append): Remove.
3390 Hook the routines from reader.
3391 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3392 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3393
3394 * src/reader.c (read_declarations): Remove, unused.
3395
3396 * src/parse-gram.y: Handle the epilogue.
3397 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3398 (grammar_start_symbol_set): this.
3399 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3400 * src/reader.c (readgram): Remove, unused.
3401 (reader): Adjust to insert eoftoken and axiom where appropriate.
3402
3403 * src/reader.c (copy_dollar): Replace with...
3404 * src/scan-gram.h (handle_dollar): this.
3405 * src/parse-gram.y: Remove `%thong'.
3406
3407 * src/reader.c (copy_at): Replace with...
3408 * src/scan-gram.h (handle_at): this.
3409
3410 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3411 New.
3412
3413 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3414 time being.
3415
3416 * src/reader.h, src/reader.c (grammar_rule_end): New.
3417
3418 * src/parse.y (current_type, current_class): New.
3419 Implement `%nterm', `%token' support.
3420 Merge `%term' into `%token'.
3421 (string_as_id): New.
3422 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3423 type name.
3424
3425 * src/parse-gram.y: Be sure to handle properly the beginning of
3426 rules.
3427
3428 * src/parse-gram.y: Handle %type.
3429 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3430
3431 * src/parse-gram.y: More directives support.
3432 * src/options.c: No longer handle source directives.
3433
3434 * src/parse-gram.y: Fix %output.
3435
3436 * src/parse-gram.y: Handle %union.
3437 Use the prologue locations.
3438 * src/reader.c (parse_union_decl): Remove.
3439
3440 * src/reader.h, src/reader.c (epilogue_set): New.
3441 * src/parse-gram.y: Use it.
3442
3443 * data/bison.simple, data/bison.c++: b4_stype is now either not
3444 defined, then default to int, or to the contents of %union,
3445 without `union' itself.
3446 Adjust.
3447 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3448
3449 * src/output.c (actions_output): Don't output braces, as they are
3450 already handled by the scanner.
3451
3452 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3453 characters to themselves.
3454
3455 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3456 that the epilogue has a proper #line.
3457
3458 * src/parse-gram.y: Handle precedence/associativity.
3459
3460 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3461 a terminal.
3462 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3463 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3464 at all to define terminals that cannot be emitted.
3465
3466 * src/scan-gram.l: Escape M4 characters.
3467
3468 * src/scan-gram.l: Working properly with escapes in user
3469 strings/characters.
3470
3471 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3472 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3473 grammar.
3474 Use more modest sizes, as for the time being the parser does not
3475 release memory, and therefore the process swallows a huge amount
3476 of memory.
3477
3478 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3479 stricter %token grammar.
3480
3481 * src/symtab.h (associativity): Add `undef_assoc'.
3482 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3483 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3484
3485 * tests/regression.at (Invalid %directive): Remove, as it is now
3486 meaningless.
3487 (Invalid inputs): Adjust to the new error messages.
3488 (Token definitions): The new grammar doesn't allow too many
3489 eccentricities.
3490
3491 * src/lex.h, src/lex.c: Remove.
3492 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3493 (copy_character, copy_string2, copy_string, copy_identifier)
3494 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3495 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3496 (parse_action): Remove.
3497 * po/POTFILES.in: Adjust.
3498
34992002-06-11 Akim Demaille <akim@epita.fr>
3500
3501 * src/reader.c (parse_action): Don't store directly into the
3502 rule's action member: return the action as a string.
3503 Don't require `rule_length' as an argument: compute it.
3504 (grammar_current_rule_symbol_append)
3505 (grammar_current_rule_action_append): New, eved out from
3506 (readgram): here.
3507 Remove `action_flag', `rulelength', unused now.
3508
35092002-06-11 Akim Demaille <akim@epita.fr>
3510
3511 * src/reader.c (grammar_current_rule_prec_set).
3512 (grammar_current_rule_check): New, eved out from...
3513 (readgram): here.
3514 Remove `xaction', `first_rhs': useless.
3515 * tests/input.at (Type clashes): New.
3516 * tests/existing.at (GNU Cim Grammar): Adjust.
3517
35182002-06-11 Akim Demaille <akim@epita.fr>
3519
3520 * src/reader.c (grammar_midrule_action): New, Eved out from
3521 (readgram): here.
3522
35232002-06-11 Akim Demaille <akim@epita.fr>
3524
3525 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3526 New.
3527 (readgram): Use them as replacement of inlined code, crule and
3528 crule1.
3529
35302002-06-11 Akim Demaille <akim@epita.fr>
3531
3532 * src/reader.c (grammar_end, grammar_symbol_append): New.
3533 (readgram): Use them.
3534 Make the use of `p' as local as possible.
3535
35362002-06-10 Akim Demaille <akim@epita.fr>
3537
3538 GCJ's parser requires the tokens to be defined before the prologue.
3539
3540 * data/bison.simple: Output the token definition before the user's
3541 prologue.
3542 * tests/regression.at (Braces parsing, Duplicate string)
3543 (Mixing %token styles): Check the output from bison.
3544 (Early token definitions): New.
3545
35462002-06-10 Akim Demaille <akim@epita.fr>
3547
3548 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3549 assigning twice the same user number to a token, so that we can
3550 use it in...
3551 * src/lex.c (lex): here.
3552 Also use `symbol_class_set' instead of hand written code.
3553 * src/reader.c (parse_assoc_decl): Likewise.
3554
35552002-06-10 Akim Demaille <akim@epita.fr>
3556
3557 * src/symtab.c, src/symtab.c (symbol_class_set)
3558 (symbol_user_token_number_set): New.
3559 * src/reader.c (parse_token_decl): Use them.
3560 Use a switch instead of ifs.
3561 Use a single argument.
3562
35632002-06-10 Akim Demaille <akim@epita.fr>
3564
3565 Remove `%thong' support as it is undocumented, unused, duplicates
3566 `%token's job, and creates useless e-mail traffic with people who
3567 want to know what it is, why it is undocumented, unused, and
3568 duplicates `%token's job.
3569
3570 * src/reader.c (parse_thong_decl): Remove.
3571 * src/options.c (option_table): Remove "thong".
3572 * src/lex.h (tok_thong): Remove.
3573
35742002-06-10 Akim Demaille <akim@epita.fr>
3575
3576 * src/symtab.c, src/symtab.c (symbol_type_set)
3577 (symbol_precedence_set): New.
3578 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3579 (value_components_used): Remove, unused.
3580
35812002-06-09 Akim Demaille <akim@epita.fr>
3582
3583 Move symbols handling code out of the reader.
3584
3585 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3586 (axiom): Move to...
3587 * src/symtab.h, src/symtab.c: here.
3588
3589 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3590 * src/reader.c (startval): Rename as...
3591 * src/symtab.h, src/symtab.c (startsymbol): this.
3592 * src/reader.c: Adjust.
3593
3594 * src/reader.c (symbol_check_defined, symbol_make_alias)
3595 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3596 (token_translations_init)
3597 Move to...
3598 * src/symtab.c: here.
3599 * src/reader.c (packsymbols): Move to...
3600 * src/symtab.h, src/symtab.c (symbols_pack): here.
3601 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3602 argument.
3603
36042002-06-03 Akim Demaille <akim@epita.fr>
3605
3606 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3607 then statements.
3608
36092002-06-03 Akim Demaille <akim@epita.fr>
3610
3611 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3612 structs with non literals.
3613 * src/scan-skel.l: never-interactive.
3614 * src/conflicts.c (enum conflict_resolution_e): No trailing
3615 comma.
3616 * src/getargs.c (usage): Split long literal strings.
3617 Reported by Hans Aberg.
3618
36192002-05-28 Akim Demaille <akim@epita.fr>
3620
3621 * data/bison.c++: Use C++ ostreams.
3622 (cdebug_): New member.
3623
36242002-05-28 Akim Demaille <akim@epita.fr>
3625
3626 * src/output.c (output_skeleton): Be sure to allocate enough room
3627 for `/' _and_ for `\0' in full_skeleton.
3628
36292002-05-28 Akim Demaille <akim@epita.fr>
3630
3631 * data/bison.c++: Catch up with bison.simple:
3632 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3633 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3634 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3635 and popping traces.
3636
36372002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3638
3639 * src/output.c (output_skeleton): Put an explicit path in front of
3640 the skeleton file name, rather than relying on the -I directory,
3641 to partially alleviate effects of having a skeleton file lying around
3642 in the current directory.
3643
36442002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3645
3646 * src/conflicts.c (log_resolution): Correct typo:
3647 obstack_printf should be obstack_fgrow1.
3648
36492002-05-26 Akim Demaille <akim@epita.fr>
3650
3651 * src/state.h (state_t): `solved_conflicts' is a new member.
3652 * src/LR0.c (new_state): Set it to 0.
3653 * src/conflicts.h, src/conflicts.c (print_conflicts)
3654 (free_conflicts, solve_conflicts): Rename as...
3655 (conflicts_print, conflicts_free, conflicts_solve): these.
3656 Adjust callers.
3657 * src/conflicts.c (enum conflict_resolution_e)
3658 (solved_conflicts_obstack): New, used by...
3659 (log_resolution): this.
3660 Adjust to attach the conflict resolution to each state.
3661 Complete the description with the precedence/associativity
3662 information.
3663 (resolve_sr_conflict): Adjust.
3664 * src/print.c (print_state): Output its solved_conflicts.
3665 * tests/conflicts.at (Unresolved SR Conflicts)
3666 (Solved SR Conflicts): Exercise --report=all.
3667
36682002-05-26 Akim Demaille <akim@epita.fr>
3669
3670 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3671 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3672 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3673 (token_number_t, item_number_as_token_number)
3674 (token_number_as_item_number, muscle_insert_token_number_table):
3675 Rename as...
3676 (symbol_number_t, item_number_as_symbol_number)
3677 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3678 these, since it is more appropriate.
3679
36802002-05-26 Akim Demaille <akim@epita.fr>
3681
3682 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3683 `Error:' lines.
3684 * data/bison.simple (yystos) [YYDEBUG]: New.
3685 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3686 error recovery.
3687 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3688
36892002-05-25 Akim Demaille <akim@epita.fr>
3690
3691 * doc/bison.texinfo (Debugging): Split into...
3692 (Tracing): this new section, its former contents, and...
3693 (Understanding): this new section.
3694 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3695 by...
3696 (report_flag): this.
3697 Adjust all dependencies.
3698 (report_args, report_types, report_argmatch): New.
3699 (usage, getargs): Report/support -r, --report.
3700 * src/options.h
3701 (struct option_table_struct): Rename as..,
3702 (struct option_table_s): this.
3703 Rename the `set_flag' member to `flag' to match with getopt_long's
3704 struct.
3705 * src/options.c (option_table): Split verbose into an entry for
3706 %verbose, and another for --verbose.
3707 Support --report/-r, so remove -r from the obsolete --raw.
3708 * src/print.c: Attach full item sets and lookaheads reports to
3709 report_flag instead of trace_flag.
3710 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3711
37122002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3713 and Paul Eggert <eggert@twinsun.com>
3714
3715 * data/bison.simple (yyparse): Correct error handling to conform to
3716 POSIX and yacc. Specifically, after syntax error is discovered,
3717 do not reduce further before shifting the error token.
3718 Clean up the code a bit by removing the labels yyerrdefault,
3719 yyerrhandle, yyerrpop.
3720 * NEWS: Document the above.
3721
37222002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3723
3724 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3725 type; it isn't always big enough, since it doesn't necessarily
3726 include non-terminals.
3727 (yytranslate): Expand definition of yy_token_number_type, so that
3728 the latter can be removed.
3729 (yy_token_number_type): Remove, only one use.
3730 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3731 don't use TokenNumberType as element type.
3732
3733 * tests/regression.at: Modify expected output to agree with change
3734 to yyr1 and yytranslate.
3735
37362002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3737
3738 * src/reader.c (parse_action): Use copy_character instead of
3739 obstack_1grow.
3740
37412002-05-13 Akim Demaille <akim@epita.fr>
3742
3743 * tests/regression.at (Token definitions): Prototype yylex and
3744 yyerror.
3745
37462002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3747
3748 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
3749 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3750 32-bit arithmetic.
3751 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3752
37532002-05-07 Akim Demaille <akim@epita.fr>
3754
3755 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3756 avoid GCC warnings.
3757
37582002-05-07 Akim Demaille <akim@epita.fr>
3759
3760 Kill GCC warnings.
3761
3762 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3763 over the RHS of each rule.
3764 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3765 * src/state.h (state_t): Member `nitems' is unsigned short.
3766 * src/LR0.c (get_state): Adjust.
3767 * src/reader.c (packgram): Likewise.
3768 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3769 `Type'.
3770 (muscle_insert_int_table): Remove, unused.
3771 (prepare_rules): Remove `max'.
3772
37732002-05-06 Akim Demaille <akim@epita.fr>
3774
3775 * src/closure.c (print_firsts): Display of the symbol tags.
3776 (bitmatrix_print): Move to...
3777 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
3778 here.
3779 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
3780
37812002-05-06 Akim Demaille <akim@epita.fr>
3782
3783 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
3784 hash_do_for_each.
3785
37862002-05-06 Akim Demaille <akim@epita.fr>
3787
3788 * src/LR0.c (new_state, get_state): Instead of using the global
3789 `kernel_size' and `kernel_base', have two new arguments:
3790 `core_size' and `core'.
3791 Adjust callers.
3792
37932002-05-06 Akim Demaille <akim@epita.fr>
3794
3795 * src/reader.c (packgram): No longer end `ritem' with a 0
3796 sentinel: it is not used.
3797
37982002-05-05 Akim Demaille <akim@epita.fr>
3799
3800 New experimental feature: display the lookaheads in the report and
3801 graph.
3802
3803 * src/print (print_core): When --trace-flag, display the rules
3804 lookaheads.
3805 * src/print_graph.c (print_core): Likewise.
3806 Swap the arguments.
3807 Adjust caller.
3808
38092002-05-05 Akim Demaille <akim@epita.fr>
3810
3811 * tests/torture.at (Many lookaheads): New test.
3812
38132002-05-05 Akim Demaille <akim@epita.fr>
3814
3815 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
3816 (GENERATE_MUSCLE_INSERT_TABLE): this.
3817 (output_int_table, output_unsigned_int_table, output_short_table)
3818 (output_token_number_table, output_item_number_table): Replace with...
3819 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
3820 (muscle_insert_short_table, muscle_insert_token_number_table)
3821 (muscle_insert_item_number_table): these.
3822 Adjust all callers.
3823 (prepare_tokens): Don't free `translations', since...
3824 * src/reader.h, src/reader.c (grammar_free): do it.
3825 Move to...
3826 * src/gram.h, src/gram.c (grammar_free): here.
3827 * data/bison.simple, data/bison.c++: b4_token_number_max is now
3828 b4_translate_max.
3829
38302002-05-05 Akim Demaille <akim@epita.fr>
3831
3832 * src/output.c (output_unsigned_int_table): New.
3833 (prepare_rules): `i' is unsigned.
3834 `prhs', `rline', `r2' are unsigned int.
3835 Rename muscle `rhs_number_max' as `rhs_max'.
3836 Output muscles `prhs_max', `rline_max', and `r2_max'.
3837 Free rline and r1.
3838 * data/bison.simple, data/bison.c++: Adjust to use these muscles
3839 to compute types instead of constant types.
3840 * tests/regression.at (Web2c Actions): Adjust.
3841
38422002-05-04 Akim Demaille <akim@epita.fr>
3843
3844 * src/symtab.h (SALIAS, SUNDEF): Rename as...
3845 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
3846 Adjust dependencies.
3847 * src/output.c (token_definitions_output): Be sure not to output a
3848 `#define 'a'' when fed with `%token 'a' "a"'.
3849 * tests/regression.at (Token definitions): New.
3850
38512002-05-03 Paul Eggert <eggert@twinsun.com>
3852
3853 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
3854 for K&R C.
3855
38562002-05-03 gettextize <bug-gnu-gettext@gnu.org>
3857
3858 * Makefile.am (SUBDIRS): Remove intl.
3859 (EXTRA_DIST): Add config/config.rpath.
3860
38612002-05-03 Akim Demaille <akim@epita.fr>
3862
3863 * data/bison.simple (m4_if): Don't output empty enums.
3864 And actually, output valid enum definitions :(.
3865
38662002-05-03 Akim Demaille <akim@epita.fr>
3867
3868 * configure.bat: Remove, completely obsolete.
3869 * Makefile.am (EXTRA_DIST): Adjust.
3870 Don't distribute config.rpath...
3871 * config/Makefile.am (EXTRA_DIST): Do it.
3872
38732002-05-03 Akim Demaille <akim@epita.fr>
3874
3875 * configure.in (GETTEXT_VERSION): New.
3876 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
3877
38782002-05-03 Akim Demaille <akim@epita.fr>
3879
3880 * data/bison.simple (b4_token_enum): New.
3881 (b4_token_defines): Use it to output tokens both as #define and
3882 enums.
3883 Suggested by Paul Eggert.
3884 * src/output.c (token_definitions_output): Don't output spurious
3885 white spaces.
3886
38872002-05-03 Akim Demaille <akim@epita.fr>
3888
3889 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3890
38912002-05-02 Robert Anisko <robert@lrde.epita.fr>
3892
3893 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
3894 Update the stack class, give a try to deque as the default container.
3895
38962002-05-02 Akim Demaille <akim@epita.fr>
3897
3898 * data/bison.simple (yyparse): Do not implement @$ = @1.
3899 (YYLLOC_DEFAULT): Adjust to do it.
3900 * doc/bison.texinfo (Location Default Action): Fix.
3901
39022002-05-02 Akim Demaille <akim@epita.fr>
3903
3904 * src/reader.c (parse_braces): Merge into...
3905 (parse_action): this.
3906
39072002-05-02 Akim Demaille <akim@epita.fr>
3908
3909 * configure.in (ALL_LINGUAS): Remove.
3910 * po/LINGUAS, hr.po: New.
3911
39122002-05-02 Akim Demaille <akim@epita.fr>
3913
3914 Remove the so called hairy (semantic) parsers.
3915
3916 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
3917 * src/gram.h, src/gram.c (semantic_parser): Remove.
3918 (rule_t): Remove the guard and guard_line members.
3919 * src/lex.h (token_t): remove tok_guard.
3920 * src/options.c (option_table): Remove %guard and %semantic_parser
3921 support.
3922 * src/output.c, src/output.h (guards_output): Remove.
3923 (prepare): Adjust.
3924 (token_definitions_output): Don't output the `T'
3925 tokens (???).
3926 (output_skeleton): Don't output the guards.
3927 * src/files.c, src/files.c (attrsfile): Remove.
3928 * src/reader.c (symbol_list): Remove the guard and guard_line
3929 members.
3930 Adjust dependencies.
3931 (parse_guard): Remove.
3932 * data/bison.hairy: Remove.
3933 * doc/bison.texinfo (Environment Variables): Remove occurrences of
3934 BISON_HAIRY.
3935
39362002-05-02 Akim Demaille <akim@epita.fr>
3937
3938 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
3939 (parse_guard): Rename the formal argument `stack_offset' as
3940 `rule_length', which is more readable.
3941 Adjust callers.
3942 (copy_at, copy_dollar): Instead of outputting the hard coded
3943 values of $$, $n and so forth, output invocation to b4_lhs_value,
3944 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
3945 Note: this patch partially drops `semantic-parser' support: it
3946 always does `rule_length - n', where semantic parsers ought to
3947 always use `-n'.
3948 * data/bison.simple, data/bison.c++ (b4_lhs_value)
3949 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
3950
39512002-05-02 Akim Demaille <akim@epita.fr>
3952
3953 * configure.in (AC_INIT): Bump to 1.49b.
3954 (AM_INIT_AUTOMAKE): Short invocation.
3955
39562002-05-02 Akim Demaille <akim@epita.fr>
3957
3958 Version 1.49a.
3959
39602002-05-01 Akim Demaille <akim@epita.fr>
3961
3962 * src/skeleton.h: Remove.
3963
39642002-05-01 Akim Demaille <akim@epita.fr>
3965
3966 * src/skeleton.h: Fix the #endif.
3967 Reported by Magnus Fromreide.
3968
39692002-04-26 Paul Eggert <eggert@twinsun.com>
3970
3971 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
3972 Define if we define YYSTYPE and YYLTYPE, respectively.
3973 (YYCOPY): Fix [] quoting problem in the non-GCC case.
3974
39752002-04-25 Robert Anisko <robert@lrde.epita.fr>
3976
3977 * src/scan-skel.l: Postprocess quadrigraphs.
3978
3979 * src/reader.c (copy_character): New function, used to output
3980 single characters while replacing `[' and `]' with quadrigraphs, to
3981 avoid troubles with M4 quotes.
3982 (copy_comment): Output characters with copy_character.
3983 (read_additionnal_code): Likewise.
3984 (copy_string2): Likewise.
3985 (copy_definition): Likewise.
3986
3987 * tests/calc.at: Exercise M4 quoting.
3988
39892002-04-25 Akim Demaille <akim@epita.fr>
3990
3991 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
3992 between `!' and the command.
3993 Reported by Paul Eggert.
3994
39952002-04-24 Robert Anisko <robert@lrde.epita.fr>
3996
3997 * tests/calc.at: Exercise prologue splitting.
3998
3999 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
4000 `b4_post_prologue' instead of `b4_prologue'.
4001
4002 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
4003 muscles.
4004 (output): Free pre_prologue_obstack and post_prologue_obstack.
4005 * src/files.h, src/files.c (attrs_obstack): Remove.
4006 (pre_prologue_obstack, post_prologue_obstack): New.
4007 * src/reader.c (copy_definition): Add a parameter to specify the
4008 obstack to fill, instead of using attrs_obstack unconditionally.
4009 (read_declarations): Pass pre_prologue_obstack to copy_definition if
4010 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
4011
40122002-04-23 Paul Eggert <eggert@twinsun.com>
4013
4014 * data/bison.simple: Remove unnecessary commentary and white
4015 space differences from 1_29-branch.
4016 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
4017
4018 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
4019 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
4020 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
4021 constructors or destructors.
4022
4023 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
4024
40252002-04-23 Akim Demaille <akim@epita.fr>
4026
4027 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
4028 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
4029 location with columns.
4030 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
4031 All reported by Paul Eggert.
4032
40332002-04-22 Akim Demaille <akim@epita.fr>
4034
4035 * src/reduce.c (dump_grammar): Move to...
4036 * src/gram.h, src/gram.c (grammar_dump): here.
4037 Be sure to separate long item numbers.
4038 Don't read the members of a rule's prec if its nil.
4039
40402002-04-22 Akim Demaille <akim@epita.fr>
4041
4042 * src/output.c (table_size, table_grow): New.
4043 (MAXTABLE): Remove, replace uses with table_size.
4044 (pack_vector): Instead of dying when the table is too big, grow it.
4045
40462002-04-22 Akim Demaille <akim@epita.fr>
4047
4048 * data/bison.simple (yyr1): Its type is that of a token number.
4049 * data/bison.c++ (r1_): Likewise.
4050 * tests/regression.at (Web2c Actions): Adjust.
4051
40522002-04-22 Akim Demaille <akim@epita.fr>
4053
4054 * src/reader.c (token_translations_init): 256 is now the default
4055 value for the error token, i.e., it will be assigned another
4056 number if the user assigned 256 to one of her tokens.
4057 (reader): Don't force 256 to error.
4058 * doc/bison.texinfo (Symbols): Adjust.
4059 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
4060 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
4061 etc. instead of 10, 20, 30 (which was used to `jump' over error
4062 (256) and undefined (2)).
4063
40642002-04-22 Akim Demaille <akim@epita.fr>
4065
4066 Propagate more token_number_t.
4067
4068 * src/gram.h (token_number_as_item_number)
4069 (item_number_as_token_number): New.
4070 * src/output.c (GENERATE_OUTPUT_TABLE): New.
4071 Use it to create output_item_number_table and
4072 output_token_number_table.
4073 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4074 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
4075 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
4076 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
4077
40782002-04-22 Akim Demaille <akim@epita.fr>
4079
4080 * src/output.h, src/output.c (get_lines_number): Remove.
4081
40822002-04-19 Akim Demaille <akim@epita.fr>
4083
4084 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
4085 as Lex/Flex'.
4086 (Debugging): More details about enabling the debugging features.
4087 (Table of Symbols): Describe $$, $n, @$, and @n.
4088 Suggested by Tim Josling.
4089
40902002-04-19 Akim Demaille <akim@epita.fr>
4091
4092 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
4093
40942002-04-10 Akim Demaille <akim@epita.fr>
4095
4096 * src/system.h: Rely on HAVE_LIMITS_H.
4097 Suggested by Paul Eggert.
4098
40992002-04-09 Akim Demaille <akim@epita.fr>
4100
4101 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
4102 full stderr, and strip it according to the bison options, instead
4103 of composing the error message from different bits.
4104 This makes it easier to check for several error messages.
4105 Adjust all the invocations.
4106 Add an invocation exercising the error token.
4107 Add an invocation demonstrating a stupid error message.
4108 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
4109 Adjust the tests.
4110 Error message are for stderr, not stdout.
4111
41122002-04-09 Akim Demaille <akim@epita.fr>
4113
4114 * src/gram.h, src/gram.c (error_token_number): Remove, use
4115 errtoken->number.
4116 * src/reader.c (reader): Don't specify the user token number (2)
4117 for $undefined, as it uselessly prevents using it.
4118 * src/gram.h (token_number_t): Move to...
4119 * src/symtab.h: here.
4120 (state_t.number): Is a token_number_t.
4121 * src/print.c, src/reader.c: Use undeftoken->number instead of
4122 hard coded 2.
4123 (Even though this 2 is not the same as above: the number of the
4124 undeftoken remains being 2, it is its user token number which
4125 might not be 2).
4126 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
4127 `user_token_number_max'.
4128 Output `undef_token_number'.
4129 * data/bison.simple, data/bison.c++: Use them.
4130 Be sure to map invalid yylex return values to
4131 `undef_token_number'. This saves us from gratuitous SEGV.
4132
4133 * tests/conflicts.at (Solved SR Conflicts)
4134 (Unresolved SR Conflicts): Adjust.
4135 * tests/regression.at (Web2c Actions): Adjust.
4136
41372002-04-08 Akim Demaille <akim@epita.fr>
4138
4139 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
4140 Adding #line.
4141 Remove the duplicate `typedefs'.
4142 (RhsNumberType): Fix the declaration and various other typos.
4143 Use __ofile__.
4144 * data/bison.simple: Use __ofile__.
4145 * src/scan-skel.l: Handle __ofile__.
4146
41472002-04-08 Akim Demaille <akim@epita.fr>
4148
4149 * src/gram.h (item_number_t): New, the type of item numbers in
4150 RITEM. Note that it must be able to code symbol numbers as
4151 positive number, and the negation of rule numbers as negative
4152 numbers.
4153 Adjust all dependencies (pretty many).
4154 * src/reduce.c (rule): Remove this `short *' pointer: use
4155 item_number_t.
4156 * src/system.h (MINSHORT, MAXSHORT): Remove.
4157 Include `limits.h'.
4158 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
4159 (shortcpy): Remove.
4160 (MAXTABLE): Move to...
4161 * src/output.c (MAXTABLE): here.
4162 (prepare_rules): Use output_int_table to output rhs.
4163 * data/bison.simple, data/bison.c++: Adjust.
4164 * tests/torture.at (Big triangle): Move the limit from 254 to
4165 500.
4166 * tests/regression.at (Web2c Actions): Ajust.
4167
4168 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
4169 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
4170 passes, but produces negative #line number, once fixed, GCC is
4171 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
4172 C), it passes.
4173 * src/state.h (state_h): Code input lines on ints, not shorts.
4174
41752002-04-08 Akim Demaille <akim@epita.fr>
4176
4177 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
4178 and then the grammar.
4179
41802002-04-08 Akim Demaille <akim@epita.fr>
4181
4182 * src/system.h: No longer using strndup.
4183
41842002-04-07 Akim Demaille <akim@epita.fr>
4185
4186 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
4187 * src/output.c (output_table_data): Return the longest number.
4188 (prepare_tokens): Output `token_number_max').
4189 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
4190 New.
4191 Use them to define yy_token_number_type/TokenNumberType.
4192 Use this type for yytranslate.
4193 * tests/torture.at (Big triangle): Push the limit from 124 to
4194 253.
4195 * tests/regression.at (Web2c Actions): Adjust.
4196
41972002-04-07 Akim Demaille <akim@epita.fr>
4198
4199 * tests/torture.at (Big triangle): New.
4200 (GNU AWK Grammar, GNU Cim Grammar): Move to...
4201 * tests/existing.at: here.
4202
42032002-04-07 Akim Demaille <akim@epita.fr>
4204
4205 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
4206 nritems.
4207 Adjust dependencies.
4208
42092002-04-07 Akim Demaille <akim@epita.fr>
4210
4211 * src/reader.c: Normalize increments to prefix form.
4212
42132002-04-07 Akim Demaille <akim@epita.fr>
4214
4215 * src/reader.c, symtab.c: Remove debugging code.
4216
42172002-04-07 Akim Demaille <akim@epita.fr>
4218
4219 Rename all the `bucket's as `symbol_t'.
4220
4221 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
4222 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
4223 * src/symtab.c, src/symtab.h (bucket): Rename as...
4224 (symbol_t): this.
4225 (symbol_list_new, bucket_check_defined, bucket_make_alias)
4226 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
4227 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4228 (buckets_new, buckets_free, buckets_do): Rename as...
4229 (symbol_list_new, symbol_check_defined, symbol_make_alias)
4230 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4231 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
4232 (symbols_new, symbols_free, symbols_do): these.
4233
42342002-04-07 Akim Demaille <akim@epita.fr>
4235
4236 Use lib/hash for the symbol table.
4237
4238 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
4239 EOF.
4240 * src/lex.c (lex): Set the `number' member of new terminals.
4241 * src/reader.c (bucket_check_defined, bucket_make_alias)
4242 (bucket_check_alias_consistence, bucket_translation): New.
4243 (reader, grammar_free, readgram, token_translations_init)
4244 (packsymbols): Adjust.
4245 (reader): Number the predefined tokens.
4246 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
4247 for predefined tokens.
4248 * src/symtab.h (bucket): Remove all the hash table related
4249 members.
4250 * src/symtab.c (symtab): Replace by...
4251 (bucket_table): this.
4252 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4253 (buckets_new, buckets_do): New.
4254
42552002-04-07 Akim Demaille <akim@epita.fr>
4256
4257 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
4258 (start_symbol, max_user_token_number, semantic_parser)
4259 (error_token_number): Initialize.
4260 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
4261 Initialize.
4262 (reader): Don't.
4263 (errtoken, eoftoken, undeftoken, axiom): Extern.
4264
42652002-04-07 Akim Demaille <akim@epita.fr>
4266
4267 * src/gram.h (rule_s): prec and precsym are now pointers
4268 to the bucket giving the priority/associativity.
4269 Member `associativity' removed: useless.
4270 * src/reduce.c, src/conflicts.c: Adjust.
4271
42722002-04-07 Akim Demaille <akim@epita.fr>
4273
4274 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4275 Properly escape the symbols' TAG when outputting them.
4276
42772002-04-07 Akim Demaille <akim@epita.fr>
4278
4279 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4280
42812002-04-07 Akim Demaille <akim@epita.fr>
4282
4283 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4284 (LArule): this, which is an array to rule_t*.
4285 * src/print.c, src/conflicts.c: Adjust.
4286
42872002-04-07 Akim Demaille <akim@epita.fr>
4288
4289 * src/gram.h (rule_t): Rename `number' as `user_number'.
4290 `number' is a new member.
4291 Adjust dependencies.
4292 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4293
42942002-04-07 Akim Demaille <akim@epita.fr>
4295
4296 As a result of the previous patch, it is no longer needed
4297 to reorder ritem itself.
4298
4299 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4300
43012002-04-07 Akim Demaille <akim@epita.fr>
4302
4303 Be sure never to walk through RITEMS, but use only data related to
4304 the rules themselves. RITEMS should be banished.
4305
4306 * src/output.c (output_token_translations): Rename as...
4307 (prepare_tokens): this.
4308 In addition to `translate', prepare the muscles `tname' and
4309 `toknum', which were handled by...
4310 (output_rule_data): this.
4311 Remove, and move the remainder of its outputs into...
4312 (prepare_rules): this new routines, which also merges content from
4313 (output_gram): this.
4314 (prepare_rules): Be sure never to walk through RITEMS.
4315 (output_stos): Rename as...
4316 (prepare_stos): this.
4317 (output): Always invoke prepare_states, after all, just don't use it
4318 in the output if you don't need it.
4319
43202002-04-07 Akim Demaille <akim@epita.fr>
4321
4322 * src/LR0.c (new_state): Display `nstates' as the name of the
4323 newly created state.
4324 Adjust to initialize first_state and last_state if needed.
4325 Be sure to distinguish the initial from the final state.
4326 (new_states): Create the itemset of the initial state, and use
4327 new_state.
4328 * src/closure.c (closure): Now that the initial state has its
4329 items properly set, there is no need for a special case when
4330 creating `ruleset'.
4331
4332 As a result, now the rule 0, reducing to $axiom, is visible in the
4333 outputs. Adjust the test suite.
4334
4335 * tests/conflicts.at (Solved SR Conflicts)
4336 (Unresolved SR Conflicts): Adjust.
4337 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4338 * tests/conflicts.at (S/R in initial): New.
4339
43402002-04-07 Akim Demaille <akim@epita.fr>
4341
4342 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4343 the RHS of the rules.
4344 * src/output.c (output_gram): Likewise.
4345
43462002-04-07 Akim Demaille <akim@epita.fr>
4347
4348 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4349 bucket.
4350 Adjust all dependencies.
4351 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4352 `number' of the buckets too.
4353 * src/gram.h: Include `symtab.h'.
4354 (associativity): Move to...
4355 * src/symtab.h: here.
4356 No longer include `gram.h'.
4357
43582002-04-07 Akim Demaille <akim@epita.fr>
4359
4360 * src/gram.h, src/gram.c (rules_rhs_length): New.
4361 (ritem_longest_rhs): Use it.
4362 * src/gram.h (rule_t): `number' is a new member.
4363 * src/reader.c (packgram): Set it.
4364 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4365 the end of `rules', and count them out of `nrules'.
4366 (reduce_output, dump_grammar): Adjust.
4367 * src/print.c (print_grammar): It is no longer needed to check for
4368 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4369 * tests/reduce.at (Reduced Automaton): New test.
4370
43712002-04-07 Akim Demaille <akim@epita.fr>
4372
4373 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4374 lacking `+ 1' to nrules, Bison reported as useless a token if it
4375 was used solely to set the precedence of the last rule...
4376
43772002-04-07 Akim Demaille <akim@epita.fr>
4378
4379 * data/bison.c++, data/bison.simple: Don't output the current file
4380 name in #line, to avoid useless diffs between two identical
4381 outputs under different names.
4382
43832002-04-07 Akim Demaille <akim@epita.fr>
4384
4385 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4386 Normalize loops to using `< nrules + 1', not `<= nrules'.
4387
43882002-04-07 Akim Demaille <akim@epita.fr>
4389
4390 * TODO: Update.
4391
43922002-04-07 Akim Demaille <akim@epita.fr>
4393
4394 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4395 bucket.value as bucket.number.
4396
43972002-04-07 Akim Demaille <akim@epita.fr>
4398
4399 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4400 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4401 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4402 RHS, instead of being an index in RITEMS.
4403
44042002-04-04 Paul Eggert <eggert@twinsun.com>
4405
4406 * doc/bison.texinfo: Update copyright date.
4407 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4408 (Symbols): Warn about running Bison in one character set,
4409 but compiling and/or running in an incompatible one.
4410 Warn about character code 256, too.
4411
44122002-04-03 Paul Eggert <eggert@twinsun.com>
4413
4414 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4415 YYERROR_VERBOSE is nonzero, not whether it is defined.
4416
4417 Merge changes from bison-1_29-branch.
4418
44192002-03-20 Paul Eggert <eggert@twinsun.com>
4420
4421 Merge fixes from Debian bison_1.34-1.diff.
4422
4423 * configure.in (AC_PREREQ): 2.53.
4424
44252002-03-20 Akim Demaille <akim@epita.fr>
4426
4427 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4428
44292002-03-19 Paul Eggert <eggert@twinsun.com>
4430
4431 * src/bison.simple (YYCOPY): New macro.
4432 (YYSTACK_RELOCATE): Use it.
4433 Remove Type arg; no longer needed. All callers changed.
4434 (yymemcpy): Remove; no longer needed.
4435
4436 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4437 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4438
44392002-03-19 Akim Demaille <akim@epita.fr>
4440
4441 Test and fix the #line outputs.
4442
4443 * tests/atlocal.at (GCC): New.
4444 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4445 (Prologue synch line, ,%union synch line, Postprologue synch line)
4446 (Action synch line, Epilogue synch line): New tests.
4447 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4448 * data/bison.simple, data/bison.c++: Use it.
4449
44502002-03-19 Akim Demaille <akim@epita.fr>
4451
4452 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4453 (Solved SR Conflicts, %expect not enough, %expect right)
4454 (%expect too much): Move to...
4455 * tests/conflicts.at: this new file.
4456
44572002-03-19 Akim Demaille <akim@epita.fr>
4458
4459 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4460 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4461 that we can move to enums for instance.
4462 * src/output.c (token_definitions_output): Output a list of
4463 `token-name, token-number' instead of the #define.
4464 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4465
44662002-03-14 Akim Demaille <akim@epita.fr>
4467
4468 Use Gettext 0.11.1.
4469
44702002-03-09 Robert Anisko <robert@lrde.epita.fr>
4471
4472 * data/bison.c++: Make the user able to add members to the generated
4473 parser by subclassing.
4474
44752002-03-05 Robert Anisko <robert@lrde.epita.fr>
4476
4477 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4478 a character.
4479 Reported by Nicolas Tisserand and Nicolas Burrus.
4480
44812002-03-04 Robert Anisko <robert@lrde.epita.fr>
4482
4483 * src/reader.c: Warn about lacking semi-colons, do not complain.
4484
44852002-03-04 Robert Anisko <robert@lrde.epita.fr>
4486
4487 * data/bison.c++: Remove a debug line.
4488
44892002-03-04 Robert Anisko <robert@lrde.epita.fr>
4490
4491 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4492 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4493 provide a default implementation.
4494
44952002-03-04 Akim Demaille <akim@epita.fr>
4496
4497 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4498 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4499 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4500 * tests/semantic.at (Parsing Guards): Similarly.
4501 * src/reader.at (readgram): Complain if the last rule is not ended
4502 with a semi-colon.
4503
45042002-03-04 Akim Demaille <akim@epita.fr>
4505
4506 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4507 * src/closure.c: here.
4508 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4509 RTC.
4510 * src/warshall.h, src/warshall.c: Remove.
4511 * tests/sets.at (Broken Closure): Adjust.
4512
45132002-03-04 Akim Demaille <akim@epita.fr>
4514
4515 * src/output.c (output_skeleton): tempdir is const.
4516 bytes_read is unused.
4517
45182002-03-04 Akim Demaille <akim@epita.fr>
4519
4520 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4521 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4522 Update.
4523 From Michael Hayes.
4524
45252002-03-04 Akim Demaille <akim@epita.fr>
4526
4527 * src/closure.c (closure): `r' is unused.
4528
45292002-03-04 Akim Demaille <akim@epita.fr>
4530
4531 * tests/sets.at (Broken Closure): Add the ending `;'.
4532 * src/reader.at (readgram): Complain if a rule is not ended with a
4533 semi-colon.
4534
45352002-03-04 Akim Demaille <akim@epita.fr>
4536
4537 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4538 (count_sr_conflicts): Use bitset_count.
4539 * src/reduce.c (inaccessable_symbols): Ditto.
4540 (bits_size): Remove.
4541 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4542
45432002-03-04 Akim Demaille <akim@epita.fr>
4544
4545 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4546 * src/reduce.c: Remove the `bitset_zero's following the
4547 `bitset_create's, as now it is performed by the latter.
4548
45492002-03-04 Akim Demaille <akim@epita.fr>
4550
4551 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4552 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4553 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4554 latest sources from Michael.
4555
45562002-03-04 Akim Demaille <akim@epita.fr>
4557
4558 * src/output.c (output): Don't free the grammar.
4559 * src/reader.c (grammar_free): New.
4560 * src/main.c (main): Call it and don't free symtab here.
4561
45622002-03-04 Akim Demaille <akim@epita.fr>
4563
4564 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4565 before returning.
4566 Reported by Benoit Perrot.
4567
45682002-03-04 Akim Demaille <akim@epita.fr>
4569
4570 Use bitset operations when possible, not loops over bits.
4571
4572 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4573 bitset_or.
4574 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4575 * src/reduce.c (useless_nonterminals): Formatting changes.
4576 * src/warshall.c (TC): Use bitset_or.
4577
45782002-03-04 Akim Demaille <akim@epita.fr>
4579
4580 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4581 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4582 Ditto.
4583
45842002-03-04 Akim Demaille <akim@epita.fr>
4585
4586 * src/lalr.c (F): Now a bitset*.
4587 Adjust all dependencies.
4588
45892002-03-04 Akim Demaille <akim@epita.fr>
4590
4591 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4592 Adjust all dependencies.
4593
45942002-03-04 Akim Demaille <akim@epita.fr>
4595
4596 * src/L0.c, src/LR0.h (nstates): Be size_t.
4597 Adjust comparisons (signed vs unsigned).
4598 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4599 bitset*.
4600 Adjust all dependencies.
4601
46022002-03-04 Akim Demaille <akim@epita.fr>
4603
4604 * src/closure.c (firsts): Now, also a bitset.
4605 Adjust all dependencies.
4606 (varsetsize): Remove, now unused.
4607 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4608
46092002-03-04 Akim Demaille <akim@epita.fr>
4610
4611 * src/print.c: Convert to use bitset.h, not hand coded iterations
4612 over ints.
4613
46142002-03-04 Akim Demaille <akim@epita.fr>
4615
4616 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4617
46182002-03-04 Akim Demaille <akim@epita.fr>
4619
4620 * src/closure.c (ruleset): Be a bitset.
4621 (rulesetsize): Remove.
4622
46232002-03-04 Akim Demaille <akim@epita.fr>
4624
4625 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4626 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4627 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4628 * src/closure.c (fderives): Be an array of bitsets.
4629
46302002-02-28 Robert Anisko <robert@lrde.epita.fr>
4631
4632 * data/bison.c++: Merge the two generated headers. Insert a copyright
4633 notice in each output file.
4634
46352002-02-28 Akim Demaille <akim@epita.fr>
4636
4637 * data/bison.c++: Copy the prologue of bison.simple to fetch
4638 useful M4 definitions, such as b4_header_guard.
4639
46402002-02-25 Akim Demaille <akim@epita.fr>
4641
4642 * src/getargs.c (version): Give the name of the authors, and use a
4643 translator friendly scheme for the bgr
4644 copyright notice.
4645
46462002-02-25 Akim Demaille <akim@epita.fr>
4647
4648 * src/output.c (header_output): Remove, now handled completely via
4649 M4.
4650
46512002-02-25 Akim Demaille <akim@epita.fr>
4652
4653 * m4/m4.m4: New, from CVS Autoconf.
4654 * configure.in: Invoke it.
4655 * src/output.c (output_skeleton): Use its result instead of the
4656 hard coded name.
4657
46582002-02-25 Akim Demaille <akim@epita.fr>
4659
4660 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4661 Fileutils 4.1.5.
4662 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4663 * src/output.c (output_skeleton): Use mkstemp to create a real
4664 temporary file.
4665 Move the filling of `skeleton' and its muscle to...
4666 (prepare): here.
4667 (output): Move the definition of the prologue muscle to...
4668 (prepare): here.
4669 * src/system.h (DEFAULT_TMPDIR): New.
4670
46712002-02-14 Paul Eggert <eggert@twinsun.com>
4672
4673 Remove the support for C++ namespace cleanliness; it was
4674 causing more problems than it was curing, since it didn't work
4675 properly on some nonstandard C++ compilers. This can wait
4676 for a proper C++ parser.
4677
4678 * NEWS: Document this.
4679 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4680 of C++, as it's treated like C now.
4681 * src/bison.simple (YYSTD): Remove.
4682 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4683 Treat C++ just like Standard C instead of trying to support
4684 namespace cleanliness.
4685
46862002-02-14 Akim Demaille <akim@epita.fr>
4687
4688 * tests/regression.at (else): Adjust to Andreas' change.
4689
46902002-02-14 Akim Demaille <akim@epita.fr>
4691
4692 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4693
46942002-02-13 Andreas Schwab <schwab@suse.de>
4695
4696 * src/output.c (output_rule_data): Don't output NULL, it might
4697 not be defined yet.
4698
46992002-02-11 Robert Anisko <robert@lrde.epita.fr>
4700
4701 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4702 (Copyright notice): Update.
4703
47042002-02-11 Akim Demaille <akim@epita.fr>
4705
4706 * tests/regression.at (%nonassoc and eof): Don't include
4707 nonportable headers.
4708
47092002-02-08 Robert Anisko <robert@lrde.epita.fr>
4710
4711 * data/bison.c++: Correct error recovery. Make the user able to
4712 initialize the starting location.
4713
47142002-02-07 Akim Demaille <akim@epita.fr>
4715
4716 * tests/input.at: New.
4717
47182002-02-07 Robert Anisko <robert@lrde.epita.fr>
4719
4720 * data/bison.c++: Replace some direct m4 expansions by constants. Be
4721 more consistent when naming methods and variables. Put preprocessor
4722 directives around tables only needed for debugging.
4723
47242002-02-07 Robert Anisko <robert@lrde.epita.fr>
4725
4726 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4727 C++ parsers.
4728 (yy::b4_name::parse): Use print_.
4729
47302002-02-07 Robert Anisko <robert@lrde.epita.fr>
4731
4732 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4733
47342002-02-07 Robert Anisko <robert@lrde.epita.fr>
4735
4736 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4737 C++ parsers.
4738 (yy::b4_name::parse): Build verbose error messages, and use error_.
4739
47402002-02-06 Robert Anisko <robert@lrde.epita.fr>
4741
4742 * data/bison.c++: Fix m4 quoting in comments.
4743
47442002-02-06 Robert Anisko <robert@lrde.epita.fr>
4745
4746 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4747 not expanded by m4.
4748
47492002-02-05 Akim Demaille <akim@epita.fr>
4750
4751 * data/bison.c++: Adjust to the M4 back end.
4752 More is certainly needed.
4753
47542002-02-05 Akim Demaille <akim@epita.fr>
4755
4756 Give a try to M4 as a back end.
4757
4758 * lib/readpipe.c: New, from wdiff.
4759 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4760 BISON_HAIRY.
4761 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4762 specific values. Now it is m4 that performs the lookup.
4763 * src/parse-skel.y: Remove.
4764 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4765 * src/output.c (actions_output, guards_output)
4766 (token_definitions_output): No longer keeps track of the output
4767 line number, hence remove the second argument.
4768 (guards_output): Check against the guard member of a rule, not the
4769 action member.
4770 Adjust callers.
4771 (output_skeleton): Don't look for the skeleton location, let m4 do
4772 that.
4773 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
4774 file will be used.
4775 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
4776 (prepare): Given that for the time being changesyntax is not
4777 usable in M4, rename the muscles using `-' to `_'.
4778 Define `defines_flag', `output_parser_name' and `output_header_name'.
4779 * src/output.h (actions_output, guards_output)
4780 (token_definitions_output): Adjust prototypes.
4781 * src/scan-skel.l: Instead of scanning the skeletons, it now
4782 processes the output of m4: `__oline__' and `#output'.
4783 * data/bison.simple: Adjust to be used by M4(sugar).
4784 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
4785 to date.
4786 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
4787 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
4788 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
4789 shamelessly stolen from CVS Autoconf.
4790
47912002-02-05 Akim Demaille <akim@epita.fr>
4792
4793 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
4794 * configure.in: Check for the declarations of free and malloc.
4795 * src/muscle_tab.c: Adjust.
4796
47972002-02-05 Akim Demaille <akim@epita.fr>
4798
4799 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
4800 which have no values.
4801
48022002-02-05 Akim Demaille <akim@epita.fr>
4803
4804 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
4805 * data/: here.
4806
48072002-01-29 Paul Eggert <eggert@twinsun.com>
4808
4809 * src/bison.simple (YYSIZE_T): Do not define merely because
4810 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
4811 On some platforms, <alloca.h> does not declare YYSTD (size_t).
4812
48132002-01-27 Akim Demaille <akim@epita.fr>
4814
4815 Fix `%nonassoc and eof'.
4816
4817 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
4818 which were not properly copied! Replace
4819 memcpy (res->errs, src->errs, src->nerrs);
4820 with
4821 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
4822 !!!
4823 * tests/regression.at (%nonassoc and eof): Adjust to newest
4824 Autotest: `.' is not in the PATH.
4825
48262002-01-27 Akim Demaille <akim@epita.fr>
4827
4828 * tests/sets.at (AT_EXTRACT_SETS): New.
4829 (Nullable): Use it.
4830 (Firsts): New.
4831
48322002-01-26 Akim Demaille <akim@epita.fr>
4833
4834 * tests/actions.at, tests/calc.at, tests/headers.at,
4835 * tests/torture.at: Adjust to the newest Autotest which no longer
4836 forces `.' in the PATH.
4837
48382002-01-25 Akim Demaille <akim@epita.fr>
4839
4840 * tests/regression.at (%nonassoc and eof): New.
4841 Suggested by Robert Anisko.
4842
48432002-01-24 Akim Demaille <akim@epita.fr>
4844
4845 Bison dumps core when trying to complain about broken input files.
4846 Reported by Cris van Pelt.
4847
4848 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
4849 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
4850 into...
4851 (Invalid inputs): Strengthen: exercise parse_percent_token.
4852
48532002-01-24 Robert Anisko <robert.anisko@epita.fr>
4854
4855 * src/Makefile.am: Add bison.c++.
4856 * src/bison.c++: New skeleton.
4857
48582002-01-21 Paolo Bonzini <bonzini@gnu.org>
4859
4860 * po/it.po: New.
4861
48622002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
4863
4864 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
4865
48662002-01-20 Marc Autret <marc@gnu.org>
4867
4868 * src/files.c (compute_output_file_names): Fix
4869
48702002-01-20 Marc Autret <marc@gnu.org>
4871
4872 * tests/output.at: New test.
4873 * src/files.c (compute_base_names): Don't map extensions when
4874 the YACC flag is set, use defaults.
4875 Reported by Evgeny Stambulchik.
4876
48772002-01-20 Marc Autret <marc@gnu.org>
4878
4879 * src/system.h: Need to define __attribute__ away for non-GCC
4880 compilers as well (i.e. the vendor C compiler).
4881 Suggested by Albert Chin-A-Young.
4882
48832002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
4884
4885 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
4886 canonical definition.
4887 * src/system.h: Use the canonical definition for PARAMS (avoids
4888 a conflict with the macro from lib/hash.h).
4889
48902002-01-11 Akim Demaille <akim@epita.fr>
4891
4892 * configure.in: Use AC_FUNC_STRNLEN.
4893 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
4894
48952002-01-09 Akim Demaille <akim@epita.fr>
4896
4897 * src/files.c, src/files.h (output_infix): New.
4898 (tab_extension): Remove.
4899 (compute_base_names): Compute the former, drop the latter.
4900 * src/output.c (prepare): Insert the muscles `output-infix', and
4901 `output-suffix'.
4902 * src/parse-skel.y (string, string.1): New.
4903 (section.header): Use it.
4904 (section.yacc): Remove.
4905 (prefix): Remove too.
4906 * src/scan-skel.l: Adjust.
4907 * src/bison.simple, src/bison.hairy: Adjust.
4908
49092002-01-09 Akim Demaille <akim@epita.fr>
4910
4911 * configure.in (WERROR_CFLAGS): Compute it.
4912 * src/Makefile.am (CFLAGS): Pass it.
4913 * tests/atlocal.in (CFLAGS): Idem.
4914 * src/files.c: Fix a few warnings.
4915 (get_extension_index): Remove, unused.
4916
49172002-01-08 Akim Demaille <akim@epita.fr>
4918
4919 * src/getargs.c (AS_FILE_NAME): New.
4920 (getargs): Use it to convert DOSish file names.
4921 * src/files.c (base_name): Rename as full_base_name to avoid
4922 clashes with `base_name ()'.
4923 (filename_split): New.
4924 (compute_base_names): N-th rewrite, using filename_split.
4925
49262002-01-08 Akim Demaille <akim@epita.fr>
4927
4928 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
4929 New, stolen from the Fileutils 4.1.
4930 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
4931 * configure.in: Check for the presence of memrchr, and of its
4932 prototype.
4933
49342002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
4935
4936 * lib/hash.h (__P): Added definition for this macro.
4937 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
4938 BUILT_SOURCES, to ensure they are generated first.
4939 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
4940 %error-verbose to allow bootstrapping with bison 1.30x.
4941
49422002-01-06 Akim Demaille <akim@epita.fr>
4943
4944 * src/reader.c (parse_braces): Don't fetch the next char, the
4945 convention is to fetch on entry.
4946 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
4947 'switch' without a following semicolon.
4948 * tests/regression.at (braces parsing): New.
4949
49502002-01-06 Akim Demaille <akim@epita.fr>
4951
4952 Bison is dead wrong in its RR conflict reports.
4953
4954 * tests/torture.at (GNU Cim Grammar): New.
4955 * src/conflicts.c (count_rr_conflicts): Fix.
4956
49572002-01-06 Akim Demaille <akim@epita.fr>
4958
4959 Creating package.m4 from configure.ac causes too many problems.
4960
4961 * tests/Makefile.am (package.m4): Create it by hand,
4962 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
4963
49642002-01-06 Akim Demaille <akim@epita.fr>
4965
4966 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
4967 skeleton.h.
4968
49692002-01-04 Paul Eggert <eggert@twinsun.com>
4970
4971 * doc/bison.texinfo (Debugging):
4972 Remove YYSTDERR; it's no longer defined or used.
4973 Also, s/cstdio.h/cstdio/.
4974
49752002-01-03 Akim Demaille <akim@epita.fr>
4976
4977 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
4978
49792002-01-03 Akim Demaille <akim@epita.fr>
4980
4981 * src/parse-skel.y (process_skeleton): Don't bind the parser's
4982 tracing code to --trace, wait for a better --trace option, with
4983 args.
4984
49852002-01-03 Akim Demaille <akim@epita.fr>
4986
4987 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
4988 The ISO C++ standard is extremely clear about it: stderr is
4989 considered a macro, not a regular symbol (see table 94 `Header
4990 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
4991 Therefore std:: does not apply to it. It still does with fprintf.
4992 Also, s/cstdio.h/cstdio/.
4993
49942002-01-03 Akim Demaille <akim@epita.fr>
4995
4996 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
4997 for non system headers.
4998
49992002-01-02 Akim Demaille <akim@epita.fr>
5000
5001 Equip the skeleton chain with location tracking, runtime trace,
5002 pure parser and scanner.
5003
5004 * src/parse-skel.y: Request a pure parser, locations, and prefix
5005 renaming.
5006 (%union): Having several members with the same type does not help
5007 type mismatches, simplify.
5008 (YYPRINT, yyprint): New.
5009 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
5010 (skel_error): this.
5011 Handle locations.
5012 * src/scan-skel.l: Adjust to these changes.
5013 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
5014 (LOCATION_PRINT, skel_control_t): New.
5015
50162001-12-30 Akim Demaille <akim@epita.fr>
5017
5018 * src/parse-skel.y: Get rid of the shift/reduce conflict:
5019 replace `gb' with BLANKS.
5020 * src/scan-skel.l: Adjust.
5021
50222001-12-30 Akim Demaille <akim@epita.fr>
5023
5024 * src/system.h: We don't need nor want bcopy.
5025 Throw away MS-DOS crap: we don't need getpid.
5026 * configure.in: We don't need strndup. It was even causing
5027 problems: because Flex includes the headers *before* us,
5028 _GNU_SOURCE is not defined by config.h, and therefore strndup was
5029 not visible.
5030 * lib/xstrndup.c: New.
5031 * src/scan-skel.l: Use it.
5032 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
5033 * src/parse-skel.y: Use %directives instead of #defines.
5034
50352001-12-30 Akim Demaille <akim@epita.fr>
5036
5037 * src/skeleton.h: New.
5038 * src/output.c (output_parser, output_master_parser): Remove, dead
5039 code.
5040 * src/output.h (get_lines_number, actions_output, guards_output)
5041 (token_definitions_output): Prototype them.
5042 * src/parse-skel.y: Add the license notice.
5043 Include output.h and skeleton.h.
5044 (process_skeleton): Returns void, and takes a single parameter.
5045 * src/scan-skel.l: Add the license notice.
5046 Include skeleton.h.
5047 Don't use %option yylineno: it seems that then Flex imagines
5048 REJECT has been used, and therefore it won't reallocate its
5049 buffers (which makes no other sense to me than a bug). It results
5050 in warnings for `unused: yy_flex_realloc'.
5051
50522001-12-30 Robert Anisko <robert.anisko@epita.fr>
5053
5054 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5055 (MUSCLE_INSERT_PREFIX): ...to there.
5056 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5057 (MUSCLE_INSERT_PREFIX): Move from here...
5058
5059 * src/bison.hairy: Add a section directive. Put braces around muscle
5060 names. This parser skeleton is still broken, but Bison should not
5061 choke on a bad muscle 'syntax'.
5062 * src/bison.simple: Add a section directive. Put braces around muscle
5063 names.
5064
5065 * src/files.h (strsuffix, stringappend): Add declarations.
5066 (tab_extension): Add declaration.
5067 (short_base_name): Add declaration.
5068
5069 * src/files.c (strsuffix, stringappend): No longer static. These
5070 functions are used in the skeleton parser.
5071 (tab_extension): New.
5072 (compute_base_names): Use the computations done in this function
5073 to guess if the generated parsers should have '.tab' in their
5074 names.
5075 (short_base_name): No longer static.
5076
5077 * src/output.c (output_skeleton): New.
5078 (output): Disable call to output_master_parser, and give a try to
5079 a new skeleton handling system.
5080 (guards_output, actions_output): No longer static.
5081 (token_definitions_output, get_lines_number): No longer static.
5082
5083 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
5084
5085 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
5086 parse-skel.y.
5087
5088 * src/parse-skel.y: New file.
5089 * src/scan-skel.l: New file.
5090
50912001-12-29 Akim Demaille <akim@epita.fr>
5092
5093 %name-prefix is broken.
5094
5095 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
5096 Adjust all dependencies.
5097 * tests/headers.at (export YYLTYPE): Strengthen this test: use
5098 %name-prefix.
5099
5100 Renaming yylval but not yylloc is not consistent. Now we do.
5101
5102 * src/bison.simple: Prefix yylloc if used.
5103 * doc/bison.texinfo (Decl Summary): Document that.
5104
51052001-12-29 Akim Demaille <akim@epita.fr>
5106
5107 * doc/bison.texinfo: Promote `%long-directive' over
5108 `%long_directive'.
5109 Remove all references to fixed-output-files, yacc is enough.
5110
51112001-12-29 Akim Demaille <akim@epita.fr>
5112
5113 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
5114 user prologue. These are defaults.
5115 * tests/actions.at (Mid-rule actions): Make sure the user can
5116 define YYDEBUG and YYERROR_VERBOSE.
5117
51182001-12-29 Akim Demaille <akim@epita.fr>
5119
5120 * src/output.c (header_output): Don't forget to export YYLTYPE and
5121 yylloc.
5122 * tests/headers.at (export YYLTYPE): New, make sure it does.
5123 * tests/regression.at (%union and --defines, Invalid CPP headers):
5124 Move to...
5125 * tests/headers.at: here.
5126
51272001-12-29 Akim Demaille <akim@epita.fr>
5128
5129 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
5130
51312001-12-29 Akim Demaille <akim@epita.fr>
5132
5133 * tests/actions.at (Mid-rule actions): Output on a single line
5134 instead of several.
5135
51362001-12-29 Akim Demaille <akim@epita.fr>
5137
5138 * doc/bison.texinfo: Formatting changes.
5139
51402001-12-29 Akim Demaille <akim@epita.fr>
5141
5142 Don't store the token defs in a muscle, just be ready to output it
5143 on command. Now possible via `symbols'. Fixes a memory leak.
5144
5145 * src/output.c (token_definitions_output): New.
5146 (output_parser, header_output): Use it.
5147 * src/reader.c (symbols_save): Remove.
5148
51492001-12-29 Akim Demaille <akim@epita.fr>
5150
5151 * src/bison.simple: Do not provide a default for YYSTYPE and
5152 YYLTYPE before the user's prologue. Otherwise it's hardly... a
5153 default.
5154
51552001-12-29 Akim Demaille <akim@epita.fr>
5156
5157 Mid-rule actions are simply... ignored!
5158
5159 * src/reader.c (readgram): Be sure to attach mid-rule actions to
5160 the empty-rule associated to the dummy symbol, not to the host
5161 rule.
5162 * tests/actions.at (Mid-rule actions): New.
5163
51642001-12-29 Akim Demaille <akim@epita.fr>
5165
5166 Memory leak.
5167
5168 * src/reader.c (reader): Free grammar.
5169
51702001-12-29 Akim Demaille <akim@epita.fr>
5171
5172 Memory leak.
5173
5174 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
5175 since it allocates it for each state, although only one is needed.
5176 (allocate_storage): Do it here.
5177
51782001-12-29 Akim Demaille <akim@epita.fr>
5179
5180 * src/options.h, src/options.c (create_long_option_table): Rename
5181 as...
5182 (long_option_table_new): this, with a clearer prototype.
5183 (percent_table): Remove, unused,
5184 * src/getargs.c (getargs): Adjust.
5185
51862001-12-29 Akim Demaille <akim@epita.fr>
5187
5188 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
5189 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
5190 as states.
5191
51922001-12-29 Akim Demaille <akim@epita.fr>
5193
5194 * src/lalr.c (build_relations): Rename `states' as `states1'.
5195 Sorry, I don't understand exactly what it is, no better name...
5196
51972001-12-29 Akim Demaille <akim@epita.fr>
5198
5199 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
5200 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
5201 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
5202 as rules.
5203
52042001-12-29 Akim Demaille <akim@epita.fr>
5205
5206 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
5207 ago.
5208
52092001-12-29 Akim Demaille <akim@epita.fr>
5210
5211 * src/reader.c, src/reader.h (user_toknums): Remove.
5212 Adjust all users to use symbols[i]->user_token_number.
5213
52142001-12-29 Akim Demaille <akim@epita.fr>
5215
5216 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
5217 Adjust all users to use symbols[i]->prec or ->assoc.
5218
52192001-12-29 Akim Demaille <akim@epita.fr>
5220
5221 * src/reader.c, src/reader.h (tags): Remove.
5222 Adjust all users to use symbols[i]->tag.
5223
52242001-12-29 Akim Demaille <akim@epita.fr>
5225
5226 * src/gram.h, src/gram.c (symbols): New, similar to state_table
5227 and rule_table.
5228 * src/reader.c (packsymbols): Fill this table.
5229 Drop sprec.
5230 * src/conflicts.c (resolve_sr_conflict): Adjust.
5231 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
5232 single table.
5233 Use symbols[i]->tag instead of tags[i].
5234
52352001-12-29 Akim Demaille <akim@epita.fr>
5236
5237 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
5238 In addition, put a comment in there, to replace...
5239 * tests/regression.at (%union and C comments): Remove.
5240
52412001-12-29 Akim Demaille <akim@epita.fr>
5242
5243 * tests/regression.at (Web2c Actions): Blindly move the actual
5244 output as expected output. The contents *seem* right to me, but I
5245 can't pretend reading perfectly parser tables... Nonetheless, all
5246 the other tests pass correctly, the table look OK, even though the
5247 presence of `$axiom' is to be noted: AFAICS it is useless (but
5248 harmless).
5249
52502001-12-29 Akim Demaille <akim@epita.fr>
5251
5252 * src/reader.c (readgram): Don't add the rule 0 if there were no
5253 rules read. In other words, add it _after_ having performed
5254 grammar sanity checks.
5255 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
5256
52572001-12-29 Akim Demaille <akim@epita.fr>
5258
5259 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
5260 visible, and some states have now a different number.
5261
52622001-12-29 Akim Demaille <akim@epita.fr>
5263
5264 * src/reader.c (readgram): Bind the initial rule's lineno to that
5265 of the first rule.
5266 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5267 (Solved SR Conflicts): Adjust rule 0's line number.
5268
52692001-12-29 Akim Demaille <akim@epita.fr>
5270
5271 Fix the `GAWK Grammar' failure.
5272
5273 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5274 the reductions of the first state which was mistakenly confused
5275 with the final state because precisely final_state was initialized
5276 to 0.
5277 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5278 now noticed by Bison.
5279 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5280 have a reduction on $default.
5281
52822001-12-29 Akim Demaille <akim@epita.fr>
5283
5284 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5285 rule line numbers.
5286 * src/closure.c (print_closure): Likewise.
5287 * src/derives.c (print_derives): Likewise.
5288 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5289 now.
5290
52912001-12-29 Akim Demaille <akim@epita.fr>
5292
5293 * src/lalr.c (lookaheads_print): New.
5294 (lalr): Call it when --trace-flag.
5295 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5296 are dumped.
5297
52982001-12-29 Akim Demaille <akim@epita.fr>
5299
5300 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5301 when walking through ritem, even via rule->rhs.
5302 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5303 (useful_production, useless_nonterminals): Likewise.
5304 (reduce_grammar_tables): Likewise, plus update nritems.
5305 * src/nullable.c (set_nullable): Likewise.
5306 * src/lalr.c (build_relations): Likewise.
5307 * tests/sets.at (Nullable): Adjust.
5308 Fortunately, now, the $axiom is no longer nullable.
5309
53102001-12-29 Akim Demaille <akim@epita.fr>
5311
5312 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5313 the 0-sentinel.
5314 * src/gram.c (ritem_longest_rhs): Likewise.
5315 * src/reduce.c (nonterminals_reduce): Likewise.
5316 * src/print_graph.c (print_graph): Likewise.
5317 * src/output.c (output_rule_data): Likewise.
5318 * src/nullable.c (set_nullable): Likewise.
5319
53202001-12-29 Akim Demaille <akim@epita.fr>
5321
5322 * src/output.c: Comment changes.
5323
53242001-12-27 Paul Eggert <eggert@twinsun.com>
5325
5326 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5327 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5328 Sparc, as they were causing more porting problems than the
5329 (minor) performance improvement was worth.
5330
5331 Also, catch up with 1.31's YYSTD.
5332
53332001-12-27 Akim Demaille <akim@epita.fr>
5334
5335 * src/output.c (output_gram): Rely on nritems, not the
5336 0-sentinel. See below.
5337 Use -1 as separator, not 0.
5338 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5339 Rely on -1 as separator in yyrhs, instead of 0.
5340 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5341 twice `Now at end of input', therefore there are two lines less to
5342 expect.
5343
53442001-12-27 Akim Demaille <akim@epita.fr>
5345
5346 * tests/regression.at (Unresolved SR Conflicts):
5347 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5348 below.
5349
53502001-12-27 Akim Demaille <akim@epita.fr>
5351
5352 * src/LR0.c (new_state): Recognize the final state by the fact it
5353 is reached by eoftoken.
5354 (insert_start_shifting_state, insert_eof_shifting_state)
5355 (insert_accepting_state, augment_automaton): Remove, since now
5356 these states are automatically computed from the initial state.
5357 (generate_states): Adjust.
5358 * src/print.c: When reporting a rule number to the user, substract
5359 1, so that the axiom rule is rule 0, and the first user rule is 1.
5360 * src/reduce.c: Likewise.
5361 * src/print_graph.c (print_core): For the time being, just as for
5362 the report, depend upon --trace-flags to dump the full set of
5363 items.
5364 * src/reader.c (readgram): Once the grammar read, insert the rule
5365 0: `$axiom: START-SYMBOL $'.
5366 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5367 number of the states has changed (the final state is no longer
5368 necessarily the last), catch up.
5369
53702001-12-27 Akim Demaille <akim@epita.fr>
5371
5372 Try to make the use of the eoftoken valid. Given that its value
5373 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5374 is used instead of > 0 where appropriate, (ii), depend upon nritems
5375 instead of the 0-sentinel.
5376
5377 * src/gram.h, src/gram.c (nritems): New.
5378 Expected to be duplication of nitems, but for the time being...
5379 * src/reader.c (packgram): Assert nritems and nitems are equal.
5380 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5381 * src/closure.c (print_closure, print_fderives): Likewise.
5382 * src/gram.c (ritem_print): Likewise.
5383 * src/print.c (print_core, print_grammar): Likewise.
5384 * src/print_graph.c: Likewise.
5385
53862001-12-27 Akim Demaille <akim@epita.fr>
5387
5388 * src/main.c (main): If there are complains after grammar
5389 reductions, then output the report anyway if requested, then die.
5390 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5391 * src/reader.c (eoftoken): New.
5392 (parse_token_decl): If the token being defined has value `0', it
5393 is the eoftoken.
5394 (packsymbols): No longer hack `tags' to insert `$' by hand.
5395 Be sure to preserve the value of the eoftoken.
5396 (reader): Make sure eoftoken is defined.
5397 Initialize nsyms to 0: now eoftoken is created just like the others.
5398 * src/print.c (print_grammar): Don't special case the eof token.
5399 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5400 lie anyway, albeit pleasant.
5401 * tests/calc.at: Exercise error messages with eoftoken.
5402 Change the grammar so that empty input is invalid.
5403 Adjust expectations.
5404 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5405
54062001-12-27 Akim Demaille <akim@epita.fr>
5407
5408 * configure.in: Check the protos of strchr ans strspn.
5409 Replace strchr if needed.
5410 * src/system.h: Provide the protos of strchr, strspn and memchr if
5411 missing.
5412 * lib/strchr.c: New.
5413 * src/reader.c (symbols_save): Use strchr.
5414
54152001-12-27 Akim Demaille <akim@epita.fr>
5416
5417 * src/print.c, src/print_graph.c (escape): New.
5418 Use it to quote the TAGS outputs.
5419 * src/print_graph.c (print_state): Now errors are in red, and
5420 reductions in green.
5421 Prefer high to wide: output the state number on a line of its own.
5422
54232001-12-27 Akim Demaille <akim@epita.fr>
5424
5425 * src/state.h, src/state.c (reductions_new): New.
5426 * src/LR0.c (set_state_table): Let all the states have a
5427 `reductions', even if reduced to 0.
5428 (save_reductions): Adjust.
5429 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5430 * src/print.c (print_reductions, print_actions): Adjust.
5431 * src/output.c (action_row): Adjust.
5432
54332001-12-27 Akim Demaille <akim@epita.fr>
5434
5435 * src/state.h, src/state.c (errs_new, errs_dup): New.
5436 * src/LR0.c (set_state_table): Let all the states have an errs,
5437 even if reduced to 0.
5438 * src/print.c (print_errs, print_reductions): Adjust.
5439 * src/output.c (output_actions, action_row): Adjust.
5440 * src/conflicts.c (resolve_sr_conflict): Adjust.
5441
54422001-12-27 Akim Demaille <akim@epita.fr>
5443
5444 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5445
54462001-12-27 Akim Demaille <akim@epita.fr>
5447
5448 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5449 * src/print.c: here.
5450 (lookaheadset, shiftset): New, used as additional storage by
5451 print_reductions.
5452 (print_results): Adjust.
5453 (print_shifts, print_gotos, print_errs): New, extracted from...
5454 (print_actions): here.
5455 * src/print_graph.c (print_actions): Remove dead code.
5456
54572001-12-27 Akim Demaille <akim@epita.fr>
5458
5459 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5460 `$n' and `@n'.
5461
54622001-12-27 Akim Demaille <akim@epita.fr>
5463
5464 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5465 (build_relations): Adjust.
5466
54672001-12-27 Akim Demaille <akim@epita.fr>
5468
5469 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5470 duplication.
5471
54722001-12-27 Akim Demaille <akim@epita.fr>
5473
5474 * src/reader.c (packgram): Catch nitems overflows.
5475
54762001-12-27 Akim Demaille <akim@epita.fr>
5477
5478 * src/files.c, src/files.h (guard_obstack): Remove.
5479 * src/output.c (output): Adjust.
5480 * src/reader.c (parse_braces): New, factoring...
5481 (copy_action, copy_guard): these two which are renamed as...
5482 (parse_action, parse_guard): these.
5483 As a voluntary consequence, using braces around guards is now
5484 mandatory.
5485
54862001-12-27 Akim Demaille <akim@epita.fr>
5487
5488 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5489 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5490 members.
5491 (symbol_list_new): Adjust.
5492 (copy_action): action_line is the first line, not the last.
5493 (copy_guard): Just as for actions, store the `action' only, not
5494 the switch/case/break flesh.
5495 Don't parse the user action that might follow the guard, let...
5496 (readgram): do it, i.e., now, there can be an action after a
5497 guard.
5498 In other words the guard is just explicitly optional.
5499 (packgram): Adjust.
5500 * src/output.c (guards_output): New.
5501 (output_parser): Call it when needed.
5502 (output): Also free the guard and attrs obstacks.
5503 * src/files.c, src/files.h (obstack_save): Remove.
5504 (output_files): Remove.
5505 As a result, if one needs the former `.act' file, using an
5506 appropriate skeleton which requires actions and guards is now
5507 required.
5508 * src/main.c (main): Adjust.
5509 * tests/semantic.at: New.
5510 * tests/regression.at: Use `input.y' as input file name.
5511 Avoid 8+3 problems by requiring input.c when the test needs the
5512 parser.
5513
55142001-12-27 Akim Demaille <akim@epita.fr>
5515
5516 * src/reader.c (symbol_list_new): Be sure to initialize all the
5517 fields.
5518
55192001-12-27 Akim Demaille <akim@epita.fr>
5520
5521 All the hacks using a final pseudo state are now useless.
5522
5523 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5524 * src/lalr.c (nLA): New.
5525 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5526 instead of lookaheadsp from the pseudo state (nstate + 1).
5527
55282001-12-27 Akim Demaille <akim@epita.fr>
5529
5530 * src/output.c (action_row, token_actions): Use a state_t instead
5531 of a integer, and nlookaheads instead of the following state's
5532 lookaheadsp.
5533
55342001-12-27 Akim Demaille <akim@epita.fr>
5535
5536 * src/conflicts.c (log_resolution, flush_shift)
5537 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5538 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5539 (conflicts_print, print_reductions): Use a state_t instead of an
5540 integer when referring to a state.
5541 As much as possible, depend upon nlookaheads, instead of the
5542 `lookaheadsp' member of the following state (since lookaheads of
5543 successive states are successive, the difference between state n + 1
5544 and n served as the number of lookaheads for state n).
5545 * src/lalr.c (add_lookback_edge): Likewise.
5546 * src/print.c (print_core, print_actions, print_state)
5547 (print_results): Likewise.
5548 * src/print_graph.c (print_core, print_actions, print_state)
5549 (print_graph): Likewise.
5550 * src/conflicts.h: Adjust.
5551
55522001-12-27 Akim Demaille <akim@epita.fr>
5553
5554 * src/bison.hairy: Formatting/comment changes.
5555 ANSIfy.
5556 Remove `register' indications.
5557 Add plenty of `static'.
5558
55592001-12-27 Akim Demaille <akim@epita.fr>
5560
5561 * src/output.c (prepare): Drop the muscle `ntbase' which
5562 duplicates ntokens.
5563 * src/bison.simple: Formatting/comment changes.
5564 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5565 is an undocumented synonym.
5566
55672001-12-22 Akim Demaille <akim@epita.fr>
5568
5569 * src/output.c (output_table_data): Change the prototype to use
5570 `int' for array ranges: some invocations do pass an int, not a
5571 short.
5572 Reported by Wayne Green.
5573
55742001-12-22 Akim Demaille <akim@epita.fr>
5575
5576 Some actions of web2c.y are improperly triggered.
5577 Reported by Mike Castle.
5578
5579 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5580 * tests/regression.at (Web2c): Rename as...
5581 (Web2c Report): this.
5582 (Web2c Actions): New.
5583
55842001-12-22 Akim Demaille <akim@epita.fr>
5585
5586 Reductions in web2c.y are improperly reported.
5587 Reported by Mike Castle.
5588
5589 * src/conflicts.c (print_reductions): Fix.
5590 * tests/regression.at (Web2c): New.
5591
55922001-12-18 Akim Demaille <akim@epita.fr>
5593
5594 Some host fail on `assert (!"foo")', which expands to
5595 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5596 Reported by Nelson Beebee.
5597
5598 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5599 `#define it_succeeded 0' and `assert (it_succeeded)'.
5600
56012001-12-17 Marc Autret <autret_m@epita.fr>
5602
5603 * src/bison.simple: Don't hard code the skeleton line and filename.
5604 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5605 New line counter 'skeleton_line' (skeleton-line muscle).
5606
56072001-12-17 Paul Eggert <eggert@twinsun.com>
5608
5609 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5610 YYDEBUG must be defined to a nonzero value.
5611
5612 * src/bison.simple (yytname): Do not assume that the user defines
5613 YYDEBUG to a properly parenthesized expression.
5614
56152001-12-17 Akim Demaille <akim@epita.fr>
5616
5617 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5618 nlookaheads is a new member.
5619 Adjust all users.
5620 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5621 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5622 state.
5623
56242001-12-17 Akim Demaille <akim@epita.fr>
5625
5626 * src/files.h, src/files.c (open_files, close_files): Remove.
5627 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5628 let...
5629 * src/reader.c (reader): Do it.
5630
56312001-12-17 Akim Demaille <akim@epita.fr>
5632
5633 * src/conflicts.c (print_reductions): Formatting changes.
5634
56352001-12-17 Akim Demaille <akim@epita.fr>
5636
5637 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5638 (flush_reduce): New.
5639 (resolve_sr_conflict): Adjust.
5640
56412001-12-17 Akim Demaille <akim@epita.fr>
5642
5643 * src/output.c (output_obstack): Be static and rename as...
5644 (format_obstack): this, to avoid any confusion with files.c's
5645 output_obstack.
5646 * src/reader.h (muscle_obstack): Move to...
5647 * src/output.h: here, since it's defined in output.c.
5648
56492001-12-17 Akim Demaille <akim@epita.fr>
5650
5651 * src/output.c (action_row, save_column, default_goto)
5652 (sort_actions, matching_state, pack_vector): Better variable
5653 locality.
5654
56552001-12-17 Akim Demaille <akim@epita.fr>
5656
5657 * src/output.c: Various formatting changes.
5658
56592001-12-17 Akim Demaille <akim@epita.fr>
5660
5661 * src/files.c (output_files): Free the output_obstack.
5662 * src/main.c (main): Call print and print_graph conditionally.
5663 * src/print.c (print): Work unconditionally.
5664 * src/print_graph.c (print_graph): Work unconditionally.
5665 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5666
56672001-12-16 Marc Autret <autret_m@epita.fr>
5668
5669 * src/output.c (actions_output): Fix. When we use %no-lines,
5670 there is one less line per action.
5671
56722001-12-16 Marc Autret <autret_m@epita.fr>
5673
5674 * src/bison.simple: Remove a useless #line directive.
5675 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5676 * src/output.c (get_lines_number): New.
5677 (output_parser): Adjust, now takes care about the lines of a
5678 output muscles.
5679 Fix line numbering.
5680 (actions_output): Computes the number of lines taken by actions.
5681 (output_master_parser): Insert new skeleton which is the name of
5682 the output parser file name.
5683
56842001-12-15 Marc Autret <autret_m@epita.fr>
5685
5686 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5687
56882001-12-15 Marc Autret <autret_m@epita.fr>
5689
5690 * src/output.c (output_gram): Keep track of the hairy one.
5691
56922001-12-15 Akim Demaille <akim@epita.fr>
5693
5694 Make `make distcheck' work.
5695
5696 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5697 system.h which uses libgettext.h.
5698
56992001-12-15 Akim Demaille <akim@epita.fr>
5700
5701 * src/nullable.c (set_nullable): Useless rules must be skipped,
5702 otherwise, since we range over their symbols, we might look at a
5703 nonterminal which no longer ``exists'', i.e., it is not counted in
5704 `nvars', hence we overflow our arrays.
5705
57062001-12-15 Akim Demaille <akim@epita.fr>
5707
5708 The header can also be produced directly, without any obstack!
5709 Yahoo!
5710
5711 * src/files.c, src/files.h (defines_obstack): Remove.
5712 (compute_header_macro): Global.
5713 (defines_obstack_save): Remove.
5714 * src/reader.c (parse_union_decl): No longer output to
5715 defines_obstack: its content can be found in the `stype' muscle
5716 anyway.
5717 (output_token_translations): Merge into...
5718 (symbols_output): this.
5719 Rename as...
5720 (symbols_save): this.
5721 (reader): Adjust.
5722 * src/output.c (header_output): New.
5723 (output): Call it.
5724
57252001-12-15 Akim Demaille <akim@epita.fr>
5726
5727 * src/reader.c (parse_union_decl): Instead of handling two obstack
5728 simultaneously, use one to define the `stype' muscle, and use the
5729 value of the latter to fill defines_obstack.
5730 (copy_comment): Remove.
5731 (copy_comment2): Work for a single obstack.
5732 Rename as...
5733 (copy_comment): this.
5734
57352001-12-15 Akim Demaille <akim@epita.fr>
5736
5737 * src/lex.c, src/lex.h (xgetc): No longer static.
5738 * src/reader.c (parse_union_decl): Revamp.
5739
57402001-12-15 Akim Demaille <akim@epita.fr>
5741
5742 Still making progress in separating Bison into (i) input, (ii)
5743 process, (iii) output: now we can directly output the parser file
5744 without using table_obstack at all.
5745
5746 * src/files.c, src/files.h (table_obstack): Bye bye.
5747 (parser_file_name): New.
5748 * src/files.c (compute_output_file_names): Compute it.
5749 * src/output.c (actions_output, output_parser)
5750 (output_master_parser): To a file instead of an obstack.
5751
57522001-12-15 Akim Demaille <akim@epita.fr>
5753
5754 Attach actions to rules, instead of pre-outputting them to
5755 actions_obstack.
5756
5757 * src/gram.h (rule_t): action and action_line are new members.
5758 * src/reader.c (symbol_list): Likewise.
5759 (copy_action): Save the actions within the rule.
5760 (packgram): Save them in rule_table.
5761 * src/output.c (actions_output): New.
5762 (output_parser): Use it on `%%actions'.
5763 (output_rule_data): Don't free rule_table.
5764 (output): Do it.
5765 (prepare): Don't save the `action' muscle.
5766 * src/bison.simple: s/%%action/%%actions/.
5767
57682001-12-15 Akim Demaille <akim@epita.fr>
5769
5770 * src/reader.c (copy_action): When --yacc, don't append a `;'
5771 to the user action: let it fail if lacking.
5772 Suggested by Arnold Robbins and Tom Tromey.
5773
57742001-12-14 Akim Demaille <akim@epita.fr>
5775
5776 * src/lex.c (literalchar): Simply return the char you decoded, non
5777 longer mess around with obstacks and int pointers.
5778 Adjust all callers.
5779
57802001-12-14 Akim Demaille <akim@epita.fr>
5781
5782 * src/lex.c (literalchar): Don't escape the special characters,
5783 just decode them, and keep them as char (before, eol was output as
5784 the 2 char string `\n' etc.).
5785 * src/output.c (output_rule_data): Use quotearg to output the
5786 token strings.
5787
57882001-12-13 Paul Eggert <eggert@twinsun.com>
5789
5790 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
5791 Do not infringe on the global user namespace when using C++.
5792 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
5793 All uses of `fprintf' and `stderr' changed.
5794
5795 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
5796
57972001-12-13 Akim Demaille <akim@epita.fr>
5798
5799 The computation of nullable is broken: it doesn't handle empty
5800 RHS's properly.
5801
5802 * tests/torture.at (GNU AWK Grammar): New.
5803 * tests/sets.at (Nullable): New.
5804 * src/nullable.c (set_nullable): Instead of blindly looping over
5805 `ritems', loop over the rules, and then over their rhs's.
5806
5807 Work around Autotest bugs.
5808
5809 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
5810 frame, because Autotest understand lines starting with a `+' as
5811 traces from the shell. Then, they are not processed properly.
5812 Admittedly an Autotest bug, but we don't have time to wait for
5813 Autotest to catch up.
5814 * tests/regression.at (Broken Closure): Adjust to the new table
5815 frames.
5816 Move to...
5817 * tests/sets.at: here.
5818
58192001-12-13 Akim Demaille <akim@epita.fr>
5820
5821 * src/closure.c (closure): Use nrules instead of playing tricks
5822 with BITS_PER_WORD.
5823
58242001-12-13 Akim Demaille <akim@epita.fr>
5825
5826 * src/print.c (print_actions): Output the handling of `$' as the
5827 traces do: shifting the token EOF. Before EOF was treated as a
5828 nonterminal.
5829 * tests/regression.at: Adjust some tests.
5830 * src/print_graph.c (print_core): Complete the set of items via
5831 closure. The next-to-final and final states are still unsatisfying,
5832 but that's to be addressed elsewhere.
5833 No longer output the rule numbers, but do output the state number.
5834 A single loop for the shifts + gotos is enough, but picked a
5835 distinct color for each.
5836 (print_graph): Initialize and finalize closure.
5837
58382001-12-13 Akim Demaille <akim@epita.fr>
5839
5840 * src/reader.c (readgram): Remove dead code, an strip useless
5841 braces.
5842 (get_type): Remove, unused.
5843
58442001-12-12 Akim Demaille <akim@epita.fr>
5845
5846 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
5847 on that of lib/error.c.
5848
58492001-12-12 Akim Demaille <akim@epita.fr>
5850
5851 Some hosts don't like `/' in includes.
5852
5853 * src/system.h: Include libgettext.h without qualifying the path.
5854 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
5855 $(top_srcdir).
5856
58572001-12-11 Marc Autret <autret_m@epita.fr>
5858
5859 * src/output.c (output_parser): Remove useless muscle.
5860
58612001-12-11 Marc Autret <autret_m@epita.fr>
5862
5863 * src/bison.simple: Remove #line just before %%epilogue. It
5864 is now handled in ...
5865 * src/reader.c (read_additionnal_code): Add the output of a
5866 #line for the epilogue.
5867
58682001-12-10 Marc Autret <autret_m@epita.fr>
5869
5870 * src/reader.c (copy_definition): Re-use CPP-outed code which
5871 replace precedent remove.
5872 * src/bison.simple: Remove #line before %%prologue because
5873 %%input-line is wrong at this time.
5874
58752001-12-10 Marc Autret <autret_m@epita.fr>
5876
5877 * src/reader.c (symbols_output): Clean up.
5878 * src/output.c (output_gram, output): Clean up.
5879
58802001-12-10 Akim Demaille <akim@epita.fr>
5881
5882 * src/lalr.c (initialize_lookaheads): New. Extracted from...
5883 * src/LR0.c (set_state_table): here.
5884 * src/lalr.c (lalr): Call it.
5885
58862001-12-10 Akim Demaille <akim@epita.fr>
5887
5888 * src/state.h (shifts): Remove the `number' member: shifts are
5889 attached to state, hence no longer need to be labelled with a
5890 state number.
5891
58922001-12-10 Akim Demaille <akim@epita.fr>
5893
5894 Now that states have a complete set of members, the linked list of
5895 shifts is useless: just fill directly the state's shifts member.
5896
5897 * src/state.h (shifts): Remove the `next' member.
5898 * src/LR0.c (first_state, last_state): Remove.
5899 Adjust the callers.
5900 (augment_automaton): Don't look for the shifts that must be added
5901 a shift on EOF: it is those of the state we looked for! But now,
5902 since shifts are attached, it is no longer needed to looking
5903 merely by its id: its number.
5904
59052001-12-10 Akim Demaille <akim@epita.fr>
5906
5907 * src/LR0.c (augment_automaton): Better variable locality.
5908 Remove an impossible branch: if there is a state corresponding to
5909 the start symbol being shifted, then there is shift for the start
5910 symbol from the initial state.
5911
59122001-12-10 Akim Demaille <akim@epita.fr>
5913
5914 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
5915 only when appropriate: when insert_start_shifting_state' is not
5916 invoked.
5917 * tests/regression.at (Rule Line Numbers): Adjust.
5918
59192001-12-10 Akim Demaille <akim@epita.fr>
5920
5921 * src/LR0.c (augment_automaton): Now that all states have shifts,
5922 merge the two cases addition shifts to the initial state.
5923
59242001-12-10 Akim Demaille <akim@epita.fr>
5925
5926 * src/lalr.c (set_state_table): Move to...
5927 * src/LR0.c: here.
5928 * src/lalr.c (lalr): Don't call it...
5929 * src/LR0.c (generate_states): do it.
5930 * src/LR0.h (first_state): Remove, only the table is used.
5931
59322001-12-10 Akim Demaille <akim@epita.fr>
5933
5934 * src/LR0.h (first_shift, first_reduction): Remove.
5935 * src/lalr.c: Don't use first_shift: find shifts through the
5936 states.
5937
59382001-12-10 Akim Demaille <akim@epita.fr>
5939
5940 * src/LR0.c: Attach shifts to states as soon as they are
5941 computed.
5942 * src/lalr.c (set_state_table): Instead of assigning shifts to
5943 state, just assert that the mapping was properly done.
5944
59452001-12-10 Akim Demaille <akim@epita.fr>
5946
5947 * src/LR0.c (insert_start_shift): Rename as...
5948 (insert_start_shifting_state): this.
5949 (insert_eof_shifting_state, insert_accepting_state): New.
5950 (augment_automaton): Adjust.
5951 Better locality of the variables.
5952 When looking if the start_symbol is shifted from the initial
5953 state, using `while (... symbol != start_symbol ...)' sounds
5954 better than `while (... symbol < start_symbol ...)': If fail
5955 to see how the order between symbols could be relevant!
5956
59572001-12-10 Akim Demaille <akim@epita.fr>
5958
5959 * src/getargs.h: Don't declare `spec_name_prefix' and
5960 `spec_file_prefix', declared by src/files.h.
5961 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
5962 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
5963 * src/output.c (prepare): Adjust.
5964 * src/reader.c (symbols_output): Likewise.
5965 * src/vmsgetargs.c: Vaguely adjust, but who cares?
5966
59672001-12-10 Akim Demaille <akim@epita.fr>
5968
5969 * src/muscle_tab.c (muscle_init): NULL is a better default than
5970 `"0"'.
5971
59722001-12-10 Akim Demaille <akim@epita.fr>
5973
5974 * src/reader.c (reader): Calling symbols_output once is enough.
5975
59762001-12-10 Akim Demaille <akim@epita.fr>
5977
5978 Now that states have a complete set of members, the linked list of
5979 reductions is useless: just fill directly the state's reductions
5980 member.
5981
5982 * src/state.h (struct reductions): Remove member `number' and
5983 `next'.
5984 * src/LR0.c (first_reduction, last_reduction): Remove.
5985 (save_reductions): Don't link the new reductions, store them in
5986 this_state.
5987 * src/lalr.c (set_state_table): No need to attach reductions to
5988 states, it's already done.
5989 * src/output.c (output_actions): No longer free the shifts, then
5990 the reductions, then the states: free all the states and their
5991 members.
5992
59932001-12-10 Akim Demaille <akim@epita.fr>
5994
5995 * src/options.c (OPTN, DRTV, BOTH): New.
5996 (option_table): Use them.
5997
5998 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
5999 the job of system.h.
6000 * src/options.c: Don't include stdio.h and xalloc.h for the same
6001 reasons.
6002
60032001-12-10 Akim Demaille <akim@epita.fr>
6004
6005 * src/output.c (output, prepare): Make sure the values of the
6006 muscles `action' and `prologue' are 0-terminated.
6007
60082001-12-10 Akim Demaille <akim@epita.fr>
6009
6010 Clean up GCC warnings.
6011
6012 * src/reader.c (copy_action): `buf' is not used.
6013 (parse_skel_decl): Be static.
6014 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
6015 * src/options.h (create_long_option_table): Have a real prototype.
6016 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
6017 (hash_delete_at): Return const void *.
6018 Adjust casts to preserve the const.
6019
60202001-12-10 Akim Demaille <akim@epita.fr>
6021
6022 * configure.in: Require 2.52g.
6023 M4 is not needed, but AUTOM4TE is.
6024 * m4/m4.m4: Remove.
6025 * tests/Makefile.am: Adjust.
6026
60272001-12-10 Akim Demaille <akim@epita.fr>
6028
6029 One structure for states is enough, even though theoretically
6030 there are LR(0) states and LALR(1) states.
6031
6032 * src/lalr.h (state_t): Remove.
6033 (state_table): Be state_t **, not state_t *.
6034 * src/state.h (core, CORE_ALLOC): Rename as...
6035 (state_t, STATE_ALLOC): this.
6036 Add the LALR(1) members: shifts, reductions, errs.
6037 * src/LR0.c (state_table): Rename as...
6038 (state_hash): this, to avoid name clashes with the global
6039 `state_table'.
6040 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
6041 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
6042
60432001-12-10 Akim Demaille <akim@epita.fr>
6044
6045 Bison dumps core on bash.y.
6046 Reported by Pascal Bart.
6047
6048 * src/warshall.c (bitmatrix_print): New.
6049 (TC): Use it.
6050 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
6051 j must be the outer loop.
6052 * tests/regression.at (Broken Closure): New.
6053
60542001-12-05 Akim Demaille <akim@epita.fr>
6055
6056 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
6057 its argument.
6058