]> git.saurik.com Git - bison.git/blame - ChangeLog
Avoid over-quoting of __line__ and __file.
[bison.git] / ChangeLog
CommitLineData
6e649e65
PE
12002-11-15 Paul Eggert <eggert@twinsun.com>
2
b25d88f6
PE
3 * tests/actions.at (Actions after errors): New test case.
4
6e649e65
PE
5 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
6 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
7 tests/action.at, tests/calc.at, tests/conflicts.at,
8 tests/cxx-type.at, tests/regression.at:
9 "parse error" -> "syntax error" for POSIX compatibility.
10 "parsing stack overflow..." -> "parser stack overflow" so
11 that code matches Bison documentation.
12
0f39aab9
AD
132002-11-15 Akim Demaille <akim@epita.fr>
14
15 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
16 take two BRACED_CODE, not two string_content.
17 Free the scanner's obstack when we are done.
18 (code_content): New.
19 * tests/calc.at: Adjust.
20 * doc/bison.texinfo: Adjust.
21 Also, make sure to include the `,' for these declarations.
22
761c1926
AD
232002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
24
25 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
26 definition; avoids potential autoreconf problems.
27
b0f98b10
AD
282002-11-15 Akim Demaille <akim@epita.fr>
29
30 Always check the value returned by yyparse.
31
32 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
33 returned by yyparse.
34 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
35 Adjust calls.
36 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
37 returned by yyparse.
38
970785f1
PH
392002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
40
41 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
42 on input.at test.
43
8fcc7db1
PE
442002-11-14 Paul Eggert <eggert@twinsun.com>
45
7ec1b48e
PE
46 * src/output.c (output_skeleton): Call xfopen instead of
47 duplicating xfopen's body.
48
cfff7583
PE
49 Fix bugs reported by Nelson H. F. Beebe in
50 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
51
8fcc7db1
PE
52 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
53 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
54 Group compiler. Instead, use "$CC -E bar.c". Include the .h
55 file twice in the grammar, as an extra check.
56
57 * tests/input.at (Torturing the Scanner): Surround the
58 backslash-newline tests with "#if 0", to make it less likely that
59 we'll run into compiler bugs. Bring back solitary \ inside
60 comment, but add a closing comment to work around HP C bug. Don't
61 test backslash-newline in C character constant. This should fix
62 the input.at bug reported by Nelson H. F. Beebe in
63 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
64
4e8d992c
AD
652002-11-14 Akim Demaille <akim@epita.fr>
66
67 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
68 status of the compiler.
f32b346d 69 Calling `exit 1' is no longer needed.
4e8d992c
AD
70 Reported by Nelson H. F. Beebe.
71
9501dc6e
AD
722002-11-14 Akim Demaille <akim@epita.fr>
73
74 * tests/atlocal.in (CPPFLAGS): We have config.h.
75 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
76 New.
77 * tests/actions.at, tests/calc.at, tests/conflicts.at,
78 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
79 * tests/regression.at, tests/torture.at: Use them for all the
80 grammars that are to be compiled.
81 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
82 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
83 * doc/bison.texinfo (GLR Parsers): Document `inline'.
84
18b519c0
AD
852002-11-14 Akim Demaille <akim@epita.fr>
86
87 * doc/bison.texinfo: Various formatting changes (alignments in
88 samples, additional @group/@end group, GCS in samples.
89 Use @deffn instead of simple @table to define the directives,
90 macros, variables etc.
91
9a86cdb9
PE
922002-11-13 Paul Eggert <eggert@twinsun.com>
93
daa33def
PE
94 Fix some bugs reported by Albert Chin-A-Young in
95 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
18b519c0 96
daa33def 97 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
8fcc7db1 98 -o c"; the HP C compiler chatters during compilation.
daa33def
PE
99 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
100 * tests/headers.at (export YYLTYPE): Likewise.
101
102 * tests/input.at (Torturing the Scanner): Remove lines containing
8fcc7db1 103 solitary backslashes, as they tickle a bug in the HP C compiler.
daa33def 104
9a86cdb9
PE
105 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
106 comments, since they're not portable. Use GNU coding style.
107
9c1e26bd
AD
1082002-11-13 Akim Demaille <akim@epita.fr>
109
110 * data/yacc.c: Leave bigger chunks of quoted text.
111 (YYDSYMPRINTF): New.
112 Use it to report symbol activities.
113 * data/glr.c (YYDSYMPRINTF): New.
114 Use it.
115
87f721cc
PE
1162002-11-12 Paul Eggert <eggert@twinsun.com>
117
118 Version 1.75b.
119
120 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
121 (yyglrReduce): Return yyok, not 0.
122 This should avoid the enumerated-type warnings reported
123 by Nelson H.F. Beebe in
124 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
125
126 * lib/bbitset.h (BITSET_INLINE): Remove.
127 * lib/bitset.h [! BITSET_INLINE]: Remove.
128 (bitset_set, bitset_reset, bitset_test): Rename local vars
129 to avoid shadowing warnings by GCC.
130
131 * data/glr.c (inline): Remove #define. It's the user's
132 responsibility to #define it away, just like 'const'.
133 This fixes one of the bugs reported by Nelson H.F. Beebe in
134 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
18b519c0 135
87f721cc
PE
136 * Makefile.maint (po-check): Scan .l and .y files instead of the
137 .c and the .h files that they generate. This fixes the bug
138 reported by Tim Van Holder in:
139 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
140 Look for N_ as well as for _. Try to avoid matching #define for
141 N_ and _.
142 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
143 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
144 * src/scan-gram.l: Revamp regular expressions so that " and '
145 do not confuse xgettext.
146
147 * src/struniq.h (struniq_new): Do not declare the return type
148 to be 'const'; this violates the C standard.
149 * src/struniq.c (struniq_new): Likewise.
150
be14ade5
AD
1512002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
152
153 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
154 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
155 linker.
156
05291fbc
AD
1572002-11-12 Akim Demaille <akim@epita.fr>
158
159 * Makefile.maint: Sync with Autoconf:
160 (local_updates): New.
161
1f5fd52e
AD
1622002-11-12 Akim Demaille <akim@epita.fr>
163
164 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
165
283f1e64
AD
1662002-11-12 Akim Demaille <akim@epita.fr>
167
168 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
169 locations.
170
886b69d1
AD
1712002-11-12 Akim Demaille <akim@epita.fr>
172
173 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
174 not yyvalue.
175
3df37415
AD
1762002-11-12 Akim Demaille <akim@epita.fr>
177
178 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
179 Use it to test the GLR parser.
180
7bd6c77e
AD
1812002-11-12 Akim Demaille <akim@epita.fr>
182
183 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
184 defines it.
185 * data/glr.c (yystos): New.
186 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
187 (YYDSYMPRINT): New.
188 (yyval): Don't define it, it is handled via M4.
189 (yyrecoverParseError): Free verbosely the discarded symbols.
190 * data/yacc.c (yysymprint): Remove, rather...
191 (b4_yysymprint_generate): invoke.
192 * data/c.m4 (b4_yysymprint_generate): New.
193 Accept pointers as arguments, as opposed to the version from
194 yacc.c.
195 (b4_yydestruct_generate): Likewise.
196 * tests/cations.at (Printers and Destructors): Use Bison directives
197 instead of CPP macros.
198 Don't rely on internal details.
199
b0400cc6
AD
2002002-11-12 Akim Demaille <akim@epita.fr>
201
202 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
203 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
204 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
205 it against YYEMPTY and so forth), work on yytoken (i.e., set
206 it to YYEMPTY etc.).
207 (yydestruct): Replace with a b4_yydestruct_generate invocation.
208 (b4_symbol_actions): Remove.
209 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
210 for 0, end-of-input.
211
72f889cc
AD
2122002-11-12 Akim Demaille <akim@epita.fr>
213
214 * doc/bison.texinfo (Destructor Decl): New.
215
b1ae9233
AD
2162002-11-12 Akim Demaille <akim@epita.fr>
217
218 * src/tables.c (tables_generate): Use free for pointers that
219 cannot be NULL, not XFREE.
220 (pack_vector): Use assert, not fatal, for bound violations.
221 * src/state.c (state_new): Likewise.
222 * src/reader.c (reader): Likewise.
223 * src/lalr.c (set_goto_map): Likewise.
72f889cc 224 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
b1ae9233
AD
225 the file name.
226
7ec2d4cd
AD
2272002-11-12 Akim Demaille <akim@epita.fr>
228
229 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
230 Restore.
231 * src/scan-gram.l (last_string): Is global to the file, not to
232 yylex.
233 * src/parse-gram.y (input): Don't append the epilogue here,
234 (epilogue.opt): do it here, and free the scanner's obstack.
235 * src/reader.c (epilogue_set): Rename as...
236 (epilogue_augment): this.
237 * data/c.m4 (b4_epilogue): Defaults to empty.
238
573a6cd3
AD
2392002-11-12 Akim Demaille <akim@epita.fr>
240
241 * src/getargs.c (long_options): Remove duplicates.
242 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
243 Remove.
244 * doc/bison.rnh: Remove.
245 * doc/bison.texinfo (VMS Invocation): Remove.
246
95612cfa
AD
2472002-11-12 Akim Demaille <akim@epita.fr>
248
249 * src/struniq.h, src/struniq.c (struniq_t): Is const.
250 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
251
252 Use struniq for symbols.
253
254 * src/symtab.h (symbol_t): The tag member is a struniq.
255 (symbol_type_set): Adjust.
256 * src/symtab.c (symbol_new): Takes a struniq.
257 (symbol_free): Don't free the tag member.
258 (hash_compare_symbol_t, hash_symbol_t): Rename as...
259 (hash_compare_symbol, hash_symbol): these.
260 Use the fact that tags as struniqs.
261 (symbol_get): Use struniq_new.
262 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
263 Returns a strniq.
264 * src/reader.h (merger_list, grammar_currentmerge_set): The name
265 and type members are struniqs.
266 * src/reader.c (get_merge_function)
267 (grammar_current_rule_merge_set): Adjust.
268 (TYPE, current_type): Are struniq.
269
270 Use struniq for file names.
271
272 * src/files.h, src/files.c (infile): Split into...
273 (grammar_file, current_file): these.
274 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
275 * src/reduce.c (reduce_print): Likewise.
276 * src/getargs.c (getargs): Likewise.
277 * src/complain.h, src/complain.c: Likewise.
278 * src/main.c (main): Call struniqs_new early enough to use it for
279 file names.
280 Don't free the input file name.
281
3e6656f9
AD
2822002-11-12 Akim Demaille <akim@epita.fr>
283
284 * src/symtab.c (symbol_free): Remove dead deactivated code:
285 type_name are properly removed.
286 Don't use XFREE to free items that cannot be NULL.
287 * src/struniq.h, src/struniq.c: New.
288 * src/main.c (main): Initialize/free struniqs.
289 * src/parse-gram.y (%union): Add astruniq member.
290 (yyprint): Adjust.
291 * src/scan-gram.l (<{tag}>): Return a struniq.
292 Free the obstack bit that used to store it.
293 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
294
7672019c
PE
2952002-11-11 Paul Eggert <eggert@twinsun.com>
296
297 Revamp to fix many (but not all) of the C- and M4-related quoting
298 problems. Among other things, this fixes the Bison bug reported
299 by Jan Hubicka when processing the Bash grammar; see:
300 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
301
302 Use new @ escapes consistently. Represent brackets with @{ and @}
303 rather than @<:@ and @:>@, since this works a bit better with dumb
304 editors like vi. Represent @ with @@, since @ is now consistently
305 an escape. Use @oline@ and @ofile@ rather than __oline__ and
306 __ofile__, to avoid unexpected expansions. Similarly, use @output
307 rather than #output.
308
309 * data/c.m4 (b4_copyright): Omit file name from comment, since
310 the file name could contain "*/".
311 (b4_synclines_flag): Don't quote the 2nd argument; it should already
312 be quoted. All uses changed.
313
314 * data/glr.c: Use new @ escapes consistently.
315 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
316 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
317 Remove, since they couldn't handle arbitrary characters in file
318 names.
319 * data/lalr1.cc: Likewise.
320 * data/yacc.c: Likewise.
321
322 * src/files.c (output_infix): Remove; all uses removed.
323 * src/files.h: Likewise.
324
325 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
326 mishandled funny characters in file names, and anyway it isn't
327 needed any more.
328 * data/yacc.c: Likewise.
329 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
330
331 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
332 * data/yacc.c: Likewise.
333
334 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
335 strings now.
336 (muscle_init): Quote filename as a C string.
337 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
338 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
339 * src/output.c (escaped_file_name_output): New function.
340 (prepare_symbols): Quote tokens for M4.
341 (prepare): Don't insert output_infix, output_prefix,
342 output_parser_name, output_header_name; this is now down by scan-skel.
343 Insert skeleton as a C string.
344
345 * src/output.c (user_actions_output, symbol_destructors_output,
346 symbol_printers_output): Quote filenames for C and M4.
347 * src/reader.c (prologue_augment, epilogue_set): Likewise.
348
349 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
350 escapes other than \\ and \'; this simplifies the code.
351 (<SC_STRING>): Likewise, for \\ and \".
352 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
353 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
354 Use new escapes @{ and @} for [ and ].
355
356 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
357 them with auto vars.
358 Switch to new escape scheme, where @ is the escape character uniformly.
359 Abort if a stray escape character is found. Avoid unbounded input
360 buffer when parsing non-escaped text.
361
362 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
363 __oline__, #output, $@, and @{ do not have unintended meanings.
364
acea4f3b
PE
3652002-11-09 Paul Eggert <eggert@twinsun.com>
366
367 Fix the test failure due to GCC warnings described in
368 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
369 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
370 evaluate to 0 if it's impossible for NINF to be in the respective
371 table.
372 (yygetLRActions, yyrecoverParseError): Use them.
373
374 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
375 counted in the token inserted at end of file. Now takes
376 location_t *, not location_t, so that the location can be
377 adjusted. All uses changed.
378
379 * tests/regression.at (Invalid inputs): Adjust wording in
380 diagnostic to match the new behavior.
381
382 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
383 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
384 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
385 abort ();'. This reduces the runtime of the "Many lookaheads"
386 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
387 GCC 3.2.
388
20ef1ad5
PE
3892002-11-07 Paul Eggert <eggert@twinsun.com>
390
391 * src/parse-gram.y (CHARACTER): Remove unused token.
392 All uses removed.
393
394 * src/scan-gram.l: Remove stack option. We no longer use the
395 stack, since the stack was never deeper than 1; instead, use the
396 new auto var c_context to record the stacked value.
397
398 Remove nounput option. At an unexpected end of file, we now unput
399 the minimal input necessary to end cleanly; this simplifies the
400 code.
401
402 Avoid unbounded token sizes where this is easy.
403
404 (unexpected_end_of_file): New function.
405 Use it to systematize the error message on unexpected EOF.
406 (last-string): Now auto, not static.
407 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
408 (scanner_last_string_free): Remove; not used.
409 (percent_percent_count): Move decl to just before use.
410 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
411 not the (never otherwised-used) CHARACTER.
412
93724f13
AD
4132002-11-07 Akim Demaille <akim@epita.fr>
414
415 Let yyerror always receive the msg as last argument, so that
416 yyerror can be variadic.
417
418 * data/yacc.c (b4_yyerror_args): New.
419 Use it when calling yyerror.
420 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
421 Use it when calling yyerror.
422 * doc/bison.texinfo (Error Reporting): Adjust.
423 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
424 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
425
6e40b4eb
AD
4262002-11-06 Akim Demaille <akim@epita.fr>
427
428 #line should have quoted strings.
429 Ideally, this should be done by m4_quotearg.
430
431 * src/scan-skel.l: Include quotearg.h.
432 Quote __ofile__.
433 * src/output.c (symbol_printers_output)
434 (symbol_destructors_output): Quote the file name.
435
2dfbfc12
AD
4362002-11-06 Akim Demaille <akim@epita.fr>
437
438 * tests/regression.at (Invalid inputs): Adjust to the recent
439 messages.
440
437c2d80
AD
4412002-11-06 Akim Demaille <akim@epita.fr>
442
443 Restore --no-lines.
444 Reported by Jim Kent.
445
446 * data/c.m4 (b4_syncline): New.
447 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
448 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
449 * src/output.c (user_actions_output): Likewise.
450 (prepare): Define 'b4_synclines_flag'.
2dfbfc12 451 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
437c2d80 452
900c5db5
AD
4532002-11-06 Akim Demaille <akim@epita.fr>
454
455 * src/main.c (main): Free `infile'.
456 * src/scan-gram.l (handle_syncline): New.
457 Recognize `#line'.
458 * src/output.c (user_actions_output, symbol_destructors_output)
459 (symbol_printers_output): Use the location's file name, not
460 infile.
461 * src/reader.c (prologue_augment, epilogue_set): Likewise.
462
e183b123 4632002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
51b4a04c 464
e183b123 465 * src/tables.c (matching_state): Don't allow states to match if
51b4a04c 466 either has GLR conflict entries.
e183b123 467
193eb6b7
PE
4682002-11-05 Paul Eggert <eggert@twinsun.com>
469
e183b123
PE
470 * src/scan-gram.l: Use more accurate diagnostics, e.g.
471 "integer out of range" rather than "invalid value".
472 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
473 accordingly.
474
193eb6b7
PE
475 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
476 Also, remove one static variable in the scanner.
477
478 * src/scan-gram.l (braces_level): Now auto, not static.
479 Initialize to zero if the compiler is being picky.
480 (INITIAL): Clear braces_level instead of incrementing it.
481 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
482 as POSIX 1003.1-2001 requires.
483 * src/system.h (IF_LINT): New macro, taken from coreutils.
484 * configure.ac: Define "lint" if --enable-gcc-warnings.
485
29c01725
AD
4862002-11-05 Akim Demaille <akim@epita.fr>
487
488 * src/scan-gram.l: When it starts with `%', complain about the
489 whole directive, not just that `invalid character: %'.
490
8aeac3ca
AD
4912002-11-04 Akim Demaille <akim@epita.fr>
492
493 * Makefile.maint: Update from Autoconf.
494 (update, cvs-update, po-update, do-po-update): New.
495
793a58bb
AD
4962002-11-04 Akim Demaille <akim@epita.fr>
497
498 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
499 and yyerror.
500 Have yyerror `use' its arguments.
501 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
502 returns true when location & yacc & pure & parse-param.
503 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
504
c4d720cd
AD
5052002-11-04 Akim Demaille <akim@epita.fr>
506
507 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
508 clashes.
509 * src/scan-gram.l: Use [\'] instead of ['] to pacify
510 font-lock-mode.
511 Use complain_at.
512 Use quote, not quote_n since LOCATION_PRINT no longer uses the
513 slot 0.
514
613a0dc5
PE
5152002-11-03 Paul Eggert <eggert@twinsun.com>
516
517 * src/reader.c (get_merge_function, grammar_current_rule_check):
518 Use consistent diagnostics for reporting type name clashes.
519 Quote the types with <>, for consistency with Yacc.
520 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
521
2a8d363a
AD
5222002-11-03 Akim Demaille <akim@epita.fr>
523
524 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
525 New.
526 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
527 (b4_parse_param): Remove.
528 Use b4_identification.
529 Propagate b4_pure_args where needed to pass them to yyerror.
530 * data/glr.m4 (b4_parse_param): Remove.
531 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
532 (b4_lpure_formals): New.
533 Use b4_identification.
534 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
535 b4_user_formals and b4_user_args.
536 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
537 (yyreportAmbiguity): When using a pure parser, also need
538 the location, and the parse-params.
539 Adjust callers.
540 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
541 When using a pure parser, also need the parse-params.
542 Adjust callers.
543 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
544 (%pure-parser + %parse-param) LALR and GLR parsers.
545 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
546 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
547 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
548 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
549 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
550 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
551 * doc/bison.texinfo: Untabify the whole file.
552 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
553 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
554 (Error Reporting): Adjust to these new directives.
555 Document %error-verbose, deprecate YYERROR_VERBOSE.
556
9e32add8
AD
5572002-11-03 Akim Demaille <akim@epita.fr>
558
559 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
560 AT_CHECK_CALC_GLR invocations to use % directives, instead of
561 command line options.
562 * tests/cxx-type.at: Formatting changes.
563
b02d90a5
PE
5642002-11-03 Paul Eggert <eggert@twinsun.com>
565
566 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
567 to count columns correctly, and to check for invalid inputs.
9e32add8 568
b02d90a5
PE
569 Use mbsnwidth to count columns correctly. Account for tabs, too.
570 Include mbswidth.h.
571 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
572 (extend_location): New function.
573 (YY_LINES): Remove.
574
575 Handle CRLF in C code rather than in Lex code.
576 (YY_INPUT): New macro.
577 (no_cr_read): New function.
578
579 Scan UCNs, even though we don't fully handle them yet.
580 (convert_ucn_to_byte): New function.
581
582 Handle backslash-newline correctly in C code.
583 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
584 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
585 all uses changed.
586 (tag, splice): New EREs. Do not allow NUL or newline in tags.
587 Use {splice} wherever C allows backslash-newline.
588 YY_STEP after space, newline, vertical-tab.
589 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
9e32add8 590
b02d90a5
PE
591 (letter, id): Don't assume ASCII; e.g., spell out a-z.
592
593 ({int}, handle_action_dollar, handle_action_at): Check for integer
594 overflow.
9e32add8 595
b02d90a5
PE
596 (YY_STEP): Omit trailing semicolon, so that it's more like C.
597
598 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
599 as well as \000. Check for UCHAR_MAX, not 255.
600 Allow \x with an arbitrary positive number of digits, as in C.
601 Check for overflow here.
602 Allow \? and UCNs, for compatibility with C.
603
604 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
605 with quote slot used by complain_at.
606
607 * tests/input.at: Add tests for backslash-newline, m4 quotes
608 in symbols, long literals, and funny escapes in strings.
609
610 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
611 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
612 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
613 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
614 * m4/mbswidth.m4: New file, from GNU coreutils.
615
616 * doc/bison.texinfo (Grammar Outline): Document // comments.
617 (Symbols): Document that trigraphs have no special meaning in Bison,
618 nor is backslash-newline allowed.
619 (Actions): Document that trigraphs have no special meaning.
620
621 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
622 no longer used.
623
6242002-11-02 Paul Eggert <eggert@twinsun.com>
625
626 * src/reader.c: Don't include quote.h; not needed.
627 (get_merge_function): Reword warning to be consistent with
628 type clash diagnostic in grammar_current_rule_check.
629
630 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
631 bug in trigraph handling.
632
633 * src/output.c (prepare_symbols): When printing token names,
634 escape "[" as "@<:@" and likewise for "]".
635
636 * src/system.h (errno): Remove declaration, as we are now
637 assuming C89 or better, and C89 guarantees errno.
638
762b212b
PE
6392002-10-30 Paul Eggert <eggert@twinsun.com>
640
641 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
642 Check for close failures.
643 * src/files.h (xfclose): Return void, not int, since it always
644 returned zero.
645 * src/files.c (xfclose): Likewise. Report I/O error if ferror
646 indicates one.
647 * src/output.c (output_skeleton): Use xfclose rather than fclose
648 and ferror. xfclose now checks ferror.
649
650 * data/glr.c (YYLEFTMOST_STATE): Remove.
651 (yyreportTree): Use a stack-based leftmost state. This avoids
652 our continuing battles with bogus warnings about initializers.
653
56100c60
AD
6542002-10-30 Akim Demaille <akim@epita.fr>
655
656 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
657 #if.
658
51b4a04c
PH
6592002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
660
661 * tests/glr-regr1.at: New test for reported regressions.
662 * tests/testsuite.at: Add glr-regr1.at test.
663 * tests/Makefile.am: Add glr-regr1.at test.
e183b123 664
bf1ebda2
PE
6652002-10-24 Paul Eggert <eggert@twinsun.com>
666
5c16c6b1
PE
667 Version 1.75a.
668
bf1ebda2
PE
669 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
670 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
671 we use malloc. Don't assume 'A' through 'Z' are contiguous.
672 Don't assume strdup exists; POSIX says its an XSI extension.
673 Check for buffer overflow on input.
674
b526ee61
AD
6752002-10-24 Akim Demaille <akim@epita.fr>
676
677 * src/output.c (output_skeleton): Don't disable M4sugar comments
678 too soon: it results in comments being expanded.
679 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
680 first output.
681
f1886bb2
AD
6822002-10-24 Akim Demaille <akim@epita.fr>
683
684 * data/yacc.c (m4_int_type): New.
685 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
686 char' as only yacc.c wants K&R portability.
687 * data/glr.c (yysigned_char): Remove.
688 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
689 Reported by Quoc Peyrot.
690
c5576256
PE
6912002-10-23 Paul Eggert <eggert@twinsun.com>
692
693 * src/main.c (main): With --trace=time, report times even if a
694 non-fatal error occurs. Formerly, the times were reported in some
695 such cases but not in others.
696 * src/reader.c (reader): Just return if a complaint has been issued,
697 instead of exiting, so that 'main' can report times.
698
27b0ffea
AD
6992002-10-22 Akim Demaille <akim@epita.fr>
700
701 * src/system.h: Include sys/types.
702 Reported by Bert Deknuydt.
703
223a7883
PE
7042002-10-23 Paul Eggert <eggert@twinsun.com>
705
706 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
707 Suggested by Art Haas.
708
7092002-10-22 Paul Eggert <eggert@twinsun.com>
710
711 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
712 decl; not needed any more.
713 * src/main.c (main): Use return to exit, undoing yesterday's change.
714 The last OS that we could find where this wouldn't work is
715 SunOS 3.5, and that's too old to worry about now.
716
717 * data/glr.c (struct yyltype): Define members even when not
718 doing locations. This is more consistent with yacc.c, and it
719 works around the following bug reports:
720 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
721 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
722 and I hope it also fixes this bug report:
723 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
27b0ffea 724
223a7883
PE
725 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
726 @acronym consistently. Standardize on "Yacc" instead of "YACC",
727 "Algol" instead of "ALGOL". Give a bit more history about BNF.
728
8b76775a
AD
7292002-10-22 Akim Demaille <akim@epita.fr>
730
731 * data/README: New.
732
6db10d14
PE
7332002-10-21 Paul Eggert <eggert@twinsun.com>
734
735 Be consistent about 'bool'; the old code used an enum in one
736 module and an int in another, and this violates the C standard.
737 * m4/stdbool.m4: New file, from coreutils 4.5.3.
738 * configure.ac (AC_HEADER_STDBOOL): Add.
739 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
740 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
741 * src/symtab.c (hash_compare_symbol_t): Likewise.
742 * src/system.h (bool, false, true): Use a definition consistent
743 with ../lib/hash.c. All uses changed.
744
745 * src/complain.c (warning_issued): Renamed from warn_message_count,
746 so that we needn't worry about integer overflow (!).
747 Now of type bool. All uses changed.
748 (complaint_issued): Renamed from complain_message_count; likewise.
749
750 * src/main.c (main): Use exit to exit with failure.
27b0ffea 751
6db10d14
PE
752 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
753 rather than 1 and 0.
754 * src/main.c (main): Likewise.
755 * src/getargs.c (getargs): Likewise.
756 * src/reader.c (reader): Likewise.
757
758 * src/getarg.c (getargs): Remove duplicate code for
759 "Try `bison --help'".
760
761 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
762 What was that "2" for?
763
764 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
765 * src/getargs.c (usage): Likewise.
766
767 * src/getargs.c (getargs): When there are too few operands, report
768 the last one. When there are too many, report the first extra
769 one. This is how diffutils does it.
770
92a060fd
PE
7712002-10-20 Paul Eggert <eggert@twinsun.com>
772
773 Remove K&R vestiges.
774 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
775 * src/complain.c (VA_START): Remove. Assume prototypes.
776 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
777 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
778 fatal): Assume prototypes.
779 * src/complain.h: Assume prototypes.
780 * src/system.h (PARAMS): Remove.
781 Include <limits.h> unconditionally, since it's guaranteeed even
782 for a freestanding C89 compiler.
783 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
784 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 785
e7cb57c0
AD
7862002-10-20 Akim Demaille <akim@epita.fr>
787
788 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
789 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
790 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
791 (yyresolveStates, yyresolveAction, yyresolveStack)
792 (yyprocessOneStack): Use them.
793 (yy_reduce_print): New.
794 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
795
0245f82d
AD
7962002-10-20 Akim Demaille <akim@epita.fr>
797
798 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
799 arguments and output `void'.
800 (b4_c_function): Rename as...
801 (b4_c_function_def): this.
802 (b4_c_function_decl, b4_c_ansi_function_def)
803 (b4_c_ansi_function_decl): New.
804 Change the interpretation of the arguments: before `int, foo', now
805 `int foo, foo'.
806 * data/yacc.c (yyparse): Prototype and define thanks to these.
807 Adjust b4_c_function_def uses.
808 * data/glr.c (yyparse): Likewise, but ANSI only.
809
39912f52
AD
8102002-10-20 Akim Demaille <akim@epita.fr>
811
812 * src/output.c (prepare): Move the definition of `tokens_number',
813 `nterms_number', `undef_token_number', `user_token_number_max'
814 to...
815 (prepare_tokens): Here.
816 (prepare_tokens): Rename as...
817 (prepare_symbols): this.
818 (prepare): Move the definition of `rules_number' to...
819 (prepare_rules): here.
820 (prepare): Move the definition of `last', `final_state_number',
821 `states_number' to...
822 (prepare_states): here.
823 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
824
20c1e2ad
AD
8252002-10-20 Akim Demaille <akim@epita.fr>
826
827 * src/tables.h, src/tables.c, src/output.c: Comment changes.
828
21964f43
AD
8292002-10-20 Akim Demaille <akim@epita.fr>
830
831 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
832 * data/c.m4: here.
833
66d30cd4
AD
8342002-10-20 Akim Demaille <akim@epita.fr>
835
836 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
837 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
838 `pair'.
839 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
840 `name' to...
841 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
842 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
843 These.
844
95f2c9fe
PE
8452002-10-19 Paul Eggert <eggert@twinsun.com>
846
847 Do not create a temporary file, as that involves security and
848 cleanup headaches. Instead, use a pair of pipes.
849 Derived from a suggestion by Florian Krohm.
850 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
851 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
852 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
853 (BISON_PREREQ_SUBPIPE): Add.
854 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
855 Add subpipe.h, subpipe.c.
856 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
857 * po/POTFILES.in: Add lib/subpipe.c.
858 * src/output.c: Include "subpipe.h".
859 (m4_invoke): Remove decl.
860 (scan_skel): New decl.
861 (output_skeleton): Use pipe rather than temporary file for m4 input.
862 Check that m4sugar.m4 is readable, to avoid deadlock.
863 Check for pipe I/O error.
864 * src/scan-skel.l (readpipe): Remove decl.
865 (scan_skel): New function, to be used in place of m4_invoke.
866 Read from stream rather than file.
66d30cd4 867
95f2c9fe
PE
868 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
869 float, as this generates a warning on Solaris 8 + GCC 3.2 with
870 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
871 this generates a more-accurate value anyway.
872
873 * lib/timevar.c (timervar_accumulate): Rename locals to
874 avoid confusion with similarly-named more-global.
875 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
876
877 * src/output.c (prepare): Use xstrdup to convert char const *
878 to char *, to avoid GCC warning.
879
c19988b7
AD
8802002-10-19 Akim Demaille <akim@epita.fr>
881
882 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
883 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
884 Use them to have `calc.y' ready for %pure-parser.
885 * data/yacc.c (YYLEX): Pass a yylex return type to
886 b4_c_function_call.
887
ae7453f2
AD
8882002-10-19 Akim Demaille <akim@epita.fr>
889
890 Prototype support of %lex-param and %parse-param.
891
892 * src/parse-gram.y: Add the definition of the %lex-param and
893 %parse-param tokens, plus their rules.
894 Drop the `_' version of %glr-parser.
895 Add the "," token.
896 * src/scan-gram.l (INITIAL): Scan them.
897 * src/muscle_tab.c: Comment changes.
898 (muscle_insert, muscle_find): Rename `pair' as `probe'.
899 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
900 (muscle_entry_s): The `value' member is no longer const.
901 Adjust all dependencies.
902 * src/muscle_tab.c (muscle_init): Adjust: use
903 MUSCLE_INSERT_STRING.
904 Initialize the obstack earlier.
905 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
906 (muscle_pair_list_grow): New.
907 * data/c.m4 (b4_c_function_call, b4_c_args): New.
908 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
909 * tests/calc.at: Use %locations, not --locations.
910 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
911
0e575721
AD
9122002-10-19 Akim Demaille <akim@epita.fr>
913
914 * src/getargs.c (usage): Take status as argument and exit
915 accordingly.
916 Report the traditional `Try ... --help' message when status != 0.
917 (usage, version): Don't take a FILE * as arg, it is pointless.
918 (getargs): When there is an incorrect number of arguments, make it
919 an error, and report it GNUlically thanks to `usage ()'.
920
724ce7f5
PE
9212002-10-18 Paul Eggert <eggert@twinsun.com>
922
3a781eb2
PE
923 * data/glr.c (yyreportParseError): Don't assume that sprintf
924 yields the length of the printed string, as this is not true
925 on SunOS 4.1.4. Reported by Peter Klein.
926
724ce7f5
PE
927 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
928 * tests/conflicts.at (%nonassoc and eof): Likewise.
929 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
930
473d0a75
AD
9312002-10-17 Akim Demaille <akim@epita.fr>
932
933 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
934 * src/getargs.c (trace_types, trace_args): Adjust.
935 * src/reader.c (grammar_current_rule_prec_set)
936 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
937 Standardize error messages.
938 And s/@prec/%prec/!
939 (reader): Use trace_flag to enable scanner/parser debugging,
940 instead of an adhoc scheme.
941 * src/scan-gram.l: Remove trailing debugging code.
942
e76d2469
PE
9432002-10-16 Paul Eggert <eggert@twinsun.com>
944
93e2236a
PE
945 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
946 MUSCLE_TAB_H.
947
e76d2469
PE
948 * NEWS: Officially drop support for building Bison with K&R C,
949 since it didn't work anyway and it's not worth worrying about.
950 * Makefile.maint (wget_files): Remove ansi2knr.c.
951 (ansi2knr.c-url_prefix): Remove.
952 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
953 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
954 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
955
5bd1c419
PE
9562002-10-15 Paul Eggert <eggert@twinsun.com>
957
958 Stop using the "enum_" trick for K&R-style function definitions;
959 it confused me, and I was the author! Instead, assume that people
960 who want to use K&R C compilers (when using these modules in GCC,
961 perhaps?) will run ansi2knr.
962
963 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
964 All uses of "enum_" changed to "enum ".
965 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
966 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 967
5bd1c419
PE
968 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
969 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
970 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
971 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
972 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
973 abitset_not, abitset_ones, abitset_or, abitset_or_and,
974 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
975 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
976 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
977 Use function prototypes; this removes the need for declaring
978 static functions simply to provide their prototypes.
979 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
980 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
981 bitset_count_, bitset_create, bitset_dump, bitset_first,
982 bitset_free, bitset_init, bitset_last, bitset_next,
983 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
984 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
985 bitset_print, bitset_release_memory, bitset_toggle_,
986 bitset_type_choose, bitset_type_get, bitset_type_name_get,
987 debug_bitset): Likewise.
988 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
989 * lib/bitset_stats.c (bitset_log_histogram_print,
990 bitset_percent_histogram_print, bitset_stats_and,
991 bitset_stats_and_cmp, bitset_stats_and_or,
992 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
993 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
994 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
995 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
996 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
997 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
998 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
999 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1000 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1001 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1002 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1003 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1004 bitset_stats_zero): Likewise.
1005 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1006 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1007 bitsetv_dump, debug_bitsetv): Likewise.
1008 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1009 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1010 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1011 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1012 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1013 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1014 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1015 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1016 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1017 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1018 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1019 Likewise.
1020 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1021 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1022 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1023 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1024 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1025 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1026 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1027 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1028 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1029 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1030 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 1031
ae26e1f0
AD
10322002-10-14 Akim Demaille <akim@epita.fr>
1033
1034 Version 1.75.
1035
d43baf71
AD
10362002-10-14 Akim Demaille <akim@epita.fr>
1037
1038 * tests/Makefile.am (maintainer-check-posix): New.
1039
7ebc83e3
AD
10402002-10-14 Akim Demaille <akim@epita.fr>
1041
1042 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1043 member.
1044
05846dae
AD
10452002-10-14 Akim Demaille <akim@epita.fr>
1046
1047 * src/tables.c (table_ninf_remap): base -> tab.
1048 Reported by Matt Rosing.
1049
1318e37d
PE
10502002-10-14 Paul Eggert <eggert@twinsun.com>
1051
447fbb17
PE
1052 * tests/action.at, tests/calc.at, tests/conflicts.at,
1053 tests/cxx-type.at, tests/headers.at, tests/input.at,
1054 tests/regression.at, tests/synclines.at, tests/torture.at:
1055 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1056 so that the tests still work even if POSIXLY_CORRECT is set.
1057 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 1058
1318e37d
PE
1059 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1060 for portability to K&R hosts. Fix typo: signed char is guaranteed
1061 only to 127, not to 128.
1062 * data/glr.c (yysigned_char): New type.
1063 * data/yacc.c (yysigned_char): Likewise.
1064 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1065
cc0f0794
PE
10662002-10-13 Paul Eggert <eggert@twinsun.com>
1067
5038f418
PE
1068 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1069 true due to limited range of data type" warning from GCC.
1070
cc0f0794
PE
1071 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1072 by wrapping enum yytokentype's definition inside #ifndef
1073 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1074
6fed0802
AD
10752002-10-13 Akim Demaille <akim@epita.fr>
1076
1077 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1078 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1079
32f0598d
AD
10802002-10-13 Akim Demaille <akim@epita.fr>
1081
1082 * Makefile.maint: Update from Autoconf 2.54.
1083 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1084
7ea9a33f
AD
10852002-10-13 Akim Demaille <akim@epita.fr>
1086
1087 * src/print.c (print_state): Separate the list of solved conflicts
1088 from the other items.
1089 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1090
ea99527d
AD
10912002-10-13 Akim Demaille <akim@epita.fr>
1092
1093 Let nondeterministic skeletons be usable with deterministic
1094 tables.
1095
1096 With the patch, GAWK compiled by GCC without -O2 passes its test
1097 suite using a GLR parser driven by LALR tables. It fails with -O2
1098 because `struct stat' gives two different answers on my machine:
1099 88 (definition of an auto var) and later 96 (memset on this var).
1100 Hence the stack is badly corrumpted. The headers inclusion is to
1101 blame: if I move the awk.h inclusion before GLR's system header
1102 inclusion, the two struct stat have the same size.
1103
1104 * src/tables.c (pack_table): Always create conflict_table.
1105 (token_actions): Always create conflict_list.
1106 * data/glr.c (YYFLAG): Remove, unused.
1107
f377f69f
AD
11082002-10-13 Akim Demaille <akim@epita.fr>
1109
1110 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1111 (O0FLAGS): New.
1112 (VALGRIND, GXX): New.
1113 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1114 * tests/bison.in: Run $PREBISON a pre-command.
1115 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1116 (maintainer-check-g++): New.
1117 * Makefile.am (maintainer-check): New.
1118
2a1fe6ed
AD
11192002-10-13 Akim Demaille <akim@epita.fr>
1120
1121 * data/glr.c: Formatting changes.
1122 Tweak some trace messages to match yacc.c's.
1123
f50adbbd
AD
11242002-10-13 Akim Demaille <akim@epita.fr>
1125
1126 GLR parsers sometimes raise parse errors instead of performing the
1127 default reduction.
1128 Reported by Charles-Henry de Boysson.
1129
1130 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1131 check the length of the traces when %glr.
1132 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1133 GLR's traces.
1134 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1135 Test GLR parsers.
1136 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1137 (yyltype): Remove the yy prefix from the member names.
1138 (yytable): Complete its comment.
1139 (yygetLRActions): Map error action number from YYTABLE from
1140 YYTABLE_NINF to 0.
1141 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1142 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1143 not satisfying as we could compare an YYACTION computed from
1144 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1145 only value for error actions.
1146 (yyreportParseError): In verbose parse error messages, don't issue
1147 `error' in the list of expected tokens.
1148 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1149 next action to perform to match glr.c's decoding.
1150 (yytable): Complete its comment.
1151
bcbad5b9
PE
11522002-10-13 Paul Eggert <eggert@twinsun.com>
1153
1154 Fix problem reported by Henrik Grubbstroem in
1155 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1156 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1157 because the Bison parser reads the second action before reducing
1158 the first one.
1159 * src/scan-gram.l (rule_length): New static var.
1160 Use it to keep track of the rule length in the scanner, since
1161 we can't expect the parser to be in lock-step sync with the scanner.
1162 (handle_action_dollar, handle_action_at): Use this var.
1163 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 1164
14904b89
PE
11652002-10-12 Paul Eggert <eggert@twinsun.com>
1166
1fe611e5
PE
1167 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1168 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1169 Include <sys/time.h> when checking for clock_t and struct tms.
1170 Use same include order as source.
1171 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1172 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
05846dae 1173
1fe611e5
PE
1174 * lib/timevar.c: Update copyright date and clarify comments.
1175 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 1176
1fe611e5
PE
1177 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1178 GCC version as of today, then merge Bison's changes.
1179 Change "GCC" to "Bison" in copyright notice. timevar.def's
1180 author is Akim, so change that too.
1181
98194095
PE
1182 * src/reader.c (grammar_current_rule_check):
1183 Don't worry about the default action if $$ is untyped.
1184 Prevents bogus warnings reported by Jim Gifford in
1185 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1186
14904b89
PE
1187 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1188 * data/glr.c, data/lalr1.cc, data/yacc.c:
1189 Output token definitions before the first part of user declarations.
1190 Fixes compatibility problem reported by Jim Gifford for kbd in
1191 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1192
ff6dca18
PE
11932002-10-11 Paul Eggert <eggert@twinsun.com>
1194
1195 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1196 (yyparse): here. This undoes some of the 2002-07-25 change.
1197 Compatibility problem reported by Ralf S. Engelschall with
1198 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1199
eb714592
AD
12002002-10-11 Akim Demaille <akim@epita.fr>
1201
1202 * tests/regression.at Characters Escapes): New.
1203 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1204 characters.
1205 Reported by Jan Nieuwenhuizen.
1206
b7195100
AD
12072002-10-11 Akim Demaille <akim@epita.fr>
1208
1209 * po/id.po: New.
1210
f28a0f2d
PE
12112002-10-10 Paul Eggert <eggert@twinsun.com>
1212
1213 Portability fixes for bitsets; this also avoids several GCC
1214 warnings.
1215
1216 * lib/abitset.c: Include <stddef.h>, for offsetof.
1217 * lib/lbitset.c: Likewise.
1218
1219 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1220 properly for vectors of objects. Do not assume that adding a
1221 header size to a multiple of a word size yields a value that is
1222 properly aligned for the whole union.
1223 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1224
1225 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1226 unique names for structures.
1227 * lib/ebitset.c (ebitset_bytes): Likewise.
1228 * lib/lbitset.c (lbitset_bytes): Likewise.
1229
1230 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1231 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1232 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1233 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1234 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1235 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1236 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1237 to improve the type-checking that GCC can do.
1238 * lib/bitset.c (bitset_op4_cmp): Likewise.
1239 * lib/bitset_stats.c (bitset_stats_count,
1240 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1241 bitset_stats_copy, bitset_stats_disjoint_p,
1242 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1243 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1244 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1245 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1246 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1247 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1248 bitset_stats_or_and_cmp): Likewise.
1249 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1250 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1251 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1252 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1253
1254 * lib/abitset.h: Include bitset.h, not bbitset.h.
1255 * lib/ebitset.h: Likewise.
1256 * lib/lbitset.h: Likewise.
1257
1258 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1259 All instances of parameters of type enum bitset_opts are now of
1260 type enum_bitset_opts, to conform to the C Standard, and similarly
1261 for enum_bitset_type.
1262 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1263 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1264
1265 Do not use "struct bitset_struct" to mean different things in
1266 different modules. Not only is this confusing, it violates
1267 the C Standard, which requires that structure types in different
1268 modules must be compatible if one is to be passed to the other.
1269 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1270 All instances of "struct bitset_struct *" replaced with "bitset".
1271 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1272 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1273 struct lbitset_struct, struct bitset_stats_struct): New types.
1274 All uses of struct bitset_struct changed to union bitset_union,
1275 etc.
1276 * lib/abitset.c (struct abitset_struct, abitset,
1277 struct bitset_struct): Remove.
1278 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1279 struct bitset_struct): Remove.
1280 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1281 bitset_struct): Remove.
1282 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1283 Likewise.
1284
1285 Do not call a function of type T using a call that assumes the
1286 function is of a different type U. Standard C requires that a
1287 function must be called with a type that is compatible with its
1288 definition.
1289 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1290 New decls.
1291 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1292 New functions.
1293 * lib/ebitset.c (PFV): Remove.
1294 * lib/lbitset.c (PFV): Likewise.
1295 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
1296 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
1297 decls.
1298 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
1299 (ebitset_vtable): Use them.
1300 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
1301 lbitset_xor): New functions.
1302 (lbitset_vtable): Use them.
1303
1304 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
1305 Declare.
1306
1307 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
1308 GCC warning.
1309 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
1310 Use offsetof, for simplicity.
1311
6fbe4984
PE
13122002-10-06 Paul Eggert <eggert@twinsun.com>
1313
1314 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
1315 the same width as int. This reapplies a hunk of the 2002-08-12 patch
1316 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
1317 which was inadvertently undone by the 2002-09-30 patch.
1318 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
1319 the same width as int.
1320
420f93c8
PE
13212002-10-04 Paul Eggert <eggert@twinsun.com>
1322
1323 Version 1.50.
1324
1325 * configure.ac (AC_INIT), NEWS: Increment version number.
1326
1327 * doc/bison.texinfo: Minor spelling, grammar, and white space
1328 fixes.
1329 (Symbols): Mention that any negative value returned from yylex
1330 signifies end-of-input. Warn about negative chars. Mention
1331 the portable Standard C character set.
1332
1333 The GNU coding standard says CFLAGS and YFLAGS are reserved
1334 for the installer to set.
1335 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
1336 * src/Makefile.am (AM_CFLAGS): Likewise.
1337 (AM_YFLAGS): Renamed from YFLAGS.
1338
1339 Fix some MAX and MIN problems.
1340 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
1341 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
1342 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
1343 * src/reader.c (reader): Use it.
1344
1345 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
1346 POSIX 1003.1-2001 has removed fgrep.
1347
13482002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
1349
1350 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
1351 interpreted as signed.
1352 * lib/ebitset.c (ebitset_list): Fix bug.
1353
ff68026d
PE
13542002-10-01 Paul Eggert <eggert@twinsun.com>
1355
1356 More fixes for 64-bit hosts and large bitsets.
1357
1358 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
1359 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
1360 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
1361 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
1362 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
1363 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
1364 bitset_count_): Likewise.
1365 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
1366 bitset_first, bitset_last): Likewise.
1367 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
1368 bitset_stats_list_reverse, bitset_stats_size,
1369 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
1370 Likewise.
1371 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1372 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1373 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1374 bitsetv_reflexive_transitive_closure): Likewise.
1375 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
1376 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
1377 Likewise.
1378 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
1379 Likewise.
420f93c8 1380
ff68026d
PE
1381 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
1382 Use size_t, not unsigned int, to count bytes.
1383 * lib/abitset.h (abitset_bytes): Likewise.
1384 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
1385 Likewise.
1386 * lib/bitset.h (bitset_bytes): Likewise.
1387 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
1388 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
1389 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1390 * lib/ebitset.c (ebitset_bytes): Likewise.
1391 * lib/ebitset.h (ebitset_bytes): Likewise.
1392 * lib/lbitset.c (lbitset_bytes): Likewise.
1393 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 1394
ff68026d
PE
1395 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
1396 abitset_subset_p, abitset_disjoint_p, abitset_and,
1397 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
1398 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
1399 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
1400 abitset_or_and, abitset_or_and_cmp):
1401 Use bitset_windex instead of unsigned int.
1402 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1403 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
1404 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
1405 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
1406 Likewise.
1407 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 1408
ff68026d
PE
1409 * lib/bitset.c (bitset_print):
1410 Use proper printf formats for widths of integer types.
1411 * lib/bitset_stats.c (bitset_percent_histogram_print,
1412 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
1413 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1414 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1415 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 1416
ff68026d
PE
1417 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
1418 BITSET_SIZE_MAX): New macros.
1419 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
1420 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
1421 to BITSET_WINDEX_MAX.
1422
1423 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
1424 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
1425 since we now return the bitset_bindex type (not int).
1426
1427 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
1428 when computing sizes.
1429 * lib/ebitset.c (ebitset_elts_grow): Likewise.
1430
1431 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
1432 and avoid cast to unsigned.
1433
6aa452a6
AD
14342002-09-30 Akim Demaille <akim@epita.fr>
1435
1436 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
1437 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
1438 Updates from Michael Hayes.
1439
927f7817
AD
14402002-09-30 Art Haas <ahaas@neosoft.com>
1441
1442 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
1443 invocations.
1444 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
1445 defined.
1446
9738f41e
AD
14472002-09-27 Akim Demaille <akim@epita.fr>
1448
1449 Version 1.49c.
1450
a5c75d7f
AD
14512002-09-27 Akim Demaille <akim@epita.fr>
1452
1453 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
1454 (Because of AC_LIBSOURCE).
1455
8280e179
AD
14562002-09-27 Akim Demaille <akim@epita.fr>
1457
1458 Playing with Autoscan.
1459
1460 * configure.ac: Remove the old LIBOBJ tweaks.
1461 (AC_REPLACE_FUNCS): Add strrchr and strtol.
1462 * lib/strrchr.c: New.
1463 * lib/strtol.c: New, from the Coreutils 4.5.1.
1464
ae64af35
AD
14652002-09-27 Akim Demaille <akim@epita.fr>
1466
1467 Playing with Autoscan.
1468
1469 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
1470 * lib/Makefile.am (libbison_a_SOURCES): No longer include
1471 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
1472 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
1473 Coreutils 4.5.1.
1474
d1a1114f
AD
14752002-09-24 Akim Demaille <akim@epita.fr>
1476
1477 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
1478 (Frequently Asked Questions, Parser Stack Overflow): New.
1479
b906441c
AD
14802002-09-13 Akim Demaille <akim@epita.fr>
1481
1482 Playing with autoscan.
1483
1484 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
1485 * src/files.c (skeleton_find): Remove, unused.
1486 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
1487 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
1488
bd701811
AD
14892002-09-13 Akim Demaille <akim@epita.fr>
1490
1491 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
1492 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
1493
e0a13e7b
AD
14942002-09-13 Akim Demaille <akim@epita.fr>
1495
1496 * configure.ac: Require 2.54.
1497 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
1498 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
1499 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
1500 Remove, provided by Autoconf macros.
1501
c97011bf
AD
15022002-09-12 Akim Demaille <akim@epita.fr>
1503
1504 * m4/prereq.m4: Update, from Coreutils 4.5.1.
1505
d862b1be
AD
15062002-09-12 Akim Demaille <akim@epita.fr>
1507
1508 * m4/prereq.m4: Update, from Fileutils 4.1.5.
1509 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
1510 Reported by Martin Mokrejs.
1511
3d38c03a
AD
15122002-09-10 Akim Demaille <akim@epita.fr>
1513
1514 * src/parse-gram.y: Associate a human readable string to each
1515 token type.
1516 * tests/regression.at (Invalid inputs): Adjust.
1517
b6347355
AD
15182002-09-10 Gary V. Vaughan <gary@gnu.org>
1519
1520 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
1521 with an Autoconf-2.5x style configure.ac.
1522
09ba4ab2
PE
15232002-09-06 Paul Eggert <eggert@twinsun.com>
1524
1525 * doc/bison.texinfo (Conditions): Make explicit that the GPL
1526 exception applies only to yacc.c. This is a modification of a
1527 patch originally suggested by Akim Demaille.
1528
21846f69
AD
15292002-09-06 Akim Demaille <akim@epita.fr>
1530
09ba4ab2
PE
1531 * data/c.m4 (b4_copyright): Move the GPL exception comment from
1532 here to...
1533 * data/yacc.c: here.
1534
21846f69
AD
1535 * data/lalr1.cc (struct yyltype): Don't define it, since we use
1536 LocationType.
1537 (b4_ltype): Default to yy::Location from location.hh.
1538
c0ad8bf3
AD
15392002-09-04 Jim Meyering <jim@meyering.net>
1540
1541 * data/yacc.c: Guard the declaration of yytoknum also with
1542 `#ifdef YYPRINT', so it is declared only when used.
1543
3a93251e
AD
15442002-09-04 Akim Demaille <akim@epita.fr>
1545
1546 * configure.in: Rename as...
1547 * configure.ac: this.
1548 Bump to 1.49c.
1549
427c0dda
AD
15502002-09-04 Akim Demaille <akim@epita.fr>
1551
1552 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
1553 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
1554 translate maintainer only messages.
1555
6a254321
PE
15562002-08-12 Paul Eggert <eggert@twinsun.com>
1557
645e30d1
PE
1558 Version 1.49b.
1559
6a254321
PE
1560 * Makefile.am (SUBDIRS): Remove intl.
1561 (DISTCLEANFILES): Remove.
1562 * NEWS: Mention that GNU M4 is now required. Clarify what is
1563 meant by "larger grammars". Mention the pt_BR translation.
1564 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
1565 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
1566 Bump version from 0.11.2 to 0.11.5.
1567 (BISON_PREREQ_STAGE): Remove.
1568 (AM_GNU_GETTEXT): Use external gettext.
1569 (AC_OUTPUT): Remove intl/Makefile.
1570
1571 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
1572
1573 * data/glr.c: Include string.h, for strlen.
1574 (yyreportParseError): Use size_t for yysize.
1575 (yy_yypstack): No longer nested inside yypstates, as nested
1576 functions are not portable. Do not assume size_t is the
1577 same width as int.
1578 (yypstates): Do not assume that ptrdiff_t is the same width
1579 as int, and similarly for yyposn and YYINDEX.
1580
1581 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
1582
1583 * lib/Makefile.am (INCLUDES): Do not include from the intl
1584 directory, which has been removed.
1585 * src/Makefile.am (INCLUDES): Likewise.
1586
1587 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
1588 (bitsets_sources, additional_bitsets_sources, timevars_sources):
1589 New vars.
1590
1591 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
1592 * tests/Makefile.am (EXTRA_DIST): Likewise.
1593
1594 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
1595 Do not assume that bitset_windex is the same width as unsigned.
1596
1597 * lib/abitset.c (abitset_unused_clear): Do not assume that
1598 bitset_word is the same width as int.
1599 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
1600 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
1601 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
1602 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
1603 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
1604
1605 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
1606 portability to one's complement hosts!).
1607 * lib/ebitset.c (ebitset_op1): Likewise.
1608 * lib/lbitset.c (lbitset_op1): Likewise.
1609
1610 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
1611 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
1612 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
1613 Sync with fileutils.
1614 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
1615 lib/gettext.h: Sync with diffutils.
1616
1617 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
1618 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
1619
1620 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
1621 PROTOTYPES to check for prototypes, and "defined __STDC__" to
1622 check for void *.
1623
1624 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
1625 size_t; the old version tried to do this but casted improperly.
1626 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
1627 (bitset_test): Now returns int, not unsigned long.
1628
1629 * lib/bitset_stats.c: Include "gettext.h".
1630 (_): New macro.
1631 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
1632 name locals "index", as it generates unnecessary warnings on some
1633 hosts that have an "index" function.
1634
1635 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
1636 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
1637 they need translation.
1638 * src/LR0.c (state_list_append, new_itemsets, get_state,
1639 append_states, generate_states): Likewise.
1640 * src/assoc.c (assoc_to_string): Likewise.
1641 * src/closure.c (print_closure, set_firsts, closure): Likewise.
1642 * src/gram.c (grammar_dump): Likewise.
1643 * src/injections.c (injections_compute): Likewise.
1644 * src/lalr.c (lookaheads_print): Likewise.
1645 * src/relation.c (relation_transpose): Likewise.
1646 * src/scan-gram.l: Likewise.
1647 * src/tables.c (table_grow, pack_vector): Likewise.
1648
1649 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
1650 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
1651 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
1652 * m4/mbstate_t.m4: Sync with fileutils.
1653 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
1654
1655 * po/LINGUAS: Add pt_BR.
1656 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
1657 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
1658 lib/timevar.c.
1659 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
1660 manual recommends.
1661 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
1662
1663 * src/complain.c (strerror_r): Remove decl; not needed.
1664 (strerror): Use same pattern as ../lib/error.c.
1665
1666 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
1667
1668 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
1669
1670 * src/main.c (main): Cast result of bindtextdomain and textdomain
1671 to void, to avoid a GCC warning when --disable-nls is in effect.
1672
1673 * src/scan-gram.l: Use strings rather than escapes when possible,
1674 to minimize the number of warnings from xgettext.
1675 (handle_action_dollar, handle_action_at): Don't use isdigit,
1676 as it mishandles negative chars and it may not work as expected
1677 outside the C locale.
1678
1679 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
1680 this is a GCC extension and is not portable to other compilers.
1681
1682 * src/system.h (alloca): Use same pattern as ../lib/error.c.
1683 Do not include <ctype.h>; no longer needed.
1684 Do not include <malloc.h>; no longer needed (and generates
1685 warnings on OpenBSD 3.0).
1686
1687 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
1688 it's not portable.
1689
1690 * tests/regression.at: Do not use 'cc -c input.c -o input';
1691 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1692
1693 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1694 exit status as failure, not just exit status 1. Sun C exits
1695 with status 2 sometimes.
1696
1697 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1698 Use it for the two large tests.
1699
c8f002c7
AD
17002002-08-02 Akim Demaille <akim@epita.fr>
1701
1702 * src/conflicts.c (conflicts_output): Don't output rules never
1703 reduced here, since anyway that computation doesn't work.
1704 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1705 (rule_useless_p, rule_never_reduced_p): New.
1706 (grammar_rules_partial_print): Use a filter instead of a range.
1707 Display the title only if needed.
1708 (grammar_rules_print): Adjust.
1709 (grammar_rules_never_reduced_report): New.
1710 * src/tables.c (action_row): Move the computation of rules never
1711 reduced to...
1712 (token_actions): here.
1713 * src/main.c (main): Make the parser before making the report, so
1714 that rules never reduced are computed.
1715 Call grammar_rules_never_reduced_report.
1716 * src/print.c (print_results): Report rules never reduced.
1717 * tests/conflicts.at, tests/reduce.at: Adjust.
1718
cd08e51e
AD
17192002-08-01 Akim Demaille <akim@epita.fr>
1720
1721 Instead of attaching lookaheads and duplicating the rules being
1722 reduced by a state, attach the lookaheads to the reductions.
1723
1724 * src/state.h (state_t): Remove the `lookaheads',
1725 `lookaheads_rule' member.
1726 (reductions_t): Add a `lookaheads' member.
1727 Use a regular array for the `rules'.
1728 * src/state.c (reductions_new): Initialize the lookaheads member
1729 to 0.
1730 (state_rule_lookaheads_print): Adjust.
1731 * src/state.h, src/state.c (state_reductions_find): New.
1732 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1733 (count_rr_conflicts): Adjust.
1734 * src/lalr.c (LArule): Remove.
1735 (add_lookback_edge): Adjust.
1736 (state_lookaheads_count): New.
1737 (states_lookaheads_initialize): Merge into...
1738 (initialize_LA): this.
1739 (lalr_free): Adjust.
1740 * src/main.c (main): Don't free nullable and derives too early: it
1741 is used by --verbose.
1742 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1743
bb0027a9
AD
17442002-08-01 Akim Demaille <akim@epita.fr>
1745
1746 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1747 `rule_number_t**'.
1748 (set_derives, free_derives): Rename as...
1749 (derives_compute, derives_free): this.
1750 Adjust all dependencies.
1751 * src/nullable.c (set_nullable, free_nullable): Rename as...
1752 (nullable_compute, nullable_free): these.
1753 (rule_list_t): Store rule_t *, not rule_number_t.
1754 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1755 pointers, instead of their numbers.
1756 * src/main.c (main): Call nullable_free, and derives_free earlier,
1757 as they were lo longer used.
1758
3325ddc4
AD
17592002-08-01 Akim Demaille <akim@epita.fr>
1760
1761 * lib/timevar.c (get_time): Include children time.
1762 * src/lalr.h (LA, LArule): Don't export them: used with the
1763 state_t.
1764 * src/lalr.c (LA, LArule): Static.
1765 * src/lalr.h, src/lalr.c (lalr_free): New.
1766 * src/main.c (main): Call it.
1767 * src/tables.c (pack_vector): Check whether loc is >= to the
1768 table_size, not >.
1769 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1770 (tables_generate): do it, since that's also it which allocates
1771 them.
1772 Don't free LA and LArule, main does.
1773
c6f1a33c
AD
17742002-07-31 Akim Demaille <akim@epita.fr>
1775
1776 Separate parser tables computation and output.
1777
1778 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1779 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1780 (yydefgoto, yydefact, high): Move to...
1781 * src/tables.h, src/tables.c: here.
1782 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1783 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1784 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1785 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1786 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1787 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1788 (action_row, save_row, token_actions, save_column, default_goto)
1789 (goto_actions, sort_actions, matching_state, pack_vector)
1790 (table_ninf_remap, pack_table, prepare_actions): Move to...
1791 * src/tables.c: here.
1792 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1793 * src/output.c (token_actions, output_base, output_conflicts)
1794 (output_check): Merge into...
1795 (prepare_actions): this.
1796 (actions_output): Rename as...
1797 (user_actions_output): this.
1798 * src/main.c (main): Call tables_generate and tables_free.
1799
1509d42f
AD
18002002-07-31 Akim Demaille <akim@epita.fr>
1801
1802 Steal GCC's --time-report support.
1803
1804 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1805 stolen/adjusted from GCC.
1806 * m4/stage.m4: Remove time related checks.
1807 * m4/timevar.m4: New.
1808 * configure.in: Adjust.
1809 * src/system.h: Adjust to using timevar.h.
1810 * src/getargs.h, src/getargs.c: Support trace_time for
1811 --trace=time.
1812 * src/main.c (stage): Remove.
1813 (main): Replace `stage' invocations with timevar calls.
1814 * src/output.c: Insert pertinent timevar calls.
1815
273a74fa
AD
18162002-07-31 Akim Demaille <akim@epita.fr>
1817
1818 Let --trace have arguments.
1819
1820 * src/getargs.h (enum trace_e): New.
1821 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1822 (long_options, short_options): --trace/-T takes an optional
1823 argument.
1824 Change all the uses of trace_flag to reflect the new flags.
1825 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1826
1827 Strengthen `stage' portability.
1828
1829 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1830 * configure.in: Use it.
1831 Don't check for malloc.h and sys/times.h.
1832 * src/system.h: Include them when appropriate.
1833 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1834 times and struct tms are available.
1835
217598da
AD
18362002-07-30 Akim Demaille <akim@epita.fr>
1837
1838 In verbose parse error message, don't report `error' as an
1839 expected token.
1840 * tests/actions.at (Printers and Destructors): Adjust.
1841 * tests/calc.at (Calculator $1): Adjust.
1842 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1843 error message, do not report the parser accepts the error token in
1844 that state.
1845
52489d44
AD
18462002-07-30 Akim Demaille <akim@epita.fr>
1847
1848 Normalize conflict related messages.
1849
1850 * src/complain.h, src/complain.c (warn, complain): New.
1851 * src/conflicts.c (conflicts_print): Use them.
1852 (conflict_report_yacc): New, extracted from...
1853 (conflicts_print): here.
1854 * tests/conflicts.at, tests/existing.at: Adjust.
1855
e8832397
AD
18562002-07-30 Akim Demaille <akim@epita.fr>
1857
1858 Report rules which are never reduced by the parser: those hidden
1859 by conflicts.
1860
1861 * src/LR0.c (save_reductions): Don't make the final state too
1862 different: save its reduction (accept) instead of having a state
1863 without any action (no shift or goto, no reduce).
1864 Note: the final state is now a ``regular'' state, i.e., the
1865 parsers now contain `reduce 0' as default reduction.
1866 Nevertheless, since they decide to `accept' when yystate =
1867 final_state, they still will not reduce rule 0.
1868 * src/print.c (print_actions, print_reduction): Adjust.
1869 * src/output.c (action_row): Track reduced rules.
1870 (token_actions): Report rules never reduced.
1871 * tests/conflicts.at, tests/regression.at: Adjust.
1872
caf23d24
AD
18732002-07-30 Akim Demaille <akim@epita.fr>
1874
1875 `stage' was accidently included in a previous patch.
1876 Initiate its autoconfiscation.
1877
1878 * configure.in: Look for malloc.h and sys/times.h.
1879 * src/main.c (stage): Adjust.
1880 Report only when trace_flag.
1881
640748ee
AD
18822002-07-29 Akim Demaille <akim@epita.fr>
1883
1884 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1885 state_number_t.
1886 (errs_t): symbol_t*, not symbol_number_t.
1887 (reductions_t): rule_t*, not rule_number_t.
1888 (FOR_EACH_SHIFT): New.
1889 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1890 * src/print.c, src/print_graph.c: Adjust.
1891
88bce5a2
AD
18922002-07-29 Akim Demaille <akim@epita.fr>
1893
1894 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1895
1896 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1897 (endtoken, accept): these.
1898 * src/reader.c (reader): Set endtoken's default tag to "$end".
1899 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1900 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1901 Adjust.
1902
1bfb97db
AD
19032002-07-29 Akim Demaille <akim@epita.fr>
1904
1905 * src/reduce.c (reduce_grammar): When the language is empty,
1906 complain about the start symbol, not the axiom.
1907 Use its location.
1908 * tests/reduce.at (Empty Language): New.
1909
fc5734fe
AD
19102002-07-26 Akim Demaille <akim@epita.fr>
1911
1912 * src/reader.h, src/reader.c (gram_error): ... can't get
1913 yycontrol without making too strong assumptions on the parser
1914 itself.
1915 * src/output.c (prepare_tokens): Use the real 0th value of
1916 token_translations instead of `0'.
1917 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1918 visible here.
1919 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1920 for the time being: %locations ought to provide it to yyerror.
1921
3650b4b8
AD
19222002-07-25 Akim Demaille <akim@epita.fr>
1923
1924 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1925 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1926 * tests/regression.at (Web2c Actions): Adjust.
1927
4b3d3a8e
AD
19282002-07-25 Akim Demaille <akim@epita.fr>
1929
1930 Stop storing rules from 1 to nrules + 1.
1931
1932 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1933 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1934 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1935 Iterate from 0 to nrules.
1936 Use rule_number_as_item_number and item_number_as_rule_number.
1937 Adjust to `derive' now containing possibly 0.
1938 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1939 Handle the `- 1' part in rule numbers from/to item numbers.
1940 * src/conflicts.c (log_resolution): Fix the message which reversed
1941 shift and reduce.
1942 * src/output.c (action_row): Initialize default_rule to -1.
1943 (token_actions): Adjust.
1944 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1945 expected output.
1946 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1947
4a2a22f4
AD
19482002-07-25 Akim Demaille <akim@epita.fr>
1949
1950 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1951 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1952 (b4_c_knr_arg_decl): New.
1953 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1954 yyreport_parse_error.
1955
b8df3223
AD
19562002-07-25 Akim Demaille <akim@epita.fr>
1957
1958 * data/yacc.c (yyreport_parse_error): New, extracted from...
1959 (yyparse): here.
1960 (yydestruct, yysymprint): Move above yyparse.
1961 Be K&R compliant.
1962
a762e609
AD
19632002-07-25 Akim Demaille <akim@epita.fr>
1964
1965 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1966 replace...
1967 (b4_sint_type, b4_uint_type): these.
1968 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1969 * tests/regression.at (Web2c Actions): Adjust.
1970
12b0043a
AD
19712002-07-25 Akim Demaille <akim@epita.fr>
1972
1973 * src/gram.h (TIEM_NUMBER_MAX): New.
1974 (item_number_of_rule_number, rule_number_of_item_number): Rename
1975 as...
1976 (rule_number_as_item_number, item_number_as_rule_number): these.
1977 Adjust dependencies.
1978 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1979 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1980 (symbol_number_to_vector_number): New.
1981 (order): Of vector_number_t* type.
1982 (base_t, BASE_MAX, BASE_MIN): New.
1983 (froms, tos, width, pos, check): Of base_t type.
1984 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1985 (actrow): Of action_number_t type.
1986 (conflrow): Of unsigned int type.
1987 (table_ninf, base_ninf): New.
1988 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1989 (muscle_insert_int_table, muscle_insert_base_table)
1990 (muscle_insert_rule_number_table): New.
1991 (prepare_tokens): Output `toknum' as int_table.
1992 (action_row): Returns a rule_number_t.
1993 Use ACTION_MIN, not SHRT_MIN.
1994 (token_actions): yydefact is rule_number_t*.
1995 (table_ninf_remap): New.
1996 (pack_table): Use it for `base' and `table'.
1997 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1998 replaced with...
1999 (YYPACT_NINF, YYTABLE_NINF): these.
2000 (yypact, yytable): Compute their types instead of hard-coded
2001 `short'.
2002 * tests/regression.at (Web2c Actions): Adjust.
2003
5dde258a
AD
20042002-07-19 Akim Demaille <akim@epita.fr>
2005
2006 * src/scan-gram.l (id): Can start with an underscore.
2007
a945ec39
AD
20082002-07-16 Akim Demaille <akim@epita.fr>
2009
2010 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2011 Adjust all former `associativity' dependencies.
2012 * src/symtab.c (symbol_new): Default associativity is `undef', not
2013 `right'.
2014 (symbol_check_alias_consistence): Adjust.
2015
fae437e8
AD
20162002-07-09 Akim Demaille <akim@epita.fr>
2017
2018 * doc/bison.texinfo: Properly set the ``header'' part.
2019 Use @dircategory ``GNU programming tools'' as per Texinfo's
2020 documentation.
2021 Use @copying.
2022
1a715ef2
AD
20232002-07-09 Akim Demaille <akim@epita.fr>
2024
2025 * lib/quotearg.h: Protect against multiple inclusions.
2026 * src/location.h (location_t): Add a `file' member.
2027 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2028 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2029 `error_one_per_line' support.
2030
a5d50994
AD
20312002-07-09 Akim Demaille <akim@epita.fr>
2032
2033 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2034 * src/reader.c (lineno): Remove.
2035 Adjust all dependencies.
2036 (get_merge_function): Take a location and use complain_at.
2037 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2038 * tests/regression.at (Invalid inputs, Mixing %token styles):
2039 Adjust.
2040
b275314e
AD
20412002-07-09 Akim Demaille <akim@epita.fr>
2042
2043 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2044 recovery rule, and forbid extensions when --yacc.
2045 (gram_error): Use complain_at.
2046 * src/reader.c (reader): Exit if there were parse errors.
2047
865b9df1
AD
20482002-07-09 Akim Demaille <akim@epita.fr>
2049
2050 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2051 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2052 Reported by R Blake <blakers@mac.com>.
2053
c76e14da
AD
20542002-07-09 Akim Demaille <akim@epita.fr>
2055
2056 * data/yacc.c: Output the copyright notive in the header.
2057
7db2ed2d
AD
20582002-07-03 Akim Demaille <akim@epita.fr>
2059
2060 * src/output.c (froms, tos): Are state_number_t.
2061 (save_column): sp, sp1, and sp2 are state_number_t.
2062 (prepare): Rename `final' as `final_state_number', `nnts' as
2063 `nterms_number', `nrules' as `rules_number', `nstates' as
2064 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2065 unused.
2066 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2067 * data/lalr1.cc (nsym_): Remove, unused.
2068
e68e0410
AD
20692002-07-03 Akim Demaille <akim@epita.fr>
2070
2071 * src/lalr.h, src/lalr.c (goto_number_t): New.
2072 * src/lalr.c (goto_list_t): New.
2073 Propagate them.
2074 * src/nullable.c (rule_list_t): New.
2075 Propagate.
2076 * src/types.h: Remove.
2077
e1a4f3a4
AD
20782002-07-03 Akim Demaille <akim@epita.fr>
2079
2080 * src/closure.c (print_fderives): Use rule_rhs_print.
2081 * src/derives.c (print_derives): Use rule_rhs_print.
2082 (rule_list_t): New, replaces `shorts'.
2083 (set_derives): Add comments.
2084 * tests/sets.at (Nullable, Firsts): Adjust.
2085
536545f3
AD
20862002-07-03 Akim Demaille <akim@epita.fr>
2087
2088 * src/output.c (prepare_actions): Free `tally' and `width'.
2089 (prepare_actions): Allocate and free `order'.
2090 * src/symtab.c (symbols_free): Free `symbols'.
2091 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2092 * src/output.c (m4_invoke): Move to...
2093 * src/scan-skel.l: here.
2094 (<<EOF>>): Close yyout, and free its name.
2095
8b752b00
AD
20962002-07-03 Akim Demaille <akim@epita.fr>
2097
2098 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2099
2100 * src/LR0.c (new_state): Merge into...
2101 (state_list_append): this.
2102 (new_states): Merge into...
2103 (generate_states): here.
2104 (set_states): Don't ensure a proper `errs' state member here, do it...
2105 * src/conflicts.c (conflicts_solve): here.
2106 * src/state.h, src/state.c: Comment changes.
2107 (state_t): Rename member `shifts' as `transitions'.
2108 Adjust all dependencies.
2109 (errs_new): For consistency, also take the values as argument.
2110 (errs_dup): Remove.
2111 (state_errs_set): New.
2112 (state_reductions_set, state_transitions_set): Assert that no
2113 previous value was assigned.
2114 (state_free): New.
2115 (states_free): Use it.
2116 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2117 temporary storage: use `errs' and `nerrs' as elsewhere.
2118 (set_conflicts): Allocate and free this `errs'.
2119
613f5e1a
AD
21202002-07-02 Akim Demaille <akim@epita.fr>
2121
2122 * lib/libiberty.h: New.
2123 * lib: Update the bitset implementation from upstream.
2124 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2125 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2126 * src/main.c: Adjust bitset stats calls.
2127
26e0cadc
PE
21282002-07-01 Paul Eggert <eggert@twinsun.com>
2129
2130 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2131 char, so that negative chars don't collide with $.
2132
1154cced
AD
21332002-06-30 Akim Demaille <akim@epita.fr>
2134
2135 Have the GLR tests be `warning' checked, and fix the warnings.
2136
2137 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2138 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2139 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2140 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2141 (yyaddDeferredAction): static.
2142 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2143 (yyreportParseError): yyprefix is const.
2144 yytokenp is used only when verbose.
2145 (yy__GNUC__): Replace with __GNUC__.
2146 (yypdumpstack): yyi is size_t.
2147 (yypreference): Un-yy local variables and arguments, to avoid
2148 clashes with `yyr1'. Anyway, we are not in the user name space.
2149 (yytname_size): be an int, as is compared with ints.
2150 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2151 Use them.
2152 * tests/cxx-gram.at: Use quotation to protect $1.
2153 Use AT_COMPILE to enable warnings hunts.
2154 Prototype yylex and yyerror.
2155 `Use' argc.
2156 Include `string.h', not `strings.h'.
2157 Produce and prototype stmtMerge only when used.
2158 yylex takes a location.
2159
97650f4e
AD
21602002-06-30 Akim Demaille <akim@epita.fr>
2161
2162 We spend a lot of time in quotearg, in particular when --verbose.
2163
2164 * src/symtab.c (symbol_get): Store a quoted version of the key.
2165 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2166 Adjust all callers.
2167
d2576365
AD
21682002-06-30 Akim Demaille <akim@epita.fr>
2169
2170 * src/state.h (reductions_t): Rename member `nreds' as num.
2171 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2172 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2173
ccaf65bc
AD
21742002-06-30 Akim Demaille <akim@epita.fr>
2175
2176 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2177 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2178 (shifts_to): Rename as...
2179 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2180 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2181 (TRANSITION_IS_DISABLED, transitions_to): these.
2182
87675353
AD
21832002-06-30 Akim Demaille <akim@epita.fr>
2184
2185 * src/print.c (print_shifts, print_gotos): Merge into...
2186 (print_transitions): this.
2187 (print_transitions, print_errs, print_reductions): Align the
2188 lookaheads columns.
2189 (print_core, print_transitions, print_errs, print_state,
2190 print_grammar): Output empty lines separator before, not after.
2191 (state_default_rule_compute): Rename as...
2192 (state_default_rule): this.
2193 * tests/conflicts.at (Defaulted Conflicted Reduction),
2194 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2195 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2196
ce4ccb4b
AD
21972002-06-30 Akim Demaille <akim@epita.fr>
2198
2199 Display items as we display rules.
2200
2201 * src/gram.h, src/gram.c (rule_lhs_print): New.
2202 * src/gram.c (grammar_rules_partial_print): Use it.
2203 * src/print.c (print_core): Likewise.
2204 * tests/conflicts.at (Defaulted Conflicted Reduction),
2205 (Unresolved SR Conflicts): Adjust.
2206 (Unresolved SR Conflicts): Adjust and rename as...
2207 (Resolved SR Conflicts): this, as was meant.
2208 * tests/regression.at (Web2c Report): Adjust.
2209
bc933ef1
AD
22102002-06-30 Akim Demaille <akim@epita.fr>
2211
2212 * src/print.c (state_default_rule_compute): New, extracted from...
2213 (print_reductions): here.
2214 Pessimize, but clarify the code.
2215 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2216
53d4308d
AD
22172002-06-30 Akim Demaille <akim@epita.fr>
2218
2219 * src/output.c (action_row): Let default_rule be always a rule
2220 number.
2221
574fb2d5
AD
22222002-06-30 Akim Demaille <akim@epita.fr>
2223
2224 * src/closure.c (print_firsts, print_fderives, closure):
2225 Use BITSET_EXECUTE.
2226 * src/lalr.c (lookaheads_print): Likewise.
2227 * src/state.c (state_rule_lookaheads_print): Likewise.
2228 * src/print_graph.c (print_core): Likewise.
2229 * src/print.c (print_reductions): Likewise.
2230 * src/output.c (action_row): Likewise.
2231 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2232
05811fd7
AD
22332002-06-30 Akim Demaille <akim@epita.fr>
2234
2235 * src/print_graph.c: Use report_flag.
2236
0e4d5753
AD
22372002-06-30 Akim Demaille <akim@epita.fr>
2238
2239 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2240 to...
2241 * src/relation.h, src/relation.c (traverse, relation_digraph)
2242 (relation_print, relation_transpose): New.
2243
24c7d800
AD
22442002-06-30 Akim Demaille <akim@epita.fr>
2245
2246 * src/state.h, src/state.c (shifts_to): New.
2247 * src/lalr.c (build_relations): Use it.
2248
9222837b
AD
22492002-06-30 Akim Demaille <akim@epita.fr>
2250
2251 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2252 (item_number_of_rule_number, rule_number_of_item_number): New.
2253 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2254 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2255 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2256 Propagate their use.
2257 Much remains to be done, in particular wrt `shorts' from types.h.
2258
260008e5
AD
22592002-06-30 Akim Demaille <akim@epita.fr>
2260
2261 * src/symtab.c (symbol_new): Initialize the `printer' member.
2262
8a731ca8
AD
22632002-06-30 Akim Demaille <akim@epita.fr>
2264
2265 * src/LR0.c (save_reductions): Remove, replaced by...
2266 * src/state.h, src/state.c (state_reductions_set): New.
2267 (reductions, errs): Rename as...
2268 (reductions_t, errs_t): these.
2269 Adjust all dependencies.
2270
32e1e0a4
AD
22712002-06-30 Akim Demaille <akim@epita.fr>
2272
2273 * src/LR0.c (state_list_t, state_list_append): New.
2274 (first_state, last_state): Now symbol_list_t.
2275 (this_state): Remove.
2276 (new_itemsets, append_states, save_reductions): Take a state_t as
2277 argument.
2278 (set_states, generate_states): Adjust.
2279 (save_shifts): Remove, replaced by...
2280 * src/state.h, src/state.c (state_shifts_set): New.
2281 (shifts): Rename as...
2282 (shifts_t): this.
2283 Adjust all dependencies.
2284 * src/state.h (state_t): Remove the `next' member.
2285
e5fb6710
AD
22862002-06-30 Akim Demaille <akim@epita.fr>
2287
2288 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2289 escaped in slot 0.
2290
c7ca99d4
AD
22912002-06-30 Akim Demaille <akim@epita.fr>
2292
2293 Use hash.h for the state hash table.
2294
2295 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
2296 (allocate_storage): Use state_hash_new.
2297 (free_storage): Use state_hash_free.
2298 (new_state, get_state): Adjust.
2299 * src/lalr.h, src/lalr.c (states): Move to...
2300 * src/states.h (state_t): Remove the `link' member, no longer
2301 used.
2302 * src/states.h, src/states.c: here.
2303 (state_hash_new, state_hash_free, state_hash_lookup)
2304 (state_hash_insert, states_free): New.
2305 * src/states.c (state_table, state_compare, state_hash): New.
2306 * src/output.c (output_actions): Do not free states now, since we
2307 still need to know the final_state number in `prepare', called
2308 afterwards. Do it...
2309 * src/main.c (main): here: call states_free after `output'.
2310
df0e7316
AD
23112002-06-30 Akim Demaille <akim@epita.fr>
2312
2313 * src/state.h, src/state.c (state_new): New, extracted from...
2314 * src/LR0.c (new_state): here.
2315 * src/state.h (STATE_ALLOC): Move to...
2316 * src/state.c: here.
2317 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
2318 * src/state.h, src/state.c: here.
2319
39f41916
AD
23202002-06-30 Akim Demaille <akim@epita.fr>
2321
2322 * src/reader.c (gensym): Rename as...
2323 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
2324 (getsym): Rename as...
2325 (symbol_get): this.
2326
d57650a5
AD
23272002-06-30 Akim Demaille <akim@epita.fr>
2328
2329 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
2330 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
2331 * src/output.c, src/print.c, src/print_graph.c: Propagate.
2332 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
2333
5a08f1ce
AD
23342002-06-30 Akim Demaille <akim@epita.fr>
2335
2336 Make the test suite pass with warnings checked.
2337
2338 * tests/actions.at (Printers and Destructors): Improve.
2339 Avoid unsigned vs. signed issues.
2340 * tests/calc.at: Don't exercise the scanner here, do it...
2341 * tests/input.at (Torturing the Scanner): here.
2342
720623af
PH
23432002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2344
88e7e941 2345 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
2346 reorganize first lines parallel to yacc.c.
2347
fb8135fa
AD
23482002-06-28 Akim Demaille <akim@epita.fr>
2349
2350 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
2351 (b4_token_enum, b4_token_defines): New, factored from...
2352 * data/lalr1.cc, data/yacc.c, glr.c: here.
2353
41442480
AD
23542002-06-28 Akim Demaille <akim@epita.fr>
2355
2356 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
2357 unused variables.
2358 * src/output.c (merger_output): static.
2359
e0e5bf84
AD
23602002-06-28 Akim Demaille <akim@epita.fr>
2361
2362 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
2363 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
2364 pacify GCC.
2365 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 2366
676385e2
PH
23672002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2368
2369 Accumulated changelog for new GLR parsing features.
2370
6a254321 2371 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
2372 conflicts_total_count.
2373 * src/conflicts.h: Ditto.
2374 * src/output.c (token_actions): Use the new name.
2375 (output_conflicts): Change conflp => conflict_list_heads, and
2376 confl => conflict_list for better readability.
2377 * data/glr.c: Use the new names.
2378 * NEWS: Add self to GLR announcement.
e0e5bf84 2379
676385e2
PH
2380 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
2381
2382 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
2383 Akim Demaille.
2384
2385 * data/bison.glr: Change name to glr.c
2386 * data/glr.c: Renamed from bison.glr.
2387 * data/Makefile.am: Add glr.c
e0e5bf84
AD
2388
2389 * src/getargs.c:
2390
676385e2
PH
2391 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
2392 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 2393
676385e2
PH
2394 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2395
2396 * data/bison.glr: Be sure to restore the
2397 current #line when returning to the skeleton contents after having
2398 exposed the input file's #line.
2399
2400 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2401
2402 * data/bison.glr: Bring up to date with changes to bison.simple.
2403
2404 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2405
2406 * data/bison.glr: Correct definitions that use b4_prefix.
2407 Various reformatting.
2408 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
2409 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
2410 yytokenp argument; now part of stack.
2411 (yychar): Define to behave as documented.
2412 (yyclearin): Ditto.
e0e5bf84 2413
676385e2
PH
2414 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2415
2416 * src/reader.h: Add declaration for free_merger_functions.
2417
2418 * src/reader.c (merge_functions): New variable.
2419 (get_merge_function): New function.
2420 (free_merger_functions): New function.
2421 (readgram): Check for %prec that is not followed by a symbol.
2422 Handle %dprec and %merge declarations.
2423 (packgram): Initialize dprec and merger fields in rules array.
2424
2425 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
2426 conflict_list_cnt, conflict_list_free): New variables.
2427 (table_grow): Also grow conflict_table.
e0e5bf84 2428 (prepare_rules): Output dprec and merger tables.
676385e2 2429 (conflict_row): New function.
e0e5bf84 2430 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
2431 default reduction in conflicted states for GLR parser so that there
2432 are spaces for the conflict lists.
2433 (save_row): Also save conflict information.
2434 (token_actions): Allocate conflict list.
2435 (merger_output): New function.
2436 (pack_vector): Pack conflict table, too.
2437 (output_conflicts): New function to output yyconflp and yyconfl.
2438 (output_check): Allocate conflict_tos.
2439 (output_actions): Output conflict tables, also.
2440 (output_skeleton): Output b4_mergers definition.
2441 (prepare): Output b4_max_rhs_length definition.
2442 Use 'bison.glr' as default skeleton for GLR parsers.
2443
2444 * src/gram.c (glr_parser): New flag.
2445 (grammar_free): Call free_merger_functions.
2446
2447 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
2448 all pairs of conflicting reductions, rather than just all tokens
2449 causing conflicts. Needed to size conflict tables.
e0e5bf84 2450 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
2451 interface.
2452 (conflicts_print): Ditto.
2453 (count_total_conflicts): New function.
2454
2455 * src/reader.h (merger_list): New type.
2456 (merge_functions): New variable.
2457
2458 * src/lex.h (tok_dprec, tok_merge): New token types.
2459
2460 * src/gram.h (rule_s): Add dprec and merger fields.
2461 (glr_parser): New flag.
2462
2463 * src/conflicts.h (count_total_conflicts): New function.
2464
2465 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
2466
2467 * doc/bison.texinfo (Generalized LR Parsing): New section.
2468 (GLR Parsers): New section.
2469 (Language and Grammar): Mention GLR parsing.
2470 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
2471 Correct typo ("tge" -> "the").
2472
2473 * data/bison.glr: New skeleton for GLR parsing.
2474
2475 * tests/cxx-gram.at: New tests for GLR parsing.
2476
2477 * tests/testsuite.at: Include cxx-gram.at.
2478
2479 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 2480
676385e2
PH
2481 * src/parse-gram.y:
2482
2483 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
2484
2485 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 2486
b5480d74 24872002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
2488
2489 * src/options.h, src/options.c: Remove.
2490 * src/getargs.c (short_options, long_options): New.
2491
60491a94
AD
24922002-06-27 Akim Demaille <akim@epita.fr>
2493
2494 * data/bison.simple, data/bison.c++: Rename as...
2495 * data/yacc.c, data/lalr1.cc: these.
2496 * doc/bison.texinfo (Environment Variables): Remove.
2497
9be0c25b
AD
24982002-06-25 Raja R Harinath <harinath@cs.umn.edu>
2499
2500 * src/getargs.c (report_argmatch): Initialize strtok().
2501
1ae72863
AD
25022002-06-20 Akim Demaille <akim@epita.fr>
2503
2504 * data/bison.simple (b4_symbol_actions): New, replaces...
2505 (b4_symbol_destructor, b4_symbol_printer): these.
2506 (yysymprint): Be sure to call YYPRINT only for tokens, and using
2507 user token numbers.
2508
87542d29
AD
25092002-06-20 Akim Demaille <akim@epita.fr>
2510
2511 * data/bison.simple (yydestructor): Rename as...
2512 (yydestruct): this.
2513
1a31ed21
AD
25142002-06-20 Akim Demaille <akim@epita.fr>
2515
2516 * src/symtab.h, src/symtab.c (symbol_type_set)
2517 (symbol_destructor_set, symbol_precedence_set): The location is
2518 the last argument.
2519 Adjust all callers.
2520
e776192e
AD
25212002-06-20 Akim Demaille <akim@epita.fr>
2522
2523 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
2524 internals.
2525 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
2526 Takes a location.
2527 * src/symtab.h, src/symtab.c (symbol_class_set)
2528 (symbol_user_token_number_set): Likewise.
2529 Adjust all callers.
2530 Promote complain_at.
2531 * tests/input.at (Type Clashes): Adjust.
2532
5c1180b3
AD
25332002-06-20 Akim Demaille <akim@epita.fr>
2534
2535 * data/bison.simple (YYLEX): Fix the declaration when
2536 %pure-parser.
2537
e3170060
AD
25382002-06-20 Akim Demaille <akim@epita.fr>
2539
2540 * data/bison.simple (yysymprint): Don't print the token number,
2541 just its name.
2542 * tests/actions.at (Destructors): Rename as...
2543 (Printers and Destructors): this.
2544 Also exercise %printer.
2545
253862fd
AD
25462002-06-20 Akim Demaille <akim@epita.fr>
2547
2548 * data/bison.simple (YYDSYMPRINT): New.
2549 Use it to remove many of the #if YYDEBUG/if (yydebug).
2550
366eea36
AD
25512002-06-20 Akim Demaille <akim@epita.fr>
2552
2553 * src/symtab.h, src/symtab.c (symbol_t): printer and
2554 printer_location are new members.
2555 (symbol_printer_set): New.
2556 * src/parse-gram.y (PERCENT_PRINTER): New token.
2557 Handle its associated rule.
2558 * src/scan-gram.l: Adjust.
2559 (handle_destructor_at, handle_destructor_dollar): Rename as...
2560 (handle_symbol_code_at, handle_symbol_code_dollar): these.
2561 * src/output.c (symbol_printers_output): New.
2562 (output_skeleton): Call it.
2563 * data/bison.simple (yysymprint): New. Cannot be named yyprint
2564 since there are already many grammar files with a user `yyprint'.
2565 Replace the calls to YYPRINT to calls to yysymprint.
2566 * tests/calc.at: Adjust.
2567 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
2568 taking advantage of parser very internal details (stack size!).
2569
4f25ebb0
AD
25702002-06-20 Akim Demaille <akim@epita.fr>
2571
2572 * src/scan-gram.l: Complete the scanner with the missing patterns
2573 to pacify Flex.
2574 Use `quote' and `symbol_tag_get' where appropriate.
2575
93b68a0e
AD
25762002-06-19 Akim Demaille <akim@epita.fr>
2577
2578 * tests/actions.at (Destructors): Augment to test locations.
2579 * data/bison.simple (yydestructor): Pass it the current location
2580 if locations are enabled.
2581 Prototype only when __STDC__ or C++.
2582 Change the argument names to move into the yy name space: there is
2583 user code here.
2584
58612f1d
AD
25852002-06-19 Akim Demaille <akim@epita.fr>
2586
74310291
AD
2587 * data/bison.simple (b4_pure_if): New.
2588 Use it instead of #ifdef YYPURE.
2589
25902002-06-19 Akim Demaille <akim@epita.fr>
2591
2592 * data/bison.simple (b4_location_if): New.
58612f1d
AD
2593 Use it instead of #ifdef YYLSP_NEEDED.
2594
f25bfb75
AD
25952002-06-19 Akim Demaille <akim@epita.fr>
2596
2597 Prepare @$ in %destructor, but currently don't bind it in the
2598 skeleton, as %location use is not cleaned up yet.
2599
2600 * src/scan-gram.l (handle_dollar, handle_destructor_at)
2601 (handle_action_at): New.
2602 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
2603 a braced_code_t and a location as additional arguments.
2604 (handle_destructor_dollar): Instead of requiring `b4_eval', just
2605 unquote one when outputting `b4_dollar_dollar'.
2606 Adjust callers.
2607 * data/bison.simple (b4_eval): Remove.
2608 (b4_symbol_destructor): Adjust.
2609 * tests/input.at (Invalid @n): Adjust.
2610
c732d2c6
AD
26112002-06-19 Zack Weinberg <zack@codesourcery.com>
2612
2613 * doc/bison.texinfo: Document ability to have multiple
2614 prologue sections.
2615
8c165d89
AD
26162002-06-18 Akim Demaille <akim@epita.fr>
2617
2618 * src/files.c (compute_base_names): When computing the output file
2619 names from the input file name, strip the directory part.
2620
ca98bf57
AD
26212002-06-18 Akim Demaille <akim@epita.fr>
2622
2623 * data/bison.simple.new: Comment changes.
2624 Reported by Andreas Schwab.
2625
0bfb02ff
AD
26262002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
2627
2628 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
2629 there are no `label `yyoverflowlab' defined but not used' warnings
2630 when yyoverflow is defined.
2631
24c0aad7
AD
26322002-06-18 Akim Demaille <akim@epita.fr>
2633
2634 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
2635 new member.
2636 (symbol_destructor_set): Adjust.
2637 * src/output.c (symbol_destructors_output): Output the destructor
2638 locations.
2639 Output the symbol name.
2640 * data/bison.simple (b4_symbol_destructor): Adjust.
2641
5719c109
AD
26422002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
2643 and Akim Demaille <akim@epita.fr>
2644
2645 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
2646 what's left on the stack when the error recovery hits EOF.
2647 * tests/actions.at (Destructors): Complete to exercise this case.
2648
9280d3ef
AD
26492002-06-17 Akim Demaille <akim@epita.fr>
2650
2651 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
2652 arguments is really empty, not only equal to `[]'.
2653 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
2654 member.
2655 (symbol_destructor_set): New.
2656 * src/output.c (symbol_destructors_output): New.
2657 * src/reader.h (brace_code_t, current_braced_code): New.
2658 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
2659 (handle_dollar): Rename as...
2660 (handle_action_dollar): this.
2661 (handle_destructor_dollar): New.
2662 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
2663 (grammar_declaration): Use it.
2664 * data/bison.simple (yystos): Is always defined.
2665 (yydestructor): New.
2666 * tests/actions.at (Destructors): New.
2667 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
2668
dafdc66f
AD
26692002-06-17 Akim Demaille <akim@epita.fr>
2670
2671 * src/symlist.h, src/symlist.c (symbol_list_length): New.
2672 * src/scan-gram.l (handle_dollar, handle_at): Compute the
2673 rule_length only when needed.
2674 * src/output.c (actions_output, token_definitions_output): Output
2675 the full M4 block.
2676 * src/symtab.c: Don't access directly to the symbol tag, use
2677 symbol_tag_get.
2678 * src/parse-gram.y: Use symbol_list_free.
2679
56c47203
AD
26802002-06-17 Akim Demaille <akim@epita.fr>
2681
2682 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
2683 (symbol_list_prepend, get_type_name): Move to...
2684 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
2685 (symbol_list_prepend, symbol_list_n_type_name_get): here.
2686 Adjust all callers.
2687 (symbol_list_free): New.
2688 * src/scan-gram.l (handle_dollar): Takes a location.
2689 * tests/input.at (Invalid $n): Adjust.
2690
1e0bab92
AD
26912002-06-17 Akim Demaille <akim@epita.fr>
2692
2693 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2694 (symbol_list_prepend): New.
2695 * src/parse-gram.y (%union): `list' is a new member.
2696 (symbols.1): New, replaces...
2697 (terms_to_prec.1, nterms_to_type.1): these.
2698 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2699 Take a location as additional argument.
2700 Adjust all callers.
2701
04e60654
AD
27022002-06-15 Akim Demaille <akim@epita.fr>
2703
2704 * src/parse-gram.y: Move %token in the declaration section so that
2705 we don't depend upon CVS Bison.
2706
10e5b8bd
AD
27072002-06-15 Akim Demaille <akim@epita.fr>
2708
2709 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2710 * src/print.c (print_core): Use it.
2711
9801d40c
AD
27122002-06-15 Akim Demaille <akim@epita.fr>
2713
2714 * src/conflicts.c (log_resolution): Accept the rule involved in
2715 the sr conflicts instead of the lookahead number that points to
2716 that rule.
2717 (flush_reduce): Accept the current lookahead vector as argument,
2718 instead of the index in LA.
2719 (resolve_sr_conflict): Accept the current number of lookahead
2720 bitset to consider for the STATE, instead of the index in LA.
2721 (set_conflicts): Adjust.
2722 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2723
c0263492
AD
27242002-06-15 Akim Demaille <akim@epita.fr>
2725
2726 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2727 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2728 Adjust all dependencies.
2729 * src/lalr.c (initialize_lookaheads): Split into...
2730 (states_lookaheads_count, states_lookaheads_initialize): these.
2731 (lalr): Adjust.
2732
9757c359
AD
27332002-06-15 Akim Demaille <akim@epita.fr>
2734
2735 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2736 out of...
2737 (grammar_rules_print): here.
2738 * src/reduce.c (reduce_output): Use it.
2739 * tests/reduce.at (Useless Rules, Reduced Automaton)
2740 (Underivable Rules): Adjust.
2741
6b98e4b5
AD
27422002-06-15 Akim Demaille <akim@epita.fr>
2743
2744 Copy BYacc's nice way to report the grammar.
2745
2746 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2747 New.
2748 Don't print the rules' location, it is confusing and useless.
2749 (rule_print): Use grammar_rhs_print.
2750 * src/print.c (print_grammar): Use grammar_rules_print.
2751
6b98e4b5
AD
27522002-06-15 Akim Demaille <akim@epita.fr>
2753
2754 Complete and rationalize `useless thing' warnings.
2755
2756 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2757 (symbol_tag_print): New.
2758 Use them everywhere in place of accessing directly the tag member.
2759 * src/gram.h, src/gram.c (rule_print): New.
2760 Use it where a rule used to be printed `by hand'.
2761 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2762 (reduce_grammar_tables): Report the useless rules.
2763 (reduce_print): Useless things are a warning, not an error.
2764 Report it as such.
2765 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2766 (Reduced Automaton, Underivable Rules): Adjust.
2767 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2768 * tests/conflicts.at (Unresolved SR Conflicts)
2769 (Solved SR Conflicts): Adjust.
2770
ee000ba4
AD
27712002-06-15 Akim Demaille <akim@epita.fr>
2772
2773 Let symbols have a location.
2774
2775 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2776 (getsym): Adjust.
2777 Adjust all callers.
2778 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2779 Use location_t, not int.
2780 * src/symtab.c (symbol_check_defined): Take advantage of the
2781 location.
2782 * tests/regression.at (Invalid inputs): Adjust.
2783
8efe435c
AD
27842002-06-15 Akim Demaille <akim@epita.fr>
2785
2786 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2787 (input): Don't try to initialize yylloc here, do it in the
2788 scanner.
2789 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2790 * src/gram.h (rule_t): Change line and action_line into location
2791 and action_location, of location_t type.
2792 Adjust all dependencies.
2793 * src/location.h, src/location.c (empty_location): New.
2794 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2795 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2796 (grammar_current_rule_symbol_append)
2797 (grammar_current_rule_action_append): Expect a location as argument.
2798 * src/reader.c (grammar_midrule_action): Adjust to attach an
2799 action's location as dummy symbol location.
2800 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2801 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2802 the line numbers.
2803
1921f1d7
AD
28042002-06-14 Akim Demaille <akim@epita.fr>
2805
2806 Grammar declarations may be found in the grammar section.
2807
2808 * src/parse-gram.y (rules_or_grammar_declaration): New.
2809 (declarations): Each declaration may end with a semicolon, not
2810 just...
2811 (grammar_declaration): `"%union"'.
2812 (grammar): Branch to rules_or_grammar_declaration.
2813
4515534c
AD
28142002-06-14 Akim Demaille <akim@epita.fr>
2815
2816 * src/main.c (main): Invoke scanner_free.
2817
f958596b
AD
28182002-06-14 Akim Demaille <akim@epita.fr>
2819
2820 * src/output.c (m4_invoke): Extracted from...
2821 (output_skeleton): here.
2822 Free tempfile.
2823
2c569025
AD
28242002-06-14 Akim Demaille <akim@epita.fr>
2825
2826 * src/parse-gram.y (directives, directive, gram)
2827 (grammar_directives, precedence_directives, precedence_directive):
2828 Rename as...
2829 (declarations, declaration, grammar, grammar_declaration)
2830 (precedence_declaration, precedence_declarator): these.
2831 (symbol_declaration): New.
2832
592e8d4d
AD
28332002-06-14 Akim Demaille <akim@epita.fr>
2834
2835 * src/files.c (action_obstack): Remove, unused.
2836 (output_obstack): Remove it, and all its dependencies, as it is no
2837 longer needed.
2838 * src/reader.c (epilogue_set): Build the epilogue in the
2839 muscle_obstack.
2840 * src/output.h, src/output.c (muscle_obstack): Move to...
2841 * src/muscle_tab.h, src/muscle_tab.h: here.
2842 (muscle_init): Initialize muscle_obstack.
2843 (muscle_free): New.
2844 * src/main.c (main): Call it.
2845
0c15323d
AD
28462002-06-14 Akim Demaille <akim@epita.fr>
2847
2848 * src/location.h: New, extracted from...
2849 * src/reader.h: here.
2850 * src/Makefile.am (noinst_HEADERS): Merge into
2851 (bison_SOURCES): this.
2852 Add location.h.
2853 * src/parse-gram.y: Use location_t instead of Bison's.
2854 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2855 Use location_t instead of ints.
2856
e96c9728
AD
28572002-06-14 Akim Demaille <akim@epita.fr>
2858
2859 * data/bison.simple, data/bison.c++: Be sure to restore the
2860 current #line when returning to the skeleton contents after having
2861 exposed the input file's #line.
2862
75d1fe16
AD
28632002-06-12 Akim Demaille <akim@epita.fr>
2864
2865 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2866 eager.
2867 * tests/actions.at (Exotic Dollars): New.
2868
6c35d22c
AD
28692002-06-12 Akim Demaille <akim@epita.fr>
2870
2871 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2872 ['"/] too eagerly.
2873 * tests/input.at (Torturing the Scanner): New.
2874
1d6412ad
AD
28752002-06-11 Akim Demaille <akim@epita.fr>
2876
2877 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2878 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2879 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2880 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2881 * src/reader.c (reader): Use it.
2882
4cdb01db
AD
28832002-06-11 Akim Demaille <akim@epita.fr>
2884
2885 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2886 Adjust all callers.
2887 (scanner_last_string_free): New.
2888
44995b2e
AD
28892002-06-11 Akim Demaille <akim@epita.fr>
2890
2891 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2892 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2893 (last_string, YY_OBS_FREE): New.
2894 Use them when returning an ID.
2895
e9955c83
AD
28962002-06-11 Akim Demaille <akim@epita.fr>
2897
2898 Have Bison grammars parsed by a Bison grammar.
2899
2900 * src/reader.c, src/reader.h (prologue_augment): New.
2901 * src/reader.c (copy_definition): Remove.
2902
2903 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2904 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2905 (grammar_current_rule_prec_set, grammar_current_rule_check)
2906 (grammar_current_rule_symbol_append)
2907 (grammar_current_rule_action_append): Export.
2908 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2909 (symbol_list_action_append): Remove.
2910 Hook the routines from reader.
2911 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2912 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2913
2914 * src/reader.c (read_declarations): Remove, unused.
2915
2916 * src/parse-gram.y: Handle the epilogue.
2917 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2918 (grammar_start_symbol_set): this.
2919 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2920 * src/reader.c (readgram): Remove, unused.
2921 (reader): Adjust to insert eoftoken and axiom where appropriate.
2922
2923 * src/reader.c (copy_dollar): Replace with...
2924 * src/scan-gram.h (handle_dollar): this.
2925 * src/parse-gram.y: Remove `%thong'.
2926
2927 * src/reader.c (copy_at): Replace with...
2928 * src/scan-gram.h (handle_at): this.
2929
2930 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2931 New.
2932
2933 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2934 time being.
2935
2936 * src/reader.h, src/reader.c (grammar_rule_end): New.
2937
2938 * src/parse.y (current_type, current_class): New.
2939 Implement `%nterm', `%token' support.
2940 Merge `%term' into `%token'.
2941 (string_as_id): New.
2942 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2943 type name.
2944
2945 * src/parse-gram.y: Be sure to handle properly the beginning of
2946 rules.
2947
2948 * src/parse-gram.y: Handle %type.
2949 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2950
2951 * src/parse-gram.y: More directives support.
2952 * src/options.c: No longer handle source directives.
2953
2954 * src/parse-gram.y: Fix %output.
2955
2956 * src/parse-gram.y: Handle %union.
2957 Use the prologue locations.
2958 * src/reader.c (parse_union_decl): Remove.
2959
2960 * src/reader.h, src/reader.c (epilogue_set): New.
2961 * src/parse-gram.y: Use it.
2962
2963 * data/bison.simple, data/bison.c++: b4_stype is now either not
2964 defined, then default to int, or to the contents of %union,
2965 without `union' itself.
2966 Adjust.
2967 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2968
2969 * src/output.c (actions_output): Don't output braces, as they are
2970 already handled by the scanner.
2971
2972 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2973 characters to themselves.
2974
2975 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2976 that the epilogue has a proper #line.
2977
2978 * src/parse-gram.y: Handle precedence/associativity.
2979
2980 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2981 a terminal.
2982 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2983 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2984 at all to define terminals that cannot be emitted.
2985
2986 * src/scan-gram.l: Escape M4 characters.
2987
2988 * src/scan-gram.l: Working properly with escapes in user
2989 strings/characters.
2990
2991 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2992 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2993 grammar.
2994 Use more modest sizes, as for the time being the parser does not
2995 release memory, and therefore the process swallows a huge amount
2996 of memory.
2997
2998 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2999 stricter %token grammar.
3000
3001 * src/symtab.h (associativity): Add `undef_assoc'.
3002 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3003 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3004
3005 * tests/regression.at (Invalid %directive): Remove, as it is now
3006 meaningless.
3007 (Invalid inputs): Adjust to the new error messages.
3008 (Token definitions): The new grammar doesn't allow too many
3009 eccentricities.
3010
3011 * src/lex.h, src/lex.c: Remove.
3012 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3013 (copy_character, copy_string2, copy_string, copy_identifier)
3014 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3015 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3016 (parse_action): Remove.
3017 * po/POTFILES.in: Adjust.
3018
2e047461
AD
30192002-06-11 Akim Demaille <akim@epita.fr>
3020
3021 * src/reader.c (parse_action): Don't store directly into the
3022 rule's action member: return the action as a string.
3023 Don't require `rule_length' as an argument: compute it.
3024 (grammar_current_rule_symbol_append)
3025 (grammar_current_rule_action_append): New, eved out from
3026 (readgram): here.
3027 Remove `action_flag', `rulelength', unused now.
3028
9af3fbce
AD
30292002-06-11 Akim Demaille <akim@epita.fr>
3030
3031 * src/reader.c (grammar_current_rule_prec_set).
3032 (grammar_current_rule_check): New, eved out from...
3033 (readgram): here.
3034 Remove `xaction', `first_rhs': useless.
3035 * tests/input.at (Type clashes): New.
3036 * tests/existing.at (GNU Cim Grammar): Adjust.
3037
1485e106
AD
30382002-06-11 Akim Demaille <akim@epita.fr>
3039
3040 * src/reader.c (grammar_midrule_action): New, Eved out from
3041 (readgram): here.
3042
da4160c3
AD
30432002-06-11 Akim Demaille <akim@epita.fr>
3044
3045 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3046 New.
3047 (readgram): Use them as replacement of inlined code, crule and
3048 crule1.
3049
f6d0f937
AD
30502002-06-11 Akim Demaille <akim@epita.fr>
3051
3052 * src/reader.c (grammar_end, grammar_symbol_append): New.
3053 (readgram): Use them.
3054 Make the use of `p' as local as possible.
3055
69078d4b
AD
30562002-06-10 Akim Demaille <akim@epita.fr>
3057
3058 GCJ's parser requires the tokens to be defined before the prologue.
3059
3060 * data/bison.simple: Output the token definition before the user's
3061 prologue.
3062 * tests/regression.at (Braces parsing, Duplicate string)
3063 (Mixing %token styles): Check the output from bison.
3064 (Early token definitions): New.
3065
5e424082
AD
30662002-06-10 Akim Demaille <akim@epita.fr>
3067
3068 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3069 assigning twice the same user number to a token, so that we can
3070 use it in...
3071 * src/lex.c (lex): here.
3072 Also use `symbol_class_set' instead of hand written code.
3073 * src/reader.c (parse_assoc_decl): Likewise.
3074
44536b35
AD
30752002-06-10 Akim Demaille <akim@epita.fr>
3076
3077 * src/symtab.c, src/symtab.c (symbol_class_set)
3078 (symbol_user_token_number_set): New.
3079 * src/reader.c (parse_token_decl): Use them.
3080 Use a switch instead of ifs.
3081 Use a single argument.
3082
8b9f2372
AD
30832002-06-10 Akim Demaille <akim@epita.fr>
3084
3085 Remove `%thong' support as it is undocumented, unused, duplicates
3086 `%token's job, and creates useless e-mail traffic with people who
3087 want to know what it is, why it is undocumented, unused, and
3088 duplicates `%token's job.
3089
3090 * src/reader.c (parse_thong_decl): Remove.
3091 * src/options.c (option_table): Remove "thong".
3092 * src/lex.h (tok_thong): Remove.
3093
3ae2b51f
AD
30942002-06-10 Akim Demaille <akim@epita.fr>
3095
3096 * src/symtab.c, src/symtab.c (symbol_type_set)
3097 (symbol_precedence_set): New.
3098 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3099 (value_components_used): Remove, unused.
3100
2f1afb73
AD
31012002-06-09 Akim Demaille <akim@epita.fr>
3102
3103 Move symbols handling code out of the reader.
3104
3105 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3106 (axiom): Move to...
3107 * src/symtab.h, src/symtab.c: here.
3108
3109 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3110 * src/reader.c (startval): Rename as...
3111 * src/symtab.h, src/symtab.c (startsymbol): this.
3112 * src/reader.c: Adjust.
3113
3114 * src/reader.c (symbol_check_defined, symbol_make_alias)
3115 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3116 (token_translations_init)
3117 Move to...
3118 * src/symtab.c: here.
3119 * src/reader.c (packsymbols): Move to...
3120 * src/symtab.h, src/symtab.c (symbols_pack): here.
3121 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3122 argument.
3123
e9bca3ad
AD
31242002-06-03 Akim Demaille <akim@epita.fr>
3125
3126 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3127 then statements.
3128
86eff183
AD
31292002-06-03 Akim Demaille <akim@epita.fr>
3130
3131 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3132 structs with non literals.
3133 * src/scan-skel.l: never-interactive.
3134 * src/conflicts.c (enum conflict_resolution_e): No trailing
3135 comma.
3136 * src/getargs.c (usage): Split long literal strings.
3137 Reported by Hans Aberg.
3138
717be197
AD
31392002-05-28 Akim Demaille <akim@epita.fr>
3140
3141 * data/bison.c++: Use C++ ostreams.
3142 (cdebug_): New member.
3143
670ddffd
AD
31442002-05-28 Akim Demaille <akim@epita.fr>
3145
3146 * src/output.c (output_skeleton): Be sure to allocate enough room
3147 for `/' _and_ for `\0' in full_skeleton.
3148
769b430f
AD
31492002-05-28 Akim Demaille <akim@epita.fr>
3150
3151 * data/bison.c++: Catch up with bison.simple:
3152 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3153 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3154 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3155 and popping traces.
3156
7067cb36
PH
31572002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3158
3159 * src/output.c (output_skeleton): Put an explicit path in front of
3160 the skeleton file name, rather than relying on the -I directory,
3161 to partially alleviate effects of having a skeleton file lying around
3162 in the current directory.
769b430f 3163
4a713ec2
PH
31642002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3165
769b430f 3166 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
3167 obstack_printf should be obstack_fgrow1.
3168
b408954b
AD
31692002-05-26 Akim Demaille <akim@epita.fr>
3170
3171 * src/state.h (state_t): `solved_conflicts' is a new member.
3172 * src/LR0.c (new_state): Set it to 0.
3173 * src/conflicts.h, src/conflicts.c (print_conflicts)
3174 (free_conflicts, solve_conflicts): Rename as...
3175 (conflicts_print, conflicts_free, conflicts_solve): these.
3176 Adjust callers.
3177 * src/conflicts.c (enum conflict_resolution_e)
3178 (solved_conflicts_obstack): New, used by...
3179 (log_resolution): this.
3180 Adjust to attach the conflict resolution to each state.
3181 Complete the description with the precedence/associativity
3182 information.
3183 (resolve_sr_conflict): Adjust.
3184 * src/print.c (print_state): Output its solved_conflicts.
3185 * tests/conflicts.at (Unresolved SR Conflicts)
3186 (Solved SR Conflicts): Exercise --report=all.
3187
a49aecd5
AD
31882002-05-26 Akim Demaille <akim@epita.fr>
3189
3190 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3191 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3192 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3193 (token_number_t, item_number_as_token_number)
3194 (token_number_as_item_number, muscle_insert_token_number_table):
3195 Rename as...
3196 (symbol_number_t, item_number_as_symbol_number)
3197 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3198 these, since it is more appropriate.
3199
5504898e
AD
32002002-05-26 Akim Demaille <akim@epita.fr>
3201
3202 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3203 `Error:' lines.
3204 * data/bison.simple (yystos) [YYDEBUG]: New.
3205 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3206 error recovery.
3207 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3208
ec3bc396
AD
32092002-05-25 Akim Demaille <akim@epita.fr>
3210
3211 * doc/bison.texinfo (Debugging): Split into...
3212 (Tracing): this new section, its former contents, and...
3213 (Understanding): this new section.
3214 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3215 by...
3216 (report_flag): this.
3217 Adjust all dependencies.
3218 (report_args, report_types, report_argmatch): New.
3219 (usage, getargs): Report/support -r, --report.
3220 * src/options.h
3221 (struct option_table_struct): Rename as..,
3222 (struct option_table_s): this.
3223 Rename the `set_flag' member to `flag' to match with getopt_long's
3224 struct.
3225 * src/options.c (option_table): Split verbose into an entry for
3226 %verbose, and another for --verbose.
3227 Support --report/-r, so remove -r from the obsolete --raw.
3228 * src/print.c: Attach full item sets and lookaheads reports to
3229 report_flag instead of trace_flag.
3230 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3231
78df8250
PE
32322002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3233 and Paul Eggert <eggert@twinsun.com>
769b430f 3234
78df8250
PE
3235 * data/bison.simple (yyparse): Correct error handling to conform to
3236 POSIX and yacc. Specifically, after syntax error is discovered,
3237 do not reduce further before shifting the error token.
3238 Clean up the code a bit by removing the labels yyerrdefault,
3239 yyerrhandle, yyerrpop.
3240 * NEWS: Document the above.
3241
c0c9ea05
PH
32422002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3243
3244 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3245 type; it isn't always big enough, since it doesn't necessarily
3246 include non-terminals.
769b430f 3247 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
3248 the latter can be removed.
3249 (yy_token_number_type): Remove, only one use.
3250 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3251 don't use TokenNumberType as element type.
769b430f 3252
c0c9ea05
PH
3253 * tests/regression.at: Modify expected output to agree with change
3254 to yyr1 and yytranslate.
769b430f 3255
6390a83f
FK
32562002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3257
3258 * src/reader.c (parse_action): Use copy_character instead of
3259 obstack_1grow.
3260
db7c8e9a
AD
32612002-05-13 Akim Demaille <akim@epita.fr>
3262
3263 * tests/regression.at (Token definitions): Prototype yylex and
3264 yyerror.
3265
fcc61800
PH
32662002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3267
158c687b 3268 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
3269 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3270 32-bit arithmetic.
3271 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3272
5683e9b2
AD
32732002-05-07 Akim Demaille <akim@epita.fr>
3274
3275 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3276 avoid GCC warnings.
3277
0c2d3f4c
AD
32782002-05-07 Akim Demaille <akim@epita.fr>
3279
3280 Kill GCC warnings.
3281
3282 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3283 over the RHS of each rule.
3284 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3285 * src/state.h (state_t): Member `nitems' is unsigned short.
3286 * src/LR0.c (get_state): Adjust.
3287 * src/reader.c (packgram): Likewise.
3288 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3289 `Type'.
3290 (muscle_insert_int_table): Remove, unused.
3291 (prepare_rules): Remove `max'.
3292
1565b720
AD
32932002-05-06 Akim Demaille <akim@epita.fr>
3294
3295 * src/closure.c (print_firsts): Display of the symbol tags.
3296 (bitmatrix_print): Move to...
3297 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
3298 here.
3299 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
3300
cfaee611
AD
33012002-05-06 Akim Demaille <akim@epita.fr>
3302
3303 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
3304 hash_do_for_each.
3305
458be8e0
AD
33062002-05-06 Akim Demaille <akim@epita.fr>
3307
3308 * src/LR0.c (new_state, get_state): Instead of using the global
3309 `kernel_size' and `kernel_base', have two new arguments:
3310 `core_size' and `core'.
3311 Adjust callers.
3312
a900a624
AD
33132002-05-06 Akim Demaille <akim@epita.fr>
3314
3315 * src/reader.c (packgram): No longer end `ritem' with a 0
3316 sentinel: it is not used.
3317
d4e7d3a1
AD
33182002-05-05 Akim Demaille <akim@epita.fr>
3319
3320 New experimental feature: display the lookaheads in the report and
3321 graph.
3322
3323 * src/print (print_core): When --trace-flag, display the rules
3324 lookaheads.
3325 * src/print_graph.c (print_core): Likewise.
3326 Swap the arguments.
3327 Adjust caller.
3328
39ceb25b
AD
33292002-05-05 Akim Demaille <akim@epita.fr>
3330
3331 * tests/torture.at (Many lookaheads): New test.
3332
5372019f
AD
33332002-05-05 Akim Demaille <akim@epita.fr>
3334
3335 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
3336 (GENERATE_MUSCLE_INSERT_TABLE): this.
3337 (output_int_table, output_unsigned_int_table, output_short_table)
3338 (output_token_number_table, output_item_number_table): Replace with...
3339 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
3340 (muscle_insert_short_table, muscle_insert_token_number_table)
3341 (muscle_insert_item_number_table): these.
3342 Adjust all callers.
3343 (prepare_tokens): Don't free `translations', since...
3344 * src/reader.h, src/reader.c (grammar_free): do it.
3345 Move to...
3346 * src/gram.h, src/gram.c (grammar_free): here.
3347 * data/bison.simple, data/bison.c++: b4_token_number_max is now
3348 b4_translate_max.
3349
5df5f6d5
AD
33502002-05-05 Akim Demaille <akim@epita.fr>
3351
3352 * src/output.c (output_unsigned_int_table): New.
3353 (prepare_rules): `i' is unsigned.
3354 `prhs', `rline', `r2' are unsigned int.
3355 Rename muscle `rhs_number_max' as `rhs_max'.
3356 Output muscles `prhs_max', `rline_max', and `r2_max'.
3357 Free rline and r1.
3358 * data/bison.simple, data/bison.c++: Adjust to use these muscles
3359 to compute types instead of constant types.
3360 * tests/regression.at (Web2c Actions): Adjust.
3361
b87f8b21
AD
33622002-05-04 Akim Demaille <akim@epita.fr>
3363
3364 * src/symtab.h (SALIAS, SUNDEF): Rename as...
3365 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
3366 Adjust dependencies.
3367 * src/output.c (token_definitions_output): Be sure not to output a
3368 `#define 'a'' when fed with `%token 'a' "a"'.
3369 * tests/regression.at (Token definitions): New.
3370
8bb936e4
PE
33712002-05-03 Paul Eggert <eggert@twinsun.com>
3372
3373 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
3374 for K&R C.
3375
33762002-05-03 gettextize <bug-gnu-gettext@gnu.org>
3377
3378 * Makefile.am (SUBDIRS): Remove intl.
3379 (EXTRA_DIST): Add config/config.rpath.
3380
53c71a12
AD
33812002-05-03 Akim Demaille <akim@epita.fr>
3382
3383 * data/bison.simple (m4_if): Don't output empty enums.
3384 And actually, output valid enum definitions :(.
3385
289dd0cf
AD
33862002-05-03 Akim Demaille <akim@epita.fr>
3387
3388 * configure.bat: Remove, completely obsolete.
3389 * Makefile.am (EXTRA_DIST): Adjust.
3390 Don't distribute config.rpath...
3391 * config/Makefile.am (EXTRA_DIST): Do it.
3392
db85e524
AD
33932002-05-03 Akim Demaille <akim@epita.fr>
3394
3395 * configure.in (GETTEXT_VERSION): New.
3396 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
3397
83ccf991
AD
33982002-05-03 Akim Demaille <akim@epita.fr>
3399
3400 * data/bison.simple (b4_token_enum): New.
3401 (b4_token_defines): Use it to output tokens both as #define and
3402 enums.
3403 Suggested by Paul Eggert.
3404 * src/output.c (token_definitions_output): Don't output spurious
3405 white spaces.
3406
1f418995
AD
34072002-05-03 Akim Demaille <akim@epita.fr>
3408
3409 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3410
45119f04
RA
34112002-05-02 Robert Anisko <robert@lrde.epita.fr>
3412
3413 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
3414 Update the stack class, give a try to deque as the default container.
3415
b2d52318
AD
34162002-05-02 Akim Demaille <akim@epita.fr>
3417
3418 * data/bison.simple (yyparse): Do not implement @$ = @1.
3419 (YYLLOC_DEFAULT): Adjust to do it.
3420 * doc/bison.texinfo (Location Default Action): Fix.
3421
3a8b4109
AD
34222002-05-02 Akim Demaille <akim@epita.fr>
3423
3424 * src/reader.c (parse_braces): Merge into...
3425 (parse_action): this.
3426
84614e13
AD
34272002-05-02 Akim Demaille <akim@epita.fr>
3428
3429 * configure.in (ALL_LINGUAS): Remove.
3430 * po/LINGUAS, hr.po: New.
3431
fdbcd8e2
AD
34322002-05-02 Akim Demaille <akim@epita.fr>
3433
3434 Remove the so called hairy (semantic) parsers.
3435
3436 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
3437 * src/gram.h, src/gram.c (semantic_parser): Remove.
3438 (rule_t): Remove the guard and guard_line members.
3439 * src/lex.h (token_t): remove tok_guard.
3440 * src/options.c (option_table): Remove %guard and %semantic_parser
3441 support.
3442 * src/output.c, src/output.h (guards_output): Remove.
3443 (prepare): Adjust.
3444 (token_definitions_output): Don't output the `T'
3445 tokens (???).
3446 (output_skeleton): Don't output the guards.
3447 * src/files.c, src/files.c (attrsfile): Remove.
3448 * src/reader.c (symbol_list): Remove the guard and guard_line
3449 members.
3450 Adjust dependencies.
3451 (parse_guard): Remove.
3452 * data/bison.hairy: Remove.
3453 * doc/bison.texinfo (Environment Variables): Remove occurrences of
3454 BISON_HAIRY.
3455
82b6cb3f
AD
34562002-05-02 Akim Demaille <akim@epita.fr>
3457
3458 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
3459 (parse_guard): Rename the formal argument `stack_offset' as
3460 `rule_length', which is more readable.
3461 Adjust callers.
3462 (copy_at, copy_dollar): Instead of outputting the hard coded
3463 values of $$, $n and so forth, output invocation to b4_lhs_value,
3464 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
3465 Note: this patch partially drops `semantic-parser' support: it
3466 always does `rule_length - n', where semantic parsers ought to
3467 always use `-n'.
82b6cb3f
AD
3468 * data/bison.simple, data/bison.c++ (b4_lhs_value)
3469 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
3470
6cbfbcc5
AD
34712002-05-02 Akim Demaille <akim@epita.fr>
3472
3473 * configure.in (AC_INIT): Bump to 1.49b.
3474 (AM_INIT_AUTOMAKE): Short invocation.
3475
b8548114
AD
34762002-05-02 Akim Demaille <akim@epita.fr>
3477
3478 Version 1.49a.
3479
c20cd1fa
AD
34802002-05-01 Akim Demaille <akim@epita.fr>
3481
3482 * src/skeleton.h: Remove.
3483
8a9566d4
AD
34842002-05-01 Akim Demaille <akim@epita.fr>
3485
3486 * src/skeleton.h: Fix the #endif.
3487 Reported by Magnus Fromreide.
3488
8c6d399a
PE
34892002-04-26 Paul Eggert <eggert@twinsun.com>
3490
3491 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
3492 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 3493 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 3494
2b7ed18a
RA
34952002-04-25 Robert Anisko <robert@lrde.epita.fr>
3496
3497 * src/scan-skel.l: Postprocess quadrigraphs.
3498
3499 * src/reader.c (copy_character): New function, used to output
3500 single characters while replacing `[' and `]' with quadrigraphs, to
3501 avoid troubles with M4 quotes.
3502 (copy_comment): Output characters with copy_character.
3503 (read_additionnal_code): Likewise.
3504 (copy_string2): Likewise.
3505 (copy_definition): Likewise.
3506
3507 * tests/calc.at: Exercise M4 quoting.
3508
34a89c50
AD
35092002-04-25 Akim Demaille <akim@epita.fr>
3510
3511 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
3512 between `!' and the command.
3513 Reported by Paul Eggert.
3514
0dd1580a
RA
35152002-04-24 Robert Anisko <robert@lrde.epita.fr>
3516
3517 * tests/calc.at: Exercise prologue splitting.
3518
3519 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
3520 `b4_post_prologue' instead of `b4_prologue'.
3521
3522 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
3523 muscles.
3524 (output): Free pre_prologue_obstack and post_prologue_obstack.
3525 * src/files.h, src/files.c (attrs_obstack): Remove.
3526 (pre_prologue_obstack, post_prologue_obstack): New.
3527 * src/reader.c (copy_definition): Add a parameter to specify the
3528 obstack to fill, instead of using attrs_obstack unconditionally.
3529 (read_declarations): Pass pre_prologue_obstack to copy_definition if
3530 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
3531
83c1796f
PE
35322002-04-23 Paul Eggert <eggert@twinsun.com>
3533
3534 * data/bison.simple: Remove unnecessary commentary and white
3535 space differences from 1_29-branch.
3536 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
3537
3538 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
3539 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
3540 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
3541 constructors or destructors.
3542
3543 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
3544
1207eeac
AD
35452002-04-23 Akim Demaille <akim@epita.fr>
3546
3547 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
3548 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
3549 location with columns.
3550 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
3551 All reported by Paul Eggert.
3552
78ab8f67
AD
35532002-04-22 Akim Demaille <akim@epita.fr>
3554
3555 * src/reduce.c (dump_grammar): Move to...
3556 * src/gram.h, src/gram.c (grammar_dump): here.
3557 Be sure to separate long item numbers.
3558 Don't read the members of a rule's prec if its nil.
3559
133c20e2
AD
35602002-04-22 Akim Demaille <akim@epita.fr>
3561
3562 * src/output.c (table_size, table_grow): New.
3563 (MAXTABLE): Remove, replace uses with table_size.
3564 (pack_vector): Instead of dying when the table is too big, grow it.
3565
9515e8a7
AD
35662002-04-22 Akim Demaille <akim@epita.fr>
3567
3568 * data/bison.simple (yyr1): Its type is that of a token number.
3569 * data/bison.c++ (r1_): Likewise.
3570 * tests/regression.at (Web2c Actions): Adjust.
3571
23c5a174
AD
35722002-04-22 Akim Demaille <akim@epita.fr>
3573
3574 * src/reader.c (token_translations_init): 256 is now the default
3575 value for the error token, i.e., it will be assigned another
3576 number if the user assigned 256 to one of her tokens.
3577 (reader): Don't force 256 to error.
3578 * doc/bison.texinfo (Symbols): Adjust.
3579 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
3580 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
3581 etc. instead of 10, 20, 30 (which was used to `jump' over error
3582 (256) and undefined (2)).
3583
5fbb0954
AD
35842002-04-22 Akim Demaille <akim@epita.fr>
3585
3586 Propagate more token_number_t.
3587
3588 * src/gram.h (token_number_as_item_number)
3589 (item_number_as_token_number): New.
3590 * src/output.c (GENERATE_OUTPUT_TABLE): New.
3591 Use it to create output_item_number_table and
3592 output_token_number_table.
3593 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3594 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
3595 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
3596 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
3597
4f940944
AD
35982002-04-22 Akim Demaille <akim@epita.fr>
3599
3600 * src/output.h, src/output.c (get_lines_number): Remove.
3601
3ded9a63
AD
36022002-04-19 Akim Demaille <akim@epita.fr>
3603
3604 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
3605 as Lex/Flex'.
3606 (Debugging): More details about enabling the debugging features.
3607 (Table of Symbols): Describe $$, $n, @$, and @n.
3608 Suggested by Tim Josling.
3609
e0c471a9
AD
36102002-04-19 Akim Demaille <akim@epita.fr>
3611
3612 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
3613
fecc10cd
AD
36142002-04-10 Akim Demaille <akim@epita.fr>
3615
3616 * src/system.h: Rely on HAVE_LIMITS_H.
3617 Suggested by Paul Eggert.
3618
51dec47b
AD
36192002-04-09 Akim Demaille <akim@epita.fr>
3620
3621 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
3622 full stderr, and strip it according to the bison options, instead
3623 of composing the error message from different bits.
3624 This makes it easier to check for several error messages.
3625 Adjust all the invocations.
3626 Add an invocation exercising the error token.
3627 Add an invocation demonstrating a stupid error message.
3628 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
3629 Adjust the tests.
3630 Error message are for stderr, not stdout.
3631
007a50a4
AD
36322002-04-09 Akim Demaille <akim@epita.fr>
3633
3634 * src/gram.h, src/gram.c (error_token_number): Remove, use
3635 errtoken->number.
3636 * src/reader.c (reader): Don't specify the user token number (2)
3637 for $undefined, as it uselessly prevents using it.
3638 * src/gram.h (token_number_t): Move to...
3639 * src/symtab.h: here.
3640 (state_t.number): Is a token_number_t.
3641 * src/print.c, src/reader.c: Use undeftoken->number instead of
3642 hard coded 2.
3643 (Even though this 2 is not the same as above: the number of the
3644 undeftoken remains being 2, it is its user token number which
3645 might not be 2).
3646 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
3647 `user_token_number_max'.
3648 Output `undef_token_number'.
3649 * data/bison.simple, data/bison.c++: Use them.
3650 Be sure to map invalid yylex return values to
3651 `undef_token_number'. This saves us from gratuitous SEGV.
3652
3653 * tests/conflicts.at (Solved SR Conflicts)
3654 (Unresolved SR Conflicts): Adjust.
3655 * tests/regression.at (Web2c Actions): Adjust.
3656
06446ccf
AD
36572002-04-08 Akim Demaille <akim@epita.fr>
3658
3659 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
3660 Adding #line.
3661 Remove the duplicate `typedefs'.
3662 (RhsNumberType): Fix the declaration and various other typos.
3663 Use __ofile__.
3664 * data/bison.simple: Use __ofile__.
3665 * src/scan-skel.l: Handle __ofile__.
3666
62a3e4f0
AD
36672002-04-08 Akim Demaille <akim@epita.fr>
3668
3669 * src/gram.h (item_number_t): New, the type of item numbers in
3670 RITEM. Note that it must be able to code symbol numbers as
3671 positive number, and the negation of rule numbers as negative
3672 numbers.
3673 Adjust all dependencies (pretty many).
3674 * src/reduce.c (rule): Remove this `short *' pointer: use
3675 item_number_t.
3676 * src/system.h (MINSHORT, MAXSHORT): Remove.
3677 Include `limits.h'.
3678 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
3679 (shortcpy): Remove.
3680 (MAXTABLE): Move to...
3681 * src/output.c (MAXTABLE): here.
3682 (prepare_rules): Use output_int_table to output rhs.
3683 * data/bison.simple, data/bison.c++: Adjust.
3684 * tests/torture.at (Big triangle): Move the limit from 254 to
3685 500.
3686 * tests/regression.at (Web2c Actions): Ajust.
3687
3688 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
3689 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3690 passes, but produces negative #line number, once fixed, GCC is
3691 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3692 C), it passes.
3693 * src/state.h (state_h): Code input lines on ints, not shorts.
3694
bb88b0fc
AD
36952002-04-08 Akim Demaille <akim@epita.fr>
3696
3697 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3698 and then the grammar.
3699
9a636f47
AD
37002002-04-08 Akim Demaille <akim@epita.fr>
3701
3702 * src/system.h: No longer using strndup.
3703
680e8701
AD
37042002-04-07 Akim Demaille <akim@epita.fr>
3705
3706 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3707 * src/output.c (output_table_data): Return the longest number.
3708 (prepare_tokens): Output `token_number_max').
3709 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3710 New.
3711 Use them to define yy_token_number_type/TokenNumberType.
3712 Use this type for yytranslate.
3713 * tests/torture.at (Big triangle): Push the limit from 124 to
3714 253.
3715 * tests/regression.at (Web2c Actions): Adjust.
3716
817e9f41
AD
37172002-04-07 Akim Demaille <akim@epita.fr>
3718
3719 * tests/torture.at (Big triangle): New.
3720 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3721 * tests/existing.at: here.
3722
5123689b
AD
37232002-04-07 Akim Demaille <akim@epita.fr>
3724
3725 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3726 nritems.
3727 Adjust dependencies.
3728
f3849179
AD
37292002-04-07 Akim Demaille <akim@epita.fr>
3730
3731 * src/reader.c: Normalize increments to prefix form.
3732
bd02036a
AD
37332002-04-07 Akim Demaille <akim@epita.fr>
3734
3735 * src/reader.c, symtab.c: Remove debugging code.
3736
db8837cb
AD
37372002-04-07 Akim Demaille <akim@epita.fr>
3738
3739 Rename all the `bucket's as `symbol_t'.
3740
3741 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3742 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3743 * src/symtab.c, src/symtab.h (bucket): Rename as...
3744 (symbol_t): this.
3745 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3746 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3747 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3748 (buckets_new, buckets_free, buckets_do): Rename as...
3749 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3750 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3751 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3752 (symbols_new, symbols_free, symbols_do): these.
3753
72a23c97
AD
37542002-04-07 Akim Demaille <akim@epita.fr>
3755
3756 Use lib/hash for the symbol table.
3757
3758 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3759 EOF.
3760 * src/lex.c (lex): Set the `number' member of new terminals.
3761 * src/reader.c (bucket_check_defined, bucket_make_alias)
3762 (bucket_check_alias_consistence, bucket_translation): New.
3763 (reader, grammar_free, readgram, token_translations_init)
3764 (packsymbols): Adjust.
3765 (reader): Number the predefined tokens.
3766 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3767 for predefined tokens.
3768 * src/symtab.h (bucket): Remove all the hash table related
3769 members.
3770 * src/symtab.c (symtab): Replace by...
3771 (bucket_table): this.
3772 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3773 (buckets_new, buckets_do): New.
3774
280a38c3
AD
37752002-04-07 Akim Demaille <akim@epita.fr>
3776
3777 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3778 (start_symbol, max_user_token_number, semantic_parser)
3779 (error_token_number): Initialize.
3780 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3781 Initialize.
3782 (reader): Don't.
3783 (errtoken, eoftoken, undeftoken, axiom): Extern.
3784
03b31c0c
AD
37852002-04-07 Akim Demaille <akim@epita.fr>
3786
3787 * src/gram.h (rule_s): prec and precsym are now pointers
3788 to the bucket giving the priority/associativity.
3789 Member `associativity' removed: useless.
3790 * src/reduce.c, src/conflicts.c: Adjust.
3791
8b3df748
AD
37922002-04-07 Akim Demaille <akim@epita.fr>
3793
3794 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3795 Properly escape the symbols' TAG when outputting them.
3796
e601aa1d
AD
37972002-04-07 Akim Demaille <akim@epita.fr>
3798
3799 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3800
b0299a2e
AD
38012002-04-07 Akim Demaille <akim@epita.fr>
3802
3803 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3804 (LArule): this, which is an array to rule_t*.
3805 * src/print.c, src/conflicts.c: Adjust.
3806
d7e1f00c
AD
38072002-04-07 Akim Demaille <akim@epita.fr>
3808
3809 * src/gram.h (rule_t): Rename `number' as `user_number'.
3810 `number' is a new member.
3811 Adjust dependencies.
3812 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3813
cc9305dd
AD
38142002-04-07 Akim Demaille <akim@epita.fr>
3815
3816 As a result of the previous patch, it is no longer needed
3817 to reorder ritem itself.
3818
3819 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3820
b0940840
AD
38212002-04-07 Akim Demaille <akim@epita.fr>
3822
3823 Be sure never to walk through RITEMS, but use only data related to
3824 the rules themselves. RITEMS should be banished.
3825
3826 * src/output.c (output_token_translations): Rename as...
3827 (prepare_tokens): this.
3828 In addition to `translate', prepare the muscles `tname' and
3829 `toknum', which were handled by...
3830 (output_rule_data): this.
3831 Remove, and move the remainder of its outputs into...
3832 (prepare_rules): this new routines, which also merges content from
3833 (output_gram): this.
3834 (prepare_rules): Be sure never to walk through RITEMS.
3835 (output_stos): Rename as...
3836 (prepare_stos): this.
3837 (output): Always invoke prepare_states, after all, just don't use it
3838 in the output if you don't need it.
3839
643a5994
AD
38402002-04-07 Akim Demaille <akim@epita.fr>
3841
3842 * src/LR0.c (new_state): Display `nstates' as the name of the
3843 newly created state.
3844 Adjust to initialize first_state and last_state if needed.
3845 Be sure to distinguish the initial from the final state.
3846 (new_states): Create the itemset of the initial state, and use
3847 new_state.
3848 * src/closure.c (closure): Now that the initial state has its
3849 items properly set, there is no need for a special case when
3850 creating `ruleset'.
3851
3852 As a result, now the rule 0, reducing to $axiom, is visible in the
3853 outputs. Adjust the test suite.
3854
3855 * tests/conflicts.at (Solved SR Conflicts)
3856 (Unresolved SR Conflicts): Adjust.
3857 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3858 * tests/conflicts.at (S/R in initial): New.
3859
b4c4ccc2
AD
38602002-04-07 Akim Demaille <akim@epita.fr>
3861
3862 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3863 the RHS of the rules.
3864 * src/output.c (output_gram): Likewise.
3865
bba97eb2
AD
38662002-04-07 Akim Demaille <akim@epita.fr>
3867
3868 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3869 bucket.
3870 Adjust all dependencies.
3871 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3872 `number' of the buckets too.
3873 * src/gram.h: Include `symtab.h'.
3874 (associativity): Move to...
3875 * src/symtab.h: here.
3876 No longer include `gram.h'.
3877
c3b407f4
AD
38782002-04-07 Akim Demaille <akim@epita.fr>
3879
3880 * src/gram.h, src/gram.c (rules_rhs_length): New.
3881 (ritem_longest_rhs): Use it.
3882 * src/gram.h (rule_t): `number' is a new member.
3883 * src/reader.c (packgram): Set it.
3884 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3885 the end of `rules', and count them out of `nrules'.
3886 (reduce_output, dump_grammar): Adjust.
3887 * src/print.c (print_grammar): It is no longer needed to check for
3888 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3889 * tests/reduce.at (Reduced Automaton): New test.
3890
11652ab3
AD
38912002-04-07 Akim Demaille <akim@epita.fr>
3892
3893 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3894 lacking `+ 1' to nrules, Bison reported as useless a token if it
3895 was used solely to set the precedence of the last rule...
3896
26b23c1a
AD
38972002-04-07 Akim Demaille <akim@epita.fr>
3898
3899 * data/bison.c++, data/bison.simple: Don't output the current file
3900 name in #line, to avoid useless diffs between two identical
3901 outputs under different names.
3902
18bcecb0
AD
39032002-04-07 Akim Demaille <akim@epita.fr>
3904
3905 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3906 Normalize loops to using `< nrules + 1', not `<= nrules'.
3907
fa770c86
AD
39082002-04-07 Akim Demaille <akim@epita.fr>
3909
3910 * TODO: Update.
3911
d9b739c3
AD
39122002-04-07 Akim Demaille <akim@epita.fr>
3913
3914 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3915 bucket.value as bucket.number.
3916
99013900
AD
39172002-04-07 Akim Demaille <akim@epita.fr>
3918
3919 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3920 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3921 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3922 RHS, instead of being an index in RITEMS.
3923
e966383b
PE
39242002-04-04 Paul Eggert <eggert@twinsun.com>
3925
3926 * doc/bison.texinfo: Update copyright date.
3927 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3928 (Symbols): Warn about running Bison in one character set,
3929 but compiling and/or running in an incompatible one.
3930 Warn about character code 256, too.
3931
39322002-04-03 Paul Eggert <eggert@twinsun.com>
3933
3934 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3935 YYERROR_VERBOSE is nonzero, not whether it is defined.
3936
3937 Merge changes from bison-1_29-branch.
c307773e 3938
8d6c48b9
PE
39392002-03-20 Paul Eggert <eggert@twinsun.com>
3940
3941 Merge fixes from Debian bison_1.34-1.diff.
3942
3943 * configure.in (AC_PREREQ): 2.53.
3944
e53c6322
AD
39452002-03-20 Akim Demaille <akim@epita.fr>
3946
3947 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3948
9ffbeca7
PE
39492002-03-19 Paul Eggert <eggert@twinsun.com>
3950
21db0b2a
PE
3951 * src/bison.simple (YYCOPY): New macro.
3952 (YYSTACK_RELOCATE): Use it.
3953 Remove Type arg; no longer needed. All callers changed.
3954 (yymemcpy): Remove; no longer needed.
3955
9ffbeca7
PE
3956 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3957 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3958
642cb8f8
AD
39592002-03-19 Akim Demaille <akim@epita.fr>
3960
3961 Test and fix the #line outputs.
3962
3963 * tests/atlocal.at (GCC): New.
3964 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3965 (Prologue synch line, ,%union synch line, Postprologue synch line)
3966 (Action synch line, Epilogue synch line): New tests.
3967 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3968 * data/bison.simple, data/bison.c++: Use it.
3969
3c31a486
AD
39702002-03-19 Akim Demaille <akim@epita.fr>
3971
3972 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3973 (Solved SR Conflicts, %expect not enough, %expect right)
3974 (%expect too much): Move to...
3975 * tests/conflicts.at: this new file.
3976
0d8bed56
AD
39772002-03-19 Akim Demaille <akim@epita.fr>
3978
3979 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3980 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3981 that we can move to enums for instance.
3982 * src/output.c (token_definitions_output): Output a list of
3983 `token-name, token-number' instead of the #define.
3984 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3985
9208d17f
AD
39862002-03-14 Akim Demaille <akim@epita.fr>
3987
3988 Use Gettext 0.11.1.
3989
af27eacb
RA
39902002-03-09 Robert Anisko <robert@lrde.epita.fr>
3991
3992 * data/bison.c++: Make the user able to add members to the generated
3993 parser by subclassing.
3994
9101a310
RA
39952002-03-05 Robert Anisko <robert@lrde.epita.fr>
3996
3997 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3998 a character.
3999 Reported by Nicolas Tisserand and Nicolas Burrus.
4000
fff9bf0b
RA
40012002-03-04 Robert Anisko <robert@lrde.epita.fr>
4002
4003 * src/reader.c: Warn about lacking semi-colons, do not complain.
4004
64dba31e
RA
40052002-03-04 Robert Anisko <robert@lrde.epita.fr>
4006
4007 * data/bison.c++: Remove a debug line.
4008
374f5a14
RA
40092002-03-04 Robert Anisko <robert@lrde.epita.fr>
4010
4011 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4012 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4013 provide a default implementation.
4014
bfcf1f3a
AD
40152002-03-04 Akim Demaille <akim@epita.fr>
4016
4017 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4018 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4019 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4020 * tests/semantic.at (Parsing Guards): Similarly.
4021 * src/reader.at (readgram): Complain if the last rule is not ended
4022 with a semi-colon.
4023
65ccf9fc
AD
40242002-03-04 Akim Demaille <akim@epita.fr>
4025
4026 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4027 * src/closure.c: here.
4028 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4029 RTC.
4030 * src/warshall.h, src/warshall.c: Remove.
4031 * tests/sets.at (Broken Closure): Adjust.
4032
d0039cbc
AD
40332002-03-04 Akim Demaille <akim@epita.fr>
4034
4035 * src/output.c (output_skeleton): tempdir is const.
4036 bytes_read is unused.
4037
345cea78
AD
40382002-03-04 Akim Demaille <akim@epita.fr>
4039
4040 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4041 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4042 Update.
4043 From Michael Hayes.
4044
564801f7
AD
40452002-03-04 Akim Demaille <akim@epita.fr>
4046
4047 * src/closure.c (closure): `r' is unused.
4048
e5352bc7
AD
40492002-03-04 Akim Demaille <akim@epita.fr>
4050
4051 * tests/sets.at (Broken Closure): Add the ending `;'.
4052 * src/reader.at (readgram): Complain if a rule is not ended with a
4053 semi-colon.
4054
914feea9
AD
40552002-03-04 Akim Demaille <akim@epita.fr>
4056
4057 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4058 (count_sr_conflicts): Use bitset_count.
4059 * src/reduce.c (inaccessable_symbols): Ditto.
4060 (bits_size): Remove.
4061 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4062
f0250de6
AD
40632002-03-04 Akim Demaille <akim@epita.fr>
4064
4065 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4066 * src/reduce.c: Remove the `bitset_zero's following the
4067 `bitset_create's, as now it is performed by the latter.
4068
ef017502
AD
40692002-03-04 Akim Demaille <akim@epita.fr>
4070
4071 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4072 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4073 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4074 latest sources from Michael.
4075
76514394
AD
40762002-03-04 Akim Demaille <akim@epita.fr>
4077
4078 * src/output.c (output): Don't free the grammar.
4079 * src/reader.c (grammar_free): New.
4080 * src/main.c (main): Call it and don't free symtab here.
4081
55024580
AD
40822002-03-04 Akim Demaille <akim@epita.fr>
4083
4084 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4085 before returning.
4086 Reported by Benoit Perrot.
4087
f9abaa2c
AD
40882002-03-04 Akim Demaille <akim@epita.fr>
4089
4090 Use bitset operations when possible, not loops over bits.
4091
4092 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4093 bitset_or.
4094 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4095 * src/reduce.c (useless_nonterminals): Formatting changes.
4096 * src/warshall.c (TC): Use bitset_or.
4097
0e721e75
AD
40982002-03-04 Akim Demaille <akim@epita.fr>
4099
4100 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4101 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4102 Ditto.
4103
0fb1ffb1
AD
41042002-03-04 Akim Demaille <akim@epita.fr>
4105
4106 * src/lalr.c (F): Now a bitset*.
4107 Adjust all dependencies.
4108
b86796bf
AD
41092002-03-04 Akim Demaille <akim@epita.fr>
4110
4111 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4112 Adjust all dependencies.
4113
602bbf31
AD
41142002-03-04 Akim Demaille <akim@epita.fr>
4115
4116 * src/L0.c, src/LR0.h (nstates): Be size_t.
4117 Adjust comparisons (signed vs unsigned).
4118 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4119 bitset*.
4120 Adjust all dependencies.
4121
d8a0245c
AD
41222002-03-04 Akim Demaille <akim@epita.fr>
4123
4124 * src/closure.c (firsts): Now, also a bitset.
4125 Adjust all dependencies.
4126 (varsetsize): Remove, now unused.
4127 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4128
34ba9743
AD
41292002-03-04 Akim Demaille <akim@epita.fr>
4130
4131 * src/print.c: Convert to use bitset.h, not hand coded iterations
4132 over ints.
4133
ed86e78c
AD
41342002-03-04 Akim Demaille <akim@epita.fr>
4135
4136 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4137
dfdb1797
AD
41382002-03-04 Akim Demaille <akim@epita.fr>
4139
4140 * src/closure.c (ruleset): Be a bitset.
4141 (rulesetsize): Remove.
4142
7086e707
AD
41432002-03-04 Akim Demaille <akim@epita.fr>
4144
4145 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4146 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4147 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4148 * src/closure.c (fderives): Be an array of bitsets.
4149
98254360
RA
41502002-02-28 Robert Anisko <robert@lrde.epita.fr>
4151
4152 * data/bison.c++: Merge the two generated headers. Insert a copyright
4153 notice in each output file.
4154
a75c057f
AD
41552002-02-28 Akim Demaille <akim@epita.fr>
4156
4157 * data/bison.c++: Copy the prologue of bison.simple to fetch
4158 useful M4 definitions, such as b4_header_guard.
4159
06b00abc
AD
41602002-02-25 Akim Demaille <akim@epita.fr>
4161
4162 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
4163 translator friendly scheme for the bgr
4164 copyright notice.
06b00abc 4165
70e7d534
AD
41662002-02-25 Akim Demaille <akim@epita.fr>
4167
4168 * src/output.c (header_output): Remove, now handled completely via
4169 M4.
4170
abe017f6
AD
41712002-02-25 Akim Demaille <akim@epita.fr>
4172
4173 * m4/m4.m4: New, from CVS Autoconf.
4174 * configure.in: Invoke it.
4175 * src/output.c (output_skeleton): Use its result instead of the
4176 hard coded name.
4177
381fb12e
AD
41782002-02-25 Akim Demaille <akim@epita.fr>
4179
4180 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4181 Fileutils 4.1.5.
4182 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4183 * src/output.c (output_skeleton): Use mkstemp to create a real
4184 temporary file.
4185 Move the filling of `skeleton' and its muscle to...
4186 (prepare): here.
4187 (output): Move the definition of the prologue muscle to...
4188 (prepare): here.
4189 * src/system.h (DEFAULT_TMPDIR): New.
4190
6f38107f
PE
41912002-02-14 Paul Eggert <eggert@twinsun.com>
4192
4193 Remove the support for C++ namespace cleanliness; it was
4194 causing more problems than it was curing, since it didn't work
4195 properly on some nonstandard C++ compilers. This can wait
4196 for a proper C++ parser.
4197
4198 * NEWS: Document this.
4199 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4200 of C++, as it's treated like C now.
4201 * src/bison.simple (YYSTD): Remove.
4202 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4203 Treat C++ just like Standard C instead of trying to support
4204 namespace cleanliness.
4205
80cce3da
AD
42062002-02-14 Akim Demaille <akim@epita.fr>
4207
4208 * tests/regression.at (else): Adjust to Andreas' change.
4209
842e8679
AD
42102002-02-14 Akim Demaille <akim@epita.fr>
4211
4212 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4213
4bda3f10
AD
42142002-02-13 Andreas Schwab <schwab@suse.de>
4215
4216 * src/output.c (output_rule_data): Don't output NULL, it might
4217 not be defined yet.
4218
4162fa07 42192002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 4220
4162fa07
RA
4221 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4222 (Copyright notice): Update.
b418ecd8 4223
bd16a5dc
AD
42242002-02-11 Akim Demaille <akim@epita.fr>
4225
4226 * tests/regression.at (%nonassoc and eof): Don't include
4227 nonportable headers.
4228
8d69a1a3
RA
42292002-02-08 Robert Anisko <robert@lrde.epita.fr>
4230
4231 * data/bison.c++: Correct error recovery. Make the user able to
4232 initialize the starting location.
4233
9b2d0677
AD
42342002-02-07 Akim Demaille <akim@epita.fr>
4235
4236 * tests/input.at: New.
4237
69e2658b
RA
42382002-02-07 Robert Anisko <robert@lrde.epita.fr>
4239
4240 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 4241 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
4242 directives around tables only needed for debugging.
4243
4aacc3a7
RA
42442002-02-07 Robert Anisko <robert@lrde.epita.fr>
4245
4246 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4247 C++ parsers.
4248 (yy::b4_name::parse): Use print_.
4249
762a801e
RA
42502002-02-07 Robert Anisko <robert@lrde.epita.fr>
4251
4252 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4253
4bb2bc3f
RA
42542002-02-07 Robert Anisko <robert@lrde.epita.fr>
4255
4256 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4257 C++ parsers.
4258 (yy::b4_name::parse): Build verbose error messages, and use error_.
4259
6b45a3ca
RA
42602002-02-06 Robert Anisko <robert@lrde.epita.fr>
4261
4262 * data/bison.c++: Fix m4 quoting in comments.
4263
50997c6e
RA
42642002-02-06 Robert Anisko <robert@lrde.epita.fr>
4265
4266 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4267 not expanded by m4.
4268
3f3eed27
AD
42692002-02-05 Akim Demaille <akim@epita.fr>
4270
4271 * data/bison.c++: Adjust to the M4 back end.
4272 More is certainly needed.
4273
be2a1a68
AD
42742002-02-05 Akim Demaille <akim@epita.fr>
4275
4276 Give a try to M4 as a back end.
4277
4278 * lib/readpipe.c: New, from wdiff.
4279 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4280 BISON_HAIRY.
4281 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4282 specific values. Now it is m4 that performs the lookup.
4283 * src/parse-skel.y: Remove.
4284 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4285 * src/output.c (actions_output, guards_output)
4286 (token_definitions_output): No longer keeps track of the output
4287 line number, hence remove the second argument.
4288 (guards_output): Check against the guard member of a rule, not the
4289 action member.
4290 Adjust callers.
4291 (output_skeleton): Don't look for the skeleton location, let m4 do
4292 that.
4293 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
4294 file will be used.
4295 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
4296 (prepare): Given that for the time being changesyntax is not
4297 usable in M4, rename the muscles using `-' to `_'.
4298 Define `defines_flag', `output_parser_name' and `output_header_name'.
4299 * src/output.h (actions_output, guards_output)
4300 (token_definitions_output): Adjust prototypes.
4301 * src/scan-skel.l: Instead of scanning the skeletons, it now
4302 processes the output of m4: `__oline__' and `#output'.
4303 * data/bison.simple: Adjust to be used by M4(sugar).
4304 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
4305 to date.
4306 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
4307 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
4308 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
4309 shamelessly stolen from CVS Autoconf.
4310
beda758b
AD
43112002-02-05 Akim Demaille <akim@epita.fr>
4312
4313 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
4314 * configure.in: Check for the declarations of free and malloc.
4315 * src/muscle_tab.c: Adjust.
4316
5ece6d43
AD
43172002-02-05 Akim Demaille <akim@epita.fr>
4318
4319 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
4320 which have no values.
4321
5bb18f9a
AD
43222002-02-05 Akim Demaille <akim@epita.fr>
4323
4324 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
4325 * data/: here.
4326
894dd62e
PE
43272002-01-29 Paul Eggert <eggert@twinsun.com>
4328
4329 * src/bison.simple (YYSIZE_T): Do not define merely because
4330 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
4331 On some platforms, <alloca.h> does not declare YYSTD (size_t).
4332
82841af7
AD
43332002-01-27 Akim Demaille <akim@epita.fr>
4334
4335 Fix `%nonassoc and eof'.
4336
4337 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
4338 which were not properly copied! Replace
4339 memcpy (res->errs, src->errs, src->nerrs);
4340 with
4341 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
4342 !!!
4343 * tests/regression.at (%nonassoc and eof): Adjust to newest
4344 Autotest: `.' is not in the PATH.
4345
318b76e9
AD
43462002-01-27 Akim Demaille <akim@epita.fr>
4347
4348 * tests/sets.at (AT_EXTRACT_SETS): New.
4349 (Nullable): Use it.
4350 (Firsts): New.
4351
30d2f3d5
AD
43522002-01-26 Akim Demaille <akim@epita.fr>
4353
4354 * tests/actions.at, tests/calc.at, tests/headers.at,
4355 * tests/torture.at: Adjust to the newest Autotest which no longer
4356 forces `.' in the PATH.
4357
30f8c395
AD
43582002-01-25 Akim Demaille <akim@epita.fr>
4359
4360 * tests/regression.at (%nonassoc and eof): New.
4361 Suggested by Robert Anisko.
4362
29ae55f1
AD
43632002-01-24 Akim Demaille <akim@epita.fr>
4364
4365 Bison dumps core when trying to complain about broken input files.
4366 Reported by Cris van Pelt.
4367
4368 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
4369 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
4370 into...
4371 (Invalid inputs): Strengthen: exercise parse_percent_token.
4372
2b548aa6
RA
43732002-01-24 Robert Anisko <robert.anisko@epita.fr>
4374
4375 * src/Makefile.am: Add bison.c++.
4376 * src/bison.c++: New skeleton.
4377
bb0146c2
AD
43782002-01-21 Paolo Bonzini <bonzini@gnu.org>
4379
4380 * po/it.po: New.
4381
bec30531
AD
43822002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
4383
4384 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
4385
fc6edc45
MA
43862002-01-20 Marc Autret <marc@gnu.org>
4387
4388 * src/files.c (compute_output_file_names): Fix
4389
5e5d5415
MA
43902002-01-20 Marc Autret <marc@gnu.org>
4391
4392 * tests/output.at: New test.
4393 * src/files.c (compute_base_names): Don't map extensions when
4394 the YACC flag is set, use defaults.
4395 Reported by Evgeny Stambulchik.
4396
44ea3fbd
MA
43972002-01-20 Marc Autret <marc@gnu.org>
4398
bb0146c2 4399 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
4400 compilers as well (i.e. the vendor C compiler).
4401 Suggested by Albert Chin-A-Young.
4402
338963d1
TVH
44032002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
4404
4405 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
4406 canonical definition.
4407 * src/system.h: Use the canonical definition for PARAMS (avoids
4408 a conflict with the macro from lib/hash.h).
4409
c57b2479
AD
44102002-01-11 Akim Demaille <akim@epita.fr>
4411
4412 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 4413 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 4414
b85810ae
AD
44152002-01-09 Akim Demaille <akim@epita.fr>
4416
4417 * src/files.c, src/files.h (output_infix): New.
4418 (tab_extension): Remove.
4419 (compute_base_names): Compute the former, drop the latter.
4420 * src/output.c (prepare): Insert the muscles `output-infix', and
4421 `output-suffix'.
4422 * src/parse-skel.y (string, string.1): New.
4423 (section.header): Use it.
4424 (section.yacc): Remove.
4425 (prefix): Remove too.
4426 * src/scan-skel.l: Adjust.
4427 * src/bison.simple, src/bison.hairy: Adjust.
4428
cae60122
AD
44292002-01-09 Akim Demaille <akim@epita.fr>
4430
4431 * configure.in (WERROR_CFLAGS): Compute it.
4432 * src/Makefile.am (CFLAGS): Pass it.
4433 * tests/atlocal.in (CFLAGS): Idem.
4434 * src/files.c: Fix a few warnings.
4435 (get_extension_index): Remove, unused.
4436
ae404801
AD
44372002-01-08 Akim Demaille <akim@epita.fr>
4438
4439 * src/getargs.c (AS_FILE_NAME): New.
4440 (getargs): Use it to convert DOSish file names.
4441 * src/files.c (base_name): Rename as full_base_name to avoid
4442 clashes with `base_name ()'.
4443 (filename_split): New.
4444 (compute_base_names): N-th rewrite, using filename_split.
4445
22312b71
AD
44462002-01-08 Akim Demaille <akim@epita.fr>
4447
4448 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
4449 New, stolen from the Fileutils 4.1.
4450 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
4451 * configure.in: Check for the presence of memrchr, and of its
4452 prototype.
4453
a67cef01
TVH
44542002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
4455
4456 * lib/hash.h (__P): Added definition for this macro.
4457 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
4458 BUILT_SOURCES, to ensure they are generated first.
4459 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
4460 %error-verbose to allow bootstrapping with bison 1.30x.
4461
2b25d624
AD
44622002-01-06 Akim Demaille <akim@epita.fr>
4463
4464 * src/reader.c (parse_braces): Don't fetch the next char, the
4465 convention is to fetch on entry.
4466 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
4467 'switch' without a following semicolon.
4468 * tests/regression.at (braces parsing): New.
4469
3460813b
AD
44702002-01-06 Akim Demaille <akim@epita.fr>
4471
4472 Bison is dead wrong in its RR conflict reports.
4473
4474 * tests/torture.at (GNU Cim Grammar): New.
4475 * src/conflicts.c (count_rr_conflicts): Fix.
4476
73784c64
AD
44772002-01-06 Akim Demaille <akim@epita.fr>
4478
4479 Creating package.m4 from configure.ac causes too many problems.
4480
4481 * tests/Makefile.am (package.m4): Create it by hand,
4482 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
4483
25d81090
AD
44842002-01-06 Akim Demaille <akim@epita.fr>
4485
4486 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
4487 skeleton.h.
4488
a9b8959e
PE
44892002-01-04 Paul Eggert <eggert@twinsun.com>
4490
4491 * doc/bison.texinfo (Debugging):
4492 Remove YYSTDERR; it's no longer defined or used.
4493 Also, s/cstdio.h/cstdio/.
4494
25d81090
AD
44952002-01-03 Akim Demaille <akim@epita.fr>
4496
4497 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
4498
1109455c
AD
44992002-01-03 Akim Demaille <akim@epita.fr>
4500
4501 * src/parse-skel.y (process_skeleton): Don't bind the parser's
4502 tracing code to --trace, wait for a better --trace option, with
4503 args.
4504
7ea5e977
AD
45052002-01-03 Akim Demaille <akim@epita.fr>
4506
4507 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
4508 The ISO C++ standard is extremely clear about it: stderr is
4509 considered a macro, not a regular symbol (see table 94 `Header
4510 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
4511 Therefore std:: does not apply to it. It still does with fprintf.
4512 Also, s/cstdio.h/cstdio/.
4513
fab5b110
AD
45142002-01-03 Akim Demaille <akim@epita.fr>
4515
4516 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
4517 for non system headers.
4518
aed7fd9b
AD
45192002-01-02 Akim Demaille <akim@epita.fr>
4520
4521 Equip the skeleton chain with location tracking, runtime trace,
4522 pure parser and scanner.
4523
4524 * src/parse-skel.y: Request a pure parser, locations, and prefix
4525 renaming.
4526 (%union): Having several members with the same type does not help
4527 type mismatches, simplify.
4528 (YYPRINT, yyprint): New.
4529 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
4530 (skel_error): this.
4531 Handle locations.
4532 * src/scan-skel.l: Adjust to these changes.
4533 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
4534 (LOCATION_PRINT, skel_control_t): New.
4535
24fad99e
AD
45362001-12-30 Akim Demaille <akim@epita.fr>
4537
4538 * src/parse-skel.y: Get rid of the shift/reduce conflict:
4539 replace `gb' with BLANKS.
4540 * src/scan-skel.l: Adjust.
4541
a4b36db4
AD
45422001-12-30 Akim Demaille <akim@epita.fr>
4543
4544 * src/system.h: We don't need nor want bcopy.
4545 Throw away MS-DOS crap: we don't need getpid.
4546 * configure.in: We don't need strndup. It was even causing
4547 problems: because Flex includes the headers *before* us,
4548 _GNU_SOURCE is not defined by config.h, and therefore strndup was
4549 not visible.
4550 * lib/xstrndup.c: New.
4551 * src/scan-skel.l: Use it.
4552 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
4553 * src/parse-skel.y: Use %directives instead of #defines.
4554
1239777d
AD
45552001-12-30 Akim Demaille <akim@epita.fr>
4556
4557 * src/skeleton.h: New.
4558 * src/output.c (output_parser, output_master_parser): Remove, dead
4559 code.
4560 * src/output.h (get_lines_number, actions_output, guards_output)
4561 (token_definitions_output): Prototype them.
4562 * src/parse-skel.y: Add the license notice.
4563 Include output.h and skeleton.h.
4564 (process_skeleton): Returns void, and takes a single parameter.
4565 * src/scan-skel.l: Add the license notice.
4566 Include skeleton.h.
4567 Don't use %option yylineno: it seems that then Flex imagines
4568 REJECT has been used, and therefore it won't reallocate its
4569 buffers (which makes no other sense to me than a bug). It results
4570 in warnings for `unused: yy_flex_realloc'.
4571
9b3add5b
RA
45722001-12-30 Robert Anisko <robert.anisko@epita.fr>
4573
4574 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4575 (MUSCLE_INSERT_PREFIX): ...to there.
4576 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4577 (MUSCLE_INSERT_PREFIX): Move from here...
4578
4579 * src/bison.hairy: Add a section directive. Put braces around muscle
4580 names. This parser skeleton is still broken, but Bison should not
4581 choke on a bad muscle 'syntax'.
4582 * src/bison.simple: Add a section directive. Put braces around muscle
4583 names.
4584
4585 * src/files.h (strsuffix, stringappend): Add declarations.
4586 (tab_extension): Add declaration.
4587 (short_base_name): Add declaration.
4588
4589 * src/files.c (strsuffix, stringappend): No longer static. These
4590 functions are used in the skeleton parser.
4591 (tab_extension): New.
4592 (compute_base_names): Use the computations done in this function
fab5b110 4593 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
4594 names.
4595 (short_base_name): No longer static.
4596
4597 * src/output.c (output_skeleton): New.
4598 (output): Disable call to output_master_parser, and give a try to
4599 a new skeleton handling system.
4600 (guards_output, actions_output): No longer static.
4601 (token_definitions_output, get_lines_number): No longer static.
4602
4603 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
4604
fab5b110 4605 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
4606 parse-skel.y.
4607
4608 * src/parse-skel.y: New file.
4609 * src/scan-skel.l: New file.
4610
b5b61c61
AD
46112001-12-29 Akim Demaille <akim@epita.fr>
4612
4613 %name-prefix is broken.
4614
4615 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
4616 Adjust all dependencies.
4617 * tests/headers.at (export YYLTYPE): Strengthen this test: use
4618 %name-prefix.
4619
4620 Renaming yylval but not yylloc is not consistent. Now we do.
4621
4622 * src/bison.simple: Prefix yylloc if used.
4623 * doc/bison.texinfo (Decl Summary): Document that.
4624
8c9a50be
AD
46252001-12-29 Akim Demaille <akim@epita.fr>
4626
4627 * doc/bison.texinfo: Promote `%long-directive' over
4628 `%long_directive'.
4629 Remove all references to fixed-output-files, yacc is enough.
4630
d99361e6
AD
46312001-12-29 Akim Demaille <akim@epita.fr>
4632
4633 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
4634 user prologue. These are defaults.
4635 * tests/actions.at (Mid-rule actions): Make sure the user can
4636 define YYDEBUG and YYERROR_VERBOSE.
4637
b9cecb91
AD
46382001-12-29 Akim Demaille <akim@epita.fr>
4639
4640 * src/output.c (header_output): Don't forget to export YYLTYPE and
4641 yylloc.
4642 * tests/headers.at (export YYLTYPE): New, make sure it does.
4643 * tests/regression.at (%union and --defines, Invalid CPP headers):
4644 Move to...
4645 * tests/headers.at: here.
4646
aea13e97
AD
46472001-12-29 Akim Demaille <akim@epita.fr>
4648
4649 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
4650
931394cb
AD
46512001-12-29 Akim Demaille <akim@epita.fr>
4652
4653 * tests/actions.at (Mid-rule actions): Output on a single line
4654 instead of several.
4655
704a47c4
AD
46562001-12-29 Akim Demaille <akim@epita.fr>
4657
4658 * doc/bison.texinfo: Formatting changes.
4659
091e20bb
AD
46602001-12-29 Akim Demaille <akim@epita.fr>
4661
4662 Don't store the token defs in a muscle, just be ready to output it
4663 on command. Now possible via `symbols'. Fixes a memory leak.
4664
4665 * src/output.c (token_definitions_output): New.
4666 (output_parser, header_output): Use it.
4667 * src/reader.c (symbols_save): Remove.
4668
cce71710
AD
46692001-12-29 Akim Demaille <akim@epita.fr>
4670
4671 * src/bison.simple: Do not provide a default for YYSTYPE and
4672 YYLTYPE before the user's prologue. Otherwise it's hardly... a
4673 default.
4674
82c035a8
AD
46752001-12-29 Akim Demaille <akim@epita.fr>
4676
4677 Mid-rule actions are simply... ignored!
4678
4679 * src/reader.c (readgram): Be sure to attach mid-rule actions to
4680 the empty-rule associated to the dummy symbol, not to the host
4681 rule.
4682 * tests/actions.at (Mid-rule actions): New.
4683
8419d367
AD
46842001-12-29 Akim Demaille <akim@epita.fr>
4685
4686 Memory leak.
4687
4688 * src/reader.c (reader): Free grammar.
4689
375d5806
AD
46902001-12-29 Akim Demaille <akim@epita.fr>
4691
4692 Memory leak.
4693
4694 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4695 since it allocates it for each state, although only one is needed.
4696 (allocate_storage): Do it here.
4697
f51cb8ff
AD
46982001-12-29 Akim Demaille <akim@epita.fr>
4699
4700 * src/options.h, src/options.c (create_long_option_table): Rename
4701 as...
4702 (long_option_table_new): this, with a clearer prototype.
4703 (percent_table): Remove, unused,
4704 * src/getargs.c (getargs): Adjust.
4705
29e88316
AD
47062001-12-29 Akim Demaille <akim@epita.fr>
4707
4708 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4709 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4710 as states.
4711
b9f71f19
AD
47122001-12-29 Akim Demaille <akim@epita.fr>
4713
4714 * src/lalr.c (build_relations): Rename `states' as `states1'.
4715 Sorry, I don't understand exactly what it is, no better name...
4716
1a2b5d37
AD
47172001-12-29 Akim Demaille <akim@epita.fr>
4718
4719 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4720 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4721 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4722 as rules.
4723
1cca533e
AD
47242001-12-29 Akim Demaille <akim@epita.fr>
4725
4726 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4727 ago.
4728
c03ae966
AD
47292001-12-29 Akim Demaille <akim@epita.fr>
4730
4731 * src/reader.c, src/reader.h (user_toknums): Remove.
4732 Adjust all users to use symbols[i]->user_token_number.
4733
5a670b1e
AD
47342001-12-29 Akim Demaille <akim@epita.fr>
4735
4736 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4737 Adjust all users to use symbols[i]->prec or ->assoc.
4738
ad949da9
AD
47392001-12-29 Akim Demaille <akim@epita.fr>
4740
4741 * src/reader.c, src/reader.h (tags): Remove.
4742 Adjust all users to use symbols[i]->tag.
4743
0e78e603
AD
47442001-12-29 Akim Demaille <akim@epita.fr>
4745
4746 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4747 and rule_table.
4748 * src/reader.c (packsymbols): Fill this table.
4749 Drop sprec.
4750 * src/conflicts.c (resolve_sr_conflict): Adjust.
4751 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4752 single table.
4753 Use symbols[i]->tag instead of tags[i].
4754
213e640e
AD
47552001-12-29 Akim Demaille <akim@epita.fr>
4756
4757 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4758 In addition, put a comment in there, to replace...
4759 * tests/regression.at (%union and C comments): Remove.
4760
e7b8bef1
AD
47612001-12-29 Akim Demaille <akim@epita.fr>
4762
4763 * tests/regression.at (Web2c Actions): Blindly move the actual
4764 output as expected output. The contents *seem* right to me, but I
4765 can't pretend reading perfectly parser tables... Nonetheless, all
4766 the other tests pass correctly, the table look OK, even though the
4767 presence of `$axiom' is to be noted: AFAICS it is useless (but
4768 harmless).
4769
b68e7744
AD
47702001-12-29 Akim Demaille <akim@epita.fr>
4771
4772 * src/reader.c (readgram): Don't add the rule 0 if there were no
4773 rules read. In other words, add it _after_ having performed
4774 grammar sanity checks.
4775 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4776
78d5bae9
AD
47772001-12-29 Akim Demaille <akim@epita.fr>
4778
4779 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4780 visible, and some states have now a different number.
4781
ff442794
AD
47822001-12-29 Akim Demaille <akim@epita.fr>
4783
4784 * src/reader.c (readgram): Bind the initial rule's lineno to that
4785 of the first rule.
4786 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4787 (Solved SR Conflicts): Adjust rule 0's line number.
4788
610ab194
AD
47892001-12-29 Akim Demaille <akim@epita.fr>
4790
4791 Fix the `GAWK Grammar' failure.
4792
4793 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4794 the reductions of the first state which was mistakenly confused
4795 with the final state because precisely final_state was initialized
4796 to 0.
4797 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4798 now noticed by Bison.
4799 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4800 have a reduction on $default.
4801
29d29c8f
AD
48022001-12-29 Akim Demaille <akim@epita.fr>
4803
4804 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4805 rule line numbers.
4806 * src/closure.c (print_closure): Likewise.
4807 * src/derives.c (print_derives): Likewise.
4808 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4809 now.
4810
7c6b64d0
AD
48112001-12-29 Akim Demaille <akim@epita.fr>
4812
4813 * src/lalr.c (lookaheads_print): New.
4814 (lalr): Call it when --trace-flag.
4815 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4816 are dumped.
4817
3d4daee3
AD
48182001-12-29 Akim Demaille <akim@epita.fr>
4819
4820 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4821 when walking through ritem, even via rule->rhs.
4822 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4823 (useful_production, useless_nonterminals): Likewise.
4824 (reduce_grammar_tables): Likewise, plus update nritems.
4825 * src/nullable.c (set_nullable): Likewise.
4826 * src/lalr.c (build_relations): Likewise.
4827 * tests/sets.at (Nullable): Adjust.
4828 Fortunately, now, the $axiom is no longer nullable.
4829
9e7f6bbd
AD
48302001-12-29 Akim Demaille <akim@epita.fr>
4831
4832 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4833 the 0-sentinel.
4834 * src/gram.c (ritem_longest_rhs): Likewise.
4835 * src/reduce.c (nonterminals_reduce): Likewise.
4836 * src/print_graph.c (print_graph): Likewise.
4837 * src/output.c (output_rule_data): Likewise.
4838 * src/nullable.c (set_nullable): Likewise.
4839
255ef638
AD
48402001-12-29 Akim Demaille <akim@epita.fr>
4841
4842 * src/output.c: Comment changes.
4843
0d8a7363
AD
48442001-12-27 Paul Eggert <eggert@twinsun.com>
4845
4846 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4847 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4848 Sparc, as they were causing more porting problems than the
4849 (minor) performance improvement was worth.
4850
4851 Also, catch up with 1.31's YYSTD.
4852
3db472b9
AD
48532001-12-27 Akim Demaille <akim@epita.fr>
4854
4855 * src/output.c (output_gram): Rely on nritems, not the
4856 0-sentinel. See below.
4857 Use -1 as separator, not 0.
4858 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4859 Rely on -1 as separator in yyrhs, instead of 0.
4860 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4861 twice `Now at end of input', therefore there are two lines less to
4862 expect.
4863
b365aa05
AD
48642001-12-27 Akim Demaille <akim@epita.fr>
4865
4866 * tests/regression.at (Unresolved SR Conflicts):
4867 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4868 below.
4869
30171f79
AD
48702001-12-27 Akim Demaille <akim@epita.fr>
4871
4872 * src/LR0.c (new_state): Recognize the final state by the fact it
4873 is reached by eoftoken.
4874 (insert_start_shifting_state, insert_eof_shifting_state)
4875 (insert_accepting_state, augment_automaton): Remove, since now
4876 these states are automatically computed from the initial state.
4877 (generate_states): Adjust.
4878 * src/print.c: When reporting a rule number to the user, substract
4879 1, so that the axiom rule is rule 0, and the first user rule is 1.
4880 * src/reduce.c: Likewise.
4881 * src/print_graph.c (print_core): For the time being, just as for
4882 the report, depend upon --trace-flags to dump the full set of
4883 items.
4884 * src/reader.c (readgram): Once the grammar read, insert the rule
4885 0: `$axiom: START-SYMBOL $'.
4886 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4887 number of the states has changed (the final state is no longer
4888 necessarily the last), catch up.
4889
75142d45
AD
48902001-12-27 Akim Demaille <akim@epita.fr>
4891
4892 Try to make the use of the eoftoken valid. Given that its value
4893 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4894 is used instead of > 0 where appropriate, (ii), depend upon nritems
4895 instead of the 0-sentinel.
4896
4897 * src/gram.h, src/gram.c (nritems): New.
4898 Expected to be duplication of nitems, but for the time being...
4899 * src/reader.c (packgram): Assert nritems and nitems are equal.
4900 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4901 * src/closure.c (print_closure, print_fderives): Likewise.
4902 * src/gram.c (ritem_print): Likewise.
4903 * src/print.c (print_core, print_grammar): Likewise.
4904 * src/print_graph.c: Likewise.
4905
b7c49edf
AD
49062001-12-27 Akim Demaille <akim@epita.fr>
4907
4908 * src/main.c (main): If there are complains after grammar
4909 reductions, then output the report anyway if requested, then die.
4910 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4911 * src/reader.c (eoftoken): New.
4912 (parse_token_decl): If the token being defined has value `0', it
4913 is the eoftoken.
4914 (packsymbols): No longer hack `tags' to insert `$' by hand.
4915 Be sure to preserve the value of the eoftoken.
4916 (reader): Make sure eoftoken is defined.
4917 Initialize nsyms to 0: now eoftoken is created just like the others.
4918 * src/print.c (print_grammar): Don't special case the eof token.
4919 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4920 lie anyway, albeit pleasant.
4921 * tests/calc.at: Exercise error messages with eoftoken.
4922 Change the grammar so that empty input is invalid.
4923 Adjust expectations.
4924 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4925
ec2da99f
AD
49262001-12-27 Akim Demaille <akim@epita.fr>
4927
4928 * configure.in: Check the protos of strchr ans strspn.
4929 Replace strchr if needed.
4930 * src/system.h: Provide the protos of strchr, strspn and memchr if
4931 missing.
4932 * lib/strchr.c: New.
4933 * src/reader.c (symbols_save): Use strchr.
4934
8adfa272
AD
49352001-12-27 Akim Demaille <akim@epita.fr>
4936
4937 * src/print.c, src/print_graph.c (escape): New.
4938 Use it to quote the TAGS outputs.
4939 * src/print_graph.c (print_state): Now errors are in red, and
4940 reductions in green.
4941 Prefer high to wide: output the state number on a line of its own.
4942
80dac38c
AD
49432001-12-27 Akim Demaille <akim@epita.fr>
4944
4945 * src/state.h, src/state.c (reductions_new): New.
4946 * src/LR0.c (set_state_table): Let all the states have a
4947 `reductions', even if reduced to 0.
4948 (save_reductions): Adjust.
4949 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4950 * src/print.c (print_reductions, print_actions): Adjust.
4951 * src/output.c (action_row): Adjust.
4952
2cec70b9
AD
49532001-12-27 Akim Demaille <akim@epita.fr>
4954
4955 * src/state.h, src/state.c (errs_new, errs_dup): New.
4956 * src/LR0.c (set_state_table): Let all the states have an errs,
4957 even if reduced to 0.
4958 * src/print.c (print_errs, print_reductions): Adjust.
4959 * src/output.c (output_actions, action_row): Adjust.
4960 * src/conflicts.c (resolve_sr_conflict): Adjust.
4961
13ca549a
AD
49622001-12-27 Akim Demaille <akim@epita.fr>
4963
4964 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4965
5092aba5
AD
49662001-12-27 Akim Demaille <akim@epita.fr>
4967
4968 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4969 * src/print.c: here.
4970 (lookaheadset, shiftset): New, used as additional storage by
4971 print_reductions.
4972 (print_results): Adjust.
4973 (print_shifts, print_gotos, print_errs): New, extracted from...
4974 (print_actions): here.
4975 * src/print_graph.c (print_actions): Remove dead code.
4976
11e2beca
AD
49772001-12-27 Akim Demaille <akim@epita.fr>
4978
4979 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4980 `$n' and `@n'.
4981
dac3c910
AD
49822001-12-27 Akim Demaille <akim@epita.fr>
4983
4984 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4985 (build_relations): Adjust.
4986
d0b0fefa
AD
49872001-12-27 Akim Demaille <akim@epita.fr>
4988
4989 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4990 duplication.
4991
adc8c848
AD
49922001-12-27 Akim Demaille <akim@epita.fr>
4993
4994 * src/reader.c (packgram): Catch nitems overflows.
4995
14d293ac
AD
49962001-12-27 Akim Demaille <akim@epita.fr>
4997
4998 * src/files.c, src/files.h (guard_obstack): Remove.
4999 * src/output.c (output): Adjust.
5000 * src/reader.c (parse_braces): New, factoring...
5001 (copy_action, copy_guard): these two which are renamed as...
5002 (parse_action, parse_guard): these.
5003 As a voluntary consequence, using braces around guards is now
5004 mandatory.
5005
f499b062
AD
50062001-12-27 Akim Demaille <akim@epita.fr>
5007
5008 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5009 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5010 members.
5011 (symbol_list_new): Adjust.
5012 (copy_action): action_line is the first line, not the last.
5013 (copy_guard): Just as for actions, store the `action' only, not
5014 the switch/case/break flesh.
5015 Don't parse the user action that might follow the guard, let...
5016 (readgram): do it, i.e., now, there can be an action after a
5017 guard.
5018 In other words the guard is just explicitly optional.
5019 (packgram): Adjust.
5020 * src/output.c (guards_output): New.
5021 (output_parser): Call it when needed.
5022 (output): Also free the guard and attrs obstacks.
5023 * src/files.c, src/files.h (obstack_save): Remove.
5024 (output_files): Remove.
5025 As a result, if one needs the former `.act' file, using an
5026 appropriate skeleton which requires actions and guards is now
5027 required.
5028 * src/main.c (main): Adjust.
5029 * tests/semantic.at: New.
5030 * tests/regression.at: Use `input.y' as input file name.
5031 Avoid 8+3 problems by requiring input.c when the test needs the
5032 parser.
5033
d945f5cd
AD
50342001-12-27 Akim Demaille <akim@epita.fr>
5035
5036 * src/reader.c (symbol_list_new): Be sure to initialize all the
5037 fields.
5038
d200e455
AD
50392001-12-27 Akim Demaille <akim@epita.fr>
5040
5041 All the hacks using a final pseudo state are now useless.
5042
5043 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5044 * src/lalr.c (nLA): New.
5045 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5046 instead of lookaheadsp from the pseudo state (nstate + 1).
5047
f9507c28
AD
50482001-12-27 Akim Demaille <akim@epita.fr>
5049
5050 * src/output.c (action_row, token_actions): Use a state_t instead
5051 of a integer, and nlookaheads instead of the following state's
5052 lookaheadsp.
5053
065fbd27
AD
50542001-12-27 Akim Demaille <akim@epita.fr>
5055
5056 * src/conflicts.c (log_resolution, flush_shift)
5057 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5058 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5059 (conflicts_print, print_reductions): Use a state_t instead of an
5060 integer when referring to a state.
5061 As much as possible, depend upon nlookaheads, instead of the
5062 `lookaheadsp' member of the following state (since lookaheads of
5063 successive states are successive, the difference between state n + 1
5064 and n served as the number of lookaheads for state n).
5065 * src/lalr.c (add_lookback_edge): Likewise.
5066 * src/print.c (print_core, print_actions, print_state)
5067 (print_results): Likewise.
5068 * src/print_graph.c (print_core, print_actions, print_state)
5069 (print_graph): Likewise.
5070 * src/conflicts.h: Adjust.
5071
1b177bd7
AD
50722001-12-27 Akim Demaille <akim@epita.fr>
5073
5074 * src/bison.hairy: Formatting/comment changes.
5075 ANSIfy.
5076 Remove `register' indications.
5077 Add plenty of `static'.
5078
7742ddeb
AD
50792001-12-27 Akim Demaille <akim@epita.fr>
5080
5081 * src/output.c (prepare): Drop the muscle `ntbase' which
5082 duplicates ntokens.
5083 * src/bison.simple: Formatting/comment changes.
5084 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5085 is an undocumented synonym.
5086
1fa14068
AD
50872001-12-22 Akim Demaille <akim@epita.fr>
5088
5089 * src/output.c (output_table_data): Change the prototype to use
5090 `int' for array ranges: some invocations do pass an int, not a
5091 short.
5092 Reported by Wayne Green.
5093
b9752825
AD
50942001-12-22 Akim Demaille <akim@epita.fr>
5095
5096 Some actions of web2c.y are improperly triggered.
5097 Reported by Mike Castle.
5098
5099 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5100 * tests/regression.at (Web2c): Rename as...
5101 (Web2c Report): this.
5102 (Web2c Actions): New.
5103
776209d6
AD
51042001-12-22 Akim Demaille <akim@epita.fr>
5105
5106 Reductions in web2c.y are improperly reported.
5107 Reported by Mike Castle.
5108
5109 * src/conflicts.c (print_reductions): Fix.
5110 * tests/regression.at (Web2c): New.
5111
275fc3ad
AD
51122001-12-18 Akim Demaille <akim@epita.fr>
5113
5114 Some host fail on `assert (!"foo")', which expands to
5115 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5116 Reported by Nelson Beebee.
5117
5118 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5119 `#define it_succeeded 0' and `assert (it_succeeded)'.
5120
897668ee
MA
51212001-12-17 Marc Autret <autret_m@epita.fr>
5122
5123 * src/bison.simple: Don't hard code the skeleton line and filename.
5124 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5125 New line counter 'skeleton_line' (skeleton-line muscle).
5126
ab3399e0
PE
51272001-12-17 Paul Eggert <eggert@twinsun.com>
5128
5129 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5130 YYDEBUG must be defined to a nonzero value.
5131
5132 * src/bison.simple (yytname): Do not assume that the user defines
5133 YYDEBUG to a properly parenthesized expression.
5134
3877f72b
AD
51352001-12-17 Akim Demaille <akim@epita.fr>
5136
5137 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5138 nlookaheads is a new member.
5139 Adjust all users.
5140 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5141 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5142 state.
776209d6 5143
331dbc1b
AD
51442001-12-17 Akim Demaille <akim@epita.fr>
5145
5146 * src/files.h, src/files.c (open_files, close_files): Remove.
5147 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5148 let...
5149 * src/reader.c (reader): Do it.
776209d6 5150
be750e4c
AD
51512001-12-17 Akim Demaille <akim@epita.fr>
5152
5153 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 5154
709ae8c6
AD
51552001-12-17 Akim Demaille <akim@epita.fr>
5156
5157 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5158 (flush_reduce): New.
5159 (resolve_sr_conflict): Adjust.
776209d6 5160
f87685c3
AD
51612001-12-17 Akim Demaille <akim@epita.fr>
5162
5163 * src/output.c (output_obstack): Be static and rename as...
5164 (format_obstack): this, to avoid any confusion with files.c's
5165 output_obstack.
5166 * src/reader.h (muscle_obstack): Move to...
5167 * src/output.h: here, since it's defined in output.c.
5168
837491d8
AD
51692001-12-17 Akim Demaille <akim@epita.fr>
5170
5171 * src/output.c (action_row, save_column, default_goto)
5172 (sort_actions, matching_state, pack_vector): Better variable
5173 locality.
5174
796d61fb
AD
51752001-12-17 Akim Demaille <akim@epita.fr>
5176
5177 * src/output.c: Various formatting changes.
776209d6 5178
64d15509
AD
51792001-12-17 Akim Demaille <akim@epita.fr>
5180
5181 * src/files.c (output_files): Free the output_obstack.
5182 * src/main.c (main): Call print and print_graph conditionally.
5183 * src/print.c (print): Work unconditionally.
5184 * src/print_graph.c (print_graph): Work unconditionally.
5185 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5186
fbc8ecb7
MA
51872001-12-16 Marc Autret <autret_m@epita.fr>
5188
5189 * src/output.c (actions_output): Fix. When we use %no-lines,
5190 there is one less line per action.
5191
f0440388
MA
51922001-12-16 Marc Autret <autret_m@epita.fr>
5193
5194 * src/bison.simple: Remove a useless #line directive.
5195 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5196 * src/output.c (get_lines_number): New.
776209d6 5197 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
5198 output muscles.
5199 Fix line numbering.
5200 (actions_output): Computes the number of lines taken by actions.
5201 (output_master_parser): Insert new skeleton which is the name of
5202 the output parser file name.
5203
a79986b8
MA
52042001-12-15 Marc Autret <autret_m@epita.fr>
5205
5206 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5207
4ec8e00f
MA
52082001-12-15 Marc Autret <autret_m@epita.fr>
5209
5210 * src/output.c (output_gram): Keep track of the hairy one.
5211
1a4648ff
AD
52122001-12-15 Akim Demaille <akim@epita.fr>
5213
5214 Make `make distcheck' work.
5215
5216 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5217 system.h which uses libgettext.h.
5218
9c2c67e6
AD
52192001-12-15 Akim Demaille <akim@epita.fr>
5220
5221 * src/nullable.c (set_nullable): Useless rules must be skipped,
5222 otherwise, since we range over their symbols, we might look at a
5223 nonterminal which no longer ``exists'', i.e., it is not counted in
5224 `nvars', hence we overflow our arrays.
5225
93ede233
AD
52262001-12-15 Akim Demaille <akim@epita.fr>
5227
5228 The header can also be produced directly, without any obstack!
5229 Yahoo!
5230
5231 * src/files.c, src/files.h (defines_obstack): Remove.
5232 (compute_header_macro): Global.
5233 (defines_obstack_save): Remove.
5234 * src/reader.c (parse_union_decl): No longer output to
5235 defines_obstack: its content can be found in the `stype' muscle
5236 anyway.
5237 (output_token_translations): Merge into...
5238 (symbols_output): this.
5239 Rename as...
5240 (symbols_save): this.
5241 (reader): Adjust.
5242 * src/output.c (header_output): New.
5243 (output): Call it.
5244
2666f928
AD
52452001-12-15 Akim Demaille <akim@epita.fr>
5246
5247 * src/reader.c (parse_union_decl): Instead of handling two obstack
5248 simultaneously, use one to define the `stype' muscle, and use the
5249 value of the latter to fill defines_obstack.
5250 (copy_comment): Remove.
5251 (copy_comment2): Work for a single obstack.
5252 Rename as...
5253 (copy_comment): this.
5254
428046f8
AD
52552001-12-15 Akim Demaille <akim@epita.fr>
5256
5257 * src/lex.c, src/lex.h (xgetc): No longer static.
5258 * src/reader.c (parse_union_decl): Revamp.
5259
ea52d706
AD
52602001-12-15 Akim Demaille <akim@epita.fr>
5261
5262 Still making progress in separating Bison into (i) input, (ii)
5263 process, (iii) output: now we can directly output the parser file
5264 without using table_obstack at all.
5265
5266 * src/files.c, src/files.h (table_obstack): Bye bye.
5267 (parser_file_name): New.
5268 * src/files.c (compute_output_file_names): Compute it.
5269 * src/output.c (actions_output, output_parser)
5270 (output_master_parser): To a file instead of an obstack.
5271
3f96f4dc
AD
52722001-12-15 Akim Demaille <akim@epita.fr>
5273
5274 Attach actions to rules, instead of pre-outputting them to
5275 actions_obstack.
5276
5277 * src/gram.h (rule_t): action and action_line are new members.
5278 * src/reader.c (symbol_list): Likewise.
5279 (copy_action): Save the actions within the rule.
5280 (packgram): Save them in rule_table.
5281 * src/output.c (actions_output): New.
5282 (output_parser): Use it on `%%actions'.
5283 (output_rule_data): Don't free rule_table.
5284 (output): Do it.
5285 (prepare): Don't save the `action' muscle.
5286 * src/bison.simple: s/%%action/%%actions/.
5287
51576fb3
AD
52882001-12-15 Akim Demaille <akim@epita.fr>
5289
5290 * src/reader.c (copy_action): When --yacc, don't append a `;'
5291 to the user action: let it fail if lacking.
dee049eb 5292 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 5293
2648a72d
AD
52942001-12-14 Akim Demaille <akim@epita.fr>
5295
5296 * src/lex.c (literalchar): Simply return the char you decoded, non
5297 longer mess around with obstacks and int pointers.
5298 Adjust all callers.
5299
92790e5b
AD
53002001-12-14 Akim Demaille <akim@epita.fr>
5301
5302 * src/lex.c (literalchar): Don't escape the special characters,
5303 just decode them, and keep them as char (before, eol was output as
5304 the 2 char string `\n' etc.).
5305 * src/output.c (output_rule_data): Use quotearg to output the
5306 token strings.
5307
927c1557
PE
53082001-12-13 Paul Eggert <eggert@twinsun.com>
5309
5310 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
5311 Do not infringe on the global user namespace when using C++.
5312 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
5313 All uses of `fprintf' and `stderr' changed.
5314
5315 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
5316
ed8e1f68
AD
53172001-12-13 Akim Demaille <akim@epita.fr>
5318
5319 The computation of nullable is broken: it doesn't handle empty
5320 RHS's properly.
5321
5322 * tests/torture.at (GNU AWK Grammar): New.
5323 * tests/sets.at (Nullable): New.
5324 * src/nullable.c (set_nullable): Instead of blindly looping over
5325 `ritems', loop over the rules, and then over their rhs's.
5326
5327 Work around Autotest bugs.
5328
5329 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
5330 frame, because Autotest understand lines starting with a `+' as
5331 traces from the shell. Then, they are not processed properly.
5332 Admittedly an Autotest bug, but we don't have time to wait for
5333 Autotest to catch up.
5334 * tests/regression.at (Broken Closure): Adjust to the new table
5335 frames.
5336 Move to...
5337 * tests/sets.at: here.
5338
cb581495
AD
53392001-12-13 Akim Demaille <akim@epita.fr>
5340
5341 * src/closure.c (closure): Use nrules instead of playing tricks
5342 with BITS_PER_WORD.
5343
2e729273
AD
53442001-12-13 Akim Demaille <akim@epita.fr>
5345
5346 * src/print.c (print_actions): Output the handling of `$' as the
5347 traces do: shifting the token EOF. Before EOF was treated as a
5348 nonterminal.
5349 * tests/regression.at: Adjust some tests.
5350 * src/print_graph.c (print_core): Complete the set of items via
5351 closure. The next-to-final and final states are still unsatisfying,
5352 but that's to be addressed elsewhere.
5353 No longer output the rule numbers, but do output the state number.
5354 A single loop for the shifts + gotos is enough, but picked a
5355 distinct color for each.
5356 (print_graph): Initialize and finalize closure.
5357
107f7dfb
AD
53582001-12-13 Akim Demaille <akim@epita.fr>
5359
5360 * src/reader.c (readgram): Remove dead code, an strip useless
5361 braces.
5362 (get_type): Remove, unused.
5363
9b53a24f
AD
53642001-12-12 Akim Demaille <akim@epita.fr>
5365
5366 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
5367 on that of lib/error.c.
5368
dbfb6dcd
AD
53692001-12-12 Akim Demaille <akim@epita.fr>
5370
5371 Some hosts don't like `/' in includes.
5372
5373 * src/system.h: Include libgettext.h without qualifying the path.
5374 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
5375 $(top_srcdir).
5376
c25fb648
MA
53772001-12-11 Marc Autret <autret_m@epita.fr>
5378
5379 * src/output.c (output_parser): Remove useless muscle.
5380
710ddc4f
MA
53812001-12-11 Marc Autret <autret_m@epita.fr>
5382
5383 * src/bison.simple: Remove #line just before %%epilogue. It
5384 is now handled in ...
5385 * src/reader.c (read_additionnal_code): Add the output of a
5386 #line for the epilogue.
5387
e83d80b8
MA
53882001-12-10 Marc Autret <autret_m@epita.fr>
5389
927c1557 5390 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
5391 replace precedent remove.
5392 * src/bison.simple: Remove #line before %%prologue because
5393 %%input-line is wrong at this time.
5394
971d5158
MA
53952001-12-10 Marc Autret <autret_m@epita.fr>
5396
5397 * src/reader.c (symbols_output): Clean up.
927c1557 5398 * src/output.c (output_gram, output): Clean up.
971d5158 5399
5edafffd
AD
54002001-12-10 Akim Demaille <akim@epita.fr>
5401
5402 * src/lalr.c (initialize_lookaheads): New. Extracted from...
5403 * src/LR0.c (set_state_table): here.
5404 * src/lalr.c (lalr): Call it.
5405
0279f8e9
AD
54062001-12-10 Akim Demaille <akim@epita.fr>
5407
5408 * src/state.h (shifts): Remove the `number' member: shifts are
5409 attached to state, hence no longer need to be labelled with a
5410 state number.
5411
190c4f5f
AD
54122001-12-10 Akim Demaille <akim@epita.fr>
5413
5414 Now that states have a complete set of members, the linked list of
5415 shifts is useless: just fill directly the state's shifts member.
5416
5417 * src/state.h (shifts): Remove the `next' member.
5418 * src/LR0.c (first_state, last_state): Remove.
5419 Adjust the callers.
5420 (augment_automaton): Don't look for the shifts that must be added
5421 a shift on EOF: it is those of the state we looked for! But now,
5422 since shifts are attached, it is no longer needed to looking
5423 merely by its id: its number.
5424
2a73b93d
AD
54252001-12-10 Akim Demaille <akim@epita.fr>
5426
5427 * src/LR0.c (augment_automaton): Better variable locality.
5428 Remove an impossible branch: if there is a state corresponding to
5429 the start symbol being shifted, then there is shift for the start
5430 symbol from the initial state.
5431
74392f6a
AD
54322001-12-10 Akim Demaille <akim@epita.fr>
5433
5434 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
5435 only when appropriate: when insert_start_shifting_state' is not
5436 invoked.
5437 * tests/regression.at (Rule Line Numbers): Adjust.
5438
37c82725
AD
54392001-12-10 Akim Demaille <akim@epita.fr>
5440
5441 * src/LR0.c (augment_automaton): Now that all states have shifts,
5442 merge the two cases addition shifts to the initial state.
5443
6a164e0c
AD
54442001-12-10 Akim Demaille <akim@epita.fr>
5445
5446 * src/lalr.c (set_state_table): Move to...
5447 * src/LR0.c: here.
5448 * src/lalr.c (lalr): Don't call it...
5449 * src/LR0.c (generate_states): do it.
5450 * src/LR0.h (first_state): Remove, only the table is used.
5451
7215de24
AD
54522001-12-10 Akim Demaille <akim@epita.fr>
5453
5454 * src/LR0.h (first_shift, first_reduction): Remove.
5455 * src/lalr.c: Don't use first_shift: find shifts through the
5456 states.
5457
80e25d4d
AD
54582001-12-10 Akim Demaille <akim@epita.fr>
5459
5460 * src/LR0.c: Attach shifts to states as soon as they are
5461 computed.
5462 * src/lalr.c (set_state_table): Instead of assigning shifts to
5463 state, just assert that the mapping was properly done.
5464
0ab3728b
AD
54652001-12-10 Akim Demaille <akim@epita.fr>
5466
5467 * src/LR0.c (insert_start_shift): Rename as...
5468 (insert_start_shifting_state): this.
5469 (insert_eof_shifting_state, insert_accepting_state): New.
5470 (augment_automaton): Adjust.
5471 Better locality of the variables.
5472 When looking if the start_symbol is shifted from the initial
5473 state, using `while (... symbol != start_symbol ...)' sounds
5474 better than `while (... symbol < start_symbol ...)': If fail
5475 to see how the order between symbols could be relevant!
5476
78af9bbc
AD
54772001-12-10 Akim Demaille <akim@epita.fr>
5478
5479 * src/getargs.h: Don't declare `spec_name_prefix' and
5480 `spec_file_prefix', declared by src/files.h.
5481 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
5482 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
5483 * src/output.c (prepare): Adjust.
5484 * src/reader.c (symbols_output): Likewise.
5485 * src/vmsgetargs.c: Vaguely adjust, but who cares?
5486
bdef2a41
AD
54872001-12-10 Akim Demaille <akim@epita.fr>
5488
5489 * src/muscle_tab.c (muscle_init): NULL is a better default than
5490 `"0"'.
5491
3735969c
AD
54922001-12-10 Akim Demaille <akim@epita.fr>
5493
5494 * src/reader.c (reader): Calling symbols_output once is enough.
5495
49701457
AD
54962001-12-10 Akim Demaille <akim@epita.fr>
5497
5498 Now that states have a complete set of members, the linked list of
5499 reductions is useless: just fill directly the state's reductions
5500 member.
5501
5502 * src/state.h (struct reductions): Remove member `number' and
5503 `next'.
5504 * src/LR0.c (first_reduction, last_reduction): Remove.
5505 (save_reductions): Don't link the new reductions, store them in
5506 this_state.
5507 * src/lalr.c (set_state_table): No need to attach reductions to
5508 states, it's already done.
5509 * src/output.c (output_actions): No longer free the shifts, then
5510 the reductions, then the states: free all the states and their
5511 members.
5512
0edad749
AD
55132001-12-10 Akim Demaille <akim@epita.fr>
5514
5515 * src/options.c (OPTN, DRTV, BOTH): New.
5516 (option_table): Use them.
5517
0edad749
AD
5518 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
5519 the job of system.h.
5520 * src/options.c: Don't include stdio.h and xalloc.h for the same
5521 reasons.
5522
5449dd0f
AD
55232001-12-10 Akim Demaille <akim@epita.fr>
5524
5525 * src/output.c (output, prepare): Make sure the values of the
5526 muscles `action' and `prologue' are 0-terminated.
5527
a870c567
AD
55282001-12-10 Akim Demaille <akim@epita.fr>
5529
5530 Clean up GCC warnings.
5531
5532 * src/reader.c (copy_action): `buf' is not used.
5533 (parse_skel_decl): Be static.
5534 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
5535 * src/options.h (create_long_option_table): Have a real prototype.
5536 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
5537 (hash_delete_at): Return const void *.
5538 Adjust casts to preserve the const.
5539
80df8768
AD
55402001-12-10 Akim Demaille <akim@epita.fr>
5541
5542 * configure.in: Require 2.52g.
5543 M4 is not needed, but AUTOM4TE is.
5544 * m4/m4.m4: Remove.
5545 * tests/Makefile.am: Adjust.
5546
f693ad14
AD
55472001-12-10 Akim Demaille <akim@epita.fr>
5548
5549 One structure for states is enough, even though theoretically
5550 there are LR(0) states and LALR(1) states.
5551
5552 * src/lalr.h (state_t): Remove.
5553 (state_table): Be state_t **, not state_t *.
5554 * src/state.h (core, CORE_ALLOC): Rename as...
5555 (state_t, STATE_ALLOC): this.
5556 Add the LALR(1) members: shifts, reductions, errs.
5557 * src/LR0.c (state_table): Rename as...
5558 (state_hash): this, to avoid name clashes with the global
5559 `state_table'.
5560 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
5561 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
5562
74ffbcb6
AD
55632001-12-10 Akim Demaille <akim@epita.fr>
5564
5565 Bison dumps core on bash.y.
5566 Reported by Pascal Bart.
5567
5568 * src/warshall.c (bitmatrix_print): New.
5569 (TC): Use it.
5570 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
5571 j must be the outer loop.
5572 * tests/regression.at (Broken Closure): New.
5573
07708e19
AD
55742001-12-05 Akim Demaille <akim@epita.fr>
5575
5576 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
5577 its argument.
5578