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