]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
* Makefile.maint: Sync with Autoconf:
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-11-12 Akim Demaille <akim@epita.fr>
2
3 * Makefile.maint: Sync with Autoconf:
4 (local_updates): New.
5
62002-11-12 Akim Demaille <akim@epita.fr>
7
8 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
9
102002-11-12 Akim Demaille <akim@epita.fr>
11
12 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
13 locations.
14
152002-11-12 Akim Demaille <akim@epita.fr>
16
17 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
18 not yyvalue.
19
202002-11-12 Akim Demaille <akim@epita.fr>
21
22 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
23 Use it to test the GLR parser.
24
252002-11-12 Akim Demaille <akim@epita.fr>
26
27 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
28 defines it.
29 * data/glr.c (yystos): New.
30 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
31 (YYDSYMPRINT): New.
32 (yyval): Don't define it, it is handled via M4.
33 (yyrecoverParseError): Free verbosely the discarded symbols.
34 * data/yacc.c (yysymprint): Remove, rather...
35 (b4_yysymprint_generate): invoke.
36 * data/c.m4 (b4_yysymprint_generate): New.
37 Accept pointers as arguments, as opposed to the version from
38 yacc.c.
39 (b4_yydestruct_generate): Likewise.
40 * tests/cations.at (Printers and Destructors): Use Bison directives
41 instead of CPP macros.
42 Don't rely on internal details.
43
442002-11-12 Akim Demaille <akim@epita.fr>
45
46 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
47 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
48 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
49 it against YYEMPTY and so forth), work on yytoken (i.e., set
50 it to YYEMPTY etc.).
51 (yydestruct): Replace with a b4_yydestruct_generate invocation.
52 (b4_symbol_actions): Remove.
53 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
54 for 0, end-of-input.
55
562002-11-12 Akim Demaille <akim@epita.fr>
57
58 * doc/bison.texinfo (Destructor Decl): New.
59
602002-11-12 Akim Demaille <akim@epita.fr>
61
62 * src/tables.c (tables_generate): Use free for pointers that
63 cannot be NULL, not XFREE.
64 (pack_vector): Use assert, not fatal, for bound violations.
65 * src/state.c (state_new): Likewise.
66 * src/reader.c (reader): Likewise.
67 * src/lalr.c (set_goto_map): Likewise.
68 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
69 the file name.
70
712002-11-12 Akim Demaille <akim@epita.fr>
72
73 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
74 Restore.
75 * src/scan-gram.l (last_string): Is global to the file, not to
76 yylex.
77 * src/parse-gram.y (input): Don't append the epilogue here,
78 (epilogue.opt): do it here, and free the scanner's obstack.
79 * src/reader.c (epilogue_set): Rename as...
80 (epilogue_augment): this.
81 * data/c.m4 (b4_epilogue): Defaults to empty.
82
832002-11-12 Akim Demaille <akim@epita.fr>
84
85 * src/getargs.c (long_options): Remove duplicates.
86 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
87 Remove.
88 * doc/bison.rnh: Remove.
89 * doc/bison.texinfo (VMS Invocation): Remove.
90
912002-11-12 Akim Demaille <akim@epita.fr>
92
93 * src/struniq.h, src/struniq.c (struniq_t): Is const.
94 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
95
96 Use struniq for symbols.
97
98 * src/symtab.h (symbol_t): The tag member is a struniq.
99 (symbol_type_set): Adjust.
100 * src/symtab.c (symbol_new): Takes a struniq.
101 (symbol_free): Don't free the tag member.
102 (hash_compare_symbol_t, hash_symbol_t): Rename as...
103 (hash_compare_symbol, hash_symbol): these.
104 Use the fact that tags as struniqs.
105 (symbol_get): Use struniq_new.
106 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
107 Returns a strniq.
108 * src/reader.h (merger_list, grammar_currentmerge_set): The name
109 and type members are struniqs.
110 * src/reader.c (get_merge_function)
111 (grammar_current_rule_merge_set): Adjust.
112 (TYPE, current_type): Are struniq.
113
114 Use struniq for file names.
115
116 * src/files.h, src/files.c (infile): Split into...
117 (grammar_file, current_file): these.
118 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
119 * src/reduce.c (reduce_print): Likewise.
120 * src/getargs.c (getargs): Likewise.
121 * src/complain.h, src/complain.c: Likewise.
122 * src/main.c (main): Call struniqs_new early enough to use it for
123 file names.
124 Don't free the input file name.
125
1262002-11-12 Akim Demaille <akim@epita.fr>
127
128 * src/symtab.c (symbol_free): Remove dead deactivated code:
129 type_name are properly removed.
130 Don't use XFREE to free items that cannot be NULL.
131 * src/struniq.h, src/struniq.c: New.
132 * src/main.c (main): Initialize/free struniqs.
133 * src/parse-gram.y (%union): Add astruniq member.
134 (yyprint): Adjust.
135 * src/scan-gram.l (<{tag}>): Return a struniq.
136 Free the obstack bit that used to store it.
137 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
138
1392002-11-11 Paul Eggert <eggert@twinsun.com>
140
141 Revamp to fix many (but not all) of the C- and M4-related quoting
142 problems. Among other things, this fixes the Bison bug reported
143 by Jan Hubicka when processing the Bash grammar; see:
144 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
145
146 Use new @ escapes consistently. Represent brackets with @{ and @}
147 rather than @<:@ and @:>@, since this works a bit better with dumb
148 editors like vi. Represent @ with @@, since @ is now consistently
149 an escape. Use @oline@ and @ofile@ rather than __oline__ and
150 __ofile__, to avoid unexpected expansions. Similarly, use @output
151 rather than #output.
152
153 * data/c.m4 (b4_copyright): Omit file name from comment, since
154 the file name could contain "*/".
155 (b4_synclines_flag): Don't quote the 2nd argument; it should already
156 be quoted. All uses changed.
157
158 * data/glr.c: Use new @ escapes consistently.
159 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
160 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
161 Remove, since they couldn't handle arbitrary characters in file
162 names.
163 * data/lalr1.cc: Likewise.
164 * data/yacc.c: Likewise.
165
166 * src/files.c (output_infix): Remove; all uses removed.
167 * src/files.h: Likewise.
168
169 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
170 mishandled funny characters in file names, and anyway it isn't
171 needed any more.
172 * data/yacc.c: Likewise.
173 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
174
175 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
176 * data/yacc.c: Likewise.
177
178 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
179 strings now.
180 (muscle_init): Quote filename as a C string.
181 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
182 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
183 * src/output.c (escaped_file_name_output): New function.
184 (prepare_symbols): Quote tokens for M4.
185 (prepare): Don't insert output_infix, output_prefix,
186 output_parser_name, output_header_name; this is now down by scan-skel.
187 Insert skeleton as a C string.
188
189 * src/output.c (user_actions_output, symbol_destructors_output,
190 symbol_printers_output): Quote filenames for C and M4.
191 * src/reader.c (prologue_augment, epilogue_set): Likewise.
192
193 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
194 escapes other than \\ and \'; this simplifies the code.
195 (<SC_STRING>): Likewise, for \\ and \".
196 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
197 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
198 Use new escapes @{ and @} for [ and ].
199
200 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
201 them with auto vars.
202 Switch to new escape scheme, where @ is the escape character uniformly.
203 Abort if a stray escape character is found. Avoid unbounded input
204 buffer when parsing non-escaped text.
205
206 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
207 __oline__, #output, $@, and @{ do not have unintended meanings.
208
2092002-11-09 Paul Eggert <eggert@twinsun.com>
210
211 Fix the test failure due to GCC warnings described in
212 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
213 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
214 evaluate to 0 if it's impossible for NINF to be in the respective
215 table.
216 (yygetLRActions, yyrecoverParseError): Use them.
217
218 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
219 counted in the token inserted at end of file. Now takes
220 location_t *, not location_t, so that the location can be
221 adjusted. All uses changed.
222
223 * tests/regression.at (Invalid inputs): Adjust wording in
224 diagnostic to match the new behavior.
225
226 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
227 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
228 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
229 abort ();'. This reduces the runtime of the "Many lookaheads"
230 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
231 GCC 3.2.
232
2332002-11-07 Paul Eggert <eggert@twinsun.com>
234
235 * src/parse-gram.y (CHARACTER): Remove unused token.
236 All uses removed.
237
238 * src/scan-gram.l: Remove stack option. We no longer use the
239 stack, since the stack was never deeper than 1; instead, use the
240 new auto var c_context to record the stacked value.
241
242 Remove nounput option. At an unexpected end of file, we now unput
243 the minimal input necessary to end cleanly; this simplifies the
244 code.
245
246 Avoid unbounded token sizes where this is easy.
247
248 (unexpected_end_of_file): New function.
249 Use it to systematize the error message on unexpected EOF.
250 (last-string): Now auto, not static.
251 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
252 (scanner_last_string_free): Remove; not used.
253 (percent_percent_count): Move decl to just before use.
254 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
255 not the (never otherwised-used) CHARACTER.
256
2572002-11-07 Akim Demaille <akim@epita.fr>
258
259 Let yyerror always receive the msg as last argument, so that
260 yyerror can be variadic.
261
262 * data/yacc.c (b4_yyerror_args): New.
263 Use it when calling yyerror.
264 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
265 Use it when calling yyerror.
266 * doc/bison.texinfo (Error Reporting): Adjust.
267 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
268 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
269
2702002-11-06 Akim Demaille <akim@epita.fr>
271
272 #line should have quoted strings.
273 Ideally, this should be done by m4_quotearg.
274
275 * src/scan-skel.l: Include quotearg.h.
276 Quote __ofile__.
277 * src/output.c (symbol_printers_output)
278 (symbol_destructors_output): Quote the file name.
279
2802002-11-06 Akim Demaille <akim@epita.fr>
281
282 * tests/regression.at (Invalid inputs): Adjust to the recent
283 messages.
284
2852002-11-06 Akim Demaille <akim@epita.fr>
286
287 Restore --no-lines.
288 Reported by Jim Kent.
289
290 * data/c.m4 (b4_syncline): New.
291 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
292 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
293 * src/output.c (user_actions_output): Likewise.
294 (prepare): Define 'b4_synclines_flag'.
295 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
296
2972002-11-06 Akim Demaille <akim@epita.fr>
298
299 * src/main.c (main): Free `infile'.
300 * src/scan-gram.l (handle_syncline): New.
301 Recognize `#line'.
302 * src/output.c (user_actions_output, symbol_destructors_output)
303 (symbol_printers_output): Use the location's file name, not
304 infile.
305 * src/reader.c (prologue_augment, epilogue_set): Likewise.
306
3072002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
308
309 * src/tables.c (matching_state): Don't allow states to match if
310 either has GLR conflict entries.
311
3122002-11-05 Paul Eggert <eggert@twinsun.com>
313
314 * src/scan-gram.l: Use more accurate diagnostics, e.g.
315 "integer out of range" rather than "invalid value".
316 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
317 accordingly.
318
319 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
320 Also, remove one static variable in the scanner.
321
322 * src/scan-gram.l (braces_level): Now auto, not static.
323 Initialize to zero if the compiler is being picky.
324 (INITIAL): Clear braces_level instead of incrementing it.
325 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
326 as POSIX 1003.1-2001 requires.
327 * src/system.h (IF_LINT): New macro, taken from coreutils.
328 * configure.ac: Define "lint" if --enable-gcc-warnings.
329
3302002-11-05 Akim Demaille <akim@epita.fr>
331
332 * src/scan-gram.l: When it starts with `%', complain about the
333 whole directive, not just that `invalid character: %'.
334
3352002-11-04 Akim Demaille <akim@epita.fr>
336
337 * Makefile.maint: Update from Autoconf.
338 (update, cvs-update, po-update, do-po-update): New.
339
3402002-11-04 Akim Demaille <akim@epita.fr>
341
342 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
343 and yyerror.
344 Have yyerror `use' its arguments.
345 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
346 returns true when location & yacc & pure & parse-param.
347 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
348
3492002-11-04 Akim Demaille <akim@epita.fr>
350
351 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
352 clashes.
353 * src/scan-gram.l: Use [\'] instead of ['] to pacify
354 font-lock-mode.
355 Use complain_at.
356 Use quote, not quote_n since LOCATION_PRINT no longer uses the
357 slot 0.
358
3592002-11-03 Paul Eggert <eggert@twinsun.com>
360
361 * src/reader.c (get_merge_function, grammar_current_rule_check):
362 Use consistent diagnostics for reporting type name clashes.
363 Quote the types with <>, for consistency with Yacc.
364 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
365
3662002-11-03 Akim Demaille <akim@epita.fr>
367
368 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
369 New.
370 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
371 (b4_parse_param): Remove.
372 Use b4_identification.
373 Propagate b4_pure_args where needed to pass them to yyerror.
374 * data/glr.m4 (b4_parse_param): Remove.
375 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
376 (b4_lpure_formals): New.
377 Use b4_identification.
378 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
379 b4_user_formals and b4_user_args.
380 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
381 (yyreportAmbiguity): When using a pure parser, also need
382 the location, and the parse-params.
383 Adjust callers.
384 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
385 When using a pure parser, also need the parse-params.
386 Adjust callers.
387 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
388 (%pure-parser + %parse-param) LALR and GLR parsers.
389 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
390 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
391 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
392 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
393 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
394 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
395 * doc/bison.texinfo: Untabify the whole file.
396 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
397 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
398 (Error Reporting): Adjust to these new directives.
399 Document %error-verbose, deprecate YYERROR_VERBOSE.
400
4012002-11-03 Akim Demaille <akim@epita.fr>
402
403 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
404 AT_CHECK_CALC_GLR invocations to use % directives, instead of
405 command line options.
406 * tests/cxx-type.at: Formatting changes.
407
4082002-11-03 Paul Eggert <eggert@twinsun.com>
409
410 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
411 to count columns correctly, and to check for invalid inputs.
412
413 Use mbsnwidth to count columns correctly. Account for tabs, too.
414 Include mbswidth.h.
415 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
416 (extend_location): New function.
417 (YY_LINES): Remove.
418
419 Handle CRLF in C code rather than in Lex code.
420 (YY_INPUT): New macro.
421 (no_cr_read): New function.
422
423 Scan UCNs, even though we don't fully handle them yet.
424 (convert_ucn_to_byte): New function.
425
426 Handle backslash-newline correctly in C code.
427 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
428 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
429 all uses changed.
430 (tag, splice): New EREs. Do not allow NUL or newline in tags.
431 Use {splice} wherever C allows backslash-newline.
432 YY_STEP after space, newline, vertical-tab.
433 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
434
435 (letter, id): Don't assume ASCII; e.g., spell out a-z.
436
437 ({int}, handle_action_dollar, handle_action_at): Check for integer
438 overflow.
439
440 (YY_STEP): Omit trailing semicolon, so that it's more like C.
441
442 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
443 as well as \000. Check for UCHAR_MAX, not 255.
444 Allow \x with an arbitrary positive number of digits, as in C.
445 Check for overflow here.
446 Allow \? and UCNs, for compatibility with C.
447
448 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
449 with quote slot used by complain_at.
450
451 * tests/input.at: Add tests for backslash-newline, m4 quotes
452 in symbols, long literals, and funny escapes in strings.
453
454 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
455 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
456 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
457 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
458 * m4/mbswidth.m4: New file, from GNU coreutils.
459
460 * doc/bison.texinfo (Grammar Outline): Document // comments.
461 (Symbols): Document that trigraphs have no special meaning in Bison,
462 nor is backslash-newline allowed.
463 (Actions): Document that trigraphs have no special meaning.
464
465 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
466 no longer used.
467
4682002-11-02 Paul Eggert <eggert@twinsun.com>
469
470 * src/reader.c: Don't include quote.h; not needed.
471 (get_merge_function): Reword warning to be consistent with
472 type clash diagnostic in grammar_current_rule_check.
473
474 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
475 bug in trigraph handling.
476
477 * src/output.c (prepare_symbols): When printing token names,
478 escape "[" as "@<:@" and likewise for "]".
479
480 * src/system.h (errno): Remove declaration, as we are now
481 assuming C89 or better, and C89 guarantees errno.
482
4832002-10-30 Paul Eggert <eggert@twinsun.com>
484
485 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
486 Check for close failures.
487 * src/files.h (xfclose): Return void, not int, since it always
488 returned zero.
489 * src/files.c (xfclose): Likewise. Report I/O error if ferror
490 indicates one.
491 * src/output.c (output_skeleton): Use xfclose rather than fclose
492 and ferror. xfclose now checks ferror.
493
494 * data/glr.c (YYLEFTMOST_STATE): Remove.
495 (yyreportTree): Use a stack-based leftmost state. This avoids
496 our continuing battles with bogus warnings about initializers.
497
4982002-10-30 Akim Demaille <akim@epita.fr>
499
500 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
501 #if.
502
5032002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
504
505 * tests/glr-regr1.at: New test for reported regressions.
506 * tests/testsuite.at: Add glr-regr1.at test.
507 * tests/Makefile.am: Add glr-regr1.at test.
508
5092002-10-24 Paul Eggert <eggert@twinsun.com>
510
511 Version 1.75a.
512
513 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
514 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
515 we use malloc. Don't assume 'A' through 'Z' are contiguous.
516 Don't assume strdup exists; POSIX says its an XSI extension.
517 Check for buffer overflow on input.
518
5192002-10-24 Akim Demaille <akim@epita.fr>
520
521 * src/output.c (output_skeleton): Don't disable M4sugar comments
522 too soon: it results in comments being expanded.
523 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
524 first output.
525
5262002-10-24 Akim Demaille <akim@epita.fr>
527
528 * data/yacc.c (m4_int_type): New.
529 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
530 char' as only yacc.c wants K&R portability.
531 * data/glr.c (yysigned_char): Remove.
532 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
533 Reported by Quoc Peyrot.
534
5352002-10-23 Paul Eggert <eggert@twinsun.com>
536
537 * src/main.c (main): With --trace=time, report times even if a
538 non-fatal error occurs. Formerly, the times were reported in some
539 such cases but not in others.
540 * src/reader.c (reader): Just return if a complaint has been issued,
541 instead of exiting, so that 'main' can report times.
542
5432002-10-22 Akim Demaille <akim@epita.fr>
544
545 * src/system.h: Include sys/types.
546 Reported by Bert Deknuydt.
547
5482002-10-23 Paul Eggert <eggert@twinsun.com>
549
550 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
551 Suggested by Art Haas.
552
5532002-10-22 Paul Eggert <eggert@twinsun.com>
554
555 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
556 decl; not needed any more.
557 * src/main.c (main): Use return to exit, undoing yesterday's change.
558 The last OS that we could find where this wouldn't work is
559 SunOS 3.5, and that's too old to worry about now.
560
561 * data/glr.c (struct yyltype): Define members even when not
562 doing locations. This is more consistent with yacc.c, and it
563 works around the following bug reports:
564 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
565 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
566 and I hope it also fixes this bug report:
567 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
568
569 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
570 @acronym consistently. Standardize on "Yacc" instead of "YACC",
571 "Algol" instead of "ALGOL". Give a bit more history about BNF.
572
5732002-10-22 Akim Demaille <akim@epita.fr>
574
575 * data/README: New.
576
5772002-10-21 Paul Eggert <eggert@twinsun.com>
578
579 Be consistent about 'bool'; the old code used an enum in one
580 module and an int in another, and this violates the C standard.
581 * m4/stdbool.m4: New file, from coreutils 4.5.3.
582 * configure.ac (AC_HEADER_STDBOOL): Add.
583 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
584 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
585 * src/symtab.c (hash_compare_symbol_t): Likewise.
586 * src/system.h (bool, false, true): Use a definition consistent
587 with ../lib/hash.c. All uses changed.
588
589 * src/complain.c (warning_issued): Renamed from warn_message_count,
590 so that we needn't worry about integer overflow (!).
591 Now of type bool. All uses changed.
592 (complaint_issued): Renamed from complain_message_count; likewise.
593
594 * src/main.c (main): Use exit to exit with failure.
595
596 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
597 rather than 1 and 0.
598 * src/main.c (main): Likewise.
599 * src/getargs.c (getargs): Likewise.
600 * src/reader.c (reader): Likewise.
601
602 * src/getarg.c (getargs): Remove duplicate code for
603 "Try `bison --help'".
604
605 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
606 What was that "2" for?
607
608 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
609 * src/getargs.c (usage): Likewise.
610
611 * src/getargs.c (getargs): When there are too few operands, report
612 the last one. When there are too many, report the first extra
613 one. This is how diffutils does it.
614
6152002-10-20 Paul Eggert <eggert@twinsun.com>
616
617 Remove K&R vestiges.
618 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
619 * src/complain.c (VA_START): Remove. Assume prototypes.
620 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
621 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
622 fatal): Assume prototypes.
623 * src/complain.h: Assume prototypes.
624 * src/system.h (PARAMS): Remove.
625 Include <limits.h> unconditionally, since it's guaranteeed even
626 for a freestanding C89 compiler.
627 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
628 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
629
6302002-10-20 Akim Demaille <akim@epita.fr>
631
632 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
633 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
634 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
635 (yyresolveStates, yyresolveAction, yyresolveStack)
636 (yyprocessOneStack): Use them.
637 (yy_reduce_print): New.
638 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
639
6402002-10-20 Akim Demaille <akim@epita.fr>
641
642 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
643 arguments and output `void'.
644 (b4_c_function): Rename as...
645 (b4_c_function_def): this.
646 (b4_c_function_decl, b4_c_ansi_function_def)
647 (b4_c_ansi_function_decl): New.
648 Change the interpretation of the arguments: before `int, foo', now
649 `int foo, foo'.
650 * data/yacc.c (yyparse): Prototype and define thanks to these.
651 Adjust b4_c_function_def uses.
652 * data/glr.c (yyparse): Likewise, but ANSI only.
653
6542002-10-20 Akim Demaille <akim@epita.fr>
655
656 * src/output.c (prepare): Move the definition of `tokens_number',
657 `nterms_number', `undef_token_number', `user_token_number_max'
658 to...
659 (prepare_tokens): Here.
660 (prepare_tokens): Rename as...
661 (prepare_symbols): this.
662 (prepare): Move the definition of `rules_number' to...
663 (prepare_rules): here.
664 (prepare): Move the definition of `last', `final_state_number',
665 `states_number' to...
666 (prepare_states): here.
667 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
668
6692002-10-20 Akim Demaille <akim@epita.fr>
670
671 * src/tables.h, src/tables.c, src/output.c: Comment changes.
672
6732002-10-20 Akim Demaille <akim@epita.fr>
674
675 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
676 * data/c.m4: here.
677
6782002-10-20 Akim Demaille <akim@epita.fr>
679
680 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
681 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
682 `pair'.
683 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
684 `name' to...
685 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
686 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
687 These.
688
6892002-10-19 Paul Eggert <eggert@twinsun.com>
690
691 Do not create a temporary file, as that involves security and
692 cleanup headaches. Instead, use a pair of pipes.
693 Derived from a suggestion by Florian Krohm.
694 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
695 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
696 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
697 (BISON_PREREQ_SUBPIPE): Add.
698 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
699 Add subpipe.h, subpipe.c.
700 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
701 * po/POTFILES.in: Add lib/subpipe.c.
702 * src/output.c: Include "subpipe.h".
703 (m4_invoke): Remove decl.
704 (scan_skel): New decl.
705 (output_skeleton): Use pipe rather than temporary file for m4 input.
706 Check that m4sugar.m4 is readable, to avoid deadlock.
707 Check for pipe I/O error.
708 * src/scan-skel.l (readpipe): Remove decl.
709 (scan_skel): New function, to be used in place of m4_invoke.
710 Read from stream rather than file.
711
712 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
713 float, as this generates a warning on Solaris 8 + GCC 3.2 with
714 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
715 this generates a more-accurate value anyway.
716
717 * lib/timevar.c (timervar_accumulate): Rename locals to
718 avoid confusion with similarly-named more-global.
719 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
720
721 * src/output.c (prepare): Use xstrdup to convert char const *
722 to char *, to avoid GCC warning.
723
7242002-10-19 Akim Demaille <akim@epita.fr>
725
726 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
727 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
728 Use them to have `calc.y' ready for %pure-parser.
729 * data/yacc.c (YYLEX): Pass a yylex return type to
730 b4_c_function_call.
731
7322002-10-19 Akim Demaille <akim@epita.fr>
733
734 Prototype support of %lex-param and %parse-param.
735
736 * src/parse-gram.y: Add the definition of the %lex-param and
737 %parse-param tokens, plus their rules.
738 Drop the `_' version of %glr-parser.
739 Add the "," token.
740 * src/scan-gram.l (INITIAL): Scan them.
741 * src/muscle_tab.c: Comment changes.
742 (muscle_insert, muscle_find): Rename `pair' as `probe'.
743 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
744 (muscle_entry_s): The `value' member is no longer const.
745 Adjust all dependencies.
746 * src/muscle_tab.c (muscle_init): Adjust: use
747 MUSCLE_INSERT_STRING.
748 Initialize the obstack earlier.
749 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
750 (muscle_pair_list_grow): New.
751 * data/c.m4 (b4_c_function_call, b4_c_args): New.
752 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
753 * tests/calc.at: Use %locations, not --locations.
754 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
755
7562002-10-19 Akim Demaille <akim@epita.fr>
757
758 * src/getargs.c (usage): Take status as argument and exit
759 accordingly.
760 Report the traditional `Try ... --help' message when status != 0.
761 (usage, version): Don't take a FILE * as arg, it is pointless.
762 (getargs): When there is an incorrect number of arguments, make it
763 an error, and report it GNUlically thanks to `usage ()'.
764
7652002-10-18 Paul Eggert <eggert@twinsun.com>
766
767 * data/glr.c (yyreportParseError): Don't assume that sprintf
768 yields the length of the printed string, as this is not true
769 on SunOS 4.1.4. Reported by Peter Klein.
770
771 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
772 * tests/conflicts.at (%nonassoc and eof): Likewise.
773 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
774
7752002-10-17 Akim Demaille <akim@epita.fr>
776
777 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
778 * src/getargs.c (trace_types, trace_args): Adjust.
779 * src/reader.c (grammar_current_rule_prec_set)
780 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
781 Standardize error messages.
782 And s/@prec/%prec/!
783 (reader): Use trace_flag to enable scanner/parser debugging,
784 instead of an adhoc scheme.
785 * src/scan-gram.l: Remove trailing debugging code.
786
7872002-10-16 Paul Eggert <eggert@twinsun.com>
788
789 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
790 MUSCLE_TAB_H.
791
792 * NEWS: Officially drop support for building Bison with K&R C,
793 since it didn't work anyway and it's not worth worrying about.
794 * Makefile.maint (wget_files): Remove ansi2knr.c.
795 (ansi2knr.c-url_prefix): Remove.
796 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
797 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
798 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
799
8002002-10-15 Paul Eggert <eggert@twinsun.com>
801
802 Stop using the "enum_" trick for K&R-style function definitions;
803 it confused me, and I was the author! Instead, assume that people
804 who want to use K&R C compilers (when using these modules in GCC,
805 perhaps?) will run ansi2knr.
806
807 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
808 All uses of "enum_" changed to "enum ".
809 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
810 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
811
812 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
813 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
814 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
815 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
816 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
817 abitset_not, abitset_ones, abitset_or, abitset_or_and,
818 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
819 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
820 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
821 Use function prototypes; this removes the need for declaring
822 static functions simply to provide their prototypes.
823 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
824 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
825 bitset_count_, bitset_create, bitset_dump, bitset_first,
826 bitset_free, bitset_init, bitset_last, bitset_next,
827 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
828 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
829 bitset_print, bitset_release_memory, bitset_toggle_,
830 bitset_type_choose, bitset_type_get, bitset_type_name_get,
831 debug_bitset): Likewise.
832 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
833 * lib/bitset_stats.c (bitset_log_histogram_print,
834 bitset_percent_histogram_print, bitset_stats_and,
835 bitset_stats_and_cmp, bitset_stats_and_or,
836 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
837 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
838 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
839 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
840 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
841 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
842 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
843 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
844 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
845 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
846 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
847 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
848 bitset_stats_zero): Likewise.
849 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
850 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
851 bitsetv_dump, debug_bitsetv): Likewise.
852 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
853 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
854 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
855 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
856 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
857 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
858 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
859 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
860 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
861 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
862 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
863 Likewise.
864 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
865 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
866 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
867 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
868 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
869 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
870 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
871 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
872 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
873 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
874 lbitset_xor_cmp, lbitset_zero): Likewise.
875
8762002-10-14 Akim Demaille <akim@epita.fr>
877
878 Version 1.75.
879
8802002-10-14 Akim Demaille <akim@epita.fr>
881
882 * tests/Makefile.am (maintainer-check-posix): New.
883
8842002-10-14 Akim Demaille <akim@epita.fr>
885
886 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
887 member.
888
8892002-10-14 Akim Demaille <akim@epita.fr>
890
891 * src/tables.c (table_ninf_remap): base -> tab.
892 Reported by Matt Rosing.
893
8942002-10-14 Paul Eggert <eggert@twinsun.com>
895
896 * tests/action.at, tests/calc.at, tests/conflicts.at,
897 tests/cxx-type.at, tests/headers.at, tests/input.at,
898 tests/regression.at, tests/synclines.at, tests/torture.at:
899 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
900 so that the tests still work even if POSIXLY_CORRECT is set.
901 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
902
903 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
904 for portability to K&R hosts. Fix typo: signed char is guaranteed
905 only to 127, not to 128.
906 * data/glr.c (yysigned_char): New type.
907 * data/yacc.c (yysigned_char): Likewise.
908 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
909
9102002-10-13 Paul Eggert <eggert@twinsun.com>
911
912 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
913 true due to limited range of data type" warning from GCC.
914
915 * data/c.m4 (b4_token_defines): Protect against double-inclusion
916 by wrapping enum yytokentype's definition inside #ifndef
917 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
918
9192002-10-13 Akim Demaille <akim@epita.fr>
920
921 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
922 Un yy- yyrhs to avoid the name clash with the global YYRHS.
923
9242002-10-13 Akim Demaille <akim@epita.fr>
925
926 * Makefile.maint: Update from Autoconf 2.54.
927 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
928
9292002-10-13 Akim Demaille <akim@epita.fr>
930
931 * src/print.c (print_state): Separate the list of solved conflicts
932 from the other items.
933 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
934
9352002-10-13 Akim Demaille <akim@epita.fr>
936
937 Let nondeterministic skeletons be usable with deterministic
938 tables.
939
940 With the patch, GAWK compiled by GCC without -O2 passes its test
941 suite using a GLR parser driven by LALR tables. It fails with -O2
942 because `struct stat' gives two different answers on my machine:
943 88 (definition of an auto var) and later 96 (memset on this var).
944 Hence the stack is badly corrumpted. The headers inclusion is to
945 blame: if I move the awk.h inclusion before GLR's system header
946 inclusion, the two struct stat have the same size.
947
948 * src/tables.c (pack_table): Always create conflict_table.
949 (token_actions): Always create conflict_list.
950 * data/glr.c (YYFLAG): Remove, unused.
951
9522002-10-13 Akim Demaille <akim@epita.fr>
953
954 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
955 (O0FLAGS): New.
956 (VALGRIND, GXX): New.
957 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
958 * tests/bison.in: Run $PREBISON a pre-command.
959 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
960 (maintainer-check-g++): New.
961 * Makefile.am (maintainer-check): New.
962
9632002-10-13 Akim Demaille <akim@epita.fr>
964
965 * data/glr.c: Formatting changes.
966 Tweak some trace messages to match yacc.c's.
967
9682002-10-13 Akim Demaille <akim@epita.fr>
969
970 GLR parsers sometimes raise parse errors instead of performing the
971 default reduction.
972 Reported by Charles-Henry de Boysson.
973
974 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
975 check the length of the traces when %glr.
976 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
977 GLR's traces.
978 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
979 Test GLR parsers.
980 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
981 (yyltype): Remove the yy prefix from the member names.
982 (yytable): Complete its comment.
983 (yygetLRActions): Map error action number from YYTABLE from
984 YYTABLE_NINF to 0.
985 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
986 (which was a bug: it should have been YYTABEL_NINF, and yet it was
987 not satisfying as we could compare an YYACTION computed from
988 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
989 only value for error actions.
990 (yyreportParseError): In verbose parse error messages, don't issue
991 `error' in the list of expected tokens.
992 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
993 next action to perform to match glr.c's decoding.
994 (yytable): Complete its comment.
995
9962002-10-13 Paul Eggert <eggert@twinsun.com>
997
998 Fix problem reported by Henrik Grubbstroem in
999 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1000 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1001 because the Bison parser reads the second action before reducing
1002 the first one.
1003 * src/scan-gram.l (rule_length): New static var.
1004 Use it to keep track of the rule length in the scanner, since
1005 we can't expect the parser to be in lock-step sync with the scanner.
1006 (handle_action_dollar, handle_action_at): Use this var.
1007 * tests/actions.at (Exotic Dollars): Test for the problem.
1008
10092002-10-12 Paul Eggert <eggert@twinsun.com>
1010
1011 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1012 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1013 Include <sys/time.h> when checking for clock_t and struct tms.
1014 Use same include order as source.
1015 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1016 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
1017
1018 * lib/timevar.c: Update copyright date and clarify comments.
1019 (get_time) [IN_GCC]: Keep the GCC version for reference.
1020
1021 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1022 GCC version as of today, then merge Bison's changes.
1023 Change "GCC" to "Bison" in copyright notice. timevar.def's
1024 author is Akim, so change that too.
1025
1026 * src/reader.c (grammar_current_rule_check):
1027 Don't worry about the default action if $$ is untyped.
1028 Prevents bogus warnings reported by Jim Gifford in
1029 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1030
1031 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1032 * data/glr.c, data/lalr1.cc, data/yacc.c:
1033 Output token definitions before the first part of user declarations.
1034 Fixes compatibility problem reported by Jim Gifford for kbd in
1035 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1036
10372002-10-11 Paul Eggert <eggert@twinsun.com>
1038
1039 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1040 (yyparse): here. This undoes some of the 2002-07-25 change.
1041 Compatibility problem reported by Ralf S. Engelschall with
1042 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1043
10442002-10-11 Akim Demaille <akim@epita.fr>
1045
1046 * tests/regression.at Characters Escapes): New.
1047 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1048 characters.
1049 Reported by Jan Nieuwenhuizen.
1050
10512002-10-11 Akim Demaille <akim@epita.fr>
1052
1053 * po/id.po: New.
1054
10552002-10-10 Paul Eggert <eggert@twinsun.com>
1056
1057 Portability fixes for bitsets; this also avoids several GCC
1058 warnings.
1059
1060 * lib/abitset.c: Include <stddef.h>, for offsetof.
1061 * lib/lbitset.c: Likewise.
1062
1063 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1064 properly for vectors of objects. Do not assume that adding a
1065 header size to a multiple of a word size yields a value that is
1066 properly aligned for the whole union.
1067 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1068
1069 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1070 unique names for structures.
1071 * lib/ebitset.c (ebitset_bytes): Likewise.
1072 * lib/lbitset.c (lbitset_bytes): Likewise.
1073
1074 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1075 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1076 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1077 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1078 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1079 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1080 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1081 to improve the type-checking that GCC can do.
1082 * lib/bitset.c (bitset_op4_cmp): Likewise.
1083 * lib/bitset_stats.c (bitset_stats_count,
1084 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1085 bitset_stats_copy, bitset_stats_disjoint_p,
1086 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1087 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1088 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1089 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1090 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1091 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1092 bitset_stats_or_and_cmp): Likewise.
1093 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1094 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1095 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1096 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1097
1098 * lib/abitset.h: Include bitset.h, not bbitset.h.
1099 * lib/ebitset.h: Likewise.
1100 * lib/lbitset.h: Likewise.
1101
1102 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1103 All instances of parameters of type enum bitset_opts are now of
1104 type enum_bitset_opts, to conform to the C Standard, and similarly
1105 for enum_bitset_type.
1106 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1107 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1108
1109 Do not use "struct bitset_struct" to mean different things in
1110 different modules. Not only is this confusing, it violates
1111 the C Standard, which requires that structure types in different
1112 modules must be compatible if one is to be passed to the other.
1113 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1114 All instances of "struct bitset_struct *" replaced with "bitset".
1115 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1116 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1117 struct lbitset_struct, struct bitset_stats_struct): New types.
1118 All uses of struct bitset_struct changed to union bitset_union,
1119 etc.
1120 * lib/abitset.c (struct abitset_struct, abitset,
1121 struct bitset_struct): Remove.
1122 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1123 struct bitset_struct): Remove.
1124 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1125 bitset_struct): Remove.
1126 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1127 Likewise.
1128
1129 Do not call a function of type T using a call that assumes the
1130 function is of a different type U. Standard C requires that a
1131 function must be called with a type that is compatible with its
1132 definition.
1133 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1134 New decls.
1135 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1136 New functions.
1137 * lib/ebitset.c (PFV): Remove.
1138 * lib/lbitset.c (PFV): Likewise.
1139 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
1140 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
1141 decls.
1142 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
1143 (ebitset_vtable): Use them.
1144 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
1145 lbitset_xor): New functions.
1146 (lbitset_vtable): Use them.
1147
1148 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
1149 Declare.
1150
1151 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
1152 GCC warning.
1153 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
1154 Use offsetof, for simplicity.
1155
11562002-10-06 Paul Eggert <eggert@twinsun.com>
1157
1158 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
1159 the same width as int. This reapplies a hunk of the 2002-08-12 patch
1160 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
1161 which was inadvertently undone by the 2002-09-30 patch.
1162 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
1163 the same width as int.
1164
11652002-10-04 Paul Eggert <eggert@twinsun.com>
1166
1167 Version 1.50.
1168
1169 * configure.ac (AC_INIT), NEWS: Increment version number.
1170
1171 * doc/bison.texinfo: Minor spelling, grammar, and white space
1172 fixes.
1173 (Symbols): Mention that any negative value returned from yylex
1174 signifies end-of-input. Warn about negative chars. Mention
1175 the portable Standard C character set.
1176
1177 The GNU coding standard says CFLAGS and YFLAGS are reserved
1178 for the installer to set.
1179 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
1180 * src/Makefile.am (AM_CFLAGS): Likewise.
1181 (AM_YFLAGS): Renamed from YFLAGS.
1182
1183 Fix some MAX and MIN problems.
1184 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
1185 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
1186 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
1187 * src/reader.c (reader): Use it.
1188
1189 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
1190 POSIX 1003.1-2001 has removed fgrep.
1191
11922002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
1193
1194 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
1195 interpreted as signed.
1196 * lib/ebitset.c (ebitset_list): Fix bug.
1197
11982002-10-01 Paul Eggert <eggert@twinsun.com>
1199
1200 More fixes for 64-bit hosts and large bitsets.
1201
1202 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
1203 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
1204 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
1205 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
1206 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
1207 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
1208 bitset_count_): Likewise.
1209 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
1210 bitset_first, bitset_last): Likewise.
1211 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
1212 bitset_stats_list_reverse, bitset_stats_size,
1213 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
1214 Likewise.
1215 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1216 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1217 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1218 bitsetv_reflexive_transitive_closure): Likewise.
1219 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
1220 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
1221 Likewise.
1222 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
1223 Likewise.
1224
1225 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
1226 Use size_t, not unsigned int, to count bytes.
1227 * lib/abitset.h (abitset_bytes): Likewise.
1228 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
1229 Likewise.
1230 * lib/bitset.h (bitset_bytes): Likewise.
1231 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
1232 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
1233 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1234 * lib/ebitset.c (ebitset_bytes): Likewise.
1235 * lib/ebitset.h (ebitset_bytes): Likewise.
1236 * lib/lbitset.c (lbitset_bytes): Likewise.
1237 * lib/lbitset.h (lbitset_bytes): Likewise.
1238
1239 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
1240 abitset_subset_p, abitset_disjoint_p, abitset_and,
1241 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
1242 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
1243 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
1244 abitset_or_and, abitset_or_and_cmp):
1245 Use bitset_windex instead of unsigned int.
1246 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1247 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
1248 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
1249 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
1250 Likewise.
1251 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
1252
1253 * lib/bitset.c (bitset_print):
1254 Use proper printf formats for widths of integer types.
1255 * lib/bitset_stats.c (bitset_percent_histogram_print,
1256 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
1257 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1258 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1259 * lib/lbitset.c (lbitset_bytes): Likewise.
1260
1261 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
1262 BITSET_SIZE_MAX): New macros.
1263 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
1264 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
1265 to BITSET_WINDEX_MAX.
1266
1267 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
1268 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
1269 since we now return the bitset_bindex type (not int).
1270
1271 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
1272 when computing sizes.
1273 * lib/ebitset.c (ebitset_elts_grow): Likewise.
1274
1275 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
1276 and avoid cast to unsigned.
1277
12782002-09-30 Akim Demaille <akim@epita.fr>
1279
1280 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
1281 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
1282 Updates from Michael Hayes.
1283
12842002-09-30 Art Haas <ahaas@neosoft.com>
1285
1286 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
1287 invocations.
1288 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
1289 defined.
1290
12912002-09-27 Akim Demaille <akim@epita.fr>
1292
1293 Version 1.49c.
1294
12952002-09-27 Akim Demaille <akim@epita.fr>
1296
1297 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
1298 (Because of AC_LIBSOURCE).
1299
13002002-09-27 Akim Demaille <akim@epita.fr>
1301
1302 Playing with Autoscan.
1303
1304 * configure.ac: Remove the old LIBOBJ tweaks.
1305 (AC_REPLACE_FUNCS): Add strrchr and strtol.
1306 * lib/strrchr.c: New.
1307 * lib/strtol.c: New, from the Coreutils 4.5.1.
1308
13092002-09-27 Akim Demaille <akim@epita.fr>
1310
1311 Playing with Autoscan.
1312
1313 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
1314 * lib/Makefile.am (libbison_a_SOURCES): No longer include
1315 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
1316 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
1317 Coreutils 4.5.1.
1318
13192002-09-24 Akim Demaille <akim@epita.fr>
1320
1321 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
1322 (Frequently Asked Questions, Parser Stack Overflow): New.
1323
13242002-09-13 Akim Demaille <akim@epita.fr>
1325
1326 Playing with autoscan.
1327
1328 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
1329 * src/files.c (skeleton_find): Remove, unused.
1330 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
1331 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
1332
13332002-09-13 Akim Demaille <akim@epita.fr>
1334
1335 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
1336 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
1337
13382002-09-13 Akim Demaille <akim@epita.fr>
1339
1340 * configure.ac: Require 2.54.
1341 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
1342 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
1343 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
1344 Remove, provided by Autoconf macros.
1345
13462002-09-12 Akim Demaille <akim@epita.fr>
1347
1348 * m4/prereq.m4: Update, from Coreutils 4.5.1.
1349
13502002-09-12 Akim Demaille <akim@epita.fr>
1351
1352 * m4/prereq.m4: Update, from Fileutils 4.1.5.
1353 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
1354 Reported by Martin Mokrejs.
1355
13562002-09-10 Akim Demaille <akim@epita.fr>
1357
1358 * src/parse-gram.y: Associate a human readable string to each
1359 token type.
1360 * tests/regression.at (Invalid inputs): Adjust.
1361
13622002-09-10 Gary V. Vaughan <gary@gnu.org>
1363
1364 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
1365 with an Autoconf-2.5x style configure.ac.
1366
13672002-09-06 Paul Eggert <eggert@twinsun.com>
1368
1369 * doc/bison.texinfo (Conditions): Make explicit that the GPL
1370 exception applies only to yacc.c. This is a modification of a
1371 patch originally suggested by Akim Demaille.
1372
13732002-09-06 Akim Demaille <akim@epita.fr>
1374
1375 * data/c.m4 (b4_copyright): Move the GPL exception comment from
1376 here to...
1377 * data/yacc.c: here.
1378
1379 * data/lalr1.cc (struct yyltype): Don't define it, since we use
1380 LocationType.
1381 (b4_ltype): Default to yy::Location from location.hh.
1382
13832002-09-04 Jim Meyering <jim@meyering.net>
1384
1385 * data/yacc.c: Guard the declaration of yytoknum also with
1386 `#ifdef YYPRINT', so it is declared only when used.
1387
13882002-09-04 Akim Demaille <akim@epita.fr>
1389
1390 * configure.in: Rename as...
1391 * configure.ac: this.
1392 Bump to 1.49c.
1393
13942002-09-04 Akim Demaille <akim@epita.fr>
1395
1396 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
1397 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
1398 translate maintainer only messages.
1399
14002002-08-12 Paul Eggert <eggert@twinsun.com>
1401
1402 Version 1.49b.
1403
1404 * Makefile.am (SUBDIRS): Remove intl.
1405 (DISTCLEANFILES): Remove.
1406 * NEWS: Mention that GNU M4 is now required. Clarify what is
1407 meant by "larger grammars". Mention the pt_BR translation.
1408 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
1409 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
1410 Bump version from 0.11.2 to 0.11.5.
1411 (BISON_PREREQ_STAGE): Remove.
1412 (AM_GNU_GETTEXT): Use external gettext.
1413 (AC_OUTPUT): Remove intl/Makefile.
1414
1415 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
1416
1417 * data/glr.c: Include string.h, for strlen.
1418 (yyreportParseError): Use size_t for yysize.
1419 (yy_yypstack): No longer nested inside yypstates, as nested
1420 functions are not portable. Do not assume size_t is the
1421 same width as int.
1422 (yypstates): Do not assume that ptrdiff_t is the same width
1423 as int, and similarly for yyposn and YYINDEX.
1424
1425 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
1426
1427 * lib/Makefile.am (INCLUDES): Do not include from the intl
1428 directory, which has been removed.
1429 * src/Makefile.am (INCLUDES): Likewise.
1430
1431 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
1432 (bitsets_sources, additional_bitsets_sources, timevars_sources):
1433 New vars.
1434
1435 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
1436 * tests/Makefile.am (EXTRA_DIST): Likewise.
1437
1438 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
1439 Do not assume that bitset_windex is the same width as unsigned.
1440
1441 * lib/abitset.c (abitset_unused_clear): Do not assume that
1442 bitset_word is the same width as int.
1443 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
1444 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
1445 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
1446 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
1447 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
1448
1449 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
1450 portability to one's complement hosts!).
1451 * lib/ebitset.c (ebitset_op1): Likewise.
1452 * lib/lbitset.c (lbitset_op1): Likewise.
1453
1454 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
1455 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
1456 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
1457 Sync with fileutils.
1458 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
1459 lib/gettext.h: Sync with diffutils.
1460
1461 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
1462 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
1463
1464 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
1465 PROTOTYPES to check for prototypes, and "defined __STDC__" to
1466 check for void *.
1467
1468 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
1469 size_t; the old version tried to do this but casted improperly.
1470 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
1471 (bitset_test): Now returns int, not unsigned long.
1472
1473 * lib/bitset_stats.c: Include "gettext.h".
1474 (_): New macro.
1475 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
1476 name locals "index", as it generates unnecessary warnings on some
1477 hosts that have an "index" function.
1478
1479 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
1480 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
1481 they need translation.
1482 * src/LR0.c (state_list_append, new_itemsets, get_state,
1483 append_states, generate_states): Likewise.
1484 * src/assoc.c (assoc_to_string): Likewise.
1485 * src/closure.c (print_closure, set_firsts, closure): Likewise.
1486 * src/gram.c (grammar_dump): Likewise.
1487 * src/injections.c (injections_compute): Likewise.
1488 * src/lalr.c (lookaheads_print): Likewise.
1489 * src/relation.c (relation_transpose): Likewise.
1490 * src/scan-gram.l: Likewise.
1491 * src/tables.c (table_grow, pack_vector): Likewise.
1492
1493 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
1494 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
1495 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
1496 * m4/mbstate_t.m4: Sync with fileutils.
1497 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
1498
1499 * po/LINGUAS: Add pt_BR.
1500 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
1501 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
1502 lib/timevar.c.
1503 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
1504 manual recommends.
1505 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
1506
1507 * src/complain.c (strerror_r): Remove decl; not needed.
1508 (strerror): Use same pattern as ../lib/error.c.
1509
1510 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
1511
1512 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
1513
1514 * src/main.c (main): Cast result of bindtextdomain and textdomain
1515 to void, to avoid a GCC warning when --disable-nls is in effect.
1516
1517 * src/scan-gram.l: Use strings rather than escapes when possible,
1518 to minimize the number of warnings from xgettext.
1519 (handle_action_dollar, handle_action_at): Don't use isdigit,
1520 as it mishandles negative chars and it may not work as expected
1521 outside the C locale.
1522
1523 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
1524 this is a GCC extension and is not portable to other compilers.
1525
1526 * src/system.h (alloca): Use same pattern as ../lib/error.c.
1527 Do not include <ctype.h>; no longer needed.
1528 Do not include <malloc.h>; no longer needed (and generates
1529 warnings on OpenBSD 3.0).
1530
1531 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
1532 it's not portable.
1533
1534 * tests/regression.at: Do not use 'cc -c input.c -o input';
1535 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1536
1537 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1538 exit status as failure, not just exit status 1. Sun C exits
1539 with status 2 sometimes.
1540
1541 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1542 Use it for the two large tests.
1543
15442002-08-02 Akim Demaille <akim@epita.fr>
1545
1546 * src/conflicts.c (conflicts_output): Don't output rules never
1547 reduced here, since anyway that computation doesn't work.
1548 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1549 (rule_useless_p, rule_never_reduced_p): New.
1550 (grammar_rules_partial_print): Use a filter instead of a range.
1551 Display the title only if needed.
1552 (grammar_rules_print): Adjust.
1553 (grammar_rules_never_reduced_report): New.
1554 * src/tables.c (action_row): Move the computation of rules never
1555 reduced to...
1556 (token_actions): here.
1557 * src/main.c (main): Make the parser before making the report, so
1558 that rules never reduced are computed.
1559 Call grammar_rules_never_reduced_report.
1560 * src/print.c (print_results): Report rules never reduced.
1561 * tests/conflicts.at, tests/reduce.at: Adjust.
1562
15632002-08-01 Akim Demaille <akim@epita.fr>
1564
1565 Instead of attaching lookaheads and duplicating the rules being
1566 reduced by a state, attach the lookaheads to the reductions.
1567
1568 * src/state.h (state_t): Remove the `lookaheads',
1569 `lookaheads_rule' member.
1570 (reductions_t): Add a `lookaheads' member.
1571 Use a regular array for the `rules'.
1572 * src/state.c (reductions_new): Initialize the lookaheads member
1573 to 0.
1574 (state_rule_lookaheads_print): Adjust.
1575 * src/state.h, src/state.c (state_reductions_find): New.
1576 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1577 (count_rr_conflicts): Adjust.
1578 * src/lalr.c (LArule): Remove.
1579 (add_lookback_edge): Adjust.
1580 (state_lookaheads_count): New.
1581 (states_lookaheads_initialize): Merge into...
1582 (initialize_LA): this.
1583 (lalr_free): Adjust.
1584 * src/main.c (main): Don't free nullable and derives too early: it
1585 is used by --verbose.
1586 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1587
15882002-08-01 Akim Demaille <akim@epita.fr>
1589
1590 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1591 `rule_number_t**'.
1592 (set_derives, free_derives): Rename as...
1593 (derives_compute, derives_free): this.
1594 Adjust all dependencies.
1595 * src/nullable.c (set_nullable, free_nullable): Rename as...
1596 (nullable_compute, nullable_free): these.
1597 (rule_list_t): Store rule_t *, not rule_number_t.
1598 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1599 pointers, instead of their numbers.
1600 * src/main.c (main): Call nullable_free, and derives_free earlier,
1601 as they were lo longer used.
1602
16032002-08-01 Akim Demaille <akim@epita.fr>
1604
1605 * lib/timevar.c (get_time): Include children time.
1606 * src/lalr.h (LA, LArule): Don't export them: used with the
1607 state_t.
1608 * src/lalr.c (LA, LArule): Static.
1609 * src/lalr.h, src/lalr.c (lalr_free): New.
1610 * src/main.c (main): Call it.
1611 * src/tables.c (pack_vector): Check whether loc is >= to the
1612 table_size, not >.
1613 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1614 (tables_generate): do it, since that's also it which allocates
1615 them.
1616 Don't free LA and LArule, main does.
1617
16182002-07-31 Akim Demaille <akim@epita.fr>
1619
1620 Separate parser tables computation and output.
1621
1622 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1623 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1624 (yydefgoto, yydefact, high): Move to...
1625 * src/tables.h, src/tables.c: here.
1626 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1627 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1628 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1629 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1630 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1631 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1632 (action_row, save_row, token_actions, save_column, default_goto)
1633 (goto_actions, sort_actions, matching_state, pack_vector)
1634 (table_ninf_remap, pack_table, prepare_actions): Move to...
1635 * src/tables.c: here.
1636 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1637 * src/output.c (token_actions, output_base, output_conflicts)
1638 (output_check): Merge into...
1639 (prepare_actions): this.
1640 (actions_output): Rename as...
1641 (user_actions_output): this.
1642 * src/main.c (main): Call tables_generate and tables_free.
1643
16442002-07-31 Akim Demaille <akim@epita.fr>
1645
1646 Steal GCC's --time-report support.
1647
1648 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1649 stolen/adjusted from GCC.
1650 * m4/stage.m4: Remove time related checks.
1651 * m4/timevar.m4: New.
1652 * configure.in: Adjust.
1653 * src/system.h: Adjust to using timevar.h.
1654 * src/getargs.h, src/getargs.c: Support trace_time for
1655 --trace=time.
1656 * src/main.c (stage): Remove.
1657 (main): Replace `stage' invocations with timevar calls.
1658 * src/output.c: Insert pertinent timevar calls.
1659
16602002-07-31 Akim Demaille <akim@epita.fr>
1661
1662 Let --trace have arguments.
1663
1664 * src/getargs.h (enum trace_e): New.
1665 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1666 (long_options, short_options): --trace/-T takes an optional
1667 argument.
1668 Change all the uses of trace_flag to reflect the new flags.
1669 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1670
1671 Strengthen `stage' portability.
1672
1673 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1674 * configure.in: Use it.
1675 Don't check for malloc.h and sys/times.h.
1676 * src/system.h: Include them when appropriate.
1677 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1678 times and struct tms are available.
1679
16802002-07-30 Akim Demaille <akim@epita.fr>
1681
1682 In verbose parse error message, don't report `error' as an
1683 expected token.
1684 * tests/actions.at (Printers and Destructors): Adjust.
1685 * tests/calc.at (Calculator $1): Adjust.
1686 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1687 error message, do not report the parser accepts the error token in
1688 that state.
1689
16902002-07-30 Akim Demaille <akim@epita.fr>
1691
1692 Normalize conflict related messages.
1693
1694 * src/complain.h, src/complain.c (warn, complain): New.
1695 * src/conflicts.c (conflicts_print): Use them.
1696 (conflict_report_yacc): New, extracted from...
1697 (conflicts_print): here.
1698 * tests/conflicts.at, tests/existing.at: Adjust.
1699
17002002-07-30 Akim Demaille <akim@epita.fr>
1701
1702 Report rules which are never reduced by the parser: those hidden
1703 by conflicts.
1704
1705 * src/LR0.c (save_reductions): Don't make the final state too
1706 different: save its reduction (accept) instead of having a state
1707 without any action (no shift or goto, no reduce).
1708 Note: the final state is now a ``regular'' state, i.e., the
1709 parsers now contain `reduce 0' as default reduction.
1710 Nevertheless, since they decide to `accept' when yystate =
1711 final_state, they still will not reduce rule 0.
1712 * src/print.c (print_actions, print_reduction): Adjust.
1713 * src/output.c (action_row): Track reduced rules.
1714 (token_actions): Report rules never reduced.
1715 * tests/conflicts.at, tests/regression.at: Adjust.
1716
17172002-07-30 Akim Demaille <akim@epita.fr>
1718
1719 `stage' was accidently included in a previous patch.
1720 Initiate its autoconfiscation.
1721
1722 * configure.in: Look for malloc.h and sys/times.h.
1723 * src/main.c (stage): Adjust.
1724 Report only when trace_flag.
1725
17262002-07-29 Akim Demaille <akim@epita.fr>
1727
1728 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1729 state_number_t.
1730 (errs_t): symbol_t*, not symbol_number_t.
1731 (reductions_t): rule_t*, not rule_number_t.
1732 (FOR_EACH_SHIFT): New.
1733 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1734 * src/print.c, src/print_graph.c: Adjust.
1735
17362002-07-29 Akim Demaille <akim@epita.fr>
1737
1738 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1739
1740 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1741 (endtoken, accept): these.
1742 * src/reader.c (reader): Set endtoken's default tag to "$end".
1743 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1744 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1745 Adjust.
1746
17472002-07-29 Akim Demaille <akim@epita.fr>
1748
1749 * src/reduce.c (reduce_grammar): When the language is empty,
1750 complain about the start symbol, not the axiom.
1751 Use its location.
1752 * tests/reduce.at (Empty Language): New.
1753
17542002-07-26 Akim Demaille <akim@epita.fr>
1755
1756 * src/reader.h, src/reader.c (gram_error): ... can't get
1757 yycontrol without making too strong assumptions on the parser
1758 itself.
1759 * src/output.c (prepare_tokens): Use the real 0th value of
1760 token_translations instead of `0'.
1761 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1762 visible here.
1763 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1764 for the time being: %locations ought to provide it to yyerror.
1765
17662002-07-25 Akim Demaille <akim@epita.fr>
1767
1768 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1769 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1770 * tests/regression.at (Web2c Actions): Adjust.
1771
17722002-07-25 Akim Demaille <akim@epita.fr>
1773
1774 Stop storing rules from 1 to nrules + 1.
1775
1776 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1777 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1778 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1779 Iterate from 0 to nrules.
1780 Use rule_number_as_item_number and item_number_as_rule_number.
1781 Adjust to `derive' now containing possibly 0.
1782 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1783 Handle the `- 1' part in rule numbers from/to item numbers.
1784 * src/conflicts.c (log_resolution): Fix the message which reversed
1785 shift and reduce.
1786 * src/output.c (action_row): Initialize default_rule to -1.
1787 (token_actions): Adjust.
1788 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1789 expected output.
1790 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1791
17922002-07-25 Akim Demaille <akim@epita.fr>
1793
1794 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1795 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1796 (b4_c_knr_arg_decl): New.
1797 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1798 yyreport_parse_error.
1799
18002002-07-25 Akim Demaille <akim@epita.fr>
1801
1802 * data/yacc.c (yyreport_parse_error): New, extracted from...
1803 (yyparse): here.
1804 (yydestruct, yysymprint): Move above yyparse.
1805 Be K&R compliant.
1806
18072002-07-25 Akim Demaille <akim@epita.fr>
1808
1809 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1810 replace...
1811 (b4_sint_type, b4_uint_type): these.
1812 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1813 * tests/regression.at (Web2c Actions): Adjust.
1814
18152002-07-25 Akim Demaille <akim@epita.fr>
1816
1817 * src/gram.h (TIEM_NUMBER_MAX): New.
1818 (item_number_of_rule_number, rule_number_of_item_number): Rename
1819 as...
1820 (rule_number_as_item_number, item_number_as_rule_number): these.
1821 Adjust dependencies.
1822 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1823 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1824 (symbol_number_to_vector_number): New.
1825 (order): Of vector_number_t* type.
1826 (base_t, BASE_MAX, BASE_MIN): New.
1827 (froms, tos, width, pos, check): Of base_t type.
1828 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1829 (actrow): Of action_number_t type.
1830 (conflrow): Of unsigned int type.
1831 (table_ninf, base_ninf): New.
1832 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1833 (muscle_insert_int_table, muscle_insert_base_table)
1834 (muscle_insert_rule_number_table): New.
1835 (prepare_tokens): Output `toknum' as int_table.
1836 (action_row): Returns a rule_number_t.
1837 Use ACTION_MIN, not SHRT_MIN.
1838 (token_actions): yydefact is rule_number_t*.
1839 (table_ninf_remap): New.
1840 (pack_table): Use it for `base' and `table'.
1841 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1842 replaced with...
1843 (YYPACT_NINF, YYTABLE_NINF): these.
1844 (yypact, yytable): Compute their types instead of hard-coded
1845 `short'.
1846 * tests/regression.at (Web2c Actions): Adjust.
1847
18482002-07-19 Akim Demaille <akim@epita.fr>
1849
1850 * src/scan-gram.l (id): Can start with an underscore.
1851
18522002-07-16 Akim Demaille <akim@epita.fr>
1853
1854 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
1855 Adjust all former `associativity' dependencies.
1856 * src/symtab.c (symbol_new): Default associativity is `undef', not
1857 `right'.
1858 (symbol_check_alias_consistence): Adjust.
1859
18602002-07-09 Akim Demaille <akim@epita.fr>
1861
1862 * doc/bison.texinfo: Properly set the ``header'' part.
1863 Use @dircategory ``GNU programming tools'' as per Texinfo's
1864 documentation.
1865 Use @copying.
1866
18672002-07-09 Akim Demaille <akim@epita.fr>
1868
1869 * lib/quotearg.h: Protect against multiple inclusions.
1870 * src/location.h (location_t): Add a `file' member.
1871 (LOCATION_RESET, LOCATION_PRINT): Adjust.
1872 * src/complain.c (warn_at, complain_at, fatal_at): Drop
1873 `error_one_per_line' support.
1874
18752002-07-09 Akim Demaille <akim@epita.fr>
1876
1877 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
1878 * src/reader.c (lineno): Remove.
1879 Adjust all dependencies.
1880 (get_merge_function): Take a location and use complain_at.
1881 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
1882 * tests/regression.at (Invalid inputs, Mixing %token styles):
1883 Adjust.
1884
18852002-07-09 Akim Demaille <akim@epita.fr>
1886
1887 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
1888 recovery rule, and forbid extensions when --yacc.
1889 (gram_error): Use complain_at.
1890 * src/reader.c (reader): Exit if there were parse errors.
1891
18922002-07-09 Akim Demaille <akim@epita.fr>
1893
1894 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
1895 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
1896 Reported by R Blake <blakers@mac.com>.
1897
18982002-07-09 Akim Demaille <akim@epita.fr>
1899
1900 * data/yacc.c: Output the copyright notive in the header.
1901
19022002-07-03 Akim Demaille <akim@epita.fr>
1903
1904 * src/output.c (froms, tos): Are state_number_t.
1905 (save_column): sp, sp1, and sp2 are state_number_t.
1906 (prepare): Rename `final' as `final_state_number', `nnts' as
1907 `nterms_number', `nrules' as `rules_number', `nstates' as
1908 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
1909 unused.
1910 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
1911 * data/lalr1.cc (nsym_): Remove, unused.
1912
19132002-07-03 Akim Demaille <akim@epita.fr>
1914
1915 * src/lalr.h, src/lalr.c (goto_number_t): New.
1916 * src/lalr.c (goto_list_t): New.
1917 Propagate them.
1918 * src/nullable.c (rule_list_t): New.
1919 Propagate.
1920 * src/types.h: Remove.
1921
19222002-07-03 Akim Demaille <akim@epita.fr>
1923
1924 * src/closure.c (print_fderives): Use rule_rhs_print.
1925 * src/derives.c (print_derives): Use rule_rhs_print.
1926 (rule_list_t): New, replaces `shorts'.
1927 (set_derives): Add comments.
1928 * tests/sets.at (Nullable, Firsts): Adjust.
1929
19302002-07-03 Akim Demaille <akim@epita.fr>
1931
1932 * src/output.c (prepare_actions): Free `tally' and `width'.
1933 (prepare_actions): Allocate and free `order'.
1934 * src/symtab.c (symbols_free): Free `symbols'.
1935 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
1936 * src/output.c (m4_invoke): Move to...
1937 * src/scan-skel.l: here.
1938 (<<EOF>>): Close yyout, and free its name.
1939
19402002-07-03 Akim Demaille <akim@epita.fr>
1941
1942 Fix some memory leaks, and fix a bug: state 0 was examined twice.
1943
1944 * src/LR0.c (new_state): Merge into...
1945 (state_list_append): this.
1946 (new_states): Merge into...
1947 (generate_states): here.
1948 (set_states): Don't ensure a proper `errs' state member here, do it...
1949 * src/conflicts.c (conflicts_solve): here.
1950 * src/state.h, src/state.c: Comment changes.
1951 (state_t): Rename member `shifts' as `transitions'.
1952 Adjust all dependencies.
1953 (errs_new): For consistency, also take the values as argument.
1954 (errs_dup): Remove.
1955 (state_errs_set): New.
1956 (state_reductions_set, state_transitions_set): Assert that no
1957 previous value was assigned.
1958 (state_free): New.
1959 (states_free): Use it.
1960 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
1961 temporary storage: use `errs' and `nerrs' as elsewhere.
1962 (set_conflicts): Allocate and free this `errs'.
1963
19642002-07-02 Akim Demaille <akim@epita.fr>
1965
1966 * lib/libiberty.h: New.
1967 * lib: Update the bitset implementation from upstream.
1968 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
1969 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
1970 * src/main.c: Adjust bitset stats calls.
1971
19722002-07-01 Paul Eggert <eggert@twinsun.com>
1973
1974 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
1975 char, so that negative chars don't collide with $.
1976
19772002-06-30 Akim Demaille <akim@epita.fr>
1978
1979 Have the GLR tests be `warning' checked, and fix the warnings.
1980
1981 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
1982 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
1983 (yyremoveDeletes): `yyi' and `yyj' are size_t.
1984 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
1985 (yyaddDeferredAction): static.
1986 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
1987 (yyreportParseError): yyprefix is const.
1988 yytokenp is used only when verbose.
1989 (yy__GNUC__): Replace with __GNUC__.
1990 (yypdumpstack): yyi is size_t.
1991 (yypreference): Un-yy local variables and arguments, to avoid
1992 clashes with `yyr1'. Anyway, we are not in the user name space.
1993 (yytname_size): be an int, as is compared with ints.
1994 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
1995 Use them.
1996 * tests/cxx-gram.at: Use quotation to protect $1.
1997 Use AT_COMPILE to enable warnings hunts.
1998 Prototype yylex and yyerror.
1999 `Use' argc.
2000 Include `string.h', not `strings.h'.
2001 Produce and prototype stmtMerge only when used.
2002 yylex takes a location.
2003
20042002-06-30 Akim Demaille <akim@epita.fr>
2005
2006 We spend a lot of time in quotearg, in particular when --verbose.
2007
2008 * src/symtab.c (symbol_get): Store a quoted version of the key.
2009 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2010 Adjust all callers.
2011
20122002-06-30 Akim Demaille <akim@epita.fr>
2013
2014 * src/state.h (reductions_t): Rename member `nreds' as num.
2015 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2016 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2017
20182002-06-30 Akim Demaille <akim@epita.fr>
2019
2020 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2021 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2022 (shifts_to): Rename as...
2023 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2024 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2025 (TRANSITION_IS_DISABLED, transitions_to): these.
2026
20272002-06-30 Akim Demaille <akim@epita.fr>
2028
2029 * src/print.c (print_shifts, print_gotos): Merge into...
2030 (print_transitions): this.
2031 (print_transitions, print_errs, print_reductions): Align the
2032 lookaheads columns.
2033 (print_core, print_transitions, print_errs, print_state,
2034 print_grammar): Output empty lines separator before, not after.
2035 (state_default_rule_compute): Rename as...
2036 (state_default_rule): this.
2037 * tests/conflicts.at (Defaulted Conflicted Reduction),
2038 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2039 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2040
20412002-06-30 Akim Demaille <akim@epita.fr>
2042
2043 Display items as we display rules.
2044
2045 * src/gram.h, src/gram.c (rule_lhs_print): New.
2046 * src/gram.c (grammar_rules_partial_print): Use it.
2047 * src/print.c (print_core): Likewise.
2048 * tests/conflicts.at (Defaulted Conflicted Reduction),
2049 (Unresolved SR Conflicts): Adjust.
2050 (Unresolved SR Conflicts): Adjust and rename as...
2051 (Resolved SR Conflicts): this, as was meant.
2052 * tests/regression.at (Web2c Report): Adjust.
2053
20542002-06-30 Akim Demaille <akim@epita.fr>
2055
2056 * src/print.c (state_default_rule_compute): New, extracted from...
2057 (print_reductions): here.
2058 Pessimize, but clarify the code.
2059 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2060
20612002-06-30 Akim Demaille <akim@epita.fr>
2062
2063 * src/output.c (action_row): Let default_rule be always a rule
2064 number.
2065
20662002-06-30 Akim Demaille <akim@epita.fr>
2067
2068 * src/closure.c (print_firsts, print_fderives, closure):
2069 Use BITSET_EXECUTE.
2070 * src/lalr.c (lookaheads_print): Likewise.
2071 * src/state.c (state_rule_lookaheads_print): Likewise.
2072 * src/print_graph.c (print_core): Likewise.
2073 * src/print.c (print_reductions): Likewise.
2074 * src/output.c (action_row): Likewise.
2075 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2076
20772002-06-30 Akim Demaille <akim@epita.fr>
2078
2079 * src/print_graph.c: Use report_flag.
2080
20812002-06-30 Akim Demaille <akim@epita.fr>
2082
2083 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2084 to...
2085 * src/relation.h, src/relation.c (traverse, relation_digraph)
2086 (relation_print, relation_transpose): New.
2087
20882002-06-30 Akim Demaille <akim@epita.fr>
2089
2090 * src/state.h, src/state.c (shifts_to): New.
2091 * src/lalr.c (build_relations): Use it.
2092
20932002-06-30 Akim Demaille <akim@epita.fr>
2094
2095 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2096 (item_number_of_rule_number, rule_number_of_item_number): New.
2097 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2098 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2099 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2100 Propagate their use.
2101 Much remains to be done, in particular wrt `shorts' from types.h.
2102
21032002-06-30 Akim Demaille <akim@epita.fr>
2104
2105 * src/symtab.c (symbol_new): Initialize the `printer' member.
2106
21072002-06-30 Akim Demaille <akim@epita.fr>
2108
2109 * src/LR0.c (save_reductions): Remove, replaced by...
2110 * src/state.h, src/state.c (state_reductions_set): New.
2111 (reductions, errs): Rename as...
2112 (reductions_t, errs_t): these.
2113 Adjust all dependencies.
2114
21152002-06-30 Akim Demaille <akim@epita.fr>
2116
2117 * src/LR0.c (state_list_t, state_list_append): New.
2118 (first_state, last_state): Now symbol_list_t.
2119 (this_state): Remove.
2120 (new_itemsets, append_states, save_reductions): Take a state_t as
2121 argument.
2122 (set_states, generate_states): Adjust.
2123 (save_shifts): Remove, replaced by...
2124 * src/state.h, src/state.c (state_shifts_set): New.
2125 (shifts): Rename as...
2126 (shifts_t): this.
2127 Adjust all dependencies.
2128 * src/state.h (state_t): Remove the `next' member.
2129
21302002-06-30 Akim Demaille <akim@epita.fr>
2131
2132 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2133 escaped in slot 0.
2134
21352002-06-30 Akim Demaille <akim@epita.fr>
2136
2137 Use hash.h for the state hash table.
2138
2139 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
2140 (allocate_storage): Use state_hash_new.
2141 (free_storage): Use state_hash_free.
2142 (new_state, get_state): Adjust.
2143 * src/lalr.h, src/lalr.c (states): Move to...
2144 * src/states.h (state_t): Remove the `link' member, no longer
2145 used.
2146 * src/states.h, src/states.c: here.
2147 (state_hash_new, state_hash_free, state_hash_lookup)
2148 (state_hash_insert, states_free): New.
2149 * src/states.c (state_table, state_compare, state_hash): New.
2150 * src/output.c (output_actions): Do not free states now, since we
2151 still need to know the final_state number in `prepare', called
2152 afterwards. Do it...
2153 * src/main.c (main): here: call states_free after `output'.
2154
21552002-06-30 Akim Demaille <akim@epita.fr>
2156
2157 * src/state.h, src/state.c (state_new): New, extracted from...
2158 * src/LR0.c (new_state): here.
2159 * src/state.h (STATE_ALLOC): Move to...
2160 * src/state.c: here.
2161 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
2162 * src/state.h, src/state.c: here.
2163
21642002-06-30 Akim Demaille <akim@epita.fr>
2165
2166 * src/reader.c (gensym): Rename as...
2167 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
2168 (getsym): Rename as...
2169 (symbol_get): this.
2170
21712002-06-30 Akim Demaille <akim@epita.fr>
2172
2173 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
2174 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
2175 * src/output.c, src/print.c, src/print_graph.c: Propagate.
2176 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
2177
21782002-06-30 Akim Demaille <akim@epita.fr>
2179
2180 Make the test suite pass with warnings checked.
2181
2182 * tests/actions.at (Printers and Destructors): Improve.
2183 Avoid unsigned vs. signed issues.
2184 * tests/calc.at: Don't exercise the scanner here, do it...
2185 * tests/input.at (Torturing the Scanner): here.
2186
21872002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2188
2189 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
2190 reorganize first lines parallel to yacc.c.
2191
21922002-06-28 Akim Demaille <akim@epita.fr>
2193
2194 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
2195 (b4_token_enum, b4_token_defines): New, factored from...
2196 * data/lalr1.cc, data/yacc.c, glr.c: here.
2197
21982002-06-28 Akim Demaille <akim@epita.fr>
2199
2200 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
2201 unused variables.
2202 * src/output.c (merger_output): static.
2203
22042002-06-28 Akim Demaille <akim@epita.fr>
2205
2206 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
2207 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
2208 pacify GCC.
2209 * src/output.c (save_row): Initialize all the variables to pacify GCC.
2210
22112002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2212
2213 Accumulated changelog for new GLR parsing features.
2214
2215 * src/conflicts.c (count_total_conflicts): Change name to
2216 conflicts_total_count.
2217 * src/conflicts.h: Ditto.
2218 * src/output.c (token_actions): Use the new name.
2219 (output_conflicts): Change conflp => conflict_list_heads, and
2220 confl => conflict_list for better readability.
2221 * data/glr.c: Use the new names.
2222 * NEWS: Add self to GLR announcement.
2223
2224 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
2225
2226 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
2227 Akim Demaille.
2228
2229 * data/bison.glr: Change name to glr.c
2230 * data/glr.c: Renamed from bison.glr.
2231 * data/Makefile.am: Add glr.c
2232
2233 * src/getargs.c:
2234
2235 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
2236 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
2237
2238 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2239
2240 * data/bison.glr: Be sure to restore the
2241 current #line when returning to the skeleton contents after having
2242 exposed the input file's #line.
2243
2244 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2245
2246 * data/bison.glr: Bring up to date with changes to bison.simple.
2247
2248 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2249
2250 * data/bison.glr: Correct definitions that use b4_prefix.
2251 Various reformatting.
2252 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
2253 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
2254 yytokenp argument; now part of stack.
2255 (yychar): Define to behave as documented.
2256 (yyclearin): Ditto.
2257
2258 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2259
2260 * src/reader.h: Add declaration for free_merger_functions.
2261
2262 * src/reader.c (merge_functions): New variable.
2263 (get_merge_function): New function.
2264 (free_merger_functions): New function.
2265 (readgram): Check for %prec that is not followed by a symbol.
2266 Handle %dprec and %merge declarations.
2267 (packgram): Initialize dprec and merger fields in rules array.
2268
2269 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
2270 conflict_list_cnt, conflict_list_free): New variables.
2271 (table_grow): Also grow conflict_table.
2272 (prepare_rules): Output dprec and merger tables.
2273 (conflict_row): New function.
2274 (action_row): Output conflict lists for GLR parser. Don't use
2275 default reduction in conflicted states for GLR parser so that there
2276 are spaces for the conflict lists.
2277 (save_row): Also save conflict information.
2278 (token_actions): Allocate conflict list.
2279 (merger_output): New function.
2280 (pack_vector): Pack conflict table, too.
2281 (output_conflicts): New function to output yyconflp and yyconfl.
2282 (output_check): Allocate conflict_tos.
2283 (output_actions): Output conflict tables, also.
2284 (output_skeleton): Output b4_mergers definition.
2285 (prepare): Output b4_max_rhs_length definition.
2286 Use 'bison.glr' as default skeleton for GLR parsers.
2287
2288 * src/gram.c (glr_parser): New flag.
2289 (grammar_free): Call free_merger_functions.
2290
2291 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
2292 all pairs of conflicting reductions, rather than just all tokens
2293 causing conflicts. Needed to size conflict tables.
2294 (conflicts_output): Modify call to count_rr_conflicts for new
2295 interface.
2296 (conflicts_print): Ditto.
2297 (count_total_conflicts): New function.
2298
2299 * src/reader.h (merger_list): New type.
2300 (merge_functions): New variable.
2301
2302 * src/lex.h (tok_dprec, tok_merge): New token types.
2303
2304 * src/gram.h (rule_s): Add dprec and merger fields.
2305 (glr_parser): New flag.
2306
2307 * src/conflicts.h (count_total_conflicts): New function.
2308
2309 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
2310
2311 * doc/bison.texinfo (Generalized LR Parsing): New section.
2312 (GLR Parsers): New section.
2313 (Language and Grammar): Mention GLR parsing.
2314 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
2315 Correct typo ("tge" -> "the").
2316
2317 * data/bison.glr: New skeleton for GLR parsing.
2318
2319 * tests/cxx-gram.at: New tests for GLR parsing.
2320
2321 * tests/testsuite.at: Include cxx-gram.at.
2322
2323 * tests/Makefile.am: Add cxx-gram.at.
2324
2325 * src/parse-gram.y:
2326
2327 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
2328
2329 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
2330
23312002-06-27 Akim Demaille <akim@epita.fr>
2332
2333 * src/options.h, src/options.c: Remove.
2334 * src/getargs.c (short_options, long_options): New.
2335
23362002-06-27 Akim Demaille <akim@epita.fr>
2337
2338 * data/bison.simple, data/bison.c++: Rename as...
2339 * data/yacc.c, data/lalr1.cc: these.
2340 * doc/bison.texinfo (Environment Variables): Remove.
2341
23422002-06-25 Raja R Harinath <harinath@cs.umn.edu>
2343
2344 * src/getargs.c (report_argmatch): Initialize strtok().
2345
23462002-06-20 Akim Demaille <akim@epita.fr>
2347
2348 * data/bison.simple (b4_symbol_actions): New, replaces...
2349 (b4_symbol_destructor, b4_symbol_printer): these.
2350 (yysymprint): Be sure to call YYPRINT only for tokens, and using
2351 user token numbers.
2352
23532002-06-20 Akim Demaille <akim@epita.fr>
2354
2355 * data/bison.simple (yydestructor): Rename as...
2356 (yydestruct): this.
2357
23582002-06-20 Akim Demaille <akim@epita.fr>
2359
2360 * src/symtab.h, src/symtab.c (symbol_type_set)
2361 (symbol_destructor_set, symbol_precedence_set): The location is
2362 the last argument.
2363 Adjust all callers.
2364
23652002-06-20 Akim Demaille <akim@epita.fr>
2366
2367 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
2368 internals.
2369 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
2370 Takes a location.
2371 * src/symtab.h, src/symtab.c (symbol_class_set)
2372 (symbol_user_token_number_set): Likewise.
2373 Adjust all callers.
2374 Promote complain_at.
2375 * tests/input.at (Type Clashes): Adjust.
2376
23772002-06-20 Akim Demaille <akim@epita.fr>
2378
2379 * data/bison.simple (YYLEX): Fix the declaration when
2380 %pure-parser.
2381
23822002-06-20 Akim Demaille <akim@epita.fr>
2383
2384 * data/bison.simple (yysymprint): Don't print the token number,
2385 just its name.
2386 * tests/actions.at (Destructors): Rename as...
2387 (Printers and Destructors): this.
2388 Also exercise %printer.
2389
23902002-06-20 Akim Demaille <akim@epita.fr>
2391
2392 * data/bison.simple (YYDSYMPRINT): New.
2393 Use it to remove many of the #if YYDEBUG/if (yydebug).
2394
23952002-06-20 Akim Demaille <akim@epita.fr>
2396
2397 * src/symtab.h, src/symtab.c (symbol_t): printer and
2398 printer_location are new members.
2399 (symbol_printer_set): New.
2400 * src/parse-gram.y (PERCENT_PRINTER): New token.
2401 Handle its associated rule.
2402 * src/scan-gram.l: Adjust.
2403 (handle_destructor_at, handle_destructor_dollar): Rename as...
2404 (handle_symbol_code_at, handle_symbol_code_dollar): these.
2405 * src/output.c (symbol_printers_output): New.
2406 (output_skeleton): Call it.
2407 * data/bison.simple (yysymprint): New. Cannot be named yyprint
2408 since there are already many grammar files with a user `yyprint'.
2409 Replace the calls to YYPRINT to calls to yysymprint.
2410 * tests/calc.at: Adjust.
2411 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
2412 taking advantage of parser very internal details (stack size!).
2413
24142002-06-20 Akim Demaille <akim@epita.fr>
2415
2416 * src/scan-gram.l: Complete the scanner with the missing patterns
2417 to pacify Flex.
2418 Use `quote' and `symbol_tag_get' where appropriate.
2419
24202002-06-19 Akim Demaille <akim@epita.fr>
2421
2422 * tests/actions.at (Destructors): Augment to test locations.
2423 * data/bison.simple (yydestructor): Pass it the current location
2424 if locations are enabled.
2425 Prototype only when __STDC__ or C++.
2426 Change the argument names to move into the yy name space: there is
2427 user code here.
2428
24292002-06-19 Akim Demaille <akim@epita.fr>
2430
2431 * data/bison.simple (b4_pure_if): New.
2432 Use it instead of #ifdef YYPURE.
2433
24342002-06-19 Akim Demaille <akim@epita.fr>
2435
2436 * data/bison.simple (b4_location_if): New.
2437 Use it instead of #ifdef YYLSP_NEEDED.
2438
24392002-06-19 Akim Demaille <akim@epita.fr>
2440
2441 Prepare @$ in %destructor, but currently don't bind it in the
2442 skeleton, as %location use is not cleaned up yet.
2443
2444 * src/scan-gram.l (handle_dollar, handle_destructor_at)
2445 (handle_action_at): New.
2446 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
2447 a braced_code_t and a location as additional arguments.
2448 (handle_destructor_dollar): Instead of requiring `b4_eval', just
2449 unquote one when outputting `b4_dollar_dollar'.
2450 Adjust callers.
2451 * data/bison.simple (b4_eval): Remove.
2452 (b4_symbol_destructor): Adjust.
2453 * tests/input.at (Invalid @n): Adjust.
2454
24552002-06-19 Zack Weinberg <zack@codesourcery.com>
2456
2457 * doc/bison.texinfo: Document ability to have multiple
2458 prologue sections.
2459
24602002-06-18 Akim Demaille <akim@epita.fr>
2461
2462 * src/files.c (compute_base_names): When computing the output file
2463 names from the input file name, strip the directory part.
2464
24652002-06-18 Akim Demaille <akim@epita.fr>
2466
2467 * data/bison.simple.new: Comment changes.
2468 Reported by Andreas Schwab.
2469
24702002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
2471
2472 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
2473 there are no `label `yyoverflowlab' defined but not used' warnings
2474 when yyoverflow is defined.
2475
24762002-06-18 Akim Demaille <akim@epita.fr>
2477
2478 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
2479 new member.
2480 (symbol_destructor_set): Adjust.
2481 * src/output.c (symbol_destructors_output): Output the destructor
2482 locations.
2483 Output the symbol name.
2484 * data/bison.simple (b4_symbol_destructor): Adjust.
2485
24862002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
2487 and Akim Demaille <akim@epita.fr>
2488
2489 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
2490 what's left on the stack when the error recovery hits EOF.
2491 * tests/actions.at (Destructors): Complete to exercise this case.
2492
24932002-06-17 Akim Demaille <akim@epita.fr>
2494
2495 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
2496 arguments is really empty, not only equal to `[]'.
2497 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
2498 member.
2499 (symbol_destructor_set): New.
2500 * src/output.c (symbol_destructors_output): New.
2501 * src/reader.h (brace_code_t, current_braced_code): New.
2502 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
2503 (handle_dollar): Rename as...
2504 (handle_action_dollar): this.
2505 (handle_destructor_dollar): New.
2506 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
2507 (grammar_declaration): Use it.
2508 * data/bison.simple (yystos): Is always defined.
2509 (yydestructor): New.
2510 * tests/actions.at (Destructors): New.
2511 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
2512
25132002-06-17 Akim Demaille <akim@epita.fr>
2514
2515 * src/symlist.h, src/symlist.c (symbol_list_length): New.
2516 * src/scan-gram.l (handle_dollar, handle_at): Compute the
2517 rule_length only when needed.
2518 * src/output.c (actions_output, token_definitions_output): Output
2519 the full M4 block.
2520 * src/symtab.c: Don't access directly to the symbol tag, use
2521 symbol_tag_get.
2522 * src/parse-gram.y: Use symbol_list_free.
2523
25242002-06-17 Akim Demaille <akim@epita.fr>
2525
2526 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
2527 (symbol_list_prepend, get_type_name): Move to...
2528 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
2529 (symbol_list_prepend, symbol_list_n_type_name_get): here.
2530 Adjust all callers.
2531 (symbol_list_free): New.
2532 * src/scan-gram.l (handle_dollar): Takes a location.
2533 * tests/input.at (Invalid $n): Adjust.
2534
25352002-06-17 Akim Demaille <akim@epita.fr>
2536
2537 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2538 (symbol_list_prepend): New.
2539 * src/parse-gram.y (%union): `list' is a new member.
2540 (symbols.1): New, replaces...
2541 (terms_to_prec.1, nterms_to_type.1): these.
2542 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2543 Take a location as additional argument.
2544 Adjust all callers.
2545
25462002-06-15 Akim Demaille <akim@epita.fr>
2547
2548 * src/parse-gram.y: Move %token in the declaration section so that
2549 we don't depend upon CVS Bison.
2550
25512002-06-15 Akim Demaille <akim@epita.fr>
2552
2553 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2554 * src/print.c (print_core): Use it.
2555
25562002-06-15 Akim Demaille <akim@epita.fr>
2557
2558 * src/conflicts.c (log_resolution): Accept the rule involved in
2559 the sr conflicts instead of the lookahead number that points to
2560 that rule.
2561 (flush_reduce): Accept the current lookahead vector as argument,
2562 instead of the index in LA.
2563 (resolve_sr_conflict): Accept the current number of lookahead
2564 bitset to consider for the STATE, instead of the index in LA.
2565 (set_conflicts): Adjust.
2566 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2567
25682002-06-15 Akim Demaille <akim@epita.fr>
2569
2570 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2571 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2572 Adjust all dependencies.
2573 * src/lalr.c (initialize_lookaheads): Split into...
2574 (states_lookaheads_count, states_lookaheads_initialize): these.
2575 (lalr): Adjust.
2576
25772002-06-15 Akim Demaille <akim@epita.fr>
2578
2579 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2580 out of...
2581 (grammar_rules_print): here.
2582 * src/reduce.c (reduce_output): Use it.
2583 * tests/reduce.at (Useless Rules, Reduced Automaton)
2584 (Underivable Rules): Adjust.
2585
25862002-06-15 Akim Demaille <akim@epita.fr>
2587
2588 Copy BYacc's nice way to report the grammar.
2589
2590 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2591 New.
2592 Don't print the rules' location, it is confusing and useless.
2593 (rule_print): Use grammar_rhs_print.
2594 * src/print.c (print_grammar): Use grammar_rules_print.
2595
25962002-06-15 Akim Demaille <akim@epita.fr>
2597
2598 Complete and rationalize `useless thing' warnings.
2599
2600 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2601 (symbol_tag_print): New.
2602 Use them everywhere in place of accessing directly the tag member.
2603 * src/gram.h, src/gram.c (rule_print): New.
2604 Use it where a rule used to be printed `by hand'.
2605 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2606 (reduce_grammar_tables): Report the useless rules.
2607 (reduce_print): Useless things are a warning, not an error.
2608 Report it as such.
2609 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2610 (Reduced Automaton, Underivable Rules): Adjust.
2611 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2612 * tests/conflicts.at (Unresolved SR Conflicts)
2613 (Solved SR Conflicts): Adjust.
2614
26152002-06-15 Akim Demaille <akim@epita.fr>
2616
2617 Let symbols have a location.
2618
2619 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2620 (getsym): Adjust.
2621 Adjust all callers.
2622 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2623 Use location_t, not int.
2624 * src/symtab.c (symbol_check_defined): Take advantage of the
2625 location.
2626 * tests/regression.at (Invalid inputs): Adjust.
2627
26282002-06-15 Akim Demaille <akim@epita.fr>
2629
2630 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2631 (input): Don't try to initialize yylloc here, do it in the
2632 scanner.
2633 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2634 * src/gram.h (rule_t): Change line and action_line into location
2635 and action_location, of location_t type.
2636 Adjust all dependencies.
2637 * src/location.h, src/location.c (empty_location): New.
2638 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2639 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2640 (grammar_current_rule_symbol_append)
2641 (grammar_current_rule_action_append): Expect a location as argument.
2642 * src/reader.c (grammar_midrule_action): Adjust to attach an
2643 action's location as dummy symbol location.
2644 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2645 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2646 the line numbers.
2647
26482002-06-14 Akim Demaille <akim@epita.fr>
2649
2650 Grammar declarations may be found in the grammar section.
2651
2652 * src/parse-gram.y (rules_or_grammar_declaration): New.
2653 (declarations): Each declaration may end with a semicolon, not
2654 just...
2655 (grammar_declaration): `"%union"'.
2656 (grammar): Branch to rules_or_grammar_declaration.
2657
26582002-06-14 Akim Demaille <akim@epita.fr>
2659
2660 * src/main.c (main): Invoke scanner_free.
2661
26622002-06-14 Akim Demaille <akim@epita.fr>
2663
2664 * src/output.c (m4_invoke): Extracted from...
2665 (output_skeleton): here.
2666 Free tempfile.
2667
26682002-06-14 Akim Demaille <akim@epita.fr>
2669
2670 * src/parse-gram.y (directives, directive, gram)
2671 (grammar_directives, precedence_directives, precedence_directive):
2672 Rename as...
2673 (declarations, declaration, grammar, grammar_declaration)
2674 (precedence_declaration, precedence_declarator): these.
2675 (symbol_declaration): New.
2676
26772002-06-14 Akim Demaille <akim@epita.fr>
2678
2679 * src/files.c (action_obstack): Remove, unused.
2680 (output_obstack): Remove it, and all its dependencies, as it is no
2681 longer needed.
2682 * src/reader.c (epilogue_set): Build the epilogue in the
2683 muscle_obstack.
2684 * src/output.h, src/output.c (muscle_obstack): Move to...
2685 * src/muscle_tab.h, src/muscle_tab.h: here.
2686 (muscle_init): Initialize muscle_obstack.
2687 (muscle_free): New.
2688 * src/main.c (main): Call it.
2689
26902002-06-14 Akim Demaille <akim@epita.fr>
2691
2692 * src/location.h: New, extracted from...
2693 * src/reader.h: here.
2694 * src/Makefile.am (noinst_HEADERS): Merge into
2695 (bison_SOURCES): this.
2696 Add location.h.
2697 * src/parse-gram.y: Use location_t instead of Bison's.
2698 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2699 Use location_t instead of ints.
2700
27012002-06-14 Akim Demaille <akim@epita.fr>
2702
2703 * data/bison.simple, data/bison.c++: Be sure to restore the
2704 current #line when returning to the skeleton contents after having
2705 exposed the input file's #line.
2706
27072002-06-12 Akim Demaille <akim@epita.fr>
2708
2709 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2710 eager.
2711 * tests/actions.at (Exotic Dollars): New.
2712
27132002-06-12 Akim Demaille <akim@epita.fr>
2714
2715 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2716 ['"/] too eagerly.
2717 * tests/input.at (Torturing the Scanner): New.
2718
27192002-06-11 Akim Demaille <akim@epita.fr>
2720
2721 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2722 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2723 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2724 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2725 * src/reader.c (reader): Use it.
2726
27272002-06-11 Akim Demaille <akim@epita.fr>
2728
2729 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2730 Adjust all callers.
2731 (scanner_last_string_free): New.
2732
27332002-06-11 Akim Demaille <akim@epita.fr>
2734
2735 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2736 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2737 (last_string, YY_OBS_FREE): New.
2738 Use them when returning an ID.
2739
27402002-06-11 Akim Demaille <akim@epita.fr>
2741
2742 Have Bison grammars parsed by a Bison grammar.
2743
2744 * src/reader.c, src/reader.h (prologue_augment): New.
2745 * src/reader.c (copy_definition): Remove.
2746
2747 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2748 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2749 (grammar_current_rule_prec_set, grammar_current_rule_check)
2750 (grammar_current_rule_symbol_append)
2751 (grammar_current_rule_action_append): Export.
2752 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2753 (symbol_list_action_append): Remove.
2754 Hook the routines from reader.
2755 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2756 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2757
2758 * src/reader.c (read_declarations): Remove, unused.
2759
2760 * src/parse-gram.y: Handle the epilogue.
2761 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2762 (grammar_start_symbol_set): this.
2763 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2764 * src/reader.c (readgram): Remove, unused.
2765 (reader): Adjust to insert eoftoken and axiom where appropriate.
2766
2767 * src/reader.c (copy_dollar): Replace with...
2768 * src/scan-gram.h (handle_dollar): this.
2769 * src/parse-gram.y: Remove `%thong'.
2770
2771 * src/reader.c (copy_at): Replace with...
2772 * src/scan-gram.h (handle_at): this.
2773
2774 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2775 New.
2776
2777 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2778 time being.
2779
2780 * src/reader.h, src/reader.c (grammar_rule_end): New.
2781
2782 * src/parse.y (current_type, current_class): New.
2783 Implement `%nterm', `%token' support.
2784 Merge `%term' into `%token'.
2785 (string_as_id): New.
2786 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2787 type name.
2788
2789 * src/parse-gram.y: Be sure to handle properly the beginning of
2790 rules.
2791
2792 * src/parse-gram.y: Handle %type.
2793 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2794
2795 * src/parse-gram.y: More directives support.
2796 * src/options.c: No longer handle source directives.
2797
2798 * src/parse-gram.y: Fix %output.
2799
2800 * src/parse-gram.y: Handle %union.
2801 Use the prologue locations.
2802 * src/reader.c (parse_union_decl): Remove.
2803
2804 * src/reader.h, src/reader.c (epilogue_set): New.
2805 * src/parse-gram.y: Use it.
2806
2807 * data/bison.simple, data/bison.c++: b4_stype is now either not
2808 defined, then default to int, or to the contents of %union,
2809 without `union' itself.
2810 Adjust.
2811 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2812
2813 * src/output.c (actions_output): Don't output braces, as they are
2814 already handled by the scanner.
2815
2816 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2817 characters to themselves.
2818
2819 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2820 that the epilogue has a proper #line.
2821
2822 * src/parse-gram.y: Handle precedence/associativity.
2823
2824 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2825 a terminal.
2826 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2827 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2828 at all to define terminals that cannot be emitted.
2829
2830 * src/scan-gram.l: Escape M4 characters.
2831
2832 * src/scan-gram.l: Working properly with escapes in user
2833 strings/characters.
2834
2835 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2836 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2837 grammar.
2838 Use more modest sizes, as for the time being the parser does not
2839 release memory, and therefore the process swallows a huge amount
2840 of memory.
2841
2842 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2843 stricter %token grammar.
2844
2845 * src/symtab.h (associativity): Add `undef_assoc'.
2846 (symbol_precedence_set): Do nothing when passed an undef_assoc.
2847 * src/symtab.c (symbol_check_alias_consistence): Adjust.
2848
2849 * tests/regression.at (Invalid %directive): Remove, as it is now
2850 meaningless.
2851 (Invalid inputs): Adjust to the new error messages.
2852 (Token definitions): The new grammar doesn't allow too many
2853 eccentricities.
2854
2855 * src/lex.h, src/lex.c: Remove.
2856 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
2857 (copy_character, copy_string2, copy_string, copy_identifier)
2858 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
2859 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
2860 (parse_action): Remove.
2861 * po/POTFILES.in: Adjust.
2862
28632002-06-11 Akim Demaille <akim@epita.fr>
2864
2865 * src/reader.c (parse_action): Don't store directly into the
2866 rule's action member: return the action as a string.
2867 Don't require `rule_length' as an argument: compute it.
2868 (grammar_current_rule_symbol_append)
2869 (grammar_current_rule_action_append): New, eved out from
2870 (readgram): here.
2871 Remove `action_flag', `rulelength', unused now.
2872
28732002-06-11 Akim Demaille <akim@epita.fr>
2874
2875 * src/reader.c (grammar_current_rule_prec_set).
2876 (grammar_current_rule_check): New, eved out from...
2877 (readgram): here.
2878 Remove `xaction', `first_rhs': useless.
2879 * tests/input.at (Type clashes): New.
2880 * tests/existing.at (GNU Cim Grammar): Adjust.
2881
28822002-06-11 Akim Demaille <akim@epita.fr>
2883
2884 * src/reader.c (grammar_midrule_action): New, Eved out from
2885 (readgram): here.
2886
28872002-06-11 Akim Demaille <akim@epita.fr>
2888
2889 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
2890 New.
2891 (readgram): Use them as replacement of inlined code, crule and
2892 crule1.
2893
28942002-06-11 Akim Demaille <akim@epita.fr>
2895
2896 * src/reader.c (grammar_end, grammar_symbol_append): New.
2897 (readgram): Use them.
2898 Make the use of `p' as local as possible.
2899
29002002-06-10 Akim Demaille <akim@epita.fr>
2901
2902 GCJ's parser requires the tokens to be defined before the prologue.
2903
2904 * data/bison.simple: Output the token definition before the user's
2905 prologue.
2906 * tests/regression.at (Braces parsing, Duplicate string)
2907 (Mixing %token styles): Check the output from bison.
2908 (Early token definitions): New.
2909
29102002-06-10 Akim Demaille <akim@epita.fr>
2911
2912 * src/symtab.c (symbol_user_token_number_set): Don't complain when
2913 assigning twice the same user number to a token, so that we can
2914 use it in...
2915 * src/lex.c (lex): here.
2916 Also use `symbol_class_set' instead of hand written code.
2917 * src/reader.c (parse_assoc_decl): Likewise.
2918
29192002-06-10 Akim Demaille <akim@epita.fr>
2920
2921 * src/symtab.c, src/symtab.c (symbol_class_set)
2922 (symbol_user_token_number_set): New.
2923 * src/reader.c (parse_token_decl): Use them.
2924 Use a switch instead of ifs.
2925 Use a single argument.
2926
29272002-06-10 Akim Demaille <akim@epita.fr>
2928
2929 Remove `%thong' support as it is undocumented, unused, duplicates
2930 `%token's job, and creates useless e-mail traffic with people who
2931 want to know what it is, why it is undocumented, unused, and
2932 duplicates `%token's job.
2933
2934 * src/reader.c (parse_thong_decl): Remove.
2935 * src/options.c (option_table): Remove "thong".
2936 * src/lex.h (tok_thong): Remove.
2937
29382002-06-10 Akim Demaille <akim@epita.fr>
2939
2940 * src/symtab.c, src/symtab.c (symbol_type_set)
2941 (symbol_precedence_set): New.
2942 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
2943 (value_components_used): Remove, unused.
2944
29452002-06-09 Akim Demaille <akim@epita.fr>
2946
2947 Move symbols handling code out of the reader.
2948
2949 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
2950 (axiom): Move to...
2951 * src/symtab.h, src/symtab.c: here.
2952
2953 * src/gram.c (start_symbol): Remove: use startsymbol->number.
2954 * src/reader.c (startval): Rename as...
2955 * src/symtab.h, src/symtab.c (startsymbol): this.
2956 * src/reader.c: Adjust.
2957
2958 * src/reader.c (symbol_check_defined, symbol_make_alias)
2959 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2960 (token_translations_init)
2961 Move to...
2962 * src/symtab.c: here.
2963 * src/reader.c (packsymbols): Move to...
2964 * src/symtab.h, src/symtab.c (symbols_pack): here.
2965 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
2966 argument.
2967
29682002-06-03 Akim Demaille <akim@epita.fr>
2969
2970 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
2971 then statements.
2972
29732002-06-03 Akim Demaille <akim@epita.fr>
2974
2975 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
2976 structs with non literals.
2977 * src/scan-skel.l: never-interactive.
2978 * src/conflicts.c (enum conflict_resolution_e): No trailing
2979 comma.
2980 * src/getargs.c (usage): Split long literal strings.
2981 Reported by Hans Aberg.
2982
29832002-05-28 Akim Demaille <akim@epita.fr>
2984
2985 * data/bison.c++: Use C++ ostreams.
2986 (cdebug_): New member.
2987
29882002-05-28 Akim Demaille <akim@epita.fr>
2989
2990 * src/output.c (output_skeleton): Be sure to allocate enough room
2991 for `/' _and_ for `\0' in full_skeleton.
2992
29932002-05-28 Akim Demaille <akim@epita.fr>
2994
2995 * data/bison.c++: Catch up with bison.simple:
2996 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2997 and Paul Eggert <eggert@twinsun.com>: `error' handing.
2998 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
2999 and popping traces.
3000
30012002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3002
3003 * src/output.c (output_skeleton): Put an explicit path in front of
3004 the skeleton file name, rather than relying on the -I directory,
3005 to partially alleviate effects of having a skeleton file lying around
3006 in the current directory.
3007
30082002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3009
3010 * src/conflicts.c (log_resolution): Correct typo:
3011 obstack_printf should be obstack_fgrow1.
3012
30132002-05-26 Akim Demaille <akim@epita.fr>
3014
3015 * src/state.h (state_t): `solved_conflicts' is a new member.
3016 * src/LR0.c (new_state): Set it to 0.
3017 * src/conflicts.h, src/conflicts.c (print_conflicts)
3018 (free_conflicts, solve_conflicts): Rename as...
3019 (conflicts_print, conflicts_free, conflicts_solve): these.
3020 Adjust callers.
3021 * src/conflicts.c (enum conflict_resolution_e)
3022 (solved_conflicts_obstack): New, used by...
3023 (log_resolution): this.
3024 Adjust to attach the conflict resolution to each state.
3025 Complete the description with the precedence/associativity
3026 information.
3027 (resolve_sr_conflict): Adjust.
3028 * src/print.c (print_state): Output its solved_conflicts.
3029 * tests/conflicts.at (Unresolved SR Conflicts)
3030 (Solved SR Conflicts): Exercise --report=all.
3031
30322002-05-26 Akim Demaille <akim@epita.fr>
3033
3034 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3035 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3036 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3037 (token_number_t, item_number_as_token_number)
3038 (token_number_as_item_number, muscle_insert_token_number_table):
3039 Rename as...
3040 (symbol_number_t, item_number_as_symbol_number)
3041 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3042 these, since it is more appropriate.
3043
30442002-05-26 Akim Demaille <akim@epita.fr>
3045
3046 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3047 `Error:' lines.
3048 * data/bison.simple (yystos) [YYDEBUG]: New.
3049 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3050 error recovery.
3051 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3052
30532002-05-25 Akim Demaille <akim@epita.fr>
3054
3055 * doc/bison.texinfo (Debugging): Split into...
3056 (Tracing): this new section, its former contents, and...
3057 (Understanding): this new section.
3058 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3059 by...
3060 (report_flag): this.
3061 Adjust all dependencies.
3062 (report_args, report_types, report_argmatch): New.
3063 (usage, getargs): Report/support -r, --report.
3064 * src/options.h
3065 (struct option_table_struct): Rename as..,
3066 (struct option_table_s): this.
3067 Rename the `set_flag' member to `flag' to match with getopt_long's
3068 struct.
3069 * src/options.c (option_table): Split verbose into an entry for
3070 %verbose, and another for --verbose.
3071 Support --report/-r, so remove -r from the obsolete --raw.
3072 * src/print.c: Attach full item sets and lookaheads reports to
3073 report_flag instead of trace_flag.
3074 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3075
30762002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3077 and Paul Eggert <eggert@twinsun.com>
3078
3079 * data/bison.simple (yyparse): Correct error handling to conform to
3080 POSIX and yacc. Specifically, after syntax error is discovered,
3081 do not reduce further before shifting the error token.
3082 Clean up the code a bit by removing the labels yyerrdefault,
3083 yyerrhandle, yyerrpop.
3084 * NEWS: Document the above.
3085
30862002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3087
3088 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3089 type; it isn't always big enough, since it doesn't necessarily
3090 include non-terminals.
3091 (yytranslate): Expand definition of yy_token_number_type, so that
3092 the latter can be removed.
3093 (yy_token_number_type): Remove, only one use.
3094 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3095 don't use TokenNumberType as element type.
3096
3097 * tests/regression.at: Modify expected output to agree with change
3098 to yyr1 and yytranslate.
3099
31002002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3101
3102 * src/reader.c (parse_action): Use copy_character instead of
3103 obstack_1grow.
3104
31052002-05-13 Akim Demaille <akim@epita.fr>
3106
3107 * tests/regression.at (Token definitions): Prototype yylex and
3108 yyerror.
3109
31102002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3111
3112 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
3113 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3114 32-bit arithmetic.
3115 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3116
31172002-05-07 Akim Demaille <akim@epita.fr>
3118
3119 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3120 avoid GCC warnings.
3121
31222002-05-07 Akim Demaille <akim@epita.fr>
3123
3124 Kill GCC warnings.
3125
3126 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3127 over the RHS of each rule.
3128 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3129 * src/state.h (state_t): Member `nitems' is unsigned short.
3130 * src/LR0.c (get_state): Adjust.
3131 * src/reader.c (packgram): Likewise.
3132 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3133 `Type'.
3134 (muscle_insert_int_table): Remove, unused.
3135 (prepare_rules): Remove `max'.
3136
31372002-05-06 Akim Demaille <akim@epita.fr>
3138
3139 * src/closure.c (print_firsts): Display of the symbol tags.
3140 (bitmatrix_print): Move to...
3141 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
3142 here.
3143 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
3144
31452002-05-06 Akim Demaille <akim@epita.fr>
3146
3147 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
3148 hash_do_for_each.
3149
31502002-05-06 Akim Demaille <akim@epita.fr>
3151
3152 * src/LR0.c (new_state, get_state): Instead of using the global
3153 `kernel_size' and `kernel_base', have two new arguments:
3154 `core_size' and `core'.
3155 Adjust callers.
3156
31572002-05-06 Akim Demaille <akim@epita.fr>
3158
3159 * src/reader.c (packgram): No longer end `ritem' with a 0
3160 sentinel: it is not used.
3161
31622002-05-05 Akim Demaille <akim@epita.fr>
3163
3164 New experimental feature: display the lookaheads in the report and
3165 graph.
3166
3167 * src/print (print_core): When --trace-flag, display the rules
3168 lookaheads.
3169 * src/print_graph.c (print_core): Likewise.
3170 Swap the arguments.
3171 Adjust caller.
3172
31732002-05-05 Akim Demaille <akim@epita.fr>
3174
3175 * tests/torture.at (Many lookaheads): New test.
3176
31772002-05-05 Akim Demaille <akim@epita.fr>
3178
3179 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
3180 (GENERATE_MUSCLE_INSERT_TABLE): this.
3181 (output_int_table, output_unsigned_int_table, output_short_table)
3182 (output_token_number_table, output_item_number_table): Replace with...
3183 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
3184 (muscle_insert_short_table, muscle_insert_token_number_table)
3185 (muscle_insert_item_number_table): these.
3186 Adjust all callers.
3187 (prepare_tokens): Don't free `translations', since...
3188 * src/reader.h, src/reader.c (grammar_free): do it.
3189 Move to...
3190 * src/gram.h, src/gram.c (grammar_free): here.
3191 * data/bison.simple, data/bison.c++: b4_token_number_max is now
3192 b4_translate_max.
3193
31942002-05-05 Akim Demaille <akim@epita.fr>
3195
3196 * src/output.c (output_unsigned_int_table): New.
3197 (prepare_rules): `i' is unsigned.
3198 `prhs', `rline', `r2' are unsigned int.
3199 Rename muscle `rhs_number_max' as `rhs_max'.
3200 Output muscles `prhs_max', `rline_max', and `r2_max'.
3201 Free rline and r1.
3202 * data/bison.simple, data/bison.c++: Adjust to use these muscles
3203 to compute types instead of constant types.
3204 * tests/regression.at (Web2c Actions): Adjust.
3205
32062002-05-04 Akim Demaille <akim@epita.fr>
3207
3208 * src/symtab.h (SALIAS, SUNDEF): Rename as...
3209 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
3210 Adjust dependencies.
3211 * src/output.c (token_definitions_output): Be sure not to output a
3212 `#define 'a'' when fed with `%token 'a' "a"'.
3213 * tests/regression.at (Token definitions): New.
3214
32152002-05-03 Paul Eggert <eggert@twinsun.com>
3216
3217 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
3218 for K&R C.
3219
32202002-05-03 gettextize <bug-gnu-gettext@gnu.org>
3221
3222 * Makefile.am (SUBDIRS): Remove intl.
3223 (EXTRA_DIST): Add config/config.rpath.
3224
32252002-05-03 Akim Demaille <akim@epita.fr>
3226
3227 * data/bison.simple (m4_if): Don't output empty enums.
3228 And actually, output valid enum definitions :(.
3229
32302002-05-03 Akim Demaille <akim@epita.fr>
3231
3232 * configure.bat: Remove, completely obsolete.
3233 * Makefile.am (EXTRA_DIST): Adjust.
3234 Don't distribute config.rpath...
3235 * config/Makefile.am (EXTRA_DIST): Do it.
3236
32372002-05-03 Akim Demaille <akim@epita.fr>
3238
3239 * configure.in (GETTEXT_VERSION): New.
3240 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
3241
32422002-05-03 Akim Demaille <akim@epita.fr>
3243
3244 * data/bison.simple (b4_token_enum): New.
3245 (b4_token_defines): Use it to output tokens both as #define and
3246 enums.
3247 Suggested by Paul Eggert.
3248 * src/output.c (token_definitions_output): Don't output spurious
3249 white spaces.
3250
32512002-05-03 Akim Demaille <akim@epita.fr>
3252
3253 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3254
32552002-05-02 Robert Anisko <robert@lrde.epita.fr>
3256
3257 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
3258 Update the stack class, give a try to deque as the default container.
3259
32602002-05-02 Akim Demaille <akim@epita.fr>
3261
3262 * data/bison.simple (yyparse): Do not implement @$ = @1.
3263 (YYLLOC_DEFAULT): Adjust to do it.
3264 * doc/bison.texinfo (Location Default Action): Fix.
3265
32662002-05-02 Akim Demaille <akim@epita.fr>
3267
3268 * src/reader.c (parse_braces): Merge into...
3269 (parse_action): this.
3270
32712002-05-02 Akim Demaille <akim@epita.fr>
3272
3273 * configure.in (ALL_LINGUAS): Remove.
3274 * po/LINGUAS, hr.po: New.
3275
32762002-05-02 Akim Demaille <akim@epita.fr>
3277
3278 Remove the so called hairy (semantic) parsers.
3279
3280 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
3281 * src/gram.h, src/gram.c (semantic_parser): Remove.
3282 (rule_t): Remove the guard and guard_line members.
3283 * src/lex.h (token_t): remove tok_guard.
3284 * src/options.c (option_table): Remove %guard and %semantic_parser
3285 support.
3286 * src/output.c, src/output.h (guards_output): Remove.
3287 (prepare): Adjust.
3288 (token_definitions_output): Don't output the `T'
3289 tokens (???).
3290 (output_skeleton): Don't output the guards.
3291 * src/files.c, src/files.c (attrsfile): Remove.
3292 * src/reader.c (symbol_list): Remove the guard and guard_line
3293 members.
3294 Adjust dependencies.
3295 (parse_guard): Remove.
3296 * data/bison.hairy: Remove.
3297 * doc/bison.texinfo (Environment Variables): Remove occurrences of
3298 BISON_HAIRY.
3299
33002002-05-02 Akim Demaille <akim@epita.fr>
3301
3302 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
3303 (parse_guard): Rename the formal argument `stack_offset' as
3304 `rule_length', which is more readable.
3305 Adjust callers.
3306 (copy_at, copy_dollar): Instead of outputting the hard coded
3307 values of $$, $n and so forth, output invocation to b4_lhs_value,
3308 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
3309 Note: this patch partially drops `semantic-parser' support: it
3310 always does `rule_length - n', where semantic parsers ought to
3311 always use `-n'.
3312 * data/bison.simple, data/bison.c++ (b4_lhs_value)
3313 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
3314
33152002-05-02 Akim Demaille <akim@epita.fr>
3316
3317 * configure.in (AC_INIT): Bump to 1.49b.
3318 (AM_INIT_AUTOMAKE): Short invocation.
3319
33202002-05-02 Akim Demaille <akim@epita.fr>
3321
3322 Version 1.49a.
3323
33242002-05-01 Akim Demaille <akim@epita.fr>
3325
3326 * src/skeleton.h: Remove.
3327
33282002-05-01 Akim Demaille <akim@epita.fr>
3329
3330 * src/skeleton.h: Fix the #endif.
3331 Reported by Magnus Fromreide.
3332
33332002-04-26 Paul Eggert <eggert@twinsun.com>
3334
3335 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
3336 Define if we define YYSTYPE and YYLTYPE, respectively.
3337 (YYCOPY): Fix [] quoting problem in the non-GCC case.
3338
33392002-04-25 Robert Anisko <robert@lrde.epita.fr>
3340
3341 * src/scan-skel.l: Postprocess quadrigraphs.
3342
3343 * src/reader.c (copy_character): New function, used to output
3344 single characters while replacing `[' and `]' with quadrigraphs, to
3345 avoid troubles with M4 quotes.
3346 (copy_comment): Output characters with copy_character.
3347 (read_additionnal_code): Likewise.
3348 (copy_string2): Likewise.
3349 (copy_definition): Likewise.
3350
3351 * tests/calc.at: Exercise M4 quoting.
3352
33532002-04-25 Akim Demaille <akim@epita.fr>
3354
3355 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
3356 between `!' and the command.
3357 Reported by Paul Eggert.
3358
33592002-04-24 Robert Anisko <robert@lrde.epita.fr>
3360
3361 * tests/calc.at: Exercise prologue splitting.
3362
3363 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
3364 `b4_post_prologue' instead of `b4_prologue'.
3365
3366 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
3367 muscles.
3368 (output): Free pre_prologue_obstack and post_prologue_obstack.
3369 * src/files.h, src/files.c (attrs_obstack): Remove.
3370 (pre_prologue_obstack, post_prologue_obstack): New.
3371 * src/reader.c (copy_definition): Add a parameter to specify the
3372 obstack to fill, instead of using attrs_obstack unconditionally.
3373 (read_declarations): Pass pre_prologue_obstack to copy_definition if
3374 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
3375
33762002-04-23 Paul Eggert <eggert@twinsun.com>
3377
3378 * data/bison.simple: Remove unnecessary commentary and white
3379 space differences from 1_29-branch.
3380 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
3381
3382 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
3383 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
3384 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
3385 constructors or destructors.
3386
3387 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
3388
33892002-04-23 Akim Demaille <akim@epita.fr>
3390
3391 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
3392 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
3393 location with columns.
3394 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
3395 All reported by Paul Eggert.
3396
33972002-04-22 Akim Demaille <akim@epita.fr>
3398
3399 * src/reduce.c (dump_grammar): Move to...
3400 * src/gram.h, src/gram.c (grammar_dump): here.
3401 Be sure to separate long item numbers.
3402 Don't read the members of a rule's prec if its nil.
3403
34042002-04-22 Akim Demaille <akim@epita.fr>
3405
3406 * src/output.c (table_size, table_grow): New.
3407 (MAXTABLE): Remove, replace uses with table_size.
3408 (pack_vector): Instead of dying when the table is too big, grow it.
3409
34102002-04-22 Akim Demaille <akim@epita.fr>
3411
3412 * data/bison.simple (yyr1): Its type is that of a token number.
3413 * data/bison.c++ (r1_): Likewise.
3414 * tests/regression.at (Web2c Actions): Adjust.
3415
34162002-04-22 Akim Demaille <akim@epita.fr>
3417
3418 * src/reader.c (token_translations_init): 256 is now the default
3419 value for the error token, i.e., it will be assigned another
3420 number if the user assigned 256 to one of her tokens.
3421 (reader): Don't force 256 to error.
3422 * doc/bison.texinfo (Symbols): Adjust.
3423 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
3424 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
3425 etc. instead of 10, 20, 30 (which was used to `jump' over error
3426 (256) and undefined (2)).
3427
34282002-04-22 Akim Demaille <akim@epita.fr>
3429
3430 Propagate more token_number_t.
3431
3432 * src/gram.h (token_number_as_item_number)
3433 (item_number_as_token_number): New.
3434 * src/output.c (GENERATE_OUTPUT_TABLE): New.
3435 Use it to create output_item_number_table and
3436 output_token_number_table.
3437 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3438 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
3439 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
3440 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
3441
34422002-04-22 Akim Demaille <akim@epita.fr>
3443
3444 * src/output.h, src/output.c (get_lines_number): Remove.
3445
34462002-04-19 Akim Demaille <akim@epita.fr>
3447
3448 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
3449 as Lex/Flex'.
3450 (Debugging): More details about enabling the debugging features.
3451 (Table of Symbols): Describe $$, $n, @$, and @n.
3452 Suggested by Tim Josling.
3453
34542002-04-19 Akim Demaille <akim@epita.fr>
3455
3456 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
3457
34582002-04-10 Akim Demaille <akim@epita.fr>
3459
3460 * src/system.h: Rely on HAVE_LIMITS_H.
3461 Suggested by Paul Eggert.
3462
34632002-04-09 Akim Demaille <akim@epita.fr>
3464
3465 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
3466 full stderr, and strip it according to the bison options, instead
3467 of composing the error message from different bits.
3468 This makes it easier to check for several error messages.
3469 Adjust all the invocations.
3470 Add an invocation exercising the error token.
3471 Add an invocation demonstrating a stupid error message.
3472 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
3473 Adjust the tests.
3474 Error message are for stderr, not stdout.
3475
34762002-04-09 Akim Demaille <akim@epita.fr>
3477
3478 * src/gram.h, src/gram.c (error_token_number): Remove, use
3479 errtoken->number.
3480 * src/reader.c (reader): Don't specify the user token number (2)
3481 for $undefined, as it uselessly prevents using it.
3482 * src/gram.h (token_number_t): Move to...
3483 * src/symtab.h: here.
3484 (state_t.number): Is a token_number_t.
3485 * src/print.c, src/reader.c: Use undeftoken->number instead of
3486 hard coded 2.
3487 (Even though this 2 is not the same as above: the number of the
3488 undeftoken remains being 2, it is its user token number which
3489 might not be 2).
3490 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
3491 `user_token_number_max'.
3492 Output `undef_token_number'.
3493 * data/bison.simple, data/bison.c++: Use them.
3494 Be sure to map invalid yylex return values to
3495 `undef_token_number'. This saves us from gratuitous SEGV.
3496
3497 * tests/conflicts.at (Solved SR Conflicts)
3498 (Unresolved SR Conflicts): Adjust.
3499 * tests/regression.at (Web2c Actions): Adjust.
3500
35012002-04-08 Akim Demaille <akim@epita.fr>
3502
3503 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
3504 Adding #line.
3505 Remove the duplicate `typedefs'.
3506 (RhsNumberType): Fix the declaration and various other typos.
3507 Use __ofile__.
3508 * data/bison.simple: Use __ofile__.
3509 * src/scan-skel.l: Handle __ofile__.
3510
35112002-04-08 Akim Demaille <akim@epita.fr>
3512
3513 * src/gram.h (item_number_t): New, the type of item numbers in
3514 RITEM. Note that it must be able to code symbol numbers as
3515 positive number, and the negation of rule numbers as negative
3516 numbers.
3517 Adjust all dependencies (pretty many).
3518 * src/reduce.c (rule): Remove this `short *' pointer: use
3519 item_number_t.
3520 * src/system.h (MINSHORT, MAXSHORT): Remove.
3521 Include `limits.h'.
3522 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
3523 (shortcpy): Remove.
3524 (MAXTABLE): Move to...
3525 * src/output.c (MAXTABLE): here.
3526 (prepare_rules): Use output_int_table to output rhs.
3527 * data/bison.simple, data/bison.c++: Adjust.
3528 * tests/torture.at (Big triangle): Move the limit from 254 to
3529 500.
3530 * tests/regression.at (Web2c Actions): Ajust.
3531
3532 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
3533 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3534 passes, but produces negative #line number, once fixed, GCC is
3535 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3536 C), it passes.
3537 * src/state.h (state_h): Code input lines on ints, not shorts.
3538
35392002-04-08 Akim Demaille <akim@epita.fr>
3540
3541 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3542 and then the grammar.
3543
35442002-04-08 Akim Demaille <akim@epita.fr>
3545
3546 * src/system.h: No longer using strndup.
3547
35482002-04-07 Akim Demaille <akim@epita.fr>
3549
3550 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3551 * src/output.c (output_table_data): Return the longest number.
3552 (prepare_tokens): Output `token_number_max').
3553 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3554 New.
3555 Use them to define yy_token_number_type/TokenNumberType.
3556 Use this type for yytranslate.
3557 * tests/torture.at (Big triangle): Push the limit from 124 to
3558 253.
3559 * tests/regression.at (Web2c Actions): Adjust.
3560
35612002-04-07 Akim Demaille <akim@epita.fr>
3562
3563 * tests/torture.at (Big triangle): New.
3564 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3565 * tests/existing.at: here.
3566
35672002-04-07 Akim Demaille <akim@epita.fr>
3568
3569 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3570 nritems.
3571 Adjust dependencies.
3572
35732002-04-07 Akim Demaille <akim@epita.fr>
3574
3575 * src/reader.c: Normalize increments to prefix form.
3576
35772002-04-07 Akim Demaille <akim@epita.fr>
3578
3579 * src/reader.c, symtab.c: Remove debugging code.
3580
35812002-04-07 Akim Demaille <akim@epita.fr>
3582
3583 Rename all the `bucket's as `symbol_t'.
3584
3585 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3586 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3587 * src/symtab.c, src/symtab.h (bucket): Rename as...
3588 (symbol_t): this.
3589 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3590 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3591 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3592 (buckets_new, buckets_free, buckets_do): Rename as...
3593 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3594 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3595 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3596 (symbols_new, symbols_free, symbols_do): these.
3597
35982002-04-07 Akim Demaille <akim@epita.fr>
3599
3600 Use lib/hash for the symbol table.
3601
3602 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3603 EOF.
3604 * src/lex.c (lex): Set the `number' member of new terminals.
3605 * src/reader.c (bucket_check_defined, bucket_make_alias)
3606 (bucket_check_alias_consistence, bucket_translation): New.
3607 (reader, grammar_free, readgram, token_translations_init)
3608 (packsymbols): Adjust.
3609 (reader): Number the predefined tokens.
3610 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3611 for predefined tokens.
3612 * src/symtab.h (bucket): Remove all the hash table related
3613 members.
3614 * src/symtab.c (symtab): Replace by...
3615 (bucket_table): this.
3616 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3617 (buckets_new, buckets_do): New.
3618
36192002-04-07 Akim Demaille <akim@epita.fr>
3620
3621 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3622 (start_symbol, max_user_token_number, semantic_parser)
3623 (error_token_number): Initialize.
3624 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3625 Initialize.
3626 (reader): Don't.
3627 (errtoken, eoftoken, undeftoken, axiom): Extern.
3628
36292002-04-07 Akim Demaille <akim@epita.fr>
3630
3631 * src/gram.h (rule_s): prec and precsym are now pointers
3632 to the bucket giving the priority/associativity.
3633 Member `associativity' removed: useless.
3634 * src/reduce.c, src/conflicts.c: Adjust.
3635
36362002-04-07 Akim Demaille <akim@epita.fr>
3637
3638 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3639 Properly escape the symbols' TAG when outputting them.
3640
36412002-04-07 Akim Demaille <akim@epita.fr>
3642
3643 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3644
36452002-04-07 Akim Demaille <akim@epita.fr>
3646
3647 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3648 (LArule): this, which is an array to rule_t*.
3649 * src/print.c, src/conflicts.c: Adjust.
3650
36512002-04-07 Akim Demaille <akim@epita.fr>
3652
3653 * src/gram.h (rule_t): Rename `number' as `user_number'.
3654 `number' is a new member.
3655 Adjust dependencies.
3656 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3657
36582002-04-07 Akim Demaille <akim@epita.fr>
3659
3660 As a result of the previous patch, it is no longer needed
3661 to reorder ritem itself.
3662
3663 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3664
36652002-04-07 Akim Demaille <akim@epita.fr>
3666
3667 Be sure never to walk through RITEMS, but use only data related to
3668 the rules themselves. RITEMS should be banished.
3669
3670 * src/output.c (output_token_translations): Rename as...
3671 (prepare_tokens): this.
3672 In addition to `translate', prepare the muscles `tname' and
3673 `toknum', which were handled by...
3674 (output_rule_data): this.
3675 Remove, and move the remainder of its outputs into...
3676 (prepare_rules): this new routines, which also merges content from
3677 (output_gram): this.
3678 (prepare_rules): Be sure never to walk through RITEMS.
3679 (output_stos): Rename as...
3680 (prepare_stos): this.
3681 (output): Always invoke prepare_states, after all, just don't use it
3682 in the output if you don't need it.
3683
36842002-04-07 Akim Demaille <akim@epita.fr>
3685
3686 * src/LR0.c (new_state): Display `nstates' as the name of the
3687 newly created state.
3688 Adjust to initialize first_state and last_state if needed.
3689 Be sure to distinguish the initial from the final state.
3690 (new_states): Create the itemset of the initial state, and use
3691 new_state.
3692 * src/closure.c (closure): Now that the initial state has its
3693 items properly set, there is no need for a special case when
3694 creating `ruleset'.
3695
3696 As a result, now the rule 0, reducing to $axiom, is visible in the
3697 outputs. Adjust the test suite.
3698
3699 * tests/conflicts.at (Solved SR Conflicts)
3700 (Unresolved SR Conflicts): Adjust.
3701 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3702 * tests/conflicts.at (S/R in initial): New.
3703
37042002-04-07 Akim Demaille <akim@epita.fr>
3705
3706 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3707 the RHS of the rules.
3708 * src/output.c (output_gram): Likewise.
3709
37102002-04-07 Akim Demaille <akim@epita.fr>
3711
3712 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3713 bucket.
3714 Adjust all dependencies.
3715 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3716 `number' of the buckets too.
3717 * src/gram.h: Include `symtab.h'.
3718 (associativity): Move to...
3719 * src/symtab.h: here.
3720 No longer include `gram.h'.
3721
37222002-04-07 Akim Demaille <akim@epita.fr>
3723
3724 * src/gram.h, src/gram.c (rules_rhs_length): New.
3725 (ritem_longest_rhs): Use it.
3726 * src/gram.h (rule_t): `number' is a new member.
3727 * src/reader.c (packgram): Set it.
3728 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3729 the end of `rules', and count them out of `nrules'.
3730 (reduce_output, dump_grammar): Adjust.
3731 * src/print.c (print_grammar): It is no longer needed to check for
3732 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3733 * tests/reduce.at (Reduced Automaton): New test.
3734
37352002-04-07 Akim Demaille <akim@epita.fr>
3736
3737 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3738 lacking `+ 1' to nrules, Bison reported as useless a token if it
3739 was used solely to set the precedence of the last rule...
3740
37412002-04-07 Akim Demaille <akim@epita.fr>
3742
3743 * data/bison.c++, data/bison.simple: Don't output the current file
3744 name in #line, to avoid useless diffs between two identical
3745 outputs under different names.
3746
37472002-04-07 Akim Demaille <akim@epita.fr>
3748
3749 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3750 Normalize loops to using `< nrules + 1', not `<= nrules'.
3751
37522002-04-07 Akim Demaille <akim@epita.fr>
3753
3754 * TODO: Update.
3755
37562002-04-07 Akim Demaille <akim@epita.fr>
3757
3758 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3759 bucket.value as bucket.number.
3760
37612002-04-07 Akim Demaille <akim@epita.fr>
3762
3763 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3764 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3765 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3766 RHS, instead of being an index in RITEMS.
3767
37682002-04-04 Paul Eggert <eggert@twinsun.com>
3769
3770 * doc/bison.texinfo: Update copyright date.
3771 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3772 (Symbols): Warn about running Bison in one character set,
3773 but compiling and/or running in an incompatible one.
3774 Warn about character code 256, too.
3775
37762002-04-03 Paul Eggert <eggert@twinsun.com>
3777
3778 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3779 YYERROR_VERBOSE is nonzero, not whether it is defined.
3780
3781 Merge changes from bison-1_29-branch.
3782
37832002-03-20 Paul Eggert <eggert@twinsun.com>
3784
3785 Merge fixes from Debian bison_1.34-1.diff.
3786
3787 * configure.in (AC_PREREQ): 2.53.
3788
37892002-03-20 Akim Demaille <akim@epita.fr>
3790
3791 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3792
37932002-03-19 Paul Eggert <eggert@twinsun.com>
3794
3795 * src/bison.simple (YYCOPY): New macro.
3796 (YYSTACK_RELOCATE): Use it.
3797 Remove Type arg; no longer needed. All callers changed.
3798 (yymemcpy): Remove; no longer needed.
3799
3800 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3801 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3802
38032002-03-19 Akim Demaille <akim@epita.fr>
3804
3805 Test and fix the #line outputs.
3806
3807 * tests/atlocal.at (GCC): New.
3808 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3809 (Prologue synch line, ,%union synch line, Postprologue synch line)
3810 (Action synch line, Epilogue synch line): New tests.
3811 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3812 * data/bison.simple, data/bison.c++: Use it.
3813
38142002-03-19 Akim Demaille <akim@epita.fr>
3815
3816 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3817 (Solved SR Conflicts, %expect not enough, %expect right)
3818 (%expect too much): Move to...
3819 * tests/conflicts.at: this new file.
3820
38212002-03-19 Akim Demaille <akim@epita.fr>
3822
3823 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3824 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3825 that we can move to enums for instance.
3826 * src/output.c (token_definitions_output): Output a list of
3827 `token-name, token-number' instead of the #define.
3828 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3829
38302002-03-14 Akim Demaille <akim@epita.fr>
3831
3832 Use Gettext 0.11.1.
3833
38342002-03-09 Robert Anisko <robert@lrde.epita.fr>
3835
3836 * data/bison.c++: Make the user able to add members to the generated
3837 parser by subclassing.
3838
38392002-03-05 Robert Anisko <robert@lrde.epita.fr>
3840
3841 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3842 a character.
3843 Reported by Nicolas Tisserand and Nicolas Burrus.
3844
38452002-03-04 Robert Anisko <robert@lrde.epita.fr>
3846
3847 * src/reader.c: Warn about lacking semi-colons, do not complain.
3848
38492002-03-04 Robert Anisko <robert@lrde.epita.fr>
3850
3851 * data/bison.c++: Remove a debug line.
3852
38532002-03-04 Robert Anisko <robert@lrde.epita.fr>
3854
3855 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
3856 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
3857 provide a default implementation.
3858
38592002-03-04 Akim Demaille <akim@epita.fr>
3860
3861 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
3862 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
3863 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
3864 * tests/semantic.at (Parsing Guards): Similarly.
3865 * src/reader.at (readgram): Complain if the last rule is not ended
3866 with a semi-colon.
3867
38682002-03-04 Akim Demaille <akim@epita.fr>
3869
3870 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
3871 * src/closure.c: here.
3872 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
3873 RTC.
3874 * src/warshall.h, src/warshall.c: Remove.
3875 * tests/sets.at (Broken Closure): Adjust.
3876
38772002-03-04 Akim Demaille <akim@epita.fr>
3878
3879 * src/output.c (output_skeleton): tempdir is const.
3880 bytes_read is unused.
3881
38822002-03-04 Akim Demaille <akim@epita.fr>
3883
3884 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3885 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
3886 Update.
3887 From Michael Hayes.
3888
38892002-03-04 Akim Demaille <akim@epita.fr>
3890
3891 * src/closure.c (closure): `r' is unused.
3892
38932002-03-04 Akim Demaille <akim@epita.fr>
3894
3895 * tests/sets.at (Broken Closure): Add the ending `;'.
3896 * src/reader.at (readgram): Complain if a rule is not ended with a
3897 semi-colon.
3898
38992002-03-04 Akim Demaille <akim@epita.fr>
3900
3901 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
3902 (count_sr_conflicts): Use bitset_count.
3903 * src/reduce.c (inaccessable_symbols): Ditto.
3904 (bits_size): Remove.
3905 * src/warshall.h, src/warshall.c: Convert to bitsetv.
3906
39072002-03-04 Akim Demaille <akim@epita.fr>
3908
3909 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
3910 * src/reduce.c: Remove the `bitset_zero's following the
3911 `bitset_create's, as now it is performed by the latter.
3912
39132002-03-04 Akim Demaille <akim@epita.fr>
3914
3915 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
3916 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
3917 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
3918 latest sources from Michael.
3919
39202002-03-04 Akim Demaille <akim@epita.fr>
3921
3922 * src/output.c (output): Don't free the grammar.
3923 * src/reader.c (grammar_free): New.
3924 * src/main.c (main): Call it and don't free symtab here.
3925
39262002-03-04 Akim Demaille <akim@epita.fr>
3927
3928 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
3929 before returning.
3930 Reported by Benoit Perrot.
3931
39322002-03-04 Akim Demaille <akim@epita.fr>
3933
3934 Use bitset operations when possible, not loops over bits.
3935
3936 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
3937 bitset_or.
3938 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
3939 * src/reduce.c (useless_nonterminals): Formatting changes.
3940 * src/warshall.c (TC): Use bitset_or.
3941
39422002-03-04 Akim Demaille <akim@epita.fr>
3943
3944 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
3945 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
3946 Ditto.
3947
39482002-03-04 Akim Demaille <akim@epita.fr>
3949
3950 * src/lalr.c (F): Now a bitset*.
3951 Adjust all dependencies.
3952
39532002-03-04 Akim Demaille <akim@epita.fr>
3954
3955 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
3956 Adjust all dependencies.
3957
39582002-03-04 Akim Demaille <akim@epita.fr>
3959
3960 * src/L0.c, src/LR0.h (nstates): Be size_t.
3961 Adjust comparisons (signed vs unsigned).
3962 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
3963 bitset*.
3964 Adjust all dependencies.
3965
39662002-03-04 Akim Demaille <akim@epita.fr>
3967
3968 * src/closure.c (firsts): Now, also a bitset.
3969 Adjust all dependencies.
3970 (varsetsize): Remove, now unused.
3971 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
3972
39732002-03-04 Akim Demaille <akim@epita.fr>
3974
3975 * src/print.c: Convert to use bitset.h, not hand coded iterations
3976 over ints.
3977
39782002-03-04 Akim Demaille <akim@epita.fr>
3979
3980 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
3981
39822002-03-04 Akim Demaille <akim@epita.fr>
3983
3984 * src/closure.c (ruleset): Be a bitset.
3985 (rulesetsize): Remove.
3986
39872002-03-04 Akim Demaille <akim@epita.fr>
3988
3989 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3990 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
3991 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
3992 * src/closure.c (fderives): Be an array of bitsets.
3993
39942002-02-28 Robert Anisko <robert@lrde.epita.fr>
3995
3996 * data/bison.c++: Merge the two generated headers. Insert a copyright
3997 notice in each output file.
3998
39992002-02-28 Akim Demaille <akim@epita.fr>
4000
4001 * data/bison.c++: Copy the prologue of bison.simple to fetch
4002 useful M4 definitions, such as b4_header_guard.
4003
40042002-02-25 Akim Demaille <akim@epita.fr>
4005
4006 * src/getargs.c (version): Give the name of the authors, and use a
4007 translator friendly scheme for the bgr
4008 copyright notice.
4009
40102002-02-25 Akim Demaille <akim@epita.fr>
4011
4012 * src/output.c (header_output): Remove, now handled completely via
4013 M4.
4014
40152002-02-25 Akim Demaille <akim@epita.fr>
4016
4017 * m4/m4.m4: New, from CVS Autoconf.
4018 * configure.in: Invoke it.
4019 * src/output.c (output_skeleton): Use its result instead of the
4020 hard coded name.
4021
40222002-02-25 Akim Demaille <akim@epita.fr>
4023
4024 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4025 Fileutils 4.1.5.
4026 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4027 * src/output.c (output_skeleton): Use mkstemp to create a real
4028 temporary file.
4029 Move the filling of `skeleton' and its muscle to...
4030 (prepare): here.
4031 (output): Move the definition of the prologue muscle to...
4032 (prepare): here.
4033 * src/system.h (DEFAULT_TMPDIR): New.
4034
40352002-02-14 Paul Eggert <eggert@twinsun.com>
4036
4037 Remove the support for C++ namespace cleanliness; it was
4038 causing more problems than it was curing, since it didn't work
4039 properly on some nonstandard C++ compilers. This can wait
4040 for a proper C++ parser.
4041
4042 * NEWS: Document this.
4043 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4044 of C++, as it's treated like C now.
4045 * src/bison.simple (YYSTD): Remove.
4046 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4047 Treat C++ just like Standard C instead of trying to support
4048 namespace cleanliness.
4049
40502002-02-14 Akim Demaille <akim@epita.fr>
4051
4052 * tests/regression.at (else): Adjust to Andreas' change.
4053
40542002-02-14 Akim Demaille <akim@epita.fr>
4055
4056 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4057
40582002-02-13 Andreas Schwab <schwab@suse.de>
4059
4060 * src/output.c (output_rule_data): Don't output NULL, it might
4061 not be defined yet.
4062
40632002-02-11 Robert Anisko <robert@lrde.epita.fr>
4064
4065 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4066 (Copyright notice): Update.
4067
40682002-02-11 Akim Demaille <akim@epita.fr>
4069
4070 * tests/regression.at (%nonassoc and eof): Don't include
4071 nonportable headers.
4072
40732002-02-08 Robert Anisko <robert@lrde.epita.fr>
4074
4075 * data/bison.c++: Correct error recovery. Make the user able to
4076 initialize the starting location.
4077
40782002-02-07 Akim Demaille <akim@epita.fr>
4079
4080 * tests/input.at: New.
4081
40822002-02-07 Robert Anisko <robert@lrde.epita.fr>
4083
4084 * data/bison.c++: Replace some direct m4 expansions by constants. Be
4085 more consistent when naming methods and variables. Put preprocessor
4086 directives around tables only needed for debugging.
4087
40882002-02-07 Robert Anisko <robert@lrde.epita.fr>
4089
4090 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4091 C++ parsers.
4092 (yy::b4_name::parse): Use print_.
4093
40942002-02-07 Robert Anisko <robert@lrde.epita.fr>
4095
4096 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4097
40982002-02-07 Robert Anisko <robert@lrde.epita.fr>
4099
4100 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4101 C++ parsers.
4102 (yy::b4_name::parse): Build verbose error messages, and use error_.
4103
41042002-02-06 Robert Anisko <robert@lrde.epita.fr>
4105
4106 * data/bison.c++: Fix m4 quoting in comments.
4107
41082002-02-06 Robert Anisko <robert@lrde.epita.fr>
4109
4110 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4111 not expanded by m4.
4112
41132002-02-05 Akim Demaille <akim@epita.fr>
4114
4115 * data/bison.c++: Adjust to the M4 back end.
4116 More is certainly needed.
4117
41182002-02-05 Akim Demaille <akim@epita.fr>
4119
4120 Give a try to M4 as a back end.
4121
4122 * lib/readpipe.c: New, from wdiff.
4123 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4124 BISON_HAIRY.
4125 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4126 specific values. Now it is m4 that performs the lookup.
4127 * src/parse-skel.y: Remove.
4128 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4129 * src/output.c (actions_output, guards_output)
4130 (token_definitions_output): No longer keeps track of the output
4131 line number, hence remove the second argument.
4132 (guards_output): Check against the guard member of a rule, not the
4133 action member.
4134 Adjust callers.
4135 (output_skeleton): Don't look for the skeleton location, let m4 do
4136 that.
4137 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
4138 file will be used.
4139 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
4140 (prepare): Given that for the time being changesyntax is not
4141 usable in M4, rename the muscles using `-' to `_'.
4142 Define `defines_flag', `output_parser_name' and `output_header_name'.
4143 * src/output.h (actions_output, guards_output)
4144 (token_definitions_output): Adjust prototypes.
4145 * src/scan-skel.l: Instead of scanning the skeletons, it now
4146 processes the output of m4: `__oline__' and `#output'.
4147 * data/bison.simple: Adjust to be used by M4(sugar).
4148 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
4149 to date.
4150 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
4151 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
4152 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
4153 shamelessly stolen from CVS Autoconf.
4154
41552002-02-05 Akim Demaille <akim@epita.fr>
4156
4157 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
4158 * configure.in: Check for the declarations of free and malloc.
4159 * src/muscle_tab.c: Adjust.
4160
41612002-02-05 Akim Demaille <akim@epita.fr>
4162
4163 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
4164 which have no values.
4165
41662002-02-05 Akim Demaille <akim@epita.fr>
4167
4168 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
4169 * data/: here.
4170
41712002-01-29 Paul Eggert <eggert@twinsun.com>
4172
4173 * src/bison.simple (YYSIZE_T): Do not define merely because
4174 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
4175 On some platforms, <alloca.h> does not declare YYSTD (size_t).
4176
41772002-01-27 Akim Demaille <akim@epita.fr>
4178
4179 Fix `%nonassoc and eof'.
4180
4181 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
4182 which were not properly copied! Replace
4183 memcpy (res->errs, src->errs, src->nerrs);
4184 with
4185 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
4186 !!!
4187 * tests/regression.at (%nonassoc and eof): Adjust to newest
4188 Autotest: `.' is not in the PATH.
4189
41902002-01-27 Akim Demaille <akim@epita.fr>
4191
4192 * tests/sets.at (AT_EXTRACT_SETS): New.
4193 (Nullable): Use it.
4194 (Firsts): New.
4195
41962002-01-26 Akim Demaille <akim@epita.fr>
4197
4198 * tests/actions.at, tests/calc.at, tests/headers.at,
4199 * tests/torture.at: Adjust to the newest Autotest which no longer
4200 forces `.' in the PATH.
4201
42022002-01-25 Akim Demaille <akim@epita.fr>
4203
4204 * tests/regression.at (%nonassoc and eof): New.
4205 Suggested by Robert Anisko.
4206
42072002-01-24 Akim Demaille <akim@epita.fr>
4208
4209 Bison dumps core when trying to complain about broken input files.
4210 Reported by Cris van Pelt.
4211
4212 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
4213 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
4214 into...
4215 (Invalid inputs): Strengthen: exercise parse_percent_token.
4216
42172002-01-24 Robert Anisko <robert.anisko@epita.fr>
4218
4219 * src/Makefile.am: Add bison.c++.
4220 * src/bison.c++: New skeleton.
4221
42222002-01-21 Paolo Bonzini <bonzini@gnu.org>
4223
4224 * po/it.po: New.
4225
42262002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
4227
4228 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
4229
42302002-01-20 Marc Autret <marc@gnu.org>
4231
4232 * src/files.c (compute_output_file_names): Fix
4233
42342002-01-20 Marc Autret <marc@gnu.org>
4235
4236 * tests/output.at: New test.
4237 * src/files.c (compute_base_names): Don't map extensions when
4238 the YACC flag is set, use defaults.
4239 Reported by Evgeny Stambulchik.
4240
42412002-01-20 Marc Autret <marc@gnu.org>
4242
4243 * src/system.h: Need to define __attribute__ away for non-GCC
4244 compilers as well (i.e. the vendor C compiler).
4245 Suggested by Albert Chin-A-Young.
4246
42472002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
4248
4249 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
4250 canonical definition.
4251 * src/system.h: Use the canonical definition for PARAMS (avoids
4252 a conflict with the macro from lib/hash.h).
4253
42542002-01-11 Akim Demaille <akim@epita.fr>
4255
4256 * configure.in: Use AC_FUNC_STRNLEN.
4257 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
4258
42592002-01-09 Akim Demaille <akim@epita.fr>
4260
4261 * src/files.c, src/files.h (output_infix): New.
4262 (tab_extension): Remove.
4263 (compute_base_names): Compute the former, drop the latter.
4264 * src/output.c (prepare): Insert the muscles `output-infix', and
4265 `output-suffix'.
4266 * src/parse-skel.y (string, string.1): New.
4267 (section.header): Use it.
4268 (section.yacc): Remove.
4269 (prefix): Remove too.
4270 * src/scan-skel.l: Adjust.
4271 * src/bison.simple, src/bison.hairy: Adjust.
4272
42732002-01-09 Akim Demaille <akim@epita.fr>
4274
4275 * configure.in (WERROR_CFLAGS): Compute it.
4276 * src/Makefile.am (CFLAGS): Pass it.
4277 * tests/atlocal.in (CFLAGS): Idem.
4278 * src/files.c: Fix a few warnings.
4279 (get_extension_index): Remove, unused.
4280
42812002-01-08 Akim Demaille <akim@epita.fr>
4282
4283 * src/getargs.c (AS_FILE_NAME): New.
4284 (getargs): Use it to convert DOSish file names.
4285 * src/files.c (base_name): Rename as full_base_name to avoid
4286 clashes with `base_name ()'.
4287 (filename_split): New.
4288 (compute_base_names): N-th rewrite, using filename_split.
4289
42902002-01-08 Akim Demaille <akim@epita.fr>
4291
4292 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
4293 New, stolen from the Fileutils 4.1.
4294 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
4295 * configure.in: Check for the presence of memrchr, and of its
4296 prototype.
4297
42982002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
4299
4300 * lib/hash.h (__P): Added definition for this macro.
4301 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
4302 BUILT_SOURCES, to ensure they are generated first.
4303 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
4304 %error-verbose to allow bootstrapping with bison 1.30x.
4305
43062002-01-06 Akim Demaille <akim@epita.fr>
4307
4308 * src/reader.c (parse_braces): Don't fetch the next char, the
4309 convention is to fetch on entry.
4310 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
4311 'switch' without a following semicolon.
4312 * tests/regression.at (braces parsing): New.
4313
43142002-01-06 Akim Demaille <akim@epita.fr>
4315
4316 Bison is dead wrong in its RR conflict reports.
4317
4318 * tests/torture.at (GNU Cim Grammar): New.
4319 * src/conflicts.c (count_rr_conflicts): Fix.
4320
43212002-01-06 Akim Demaille <akim@epita.fr>
4322
4323 Creating package.m4 from configure.ac causes too many problems.
4324
4325 * tests/Makefile.am (package.m4): Create it by hand,
4326 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
4327
43282002-01-06 Akim Demaille <akim@epita.fr>
4329
4330 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
4331 skeleton.h.
4332
43332002-01-04 Paul Eggert <eggert@twinsun.com>
4334
4335 * doc/bison.texinfo (Debugging):
4336 Remove YYSTDERR; it's no longer defined or used.
4337 Also, s/cstdio.h/cstdio/.
4338
43392002-01-03 Akim Demaille <akim@epita.fr>
4340
4341 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
4342
43432002-01-03 Akim Demaille <akim@epita.fr>
4344
4345 * src/parse-skel.y (process_skeleton): Don't bind the parser's
4346 tracing code to --trace, wait for a better --trace option, with
4347 args.
4348
43492002-01-03 Akim Demaille <akim@epita.fr>
4350
4351 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
4352 The ISO C++ standard is extremely clear about it: stderr is
4353 considered a macro, not a regular symbol (see table 94 `Header
4354 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
4355 Therefore std:: does not apply to it. It still does with fprintf.
4356 Also, s/cstdio.h/cstdio/.
4357
43582002-01-03 Akim Demaille <akim@epita.fr>
4359
4360 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
4361 for non system headers.
4362
43632002-01-02 Akim Demaille <akim@epita.fr>
4364
4365 Equip the skeleton chain with location tracking, runtime trace,
4366 pure parser and scanner.
4367
4368 * src/parse-skel.y: Request a pure parser, locations, and prefix
4369 renaming.
4370 (%union): Having several members with the same type does not help
4371 type mismatches, simplify.
4372 (YYPRINT, yyprint): New.
4373 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
4374 (skel_error): this.
4375 Handle locations.
4376 * src/scan-skel.l: Adjust to these changes.
4377 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
4378 (LOCATION_PRINT, skel_control_t): New.
4379
43802001-12-30 Akim Demaille <akim@epita.fr>
4381
4382 * src/parse-skel.y: Get rid of the shift/reduce conflict:
4383 replace `gb' with BLANKS.
4384 * src/scan-skel.l: Adjust.
4385
43862001-12-30 Akim Demaille <akim@epita.fr>
4387
4388 * src/system.h: We don't need nor want bcopy.
4389 Throw away MS-DOS crap: we don't need getpid.
4390 * configure.in: We don't need strndup. It was even causing
4391 problems: because Flex includes the headers *before* us,
4392 _GNU_SOURCE is not defined by config.h, and therefore strndup was
4393 not visible.
4394 * lib/xstrndup.c: New.
4395 * src/scan-skel.l: Use it.
4396 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
4397 * src/parse-skel.y: Use %directives instead of #defines.
4398
43992001-12-30 Akim Demaille <akim@epita.fr>
4400
4401 * src/skeleton.h: New.
4402 * src/output.c (output_parser, output_master_parser): Remove, dead
4403 code.
4404 * src/output.h (get_lines_number, actions_output, guards_output)
4405 (token_definitions_output): Prototype them.
4406 * src/parse-skel.y: Add the license notice.
4407 Include output.h and skeleton.h.
4408 (process_skeleton): Returns void, and takes a single parameter.
4409 * src/scan-skel.l: Add the license notice.
4410 Include skeleton.h.
4411 Don't use %option yylineno: it seems that then Flex imagines
4412 REJECT has been used, and therefore it won't reallocate its
4413 buffers (which makes no other sense to me than a bug). It results
4414 in warnings for `unused: yy_flex_realloc'.
4415
44162001-12-30 Robert Anisko <robert.anisko@epita.fr>
4417
4418 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4419 (MUSCLE_INSERT_PREFIX): ...to there.
4420 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4421 (MUSCLE_INSERT_PREFIX): Move from here...
4422
4423 * src/bison.hairy: Add a section directive. Put braces around muscle
4424 names. This parser skeleton is still broken, but Bison should not
4425 choke on a bad muscle 'syntax'.
4426 * src/bison.simple: Add a section directive. Put braces around muscle
4427 names.
4428
4429 * src/files.h (strsuffix, stringappend): Add declarations.
4430 (tab_extension): Add declaration.
4431 (short_base_name): Add declaration.
4432
4433 * src/files.c (strsuffix, stringappend): No longer static. These
4434 functions are used in the skeleton parser.
4435 (tab_extension): New.
4436 (compute_base_names): Use the computations done in this function
4437 to guess if the generated parsers should have '.tab' in their
4438 names.
4439 (short_base_name): No longer static.
4440
4441 * src/output.c (output_skeleton): New.
4442 (output): Disable call to output_master_parser, and give a try to
4443 a new skeleton handling system.
4444 (guards_output, actions_output): No longer static.
4445 (token_definitions_output, get_lines_number): No longer static.
4446
4447 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
4448
4449 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
4450 parse-skel.y.
4451
4452 * src/parse-skel.y: New file.
4453 * src/scan-skel.l: New file.
4454
44552001-12-29 Akim Demaille <akim@epita.fr>
4456
4457 %name-prefix is broken.
4458
4459 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
4460 Adjust all dependencies.
4461 * tests/headers.at (export YYLTYPE): Strengthen this test: use
4462 %name-prefix.
4463
4464 Renaming yylval but not yylloc is not consistent. Now we do.
4465
4466 * src/bison.simple: Prefix yylloc if used.
4467 * doc/bison.texinfo (Decl Summary): Document that.
4468
44692001-12-29 Akim Demaille <akim@epita.fr>
4470
4471 * doc/bison.texinfo: Promote `%long-directive' over
4472 `%long_directive'.
4473 Remove all references to fixed-output-files, yacc is enough.
4474
44752001-12-29 Akim Demaille <akim@epita.fr>
4476
4477 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
4478 user prologue. These are defaults.
4479 * tests/actions.at (Mid-rule actions): Make sure the user can
4480 define YYDEBUG and YYERROR_VERBOSE.
4481
44822001-12-29 Akim Demaille <akim@epita.fr>
4483
4484 * src/output.c (header_output): Don't forget to export YYLTYPE and
4485 yylloc.
4486 * tests/headers.at (export YYLTYPE): New, make sure it does.
4487 * tests/regression.at (%union and --defines, Invalid CPP headers):
4488 Move to...
4489 * tests/headers.at: here.
4490
44912001-12-29 Akim Demaille <akim@epita.fr>
4492
4493 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
4494
44952001-12-29 Akim Demaille <akim@epita.fr>
4496
4497 * tests/actions.at (Mid-rule actions): Output on a single line
4498 instead of several.
4499
45002001-12-29 Akim Demaille <akim@epita.fr>
4501
4502 * doc/bison.texinfo: Formatting changes.
4503
45042001-12-29 Akim Demaille <akim@epita.fr>
4505
4506 Don't store the token defs in a muscle, just be ready to output it
4507 on command. Now possible via `symbols'. Fixes a memory leak.
4508
4509 * src/output.c (token_definitions_output): New.
4510 (output_parser, header_output): Use it.
4511 * src/reader.c (symbols_save): Remove.
4512
45132001-12-29 Akim Demaille <akim@epita.fr>
4514
4515 * src/bison.simple: Do not provide a default for YYSTYPE and
4516 YYLTYPE before the user's prologue. Otherwise it's hardly... a
4517 default.
4518
45192001-12-29 Akim Demaille <akim@epita.fr>
4520
4521 Mid-rule actions are simply... ignored!
4522
4523 * src/reader.c (readgram): Be sure to attach mid-rule actions to
4524 the empty-rule associated to the dummy symbol, not to the host
4525 rule.
4526 * tests/actions.at (Mid-rule actions): New.
4527
45282001-12-29 Akim Demaille <akim@epita.fr>
4529
4530 Memory leak.
4531
4532 * src/reader.c (reader): Free grammar.
4533
45342001-12-29 Akim Demaille <akim@epita.fr>
4535
4536 Memory leak.
4537
4538 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4539 since it allocates it for each state, although only one is needed.
4540 (allocate_storage): Do it here.
4541
45422001-12-29 Akim Demaille <akim@epita.fr>
4543
4544 * src/options.h, src/options.c (create_long_option_table): Rename
4545 as...
4546 (long_option_table_new): this, with a clearer prototype.
4547 (percent_table): Remove, unused,
4548 * src/getargs.c (getargs): Adjust.
4549
45502001-12-29 Akim Demaille <akim@epita.fr>
4551
4552 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4553 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4554 as states.
4555
45562001-12-29 Akim Demaille <akim@epita.fr>
4557
4558 * src/lalr.c (build_relations): Rename `states' as `states1'.
4559 Sorry, I don't understand exactly what it is, no better name...
4560
45612001-12-29 Akim Demaille <akim@epita.fr>
4562
4563 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4564 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4565 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4566 as rules.
4567
45682001-12-29 Akim Demaille <akim@epita.fr>
4569
4570 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4571 ago.
4572
45732001-12-29 Akim Demaille <akim@epita.fr>
4574
4575 * src/reader.c, src/reader.h (user_toknums): Remove.
4576 Adjust all users to use symbols[i]->user_token_number.
4577
45782001-12-29 Akim Demaille <akim@epita.fr>
4579
4580 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4581 Adjust all users to use symbols[i]->prec or ->assoc.
4582
45832001-12-29 Akim Demaille <akim@epita.fr>
4584
4585 * src/reader.c, src/reader.h (tags): Remove.
4586 Adjust all users to use symbols[i]->tag.
4587
45882001-12-29 Akim Demaille <akim@epita.fr>
4589
4590 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4591 and rule_table.
4592 * src/reader.c (packsymbols): Fill this table.
4593 Drop sprec.
4594 * src/conflicts.c (resolve_sr_conflict): Adjust.
4595 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4596 single table.
4597 Use symbols[i]->tag instead of tags[i].
4598
45992001-12-29 Akim Demaille <akim@epita.fr>
4600
4601 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4602 In addition, put a comment in there, to replace...
4603 * tests/regression.at (%union and C comments): Remove.
4604
46052001-12-29 Akim Demaille <akim@epita.fr>
4606
4607 * tests/regression.at (Web2c Actions): Blindly move the actual
4608 output as expected output. The contents *seem* right to me, but I
4609 can't pretend reading perfectly parser tables... Nonetheless, all
4610 the other tests pass correctly, the table look OK, even though the
4611 presence of `$axiom' is to be noted: AFAICS it is useless (but
4612 harmless).
4613
46142001-12-29 Akim Demaille <akim@epita.fr>
4615
4616 * src/reader.c (readgram): Don't add the rule 0 if there were no
4617 rules read. In other words, add it _after_ having performed
4618 grammar sanity checks.
4619 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4620
46212001-12-29 Akim Demaille <akim@epita.fr>
4622
4623 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4624 visible, and some states have now a different number.
4625
46262001-12-29 Akim Demaille <akim@epita.fr>
4627
4628 * src/reader.c (readgram): Bind the initial rule's lineno to that
4629 of the first rule.
4630 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4631 (Solved SR Conflicts): Adjust rule 0's line number.
4632
46332001-12-29 Akim Demaille <akim@epita.fr>
4634
4635 Fix the `GAWK Grammar' failure.
4636
4637 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4638 the reductions of the first state which was mistakenly confused
4639 with the final state because precisely final_state was initialized
4640 to 0.
4641 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4642 now noticed by Bison.
4643 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4644 have a reduction on $default.
4645
46462001-12-29 Akim Demaille <akim@epita.fr>
4647
4648 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4649 rule line numbers.
4650 * src/closure.c (print_closure): Likewise.
4651 * src/derives.c (print_derives): Likewise.
4652 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4653 now.
4654
46552001-12-29 Akim Demaille <akim@epita.fr>
4656
4657 * src/lalr.c (lookaheads_print): New.
4658 (lalr): Call it when --trace-flag.
4659 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4660 are dumped.
4661
46622001-12-29 Akim Demaille <akim@epita.fr>
4663
4664 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4665 when walking through ritem, even via rule->rhs.
4666 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4667 (useful_production, useless_nonterminals): Likewise.
4668 (reduce_grammar_tables): Likewise, plus update nritems.
4669 * src/nullable.c (set_nullable): Likewise.
4670 * src/lalr.c (build_relations): Likewise.
4671 * tests/sets.at (Nullable): Adjust.
4672 Fortunately, now, the $axiom is no longer nullable.
4673
46742001-12-29 Akim Demaille <akim@epita.fr>
4675
4676 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4677 the 0-sentinel.
4678 * src/gram.c (ritem_longest_rhs): Likewise.
4679 * src/reduce.c (nonterminals_reduce): Likewise.
4680 * src/print_graph.c (print_graph): Likewise.
4681 * src/output.c (output_rule_data): Likewise.
4682 * src/nullable.c (set_nullable): Likewise.
4683
46842001-12-29 Akim Demaille <akim@epita.fr>
4685
4686 * src/output.c: Comment changes.
4687
46882001-12-27 Paul Eggert <eggert@twinsun.com>
4689
4690 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4691 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4692 Sparc, as they were causing more porting problems than the
4693 (minor) performance improvement was worth.
4694
4695 Also, catch up with 1.31's YYSTD.
4696
46972001-12-27 Akim Demaille <akim@epita.fr>
4698
4699 * src/output.c (output_gram): Rely on nritems, not the
4700 0-sentinel. See below.
4701 Use -1 as separator, not 0.
4702 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4703 Rely on -1 as separator in yyrhs, instead of 0.
4704 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4705 twice `Now at end of input', therefore there are two lines less to
4706 expect.
4707
47082001-12-27 Akim Demaille <akim@epita.fr>
4709
4710 * tests/regression.at (Unresolved SR Conflicts):
4711 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4712 below.
4713
47142001-12-27 Akim Demaille <akim@epita.fr>
4715
4716 * src/LR0.c (new_state): Recognize the final state by the fact it
4717 is reached by eoftoken.
4718 (insert_start_shifting_state, insert_eof_shifting_state)
4719 (insert_accepting_state, augment_automaton): Remove, since now
4720 these states are automatically computed from the initial state.
4721 (generate_states): Adjust.
4722 * src/print.c: When reporting a rule number to the user, substract
4723 1, so that the axiom rule is rule 0, and the first user rule is 1.
4724 * src/reduce.c: Likewise.
4725 * src/print_graph.c (print_core): For the time being, just as for
4726 the report, depend upon --trace-flags to dump the full set of
4727 items.
4728 * src/reader.c (readgram): Once the grammar read, insert the rule
4729 0: `$axiom: START-SYMBOL $'.
4730 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4731 number of the states has changed (the final state is no longer
4732 necessarily the last), catch up.
4733
47342001-12-27 Akim Demaille <akim@epita.fr>
4735
4736 Try to make the use of the eoftoken valid. Given that its value
4737 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4738 is used instead of > 0 where appropriate, (ii), depend upon nritems
4739 instead of the 0-sentinel.
4740
4741 * src/gram.h, src/gram.c (nritems): New.
4742 Expected to be duplication of nitems, but for the time being...
4743 * src/reader.c (packgram): Assert nritems and nitems are equal.
4744 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4745 * src/closure.c (print_closure, print_fderives): Likewise.
4746 * src/gram.c (ritem_print): Likewise.
4747 * src/print.c (print_core, print_grammar): Likewise.
4748 * src/print_graph.c: Likewise.
4749
47502001-12-27 Akim Demaille <akim@epita.fr>
4751
4752 * src/main.c (main): If there are complains after grammar
4753 reductions, then output the report anyway if requested, then die.
4754 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4755 * src/reader.c (eoftoken): New.
4756 (parse_token_decl): If the token being defined has value `0', it
4757 is the eoftoken.
4758 (packsymbols): No longer hack `tags' to insert `$' by hand.
4759 Be sure to preserve the value of the eoftoken.
4760 (reader): Make sure eoftoken is defined.
4761 Initialize nsyms to 0: now eoftoken is created just like the others.
4762 * src/print.c (print_grammar): Don't special case the eof token.
4763 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4764 lie anyway, albeit pleasant.
4765 * tests/calc.at: Exercise error messages with eoftoken.
4766 Change the grammar so that empty input is invalid.
4767 Adjust expectations.
4768 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4769
47702001-12-27 Akim Demaille <akim@epita.fr>
4771
4772 * configure.in: Check the protos of strchr ans strspn.
4773 Replace strchr if needed.
4774 * src/system.h: Provide the protos of strchr, strspn and memchr if
4775 missing.
4776 * lib/strchr.c: New.
4777 * src/reader.c (symbols_save): Use strchr.
4778
47792001-12-27 Akim Demaille <akim@epita.fr>
4780
4781 * src/print.c, src/print_graph.c (escape): New.
4782 Use it to quote the TAGS outputs.
4783 * src/print_graph.c (print_state): Now errors are in red, and
4784 reductions in green.
4785 Prefer high to wide: output the state number on a line of its own.
4786
47872001-12-27 Akim Demaille <akim@epita.fr>
4788
4789 * src/state.h, src/state.c (reductions_new): New.
4790 * src/LR0.c (set_state_table): Let all the states have a
4791 `reductions', even if reduced to 0.
4792 (save_reductions): Adjust.
4793 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4794 * src/print.c (print_reductions, print_actions): Adjust.
4795 * src/output.c (action_row): Adjust.
4796
47972001-12-27 Akim Demaille <akim@epita.fr>
4798
4799 * src/state.h, src/state.c (errs_new, errs_dup): New.
4800 * src/LR0.c (set_state_table): Let all the states have an errs,
4801 even if reduced to 0.
4802 * src/print.c (print_errs, print_reductions): Adjust.
4803 * src/output.c (output_actions, action_row): Adjust.
4804 * src/conflicts.c (resolve_sr_conflict): Adjust.
4805
48062001-12-27 Akim Demaille <akim@epita.fr>
4807
4808 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4809
48102001-12-27 Akim Demaille <akim@epita.fr>
4811
4812 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4813 * src/print.c: here.
4814 (lookaheadset, shiftset): New, used as additional storage by
4815 print_reductions.
4816 (print_results): Adjust.
4817 (print_shifts, print_gotos, print_errs): New, extracted from...
4818 (print_actions): here.
4819 * src/print_graph.c (print_actions): Remove dead code.
4820
48212001-12-27 Akim Demaille <akim@epita.fr>
4822
4823 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4824 `$n' and `@n'.
4825
48262001-12-27 Akim Demaille <akim@epita.fr>
4827
4828 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4829 (build_relations): Adjust.
4830
48312001-12-27 Akim Demaille <akim@epita.fr>
4832
4833 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4834 duplication.
4835
48362001-12-27 Akim Demaille <akim@epita.fr>
4837
4838 * src/reader.c (packgram): Catch nitems overflows.
4839
48402001-12-27 Akim Demaille <akim@epita.fr>
4841
4842 * src/files.c, src/files.h (guard_obstack): Remove.
4843 * src/output.c (output): Adjust.
4844 * src/reader.c (parse_braces): New, factoring...
4845 (copy_action, copy_guard): these two which are renamed as...
4846 (parse_action, parse_guard): these.
4847 As a voluntary consequence, using braces around guards is now
4848 mandatory.
4849
48502001-12-27 Akim Demaille <akim@epita.fr>
4851
4852 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
4853 * src/reader.c (symbol_list): `guard' and `guard_line' are new
4854 members.
4855 (symbol_list_new): Adjust.
4856 (copy_action): action_line is the first line, not the last.
4857 (copy_guard): Just as for actions, store the `action' only, not
4858 the switch/case/break flesh.
4859 Don't parse the user action that might follow the guard, let...
4860 (readgram): do it, i.e., now, there can be an action after a
4861 guard.
4862 In other words the guard is just explicitly optional.
4863 (packgram): Adjust.
4864 * src/output.c (guards_output): New.
4865 (output_parser): Call it when needed.
4866 (output): Also free the guard and attrs obstacks.
4867 * src/files.c, src/files.h (obstack_save): Remove.
4868 (output_files): Remove.
4869 As a result, if one needs the former `.act' file, using an
4870 appropriate skeleton which requires actions and guards is now
4871 required.
4872 * src/main.c (main): Adjust.
4873 * tests/semantic.at: New.
4874 * tests/regression.at: Use `input.y' as input file name.
4875 Avoid 8+3 problems by requiring input.c when the test needs the
4876 parser.
4877
48782001-12-27 Akim Demaille <akim@epita.fr>
4879
4880 * src/reader.c (symbol_list_new): Be sure to initialize all the
4881 fields.
4882
48832001-12-27 Akim Demaille <akim@epita.fr>
4884
4885 All the hacks using a final pseudo state are now useless.
4886
4887 * src/LR0.c (set_state_table): state_table holds exactly nstates.
4888 * src/lalr.c (nLA): New.
4889 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
4890 instead of lookaheadsp from the pseudo state (nstate + 1).
4891
48922001-12-27 Akim Demaille <akim@epita.fr>
4893
4894 * src/output.c (action_row, token_actions): Use a state_t instead
4895 of a integer, and nlookaheads instead of the following state's
4896 lookaheadsp.
4897
48982001-12-27 Akim Demaille <akim@epita.fr>
4899
4900 * src/conflicts.c (log_resolution, flush_shift)
4901 (resolve_sr_conflict, set_conflicts, solve_conflicts)
4902 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
4903 (conflicts_print, print_reductions): Use a state_t instead of an
4904 integer when referring to a state.
4905 As much as possible, depend upon nlookaheads, instead of the
4906 `lookaheadsp' member of the following state (since lookaheads of
4907 successive states are successive, the difference between state n + 1
4908 and n served as the number of lookaheads for state n).
4909 * src/lalr.c (add_lookback_edge): Likewise.
4910 * src/print.c (print_core, print_actions, print_state)
4911 (print_results): Likewise.
4912 * src/print_graph.c (print_core, print_actions, print_state)
4913 (print_graph): Likewise.
4914 * src/conflicts.h: Adjust.
4915
49162001-12-27 Akim Demaille <akim@epita.fr>
4917
4918 * src/bison.hairy: Formatting/comment changes.
4919 ANSIfy.
4920 Remove `register' indications.
4921 Add plenty of `static'.
4922
49232001-12-27 Akim Demaille <akim@epita.fr>
4924
4925 * src/output.c (prepare): Drop the muscle `ntbase' which
4926 duplicates ntokens.
4927 * src/bison.simple: Formatting/comment changes.
4928 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
4929 is an undocumented synonym.
4930
49312001-12-22 Akim Demaille <akim@epita.fr>
4932
4933 * src/output.c (output_table_data): Change the prototype to use
4934 `int' for array ranges: some invocations do pass an int, not a
4935 short.
4936 Reported by Wayne Green.
4937
49382001-12-22 Akim Demaille <akim@epita.fr>
4939
4940 Some actions of web2c.y are improperly triggered.
4941 Reported by Mike Castle.
4942
4943 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
4944 * tests/regression.at (Web2c): Rename as...
4945 (Web2c Report): this.
4946 (Web2c Actions): New.
4947
49482001-12-22 Akim Demaille <akim@epita.fr>
4949
4950 Reductions in web2c.y are improperly reported.
4951 Reported by Mike Castle.
4952
4953 * src/conflicts.c (print_reductions): Fix.
4954 * tests/regression.at (Web2c): New.
4955
49562001-12-18 Akim Demaille <akim@epita.fr>
4957
4958 Some host fail on `assert (!"foo")', which expands to
4959 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
4960 Reported by Nelson Beebee.
4961
4962 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
4963 `#define it_succeeded 0' and `assert (it_succeeded)'.
4964
49652001-12-17 Marc Autret <autret_m@epita.fr>
4966
4967 * src/bison.simple: Don't hard code the skeleton line and filename.
4968 * src/output.c (output_parser): Rename 'line' as 'output_line'.
4969 New line counter 'skeleton_line' (skeleton-line muscle).
4970
49712001-12-17 Paul Eggert <eggert@twinsun.com>
4972
4973 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
4974 YYDEBUG must be defined to a nonzero value.
4975
4976 * src/bison.simple (yytname): Do not assume that the user defines
4977 YYDEBUG to a properly parenthesized expression.
4978
49792001-12-17 Akim Demaille <akim@epita.fr>
4980
4981 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
4982 nlookaheads is a new member.
4983 Adjust all users.
4984 * src/lalr.h (nlookaheads): Remove this orphan declaration.
4985 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
4986 state.
4987
49882001-12-17 Akim Demaille <akim@epita.fr>
4989
4990 * src/files.h, src/files.c (open_files, close_files): Remove.
4991 * src/main.c (main): Don't open/close files, nor invoke lex_free,
4992 let...
4993 * src/reader.c (reader): Do it.
4994
49952001-12-17 Akim Demaille <akim@epita.fr>
4996
4997 * src/conflicts.c (print_reductions): Formatting changes.
4998
49992001-12-17 Akim Demaille <akim@epita.fr>
5000
5001 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5002 (flush_reduce): New.
5003 (resolve_sr_conflict): Adjust.
5004
50052001-12-17 Akim Demaille <akim@epita.fr>
5006
5007 * src/output.c (output_obstack): Be static and rename as...
5008 (format_obstack): this, to avoid any confusion with files.c's
5009 output_obstack.
5010 * src/reader.h (muscle_obstack): Move to...
5011 * src/output.h: here, since it's defined in output.c.
5012
50132001-12-17 Akim Demaille <akim@epita.fr>
5014
5015 * src/output.c (action_row, save_column, default_goto)
5016 (sort_actions, matching_state, pack_vector): Better variable
5017 locality.
5018
50192001-12-17 Akim Demaille <akim@epita.fr>
5020
5021 * src/output.c: Various formatting changes.
5022
50232001-12-17 Akim Demaille <akim@epita.fr>
5024
5025 * src/files.c (output_files): Free the output_obstack.
5026 * src/main.c (main): Call print and print_graph conditionally.
5027 * src/print.c (print): Work unconditionally.
5028 * src/print_graph.c (print_graph): Work unconditionally.
5029 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5030
50312001-12-16 Marc Autret <autret_m@epita.fr>
5032
5033 * src/output.c (actions_output): Fix. When we use %no-lines,
5034 there is one less line per action.
5035
50362001-12-16 Marc Autret <autret_m@epita.fr>
5037
5038 * src/bison.simple: Remove a useless #line directive.
5039 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5040 * src/output.c (get_lines_number): New.
5041 (output_parser): Adjust, now takes care about the lines of a
5042 output muscles.
5043 Fix line numbering.
5044 (actions_output): Computes the number of lines taken by actions.
5045 (output_master_parser): Insert new skeleton which is the name of
5046 the output parser file name.
5047
50482001-12-15 Marc Autret <autret_m@epita.fr>
5049
5050 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5051
50522001-12-15 Marc Autret <autret_m@epita.fr>
5053
5054 * src/output.c (output_gram): Keep track of the hairy one.
5055
50562001-12-15 Akim Demaille <akim@epita.fr>
5057
5058 Make `make distcheck' work.
5059
5060 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5061 system.h which uses libgettext.h.
5062
50632001-12-15 Akim Demaille <akim@epita.fr>
5064
5065 * src/nullable.c (set_nullable): Useless rules must be skipped,
5066 otherwise, since we range over their symbols, we might look at a
5067 nonterminal which no longer ``exists'', i.e., it is not counted in
5068 `nvars', hence we overflow our arrays.
5069
50702001-12-15 Akim Demaille <akim@epita.fr>
5071
5072 The header can also be produced directly, without any obstack!
5073 Yahoo!
5074
5075 * src/files.c, src/files.h (defines_obstack): Remove.
5076 (compute_header_macro): Global.
5077 (defines_obstack_save): Remove.
5078 * src/reader.c (parse_union_decl): No longer output to
5079 defines_obstack: its content can be found in the `stype' muscle
5080 anyway.
5081 (output_token_translations): Merge into...
5082 (symbols_output): this.
5083 Rename as...
5084 (symbols_save): this.
5085 (reader): Adjust.
5086 * src/output.c (header_output): New.
5087 (output): Call it.
5088
50892001-12-15 Akim Demaille <akim@epita.fr>
5090
5091 * src/reader.c (parse_union_decl): Instead of handling two obstack
5092 simultaneously, use one to define the `stype' muscle, and use the
5093 value of the latter to fill defines_obstack.
5094 (copy_comment): Remove.
5095 (copy_comment2): Work for a single obstack.
5096 Rename as...
5097 (copy_comment): this.
5098
50992001-12-15 Akim Demaille <akim@epita.fr>
5100
5101 * src/lex.c, src/lex.h (xgetc): No longer static.
5102 * src/reader.c (parse_union_decl): Revamp.
5103
51042001-12-15 Akim Demaille <akim@epita.fr>
5105
5106 Still making progress in separating Bison into (i) input, (ii)
5107 process, (iii) output: now we can directly output the parser file
5108 without using table_obstack at all.
5109
5110 * src/files.c, src/files.h (table_obstack): Bye bye.
5111 (parser_file_name): New.
5112 * src/files.c (compute_output_file_names): Compute it.
5113 * src/output.c (actions_output, output_parser)
5114 (output_master_parser): To a file instead of an obstack.
5115
51162001-12-15 Akim Demaille <akim@epita.fr>
5117
5118 Attach actions to rules, instead of pre-outputting them to
5119 actions_obstack.
5120
5121 * src/gram.h (rule_t): action and action_line are new members.
5122 * src/reader.c (symbol_list): Likewise.
5123 (copy_action): Save the actions within the rule.
5124 (packgram): Save them in rule_table.
5125 * src/output.c (actions_output): New.
5126 (output_parser): Use it on `%%actions'.
5127 (output_rule_data): Don't free rule_table.
5128 (output): Do it.
5129 (prepare): Don't save the `action' muscle.
5130 * src/bison.simple: s/%%action/%%actions/.
5131
51322001-12-15 Akim Demaille <akim@epita.fr>
5133
5134 * src/reader.c (copy_action): When --yacc, don't append a `;'
5135 to the user action: let it fail if lacking.
5136 Suggested by Arnold Robbins and Tom Tromey.
5137
51382001-12-14 Akim Demaille <akim@epita.fr>
5139
5140 * src/lex.c (literalchar): Simply return the char you decoded, non
5141 longer mess around with obstacks and int pointers.
5142 Adjust all callers.
5143
51442001-12-14 Akim Demaille <akim@epita.fr>
5145
5146 * src/lex.c (literalchar): Don't escape the special characters,
5147 just decode them, and keep them as char (before, eol was output as
5148 the 2 char string `\n' etc.).
5149 * src/output.c (output_rule_data): Use quotearg to output the
5150 token strings.
5151
51522001-12-13 Paul Eggert <eggert@twinsun.com>
5153
5154 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
5155 Do not infringe on the global user namespace when using C++.
5156 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
5157 All uses of `fprintf' and `stderr' changed.
5158
5159 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
5160
51612001-12-13 Akim Demaille <akim@epita.fr>
5162
5163 The computation of nullable is broken: it doesn't handle empty
5164 RHS's properly.
5165
5166 * tests/torture.at (GNU AWK Grammar): New.
5167 * tests/sets.at (Nullable): New.
5168 * src/nullable.c (set_nullable): Instead of blindly looping over
5169 `ritems', loop over the rules, and then over their rhs's.
5170
5171 Work around Autotest bugs.
5172
5173 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
5174 frame, because Autotest understand lines starting with a `+' as
5175 traces from the shell. Then, they are not processed properly.
5176 Admittedly an Autotest bug, but we don't have time to wait for
5177 Autotest to catch up.
5178 * tests/regression.at (Broken Closure): Adjust to the new table
5179 frames.
5180 Move to...
5181 * tests/sets.at: here.
5182
51832001-12-13 Akim Demaille <akim@epita.fr>
5184
5185 * src/closure.c (closure): Use nrules instead of playing tricks
5186 with BITS_PER_WORD.
5187
51882001-12-13 Akim Demaille <akim@epita.fr>
5189
5190 * src/print.c (print_actions): Output the handling of `$' as the
5191 traces do: shifting the token EOF. Before EOF was treated as a
5192 nonterminal.
5193 * tests/regression.at: Adjust some tests.
5194 * src/print_graph.c (print_core): Complete the set of items via
5195 closure. The next-to-final and final states are still unsatisfying,
5196 but that's to be addressed elsewhere.
5197 No longer output the rule numbers, but do output the state number.
5198 A single loop for the shifts + gotos is enough, but picked a
5199 distinct color for each.
5200 (print_graph): Initialize and finalize closure.
5201
52022001-12-13 Akim Demaille <akim@epita.fr>
5203
5204 * src/reader.c (readgram): Remove dead code, an strip useless
5205 braces.
5206 (get_type): Remove, unused.
5207
52082001-12-12 Akim Demaille <akim@epita.fr>
5209
5210 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
5211 on that of lib/error.c.
5212
52132001-12-12 Akim Demaille <akim@epita.fr>
5214
5215 Some hosts don't like `/' in includes.
5216
5217 * src/system.h: Include libgettext.h without qualifying the path.
5218 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
5219 $(top_srcdir).
5220
52212001-12-11 Marc Autret <autret_m@epita.fr>
5222
5223 * src/output.c (output_parser): Remove useless muscle.
5224
52252001-12-11 Marc Autret <autret_m@epita.fr>
5226
5227 * src/bison.simple: Remove #line just before %%epilogue. It
5228 is now handled in ...
5229 * src/reader.c (read_additionnal_code): Add the output of a
5230 #line for the epilogue.
5231
52322001-12-10 Marc Autret <autret_m@epita.fr>
5233
5234 * src/reader.c (copy_definition): Re-use CPP-outed code which
5235 replace precedent remove.
5236 * src/bison.simple: Remove #line before %%prologue because
5237 %%input-line is wrong at this time.
5238
52392001-12-10 Marc Autret <autret_m@epita.fr>
5240
5241 * src/reader.c (symbols_output): Clean up.
5242 * src/output.c (output_gram, output): Clean up.
5243
52442001-12-10 Akim Demaille <akim@epita.fr>
5245
5246 * src/lalr.c (initialize_lookaheads): New. Extracted from...
5247 * src/LR0.c (set_state_table): here.
5248 * src/lalr.c (lalr): Call it.
5249
52502001-12-10 Akim Demaille <akim@epita.fr>
5251
5252 * src/state.h (shifts): Remove the `number' member: shifts are
5253 attached to state, hence no longer need to be labelled with a
5254 state number.
5255
52562001-12-10 Akim Demaille <akim@epita.fr>
5257
5258 Now that states have a complete set of members, the linked list of
5259 shifts is useless: just fill directly the state's shifts member.
5260
5261 * src/state.h (shifts): Remove the `next' member.
5262 * src/LR0.c (first_state, last_state): Remove.
5263 Adjust the callers.
5264 (augment_automaton): Don't look for the shifts that must be added
5265 a shift on EOF: it is those of the state we looked for! But now,
5266 since shifts are attached, it is no longer needed to looking
5267 merely by its id: its number.
5268
52692001-12-10 Akim Demaille <akim@epita.fr>
5270
5271 * src/LR0.c (augment_automaton): Better variable locality.
5272 Remove an impossible branch: if there is a state corresponding to
5273 the start symbol being shifted, then there is shift for the start
5274 symbol from the initial state.
5275
52762001-12-10 Akim Demaille <akim@epita.fr>
5277
5278 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
5279 only when appropriate: when insert_start_shifting_state' is not
5280 invoked.
5281 * tests/regression.at (Rule Line Numbers): Adjust.
5282
52832001-12-10 Akim Demaille <akim@epita.fr>
5284
5285 * src/LR0.c (augment_automaton): Now that all states have shifts,
5286 merge the two cases addition shifts to the initial state.
5287
52882001-12-10 Akim Demaille <akim@epita.fr>
5289
5290 * src/lalr.c (set_state_table): Move to...
5291 * src/LR0.c: here.
5292 * src/lalr.c (lalr): Don't call it...
5293 * src/LR0.c (generate_states): do it.
5294 * src/LR0.h (first_state): Remove, only the table is used.
5295
52962001-12-10 Akim Demaille <akim@epita.fr>
5297
5298 * src/LR0.h (first_shift, first_reduction): Remove.
5299 * src/lalr.c: Don't use first_shift: find shifts through the
5300 states.
5301
53022001-12-10 Akim Demaille <akim@epita.fr>
5303
5304 * src/LR0.c: Attach shifts to states as soon as they are
5305 computed.
5306 * src/lalr.c (set_state_table): Instead of assigning shifts to
5307 state, just assert that the mapping was properly done.
5308
53092001-12-10 Akim Demaille <akim@epita.fr>
5310
5311 * src/LR0.c (insert_start_shift): Rename as...
5312 (insert_start_shifting_state): this.
5313 (insert_eof_shifting_state, insert_accepting_state): New.
5314 (augment_automaton): Adjust.
5315 Better locality of the variables.
5316 When looking if the start_symbol is shifted from the initial
5317 state, using `while (... symbol != start_symbol ...)' sounds
5318 better than `while (... symbol < start_symbol ...)': If fail
5319 to see how the order between symbols could be relevant!
5320
53212001-12-10 Akim Demaille <akim@epita.fr>
5322
5323 * src/getargs.h: Don't declare `spec_name_prefix' and
5324 `spec_file_prefix', declared by src/files.h.
5325 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
5326 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
5327 * src/output.c (prepare): Adjust.
5328 * src/reader.c (symbols_output): Likewise.
5329 * src/vmsgetargs.c: Vaguely adjust, but who cares?
5330
53312001-12-10 Akim Demaille <akim@epita.fr>
5332
5333 * src/muscle_tab.c (muscle_init): NULL is a better default than
5334 `"0"'.
5335
53362001-12-10 Akim Demaille <akim@epita.fr>
5337
5338 * src/reader.c (reader): Calling symbols_output once is enough.
5339
53402001-12-10 Akim Demaille <akim@epita.fr>
5341
5342 Now that states have a complete set of members, the linked list of
5343 reductions is useless: just fill directly the state's reductions
5344 member.
5345
5346 * src/state.h (struct reductions): Remove member `number' and
5347 `next'.
5348 * src/LR0.c (first_reduction, last_reduction): Remove.
5349 (save_reductions): Don't link the new reductions, store them in
5350 this_state.
5351 * src/lalr.c (set_state_table): No need to attach reductions to
5352 states, it's already done.
5353 * src/output.c (output_actions): No longer free the shifts, then
5354 the reductions, then the states: free all the states and their
5355 members.
5356
53572001-12-10 Akim Demaille <akim@epita.fr>
5358
5359 * src/options.c (OPTN, DRTV, BOTH): New.
5360 (option_table): Use them.
5361
5362 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
5363 the job of system.h.
5364 * src/options.c: Don't include stdio.h and xalloc.h for the same
5365 reasons.
5366
53672001-12-10 Akim Demaille <akim@epita.fr>
5368
5369 * src/output.c (output, prepare): Make sure the values of the
5370 muscles `action' and `prologue' are 0-terminated.
5371
53722001-12-10 Akim Demaille <akim@epita.fr>
5373
5374 Clean up GCC warnings.
5375
5376 * src/reader.c (copy_action): `buf' is not used.
5377 (parse_skel_decl): Be static.
5378 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
5379 * src/options.h (create_long_option_table): Have a real prototype.
5380 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
5381 (hash_delete_at): Return const void *.
5382 Adjust casts to preserve the const.
5383
53842001-12-10 Akim Demaille <akim@epita.fr>
5385
5386 * configure.in: Require 2.52g.
5387 M4 is not needed, but AUTOM4TE is.
5388 * m4/m4.m4: Remove.
5389 * tests/Makefile.am: Adjust.
5390
53912001-12-10 Akim Demaille <akim@epita.fr>
5392
5393 One structure for states is enough, even though theoretically
5394 there are LR(0) states and LALR(1) states.
5395
5396 * src/lalr.h (state_t): Remove.
5397 (state_table): Be state_t **, not state_t *.
5398 * src/state.h (core, CORE_ALLOC): Rename as...
5399 (state_t, STATE_ALLOC): this.
5400 Add the LALR(1) members: shifts, reductions, errs.
5401 * src/LR0.c (state_table): Rename as...
5402 (state_hash): this, to avoid name clashes with the global
5403 `state_table'.
5404 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
5405 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
5406
54072001-12-10 Akim Demaille <akim@epita.fr>
5408
5409 Bison dumps core on bash.y.
5410 Reported by Pascal Bart.
5411
5412 * src/warshall.c (bitmatrix_print): New.
5413 (TC): Use it.
5414 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
5415 j must be the outer loop.
5416 * tests/regression.at (Broken Closure): New.
5417
54182001-12-05 Akim Demaille <akim@epita.fr>
5419
5420 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
5421 its argument.
5422