]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
(AC_REPLACE_FUNCS): Add strtoul.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-11-30 Paul Eggert <eggert@twinsun.com>
2
3 Type clashes now generate warnings, not errors, since it
4 appears that POSIX may allow some grammars with type clashes.
5 * src/reader.c (grammar_current_rule_check): Warn about
6 type clashes instead of complaining.
7 * tests/input.at (Type Clashes): Expect warnings, not complaints.
8
9 Add Yacc library, since POSIX requires it.
10 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
11 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
12 * lib/main.c, lib/yyerror.c: New files.
13
14 gram_error can be static; it need not be extern.
15 * src/reader.h (gram_error): Remove decl.
16 * src/parse-gram.y (gram_error): Now static. Add static decl.
17 (print_token_value): Omit parameter names from forward decl,
18 for consistency.
19
202002-11-29 Paul Eggert <eggert@twinsun.com>
21
22 * doc/bison.texinfo: Emphasize that yylex and yyerror must
23 be declared before being used. E.g., one should typically
24 declare them in the prologue. Use GNU coding style in examples.
25 Put "const" consistently after the type it modifies. Mention
26 that C99 supports "inline". Mention that yyerror traditionally
27 returns "int".
28
29 %parse-param and %lex-param now take just one argument, the
30 declaration; the argument name is deduced from the declaration.
31
32 * doc/bison.texinfo (Parser Function, Pure Calling, Error
33 Reporting, Table of Symbols): Document this.
34 * src/parse-gram.y (add_param): New function.
35 (COMMA): Remove.
36 (declaration): Implement new rule for %parse-param and %lex-param.
37 * src/scan-gram.l: "," now elicits a warning, rather than being
38 a token; this is more compatible with byacc.
39 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
40
412002-11-27 Paul Eggert <eggert@twinsun.com>
42
43 Rename identifiers to avoid real and potential collisions.
44
45 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
46 to avoid collision with lex macro described by Bruce Lilly in
47 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
48 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
49 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
50 * src/parse-gram.y (print_token_value): Renamed from yyprint.
51 All uses changed.
52 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
53 The name "yycontrol" violates the name space rules, and this stuff
54 wasn't being used anyway.
55 (input): Remove action; this stuff wasn't being used.
56 (gram_error): Rename local variable yylloc -> loc.
57 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
58 (YY_DECL): Don't use "yy" at start of local variables.
59 All uses changed, e.g., yylloc -> loc.
60 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
61 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
62 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
63 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
64
65 * src/parse-gram.y (gram_error): loc is now const *.
66 * src/reader.h (gram_error): Likewise.
67
682002-11-24 Paul Eggert <eggert@twinsun.com>
69
70 Version 1.75c.
71
72 * tests/actions.at (Actions after errors): Use an output format
73 more similar to that of the Printers and Destructors test.
74 Test the position of the ';' token too.
75 (Printers and Destructors): Likewise.
76 (Printers and Destructors: %glr-parser): Remove for now, to avoid
77 unnecessarily alarming people when the test fails.
78
79 * data/yacc.c (yyerrlab1): Move this label down, so that the
80 parser does not discard the lookahead token if the user code
81 invokes YYERROR. This change is required for POSIX conformance.
82
83 * lib/error.c: Sync with gnulib.
84
852002-11-22 Paul Eggert <eggert@twinsun.com>
86
87 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
88 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
89 * lib/xmalloc.c: Likewise.
90
912002-11-20 Paul Eggert <eggert@twinsun.com>
92
93 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
94
952002-11-20 Paul Eggert <eggert@twinsun.com>
96
97 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
98 should use `if (! x) abort ();' rather than `assert (x);', and
99 anyway it's one less thing to worry about configuring.
100
101 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
102 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
103 and replace all instances of assert with abort.
104 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
105 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
106
107 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
108 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
109 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
110 hash_find_entry, hash_rehash, hash_insert): Likewise.
111 * src/conflicts.c (resolve_sr_conflict): Likewise.
112 * src/lalr.c (set_goto_map, map_goto): Likewise.
113 * src/nullable.c (nullable_compute): Likewise.
114 * src/output.c (prepare_rules, token_definitions_output): Likewise.
115 * src/reader.c (packgram, reader): Likewise.
116 * src/state.c (state_new, state_free, state_transitions_set,
117 state_reduction_find): Likewise.
118 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
119 symbol_pack): Likewise.
120 * src/tables.c (conflict_row, pack_vector): Likewise.
121 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
122 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
123 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
124 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
125
126 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
127 (ARGMATCH_CONSTRAINT): New macro.
128 (ARGMATCH_ASSERT): Use it.
129
130 * src/system.h (verify): New macro.
131 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
132 rather than assert.
133 * src/tables.c (tables_generate): Likewise.
134
135 * src/struniq.c (struniq_assert): Now returns void, and aborts
136 if the assertion is false.
137 (struniq_assert_p): Remove.
138 * src/struniq.h: Likewise.
139
1402002-11-18 Paul Eggert <eggert@twinsun.com>
141
142 * data/glr.c (yygetLRActions): Replace `yyindex' with
143 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
144 This fixes the regression with Sun ONE Studio 7 cc that I reported in
145 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001892.html>.
146
1472002-11-18 Akim Demaille <akim@epita.fr>
148
149 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
150 space.
151 From Tim Van Holder.
152
1532002-11-17 Paul Eggert <eggert@twinsun.com>
154
155 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
156 to "SyntaxError" for consistency with my 2002-11-15 change.
157
158 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
159 not define to {}, since this breaks the common use of `YYDPRINTF
160 ((...));' if a single statement is desired (e.g. before `else').
161 Work around GCC warnings by surrounding corresponding calls with
162 {} if needed.
163 (yyhasResolvedValue): Remove unused function.
164 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
165 loop body.
166 (yyreportSyntaxError): Renamed from yyreportParseError.
167 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
168 All uses changed.
169 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
170 extern when possible. Remove unused initializations.
171
1722002-11-16 Akim Demaille <akim@epita.fr>
173
174 Augment the similarity between GLR and LALR traces.
175
176 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
177 (YY_REDUCE_PRINT): New.
178 (yyparse): Use them.
179 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
180 YYDPRINT here.
181 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
182 state reached after the reduction/recovery, since...
183 (yyparse, yyprocessOneStack): Report the state we are entering in.
184
1852002-11-16 Akim Demaille <akim@epita.fr>
186
187 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
188 Add support for --trace=skeleton.
189 * src/scan-skel.l: %option debug.
190 Scan strings of non-@ or \n instead of character by character.
191 (scan_skel): Handle trace_skeleton.
192 (QPUTS): New.
193 (@output_parser_name@, @output_header_name@): ``Restore'' their
194 support (used to be M4 macros).
195 * data/yacc.c: Quote larger chunks, a la glr.c.
196 * data/lalr1.cc: Likewise.
197 The header guards are no longer available, so use some other
198 string than `YYLSP_NEEDED'.
199
2002002-11-16 Akim Demaille <akim@epita.fr>
201
202 Make the ``Printers and Destructors'' test more verbose, taking
203 `yacc.c''s behavior as (possibly wrong) reference.
204
205 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
206 instead of fprint on stdout.
207 Set and report the last_line of the symbols.
208 Consistently display values and locations.
209
2102002-11-16 Paul Eggert <eggert@twinsun.com>
211
212 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
213
2142002-11-15 Paul Eggert <eggert@twinsun.com>
215
216 * tests/actions.at (Actions after errors): New test case.
217
218 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
219 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
220 tests/action.at, tests/calc.at, tests/conflicts.at,
221 tests/cxx-type.at, tests/regression.at:
222 "parse error" -> "syntax error" for POSIX compatibility.
223 "parsing stack overflow..." -> "parser stack overflow" so
224 that code matches Bison documentation.
225
2262002-11-15 Akim Demaille <akim@epita.fr>
227
228 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
229 take two BRACED_CODE, not two string_content.
230 Free the scanner's obstack when we are done.
231 (code_content): New.
232 * tests/calc.at: Adjust.
233 * doc/bison.texinfo: Adjust.
234 Also, make sure to include the `,' for these declarations.
235
2362002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
237
238 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
239 definition; avoids potential autoreconf problems.
240
2412002-11-15 Akim Demaille <akim@epita.fr>
242
243 Always check the value returned by yyparse.
244
245 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
246 returned by yyparse.
247 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
248 Adjust calls.
249 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
250 returned by yyparse.
251
2522002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
253
254 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
255 on input.at test.
256
2572002-11-14 Paul Eggert <eggert@twinsun.com>
258
259 * src/output.c (output_skeleton): Call xfopen instead of
260 duplicating xfopen's body.
261
262 Fix bugs reported by Nelson H. F. Beebe in
263 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
264
265 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
266 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
267 Group compiler. Instead, use "$CC -E bar.c". Include the .h
268 file twice in the grammar, as an extra check.
269
270 * tests/input.at (Torturing the Scanner): Surround the
271 backslash-newline tests with "#if 0", to make it less likely that
272 we'll run into compiler bugs. Bring back solitary \ inside
273 comment, but add a closing comment to work around HP C bug. Don't
274 test backslash-newline in C character constant. This should fix
275 the input.at bug reported by Nelson H. F. Beebe in
276 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
277
2782002-11-14 Akim Demaille <akim@epita.fr>
279
280 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
281 status of the compiler.
282 Calling `exit 1' is no longer needed.
283 Reported by Nelson H. F. Beebe.
284
2852002-11-14 Akim Demaille <akim@epita.fr>
286
287 * tests/atlocal.in (CPPFLAGS): We have config.h.
288 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
289 New.
290 * tests/actions.at, tests/calc.at, tests/conflicts.at,
291 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
292 * tests/regression.at, tests/torture.at: Use them for all the
293 grammars that are to be compiled.
294 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
295 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
296 * doc/bison.texinfo (GLR Parsers): Document `inline'.
297
2982002-11-14 Akim Demaille <akim@epita.fr>
299
300 * doc/bison.texinfo: Various formatting changes (alignments in
301 samples, additional @group/@end group, GCS in samples.
302 Use @deffn instead of simple @table to define the directives,
303 macros, variables etc.
304
3052002-11-13 Paul Eggert <eggert@twinsun.com>
306
307 Fix some bugs reported by Albert Chin-A-Young in
308 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
309
310 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
311 -o c"; the HP C compiler chatters during compilation.
312 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
313 * tests/headers.at (export YYLTYPE): Likewise.
314
315 * tests/input.at (Torturing the Scanner): Remove lines containing
316 solitary backslashes, as they tickle a bug in the HP C compiler.
317
318 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
319 comments, since they're not portable. Use GNU coding style.
320
3212002-11-13 Akim Demaille <akim@epita.fr>
322
323 * data/yacc.c: Leave bigger chunks of quoted text.
324 (YYDSYMPRINTF): New.
325 Use it to report symbol activities.
326 * data/glr.c (YYDSYMPRINTF): New.
327 Use it.
328
3292002-11-12 Paul Eggert <eggert@twinsun.com>
330
331 Version 1.75b.
332
333 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
334 (yyglrReduce): Return yyok, not 0.
335 This should avoid the enumerated-type warnings reported
336 by Nelson H.F. Beebe in
337 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
338
339 * lib/bbitset.h (BITSET_INLINE): Remove.
340 * lib/bitset.h [! BITSET_INLINE]: Remove.
341 (bitset_set, bitset_reset, bitset_test): Rename local vars
342 to avoid shadowing warnings by GCC.
343
344 * data/glr.c (inline): Remove #define. It's the user's
345 responsibility to #define it away, just like 'const'.
346 This fixes one of the bugs reported by Nelson H.F. Beebe in
347 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
348
349 * Makefile.maint (po-check): Scan .l and .y files instead of the
350 .c and the .h files that they generate. This fixes the bug
351 reported by Tim Van Holder in:
352 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
353 Look for N_ as well as for _. Try to avoid matching #define for
354 N_ and _.
355 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
356 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
357 * src/scan-gram.l: Revamp regular expressions so that " and '
358 do not confuse xgettext.
359
360 * src/struniq.h (struniq_new): Do not declare the return type
361 to be 'const'; this violates the C standard.
362 * src/struniq.c (struniq_new): Likewise.
363
3642002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
365
366 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
367 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
368 linker.
369
3702002-11-12 Akim Demaille <akim@epita.fr>
371
372 * Makefile.maint: Sync with Autoconf:
373 (local_updates): New.
374
3752002-11-12 Akim Demaille <akim@epita.fr>
376
377 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
378
3792002-11-12 Akim Demaille <akim@epita.fr>
380
381 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
382 locations.
383
3842002-11-12 Akim Demaille <akim@epita.fr>
385
386 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
387 not yyvalue.
388
3892002-11-12 Akim Demaille <akim@epita.fr>
390
391 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
392 Use it to test the GLR parser.
393
3942002-11-12 Akim Demaille <akim@epita.fr>
395
396 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
397 defines it.
398 * data/glr.c (yystos): New.
399 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
400 (YYDSYMPRINT): New.
401 (yyval): Don't define it, it is handled via M4.
402 (yyrecoverParseError): Free verbosely the discarded symbols.
403 * data/yacc.c (yysymprint): Remove, rather...
404 (b4_yysymprint_generate): invoke.
405 * data/c.m4 (b4_yysymprint_generate): New.
406 Accept pointers as arguments, as opposed to the version from
407 yacc.c.
408 (b4_yydestruct_generate): Likewise.
409 * tests/cations.at (Printers and Destructors): Use Bison directives
410 instead of CPP macros.
411 Don't rely on internal details.
412
4132002-11-12 Akim Demaille <akim@epita.fr>
414
415 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
416 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
417 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
418 it against YYEMPTY and so forth), work on yytoken (i.e., set
419 it to YYEMPTY etc.).
420 (yydestruct): Replace with a b4_yydestruct_generate invocation.
421 (b4_symbol_actions): Remove.
422 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
423 for 0, end-of-input.
424
4252002-11-12 Akim Demaille <akim@epita.fr>
426
427 * doc/bison.texinfo (Destructor Decl): New.
428
4292002-11-12 Akim Demaille <akim@epita.fr>
430
431 * src/tables.c (tables_generate): Use free for pointers that
432 cannot be NULL, not XFREE.
433 (pack_vector): Use assert, not fatal, for bound violations.
434 * src/state.c (state_new): Likewise.
435 * src/reader.c (reader): Likewise.
436 * src/lalr.c (set_goto_map): Likewise.
437 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
438 the file name.
439
4402002-11-12 Akim Demaille <akim@epita.fr>
441
442 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
443 Restore.
444 * src/scan-gram.l (last_string): Is global to the file, not to
445 yylex.
446 * src/parse-gram.y (input): Don't append the epilogue here,
447 (epilogue.opt): do it here, and free the scanner's obstack.
448 * src/reader.c (epilogue_set): Rename as...
449 (epilogue_augment): this.
450 * data/c.m4 (b4_epilogue): Defaults to empty.
451
4522002-11-12 Akim Demaille <akim@epita.fr>
453
454 * src/getargs.c (long_options): Remove duplicates.
455 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
456 Remove.
457 * doc/bison.rnh: Remove.
458 * doc/bison.texinfo (VMS Invocation): Remove.
459
4602002-11-12 Akim Demaille <akim@epita.fr>
461
462 * src/struniq.h, src/struniq.c (struniq_t): Is const.
463 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
464
465 Use struniq for symbols.
466
467 * src/symtab.h (symbol_t): The tag member is a struniq.
468 (symbol_type_set): Adjust.
469 * src/symtab.c (symbol_new): Takes a struniq.
470 (symbol_free): Don't free the tag member.
471 (hash_compare_symbol_t, hash_symbol_t): Rename as...
472 (hash_compare_symbol, hash_symbol): these.
473 Use the fact that tags as struniqs.
474 (symbol_get): Use struniq_new.
475 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
476 Returns a strniq.
477 * src/reader.h (merger_list, grammar_currentmerge_set): The name
478 and type members are struniqs.
479 * src/reader.c (get_merge_function)
480 (grammar_current_rule_merge_set): Adjust.
481 (TYPE, current_type): Are struniq.
482
483 Use struniq for file names.
484
485 * src/files.h, src/files.c (infile): Split into...
486 (grammar_file, current_file): these.
487 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
488 * src/reduce.c (reduce_print): Likewise.
489 * src/getargs.c (getargs): Likewise.
490 * src/complain.h, src/complain.c: Likewise.
491 * src/main.c (main): Call struniqs_new early enough to use it for
492 file names.
493 Don't free the input file name.
494
4952002-11-12 Akim Demaille <akim@epita.fr>
496
497 * src/symtab.c (symbol_free): Remove dead deactivated code:
498 type_name are properly removed.
499 Don't use XFREE to free items that cannot be NULL.
500 * src/struniq.h, src/struniq.c: New.
501 * src/main.c (main): Initialize/free struniqs.
502 * src/parse-gram.y (%union): Add astruniq member.
503 (yyprint): Adjust.
504 * src/scan-gram.l (<{tag}>): Return a struniq.
505 Free the obstack bit that used to store it.
506 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
507
5082002-11-11 Paul Eggert <eggert@twinsun.com>
509
510 Revamp to fix many (but not all) of the C- and M4-related quoting
511 problems. Among other things, this fixes the Bison bug reported
512 by Jan Hubicka when processing the Bash grammar; see:
513 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
514
515 Use new @ escapes consistently. Represent brackets with @{ and @}
516 rather than @<:@ and @:>@, since this works a bit better with dumb
517 editors like vi. Represent @ with @@, since @ is now consistently
518 an escape. Use @oline@ and @ofile@ rather than __oline__ and
519 __ofile__, to avoid unexpected expansions. Similarly, use @output
520 rather than #output.
521
522 * data/c.m4 (b4_copyright): Omit file name from comment, since
523 the file name could contain "*/".
524 (b4_synclines_flag): Don't quote the 2nd argument; it should already
525 be quoted. All uses changed.
526
527 * data/glr.c: Use new @ escapes consistently.
528 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
529 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
530 Remove, since they couldn't handle arbitrary characters in file
531 names.
532 * data/lalr1.cc: Likewise.
533 * data/yacc.c: Likewise.
534
535 * src/files.c (output_infix): Remove; all uses removed.
536 * src/files.h: Likewise.
537
538 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
539 mishandled funny characters in file names, and anyway it isn't
540 needed any more.
541 * data/yacc.c: Likewise.
542 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
543
544 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
545 * data/yacc.c: Likewise.
546
547 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
548 strings now.
549 (muscle_init): Quote filename as a C string.
550 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
551 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
552 * src/output.c (escaped_file_name_output): New function.
553 (prepare_symbols): Quote tokens for M4.
554 (prepare): Don't insert output_infix, output_prefix,
555 output_parser_name, output_header_name; this is now down by scan-skel.
556 Insert skeleton as a C string.
557
558 * src/output.c (user_actions_output, symbol_destructors_output,
559 symbol_printers_output): Quote filenames for C and M4.
560 * src/reader.c (prologue_augment, epilogue_set): Likewise.
561
562 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
563 escapes other than \\ and \'; this simplifies the code.
564 (<SC_STRING>): Likewise, for \\ and \".
565 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
566 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
567 Use new escapes @{ and @} for [ and ].
568
569 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
570 them with auto vars.
571 Switch to new escape scheme, where @ is the escape character uniformly.
572 Abort if a stray escape character is found. Avoid unbounded input
573 buffer when parsing non-escaped text.
574
575 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
576 __oline__, #output, $@, and @{ do not have unintended meanings.
577
5782002-11-09 Paul Eggert <eggert@twinsun.com>
579
580 Fix the test failure due to GCC warnings described in
581 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
582 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
583 evaluate to 0 if it's impossible for NINF to be in the respective
584 table.
585 (yygetLRActions, yyrecoverParseError): Use them.
586
587 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
588 counted in the token inserted at end of file. Now takes
589 location_t *, not location_t, so that the location can be
590 adjusted. All uses changed.
591
592 * tests/regression.at (Invalid inputs): Adjust wording in
593 diagnostic to match the new behavior.
594
595 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
596 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
597 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
598 abort ();'. This reduces the runtime of the "Many lookaheads"
599 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
600 GCC 3.2.
601
6022002-11-07 Paul Eggert <eggert@twinsun.com>
603
604 * src/parse-gram.y (CHARACTER): Remove unused token.
605 All uses removed.
606
607 * src/scan-gram.l: Remove stack option. We no longer use the
608 stack, since the stack was never deeper than 1; instead, use the
609 new auto var c_context to record the stacked value.
610
611 Remove nounput option. At an unexpected end of file, we now unput
612 the minimal input necessary to end cleanly; this simplifies the
613 code.
614
615 Avoid unbounded token sizes where this is easy.
616
617 (unexpected_end_of_file): New function.
618 Use it to systematize the error message on unexpected EOF.
619 (last-string): Now auto, not static.
620 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
621 (scanner_last_string_free): Remove; not used.
622 (percent_percent_count): Move decl to just before use.
623 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
624 not the (never otherwised-used) CHARACTER.
625
6262002-11-07 Akim Demaille <akim@epita.fr>
627
628 Let yyerror always receive the msg as last argument, so that
629 yyerror can be variadic.
630
631 * data/yacc.c (b4_yyerror_args): New.
632 Use it when calling yyerror.
633 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
634 Use it when calling yyerror.
635 * doc/bison.texinfo (Error Reporting): Adjust.
636 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
637 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
638
6392002-11-06 Akim Demaille <akim@epita.fr>
640
641 #line should have quoted strings.
642 Ideally, this should be done by m4_quotearg.
643
644 * src/scan-skel.l: Include quotearg.h.
645 Quote __ofile__.
646 * src/output.c (symbol_printers_output)
647 (symbol_destructors_output): Quote the file name.
648
6492002-11-06 Akim Demaille <akim@epita.fr>
650
651 * tests/regression.at (Invalid inputs): Adjust to the recent
652 messages.
653
6542002-11-06 Akim Demaille <akim@epita.fr>
655
656 Restore --no-lines.
657 Reported by Jim Kent.
658
659 * data/c.m4 (b4_syncline): New.
660 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
661 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
662 * src/output.c (user_actions_output): Likewise.
663 (prepare): Define 'b4_synclines_flag'.
664 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
665
6662002-11-06 Akim Demaille <akim@epita.fr>
667
668 * src/main.c (main): Free `infile'.
669 * src/scan-gram.l (handle_syncline): New.
670 Recognize `#line'.
671 * src/output.c (user_actions_output, symbol_destructors_output)
672 (symbol_printers_output): Use the location's file name, not
673 infile.
674 * src/reader.c (prologue_augment, epilogue_set): Likewise.
675
6762002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
677
678 * src/tables.c (matching_state): Don't allow states to match if
679 either has GLR conflict entries.
680
6812002-11-05 Paul Eggert <eggert@twinsun.com>
682
683 * src/scan-gram.l: Use more accurate diagnostics, e.g.
684 "integer out of range" rather than "invalid value".
685 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
686 accordingly.
687
688 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
689 Also, remove one static variable in the scanner.
690
691 * src/scan-gram.l (braces_level): Now auto, not static.
692 Initialize to zero if the compiler is being picky.
693 (INITIAL): Clear braces_level instead of incrementing it.
694 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
695 as POSIX 1003.1-2001 requires.
696 * src/system.h (IF_LINT): New macro, taken from coreutils.
697 * configure.ac: Define "lint" if --enable-gcc-warnings.
698
6992002-11-05 Akim Demaille <akim@epita.fr>
700
701 * src/scan-gram.l: When it starts with `%', complain about the
702 whole directive, not just that `invalid character: %'.
703
7042002-11-04 Akim Demaille <akim@epita.fr>
705
706 * Makefile.maint: Update from Autoconf.
707 (update, cvs-update, po-update, do-po-update): New.
708
7092002-11-04 Akim Demaille <akim@epita.fr>
710
711 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
712 and yyerror.
713 Have yyerror `use' its arguments.
714 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
715 returns true when location & yacc & pure & parse-param.
716 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
717
7182002-11-04 Akim Demaille <akim@epita.fr>
719
720 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
721 clashes.
722 * src/scan-gram.l: Use [\'] instead of ['] to pacify
723 font-lock-mode.
724 Use complain_at.
725 Use quote, not quote_n since LOCATION_PRINT no longer uses the
726 slot 0.
727
7282002-11-03 Paul Eggert <eggert@twinsun.com>
729
730 * src/reader.c (get_merge_function, grammar_current_rule_check):
731 Use consistent diagnostics for reporting type name clashes.
732 Quote the types with <>, for consistency with Yacc.
733 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
734
7352002-11-03 Akim Demaille <akim@epita.fr>
736
737 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
738 New.
739 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
740 (b4_parse_param): Remove.
741 Use b4_identification.
742 Propagate b4_pure_args where needed to pass them to yyerror.
743 * data/glr.m4 (b4_parse_param): Remove.
744 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
745 (b4_lpure_formals): New.
746 Use b4_identification.
747 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
748 b4_user_formals and b4_user_args.
749 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
750 (yyreportAmbiguity): When using a pure parser, also need
751 the location, and the parse-params.
752 Adjust callers.
753 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
754 When using a pure parser, also need the parse-params.
755 Adjust callers.
756 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
757 (%pure-parser + %parse-param) LALR and GLR parsers.
758 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
759 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
760 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
761 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
762 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
763 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
764 * doc/bison.texinfo: Untabify the whole file.
765 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
766 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
767 (Error Reporting): Adjust to these new directives.
768 Document %error-verbose, deprecate YYERROR_VERBOSE.
769
7702002-11-03 Akim Demaille <akim@epita.fr>
771
772 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
773 AT_CHECK_CALC_GLR invocations to use % directives, instead of
774 command line options.
775 * tests/cxx-type.at: Formatting changes.
776
7772002-11-03 Paul Eggert <eggert@twinsun.com>
778
779 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
780 to count columns correctly, and to check for invalid inputs.
781
782 Use mbsnwidth to count columns correctly. Account for tabs, too.
783 Include mbswidth.h.
784 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
785 (extend_location): New function.
786 (YY_LINES): Remove.
787
788 Handle CRLF in C code rather than in Lex code.
789 (YY_INPUT): New macro.
790 (no_cr_read): New function.
791
792 Scan UCNs, even though we don't fully handle them yet.
793 (convert_ucn_to_byte): New function.
794
795 Handle backslash-newline correctly in C code.
796 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
797 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
798 all uses changed.
799 (tag, splice): New EREs. Do not allow NUL or newline in tags.
800 Use {splice} wherever C allows backslash-newline.
801 YY_STEP after space, newline, vertical-tab.
802 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
803
804 (letter, id): Don't assume ASCII; e.g., spell out a-z.
805
806 ({int}, handle_action_dollar, handle_action_at): Check for integer
807 overflow.
808
809 (YY_STEP): Omit trailing semicolon, so that it's more like C.
810
811 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
812 as well as \000. Check for UCHAR_MAX, not 255.
813 Allow \x with an arbitrary positive number of digits, as in C.
814 Check for overflow here.
815 Allow \? and UCNs, for compatibility with C.
816
817 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
818 with quote slot used by complain_at.
819
820 * tests/input.at: Add tests for backslash-newline, m4 quotes
821 in symbols, long literals, and funny escapes in strings.
822
823 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
824 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
825 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
826 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
827 * m4/mbswidth.m4: New file, from GNU coreutils.
828
829 * doc/bison.texinfo (Grammar Outline): Document // comments.
830 (Symbols): Document that trigraphs have no special meaning in Bison,
831 nor is backslash-newline allowed.
832 (Actions): Document that trigraphs have no special meaning.
833
834 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
835 no longer used.
836
8372002-11-02 Paul Eggert <eggert@twinsun.com>
838
839 * src/reader.c: Don't include quote.h; not needed.
840 (get_merge_function): Reword warning to be consistent with
841 type clash diagnostic in grammar_current_rule_check.
842
843 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
844 bug in trigraph handling.
845
846 * src/output.c (prepare_symbols): When printing token names,
847 escape "[" as "@<:@" and likewise for "]".
848
849 * src/system.h (errno): Remove declaration, as we are now
850 assuming C89 or better, and C89 guarantees errno.
851
8522002-10-30 Paul Eggert <eggert@twinsun.com>
853
854 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
855 Check for close failures.
856 * src/files.h (xfclose): Return void, not int, since it always
857 returned zero.
858 * src/files.c (xfclose): Likewise. Report I/O error if ferror
859 indicates one.
860 * src/output.c (output_skeleton): Use xfclose rather than fclose
861 and ferror. xfclose now checks ferror.
862
863 * data/glr.c (YYLEFTMOST_STATE): Remove.
864 (yyreportTree): Use a stack-based leftmost state. This avoids
865 our continuing battles with bogus warnings about initializers.
866
8672002-10-30 Akim Demaille <akim@epita.fr>
868
869 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
870 #if.
871
8722002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
873
874 * tests/glr-regr1.at: New test for reported regressions.
875 * tests/testsuite.at: Add glr-regr1.at test.
876 * tests/Makefile.am: Add glr-regr1.at test.
877
8782002-10-24 Paul Eggert <eggert@twinsun.com>
879
880 Version 1.75a.
881
882 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
883 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
884 we use malloc. Don't assume 'A' through 'Z' are contiguous.
885 Don't assume strdup exists; POSIX says its an XSI extension.
886 Check for buffer overflow on input.
887
8882002-10-24 Akim Demaille <akim@epita.fr>
889
890 * src/output.c (output_skeleton): Don't disable M4sugar comments
891 too soon: it results in comments being expanded.
892 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
893 first output.
894
8952002-10-24 Akim Demaille <akim@epita.fr>
896
897 * data/yacc.c (m4_int_type): New.
898 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
899 char' as only yacc.c wants K&R portability.
900 * data/glr.c (yysigned_char): Remove.
901 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
902 Reported by Quoc Peyrot.
903
9042002-10-23 Paul Eggert <eggert@twinsun.com>
905
906 * src/main.c (main): With --trace=time, report times even if a
907 non-fatal error occurs. Formerly, the times were reported in some
908 such cases but not in others.
909 * src/reader.c (reader): Just return if a complaint has been issued,
910 instead of exiting, so that 'main' can report times.
911
9122002-10-22 Akim Demaille <akim@epita.fr>
913
914 * src/system.h: Include sys/types.
915 Reported by Bert Deknuydt.
916
9172002-10-23 Paul Eggert <eggert@twinsun.com>
918
919 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
920 Suggested by Art Haas.
921
9222002-10-22 Paul Eggert <eggert@twinsun.com>
923
924 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
925 decl; not needed any more.
926 * src/main.c (main): Use return to exit, undoing yesterday's change.
927 The last OS that we could find where this wouldn't work is
928 SunOS 3.5, and that's too old to worry about now.
929
930 * data/glr.c (struct yyltype): Define members even when not
931 doing locations. This is more consistent with yacc.c, and it
932 works around the following bug reports:
933 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
934 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
935 and I hope it also fixes this bug report:
936 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
937
938 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
939 @acronym consistently. Standardize on "Yacc" instead of "YACC",
940 "Algol" instead of "ALGOL". Give a bit more history about BNF.
941
9422002-10-22 Akim Demaille <akim@epita.fr>
943
944 * data/README: New.
945
9462002-10-21 Paul Eggert <eggert@twinsun.com>
947
948 Be consistent about 'bool'; the old code used an enum in one
949 module and an int in another, and this violates the C standard.
950 * m4/stdbool.m4: New file, from coreutils 4.5.3.
951 * configure.ac (AC_HEADER_STDBOOL): Add.
952 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
953 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
954 * src/symtab.c (hash_compare_symbol_t): Likewise.
955 * src/system.h (bool, false, true): Use a definition consistent
956 with ../lib/hash.c. All uses changed.
957
958 * src/complain.c (warning_issued): Renamed from warn_message_count,
959 so that we needn't worry about integer overflow (!).
960 Now of type bool. All uses changed.
961 (complaint_issued): Renamed from complain_message_count; likewise.
962
963 * src/main.c (main): Use exit to exit with failure.
964
965 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
966 rather than 1 and 0.
967 * src/main.c (main): Likewise.
968 * src/getargs.c (getargs): Likewise.
969 * src/reader.c (reader): Likewise.
970
971 * src/getarg.c (getargs): Remove duplicate code for
972 "Try `bison --help'".
973
974 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
975 What was that "2" for?
976
977 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
978 * src/getargs.c (usage): Likewise.
979
980 * src/getargs.c (getargs): When there are too few operands, report
981 the last one. When there are too many, report the first extra
982 one. This is how diffutils does it.
983
9842002-10-20 Paul Eggert <eggert@twinsun.com>
985
986 Remove K&R vestiges.
987 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
988 * src/complain.c (VA_START): Remove. Assume prototypes.
989 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
990 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
991 fatal): Assume prototypes.
992 * src/complain.h: Assume prototypes.
993 * src/system.h (PARAMS): Remove.
994 Include <limits.h> unconditionally, since it's guaranteeed even
995 for a freestanding C89 compiler.
996 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
997 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
998
9992002-10-20 Akim Demaille <akim@epita.fr>
1000
1001 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1002 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1003 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1004 (yyresolveStates, yyresolveAction, yyresolveStack)
1005 (yyprocessOneStack): Use them.
1006 (yy_reduce_print): New.
1007 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1008
10092002-10-20 Akim Demaille <akim@epita.fr>
1010
1011 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1012 arguments and output `void'.
1013 (b4_c_function): Rename as...
1014 (b4_c_function_def): this.
1015 (b4_c_function_decl, b4_c_ansi_function_def)
1016 (b4_c_ansi_function_decl): New.
1017 Change the interpretation of the arguments: before `int, foo', now
1018 `int foo, foo'.
1019 * data/yacc.c (yyparse): Prototype and define thanks to these.
1020 Adjust b4_c_function_def uses.
1021 * data/glr.c (yyparse): Likewise, but ANSI only.
1022
10232002-10-20 Akim Demaille <akim@epita.fr>
1024
1025 * src/output.c (prepare): Move the definition of `tokens_number',
1026 `nterms_number', `undef_token_number', `user_token_number_max'
1027 to...
1028 (prepare_tokens): Here.
1029 (prepare_tokens): Rename as...
1030 (prepare_symbols): this.
1031 (prepare): Move the definition of `rules_number' to...
1032 (prepare_rules): here.
1033 (prepare): Move the definition of `last', `final_state_number',
1034 `states_number' to...
1035 (prepare_states): here.
1036 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1037
10382002-10-20 Akim Demaille <akim@epita.fr>
1039
1040 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1041
10422002-10-20 Akim Demaille <akim@epita.fr>
1043
1044 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1045 * data/c.m4: here.
1046
10472002-10-20 Akim Demaille <akim@epita.fr>
1048
1049 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1050 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1051 `pair'.
1052 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1053 `name' to...
1054 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1055 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1056 These.
1057
10582002-10-19 Paul Eggert <eggert@twinsun.com>
1059
1060 Do not create a temporary file, as that involves security and
1061 cleanup headaches. Instead, use a pair of pipes.
1062 Derived from a suggestion by Florian Krohm.
1063 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1064 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1065 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1066 (BISON_PREREQ_SUBPIPE): Add.
1067 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1068 Add subpipe.h, subpipe.c.
1069 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1070 * po/POTFILES.in: Add lib/subpipe.c.
1071 * src/output.c: Include "subpipe.h".
1072 (m4_invoke): Remove decl.
1073 (scan_skel): New decl.
1074 (output_skeleton): Use pipe rather than temporary file for m4 input.
1075 Check that m4sugar.m4 is readable, to avoid deadlock.
1076 Check for pipe I/O error.
1077 * src/scan-skel.l (readpipe): Remove decl.
1078 (scan_skel): New function, to be used in place of m4_invoke.
1079 Read from stream rather than file.
1080
1081 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1082 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1083 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1084 this generates a more-accurate value anyway.
1085
1086 * lib/timevar.c (timervar_accumulate): Rename locals to
1087 avoid confusion with similarly-named more-global.
1088 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1089
1090 * src/output.c (prepare): Use xstrdup to convert char const *
1091 to char *, to avoid GCC warning.
1092
10932002-10-19 Akim Demaille <akim@epita.fr>
1094
1095 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1096 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1097 Use them to have `calc.y' ready for %pure-parser.
1098 * data/yacc.c (YYLEX): Pass a yylex return type to
1099 b4_c_function_call.
1100
11012002-10-19 Akim Demaille <akim@epita.fr>
1102
1103 Prototype support of %lex-param and %parse-param.
1104
1105 * src/parse-gram.y: Add the definition of the %lex-param and
1106 %parse-param tokens, plus their rules.
1107 Drop the `_' version of %glr-parser.
1108 Add the "," token.
1109 * src/scan-gram.l (INITIAL): Scan them.
1110 * src/muscle_tab.c: Comment changes.
1111 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1112 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1113 (muscle_entry_s): The `value' member is no longer const.
1114 Adjust all dependencies.
1115 * src/muscle_tab.c (muscle_init): Adjust: use
1116 MUSCLE_INSERT_STRING.
1117 Initialize the obstack earlier.
1118 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1119 (muscle_pair_list_grow): New.
1120 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1121 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1122 * tests/calc.at: Use %locations, not --locations.
1123 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1124
11252002-10-19 Akim Demaille <akim@epita.fr>
1126
1127 * src/getargs.c (usage): Take status as argument and exit
1128 accordingly.
1129 Report the traditional `Try ... --help' message when status != 0.
1130 (usage, version): Don't take a FILE * as arg, it is pointless.
1131 (getargs): When there is an incorrect number of arguments, make it
1132 an error, and report it GNUlically thanks to `usage ()'.
1133
11342002-10-18 Paul Eggert <eggert@twinsun.com>
1135
1136 * data/glr.c (yyreportParseError): Don't assume that sprintf
1137 yields the length of the printed string, as this is not true
1138 on SunOS 4.1.4. Reported by Peter Klein.
1139
1140 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1141 * tests/conflicts.at (%nonassoc and eof): Likewise.
1142 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1143
11442002-10-17 Akim Demaille <akim@epita.fr>
1145
1146 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1147 * src/getargs.c (trace_types, trace_args): Adjust.
1148 * src/reader.c (grammar_current_rule_prec_set)
1149 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1150 Standardize error messages.
1151 And s/@prec/%prec/!
1152 (reader): Use trace_flag to enable scanner/parser debugging,
1153 instead of an adhoc scheme.
1154 * src/scan-gram.l: Remove trailing debugging code.
1155
11562002-10-16 Paul Eggert <eggert@twinsun.com>
1157
1158 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1159 MUSCLE_TAB_H.
1160
1161 * NEWS: Officially drop support for building Bison with K&R C,
1162 since it didn't work anyway and it's not worth worrying about.
1163 * Makefile.maint (wget_files): Remove ansi2knr.c.
1164 (ansi2knr.c-url_prefix): Remove.
1165 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1166 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1167 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1168
11692002-10-15 Paul Eggert <eggert@twinsun.com>
1170
1171 Stop using the "enum_" trick for K&R-style function definitions;
1172 it confused me, and I was the author! Instead, assume that people
1173 who want to use K&R C compilers (when using these modules in GCC,
1174 perhaps?) will run ansi2knr.
1175
1176 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1177 All uses of "enum_" changed to "enum ".
1178 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1179 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1180
1181 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1182 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1183 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1184 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1185 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1186 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1187 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1188 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1189 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1190 Use function prototypes; this removes the need for declaring
1191 static functions simply to provide their prototypes.
1192 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1193 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1194 bitset_count_, bitset_create, bitset_dump, bitset_first,
1195 bitset_free, bitset_init, bitset_last, bitset_next,
1196 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1197 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1198 bitset_print, bitset_release_memory, bitset_toggle_,
1199 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1200 debug_bitset): Likewise.
1201 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1202 * lib/bitset_stats.c (bitset_log_histogram_print,
1203 bitset_percent_histogram_print, bitset_stats_and,
1204 bitset_stats_and_cmp, bitset_stats_and_or,
1205 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1206 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1207 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1208 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1209 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1210 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1211 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1212 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1213 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1214 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1215 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1216 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1217 bitset_stats_zero): Likewise.
1218 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1219 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1220 bitsetv_dump, debug_bitsetv): Likewise.
1221 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1222 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1223 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1224 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1225 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1226 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1227 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1228 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1229 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1230 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1231 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1232 Likewise.
1233 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1234 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1235 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1236 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1237 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1238 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1239 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1240 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1241 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1242 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1243 lbitset_xor_cmp, lbitset_zero): Likewise.
1244
12452002-10-14 Akim Demaille <akim@epita.fr>
1246
1247 Version 1.75.
1248
12492002-10-14 Akim Demaille <akim@epita.fr>
1250
1251 * tests/Makefile.am (maintainer-check-posix): New.
1252
12532002-10-14 Akim Demaille <akim@epita.fr>
1254
1255 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1256 member.
1257
12582002-10-14 Akim Demaille <akim@epita.fr>
1259
1260 * src/tables.c (table_ninf_remap): base -> tab.
1261 Reported by Matt Rosing.
1262
12632002-10-14 Paul Eggert <eggert@twinsun.com>
1264
1265 * tests/action.at, tests/calc.at, tests/conflicts.at,
1266 tests/cxx-type.at, tests/headers.at, tests/input.at,
1267 tests/regression.at, tests/synclines.at, tests/torture.at:
1268 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1269 so that the tests still work even if POSIXLY_CORRECT is set.
1270 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
1271
1272 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1273 for portability to K&R hosts. Fix typo: signed char is guaranteed
1274 only to 127, not to 128.
1275 * data/glr.c (yysigned_char): New type.
1276 * data/yacc.c (yysigned_char): Likewise.
1277 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1278
12792002-10-13 Paul Eggert <eggert@twinsun.com>
1280
1281 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1282 true due to limited range of data type" warning from GCC.
1283
1284 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1285 by wrapping enum yytokentype's definition inside #ifndef
1286 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1287
12882002-10-13 Akim Demaille <akim@epita.fr>
1289
1290 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1291 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1292
12932002-10-13 Akim Demaille <akim@epita.fr>
1294
1295 * Makefile.maint: Update from Autoconf 2.54.
1296 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1297
12982002-10-13 Akim Demaille <akim@epita.fr>
1299
1300 * src/print.c (print_state): Separate the list of solved conflicts
1301 from the other items.
1302 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1303
13042002-10-13 Akim Demaille <akim@epita.fr>
1305
1306 Let nondeterministic skeletons be usable with deterministic
1307 tables.
1308
1309 With the patch, GAWK compiled by GCC without -O2 passes its test
1310 suite using a GLR parser driven by LALR tables. It fails with -O2
1311 because `struct stat' gives two different answers on my machine:
1312 88 (definition of an auto var) and later 96 (memset on this var).
1313 Hence the stack is badly corrumpted. The headers inclusion is to
1314 blame: if I move the awk.h inclusion before GLR's system header
1315 inclusion, the two struct stat have the same size.
1316
1317 * src/tables.c (pack_table): Always create conflict_table.
1318 (token_actions): Always create conflict_list.
1319 * data/glr.c (YYFLAG): Remove, unused.
1320
13212002-10-13 Akim Demaille <akim@epita.fr>
1322
1323 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1324 (O0FLAGS): New.
1325 (VALGRIND, GXX): New.
1326 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1327 * tests/bison.in: Run $PREBISON a pre-command.
1328 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1329 (maintainer-check-g++): New.
1330 * Makefile.am (maintainer-check): New.
1331
13322002-10-13 Akim Demaille <akim@epita.fr>
1333
1334 * data/glr.c: Formatting changes.
1335 Tweak some trace messages to match yacc.c's.
1336
13372002-10-13 Akim Demaille <akim@epita.fr>
1338
1339 GLR parsers sometimes raise parse errors instead of performing the
1340 default reduction.
1341 Reported by Charles-Henry de Boysson.
1342
1343 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1344 check the length of the traces when %glr.
1345 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1346 GLR's traces.
1347 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1348 Test GLR parsers.
1349 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1350 (yyltype): Remove the yy prefix from the member names.
1351 (yytable): Complete its comment.
1352 (yygetLRActions): Map error action number from YYTABLE from
1353 YYTABLE_NINF to 0.
1354 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1355 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1356 not satisfying as we could compare an YYACTION computed from
1357 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1358 only value for error actions.
1359 (yyreportParseError): In verbose parse error messages, don't issue
1360 `error' in the list of expected tokens.
1361 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1362 next action to perform to match glr.c's decoding.
1363 (yytable): Complete its comment.
1364
13652002-10-13 Paul Eggert <eggert@twinsun.com>
1366
1367 Fix problem reported by Henrik Grubbstroem in
1368 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1369 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1370 because the Bison parser reads the second action before reducing
1371 the first one.
1372 * src/scan-gram.l (rule_length): New static var.
1373 Use it to keep track of the rule length in the scanner, since
1374 we can't expect the parser to be in lock-step sync with the scanner.
1375 (handle_action_dollar, handle_action_at): Use this var.
1376 * tests/actions.at (Exotic Dollars): Test for the problem.
1377
13782002-10-12 Paul Eggert <eggert@twinsun.com>
1379
1380 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1381 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1382 Include <sys/time.h> when checking for clock_t and struct tms.
1383 Use same include order as source.
1384 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1385 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
1386
1387 * lib/timevar.c: Update copyright date and clarify comments.
1388 (get_time) [IN_GCC]: Keep the GCC version for reference.
1389
1390 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1391 GCC version as of today, then merge Bison's changes.
1392 Change "GCC" to "Bison" in copyright notice. timevar.def's
1393 author is Akim, so change that too.
1394
1395 * src/reader.c (grammar_current_rule_check):
1396 Don't worry about the default action if $$ is untyped.
1397 Prevents bogus warnings reported by Jim Gifford in
1398 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1399
1400 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1401 * data/glr.c, data/lalr1.cc, data/yacc.c:
1402 Output token definitions before the first part of user declarations.
1403 Fixes compatibility problem reported by Jim Gifford for kbd in
1404 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1405
14062002-10-11 Paul Eggert <eggert@twinsun.com>
1407
1408 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1409 (yyparse): here. This undoes some of the 2002-07-25 change.
1410 Compatibility problem reported by Ralf S. Engelschall with
1411 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1412
14132002-10-11 Akim Demaille <akim@epita.fr>
1414
1415 * tests/regression.at Characters Escapes): New.
1416 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1417 characters.
1418 Reported by Jan Nieuwenhuizen.
1419
14202002-10-11 Akim Demaille <akim@epita.fr>
1421
1422 * po/id.po: New.
1423
14242002-10-10 Paul Eggert <eggert@twinsun.com>
1425
1426 Portability fixes for bitsets; this also avoids several GCC
1427 warnings.
1428
1429 * lib/abitset.c: Include <stddef.h>, for offsetof.
1430 * lib/lbitset.c: Likewise.
1431
1432 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1433 properly for vectors of objects. Do not assume that adding a
1434 header size to a multiple of a word size yields a value that is
1435 properly aligned for the whole union.
1436 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1437
1438 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1439 unique names for structures.
1440 * lib/ebitset.c (ebitset_bytes): Likewise.
1441 * lib/lbitset.c (lbitset_bytes): Likewise.
1442
1443 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1444 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1445 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1446 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1447 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1448 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1449 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1450 to improve the type-checking that GCC can do.
1451 * lib/bitset.c (bitset_op4_cmp): Likewise.
1452 * lib/bitset_stats.c (bitset_stats_count,
1453 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1454 bitset_stats_copy, bitset_stats_disjoint_p,
1455 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1456 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1457 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1458 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1459 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1460 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1461 bitset_stats_or_and_cmp): Likewise.
1462 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1463 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1464 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1465 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1466
1467 * lib/abitset.h: Include bitset.h, not bbitset.h.
1468 * lib/ebitset.h: Likewise.
1469 * lib/lbitset.h: Likewise.
1470
1471 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1472 All instances of parameters of type enum bitset_opts are now of
1473 type enum_bitset_opts, to conform to the C Standard, and similarly
1474 for enum_bitset_type.
1475 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1476 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1477
1478 Do not use "struct bitset_struct" to mean different things in
1479 different modules. Not only is this confusing, it violates
1480 the C Standard, which requires that structure types in different
1481 modules must be compatible if one is to be passed to the other.
1482 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1483 All instances of "struct bitset_struct *" replaced with "bitset".
1484 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1485 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1486 struct lbitset_struct, struct bitset_stats_struct): New types.
1487 All uses of struct bitset_struct changed to union bitset_union,
1488 etc.
1489 * lib/abitset.c (struct abitset_struct, abitset,
1490 struct bitset_struct): Remove.
1491 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1492 struct bitset_struct): Remove.
1493 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1494 bitset_struct): Remove.
1495 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1496 Likewise.
1497
1498 Do not call a function of type T using a call that assumes the
1499 function is of a different type U. Standard C requires that a
1500 function must be called with a type that is compatible with its
1501 definition.
1502 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1503 New decls.
1504 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1505 New functions.
1506 * lib/ebitset.c (PFV): Remove.
1507 * lib/lbitset.c (PFV): Likewise.
1508 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
1509 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
1510 decls.
1511 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
1512 (ebitset_vtable): Use them.
1513 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
1514 lbitset_xor): New functions.
1515 (lbitset_vtable): Use them.
1516
1517 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
1518 Declare.
1519
1520 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
1521 GCC warning.
1522 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
1523 Use offsetof, for simplicity.
1524
15252002-10-06 Paul Eggert <eggert@twinsun.com>
1526
1527 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
1528 the same width as int. This reapplies a hunk of the 2002-08-12 patch
1529 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
1530 which was inadvertently undone by the 2002-09-30 patch.
1531 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
1532 the same width as int.
1533
15342002-10-04 Paul Eggert <eggert@twinsun.com>
1535
1536 Version 1.50.
1537
1538 * configure.ac (AC_INIT), NEWS: Increment version number.
1539
1540 * doc/bison.texinfo: Minor spelling, grammar, and white space
1541 fixes.
1542 (Symbols): Mention that any negative value returned from yylex
1543 signifies end-of-input. Warn about negative chars. Mention
1544 the portable Standard C character set.
1545
1546 The GNU coding standard says CFLAGS and YFLAGS are reserved
1547 for the installer to set.
1548 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
1549 * src/Makefile.am (AM_CFLAGS): Likewise.
1550 (AM_YFLAGS): Renamed from YFLAGS.
1551
1552 Fix some MAX and MIN problems.
1553 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
1554 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
1555 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
1556 * src/reader.c (reader): Use it.
1557
1558 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
1559 POSIX 1003.1-2001 has removed fgrep.
1560
15612002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
1562
1563 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
1564 interpreted as signed.
1565 * lib/ebitset.c (ebitset_list): Fix bug.
1566
15672002-10-01 Paul Eggert <eggert@twinsun.com>
1568
1569 More fixes for 64-bit hosts and large bitsets.
1570
1571 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
1572 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
1573 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
1574 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
1575 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
1576 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
1577 bitset_count_): Likewise.
1578 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
1579 bitset_first, bitset_last): Likewise.
1580 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
1581 bitset_stats_list_reverse, bitset_stats_size,
1582 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
1583 Likewise.
1584 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1585 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1586 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1587 bitsetv_reflexive_transitive_closure): Likewise.
1588 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
1589 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
1590 Likewise.
1591 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
1592 Likewise.
1593
1594 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
1595 Use size_t, not unsigned int, to count bytes.
1596 * lib/abitset.h (abitset_bytes): Likewise.
1597 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
1598 Likewise.
1599 * lib/bitset.h (bitset_bytes): Likewise.
1600 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
1601 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
1602 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1603 * lib/ebitset.c (ebitset_bytes): Likewise.
1604 * lib/ebitset.h (ebitset_bytes): Likewise.
1605 * lib/lbitset.c (lbitset_bytes): Likewise.
1606 * lib/lbitset.h (lbitset_bytes): Likewise.
1607
1608 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
1609 abitset_subset_p, abitset_disjoint_p, abitset_and,
1610 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
1611 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
1612 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
1613 abitset_or_and, abitset_or_and_cmp):
1614 Use bitset_windex instead of unsigned int.
1615 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1616 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
1617 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
1618 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
1619 Likewise.
1620 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
1621
1622 * lib/bitset.c (bitset_print):
1623 Use proper printf formats for widths of integer types.
1624 * lib/bitset_stats.c (bitset_percent_histogram_print,
1625 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
1626 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1627 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1628 * lib/lbitset.c (lbitset_bytes): Likewise.
1629
1630 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
1631 BITSET_SIZE_MAX): New macros.
1632 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
1633 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
1634 to BITSET_WINDEX_MAX.
1635
1636 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
1637 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
1638 since we now return the bitset_bindex type (not int).
1639
1640 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
1641 when computing sizes.
1642 * lib/ebitset.c (ebitset_elts_grow): Likewise.
1643
1644 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
1645 and avoid cast to unsigned.
1646
16472002-09-30 Akim Demaille <akim@epita.fr>
1648
1649 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
1650 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
1651 Updates from Michael Hayes.
1652
16532002-09-30 Art Haas <ahaas@neosoft.com>
1654
1655 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
1656 invocations.
1657 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
1658 defined.
1659
16602002-09-27 Akim Demaille <akim@epita.fr>
1661
1662 Version 1.49c.
1663
16642002-09-27 Akim Demaille <akim@epita.fr>
1665
1666 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
1667 (Because of AC_LIBSOURCE).
1668
16692002-09-27 Akim Demaille <akim@epita.fr>
1670
1671 Playing with Autoscan.
1672
1673 * configure.ac: Remove the old LIBOBJ tweaks.
1674 (AC_REPLACE_FUNCS): Add strrchr and strtol.
1675 * lib/strrchr.c: New.
1676 * lib/strtol.c: New, from the Coreutils 4.5.1.
1677
16782002-09-27 Akim Demaille <akim@epita.fr>
1679
1680 Playing with Autoscan.
1681
1682 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
1683 * lib/Makefile.am (libbison_a_SOURCES): No longer include
1684 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
1685 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
1686 Coreutils 4.5.1.
1687
16882002-09-24 Akim Demaille <akim@epita.fr>
1689
1690 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
1691 (Frequently Asked Questions, Parser Stack Overflow): New.
1692
16932002-09-13 Akim Demaille <akim@epita.fr>
1694
1695 Playing with autoscan.
1696
1697 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
1698 * src/files.c (skeleton_find): Remove, unused.
1699 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
1700 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
1701
17022002-09-13 Akim Demaille <akim@epita.fr>
1703
1704 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
1705 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
1706
17072002-09-13 Akim Demaille <akim@epita.fr>
1708
1709 * configure.ac: Require 2.54.
1710 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
1711 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
1712 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
1713 Remove, provided by Autoconf macros.
1714
17152002-09-12 Akim Demaille <akim@epita.fr>
1716
1717 * m4/prereq.m4: Update, from Coreutils 4.5.1.
1718
17192002-09-12 Akim Demaille <akim@epita.fr>
1720
1721 * m4/prereq.m4: Update, from Fileutils 4.1.5.
1722 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
1723 Reported by Martin Mokrejs.
1724
17252002-09-10 Akim Demaille <akim@epita.fr>
1726
1727 * src/parse-gram.y: Associate a human readable string to each
1728 token type.
1729 * tests/regression.at (Invalid inputs): Adjust.
1730
17312002-09-10 Gary V. Vaughan <gary@gnu.org>
1732
1733 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
1734 with an Autoconf-2.5x style configure.ac.
1735
17362002-09-06 Paul Eggert <eggert@twinsun.com>
1737
1738 * doc/bison.texinfo (Conditions): Make explicit that the GPL
1739 exception applies only to yacc.c. This is a modification of a
1740 patch originally suggested by Akim Demaille.
1741
17422002-09-06 Akim Demaille <akim@epita.fr>
1743
1744 * data/c.m4 (b4_copyright): Move the GPL exception comment from
1745 here to...
1746 * data/yacc.c: here.
1747
1748 * data/lalr1.cc (struct yyltype): Don't define it, since we use
1749 LocationType.
1750 (b4_ltype): Default to yy::Location from location.hh.
1751
17522002-09-04 Jim Meyering <jim@meyering.net>
1753
1754 * data/yacc.c: Guard the declaration of yytoknum also with
1755 `#ifdef YYPRINT', so it is declared only when used.
1756
17572002-09-04 Akim Demaille <akim@epita.fr>
1758
1759 * configure.in: Rename as...
1760 * configure.ac: this.
1761 Bump to 1.49c.
1762
17632002-09-04 Akim Demaille <akim@epita.fr>
1764
1765 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
1766 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
1767 translate maintainer only messages.
1768
17692002-08-12 Paul Eggert <eggert@twinsun.com>
1770
1771 Version 1.49b.
1772
1773 * Makefile.am (SUBDIRS): Remove intl.
1774 (DISTCLEANFILES): Remove.
1775 * NEWS: Mention that GNU M4 is now required. Clarify what is
1776 meant by "larger grammars". Mention the pt_BR translation.
1777 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
1778 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
1779 Bump version from 0.11.2 to 0.11.5.
1780 (BISON_PREREQ_STAGE): Remove.
1781 (AM_GNU_GETTEXT): Use external gettext.
1782 (AC_OUTPUT): Remove intl/Makefile.
1783
1784 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
1785
1786 * data/glr.c: Include string.h, for strlen.
1787 (yyreportParseError): Use size_t for yysize.
1788 (yy_yypstack): No longer nested inside yypstates, as nested
1789 functions are not portable. Do not assume size_t is the
1790 same width as int.
1791 (yypstates): Do not assume that ptrdiff_t is the same width
1792 as int, and similarly for yyposn and YYINDEX.
1793
1794 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
1795
1796 * lib/Makefile.am (INCLUDES): Do not include from the intl
1797 directory, which has been removed.
1798 * src/Makefile.am (INCLUDES): Likewise.
1799
1800 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
1801 (bitsets_sources, additional_bitsets_sources, timevars_sources):
1802 New vars.
1803
1804 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
1805 * tests/Makefile.am (EXTRA_DIST): Likewise.
1806
1807 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
1808 Do not assume that bitset_windex is the same width as unsigned.
1809
1810 * lib/abitset.c (abitset_unused_clear): Do not assume that
1811 bitset_word is the same width as int.
1812 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
1813 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
1814 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
1815 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
1816 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
1817
1818 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
1819 portability to one's complement hosts!).
1820 * lib/ebitset.c (ebitset_op1): Likewise.
1821 * lib/lbitset.c (lbitset_op1): Likewise.
1822
1823 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
1824 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
1825 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
1826 Sync with fileutils.
1827 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
1828 lib/gettext.h: Sync with diffutils.
1829
1830 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
1831 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
1832
1833 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
1834 PROTOTYPES to check for prototypes, and "defined __STDC__" to
1835 check for void *.
1836
1837 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
1838 size_t; the old version tried to do this but casted improperly.
1839 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
1840 (bitset_test): Now returns int, not unsigned long.
1841
1842 * lib/bitset_stats.c: Include "gettext.h".
1843 (_): New macro.
1844 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
1845 name locals "index", as it generates unnecessary warnings on some
1846 hosts that have an "index" function.
1847
1848 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
1849 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
1850 they need translation.
1851 * src/LR0.c (state_list_append, new_itemsets, get_state,
1852 append_states, generate_states): Likewise.
1853 * src/assoc.c (assoc_to_string): Likewise.
1854 * src/closure.c (print_closure, set_firsts, closure): Likewise.
1855 * src/gram.c (grammar_dump): Likewise.
1856 * src/injections.c (injections_compute): Likewise.
1857 * src/lalr.c (lookaheads_print): Likewise.
1858 * src/relation.c (relation_transpose): Likewise.
1859 * src/scan-gram.l: Likewise.
1860 * src/tables.c (table_grow, pack_vector): Likewise.
1861
1862 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
1863 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
1864 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
1865 * m4/mbstate_t.m4: Sync with fileutils.
1866 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
1867
1868 * po/LINGUAS: Add pt_BR.
1869 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
1870 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
1871 lib/timevar.c.
1872 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
1873 manual recommends.
1874 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
1875
1876 * src/complain.c (strerror_r): Remove decl; not needed.
1877 (strerror): Use same pattern as ../lib/error.c.
1878
1879 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
1880
1881 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
1882
1883 * src/main.c (main): Cast result of bindtextdomain and textdomain
1884 to void, to avoid a GCC warning when --disable-nls is in effect.
1885
1886 * src/scan-gram.l: Use strings rather than escapes when possible,
1887 to minimize the number of warnings from xgettext.
1888 (handle_action_dollar, handle_action_at): Don't use isdigit,
1889 as it mishandles negative chars and it may not work as expected
1890 outside the C locale.
1891
1892 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
1893 this is a GCC extension and is not portable to other compilers.
1894
1895 * src/system.h (alloca): Use same pattern as ../lib/error.c.
1896 Do not include <ctype.h>; no longer needed.
1897 Do not include <malloc.h>; no longer needed (and generates
1898 warnings on OpenBSD 3.0).
1899
1900 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
1901 it's not portable.
1902
1903 * tests/regression.at: Do not use 'cc -c input.c -o input';
1904 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1905
1906 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1907 exit status as failure, not just exit status 1. Sun C exits
1908 with status 2 sometimes.
1909
1910 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1911 Use it for the two large tests.
1912
19132002-08-02 Akim Demaille <akim@epita.fr>
1914
1915 * src/conflicts.c (conflicts_output): Don't output rules never
1916 reduced here, since anyway that computation doesn't work.
1917 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1918 (rule_useless_p, rule_never_reduced_p): New.
1919 (grammar_rules_partial_print): Use a filter instead of a range.
1920 Display the title only if needed.
1921 (grammar_rules_print): Adjust.
1922 (grammar_rules_never_reduced_report): New.
1923 * src/tables.c (action_row): Move the computation of rules never
1924 reduced to...
1925 (token_actions): here.
1926 * src/main.c (main): Make the parser before making the report, so
1927 that rules never reduced are computed.
1928 Call grammar_rules_never_reduced_report.
1929 * src/print.c (print_results): Report rules never reduced.
1930 * tests/conflicts.at, tests/reduce.at: Adjust.
1931
19322002-08-01 Akim Demaille <akim@epita.fr>
1933
1934 Instead of attaching lookaheads and duplicating the rules being
1935 reduced by a state, attach the lookaheads to the reductions.
1936
1937 * src/state.h (state_t): Remove the `lookaheads',
1938 `lookaheads_rule' member.
1939 (reductions_t): Add a `lookaheads' member.
1940 Use a regular array for the `rules'.
1941 * src/state.c (reductions_new): Initialize the lookaheads member
1942 to 0.
1943 (state_rule_lookaheads_print): Adjust.
1944 * src/state.h, src/state.c (state_reductions_find): New.
1945 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1946 (count_rr_conflicts): Adjust.
1947 * src/lalr.c (LArule): Remove.
1948 (add_lookback_edge): Adjust.
1949 (state_lookaheads_count): New.
1950 (states_lookaheads_initialize): Merge into...
1951 (initialize_LA): this.
1952 (lalr_free): Adjust.
1953 * src/main.c (main): Don't free nullable and derives too early: it
1954 is used by --verbose.
1955 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1956
19572002-08-01 Akim Demaille <akim@epita.fr>
1958
1959 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1960 `rule_number_t**'.
1961 (set_derives, free_derives): Rename as...
1962 (derives_compute, derives_free): this.
1963 Adjust all dependencies.
1964 * src/nullable.c (set_nullable, free_nullable): Rename as...
1965 (nullable_compute, nullable_free): these.
1966 (rule_list_t): Store rule_t *, not rule_number_t.
1967 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1968 pointers, instead of their numbers.
1969 * src/main.c (main): Call nullable_free, and derives_free earlier,
1970 as they were lo longer used.
1971
19722002-08-01 Akim Demaille <akim@epita.fr>
1973
1974 * lib/timevar.c (get_time): Include children time.
1975 * src/lalr.h (LA, LArule): Don't export them: used with the
1976 state_t.
1977 * src/lalr.c (LA, LArule): Static.
1978 * src/lalr.h, src/lalr.c (lalr_free): New.
1979 * src/main.c (main): Call it.
1980 * src/tables.c (pack_vector): Check whether loc is >= to the
1981 table_size, not >.
1982 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1983 (tables_generate): do it, since that's also it which allocates
1984 them.
1985 Don't free LA and LArule, main does.
1986
19872002-07-31 Akim Demaille <akim@epita.fr>
1988
1989 Separate parser tables computation and output.
1990
1991 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1992 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1993 (yydefgoto, yydefact, high): Move to...
1994 * src/tables.h, src/tables.c: here.
1995 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1996 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1997 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1998 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1999 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2000 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2001 (action_row, save_row, token_actions, save_column, default_goto)
2002 (goto_actions, sort_actions, matching_state, pack_vector)
2003 (table_ninf_remap, pack_table, prepare_actions): Move to...
2004 * src/tables.c: here.
2005 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2006 * src/output.c (token_actions, output_base, output_conflicts)
2007 (output_check): Merge into...
2008 (prepare_actions): this.
2009 (actions_output): Rename as...
2010 (user_actions_output): this.
2011 * src/main.c (main): Call tables_generate and tables_free.
2012
20132002-07-31 Akim Demaille <akim@epita.fr>
2014
2015 Steal GCC's --time-report support.
2016
2017 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2018 stolen/adjusted from GCC.
2019 * m4/stage.m4: Remove time related checks.
2020 * m4/timevar.m4: New.
2021 * configure.in: Adjust.
2022 * src/system.h: Adjust to using timevar.h.
2023 * src/getargs.h, src/getargs.c: Support trace_time for
2024 --trace=time.
2025 * src/main.c (stage): Remove.
2026 (main): Replace `stage' invocations with timevar calls.
2027 * src/output.c: Insert pertinent timevar calls.
2028
20292002-07-31 Akim Demaille <akim@epita.fr>
2030
2031 Let --trace have arguments.
2032
2033 * src/getargs.h (enum trace_e): New.
2034 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2035 (long_options, short_options): --trace/-T takes an optional
2036 argument.
2037 Change all the uses of trace_flag to reflect the new flags.
2038 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2039
2040 Strengthen `stage' portability.
2041
2042 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2043 * configure.in: Use it.
2044 Don't check for malloc.h and sys/times.h.
2045 * src/system.h: Include them when appropriate.
2046 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2047 times and struct tms are available.
2048
20492002-07-30 Akim Demaille <akim@epita.fr>
2050
2051 In verbose parse error message, don't report `error' as an
2052 expected token.
2053 * tests/actions.at (Printers and Destructors): Adjust.
2054 * tests/calc.at (Calculator $1): Adjust.
2055 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2056 error message, do not report the parser accepts the error token in
2057 that state.
2058
20592002-07-30 Akim Demaille <akim@epita.fr>
2060
2061 Normalize conflict related messages.
2062
2063 * src/complain.h, src/complain.c (warn, complain): New.
2064 * src/conflicts.c (conflicts_print): Use them.
2065 (conflict_report_yacc): New, extracted from...
2066 (conflicts_print): here.
2067 * tests/conflicts.at, tests/existing.at: Adjust.
2068
20692002-07-30 Akim Demaille <akim@epita.fr>
2070
2071 Report rules which are never reduced by the parser: those hidden
2072 by conflicts.
2073
2074 * src/LR0.c (save_reductions): Don't make the final state too
2075 different: save its reduction (accept) instead of having a state
2076 without any action (no shift or goto, no reduce).
2077 Note: the final state is now a ``regular'' state, i.e., the
2078 parsers now contain `reduce 0' as default reduction.
2079 Nevertheless, since they decide to `accept' when yystate =
2080 final_state, they still will not reduce rule 0.
2081 * src/print.c (print_actions, print_reduction): Adjust.
2082 * src/output.c (action_row): Track reduced rules.
2083 (token_actions): Report rules never reduced.
2084 * tests/conflicts.at, tests/regression.at: Adjust.
2085
20862002-07-30 Akim Demaille <akim@epita.fr>
2087
2088 `stage' was accidently included in a previous patch.
2089 Initiate its autoconfiscation.
2090
2091 * configure.in: Look for malloc.h and sys/times.h.
2092 * src/main.c (stage): Adjust.
2093 Report only when trace_flag.
2094
20952002-07-29 Akim Demaille <akim@epita.fr>
2096
2097 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2098 state_number_t.
2099 (errs_t): symbol_t*, not symbol_number_t.
2100 (reductions_t): rule_t*, not rule_number_t.
2101 (FOR_EACH_SHIFT): New.
2102 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2103 * src/print.c, src/print_graph.c: Adjust.
2104
21052002-07-29 Akim Demaille <akim@epita.fr>
2106
2107 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2108
2109 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2110 (endtoken, accept): these.
2111 * src/reader.c (reader): Set endtoken's default tag to "$end".
2112 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2113 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2114 Adjust.
2115
21162002-07-29 Akim Demaille <akim@epita.fr>
2117
2118 * src/reduce.c (reduce_grammar): When the language is empty,
2119 complain about the start symbol, not the axiom.
2120 Use its location.
2121 * tests/reduce.at (Empty Language): New.
2122
21232002-07-26 Akim Demaille <akim@epita.fr>
2124
2125 * src/reader.h, src/reader.c (gram_error): ... can't get
2126 yycontrol without making too strong assumptions on the parser
2127 itself.
2128 * src/output.c (prepare_tokens): Use the real 0th value of
2129 token_translations instead of `0'.
2130 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2131 visible here.
2132 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2133 for the time being: %locations ought to provide it to yyerror.
2134
21352002-07-25 Akim Demaille <akim@epita.fr>
2136
2137 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2138 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2139 * tests/regression.at (Web2c Actions): Adjust.
2140
21412002-07-25 Akim Demaille <akim@epita.fr>
2142
2143 Stop storing rules from 1 to nrules + 1.
2144
2145 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2146 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2147 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2148 Iterate from 0 to nrules.
2149 Use rule_number_as_item_number and item_number_as_rule_number.
2150 Adjust to `derive' now containing possibly 0.
2151 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2152 Handle the `- 1' part in rule numbers from/to item numbers.
2153 * src/conflicts.c (log_resolution): Fix the message which reversed
2154 shift and reduce.
2155 * src/output.c (action_row): Initialize default_rule to -1.
2156 (token_actions): Adjust.
2157 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2158 expected output.
2159 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2160
21612002-07-25 Akim Demaille <akim@epita.fr>
2162
2163 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2164 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2165 (b4_c_knr_arg_decl): New.
2166 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2167 yyreport_parse_error.
2168
21692002-07-25 Akim Demaille <akim@epita.fr>
2170
2171 * data/yacc.c (yyreport_parse_error): New, extracted from...
2172 (yyparse): here.
2173 (yydestruct, yysymprint): Move above yyparse.
2174 Be K&R compliant.
2175
21762002-07-25 Akim Demaille <akim@epita.fr>
2177
2178 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2179 replace...
2180 (b4_sint_type, b4_uint_type): these.
2181 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2182 * tests/regression.at (Web2c Actions): Adjust.
2183
21842002-07-25 Akim Demaille <akim@epita.fr>
2185
2186 * src/gram.h (TIEM_NUMBER_MAX): New.
2187 (item_number_of_rule_number, rule_number_of_item_number): Rename
2188 as...
2189 (rule_number_as_item_number, item_number_as_rule_number): these.
2190 Adjust dependencies.
2191 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2192 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2193 (symbol_number_to_vector_number): New.
2194 (order): Of vector_number_t* type.
2195 (base_t, BASE_MAX, BASE_MIN): New.
2196 (froms, tos, width, pos, check): Of base_t type.
2197 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2198 (actrow): Of action_number_t type.
2199 (conflrow): Of unsigned int type.
2200 (table_ninf, base_ninf): New.
2201 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2202 (muscle_insert_int_table, muscle_insert_base_table)
2203 (muscle_insert_rule_number_table): New.
2204 (prepare_tokens): Output `toknum' as int_table.
2205 (action_row): Returns a rule_number_t.
2206 Use ACTION_MIN, not SHRT_MIN.
2207 (token_actions): yydefact is rule_number_t*.
2208 (table_ninf_remap): New.
2209 (pack_table): Use it for `base' and `table'.
2210 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2211 replaced with...
2212 (YYPACT_NINF, YYTABLE_NINF): these.
2213 (yypact, yytable): Compute their types instead of hard-coded
2214 `short'.
2215 * tests/regression.at (Web2c Actions): Adjust.
2216
22172002-07-19 Akim Demaille <akim@epita.fr>
2218
2219 * src/scan-gram.l (id): Can start with an underscore.
2220
22212002-07-16 Akim Demaille <akim@epita.fr>
2222
2223 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2224 Adjust all former `associativity' dependencies.
2225 * src/symtab.c (symbol_new): Default associativity is `undef', not
2226 `right'.
2227 (symbol_check_alias_consistence): Adjust.
2228
22292002-07-09 Akim Demaille <akim@epita.fr>
2230
2231 * doc/bison.texinfo: Properly set the ``header'' part.
2232 Use @dircategory ``GNU programming tools'' as per Texinfo's
2233 documentation.
2234 Use @copying.
2235
22362002-07-09 Akim Demaille <akim@epita.fr>
2237
2238 * lib/quotearg.h: Protect against multiple inclusions.
2239 * src/location.h (location_t): Add a `file' member.
2240 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2241 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2242 `error_one_per_line' support.
2243
22442002-07-09 Akim Demaille <akim@epita.fr>
2245
2246 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2247 * src/reader.c (lineno): Remove.
2248 Adjust all dependencies.
2249 (get_merge_function): Take a location and use complain_at.
2250 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2251 * tests/regression.at (Invalid inputs, Mixing %token styles):
2252 Adjust.
2253
22542002-07-09 Akim Demaille <akim@epita.fr>
2255
2256 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2257 recovery rule, and forbid extensions when --yacc.
2258 (gram_error): Use complain_at.
2259 * src/reader.c (reader): Exit if there were parse errors.
2260
22612002-07-09 Akim Demaille <akim@epita.fr>
2262
2263 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2264 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2265 Reported by R Blake <blakers@mac.com>.
2266
22672002-07-09 Akim Demaille <akim@epita.fr>
2268
2269 * data/yacc.c: Output the copyright notive in the header.
2270
22712002-07-03 Akim Demaille <akim@epita.fr>
2272
2273 * src/output.c (froms, tos): Are state_number_t.
2274 (save_column): sp, sp1, and sp2 are state_number_t.
2275 (prepare): Rename `final' as `final_state_number', `nnts' as
2276 `nterms_number', `nrules' as `rules_number', `nstates' as
2277 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2278 unused.
2279 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2280 * data/lalr1.cc (nsym_): Remove, unused.
2281
22822002-07-03 Akim Demaille <akim@epita.fr>
2283
2284 * src/lalr.h, src/lalr.c (goto_number_t): New.
2285 * src/lalr.c (goto_list_t): New.
2286 Propagate them.
2287 * src/nullable.c (rule_list_t): New.
2288 Propagate.
2289 * src/types.h: Remove.
2290
22912002-07-03 Akim Demaille <akim@epita.fr>
2292
2293 * src/closure.c (print_fderives): Use rule_rhs_print.
2294 * src/derives.c (print_derives): Use rule_rhs_print.
2295 (rule_list_t): New, replaces `shorts'.
2296 (set_derives): Add comments.
2297 * tests/sets.at (Nullable, Firsts): Adjust.
2298
22992002-07-03 Akim Demaille <akim@epita.fr>
2300
2301 * src/output.c (prepare_actions): Free `tally' and `width'.
2302 (prepare_actions): Allocate and free `order'.
2303 * src/symtab.c (symbols_free): Free `symbols'.
2304 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2305 * src/output.c (m4_invoke): Move to...
2306 * src/scan-skel.l: here.
2307 (<<EOF>>): Close yyout, and free its name.
2308
23092002-07-03 Akim Demaille <akim@epita.fr>
2310
2311 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2312
2313 * src/LR0.c (new_state): Merge into...
2314 (state_list_append): this.
2315 (new_states): Merge into...
2316 (generate_states): here.
2317 (set_states): Don't ensure a proper `errs' state member here, do it...
2318 * src/conflicts.c (conflicts_solve): here.
2319 * src/state.h, src/state.c: Comment changes.
2320 (state_t): Rename member `shifts' as `transitions'.
2321 Adjust all dependencies.
2322 (errs_new): For consistency, also take the values as argument.
2323 (errs_dup): Remove.
2324 (state_errs_set): New.
2325 (state_reductions_set, state_transitions_set): Assert that no
2326 previous value was assigned.
2327 (state_free): New.
2328 (states_free): Use it.
2329 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2330 temporary storage: use `errs' and `nerrs' as elsewhere.
2331 (set_conflicts): Allocate and free this `errs'.
2332
23332002-07-02 Akim Demaille <akim@epita.fr>
2334
2335 * lib/libiberty.h: New.
2336 * lib: Update the bitset implementation from upstream.
2337 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2338 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2339 * src/main.c: Adjust bitset stats calls.
2340
23412002-07-01 Paul Eggert <eggert@twinsun.com>
2342
2343 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2344 char, so that negative chars don't collide with $.
2345
23462002-06-30 Akim Demaille <akim@epita.fr>
2347
2348 Have the GLR tests be `warning' checked, and fix the warnings.
2349
2350 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2351 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2352 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2353 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2354 (yyaddDeferredAction): static.
2355 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2356 (yyreportParseError): yyprefix is const.
2357 yytokenp is used only when verbose.
2358 (yy__GNUC__): Replace with __GNUC__.
2359 (yypdumpstack): yyi is size_t.
2360 (yypreference): Un-yy local variables and arguments, to avoid
2361 clashes with `yyr1'. Anyway, we are not in the user name space.
2362 (yytname_size): be an int, as is compared with ints.
2363 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2364 Use them.
2365 * tests/cxx-gram.at: Use quotation to protect $1.
2366 Use AT_COMPILE to enable warnings hunts.
2367 Prototype yylex and yyerror.
2368 `Use' argc.
2369 Include `string.h', not `strings.h'.
2370 Produce and prototype stmtMerge only when used.
2371 yylex takes a location.
2372
23732002-06-30 Akim Demaille <akim@epita.fr>
2374
2375 We spend a lot of time in quotearg, in particular when --verbose.
2376
2377 * src/symtab.c (symbol_get): Store a quoted version of the key.
2378 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2379 Adjust all callers.
2380
23812002-06-30 Akim Demaille <akim@epita.fr>
2382
2383 * src/state.h (reductions_t): Rename member `nreds' as num.
2384 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2385 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2386
23872002-06-30 Akim Demaille <akim@epita.fr>
2388
2389 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2390 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2391 (shifts_to): Rename as...
2392 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2393 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2394 (TRANSITION_IS_DISABLED, transitions_to): these.
2395
23962002-06-30 Akim Demaille <akim@epita.fr>
2397
2398 * src/print.c (print_shifts, print_gotos): Merge into...
2399 (print_transitions): this.
2400 (print_transitions, print_errs, print_reductions): Align the
2401 lookaheads columns.
2402 (print_core, print_transitions, print_errs, print_state,
2403 print_grammar): Output empty lines separator before, not after.
2404 (state_default_rule_compute): Rename as...
2405 (state_default_rule): this.
2406 * tests/conflicts.at (Defaulted Conflicted Reduction),
2407 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2408 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2409
24102002-06-30 Akim Demaille <akim@epita.fr>
2411
2412 Display items as we display rules.
2413
2414 * src/gram.h, src/gram.c (rule_lhs_print): New.
2415 * src/gram.c (grammar_rules_partial_print): Use it.
2416 * src/print.c (print_core): Likewise.
2417 * tests/conflicts.at (Defaulted Conflicted Reduction),
2418 (Unresolved SR Conflicts): Adjust.
2419 (Unresolved SR Conflicts): Adjust and rename as...
2420 (Resolved SR Conflicts): this, as was meant.
2421 * tests/regression.at (Web2c Report): Adjust.
2422
24232002-06-30 Akim Demaille <akim@epita.fr>
2424
2425 * src/print.c (state_default_rule_compute): New, extracted from...
2426 (print_reductions): here.
2427 Pessimize, but clarify the code.
2428 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2429
24302002-06-30 Akim Demaille <akim@epita.fr>
2431
2432 * src/output.c (action_row): Let default_rule be always a rule
2433 number.
2434
24352002-06-30 Akim Demaille <akim@epita.fr>
2436
2437 * src/closure.c (print_firsts, print_fderives, closure):
2438 Use BITSET_EXECUTE.
2439 * src/lalr.c (lookaheads_print): Likewise.
2440 * src/state.c (state_rule_lookaheads_print): Likewise.
2441 * src/print_graph.c (print_core): Likewise.
2442 * src/print.c (print_reductions): Likewise.
2443 * src/output.c (action_row): Likewise.
2444 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2445
24462002-06-30 Akim Demaille <akim@epita.fr>
2447
2448 * src/print_graph.c: Use report_flag.
2449
24502002-06-30 Akim Demaille <akim@epita.fr>
2451
2452 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2453 to...
2454 * src/relation.h, src/relation.c (traverse, relation_digraph)
2455 (relation_print, relation_transpose): New.
2456
24572002-06-30 Akim Demaille <akim@epita.fr>
2458
2459 * src/state.h, src/state.c (shifts_to): New.
2460 * src/lalr.c (build_relations): Use it.
2461
24622002-06-30 Akim Demaille <akim@epita.fr>
2463
2464 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2465 (item_number_of_rule_number, rule_number_of_item_number): New.
2466 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2467 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2468 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2469 Propagate their use.
2470 Much remains to be done, in particular wrt `shorts' from types.h.
2471
24722002-06-30 Akim Demaille <akim@epita.fr>
2473
2474 * src/symtab.c (symbol_new): Initialize the `printer' member.
2475
24762002-06-30 Akim Demaille <akim@epita.fr>
2477
2478 * src/LR0.c (save_reductions): Remove, replaced by...
2479 * src/state.h, src/state.c (state_reductions_set): New.
2480 (reductions, errs): Rename as...
2481 (reductions_t, errs_t): these.
2482 Adjust all dependencies.
2483
24842002-06-30 Akim Demaille <akim@epita.fr>
2485
2486 * src/LR0.c (state_list_t, state_list_append): New.
2487 (first_state, last_state): Now symbol_list_t.
2488 (this_state): Remove.
2489 (new_itemsets, append_states, save_reductions): Take a state_t as
2490 argument.
2491 (set_states, generate_states): Adjust.
2492 (save_shifts): Remove, replaced by...
2493 * src/state.h, src/state.c (state_shifts_set): New.
2494 (shifts): Rename as...
2495 (shifts_t): this.
2496 Adjust all dependencies.
2497 * src/state.h (state_t): Remove the `next' member.
2498
24992002-06-30 Akim Demaille <akim@epita.fr>
2500
2501 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2502 escaped in slot 0.
2503
25042002-06-30 Akim Demaille <akim@epita.fr>
2505
2506 Use hash.h for the state hash table.
2507
2508 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
2509 (allocate_storage): Use state_hash_new.
2510 (free_storage): Use state_hash_free.
2511 (new_state, get_state): Adjust.
2512 * src/lalr.h, src/lalr.c (states): Move to...
2513 * src/states.h (state_t): Remove the `link' member, no longer
2514 used.
2515 * src/states.h, src/states.c: here.
2516 (state_hash_new, state_hash_free, state_hash_lookup)
2517 (state_hash_insert, states_free): New.
2518 * src/states.c (state_table, state_compare, state_hash): New.
2519 * src/output.c (output_actions): Do not free states now, since we
2520 still need to know the final_state number in `prepare', called
2521 afterwards. Do it...
2522 * src/main.c (main): here: call states_free after `output'.
2523
25242002-06-30 Akim Demaille <akim@epita.fr>
2525
2526 * src/state.h, src/state.c (state_new): New, extracted from...
2527 * src/LR0.c (new_state): here.
2528 * src/state.h (STATE_ALLOC): Move to...
2529 * src/state.c: here.
2530 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
2531 * src/state.h, src/state.c: here.
2532
25332002-06-30 Akim Demaille <akim@epita.fr>
2534
2535 * src/reader.c (gensym): Rename as...
2536 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
2537 (getsym): Rename as...
2538 (symbol_get): this.
2539
25402002-06-30 Akim Demaille <akim@epita.fr>
2541
2542 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
2543 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
2544 * src/output.c, src/print.c, src/print_graph.c: Propagate.
2545 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
2546
25472002-06-30 Akim Demaille <akim@epita.fr>
2548
2549 Make the test suite pass with warnings checked.
2550
2551 * tests/actions.at (Printers and Destructors): Improve.
2552 Avoid unsigned vs. signed issues.
2553 * tests/calc.at: Don't exercise the scanner here, do it...
2554 * tests/input.at (Torturing the Scanner): here.
2555
25562002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2557
2558 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
2559 reorganize first lines parallel to yacc.c.
2560
25612002-06-28 Akim Demaille <akim@epita.fr>
2562
2563 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
2564 (b4_token_enum, b4_token_defines): New, factored from...
2565 * data/lalr1.cc, data/yacc.c, glr.c: here.
2566
25672002-06-28 Akim Demaille <akim@epita.fr>
2568
2569 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
2570 unused variables.
2571 * src/output.c (merger_output): static.
2572
25732002-06-28 Akim Demaille <akim@epita.fr>
2574
2575 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
2576 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
2577 pacify GCC.
2578 * src/output.c (save_row): Initialize all the variables to pacify GCC.
2579
25802002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2581
2582 Accumulated changelog for new GLR parsing features.
2583
2584 * src/conflicts.c (count_total_conflicts): Change name to
2585 conflicts_total_count.
2586 * src/conflicts.h: Ditto.
2587 * src/output.c (token_actions): Use the new name.
2588 (output_conflicts): Change conflp => conflict_list_heads, and
2589 confl => conflict_list for better readability.
2590 * data/glr.c: Use the new names.
2591 * NEWS: Add self to GLR announcement.
2592
2593 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
2594
2595 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
2596 Akim Demaille.
2597
2598 * data/bison.glr: Change name to glr.c
2599 * data/glr.c: Renamed from bison.glr.
2600 * data/Makefile.am: Add glr.c
2601
2602 * src/getargs.c:
2603
2604 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
2605 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
2606
2607 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2608
2609 * data/bison.glr: Be sure to restore the
2610 current #line when returning to the skeleton contents after having
2611 exposed the input file's #line.
2612
2613 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2614
2615 * data/bison.glr: Bring up to date with changes to bison.simple.
2616
2617 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2618
2619 * data/bison.glr: Correct definitions that use b4_prefix.
2620 Various reformatting.
2621 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
2622 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
2623 yytokenp argument; now part of stack.
2624 (yychar): Define to behave as documented.
2625 (yyclearin): Ditto.
2626
2627 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2628
2629 * src/reader.h: Add declaration for free_merger_functions.
2630
2631 * src/reader.c (merge_functions): New variable.
2632 (get_merge_function): New function.
2633 (free_merger_functions): New function.
2634 (readgram): Check for %prec that is not followed by a symbol.
2635 Handle %dprec and %merge declarations.
2636 (packgram): Initialize dprec and merger fields in rules array.
2637
2638 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
2639 conflict_list_cnt, conflict_list_free): New variables.
2640 (table_grow): Also grow conflict_table.
2641 (prepare_rules): Output dprec and merger tables.
2642 (conflict_row): New function.
2643 (action_row): Output conflict lists for GLR parser. Don't use
2644 default reduction in conflicted states for GLR parser so that there
2645 are spaces for the conflict lists.
2646 (save_row): Also save conflict information.
2647 (token_actions): Allocate conflict list.
2648 (merger_output): New function.
2649 (pack_vector): Pack conflict table, too.
2650 (output_conflicts): New function to output yyconflp and yyconfl.
2651 (output_check): Allocate conflict_tos.
2652 (output_actions): Output conflict tables, also.
2653 (output_skeleton): Output b4_mergers definition.
2654 (prepare): Output b4_max_rhs_length definition.
2655 Use 'bison.glr' as default skeleton for GLR parsers.
2656
2657 * src/gram.c (glr_parser): New flag.
2658 (grammar_free): Call free_merger_functions.
2659
2660 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
2661 all pairs of conflicting reductions, rather than just all tokens
2662 causing conflicts. Needed to size conflict tables.
2663 (conflicts_output): Modify call to count_rr_conflicts for new
2664 interface.
2665 (conflicts_print): Ditto.
2666 (count_total_conflicts): New function.
2667
2668 * src/reader.h (merger_list): New type.
2669 (merge_functions): New variable.
2670
2671 * src/lex.h (tok_dprec, tok_merge): New token types.
2672
2673 * src/gram.h (rule_s): Add dprec and merger fields.
2674 (glr_parser): New flag.
2675
2676 * src/conflicts.h (count_total_conflicts): New function.
2677
2678 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
2679
2680 * doc/bison.texinfo (Generalized LR Parsing): New section.
2681 (GLR Parsers): New section.
2682 (Language and Grammar): Mention GLR parsing.
2683 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
2684 Correct typo ("tge" -> "the").
2685
2686 * data/bison.glr: New skeleton for GLR parsing.
2687
2688 * tests/cxx-gram.at: New tests for GLR parsing.
2689
2690 * tests/testsuite.at: Include cxx-gram.at.
2691
2692 * tests/Makefile.am: Add cxx-gram.at.
2693
2694 * src/parse-gram.y:
2695
2696 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
2697
2698 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
2699
27002002-06-27 Akim Demaille <akim@epita.fr>
2701
2702 * src/options.h, src/options.c: Remove.
2703 * src/getargs.c (short_options, long_options): New.
2704
27052002-06-27 Akim Demaille <akim@epita.fr>
2706
2707 * data/bison.simple, data/bison.c++: Rename as...
2708 * data/yacc.c, data/lalr1.cc: these.
2709 * doc/bison.texinfo (Environment Variables): Remove.
2710
27112002-06-25 Raja R Harinath <harinath@cs.umn.edu>
2712
2713 * src/getargs.c (report_argmatch): Initialize strtok().
2714
27152002-06-20 Akim Demaille <akim@epita.fr>
2716
2717 * data/bison.simple (b4_symbol_actions): New, replaces...
2718 (b4_symbol_destructor, b4_symbol_printer): these.
2719 (yysymprint): Be sure to call YYPRINT only for tokens, and using
2720 user token numbers.
2721
27222002-06-20 Akim Demaille <akim@epita.fr>
2723
2724 * data/bison.simple (yydestructor): Rename as...
2725 (yydestruct): this.
2726
27272002-06-20 Akim Demaille <akim@epita.fr>
2728
2729 * src/symtab.h, src/symtab.c (symbol_type_set)
2730 (symbol_destructor_set, symbol_precedence_set): The location is
2731 the last argument.
2732 Adjust all callers.
2733
27342002-06-20 Akim Demaille <akim@epita.fr>
2735
2736 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
2737 internals.
2738 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
2739 Takes a location.
2740 * src/symtab.h, src/symtab.c (symbol_class_set)
2741 (symbol_user_token_number_set): Likewise.
2742 Adjust all callers.
2743 Promote complain_at.
2744 * tests/input.at (Type Clashes): Adjust.
2745
27462002-06-20 Akim Demaille <akim@epita.fr>
2747
2748 * data/bison.simple (YYLEX): Fix the declaration when
2749 %pure-parser.
2750
27512002-06-20 Akim Demaille <akim@epita.fr>
2752
2753 * data/bison.simple (yysymprint): Don't print the token number,
2754 just its name.
2755 * tests/actions.at (Destructors): Rename as...
2756 (Printers and Destructors): this.
2757 Also exercise %printer.
2758
27592002-06-20 Akim Demaille <akim@epita.fr>
2760
2761 * data/bison.simple (YYDSYMPRINT): New.
2762 Use it to remove many of the #if YYDEBUG/if (yydebug).
2763
27642002-06-20 Akim Demaille <akim@epita.fr>
2765
2766 * src/symtab.h, src/symtab.c (symbol_t): printer and
2767 printer_location are new members.
2768 (symbol_printer_set): New.
2769 * src/parse-gram.y (PERCENT_PRINTER): New token.
2770 Handle its associated rule.
2771 * src/scan-gram.l: Adjust.
2772 (handle_destructor_at, handle_destructor_dollar): Rename as...
2773 (handle_symbol_code_at, handle_symbol_code_dollar): these.
2774 * src/output.c (symbol_printers_output): New.
2775 (output_skeleton): Call it.
2776 * data/bison.simple (yysymprint): New. Cannot be named yyprint
2777 since there are already many grammar files with a user `yyprint'.
2778 Replace the calls to YYPRINT to calls to yysymprint.
2779 * tests/calc.at: Adjust.
2780 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
2781 taking advantage of parser very internal details (stack size!).
2782
27832002-06-20 Akim Demaille <akim@epita.fr>
2784
2785 * src/scan-gram.l: Complete the scanner with the missing patterns
2786 to pacify Flex.
2787 Use `quote' and `symbol_tag_get' where appropriate.
2788
27892002-06-19 Akim Demaille <akim@epita.fr>
2790
2791 * tests/actions.at (Destructors): Augment to test locations.
2792 * data/bison.simple (yydestructor): Pass it the current location
2793 if locations are enabled.
2794 Prototype only when __STDC__ or C++.
2795 Change the argument names to move into the yy name space: there is
2796 user code here.
2797
27982002-06-19 Akim Demaille <akim@epita.fr>
2799
2800 * data/bison.simple (b4_pure_if): New.
2801 Use it instead of #ifdef YYPURE.
2802
28032002-06-19 Akim Demaille <akim@epita.fr>
2804
2805 * data/bison.simple (b4_location_if): New.
2806 Use it instead of #ifdef YYLSP_NEEDED.
2807
28082002-06-19 Akim Demaille <akim@epita.fr>
2809
2810 Prepare @$ in %destructor, but currently don't bind it in the
2811 skeleton, as %location use is not cleaned up yet.
2812
2813 * src/scan-gram.l (handle_dollar, handle_destructor_at)
2814 (handle_action_at): New.
2815 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
2816 a braced_code_t and a location as additional arguments.
2817 (handle_destructor_dollar): Instead of requiring `b4_eval', just
2818 unquote one when outputting `b4_dollar_dollar'.
2819 Adjust callers.
2820 * data/bison.simple (b4_eval): Remove.
2821 (b4_symbol_destructor): Adjust.
2822 * tests/input.at (Invalid @n): Adjust.
2823
28242002-06-19 Zack Weinberg <zack@codesourcery.com>
2825
2826 * doc/bison.texinfo: Document ability to have multiple
2827 prologue sections.
2828
28292002-06-18 Akim Demaille <akim@epita.fr>
2830
2831 * src/files.c (compute_base_names): When computing the output file
2832 names from the input file name, strip the directory part.
2833
28342002-06-18 Akim Demaille <akim@epita.fr>
2835
2836 * data/bison.simple.new: Comment changes.
2837 Reported by Andreas Schwab.
2838
28392002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
2840
2841 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
2842 there are no `label `yyoverflowlab' defined but not used' warnings
2843 when yyoverflow is defined.
2844
28452002-06-18 Akim Demaille <akim@epita.fr>
2846
2847 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
2848 new member.
2849 (symbol_destructor_set): Adjust.
2850 * src/output.c (symbol_destructors_output): Output the destructor
2851 locations.
2852 Output the symbol name.
2853 * data/bison.simple (b4_symbol_destructor): Adjust.
2854
28552002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
2856 and Akim Demaille <akim@epita.fr>
2857
2858 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
2859 what's left on the stack when the error recovery hits EOF.
2860 * tests/actions.at (Destructors): Complete to exercise this case.
2861
28622002-06-17 Akim Demaille <akim@epita.fr>
2863
2864 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
2865 arguments is really empty, not only equal to `[]'.
2866 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
2867 member.
2868 (symbol_destructor_set): New.
2869 * src/output.c (symbol_destructors_output): New.
2870 * src/reader.h (brace_code_t, current_braced_code): New.
2871 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
2872 (handle_dollar): Rename as...
2873 (handle_action_dollar): this.
2874 (handle_destructor_dollar): New.
2875 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
2876 (grammar_declaration): Use it.
2877 * data/bison.simple (yystos): Is always defined.
2878 (yydestructor): New.
2879 * tests/actions.at (Destructors): New.
2880 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
2881
28822002-06-17 Akim Demaille <akim@epita.fr>
2883
2884 * src/symlist.h, src/symlist.c (symbol_list_length): New.
2885 * src/scan-gram.l (handle_dollar, handle_at): Compute the
2886 rule_length only when needed.
2887 * src/output.c (actions_output, token_definitions_output): Output
2888 the full M4 block.
2889 * src/symtab.c: Don't access directly to the symbol tag, use
2890 symbol_tag_get.
2891 * src/parse-gram.y: Use symbol_list_free.
2892
28932002-06-17 Akim Demaille <akim@epita.fr>
2894
2895 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
2896 (symbol_list_prepend, get_type_name): Move to...
2897 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
2898 (symbol_list_prepend, symbol_list_n_type_name_get): here.
2899 Adjust all callers.
2900 (symbol_list_free): New.
2901 * src/scan-gram.l (handle_dollar): Takes a location.
2902 * tests/input.at (Invalid $n): Adjust.
2903
29042002-06-17 Akim Demaille <akim@epita.fr>
2905
2906 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2907 (symbol_list_prepend): New.
2908 * src/parse-gram.y (%union): `list' is a new member.
2909 (symbols.1): New, replaces...
2910 (terms_to_prec.1, nterms_to_type.1): these.
2911 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2912 Take a location as additional argument.
2913 Adjust all callers.
2914
29152002-06-15 Akim Demaille <akim@epita.fr>
2916
2917 * src/parse-gram.y: Move %token in the declaration section so that
2918 we don't depend upon CVS Bison.
2919
29202002-06-15 Akim Demaille <akim@epita.fr>
2921
2922 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2923 * src/print.c (print_core): Use it.
2924
29252002-06-15 Akim Demaille <akim@epita.fr>
2926
2927 * src/conflicts.c (log_resolution): Accept the rule involved in
2928 the sr conflicts instead of the lookahead number that points to
2929 that rule.
2930 (flush_reduce): Accept the current lookahead vector as argument,
2931 instead of the index in LA.
2932 (resolve_sr_conflict): Accept the current number of lookahead
2933 bitset to consider for the STATE, instead of the index in LA.
2934 (set_conflicts): Adjust.
2935 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2936
29372002-06-15 Akim Demaille <akim@epita.fr>
2938
2939 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2940 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2941 Adjust all dependencies.
2942 * src/lalr.c (initialize_lookaheads): Split into...
2943 (states_lookaheads_count, states_lookaheads_initialize): these.
2944 (lalr): Adjust.
2945
29462002-06-15 Akim Demaille <akim@epita.fr>
2947
2948 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2949 out of...
2950 (grammar_rules_print): here.
2951 * src/reduce.c (reduce_output): Use it.
2952 * tests/reduce.at (Useless Rules, Reduced Automaton)
2953 (Underivable Rules): Adjust.
2954
29552002-06-15 Akim Demaille <akim@epita.fr>
2956
2957 Copy BYacc's nice way to report the grammar.
2958
2959 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2960 New.
2961 Don't print the rules' location, it is confusing and useless.
2962 (rule_print): Use grammar_rhs_print.
2963 * src/print.c (print_grammar): Use grammar_rules_print.
2964
29652002-06-15 Akim Demaille <akim@epita.fr>
2966
2967 Complete and rationalize `useless thing' warnings.
2968
2969 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2970 (symbol_tag_print): New.
2971 Use them everywhere in place of accessing directly the tag member.
2972 * src/gram.h, src/gram.c (rule_print): New.
2973 Use it where a rule used to be printed `by hand'.
2974 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2975 (reduce_grammar_tables): Report the useless rules.
2976 (reduce_print): Useless things are a warning, not an error.
2977 Report it as such.
2978 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2979 (Reduced Automaton, Underivable Rules): Adjust.
2980 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2981 * tests/conflicts.at (Unresolved SR Conflicts)
2982 (Solved SR Conflicts): Adjust.
2983
29842002-06-15 Akim Demaille <akim@epita.fr>
2985
2986 Let symbols have a location.
2987
2988 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2989 (getsym): Adjust.
2990 Adjust all callers.
2991 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2992 Use location_t, not int.
2993 * src/symtab.c (symbol_check_defined): Take advantage of the
2994 location.
2995 * tests/regression.at (Invalid inputs): Adjust.
2996
29972002-06-15 Akim Demaille <akim@epita.fr>
2998
2999 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3000 (input): Don't try to initialize yylloc here, do it in the
3001 scanner.
3002 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3003 * src/gram.h (rule_t): Change line and action_line into location
3004 and action_location, of location_t type.
3005 Adjust all dependencies.
3006 * src/location.h, src/location.c (empty_location): New.
3007 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3008 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3009 (grammar_current_rule_symbol_append)
3010 (grammar_current_rule_action_append): Expect a location as argument.
3011 * src/reader.c (grammar_midrule_action): Adjust to attach an
3012 action's location as dummy symbol location.
3013 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3014 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3015 the line numbers.
3016
30172002-06-14 Akim Demaille <akim@epita.fr>
3018
3019 Grammar declarations may be found in the grammar section.
3020
3021 * src/parse-gram.y (rules_or_grammar_declaration): New.
3022 (declarations): Each declaration may end with a semicolon, not
3023 just...
3024 (grammar_declaration): `"%union"'.
3025 (grammar): Branch to rules_or_grammar_declaration.
3026
30272002-06-14 Akim Demaille <akim@epita.fr>
3028
3029 * src/main.c (main): Invoke scanner_free.
3030
30312002-06-14 Akim Demaille <akim@epita.fr>
3032
3033 * src/output.c (m4_invoke): Extracted from...
3034 (output_skeleton): here.
3035 Free tempfile.
3036
30372002-06-14 Akim Demaille <akim@epita.fr>
3038
3039 * src/parse-gram.y (directives, directive, gram)
3040 (grammar_directives, precedence_directives, precedence_directive):
3041 Rename as...
3042 (declarations, declaration, grammar, grammar_declaration)
3043 (precedence_declaration, precedence_declarator): these.
3044 (symbol_declaration): New.
3045
30462002-06-14 Akim Demaille <akim@epita.fr>
3047
3048 * src/files.c (action_obstack): Remove, unused.
3049 (output_obstack): Remove it, and all its dependencies, as it is no
3050 longer needed.
3051 * src/reader.c (epilogue_set): Build the epilogue in the
3052 muscle_obstack.
3053 * src/output.h, src/output.c (muscle_obstack): Move to...
3054 * src/muscle_tab.h, src/muscle_tab.h: here.
3055 (muscle_init): Initialize muscle_obstack.
3056 (muscle_free): New.
3057 * src/main.c (main): Call it.
3058
30592002-06-14 Akim Demaille <akim@epita.fr>
3060
3061 * src/location.h: New, extracted from...
3062 * src/reader.h: here.
3063 * src/Makefile.am (noinst_HEADERS): Merge into
3064 (bison_SOURCES): this.
3065 Add location.h.
3066 * src/parse-gram.y: Use location_t instead of Bison's.
3067 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3068 Use location_t instead of ints.
3069
30702002-06-14 Akim Demaille <akim@epita.fr>
3071
3072 * data/bison.simple, data/bison.c++: Be sure to restore the
3073 current #line when returning to the skeleton contents after having
3074 exposed the input file's #line.
3075
30762002-06-12 Akim Demaille <akim@epita.fr>
3077
3078 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3079 eager.
3080 * tests/actions.at (Exotic Dollars): New.
3081
30822002-06-12 Akim Demaille <akim@epita.fr>
3083
3084 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3085 ['"/] too eagerly.
3086 * tests/input.at (Torturing the Scanner): New.
3087
30882002-06-11 Akim Demaille <akim@epita.fr>
3089
3090 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3091 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3092 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3093 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3094 * src/reader.c (reader): Use it.
3095
30962002-06-11 Akim Demaille <akim@epita.fr>
3097
3098 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3099 Adjust all callers.
3100 (scanner_last_string_free): New.
3101
31022002-06-11 Akim Demaille <akim@epita.fr>
3103
3104 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3105 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3106 (last_string, YY_OBS_FREE): New.
3107 Use them when returning an ID.
3108
31092002-06-11 Akim Demaille <akim@epita.fr>
3110
3111 Have Bison grammars parsed by a Bison grammar.
3112
3113 * src/reader.c, src/reader.h (prologue_augment): New.
3114 * src/reader.c (copy_definition): Remove.
3115
3116 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3117 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3118 (grammar_current_rule_prec_set, grammar_current_rule_check)
3119 (grammar_current_rule_symbol_append)
3120 (grammar_current_rule_action_append): Export.
3121 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3122 (symbol_list_action_append): Remove.
3123 Hook the routines from reader.
3124 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3125 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3126
3127 * src/reader.c (read_declarations): Remove, unused.
3128
3129 * src/parse-gram.y: Handle the epilogue.
3130 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3131 (grammar_start_symbol_set): this.
3132 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3133 * src/reader.c (readgram): Remove, unused.
3134 (reader): Adjust to insert eoftoken and axiom where appropriate.
3135
3136 * src/reader.c (copy_dollar): Replace with...
3137 * src/scan-gram.h (handle_dollar): this.
3138 * src/parse-gram.y: Remove `%thong'.
3139
3140 * src/reader.c (copy_at): Replace with...
3141 * src/scan-gram.h (handle_at): this.
3142
3143 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3144 New.
3145
3146 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3147 time being.
3148
3149 * src/reader.h, src/reader.c (grammar_rule_end): New.
3150
3151 * src/parse.y (current_type, current_class): New.
3152 Implement `%nterm', `%token' support.
3153 Merge `%term' into `%token'.
3154 (string_as_id): New.
3155 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3156 type name.
3157
3158 * src/parse-gram.y: Be sure to handle properly the beginning of
3159 rules.
3160
3161 * src/parse-gram.y: Handle %type.
3162 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3163
3164 * src/parse-gram.y: More directives support.
3165 * src/options.c: No longer handle source directives.
3166
3167 * src/parse-gram.y: Fix %output.
3168
3169 * src/parse-gram.y: Handle %union.
3170 Use the prologue locations.
3171 * src/reader.c (parse_union_decl): Remove.
3172
3173 * src/reader.h, src/reader.c (epilogue_set): New.
3174 * src/parse-gram.y: Use it.
3175
3176 * data/bison.simple, data/bison.c++: b4_stype is now either not
3177 defined, then default to int, or to the contents of %union,
3178 without `union' itself.
3179 Adjust.
3180 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3181
3182 * src/output.c (actions_output): Don't output braces, as they are
3183 already handled by the scanner.
3184
3185 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3186 characters to themselves.
3187
3188 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3189 that the epilogue has a proper #line.
3190
3191 * src/parse-gram.y: Handle precedence/associativity.
3192
3193 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3194 a terminal.
3195 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3196 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3197 at all to define terminals that cannot be emitted.
3198
3199 * src/scan-gram.l: Escape M4 characters.
3200
3201 * src/scan-gram.l: Working properly with escapes in user
3202 strings/characters.
3203
3204 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3205 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3206 grammar.
3207 Use more modest sizes, as for the time being the parser does not
3208 release memory, and therefore the process swallows a huge amount
3209 of memory.
3210
3211 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3212 stricter %token grammar.
3213
3214 * src/symtab.h (associativity): Add `undef_assoc'.
3215 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3216 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3217
3218 * tests/regression.at (Invalid %directive): Remove, as it is now
3219 meaningless.
3220 (Invalid inputs): Adjust to the new error messages.
3221 (Token definitions): The new grammar doesn't allow too many
3222 eccentricities.
3223
3224 * src/lex.h, src/lex.c: Remove.
3225 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3226 (copy_character, copy_string2, copy_string, copy_identifier)
3227 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3228 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3229 (parse_action): Remove.
3230 * po/POTFILES.in: Adjust.
3231
32322002-06-11 Akim Demaille <akim@epita.fr>
3233
3234 * src/reader.c (parse_action): Don't store directly into the
3235 rule's action member: return the action as a string.
3236 Don't require `rule_length' as an argument: compute it.
3237 (grammar_current_rule_symbol_append)
3238 (grammar_current_rule_action_append): New, eved out from
3239 (readgram): here.
3240 Remove `action_flag', `rulelength', unused now.
3241
32422002-06-11 Akim Demaille <akim@epita.fr>
3243
3244 * src/reader.c (grammar_current_rule_prec_set).
3245 (grammar_current_rule_check): New, eved out from...
3246 (readgram): here.
3247 Remove `xaction', `first_rhs': useless.
3248 * tests/input.at (Type clashes): New.
3249 * tests/existing.at (GNU Cim Grammar): Adjust.
3250
32512002-06-11 Akim Demaille <akim@epita.fr>
3252
3253 * src/reader.c (grammar_midrule_action): New, Eved out from
3254 (readgram): here.
3255
32562002-06-11 Akim Demaille <akim@epita.fr>
3257
3258 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3259 New.
3260 (readgram): Use them as replacement of inlined code, crule and
3261 crule1.
3262
32632002-06-11 Akim Demaille <akim@epita.fr>
3264
3265 * src/reader.c (grammar_end, grammar_symbol_append): New.
3266 (readgram): Use them.
3267 Make the use of `p' as local as possible.
3268
32692002-06-10 Akim Demaille <akim@epita.fr>
3270
3271 GCJ's parser requires the tokens to be defined before the prologue.
3272
3273 * data/bison.simple: Output the token definition before the user's
3274 prologue.
3275 * tests/regression.at (Braces parsing, Duplicate string)
3276 (Mixing %token styles): Check the output from bison.
3277 (Early token definitions): New.
3278
32792002-06-10 Akim Demaille <akim@epita.fr>
3280
3281 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3282 assigning twice the same user number to a token, so that we can
3283 use it in...
3284 * src/lex.c (lex): here.
3285 Also use `symbol_class_set' instead of hand written code.
3286 * src/reader.c (parse_assoc_decl): Likewise.
3287
32882002-06-10 Akim Demaille <akim@epita.fr>
3289
3290 * src/symtab.c, src/symtab.c (symbol_class_set)
3291 (symbol_user_token_number_set): New.
3292 * src/reader.c (parse_token_decl): Use them.
3293 Use a switch instead of ifs.
3294 Use a single argument.
3295
32962002-06-10 Akim Demaille <akim@epita.fr>
3297
3298 Remove `%thong' support as it is undocumented, unused, duplicates
3299 `%token's job, and creates useless e-mail traffic with people who
3300 want to know what it is, why it is undocumented, unused, and
3301 duplicates `%token's job.
3302
3303 * src/reader.c (parse_thong_decl): Remove.
3304 * src/options.c (option_table): Remove "thong".
3305 * src/lex.h (tok_thong): Remove.
3306
33072002-06-10 Akim Demaille <akim@epita.fr>
3308
3309 * src/symtab.c, src/symtab.c (symbol_type_set)
3310 (symbol_precedence_set): New.
3311 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3312 (value_components_used): Remove, unused.
3313
33142002-06-09 Akim Demaille <akim@epita.fr>
3315
3316 Move symbols handling code out of the reader.
3317
3318 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3319 (axiom): Move to...
3320 * src/symtab.h, src/symtab.c: here.
3321
3322 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3323 * src/reader.c (startval): Rename as...
3324 * src/symtab.h, src/symtab.c (startsymbol): this.
3325 * src/reader.c: Adjust.
3326
3327 * src/reader.c (symbol_check_defined, symbol_make_alias)
3328 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3329 (token_translations_init)
3330 Move to...
3331 * src/symtab.c: here.
3332 * src/reader.c (packsymbols): Move to...
3333 * src/symtab.h, src/symtab.c (symbols_pack): here.
3334 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3335 argument.
3336
33372002-06-03 Akim Demaille <akim@epita.fr>
3338
3339 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3340 then statements.
3341
33422002-06-03 Akim Demaille <akim@epita.fr>
3343
3344 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3345 structs with non literals.
3346 * src/scan-skel.l: never-interactive.
3347 * src/conflicts.c (enum conflict_resolution_e): No trailing
3348 comma.
3349 * src/getargs.c (usage): Split long literal strings.
3350 Reported by Hans Aberg.
3351
33522002-05-28 Akim Demaille <akim@epita.fr>
3353
3354 * data/bison.c++: Use C++ ostreams.
3355 (cdebug_): New member.
3356
33572002-05-28 Akim Demaille <akim@epita.fr>
3358
3359 * src/output.c (output_skeleton): Be sure to allocate enough room
3360 for `/' _and_ for `\0' in full_skeleton.
3361
33622002-05-28 Akim Demaille <akim@epita.fr>
3363
3364 * data/bison.c++: Catch up with bison.simple:
3365 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3366 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3367 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3368 and popping traces.
3369
33702002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3371
3372 * src/output.c (output_skeleton): Put an explicit path in front of
3373 the skeleton file name, rather than relying on the -I directory,
3374 to partially alleviate effects of having a skeleton file lying around
3375 in the current directory.
3376
33772002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3378
3379 * src/conflicts.c (log_resolution): Correct typo:
3380 obstack_printf should be obstack_fgrow1.
3381
33822002-05-26 Akim Demaille <akim@epita.fr>
3383
3384 * src/state.h (state_t): `solved_conflicts' is a new member.
3385 * src/LR0.c (new_state): Set it to 0.
3386 * src/conflicts.h, src/conflicts.c (print_conflicts)
3387 (free_conflicts, solve_conflicts): Rename as...
3388 (conflicts_print, conflicts_free, conflicts_solve): these.
3389 Adjust callers.
3390 * src/conflicts.c (enum conflict_resolution_e)
3391 (solved_conflicts_obstack): New, used by...
3392 (log_resolution): this.
3393 Adjust to attach the conflict resolution to each state.
3394 Complete the description with the precedence/associativity
3395 information.
3396 (resolve_sr_conflict): Adjust.
3397 * src/print.c (print_state): Output its solved_conflicts.
3398 * tests/conflicts.at (Unresolved SR Conflicts)
3399 (Solved SR Conflicts): Exercise --report=all.
3400
34012002-05-26 Akim Demaille <akim@epita.fr>
3402
3403 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3404 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3405 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3406 (token_number_t, item_number_as_token_number)
3407 (token_number_as_item_number, muscle_insert_token_number_table):
3408 Rename as...
3409 (symbol_number_t, item_number_as_symbol_number)
3410 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3411 these, since it is more appropriate.
3412
34132002-05-26 Akim Demaille <akim@epita.fr>
3414
3415 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3416 `Error:' lines.
3417 * data/bison.simple (yystos) [YYDEBUG]: New.
3418 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3419 error recovery.
3420 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3421
34222002-05-25 Akim Demaille <akim@epita.fr>
3423
3424 * doc/bison.texinfo (Debugging): Split into...
3425 (Tracing): this new section, its former contents, and...
3426 (Understanding): this new section.
3427 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3428 by...
3429 (report_flag): this.
3430 Adjust all dependencies.
3431 (report_args, report_types, report_argmatch): New.
3432 (usage, getargs): Report/support -r, --report.
3433 * src/options.h
3434 (struct option_table_struct): Rename as..,
3435 (struct option_table_s): this.
3436 Rename the `set_flag' member to `flag' to match with getopt_long's
3437 struct.
3438 * src/options.c (option_table): Split verbose into an entry for
3439 %verbose, and another for --verbose.
3440 Support --report/-r, so remove -r from the obsolete --raw.
3441 * src/print.c: Attach full item sets and lookaheads reports to
3442 report_flag instead of trace_flag.
3443 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3444
34452002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3446 and Paul Eggert <eggert@twinsun.com>
3447
3448 * data/bison.simple (yyparse): Correct error handling to conform to
3449 POSIX and yacc. Specifically, after syntax error is discovered,
3450 do not reduce further before shifting the error token.
3451 Clean up the code a bit by removing the labels yyerrdefault,
3452 yyerrhandle, yyerrpop.
3453 * NEWS: Document the above.
3454
34552002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3456
3457 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3458 type; it isn't always big enough, since it doesn't necessarily
3459 include non-terminals.
3460 (yytranslate): Expand definition of yy_token_number_type, so that
3461 the latter can be removed.
3462 (yy_token_number_type): Remove, only one use.
3463 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3464 don't use TokenNumberType as element type.
3465
3466 * tests/regression.at: Modify expected output to agree with change
3467 to yyr1 and yytranslate.
3468
34692002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3470
3471 * src/reader.c (parse_action): Use copy_character instead of
3472 obstack_1grow.
3473
34742002-05-13 Akim Demaille <akim@epita.fr>
3475
3476 * tests/regression.at (Token definitions): Prototype yylex and
3477 yyerror.
3478
34792002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3480
3481 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
3482 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3483 32-bit arithmetic.
3484 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3485
34862002-05-07 Akim Demaille <akim@epita.fr>
3487
3488 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3489 avoid GCC warnings.
3490
34912002-05-07 Akim Demaille <akim@epita.fr>
3492
3493 Kill GCC warnings.
3494
3495 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3496 over the RHS of each rule.
3497 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3498 * src/state.h (state_t): Member `nitems' is unsigned short.
3499 * src/LR0.c (get_state): Adjust.
3500 * src/reader.c (packgram): Likewise.
3501 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3502 `Type'.
3503 (muscle_insert_int_table): Remove, unused.
3504 (prepare_rules): Remove `max'.
3505
35062002-05-06 Akim Demaille <akim@epita.fr>
3507
3508 * src/closure.c (print_firsts): Display of the symbol tags.
3509 (bitmatrix_print): Move to...
3510 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
3511 here.
3512 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
3513
35142002-05-06 Akim Demaille <akim@epita.fr>
3515
3516 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
3517 hash_do_for_each.
3518
35192002-05-06 Akim Demaille <akim@epita.fr>
3520
3521 * src/LR0.c (new_state, get_state): Instead of using the global
3522 `kernel_size' and `kernel_base', have two new arguments:
3523 `core_size' and `core'.
3524 Adjust callers.
3525
35262002-05-06 Akim Demaille <akim@epita.fr>
3527
3528 * src/reader.c (packgram): No longer end `ritem' with a 0
3529 sentinel: it is not used.
3530
35312002-05-05 Akim Demaille <akim@epita.fr>
3532
3533 New experimental feature: display the lookaheads in the report and
3534 graph.
3535
3536 * src/print (print_core): When --trace-flag, display the rules
3537 lookaheads.
3538 * src/print_graph.c (print_core): Likewise.
3539 Swap the arguments.
3540 Adjust caller.
3541
35422002-05-05 Akim Demaille <akim@epita.fr>
3543
3544 * tests/torture.at (Many lookaheads): New test.
3545
35462002-05-05 Akim Demaille <akim@epita.fr>
3547
3548 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
3549 (GENERATE_MUSCLE_INSERT_TABLE): this.
3550 (output_int_table, output_unsigned_int_table, output_short_table)
3551 (output_token_number_table, output_item_number_table): Replace with...
3552 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
3553 (muscle_insert_short_table, muscle_insert_token_number_table)
3554 (muscle_insert_item_number_table): these.
3555 Adjust all callers.
3556 (prepare_tokens): Don't free `translations', since...
3557 * src/reader.h, src/reader.c (grammar_free): do it.
3558 Move to...
3559 * src/gram.h, src/gram.c (grammar_free): here.
3560 * data/bison.simple, data/bison.c++: b4_token_number_max is now
3561 b4_translate_max.
3562
35632002-05-05 Akim Demaille <akim@epita.fr>
3564
3565 * src/output.c (output_unsigned_int_table): New.
3566 (prepare_rules): `i' is unsigned.
3567 `prhs', `rline', `r2' are unsigned int.
3568 Rename muscle `rhs_number_max' as `rhs_max'.
3569 Output muscles `prhs_max', `rline_max', and `r2_max'.
3570 Free rline and r1.
3571 * data/bison.simple, data/bison.c++: Adjust to use these muscles
3572 to compute types instead of constant types.
3573 * tests/regression.at (Web2c Actions): Adjust.
3574
35752002-05-04 Akim Demaille <akim@epita.fr>
3576
3577 * src/symtab.h (SALIAS, SUNDEF): Rename as...
3578 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
3579 Adjust dependencies.
3580 * src/output.c (token_definitions_output): Be sure not to output a
3581 `#define 'a'' when fed with `%token 'a' "a"'.
3582 * tests/regression.at (Token definitions): New.
3583
35842002-05-03 Paul Eggert <eggert@twinsun.com>
3585
3586 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
3587 for K&R C.
3588
35892002-05-03 gettextize <bug-gnu-gettext@gnu.org>
3590
3591 * Makefile.am (SUBDIRS): Remove intl.
3592 (EXTRA_DIST): Add config/config.rpath.
3593
35942002-05-03 Akim Demaille <akim@epita.fr>
3595
3596 * data/bison.simple (m4_if): Don't output empty enums.
3597 And actually, output valid enum definitions :(.
3598
35992002-05-03 Akim Demaille <akim@epita.fr>
3600
3601 * configure.bat: Remove, completely obsolete.
3602 * Makefile.am (EXTRA_DIST): Adjust.
3603 Don't distribute config.rpath...
3604 * config/Makefile.am (EXTRA_DIST): Do it.
3605
36062002-05-03 Akim Demaille <akim@epita.fr>
3607
3608 * configure.in (GETTEXT_VERSION): New.
3609 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
3610
36112002-05-03 Akim Demaille <akim@epita.fr>
3612
3613 * data/bison.simple (b4_token_enum): New.
3614 (b4_token_defines): Use it to output tokens both as #define and
3615 enums.
3616 Suggested by Paul Eggert.
3617 * src/output.c (token_definitions_output): Don't output spurious
3618 white spaces.
3619
36202002-05-03 Akim Demaille <akim@epita.fr>
3621
3622 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3623
36242002-05-02 Robert Anisko <robert@lrde.epita.fr>
3625
3626 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
3627 Update the stack class, give a try to deque as the default container.
3628
36292002-05-02 Akim Demaille <akim@epita.fr>
3630
3631 * data/bison.simple (yyparse): Do not implement @$ = @1.
3632 (YYLLOC_DEFAULT): Adjust to do it.
3633 * doc/bison.texinfo (Location Default Action): Fix.
3634
36352002-05-02 Akim Demaille <akim@epita.fr>
3636
3637 * src/reader.c (parse_braces): Merge into...
3638 (parse_action): this.
3639
36402002-05-02 Akim Demaille <akim@epita.fr>
3641
3642 * configure.in (ALL_LINGUAS): Remove.
3643 * po/LINGUAS, hr.po: New.
3644
36452002-05-02 Akim Demaille <akim@epita.fr>
3646
3647 Remove the so called hairy (semantic) parsers.
3648
3649 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
3650 * src/gram.h, src/gram.c (semantic_parser): Remove.
3651 (rule_t): Remove the guard and guard_line members.
3652 * src/lex.h (token_t): remove tok_guard.
3653 * src/options.c (option_table): Remove %guard and %semantic_parser
3654 support.
3655 * src/output.c, src/output.h (guards_output): Remove.
3656 (prepare): Adjust.
3657 (token_definitions_output): Don't output the `T'
3658 tokens (???).
3659 (output_skeleton): Don't output the guards.
3660 * src/files.c, src/files.c (attrsfile): Remove.
3661 * src/reader.c (symbol_list): Remove the guard and guard_line
3662 members.
3663 Adjust dependencies.
3664 (parse_guard): Remove.
3665 * data/bison.hairy: Remove.
3666 * doc/bison.texinfo (Environment Variables): Remove occurrences of
3667 BISON_HAIRY.
3668
36692002-05-02 Akim Demaille <akim@epita.fr>
3670
3671 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
3672 (parse_guard): Rename the formal argument `stack_offset' as
3673 `rule_length', which is more readable.
3674 Adjust callers.
3675 (copy_at, copy_dollar): Instead of outputting the hard coded
3676 values of $$, $n and so forth, output invocation to b4_lhs_value,
3677 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
3678 Note: this patch partially drops `semantic-parser' support: it
3679 always does `rule_length - n', where semantic parsers ought to
3680 always use `-n'.
3681 * data/bison.simple, data/bison.c++ (b4_lhs_value)
3682 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
3683
36842002-05-02 Akim Demaille <akim@epita.fr>
3685
3686 * configure.in (AC_INIT): Bump to 1.49b.
3687 (AM_INIT_AUTOMAKE): Short invocation.
3688
36892002-05-02 Akim Demaille <akim@epita.fr>
3690
3691 Version 1.49a.
3692
36932002-05-01 Akim Demaille <akim@epita.fr>
3694
3695 * src/skeleton.h: Remove.
3696
36972002-05-01 Akim Demaille <akim@epita.fr>
3698
3699 * src/skeleton.h: Fix the #endif.
3700 Reported by Magnus Fromreide.
3701
37022002-04-26 Paul Eggert <eggert@twinsun.com>
3703
3704 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
3705 Define if we define YYSTYPE and YYLTYPE, respectively.
3706 (YYCOPY): Fix [] quoting problem in the non-GCC case.
3707
37082002-04-25 Robert Anisko <robert@lrde.epita.fr>
3709
3710 * src/scan-skel.l: Postprocess quadrigraphs.
3711
3712 * src/reader.c (copy_character): New function, used to output
3713 single characters while replacing `[' and `]' with quadrigraphs, to
3714 avoid troubles with M4 quotes.
3715 (copy_comment): Output characters with copy_character.
3716 (read_additionnal_code): Likewise.
3717 (copy_string2): Likewise.
3718 (copy_definition): Likewise.
3719
3720 * tests/calc.at: Exercise M4 quoting.
3721
37222002-04-25 Akim Demaille <akim@epita.fr>
3723
3724 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
3725 between `!' and the command.
3726 Reported by Paul Eggert.
3727
37282002-04-24 Robert Anisko <robert@lrde.epita.fr>
3729
3730 * tests/calc.at: Exercise prologue splitting.
3731
3732 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
3733 `b4_post_prologue' instead of `b4_prologue'.
3734
3735 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
3736 muscles.
3737 (output): Free pre_prologue_obstack and post_prologue_obstack.
3738 * src/files.h, src/files.c (attrs_obstack): Remove.
3739 (pre_prologue_obstack, post_prologue_obstack): New.
3740 * src/reader.c (copy_definition): Add a parameter to specify the
3741 obstack to fill, instead of using attrs_obstack unconditionally.
3742 (read_declarations): Pass pre_prologue_obstack to copy_definition if
3743 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
3744
37452002-04-23 Paul Eggert <eggert@twinsun.com>
3746
3747 * data/bison.simple: Remove unnecessary commentary and white
3748 space differences from 1_29-branch.
3749 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
3750
3751 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
3752 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
3753 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
3754 constructors or destructors.
3755
3756 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
3757
37582002-04-23 Akim Demaille <akim@epita.fr>
3759
3760 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
3761 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
3762 location with columns.
3763 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
3764 All reported by Paul Eggert.
3765
37662002-04-22 Akim Demaille <akim@epita.fr>
3767
3768 * src/reduce.c (dump_grammar): Move to...
3769 * src/gram.h, src/gram.c (grammar_dump): here.
3770 Be sure to separate long item numbers.
3771 Don't read the members of a rule's prec if its nil.
3772
37732002-04-22 Akim Demaille <akim@epita.fr>
3774
3775 * src/output.c (table_size, table_grow): New.
3776 (MAXTABLE): Remove, replace uses with table_size.
3777 (pack_vector): Instead of dying when the table is too big, grow it.
3778
37792002-04-22 Akim Demaille <akim@epita.fr>
3780
3781 * data/bison.simple (yyr1): Its type is that of a token number.
3782 * data/bison.c++ (r1_): Likewise.
3783 * tests/regression.at (Web2c Actions): Adjust.
3784
37852002-04-22 Akim Demaille <akim@epita.fr>
3786
3787 * src/reader.c (token_translations_init): 256 is now the default
3788 value for the error token, i.e., it will be assigned another
3789 number if the user assigned 256 to one of her tokens.
3790 (reader): Don't force 256 to error.
3791 * doc/bison.texinfo (Symbols): Adjust.
3792 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
3793 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
3794 etc. instead of 10, 20, 30 (which was used to `jump' over error
3795 (256) and undefined (2)).
3796
37972002-04-22 Akim Demaille <akim@epita.fr>
3798
3799 Propagate more token_number_t.
3800
3801 * src/gram.h (token_number_as_item_number)
3802 (item_number_as_token_number): New.
3803 * src/output.c (GENERATE_OUTPUT_TABLE): New.
3804 Use it to create output_item_number_table and
3805 output_token_number_table.
3806 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3807 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
3808 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
3809 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
3810
38112002-04-22 Akim Demaille <akim@epita.fr>
3812
3813 * src/output.h, src/output.c (get_lines_number): Remove.
3814
38152002-04-19 Akim Demaille <akim@epita.fr>
3816
3817 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
3818 as Lex/Flex'.
3819 (Debugging): More details about enabling the debugging features.
3820 (Table of Symbols): Describe $$, $n, @$, and @n.
3821 Suggested by Tim Josling.
3822
38232002-04-19 Akim Demaille <akim@epita.fr>
3824
3825 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
3826
38272002-04-10 Akim Demaille <akim@epita.fr>
3828
3829 * src/system.h: Rely on HAVE_LIMITS_H.
3830 Suggested by Paul Eggert.
3831
38322002-04-09 Akim Demaille <akim@epita.fr>
3833
3834 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
3835 full stderr, and strip it according to the bison options, instead
3836 of composing the error message from different bits.
3837 This makes it easier to check for several error messages.
3838 Adjust all the invocations.
3839 Add an invocation exercising the error token.
3840 Add an invocation demonstrating a stupid error message.
3841 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
3842 Adjust the tests.
3843 Error message are for stderr, not stdout.
3844
38452002-04-09 Akim Demaille <akim@epita.fr>
3846
3847 * src/gram.h, src/gram.c (error_token_number): Remove, use
3848 errtoken->number.
3849 * src/reader.c (reader): Don't specify the user token number (2)
3850 for $undefined, as it uselessly prevents using it.
3851 * src/gram.h (token_number_t): Move to...
3852 * src/symtab.h: here.
3853 (state_t.number): Is a token_number_t.
3854 * src/print.c, src/reader.c: Use undeftoken->number instead of
3855 hard coded 2.
3856 (Even though this 2 is not the same as above: the number of the
3857 undeftoken remains being 2, it is its user token number which
3858 might not be 2).
3859 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
3860 `user_token_number_max'.
3861 Output `undef_token_number'.
3862 * data/bison.simple, data/bison.c++: Use them.
3863 Be sure to map invalid yylex return values to
3864 `undef_token_number'. This saves us from gratuitous SEGV.
3865
3866 * tests/conflicts.at (Solved SR Conflicts)
3867 (Unresolved SR Conflicts): Adjust.
3868 * tests/regression.at (Web2c Actions): Adjust.
3869
38702002-04-08 Akim Demaille <akim@epita.fr>
3871
3872 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
3873 Adding #line.
3874 Remove the duplicate `typedefs'.
3875 (RhsNumberType): Fix the declaration and various other typos.
3876 Use __ofile__.
3877 * data/bison.simple: Use __ofile__.
3878 * src/scan-skel.l: Handle __ofile__.
3879
38802002-04-08 Akim Demaille <akim@epita.fr>
3881
3882 * src/gram.h (item_number_t): New, the type of item numbers in
3883 RITEM. Note that it must be able to code symbol numbers as
3884 positive number, and the negation of rule numbers as negative
3885 numbers.
3886 Adjust all dependencies (pretty many).
3887 * src/reduce.c (rule): Remove this `short *' pointer: use
3888 item_number_t.
3889 * src/system.h (MINSHORT, MAXSHORT): Remove.
3890 Include `limits.h'.
3891 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
3892 (shortcpy): Remove.
3893 (MAXTABLE): Move to...
3894 * src/output.c (MAXTABLE): here.
3895 (prepare_rules): Use output_int_table to output rhs.
3896 * data/bison.simple, data/bison.c++: Adjust.
3897 * tests/torture.at (Big triangle): Move the limit from 254 to
3898 500.
3899 * tests/regression.at (Web2c Actions): Ajust.
3900
3901 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
3902 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3903 passes, but produces negative #line number, once fixed, GCC is
3904 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3905 C), it passes.
3906 * src/state.h (state_h): Code input lines on ints, not shorts.
3907
39082002-04-08 Akim Demaille <akim@epita.fr>
3909
3910 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3911 and then the grammar.
3912
39132002-04-08 Akim Demaille <akim@epita.fr>
3914
3915 * src/system.h: No longer using strndup.
3916
39172002-04-07 Akim Demaille <akim@epita.fr>
3918
3919 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3920 * src/output.c (output_table_data): Return the longest number.
3921 (prepare_tokens): Output `token_number_max').
3922 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3923 New.
3924 Use them to define yy_token_number_type/TokenNumberType.
3925 Use this type for yytranslate.
3926 * tests/torture.at (Big triangle): Push the limit from 124 to
3927 253.
3928 * tests/regression.at (Web2c Actions): Adjust.
3929
39302002-04-07 Akim Demaille <akim@epita.fr>
3931
3932 * tests/torture.at (Big triangle): New.
3933 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3934 * tests/existing.at: here.
3935
39362002-04-07 Akim Demaille <akim@epita.fr>
3937
3938 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3939 nritems.
3940 Adjust dependencies.
3941
39422002-04-07 Akim Demaille <akim@epita.fr>
3943
3944 * src/reader.c: Normalize increments to prefix form.
3945
39462002-04-07 Akim Demaille <akim@epita.fr>
3947
3948 * src/reader.c, symtab.c: Remove debugging code.
3949
39502002-04-07 Akim Demaille <akim@epita.fr>
3951
3952 Rename all the `bucket's as `symbol_t'.
3953
3954 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3955 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3956 * src/symtab.c, src/symtab.h (bucket): Rename as...
3957 (symbol_t): this.
3958 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3959 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3960 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3961 (buckets_new, buckets_free, buckets_do): Rename as...
3962 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3963 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3964 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3965 (symbols_new, symbols_free, symbols_do): these.
3966
39672002-04-07 Akim Demaille <akim@epita.fr>
3968
3969 Use lib/hash for the symbol table.
3970
3971 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3972 EOF.
3973 * src/lex.c (lex): Set the `number' member of new terminals.
3974 * src/reader.c (bucket_check_defined, bucket_make_alias)
3975 (bucket_check_alias_consistence, bucket_translation): New.
3976 (reader, grammar_free, readgram, token_translations_init)
3977 (packsymbols): Adjust.
3978 (reader): Number the predefined tokens.
3979 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3980 for predefined tokens.
3981 * src/symtab.h (bucket): Remove all the hash table related
3982 members.
3983 * src/symtab.c (symtab): Replace by...
3984 (bucket_table): this.
3985 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3986 (buckets_new, buckets_do): New.
3987
39882002-04-07 Akim Demaille <akim@epita.fr>
3989
3990 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3991 (start_symbol, max_user_token_number, semantic_parser)
3992 (error_token_number): Initialize.
3993 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3994 Initialize.
3995 (reader): Don't.
3996 (errtoken, eoftoken, undeftoken, axiom): Extern.
3997
39982002-04-07 Akim Demaille <akim@epita.fr>
3999
4000 * src/gram.h (rule_s): prec and precsym are now pointers
4001 to the bucket giving the priority/associativity.
4002 Member `associativity' removed: useless.
4003 * src/reduce.c, src/conflicts.c: Adjust.
4004
40052002-04-07 Akim Demaille <akim@epita.fr>
4006
4007 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4008 Properly escape the symbols' TAG when outputting them.
4009
40102002-04-07 Akim Demaille <akim@epita.fr>
4011
4012 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4013
40142002-04-07 Akim Demaille <akim@epita.fr>
4015
4016 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4017 (LArule): this, which is an array to rule_t*.
4018 * src/print.c, src/conflicts.c: Adjust.
4019
40202002-04-07 Akim Demaille <akim@epita.fr>
4021
4022 * src/gram.h (rule_t): Rename `number' as `user_number'.
4023 `number' is a new member.
4024 Adjust dependencies.
4025 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4026
40272002-04-07 Akim Demaille <akim@epita.fr>
4028
4029 As a result of the previous patch, it is no longer needed
4030 to reorder ritem itself.
4031
4032 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4033
40342002-04-07 Akim Demaille <akim@epita.fr>
4035
4036 Be sure never to walk through RITEMS, but use only data related to
4037 the rules themselves. RITEMS should be banished.
4038
4039 * src/output.c (output_token_translations): Rename as...
4040 (prepare_tokens): this.
4041 In addition to `translate', prepare the muscles `tname' and
4042 `toknum', which were handled by...
4043 (output_rule_data): this.
4044 Remove, and move the remainder of its outputs into...
4045 (prepare_rules): this new routines, which also merges content from
4046 (output_gram): this.
4047 (prepare_rules): Be sure never to walk through RITEMS.
4048 (output_stos): Rename as...
4049 (prepare_stos): this.
4050 (output): Always invoke prepare_states, after all, just don't use it
4051 in the output if you don't need it.
4052
40532002-04-07 Akim Demaille <akim@epita.fr>
4054
4055 * src/LR0.c (new_state): Display `nstates' as the name of the
4056 newly created state.
4057 Adjust to initialize first_state and last_state if needed.
4058 Be sure to distinguish the initial from the final state.
4059 (new_states): Create the itemset of the initial state, and use
4060 new_state.
4061 * src/closure.c (closure): Now that the initial state has its
4062 items properly set, there is no need for a special case when
4063 creating `ruleset'.
4064
4065 As a result, now the rule 0, reducing to $axiom, is visible in the
4066 outputs. Adjust the test suite.
4067
4068 * tests/conflicts.at (Solved SR Conflicts)
4069 (Unresolved SR Conflicts): Adjust.
4070 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4071 * tests/conflicts.at (S/R in initial): New.
4072
40732002-04-07 Akim Demaille <akim@epita.fr>
4074
4075 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4076 the RHS of the rules.
4077 * src/output.c (output_gram): Likewise.
4078
40792002-04-07 Akim Demaille <akim@epita.fr>
4080
4081 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4082 bucket.
4083 Adjust all dependencies.
4084 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4085 `number' of the buckets too.
4086 * src/gram.h: Include `symtab.h'.
4087 (associativity): Move to...
4088 * src/symtab.h: here.
4089 No longer include `gram.h'.
4090
40912002-04-07 Akim Demaille <akim@epita.fr>
4092
4093 * src/gram.h, src/gram.c (rules_rhs_length): New.
4094 (ritem_longest_rhs): Use it.
4095 * src/gram.h (rule_t): `number' is a new member.
4096 * src/reader.c (packgram): Set it.
4097 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4098 the end of `rules', and count them out of `nrules'.
4099 (reduce_output, dump_grammar): Adjust.
4100 * src/print.c (print_grammar): It is no longer needed to check for
4101 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4102 * tests/reduce.at (Reduced Automaton): New test.
4103
41042002-04-07 Akim Demaille <akim@epita.fr>
4105
4106 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4107 lacking `+ 1' to nrules, Bison reported as useless a token if it
4108 was used solely to set the precedence of the last rule...
4109
41102002-04-07 Akim Demaille <akim@epita.fr>
4111
4112 * data/bison.c++, data/bison.simple: Don't output the current file
4113 name in #line, to avoid useless diffs between two identical
4114 outputs under different names.
4115
41162002-04-07 Akim Demaille <akim@epita.fr>
4117
4118 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4119 Normalize loops to using `< nrules + 1', not `<= nrules'.
4120
41212002-04-07 Akim Demaille <akim@epita.fr>
4122
4123 * TODO: Update.
4124
41252002-04-07 Akim Demaille <akim@epita.fr>
4126
4127 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4128 bucket.value as bucket.number.
4129
41302002-04-07 Akim Demaille <akim@epita.fr>
4131
4132 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4133 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4134 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4135 RHS, instead of being an index in RITEMS.
4136
41372002-04-04 Paul Eggert <eggert@twinsun.com>
4138
4139 * doc/bison.texinfo: Update copyright date.
4140 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4141 (Symbols): Warn about running Bison in one character set,
4142 but compiling and/or running in an incompatible one.
4143 Warn about character code 256, too.
4144
41452002-04-03 Paul Eggert <eggert@twinsun.com>
4146
4147 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4148 YYERROR_VERBOSE is nonzero, not whether it is defined.
4149
4150 Merge changes from bison-1_29-branch.
4151
41522002-03-20 Paul Eggert <eggert@twinsun.com>
4153
4154 Merge fixes from Debian bison_1.34-1.diff.
4155
4156 * configure.in (AC_PREREQ): 2.53.
4157
41582002-03-20 Akim Demaille <akim@epita.fr>
4159
4160 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4161
41622002-03-19 Paul Eggert <eggert@twinsun.com>
4163
4164 * src/bison.simple (YYCOPY): New macro.
4165 (YYSTACK_RELOCATE): Use it.
4166 Remove Type arg; no longer needed. All callers changed.
4167 (yymemcpy): Remove; no longer needed.
4168
4169 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4170 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4171
41722002-03-19 Akim Demaille <akim@epita.fr>
4173
4174 Test and fix the #line outputs.
4175
4176 * tests/atlocal.at (GCC): New.
4177 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4178 (Prologue synch line, ,%union synch line, Postprologue synch line)
4179 (Action synch line, Epilogue synch line): New tests.
4180 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4181 * data/bison.simple, data/bison.c++: Use it.
4182
41832002-03-19 Akim Demaille <akim@epita.fr>
4184
4185 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4186 (Solved SR Conflicts, %expect not enough, %expect right)
4187 (%expect too much): Move to...
4188 * tests/conflicts.at: this new file.
4189
41902002-03-19 Akim Demaille <akim@epita.fr>
4191
4192 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4193 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4194 that we can move to enums for instance.
4195 * src/output.c (token_definitions_output): Output a list of
4196 `token-name, token-number' instead of the #define.
4197 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4198
41992002-03-14 Akim Demaille <akim@epita.fr>
4200
4201 Use Gettext 0.11.1.
4202
42032002-03-09 Robert Anisko <robert@lrde.epita.fr>
4204
4205 * data/bison.c++: Make the user able to add members to the generated
4206 parser by subclassing.
4207
42082002-03-05 Robert Anisko <robert@lrde.epita.fr>
4209
4210 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4211 a character.
4212 Reported by Nicolas Tisserand and Nicolas Burrus.
4213
42142002-03-04 Robert Anisko <robert@lrde.epita.fr>
4215
4216 * src/reader.c: Warn about lacking semi-colons, do not complain.
4217
42182002-03-04 Robert Anisko <robert@lrde.epita.fr>
4219
4220 * data/bison.c++: Remove a debug line.
4221
42222002-03-04 Robert Anisko <robert@lrde.epita.fr>
4223
4224 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4225 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4226 provide a default implementation.
4227
42282002-03-04 Akim Demaille <akim@epita.fr>
4229
4230 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4231 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4232 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4233 * tests/semantic.at (Parsing Guards): Similarly.
4234 * src/reader.at (readgram): Complain if the last rule is not ended
4235 with a semi-colon.
4236
42372002-03-04 Akim Demaille <akim@epita.fr>
4238
4239 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4240 * src/closure.c: here.
4241 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4242 RTC.
4243 * src/warshall.h, src/warshall.c: Remove.
4244 * tests/sets.at (Broken Closure): Adjust.
4245
42462002-03-04 Akim Demaille <akim@epita.fr>
4247
4248 * src/output.c (output_skeleton): tempdir is const.
4249 bytes_read is unused.
4250
42512002-03-04 Akim Demaille <akim@epita.fr>
4252
4253 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4254 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4255 Update.
4256 From Michael Hayes.
4257
42582002-03-04 Akim Demaille <akim@epita.fr>
4259
4260 * src/closure.c (closure): `r' is unused.
4261
42622002-03-04 Akim Demaille <akim@epita.fr>
4263
4264 * tests/sets.at (Broken Closure): Add the ending `;'.
4265 * src/reader.at (readgram): Complain if a rule is not ended with a
4266 semi-colon.
4267
42682002-03-04 Akim Demaille <akim@epita.fr>
4269
4270 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4271 (count_sr_conflicts): Use bitset_count.
4272 * src/reduce.c (inaccessable_symbols): Ditto.
4273 (bits_size): Remove.
4274 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4275
42762002-03-04 Akim Demaille <akim@epita.fr>
4277
4278 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4279 * src/reduce.c: Remove the `bitset_zero's following the
4280 `bitset_create's, as now it is performed by the latter.
4281
42822002-03-04 Akim Demaille <akim@epita.fr>
4283
4284 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4285 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4286 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4287 latest sources from Michael.
4288
42892002-03-04 Akim Demaille <akim@epita.fr>
4290
4291 * src/output.c (output): Don't free the grammar.
4292 * src/reader.c (grammar_free): New.
4293 * src/main.c (main): Call it and don't free symtab here.
4294
42952002-03-04 Akim Demaille <akim@epita.fr>
4296
4297 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4298 before returning.
4299 Reported by Benoit Perrot.
4300
43012002-03-04 Akim Demaille <akim@epita.fr>
4302
4303 Use bitset operations when possible, not loops over bits.
4304
4305 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4306 bitset_or.
4307 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4308 * src/reduce.c (useless_nonterminals): Formatting changes.
4309 * src/warshall.c (TC): Use bitset_or.
4310
43112002-03-04 Akim Demaille <akim@epita.fr>
4312
4313 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4314 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4315 Ditto.
4316
43172002-03-04 Akim Demaille <akim@epita.fr>
4318
4319 * src/lalr.c (F): Now a bitset*.
4320 Adjust all dependencies.
4321
43222002-03-04 Akim Demaille <akim@epita.fr>
4323
4324 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4325 Adjust all dependencies.
4326
43272002-03-04 Akim Demaille <akim@epita.fr>
4328
4329 * src/L0.c, src/LR0.h (nstates): Be size_t.
4330 Adjust comparisons (signed vs unsigned).
4331 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4332 bitset*.
4333 Adjust all dependencies.
4334
43352002-03-04 Akim Demaille <akim@epita.fr>
4336
4337 * src/closure.c (firsts): Now, also a bitset.
4338 Adjust all dependencies.
4339 (varsetsize): Remove, now unused.
4340 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4341
43422002-03-04 Akim Demaille <akim@epita.fr>
4343
4344 * src/print.c: Convert to use bitset.h, not hand coded iterations
4345 over ints.
4346
43472002-03-04 Akim Demaille <akim@epita.fr>
4348
4349 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4350
43512002-03-04 Akim Demaille <akim@epita.fr>
4352
4353 * src/closure.c (ruleset): Be a bitset.
4354 (rulesetsize): Remove.
4355
43562002-03-04 Akim Demaille <akim@epita.fr>
4357
4358 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4359 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4360 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4361 * src/closure.c (fderives): Be an array of bitsets.
4362
43632002-02-28 Robert Anisko <robert@lrde.epita.fr>
4364
4365 * data/bison.c++: Merge the two generated headers. Insert a copyright
4366 notice in each output file.
4367
43682002-02-28 Akim Demaille <akim@epita.fr>
4369
4370 * data/bison.c++: Copy the prologue of bison.simple to fetch
4371 useful M4 definitions, such as b4_header_guard.
4372
43732002-02-25 Akim Demaille <akim@epita.fr>
4374
4375 * src/getargs.c (version): Give the name of the authors, and use a
4376 translator friendly scheme for the bgr
4377 copyright notice.
4378
43792002-02-25 Akim Demaille <akim@epita.fr>
4380
4381 * src/output.c (header_output): Remove, now handled completely via
4382 M4.
4383
43842002-02-25 Akim Demaille <akim@epita.fr>
4385
4386 * m4/m4.m4: New, from CVS Autoconf.
4387 * configure.in: Invoke it.
4388 * src/output.c (output_skeleton): Use its result instead of the
4389 hard coded name.
4390
43912002-02-25 Akim Demaille <akim@epita.fr>
4392
4393 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4394 Fileutils 4.1.5.
4395 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4396 * src/output.c (output_skeleton): Use mkstemp to create a real
4397 temporary file.
4398 Move the filling of `skeleton' and its muscle to...
4399 (prepare): here.
4400 (output): Move the definition of the prologue muscle to...
4401 (prepare): here.
4402 * src/system.h (DEFAULT_TMPDIR): New.
4403
44042002-02-14 Paul Eggert <eggert@twinsun.com>
4405
4406 Remove the support for C++ namespace cleanliness; it was
4407 causing more problems than it was curing, since it didn't work
4408 properly on some nonstandard C++ compilers. This can wait
4409 for a proper C++ parser.
4410
4411 * NEWS: Document this.
4412 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4413 of C++, as it's treated like C now.
4414 * src/bison.simple (YYSTD): Remove.
4415 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4416 Treat C++ just like Standard C instead of trying to support
4417 namespace cleanliness.
4418
44192002-02-14 Akim Demaille <akim@epita.fr>
4420
4421 * tests/regression.at (else): Adjust to Andreas' change.
4422
44232002-02-14 Akim Demaille <akim@epita.fr>
4424
4425 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4426
44272002-02-13 Andreas Schwab <schwab@suse.de>
4428
4429 * src/output.c (output_rule_data): Don't output NULL, it might
4430 not be defined yet.
4431
44322002-02-11 Robert Anisko <robert@lrde.epita.fr>
4433
4434 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4435 (Copyright notice): Update.
4436
44372002-02-11 Akim Demaille <akim@epita.fr>
4438
4439 * tests/regression.at (%nonassoc and eof): Don't include
4440 nonportable headers.
4441
44422002-02-08 Robert Anisko <robert@lrde.epita.fr>
4443
4444 * data/bison.c++: Correct error recovery. Make the user able to
4445 initialize the starting location.
4446
44472002-02-07 Akim Demaille <akim@epita.fr>
4448
4449 * tests/input.at: New.
4450
44512002-02-07 Robert Anisko <robert@lrde.epita.fr>
4452
4453 * data/bison.c++: Replace some direct m4 expansions by constants. Be
4454 more consistent when naming methods and variables. Put preprocessor
4455 directives around tables only needed for debugging.
4456
44572002-02-07 Robert Anisko <robert@lrde.epita.fr>
4458
4459 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4460 C++ parsers.
4461 (yy::b4_name::parse): Use print_.
4462
44632002-02-07 Robert Anisko <robert@lrde.epita.fr>
4464
4465 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4466
44672002-02-07 Robert Anisko <robert@lrde.epita.fr>
4468
4469 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4470 C++ parsers.
4471 (yy::b4_name::parse): Build verbose error messages, and use error_.
4472
44732002-02-06 Robert Anisko <robert@lrde.epita.fr>
4474
4475 * data/bison.c++: Fix m4 quoting in comments.
4476
44772002-02-06 Robert Anisko <robert@lrde.epita.fr>
4478
4479 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4480 not expanded by m4.
4481
44822002-02-05 Akim Demaille <akim@epita.fr>
4483
4484 * data/bison.c++: Adjust to the M4 back end.
4485 More is certainly needed.
4486
44872002-02-05 Akim Demaille <akim@epita.fr>
4488
4489 Give a try to M4 as a back end.
4490
4491 * lib/readpipe.c: New, from wdiff.
4492 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4493 BISON_HAIRY.
4494 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4495 specific values. Now it is m4 that performs the lookup.
4496 * src/parse-skel.y: Remove.
4497 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4498 * src/output.c (actions_output, guards_output)
4499 (token_definitions_output): No longer keeps track of the output
4500 line number, hence remove the second argument.
4501 (guards_output): Check against the guard member of a rule, not the
4502 action member.
4503 Adjust callers.
4504 (output_skeleton): Don't look for the skeleton location, let m4 do
4505 that.
4506 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
4507 file will be used.
4508 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
4509 (prepare): Given that for the time being changesyntax is not
4510 usable in M4, rename the muscles using `-' to `_'.
4511 Define `defines_flag', `output_parser_name' and `output_header_name'.
4512 * src/output.h (actions_output, guards_output)
4513 (token_definitions_output): Adjust prototypes.
4514 * src/scan-skel.l: Instead of scanning the skeletons, it now
4515 processes the output of m4: `__oline__' and `#output'.
4516 * data/bison.simple: Adjust to be used by M4(sugar).
4517 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
4518 to date.
4519 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
4520 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
4521 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
4522 shamelessly stolen from CVS Autoconf.
4523
45242002-02-05 Akim Demaille <akim@epita.fr>
4525
4526 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
4527 * configure.in: Check for the declarations of free and malloc.
4528 * src/muscle_tab.c: Adjust.
4529
45302002-02-05 Akim Demaille <akim@epita.fr>
4531
4532 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
4533 which have no values.
4534
45352002-02-05 Akim Demaille <akim@epita.fr>
4536
4537 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
4538 * data/: here.
4539
45402002-01-29 Paul Eggert <eggert@twinsun.com>
4541
4542 * src/bison.simple (YYSIZE_T): Do not define merely because
4543 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
4544 On some platforms, <alloca.h> does not declare YYSTD (size_t).
4545
45462002-01-27 Akim Demaille <akim@epita.fr>
4547
4548 Fix `%nonassoc and eof'.
4549
4550 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
4551 which were not properly copied! Replace
4552 memcpy (res->errs, src->errs, src->nerrs);
4553 with
4554 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
4555 !!!
4556 * tests/regression.at (%nonassoc and eof): Adjust to newest
4557 Autotest: `.' is not in the PATH.
4558
45592002-01-27 Akim Demaille <akim@epita.fr>
4560
4561 * tests/sets.at (AT_EXTRACT_SETS): New.
4562 (Nullable): Use it.
4563 (Firsts): New.
4564
45652002-01-26 Akim Demaille <akim@epita.fr>
4566
4567 * tests/actions.at, tests/calc.at, tests/headers.at,
4568 * tests/torture.at: Adjust to the newest Autotest which no longer
4569 forces `.' in the PATH.
4570
45712002-01-25 Akim Demaille <akim@epita.fr>
4572
4573 * tests/regression.at (%nonassoc and eof): New.
4574 Suggested by Robert Anisko.
4575
45762002-01-24 Akim Demaille <akim@epita.fr>
4577
4578 Bison dumps core when trying to complain about broken input files.
4579 Reported by Cris van Pelt.
4580
4581 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
4582 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
4583 into...
4584 (Invalid inputs): Strengthen: exercise parse_percent_token.
4585
45862002-01-24 Robert Anisko <robert.anisko@epita.fr>
4587
4588 * src/Makefile.am: Add bison.c++.
4589 * src/bison.c++: New skeleton.
4590
45912002-01-21 Paolo Bonzini <bonzini@gnu.org>
4592
4593 * po/it.po: New.
4594
45952002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
4596
4597 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
4598
45992002-01-20 Marc Autret <marc@gnu.org>
4600
4601 * src/files.c (compute_output_file_names): Fix
4602
46032002-01-20 Marc Autret <marc@gnu.org>
4604
4605 * tests/output.at: New test.
4606 * src/files.c (compute_base_names): Don't map extensions when
4607 the YACC flag is set, use defaults.
4608 Reported by Evgeny Stambulchik.
4609
46102002-01-20 Marc Autret <marc@gnu.org>
4611
4612 * src/system.h: Need to define __attribute__ away for non-GCC
4613 compilers as well (i.e. the vendor C compiler).
4614 Suggested by Albert Chin-A-Young.
4615
46162002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
4617
4618 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
4619 canonical definition.
4620 * src/system.h: Use the canonical definition for PARAMS (avoids
4621 a conflict with the macro from lib/hash.h).
4622
46232002-01-11 Akim Demaille <akim@epita.fr>
4624
4625 * configure.in: Use AC_FUNC_STRNLEN.
4626 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
4627
46282002-01-09 Akim Demaille <akim@epita.fr>
4629
4630 * src/files.c, src/files.h (output_infix): New.
4631 (tab_extension): Remove.
4632 (compute_base_names): Compute the former, drop the latter.
4633 * src/output.c (prepare): Insert the muscles `output-infix', and
4634 `output-suffix'.
4635 * src/parse-skel.y (string, string.1): New.
4636 (section.header): Use it.
4637 (section.yacc): Remove.
4638 (prefix): Remove too.
4639 * src/scan-skel.l: Adjust.
4640 * src/bison.simple, src/bison.hairy: Adjust.
4641
46422002-01-09 Akim Demaille <akim@epita.fr>
4643
4644 * configure.in (WERROR_CFLAGS): Compute it.
4645 * src/Makefile.am (CFLAGS): Pass it.
4646 * tests/atlocal.in (CFLAGS): Idem.
4647 * src/files.c: Fix a few warnings.
4648 (get_extension_index): Remove, unused.
4649
46502002-01-08 Akim Demaille <akim@epita.fr>
4651
4652 * src/getargs.c (AS_FILE_NAME): New.
4653 (getargs): Use it to convert DOSish file names.
4654 * src/files.c (base_name): Rename as full_base_name to avoid
4655 clashes with `base_name ()'.
4656 (filename_split): New.
4657 (compute_base_names): N-th rewrite, using filename_split.
4658
46592002-01-08 Akim Demaille <akim@epita.fr>
4660
4661 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
4662 New, stolen from the Fileutils 4.1.
4663 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
4664 * configure.in: Check for the presence of memrchr, and of its
4665 prototype.
4666
46672002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
4668
4669 * lib/hash.h (__P): Added definition for this macro.
4670 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
4671 BUILT_SOURCES, to ensure they are generated first.
4672 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
4673 %error-verbose to allow bootstrapping with bison 1.30x.
4674
46752002-01-06 Akim Demaille <akim@epita.fr>
4676
4677 * src/reader.c (parse_braces): Don't fetch the next char, the
4678 convention is to fetch on entry.
4679 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
4680 'switch' without a following semicolon.
4681 * tests/regression.at (braces parsing): New.
4682
46832002-01-06 Akim Demaille <akim@epita.fr>
4684
4685 Bison is dead wrong in its RR conflict reports.
4686
4687 * tests/torture.at (GNU Cim Grammar): New.
4688 * src/conflicts.c (count_rr_conflicts): Fix.
4689
46902002-01-06 Akim Demaille <akim@epita.fr>
4691
4692 Creating package.m4 from configure.ac causes too many problems.
4693
4694 * tests/Makefile.am (package.m4): Create it by hand,
4695 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
4696
46972002-01-06 Akim Demaille <akim@epita.fr>
4698
4699 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
4700 skeleton.h.
4701
47022002-01-04 Paul Eggert <eggert@twinsun.com>
4703
4704 * doc/bison.texinfo (Debugging):
4705 Remove YYSTDERR; it's no longer defined or used.
4706 Also, s/cstdio.h/cstdio/.
4707
47082002-01-03 Akim Demaille <akim@epita.fr>
4709
4710 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
4711
47122002-01-03 Akim Demaille <akim@epita.fr>
4713
4714 * src/parse-skel.y (process_skeleton): Don't bind the parser's
4715 tracing code to --trace, wait for a better --trace option, with
4716 args.
4717
47182002-01-03 Akim Demaille <akim@epita.fr>
4719
4720 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
4721 The ISO C++ standard is extremely clear about it: stderr is
4722 considered a macro, not a regular symbol (see table 94 `Header
4723 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
4724 Therefore std:: does not apply to it. It still does with fprintf.
4725 Also, s/cstdio.h/cstdio/.
4726
47272002-01-03 Akim Demaille <akim@epita.fr>
4728
4729 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
4730 for non system headers.
4731
47322002-01-02 Akim Demaille <akim@epita.fr>
4733
4734 Equip the skeleton chain with location tracking, runtime trace,
4735 pure parser and scanner.
4736
4737 * src/parse-skel.y: Request a pure parser, locations, and prefix
4738 renaming.
4739 (%union): Having several members with the same type does not help
4740 type mismatches, simplify.
4741 (YYPRINT, yyprint): New.
4742 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
4743 (skel_error): this.
4744 Handle locations.
4745 * src/scan-skel.l: Adjust to these changes.
4746 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
4747 (LOCATION_PRINT, skel_control_t): New.
4748
47492001-12-30 Akim Demaille <akim@epita.fr>
4750
4751 * src/parse-skel.y: Get rid of the shift/reduce conflict:
4752 replace `gb' with BLANKS.
4753 * src/scan-skel.l: Adjust.
4754
47552001-12-30 Akim Demaille <akim@epita.fr>
4756
4757 * src/system.h: We don't need nor want bcopy.
4758 Throw away MS-DOS crap: we don't need getpid.
4759 * configure.in: We don't need strndup. It was even causing
4760 problems: because Flex includes the headers *before* us,
4761 _GNU_SOURCE is not defined by config.h, and therefore strndup was
4762 not visible.
4763 * lib/xstrndup.c: New.
4764 * src/scan-skel.l: Use it.
4765 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
4766 * src/parse-skel.y: Use %directives instead of #defines.
4767
47682001-12-30 Akim Demaille <akim@epita.fr>
4769
4770 * src/skeleton.h: New.
4771 * src/output.c (output_parser, output_master_parser): Remove, dead
4772 code.
4773 * src/output.h (get_lines_number, actions_output, guards_output)
4774 (token_definitions_output): Prototype them.
4775 * src/parse-skel.y: Add the license notice.
4776 Include output.h and skeleton.h.
4777 (process_skeleton): Returns void, and takes a single parameter.
4778 * src/scan-skel.l: Add the license notice.
4779 Include skeleton.h.
4780 Don't use %option yylineno: it seems that then Flex imagines
4781 REJECT has been used, and therefore it won't reallocate its
4782 buffers (which makes no other sense to me than a bug). It results
4783 in warnings for `unused: yy_flex_realloc'.
4784
47852001-12-30 Robert Anisko <robert.anisko@epita.fr>
4786
4787 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4788 (MUSCLE_INSERT_PREFIX): ...to there.
4789 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4790 (MUSCLE_INSERT_PREFIX): Move from here...
4791
4792 * src/bison.hairy: Add a section directive. Put braces around muscle
4793 names. This parser skeleton is still broken, but Bison should not
4794 choke on a bad muscle 'syntax'.
4795 * src/bison.simple: Add a section directive. Put braces around muscle
4796 names.
4797
4798 * src/files.h (strsuffix, stringappend): Add declarations.
4799 (tab_extension): Add declaration.
4800 (short_base_name): Add declaration.
4801
4802 * src/files.c (strsuffix, stringappend): No longer static. These
4803 functions are used in the skeleton parser.
4804 (tab_extension): New.
4805 (compute_base_names): Use the computations done in this function
4806 to guess if the generated parsers should have '.tab' in their
4807 names.
4808 (short_base_name): No longer static.
4809
4810 * src/output.c (output_skeleton): New.
4811 (output): Disable call to output_master_parser, and give a try to
4812 a new skeleton handling system.
4813 (guards_output, actions_output): No longer static.
4814 (token_definitions_output, get_lines_number): No longer static.
4815
4816 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
4817
4818 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
4819 parse-skel.y.
4820
4821 * src/parse-skel.y: New file.
4822 * src/scan-skel.l: New file.
4823
48242001-12-29 Akim Demaille <akim@epita.fr>
4825
4826 %name-prefix is broken.
4827
4828 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
4829 Adjust all dependencies.
4830 * tests/headers.at (export YYLTYPE): Strengthen this test: use
4831 %name-prefix.
4832
4833 Renaming yylval but not yylloc is not consistent. Now we do.
4834
4835 * src/bison.simple: Prefix yylloc if used.
4836 * doc/bison.texinfo (Decl Summary): Document that.
4837
48382001-12-29 Akim Demaille <akim@epita.fr>
4839
4840 * doc/bison.texinfo: Promote `%long-directive' over
4841 `%long_directive'.
4842 Remove all references to fixed-output-files, yacc is enough.
4843
48442001-12-29 Akim Demaille <akim@epita.fr>
4845
4846 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
4847 user prologue. These are defaults.
4848 * tests/actions.at (Mid-rule actions): Make sure the user can
4849 define YYDEBUG and YYERROR_VERBOSE.
4850
48512001-12-29 Akim Demaille <akim@epita.fr>
4852
4853 * src/output.c (header_output): Don't forget to export YYLTYPE and
4854 yylloc.
4855 * tests/headers.at (export YYLTYPE): New, make sure it does.
4856 * tests/regression.at (%union and --defines, Invalid CPP headers):
4857 Move to...
4858 * tests/headers.at: here.
4859
48602001-12-29 Akim Demaille <akim@epita.fr>
4861
4862 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
4863
48642001-12-29 Akim Demaille <akim@epita.fr>
4865
4866 * tests/actions.at (Mid-rule actions): Output on a single line
4867 instead of several.
4868
48692001-12-29 Akim Demaille <akim@epita.fr>
4870
4871 * doc/bison.texinfo: Formatting changes.
4872
48732001-12-29 Akim Demaille <akim@epita.fr>
4874
4875 Don't store the token defs in a muscle, just be ready to output it
4876 on command. Now possible via `symbols'. Fixes a memory leak.
4877
4878 * src/output.c (token_definitions_output): New.
4879 (output_parser, header_output): Use it.
4880 * src/reader.c (symbols_save): Remove.
4881
48822001-12-29 Akim Demaille <akim@epita.fr>
4883
4884 * src/bison.simple: Do not provide a default for YYSTYPE and
4885 YYLTYPE before the user's prologue. Otherwise it's hardly... a
4886 default.
4887
48882001-12-29 Akim Demaille <akim@epita.fr>
4889
4890 Mid-rule actions are simply... ignored!
4891
4892 * src/reader.c (readgram): Be sure to attach mid-rule actions to
4893 the empty-rule associated to the dummy symbol, not to the host
4894 rule.
4895 * tests/actions.at (Mid-rule actions): New.
4896
48972001-12-29 Akim Demaille <akim@epita.fr>
4898
4899 Memory leak.
4900
4901 * src/reader.c (reader): Free grammar.
4902
49032001-12-29 Akim Demaille <akim@epita.fr>
4904
4905 Memory leak.
4906
4907 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4908 since it allocates it for each state, although only one is needed.
4909 (allocate_storage): Do it here.
4910
49112001-12-29 Akim Demaille <akim@epita.fr>
4912
4913 * src/options.h, src/options.c (create_long_option_table): Rename
4914 as...
4915 (long_option_table_new): this, with a clearer prototype.
4916 (percent_table): Remove, unused,
4917 * src/getargs.c (getargs): Adjust.
4918
49192001-12-29 Akim Demaille <akim@epita.fr>
4920
4921 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4922 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4923 as states.
4924
49252001-12-29 Akim Demaille <akim@epita.fr>
4926
4927 * src/lalr.c (build_relations): Rename `states' as `states1'.
4928 Sorry, I don't understand exactly what it is, no better name...
4929
49302001-12-29 Akim Demaille <akim@epita.fr>
4931
4932 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4933 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4934 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4935 as rules.
4936
49372001-12-29 Akim Demaille <akim@epita.fr>
4938
4939 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4940 ago.
4941
49422001-12-29 Akim Demaille <akim@epita.fr>
4943
4944 * src/reader.c, src/reader.h (user_toknums): Remove.
4945 Adjust all users to use symbols[i]->user_token_number.
4946
49472001-12-29 Akim Demaille <akim@epita.fr>
4948
4949 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4950 Adjust all users to use symbols[i]->prec or ->assoc.
4951
49522001-12-29 Akim Demaille <akim@epita.fr>
4953
4954 * src/reader.c, src/reader.h (tags): Remove.
4955 Adjust all users to use symbols[i]->tag.
4956
49572001-12-29 Akim Demaille <akim@epita.fr>
4958
4959 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4960 and rule_table.
4961 * src/reader.c (packsymbols): Fill this table.
4962 Drop sprec.
4963 * src/conflicts.c (resolve_sr_conflict): Adjust.
4964 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4965 single table.
4966 Use symbols[i]->tag instead of tags[i].
4967
49682001-12-29 Akim Demaille <akim@epita.fr>
4969
4970 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4971 In addition, put a comment in there, to replace...
4972 * tests/regression.at (%union and C comments): Remove.
4973
49742001-12-29 Akim Demaille <akim@epita.fr>
4975
4976 * tests/regression.at (Web2c Actions): Blindly move the actual
4977 output as expected output. The contents *seem* right to me, but I
4978 can't pretend reading perfectly parser tables... Nonetheless, all
4979 the other tests pass correctly, the table look OK, even though the
4980 presence of `$axiom' is to be noted: AFAICS it is useless (but
4981 harmless).
4982
49832001-12-29 Akim Demaille <akim@epita.fr>
4984
4985 * src/reader.c (readgram): Don't add the rule 0 if there were no
4986 rules read. In other words, add it _after_ having performed
4987 grammar sanity checks.
4988 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4989
49902001-12-29 Akim Demaille <akim@epita.fr>
4991
4992 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4993 visible, and some states have now a different number.
4994
49952001-12-29 Akim Demaille <akim@epita.fr>
4996
4997 * src/reader.c (readgram): Bind the initial rule's lineno to that
4998 of the first rule.
4999 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5000 (Solved SR Conflicts): Adjust rule 0's line number.
5001
50022001-12-29 Akim Demaille <akim@epita.fr>
5003
5004 Fix the `GAWK Grammar' failure.
5005
5006 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5007 the reductions of the first state which was mistakenly confused
5008 with the final state because precisely final_state was initialized
5009 to 0.
5010 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5011 now noticed by Bison.
5012 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5013 have a reduction on $default.
5014
50152001-12-29 Akim Demaille <akim@epita.fr>
5016
5017 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5018 rule line numbers.
5019 * src/closure.c (print_closure): Likewise.
5020 * src/derives.c (print_derives): Likewise.
5021 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5022 now.
5023
50242001-12-29 Akim Demaille <akim@epita.fr>
5025
5026 * src/lalr.c (lookaheads_print): New.
5027 (lalr): Call it when --trace-flag.
5028 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5029 are dumped.
5030
50312001-12-29 Akim Demaille <akim@epita.fr>
5032
5033 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5034 when walking through ritem, even via rule->rhs.
5035 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5036 (useful_production, useless_nonterminals): Likewise.
5037 (reduce_grammar_tables): Likewise, plus update nritems.
5038 * src/nullable.c (set_nullable): Likewise.
5039 * src/lalr.c (build_relations): Likewise.
5040 * tests/sets.at (Nullable): Adjust.
5041 Fortunately, now, the $axiom is no longer nullable.
5042
50432001-12-29 Akim Demaille <akim@epita.fr>
5044
5045 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5046 the 0-sentinel.
5047 * src/gram.c (ritem_longest_rhs): Likewise.
5048 * src/reduce.c (nonterminals_reduce): Likewise.
5049 * src/print_graph.c (print_graph): Likewise.
5050 * src/output.c (output_rule_data): Likewise.
5051 * src/nullable.c (set_nullable): Likewise.
5052
50532001-12-29 Akim Demaille <akim@epita.fr>
5054
5055 * src/output.c: Comment changes.
5056
50572001-12-27 Paul Eggert <eggert@twinsun.com>
5058
5059 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5060 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5061 Sparc, as they were causing more porting problems than the
5062 (minor) performance improvement was worth.
5063
5064 Also, catch up with 1.31's YYSTD.
5065
50662001-12-27 Akim Demaille <akim@epita.fr>
5067
5068 * src/output.c (output_gram): Rely on nritems, not the
5069 0-sentinel. See below.
5070 Use -1 as separator, not 0.
5071 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5072 Rely on -1 as separator in yyrhs, instead of 0.
5073 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5074 twice `Now at end of input', therefore there are two lines less to
5075 expect.
5076
50772001-12-27 Akim Demaille <akim@epita.fr>
5078
5079 * tests/regression.at (Unresolved SR Conflicts):
5080 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5081 below.
5082
50832001-12-27 Akim Demaille <akim@epita.fr>
5084
5085 * src/LR0.c (new_state): Recognize the final state by the fact it
5086 is reached by eoftoken.
5087 (insert_start_shifting_state, insert_eof_shifting_state)
5088 (insert_accepting_state, augment_automaton): Remove, since now
5089 these states are automatically computed from the initial state.
5090 (generate_states): Adjust.
5091 * src/print.c: When reporting a rule number to the user, substract
5092 1, so that the axiom rule is rule 0, and the first user rule is 1.
5093 * src/reduce.c: Likewise.
5094 * src/print_graph.c (print_core): For the time being, just as for
5095 the report, depend upon --trace-flags to dump the full set of
5096 items.
5097 * src/reader.c (readgram): Once the grammar read, insert the rule
5098 0: `$axiom: START-SYMBOL $'.
5099 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5100 number of the states has changed (the final state is no longer
5101 necessarily the last), catch up.
5102
51032001-12-27 Akim Demaille <akim@epita.fr>
5104
5105 Try to make the use of the eoftoken valid. Given that its value
5106 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5107 is used instead of > 0 where appropriate, (ii), depend upon nritems
5108 instead of the 0-sentinel.
5109
5110 * src/gram.h, src/gram.c (nritems): New.
5111 Expected to be duplication of nitems, but for the time being...
5112 * src/reader.c (packgram): Assert nritems and nitems are equal.
5113 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5114 * src/closure.c (print_closure, print_fderives): Likewise.
5115 * src/gram.c (ritem_print): Likewise.
5116 * src/print.c (print_core, print_grammar): Likewise.
5117 * src/print_graph.c: Likewise.
5118
51192001-12-27 Akim Demaille <akim@epita.fr>
5120
5121 * src/main.c (main): If there are complains after grammar
5122 reductions, then output the report anyway if requested, then die.
5123 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5124 * src/reader.c (eoftoken): New.
5125 (parse_token_decl): If the token being defined has value `0', it
5126 is the eoftoken.
5127 (packsymbols): No longer hack `tags' to insert `$' by hand.
5128 Be sure to preserve the value of the eoftoken.
5129 (reader): Make sure eoftoken is defined.
5130 Initialize nsyms to 0: now eoftoken is created just like the others.
5131 * src/print.c (print_grammar): Don't special case the eof token.
5132 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5133 lie anyway, albeit pleasant.
5134 * tests/calc.at: Exercise error messages with eoftoken.
5135 Change the grammar so that empty input is invalid.
5136 Adjust expectations.
5137 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5138
51392001-12-27 Akim Demaille <akim@epita.fr>
5140
5141 * configure.in: Check the protos of strchr ans strspn.
5142 Replace strchr if needed.
5143 * src/system.h: Provide the protos of strchr, strspn and memchr if
5144 missing.
5145 * lib/strchr.c: New.
5146 * src/reader.c (symbols_save): Use strchr.
5147
51482001-12-27 Akim Demaille <akim@epita.fr>
5149
5150 * src/print.c, src/print_graph.c (escape): New.
5151 Use it to quote the TAGS outputs.
5152 * src/print_graph.c (print_state): Now errors are in red, and
5153 reductions in green.
5154 Prefer high to wide: output the state number on a line of its own.
5155
51562001-12-27 Akim Demaille <akim@epita.fr>
5157
5158 * src/state.h, src/state.c (reductions_new): New.
5159 * src/LR0.c (set_state_table): Let all the states have a
5160 `reductions', even if reduced to 0.
5161 (save_reductions): Adjust.
5162 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5163 * src/print.c (print_reductions, print_actions): Adjust.
5164 * src/output.c (action_row): Adjust.
5165
51662001-12-27 Akim Demaille <akim@epita.fr>
5167
5168 * src/state.h, src/state.c (errs_new, errs_dup): New.
5169 * src/LR0.c (set_state_table): Let all the states have an errs,
5170 even if reduced to 0.
5171 * src/print.c (print_errs, print_reductions): Adjust.
5172 * src/output.c (output_actions, action_row): Adjust.
5173 * src/conflicts.c (resolve_sr_conflict): Adjust.
5174
51752001-12-27 Akim Demaille <akim@epita.fr>
5176
5177 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5178
51792001-12-27 Akim Demaille <akim@epita.fr>
5180
5181 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5182 * src/print.c: here.
5183 (lookaheadset, shiftset): New, used as additional storage by
5184 print_reductions.
5185 (print_results): Adjust.
5186 (print_shifts, print_gotos, print_errs): New, extracted from...
5187 (print_actions): here.
5188 * src/print_graph.c (print_actions): Remove dead code.
5189
51902001-12-27 Akim Demaille <akim@epita.fr>
5191
5192 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5193 `$n' and `@n'.
5194
51952001-12-27 Akim Demaille <akim@epita.fr>
5196
5197 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5198 (build_relations): Adjust.
5199
52002001-12-27 Akim Demaille <akim@epita.fr>
5201
5202 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5203 duplication.
5204
52052001-12-27 Akim Demaille <akim@epita.fr>
5206
5207 * src/reader.c (packgram): Catch nitems overflows.
5208
52092001-12-27 Akim Demaille <akim@epita.fr>
5210
5211 * src/files.c, src/files.h (guard_obstack): Remove.
5212 * src/output.c (output): Adjust.
5213 * src/reader.c (parse_braces): New, factoring...
5214 (copy_action, copy_guard): these two which are renamed as...
5215 (parse_action, parse_guard): these.
5216 As a voluntary consequence, using braces around guards is now
5217 mandatory.
5218
52192001-12-27 Akim Demaille <akim@epita.fr>
5220
5221 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5222 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5223 members.
5224 (symbol_list_new): Adjust.
5225 (copy_action): action_line is the first line, not the last.
5226 (copy_guard): Just as for actions, store the `action' only, not
5227 the switch/case/break flesh.
5228 Don't parse the user action that might follow the guard, let...
5229 (readgram): do it, i.e., now, there can be an action after a
5230 guard.
5231 In other words the guard is just explicitly optional.
5232 (packgram): Adjust.
5233 * src/output.c (guards_output): New.
5234 (output_parser): Call it when needed.
5235 (output): Also free the guard and attrs obstacks.
5236 * src/files.c, src/files.h (obstack_save): Remove.
5237 (output_files): Remove.
5238 As a result, if one needs the former `.act' file, using an
5239 appropriate skeleton which requires actions and guards is now
5240 required.
5241 * src/main.c (main): Adjust.
5242 * tests/semantic.at: New.
5243 * tests/regression.at: Use `input.y' as input file name.
5244 Avoid 8+3 problems by requiring input.c when the test needs the
5245 parser.
5246
52472001-12-27 Akim Demaille <akim@epita.fr>
5248
5249 * src/reader.c (symbol_list_new): Be sure to initialize all the
5250 fields.
5251
52522001-12-27 Akim Demaille <akim@epita.fr>
5253
5254 All the hacks using a final pseudo state are now useless.
5255
5256 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5257 * src/lalr.c (nLA): New.
5258 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5259 instead of lookaheadsp from the pseudo state (nstate + 1).
5260
52612001-12-27 Akim Demaille <akim@epita.fr>
5262
5263 * src/output.c (action_row, token_actions): Use a state_t instead
5264 of a integer, and nlookaheads instead of the following state's
5265 lookaheadsp.
5266
52672001-12-27 Akim Demaille <akim@epita.fr>
5268
5269 * src/conflicts.c (log_resolution, flush_shift)
5270 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5271 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5272 (conflicts_print, print_reductions): Use a state_t instead of an
5273 integer when referring to a state.
5274 As much as possible, depend upon nlookaheads, instead of the
5275 `lookaheadsp' member of the following state (since lookaheads of
5276 successive states are successive, the difference between state n + 1
5277 and n served as the number of lookaheads for state n).
5278 * src/lalr.c (add_lookback_edge): Likewise.
5279 * src/print.c (print_core, print_actions, print_state)
5280 (print_results): Likewise.
5281 * src/print_graph.c (print_core, print_actions, print_state)
5282 (print_graph): Likewise.
5283 * src/conflicts.h: Adjust.
5284
52852001-12-27 Akim Demaille <akim@epita.fr>
5286
5287 * src/bison.hairy: Formatting/comment changes.
5288 ANSIfy.
5289 Remove `register' indications.
5290 Add plenty of `static'.
5291
52922001-12-27 Akim Demaille <akim@epita.fr>
5293
5294 * src/output.c (prepare): Drop the muscle `ntbase' which
5295 duplicates ntokens.
5296 * src/bison.simple: Formatting/comment changes.
5297 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5298 is an undocumented synonym.
5299
53002001-12-22 Akim Demaille <akim@epita.fr>
5301
5302 * src/output.c (output_table_data): Change the prototype to use
5303 `int' for array ranges: some invocations do pass an int, not a
5304 short.
5305 Reported by Wayne Green.
5306
53072001-12-22 Akim Demaille <akim@epita.fr>
5308
5309 Some actions of web2c.y are improperly triggered.
5310 Reported by Mike Castle.
5311
5312 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5313 * tests/regression.at (Web2c): Rename as...
5314 (Web2c Report): this.
5315 (Web2c Actions): New.
5316
53172001-12-22 Akim Demaille <akim@epita.fr>
5318
5319 Reductions in web2c.y are improperly reported.
5320 Reported by Mike Castle.
5321
5322 * src/conflicts.c (print_reductions): Fix.
5323 * tests/regression.at (Web2c): New.
5324
53252001-12-18 Akim Demaille <akim@epita.fr>
5326
5327 Some host fail on `assert (!"foo")', which expands to
5328 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5329 Reported by Nelson Beebee.
5330
5331 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5332 `#define it_succeeded 0' and `assert (it_succeeded)'.
5333
53342001-12-17 Marc Autret <autret_m@epita.fr>
5335
5336 * src/bison.simple: Don't hard code the skeleton line and filename.
5337 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5338 New line counter 'skeleton_line' (skeleton-line muscle).
5339
53402001-12-17 Paul Eggert <eggert@twinsun.com>
5341
5342 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5343 YYDEBUG must be defined to a nonzero value.
5344
5345 * src/bison.simple (yytname): Do not assume that the user defines
5346 YYDEBUG to a properly parenthesized expression.
5347
53482001-12-17 Akim Demaille <akim@epita.fr>
5349
5350 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5351 nlookaheads is a new member.
5352 Adjust all users.
5353 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5354 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5355 state.
5356
53572001-12-17 Akim Demaille <akim@epita.fr>
5358
5359 * src/files.h, src/files.c (open_files, close_files): Remove.
5360 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5361 let...
5362 * src/reader.c (reader): Do it.
5363
53642001-12-17 Akim Demaille <akim@epita.fr>
5365
5366 * src/conflicts.c (print_reductions): Formatting changes.
5367
53682001-12-17 Akim Demaille <akim@epita.fr>
5369
5370 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5371 (flush_reduce): New.
5372 (resolve_sr_conflict): Adjust.
5373
53742001-12-17 Akim Demaille <akim@epita.fr>
5375
5376 * src/output.c (output_obstack): Be static and rename as...
5377 (format_obstack): this, to avoid any confusion with files.c's
5378 output_obstack.
5379 * src/reader.h (muscle_obstack): Move to...
5380 * src/output.h: here, since it's defined in output.c.
5381
53822001-12-17 Akim Demaille <akim@epita.fr>
5383
5384 * src/output.c (action_row, save_column, default_goto)
5385 (sort_actions, matching_state, pack_vector): Better variable
5386 locality.
5387
53882001-12-17 Akim Demaille <akim@epita.fr>
5389
5390 * src/output.c: Various formatting changes.
5391
53922001-12-17 Akim Demaille <akim@epita.fr>
5393
5394 * src/files.c (output_files): Free the output_obstack.
5395 * src/main.c (main): Call print and print_graph conditionally.
5396 * src/print.c (print): Work unconditionally.
5397 * src/print_graph.c (print_graph): Work unconditionally.
5398 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5399
54002001-12-16 Marc Autret <autret_m@epita.fr>
5401
5402 * src/output.c (actions_output): Fix. When we use %no-lines,
5403 there is one less line per action.
5404
54052001-12-16 Marc Autret <autret_m@epita.fr>
5406
5407 * src/bison.simple: Remove a useless #line directive.
5408 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5409 * src/output.c (get_lines_number): New.
5410 (output_parser): Adjust, now takes care about the lines of a
5411 output muscles.
5412 Fix line numbering.
5413 (actions_output): Computes the number of lines taken by actions.
5414 (output_master_parser): Insert new skeleton which is the name of
5415 the output parser file name.
5416
54172001-12-15 Marc Autret <autret_m@epita.fr>
5418
5419 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5420
54212001-12-15 Marc Autret <autret_m@epita.fr>
5422
5423 * src/output.c (output_gram): Keep track of the hairy one.
5424
54252001-12-15 Akim Demaille <akim@epita.fr>
5426
5427 Make `make distcheck' work.
5428
5429 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5430 system.h which uses libgettext.h.
5431
54322001-12-15 Akim Demaille <akim@epita.fr>
5433
5434 * src/nullable.c (set_nullable): Useless rules must be skipped,
5435 otherwise, since we range over their symbols, we might look at a
5436 nonterminal which no longer ``exists'', i.e., it is not counted in
5437 `nvars', hence we overflow our arrays.
5438
54392001-12-15 Akim Demaille <akim@epita.fr>
5440
5441 The header can also be produced directly, without any obstack!
5442 Yahoo!
5443
5444 * src/files.c, src/files.h (defines_obstack): Remove.
5445 (compute_header_macro): Global.
5446 (defines_obstack_save): Remove.
5447 * src/reader.c (parse_union_decl): No longer output to
5448 defines_obstack: its content can be found in the `stype' muscle
5449 anyway.
5450 (output_token_translations): Merge into...
5451 (symbols_output): this.
5452 Rename as...
5453 (symbols_save): this.
5454 (reader): Adjust.
5455 * src/output.c (header_output): New.
5456 (output): Call it.
5457
54582001-12-15 Akim Demaille <akim@epita.fr>
5459
5460 * src/reader.c (parse_union_decl): Instead of handling two obstack
5461 simultaneously, use one to define the `stype' muscle, and use the
5462 value of the latter to fill defines_obstack.
5463 (copy_comment): Remove.
5464 (copy_comment2): Work for a single obstack.
5465 Rename as...
5466 (copy_comment): this.
5467
54682001-12-15 Akim Demaille <akim@epita.fr>
5469
5470 * src/lex.c, src/lex.h (xgetc): No longer static.
5471 * src/reader.c (parse_union_decl): Revamp.
5472
54732001-12-15 Akim Demaille <akim@epita.fr>
5474
5475 Still making progress in separating Bison into (i) input, (ii)
5476 process, (iii) output: now we can directly output the parser file
5477 without using table_obstack at all.
5478
5479 * src/files.c, src/files.h (table_obstack): Bye bye.
5480 (parser_file_name): New.
5481 * src/files.c (compute_output_file_names): Compute it.
5482 * src/output.c (actions_output, output_parser)
5483 (output_master_parser): To a file instead of an obstack.
5484
54852001-12-15 Akim Demaille <akim@epita.fr>
5486
5487 Attach actions to rules, instead of pre-outputting them to
5488 actions_obstack.
5489
5490 * src/gram.h (rule_t): action and action_line are new members.
5491 * src/reader.c (symbol_list): Likewise.
5492 (copy_action): Save the actions within the rule.
5493 (packgram): Save them in rule_table.
5494 * src/output.c (actions_output): New.
5495 (output_parser): Use it on `%%actions'.
5496 (output_rule_data): Don't free rule_table.
5497 (output): Do it.
5498 (prepare): Don't save the `action' muscle.
5499 * src/bison.simple: s/%%action/%%actions/.
5500
55012001-12-15 Akim Demaille <akim@epita.fr>
5502
5503 * src/reader.c (copy_action): When --yacc, don't append a `;'
5504 to the user action: let it fail if lacking.
5505 Suggested by Arnold Robbins and Tom Tromey.
5506
55072001-12-14 Akim Demaille <akim@epita.fr>
5508
5509 * src/lex.c (literalchar): Simply return the char you decoded, non
5510 longer mess around with obstacks and int pointers.
5511 Adjust all callers.
5512
55132001-12-14 Akim Demaille <akim@epita.fr>
5514
5515 * src/lex.c (literalchar): Don't escape the special characters,
5516 just decode them, and keep them as char (before, eol was output as
5517 the 2 char string `\n' etc.).
5518 * src/output.c (output_rule_data): Use quotearg to output the
5519 token strings.
5520
55212001-12-13 Paul Eggert <eggert@twinsun.com>
5522
5523 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
5524 Do not infringe on the global user namespace when using C++.
5525 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
5526 All uses of `fprintf' and `stderr' changed.
5527
5528 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
5529
55302001-12-13 Akim Demaille <akim@epita.fr>
5531
5532 The computation of nullable is broken: it doesn't handle empty
5533 RHS's properly.
5534
5535 * tests/torture.at (GNU AWK Grammar): New.
5536 * tests/sets.at (Nullable): New.
5537 * src/nullable.c (set_nullable): Instead of blindly looping over
5538 `ritems', loop over the rules, and then over their rhs's.
5539
5540 Work around Autotest bugs.
5541
5542 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
5543 frame, because Autotest understand lines starting with a `+' as
5544 traces from the shell. Then, they are not processed properly.
5545 Admittedly an Autotest bug, but we don't have time to wait for
5546 Autotest to catch up.
5547 * tests/regression.at (Broken Closure): Adjust to the new table
5548 frames.
5549 Move to...
5550 * tests/sets.at: here.
5551
55522001-12-13 Akim Demaille <akim@epita.fr>
5553
5554 * src/closure.c (closure): Use nrules instead of playing tricks
5555 with BITS_PER_WORD.
5556
55572001-12-13 Akim Demaille <akim@epita.fr>
5558
5559 * src/print.c (print_actions): Output the handling of `$' as the
5560 traces do: shifting the token EOF. Before EOF was treated as a
5561 nonterminal.
5562 * tests/regression.at: Adjust some tests.
5563 * src/print_graph.c (print_core): Complete the set of items via
5564 closure. The next-to-final and final states are still unsatisfying,
5565 but that's to be addressed elsewhere.
5566 No longer output the rule numbers, but do output the state number.
5567 A single loop for the shifts + gotos is enough, but picked a
5568 distinct color for each.
5569 (print_graph): Initialize and finalize closure.
5570
55712001-12-13 Akim Demaille <akim@epita.fr>
5572
5573 * src/reader.c (readgram): Remove dead code, an strip useless
5574 braces.
5575 (get_type): Remove, unused.
5576
55772001-12-12 Akim Demaille <akim@epita.fr>
5578
5579 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
5580 on that of lib/error.c.
5581
55822001-12-12 Akim Demaille <akim@epita.fr>
5583
5584 Some hosts don't like `/' in includes.
5585
5586 * src/system.h: Include libgettext.h without qualifying the path.
5587 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
5588 $(top_srcdir).
5589
55902001-12-11 Marc Autret <autret_m@epita.fr>
5591
5592 * src/output.c (output_parser): Remove useless muscle.
5593
55942001-12-11 Marc Autret <autret_m@epita.fr>
5595
5596 * src/bison.simple: Remove #line just before %%epilogue. It
5597 is now handled in ...
5598 * src/reader.c (read_additionnal_code): Add the output of a
5599 #line for the epilogue.
5600
56012001-12-10 Marc Autret <autret_m@epita.fr>
5602
5603 * src/reader.c (copy_definition): Re-use CPP-outed code which
5604 replace precedent remove.
5605 * src/bison.simple: Remove #line before %%prologue because
5606 %%input-line is wrong at this time.
5607
56082001-12-10 Marc Autret <autret_m@epita.fr>
5609
5610 * src/reader.c (symbols_output): Clean up.
5611 * src/output.c (output_gram, output): Clean up.
5612
56132001-12-10 Akim Demaille <akim@epita.fr>
5614
5615 * src/lalr.c (initialize_lookaheads): New. Extracted from...
5616 * src/LR0.c (set_state_table): here.
5617 * src/lalr.c (lalr): Call it.
5618
56192001-12-10 Akim Demaille <akim@epita.fr>
5620
5621 * src/state.h (shifts): Remove the `number' member: shifts are
5622 attached to state, hence no longer need to be labelled with a
5623 state number.
5624
56252001-12-10 Akim Demaille <akim@epita.fr>
5626
5627 Now that states have a complete set of members, the linked list of
5628 shifts is useless: just fill directly the state's shifts member.
5629
5630 * src/state.h (shifts): Remove the `next' member.
5631 * src/LR0.c (first_state, last_state): Remove.
5632 Adjust the callers.
5633 (augment_automaton): Don't look for the shifts that must be added
5634 a shift on EOF: it is those of the state we looked for! But now,
5635 since shifts are attached, it is no longer needed to looking
5636 merely by its id: its number.
5637
56382001-12-10 Akim Demaille <akim@epita.fr>
5639
5640 * src/LR0.c (augment_automaton): Better variable locality.
5641 Remove an impossible branch: if there is a state corresponding to
5642 the start symbol being shifted, then there is shift for the start
5643 symbol from the initial state.
5644
56452001-12-10 Akim Demaille <akim@epita.fr>
5646
5647 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
5648 only when appropriate: when insert_start_shifting_state' is not
5649 invoked.
5650 * tests/regression.at (Rule Line Numbers): Adjust.
5651
56522001-12-10 Akim Demaille <akim@epita.fr>
5653
5654 * src/LR0.c (augment_automaton): Now that all states have shifts,
5655 merge the two cases addition shifts to the initial state.
5656
56572001-12-10 Akim Demaille <akim@epita.fr>
5658
5659 * src/lalr.c (set_state_table): Move to...
5660 * src/LR0.c: here.
5661 * src/lalr.c (lalr): Don't call it...
5662 * src/LR0.c (generate_states): do it.
5663 * src/LR0.h (first_state): Remove, only the table is used.
5664
56652001-12-10 Akim Demaille <akim@epita.fr>
5666
5667 * src/LR0.h (first_shift, first_reduction): Remove.
5668 * src/lalr.c: Don't use first_shift: find shifts through the
5669 states.
5670
56712001-12-10 Akim Demaille <akim@epita.fr>
5672
5673 * src/LR0.c: Attach shifts to states as soon as they are
5674 computed.
5675 * src/lalr.c (set_state_table): Instead of assigning shifts to
5676 state, just assert that the mapping was properly done.
5677
56782001-12-10 Akim Demaille <akim@epita.fr>
5679
5680 * src/LR0.c (insert_start_shift): Rename as...
5681 (insert_start_shifting_state): this.
5682 (insert_eof_shifting_state, insert_accepting_state): New.
5683 (augment_automaton): Adjust.
5684 Better locality of the variables.
5685 When looking if the start_symbol is shifted from the initial
5686 state, using `while (... symbol != start_symbol ...)' sounds
5687 better than `while (... symbol < start_symbol ...)': If fail
5688 to see how the order between symbols could be relevant!
5689
56902001-12-10 Akim Demaille <akim@epita.fr>
5691
5692 * src/getargs.h: Don't declare `spec_name_prefix' and
5693 `spec_file_prefix', declared by src/files.h.
5694 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
5695 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
5696 * src/output.c (prepare): Adjust.
5697 * src/reader.c (symbols_output): Likewise.
5698 * src/vmsgetargs.c: Vaguely adjust, but who cares?
5699
57002001-12-10 Akim Demaille <akim@epita.fr>
5701
5702 * src/muscle_tab.c (muscle_init): NULL is a better default than
5703 `"0"'.
5704
57052001-12-10 Akim Demaille <akim@epita.fr>
5706
5707 * src/reader.c (reader): Calling symbols_output once is enough.
5708
57092001-12-10 Akim Demaille <akim@epita.fr>
5710
5711 Now that states have a complete set of members, the linked list of
5712 reductions is useless: just fill directly the state's reductions
5713 member.
5714
5715 * src/state.h (struct reductions): Remove member `number' and
5716 `next'.
5717 * src/LR0.c (first_reduction, last_reduction): Remove.
5718 (save_reductions): Don't link the new reductions, store them in
5719 this_state.
5720 * src/lalr.c (set_state_table): No need to attach reductions to
5721 states, it's already done.
5722 * src/output.c (output_actions): No longer free the shifts, then
5723 the reductions, then the states: free all the states and their
5724 members.
5725
57262001-12-10 Akim Demaille <akim@epita.fr>
5727
5728 * src/options.c (OPTN, DRTV, BOTH): New.
5729 (option_table): Use them.
5730
5731 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
5732 the job of system.h.
5733 * src/options.c: Don't include stdio.h and xalloc.h for the same
5734 reasons.
5735
57362001-12-10 Akim Demaille <akim@epita.fr>
5737
5738 * src/output.c (output, prepare): Make sure the values of the
5739 muscles `action' and `prologue' are 0-terminated.
5740
57412001-12-10 Akim Demaille <akim@epita.fr>
5742
5743 Clean up GCC warnings.
5744
5745 * src/reader.c (copy_action): `buf' is not used.
5746 (parse_skel_decl): Be static.
5747 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
5748 * src/options.h (create_long_option_table): Have a real prototype.
5749 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
5750 (hash_delete_at): Return const void *.
5751 Adjust casts to preserve the const.
5752
57532001-12-10 Akim Demaille <akim@epita.fr>
5754
5755 * configure.in: Require 2.52g.
5756 M4 is not needed, but AUTOM4TE is.
5757 * m4/m4.m4: Remove.
5758 * tests/Makefile.am: Adjust.
5759
57602001-12-10 Akim Demaille <akim@epita.fr>
5761
5762 One structure for states is enough, even though theoretically
5763 there are LR(0) states and LALR(1) states.
5764
5765 * src/lalr.h (state_t): Remove.
5766 (state_table): Be state_t **, not state_t *.
5767 * src/state.h (core, CORE_ALLOC): Rename as...
5768 (state_t, STATE_ALLOC): this.
5769 Add the LALR(1) members: shifts, reductions, errs.
5770 * src/LR0.c (state_table): Rename as...
5771 (state_hash): this, to avoid name clashes with the global
5772 `state_table'.
5773 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
5774 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
5775
57762001-12-10 Akim Demaille <akim@epita.fr>
5777
5778 Bison dumps core on bash.y.
5779 Reported by Pascal Bart.
5780
5781 * src/warshall.c (bitmatrix_print): New.
5782 (TC): Use it.
5783 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
5784 j must be the outer loop.
5785 * tests/regression.at (Broken Closure): New.
5786
57872001-12-05 Akim Demaille <akim@epita.fr>
5788
5789 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
5790 its argument.
5791