]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
Regen.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-10-23 Paul Eggert <eggert@twinsun.com>
2
3 * src/main.c (main): With --trace=time, report times even if a
4 non-fatal error occurs. Formerly, the times were reported in some
5 such cases but not in others.
6 * src/reader.c (reader): Just return if a complaint has been issued,
7 instead of exiting, so that 'main' can report times.
8
92002-10-22 Akim Demaille <akim@epita.fr>
10
11 * src/system.h: Include sys/types.
12 Reported by Bert Deknuydt.
13
142002-10-23 Paul Eggert <eggert@twinsun.com>
15
16 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
17 Suggested by Art Haas.
18
192002-10-22 Paul Eggert <eggert@twinsun.com>
20
21 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
22 decl; not needed any more.
23 * src/main.c (main): Use return to exit, undoing yesterday's change.
24 The last OS that we could find where this wouldn't work is
25 SunOS 3.5, and that's too old to worry about now.
26
27 * data/glr.c (struct yyltype): Define members even when not
28 doing locations. This is more consistent with yacc.c, and it
29 works around the following bug reports:
30 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
31 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
32 and I hope it also fixes this bug report:
33 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
34
35 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
36 @acronym consistently. Standardize on "Yacc" instead of "YACC",
37 "Algol" instead of "ALGOL". Give a bit more history about BNF.
38
392002-10-22 Akim Demaille <akim@epita.fr>
40
41 * data/README: New.
42
432002-10-21 Paul Eggert <eggert@twinsun.com>
44
45 Be consistent about 'bool'; the old code used an enum in one
46 module and an int in another, and this violates the C standard.
47 * m4/stdbool.m4: New file, from coreutils 4.5.3.
48 * configure.ac (AC_HEADER_STDBOOL): Add.
49 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
50 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
51 * src/symtab.c (hash_compare_symbol_t): Likewise.
52 * src/system.h (bool, false, true): Use a definition consistent
53 with ../lib/hash.c. All uses changed.
54
55 * src/complain.c (warning_issued): Renamed from warn_message_count,
56 so that we needn't worry about integer overflow (!).
57 Now of type bool. All uses changed.
58 (complaint_issued): Renamed from complain_message_count; likewise.
59
60 * src/main.c (main): Use exit to exit with failure.
61
62 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
63 rather than 1 and 0.
64 * src/main.c (main): Likewise.
65 * src/getargs.c (getargs): Likewise.
66 * src/reader.c (reader): Likewise.
67
68 * src/getarg.c (getargs): Remove duplicate code for
69 "Try `bison --help'".
70
71 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
72 What was that "2" for?
73
74 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
75 * src/getargs.c (usage): Likewise.
76
77 * src/getargs.c (getargs): When there are too few operands, report
78 the last one. When there are too many, report the first extra
79 one. This is how diffutils does it.
80
812002-10-20 Paul Eggert <eggert@twinsun.com>
82
83 Remove K&R vestiges.
84 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
85 * src/complain.c (VA_START): Remove. Assume prototypes.
86 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
87 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
88 fatal): Assume prototypes.
89 * src/complain.h: Assume prototypes.
90 * src/system.h (PARAMS): Remove.
91 Include <limits.h> unconditionally, since it's guaranteeed even
92 for a freestanding C89 compiler.
93 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
94 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
95
962002-10-20 Akim Demaille <akim@epita.fr>
97
98 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
99 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
100 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
101 (yyresolveStates, yyresolveAction, yyresolveStack)
102 (yyprocessOneStack): Use them.
103 (yy_reduce_print): New.
104 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
105
1062002-10-20 Akim Demaille <akim@epita.fr>
107
108 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
109 arguments and output `void'.
110 (b4_c_function): Rename as...
111 (b4_c_function_def): this.
112 (b4_c_function_decl, b4_c_ansi_function_def)
113 (b4_c_ansi_function_decl): New.
114 Change the interpretation of the arguments: before `int, foo', now
115 `int foo, foo'.
116 * data/yacc.c (yyparse): Prototype and define thanks to these.
117 Adjust b4_c_function_def uses.
118 * data/glr.c (yyparse): Likewise, but ANSI only.
119
1202002-10-20 Akim Demaille <akim@epita.fr>
121
122 * src/output.c (prepare): Move the definition of `tokens_number',
123 `nterms_number', `undef_token_number', `user_token_number_max'
124 to...
125 (prepare_tokens): Here.
126 (prepare_tokens): Rename as...
127 (prepare_symbols): this.
128 (prepare): Move the definition of `rules_number' to...
129 (prepare_rules): here.
130 (prepare): Move the definition of `last', `final_state_number',
131 `states_number' to...
132 (prepare_states): here.
133 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
134
1352002-10-20 Akim Demaille <akim@epita.fr>
136
137 * src/tables.h, src/tables.c, src/output.c: Comment changes.
138
1392002-10-20 Akim Demaille <akim@epita.fr>
140
141 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
142 * data/c.m4: here.
143
1442002-10-20 Akim Demaille <akim@epita.fr>
145
146 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
147 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
148 `pair'.
149 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
150 `name' to...
151 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
152 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
153 These.
154
1552002-10-19 Paul Eggert <eggert@twinsun.com>
156
157 Do not create a temporary file, as that involves security and
158 cleanup headaches. Instead, use a pair of pipes.
159 Derived from a suggestion by Florian Krohm.
160 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
161 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
162 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
163 (BISON_PREREQ_SUBPIPE): Add.
164 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
165 Add subpipe.h, subpipe.c.
166 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
167 * po/POTFILES.in: Add lib/subpipe.c.
168 * src/output.c: Include "subpipe.h".
169 (m4_invoke): Remove decl.
170 (scan_skel): New decl.
171 (output_skeleton): Use pipe rather than temporary file for m4 input.
172 Check that m4sugar.m4 is readable, to avoid deadlock.
173 Check for pipe I/O error.
174 * src/scan-skel.l (readpipe): Remove decl.
175 (scan_skel): New function, to be used in place of m4_invoke.
176 Read from stream rather than file.
177
178 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
179 float, as this generates a warning on Solaris 8 + GCC 3.2 with
180 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
181 this generates a more-accurate value anyway.
182
183 * lib/timevar.c (timervar_accumulate): Rename locals to
184 avoid confusion with similarly-named more-global.
185 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
186
187 * src/output.c (prepare): Use xstrdup to convert char const *
188 to char *, to avoid GCC warning.
189
1902002-10-19 Akim Demaille <akim@epita.fr>
191
192 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
193 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
194 Use them to have `calc.y' ready for %pure-parser.
195 * data/yacc.c (YYLEX): Pass a yylex return type to
196 b4_c_function_call.
197
1982002-10-19 Akim Demaille <akim@epita.fr>
199
200 Prototype support of %lex-param and %parse-param.
201
202 * src/parse-gram.y: Add the definition of the %lex-param and
203 %parse-param tokens, plus their rules.
204 Drop the `_' version of %glr-parser.
205 Add the "," token.
206 * src/scan-gram.l (INITIAL): Scan them.
207 * src/muscle_tab.c: Comment changes.
208 (muscle_insert, muscle_find): Rename `pair' as `probe'.
209 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
210 (muscle_entry_s): The `value' member is no longer const.
211 Adjust all dependencies.
212 * src/muscle_tab.c (muscle_init): Adjust: use
213 MUSCLE_INSERT_STRING.
214 Initialize the obstack earlier.
215 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
216 (muscle_pair_list_grow): New.
217 * data/c.m4 (b4_c_function_call, b4_c_args): New.
218 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
219 * tests/calc.at: Use %locations, not --locations.
220 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
221
2222002-10-19 Akim Demaille <akim@epita.fr>
223
224 * src/getargs.c (usage): Take status as argument and exit
225 accordingly.
226 Report the traditional `Try ... --help' message when status != 0.
227 (usage, version): Don't take a FILE * as arg, it is pointless.
228 (getargs): When there is an incorrect number of arguments, make it
229 an error, and report it GNUlically thanks to `usage ()'.
230
2312002-10-18 Paul Eggert <eggert@twinsun.com>
232
233 * data/glr.c (yyreportParseError): Don't assume that sprintf
234 yields the length of the printed string, as this is not true
235 on SunOS 4.1.4. Reported by Peter Klein.
236
237 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
238 * tests/conflicts.at (%nonassoc and eof): Likewise.
239 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
240
2412002-10-17 Akim Demaille <akim@epita.fr>
242
243 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
244 * src/getargs.c (trace_types, trace_args): Adjust.
245 * src/reader.c (grammar_current_rule_prec_set)
246 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
247 Standardize error messages.
248 And s/@prec/%prec/!
249 (reader): Use trace_flag to enable scanner/parser debugging,
250 instead of an adhoc scheme.
251 * src/scan-gram.l: Remove trailing debugging code.
252
2532002-10-16 Paul Eggert <eggert@twinsun.com>
254
255 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
256 MUSCLE_TAB_H.
257
258 * NEWS: Officially drop support for building Bison with K&R C,
259 since it didn't work anyway and it's not worth worrying about.
260 * Makefile.maint (wget_files): Remove ansi2knr.c.
261 (ansi2knr.c-url_prefix): Remove.
262 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
263 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
264 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
265
2662002-10-15 Paul Eggert <eggert@twinsun.com>
267
268 Stop using the "enum_" trick for K&R-style function definitions;
269 it confused me, and I was the author! Instead, assume that people
270 who want to use K&R C compilers (when using these modules in GCC,
271 perhaps?) will run ansi2knr.
272
273 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
274 All uses of "enum_" changed to "enum ".
275 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
276 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
277
278 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
279 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
280 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
281 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
282 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
283 abitset_not, abitset_ones, abitset_or, abitset_or_and,
284 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
285 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
286 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
287 Use function prototypes; this removes the need for declaring
288 static functions simply to provide their prototypes.
289 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
290 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
291 bitset_count_, bitset_create, bitset_dump, bitset_first,
292 bitset_free, bitset_init, bitset_last, bitset_next,
293 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
294 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
295 bitset_print, bitset_release_memory, bitset_toggle_,
296 bitset_type_choose, bitset_type_get, bitset_type_name_get,
297 debug_bitset): Likewise.
298 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
299 * lib/bitset_stats.c (bitset_log_histogram_print,
300 bitset_percent_histogram_print, bitset_stats_and,
301 bitset_stats_and_cmp, bitset_stats_and_or,
302 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
303 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
304 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
305 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
306 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
307 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
308 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
309 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
310 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
311 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
312 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
313 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
314 bitset_stats_zero): Likewise.
315 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
316 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
317 bitsetv_dump, debug_bitsetv): Likewise.
318 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
319 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
320 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
321 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
322 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
323 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
324 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
325 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
326 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
327 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
328 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
329 Likewise.
330 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
331 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
332 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
333 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
334 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
335 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
336 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
337 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
338 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
339 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
340 lbitset_xor_cmp, lbitset_zero): Likewise.
341
3422002-10-14 Akim Demaille <akim@epita.fr>
343
344 Version 1.75.
345
3462002-10-14 Akim Demaille <akim@epita.fr>
347
348 * tests/Makefile.am (maintainer-check-posix): New.
349
3502002-10-14 Akim Demaille <akim@epita.fr>
351
352 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
353 member.
354
3552002-10-14 Akim Demaille <akim@epita.fr>
356
357 * src/tables.c (table_ninf_remap): base -> tab.
358 Reported by Matt Rosing.
359
3602002-10-14 Paul Eggert <eggert@twinsun.com>
361
362 * tests/action.at, tests/calc.at, tests/conflicts.at,
363 tests/cxx-type.at, tests/headers.at, tests/input.at,
364 tests/regression.at, tests/synclines.at, tests/torture.at:
365 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
366 so that the tests still work even if POSIXLY_CORRECT is set.
367 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
368
369 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
370 for portability to K&R hosts. Fix typo: signed char is guaranteed
371 only to 127, not to 128.
372 * data/glr.c (yysigned_char): New type.
373 * data/yacc.c (yysigned_char): Likewise.
374 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
375
3762002-10-13 Paul Eggert <eggert@twinsun.com>
377
378 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
379 true due to limited range of data type" warning from GCC.
380
381 * data/c.m4 (b4_token_defines): Protect against double-inclusion
382 by wrapping enum yytokentype's definition inside #ifndef
383 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
384
3852002-10-13 Akim Demaille <akim@epita.fr>
386
387 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
388 Un yy- yyrhs to avoid the name clash with the global YYRHS.
389
3902002-10-13 Akim Demaille <akim@epita.fr>
391
392 * Makefile.maint: Update from Autoconf 2.54.
393 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
394
3952002-10-13 Akim Demaille <akim@epita.fr>
396
397 * src/print.c (print_state): Separate the list of solved conflicts
398 from the other items.
399 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
400
4012002-10-13 Akim Demaille <akim@epita.fr>
402
403 Let nondeterministic skeletons be usable with deterministic
404 tables.
405
406 With the patch, GAWK compiled by GCC without -O2 passes its test
407 suite using a GLR parser driven by LALR tables. It fails with -O2
408 because `struct stat' gives two different answers on my machine:
409 88 (definition of an auto var) and later 96 (memset on this var).
410 Hence the stack is badly corrumpted. The headers inclusion is to
411 blame: if I move the awk.h inclusion before GLR's system header
412 inclusion, the two struct stat have the same size.
413
414 * src/tables.c (pack_table): Always create conflict_table.
415 (token_actions): Always create conflict_list.
416 * data/glr.c (YYFLAG): Remove, unused.
417
4182002-10-13 Akim Demaille <akim@epita.fr>
419
420 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
421 (O0FLAGS): New.
422 (VALGRIND, GXX): New.
423 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
424 * tests/bison.in: Run $PREBISON a pre-command.
425 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
426 (maintainer-check-g++): New.
427 * Makefile.am (maintainer-check): New.
428
4292002-10-13 Akim Demaille <akim@epita.fr>
430
431 * data/glr.c: Formatting changes.
432 Tweak some trace messages to match yacc.c's.
433
4342002-10-13 Akim Demaille <akim@epita.fr>
435
436 GLR parsers sometimes raise parse errors instead of performing the
437 default reduction.
438 Reported by Charles-Henry de Boysson.
439
440 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
441 check the length of the traces when %glr.
442 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
443 GLR's traces.
444 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
445 Test GLR parsers.
446 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
447 (yyltype): Remove the yy prefix from the member names.
448 (yytable): Complete its comment.
449 (yygetLRActions): Map error action number from YYTABLE from
450 YYTABLE_NINF to 0.
451 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
452 (which was a bug: it should have been YYTABEL_NINF, and yet it was
453 not satisfying as we could compare an YYACTION computed from
454 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
455 only value for error actions.
456 (yyreportParseError): In verbose parse error messages, don't issue
457 `error' in the list of expected tokens.
458 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
459 next action to perform to match glr.c's decoding.
460 (yytable): Complete its comment.
461
4622002-10-13 Paul Eggert <eggert@twinsun.com>
463
464 Fix problem reported by Henrik Grubbstroem in
465 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
466 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
467 because the Bison parser reads the second action before reducing
468 the first one.
469 * src/scan-gram.l (rule_length): New static var.
470 Use it to keep track of the rule length in the scanner, since
471 we can't expect the parser to be in lock-step sync with the scanner.
472 (handle_action_dollar, handle_action_at): Use this var.
473 * tests/actions.at (Exotic Dollars): Test for the problem.
474
4752002-10-12 Paul Eggert <eggert@twinsun.com>
476
477 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
478 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
479 Include <sys/time.h> when checking for clock_t and struct tms.
480 Use same include order as source.
481 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
482 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
483
484 * lib/timevar.c: Update copyright date and clarify comments.
485 (get_time) [IN_GCC]: Keep the GCC version for reference.
486
487 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
488 GCC version as of today, then merge Bison's changes.
489 Change "GCC" to "Bison" in copyright notice. timevar.def's
490 author is Akim, so change that too.
491
492 * src/reader.c (grammar_current_rule_check):
493 Don't worry about the default action if $$ is untyped.
494 Prevents bogus warnings reported by Jim Gifford in
495 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
496
497 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
498 * data/glr.c, data/lalr1.cc, data/yacc.c:
499 Output token definitions before the first part of user declarations.
500 Fixes compatibility problem reported by Jim Gifford for kbd in
501 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
502
5032002-10-11 Paul Eggert <eggert@twinsun.com>
504
505 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
506 (yyparse): here. This undoes some of the 2002-07-25 change.
507 Compatibility problem reported by Ralf S. Engelschall with
508 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
509
5102002-10-11 Akim Demaille <akim@epita.fr>
511
512 * tests/regression.at Characters Escapes): New.
513 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
514 characters.
515 Reported by Jan Nieuwenhuizen.
516
5172002-10-11 Akim Demaille <akim@epita.fr>
518
519 * po/id.po: New.
520
5212002-10-10 Paul Eggert <eggert@twinsun.com>
522
523 Portability fixes for bitsets; this also avoids several GCC
524 warnings.
525
526 * lib/abitset.c: Include <stddef.h>, for offsetof.
527 * lib/lbitset.c: Likewise.
528
529 * lib/abitset.c (abitset_bytes): Return a size that is aligned
530 properly for vectors of objects. Do not assume that adding a
531 header size to a multiple of a word size yields a value that is
532 properly aligned for the whole union.
533 * lib/bitsetv.c (bitsetv_alloc): Likewise.
534
535 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
536 unique names for structures.
537 * lib/ebitset.c (ebitset_bytes): Likewise.
538 * lib/lbitset.c (lbitset_bytes): Likewise.
539
540 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
541 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
542 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
543 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
544 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
545 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
546 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
547 to improve the type-checking that GCC can do.
548 * lib/bitset.c (bitset_op4_cmp): Likewise.
549 * lib/bitset_stats.c (bitset_stats_count,
550 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
551 bitset_stats_copy, bitset_stats_disjoint_p,
552 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
553 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
554 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
555 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
556 bitset_stats_and_or_cmp, bitset_stats_andn_or,
557 bitset_stats_andn_or_cmp, bitset_stats_or_and,
558 bitset_stats_or_and_cmp): Likewise.
559 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
560 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
561 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
562 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
563
564 * lib/abitset.h: Include bitset.h, not bbitset.h.
565 * lib/ebitset.h: Likewise.
566 * lib/lbitset.h: Likewise.
567
568 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
569 All instances of parameters of type enum bitset_opts are now of
570 type enum_bitset_opts, to conform to the C Standard, and similarly
571 for enum_bitset_type.
572 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
573 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
574
575 Do not use "struct bitset_struct" to mean different things in
576 different modules. Not only is this confusing, it violates
577 the C Standard, which requires that structure types in different
578 modules must be compatible if one is to be passed to the other.
579 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
580 All instances of "struct bitset_struct *" replaced with "bitset".
581 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
582 (union bitset_union, struct abitset_struct, struct ebitset_struct,
583 struct lbitset_struct, struct bitset_stats_struct): New types.
584 All uses of struct bitset_struct changed to union bitset_union,
585 etc.
586 * lib/abitset.c (struct abitset_struct, abitset,
587 struct bitset_struct): Remove.
588 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
589 struct bitset_struct): Remove.
590 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
591 bitset_struct): Remove.
592 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
593 Likewise.
594
595 Do not call a function of type T using a call that assumes the
596 function is of a different type U. Standard C requires that a
597 function must be called with a type that is compatible with its
598 definition.
599 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
600 New decls.
601 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
602 New functions.
603 * lib/ebitset.c (PFV): Remove.
604 * lib/lbitset.c (PFV): Likewise.
605 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
606 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
607 decls.
608 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
609 (ebitset_vtable): Use them.
610 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
611 lbitset_xor): New functions.
612 (lbitset_vtable): Use them.
613
614 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
615 Declare.
616
617 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
618 GCC warning.
619 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
620 Use offsetof, for simplicity.
621
6222002-10-06 Paul Eggert <eggert@twinsun.com>
623
624 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
625 the same width as int. This reapplies a hunk of the 2002-08-12 patch
626 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
627 which was inadvertently undone by the 2002-09-30 patch.
628 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
629 the same width as int.
630
6312002-10-04 Paul Eggert <eggert@twinsun.com>
632
633 Version 1.50.
634
635 * configure.ac (AC_INIT), NEWS: Increment version number.
636
637 * doc/bison.texinfo: Minor spelling, grammar, and white space
638 fixes.
639 (Symbols): Mention that any negative value returned from yylex
640 signifies end-of-input. Warn about negative chars. Mention
641 the portable Standard C character set.
642
643 The GNU coding standard says CFLAGS and YFLAGS are reserved
644 for the installer to set.
645 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
646 * src/Makefile.am (AM_CFLAGS): Likewise.
647 (AM_YFLAGS): Renamed from YFLAGS.
648
649 Fix some MAX and MIN problems.
650 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
651 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
652 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
653 * src/reader.c (reader): Use it.
654
655 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
656 POSIX 1003.1-2001 has removed fgrep.
657
6582002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
659
660 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
661 interpreted as signed.
662 * lib/ebitset.c (ebitset_list): Fix bug.
663
6642002-10-01 Paul Eggert <eggert@twinsun.com>
665
666 More fixes for 64-bit hosts and large bitsets.
667
668 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
669 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
670 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
671 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
672 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
673 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
674 bitset_count_): Likewise.
675 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
676 bitset_first, bitset_last): Likewise.
677 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
678 bitset_stats_list_reverse, bitset_stats_size,
679 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
680 Likewise.
681 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
682 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
683 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
684 bitsetv_reflexive_transitive_closure): Likewise.
685 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
686 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
687 Likewise.
688 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
689 Likewise.
690
691 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
692 Use size_t, not unsigned int, to count bytes.
693 * lib/abitset.h (abitset_bytes): Likewise.
694 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
695 Likewise.
696 * lib/bitset.h (bitset_bytes): Likewise.
697 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
698 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
699 * lib/bitsetv.c (bitsetv_alloc): Likewise.
700 * lib/ebitset.c (ebitset_bytes): Likewise.
701 * lib/ebitset.h (ebitset_bytes): Likewise.
702 * lib/lbitset.c (lbitset_bytes): Likewise.
703 * lib/lbitset.h (lbitset_bytes): Likewise.
704
705 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
706 abitset_subset_p, abitset_disjoint_p, abitset_and,
707 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
708 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
709 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
710 abitset_or_and, abitset_or_and_cmp):
711 Use bitset_windex instead of unsigned int.
712 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
713 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
714 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
715 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
716 Likewise.
717 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
718
719 * lib/bitset.c (bitset_print):
720 Use proper printf formats for widths of integer types.
721 * lib/bitset_stats.c (bitset_percent_histogram_print,
722 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
723 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
724 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
725 * lib/lbitset.c (lbitset_bytes): Likewise.
726
727 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
728 BITSET_SIZE_MAX): New macros.
729 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
730 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
731 to BITSET_WINDEX_MAX.
732
733 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
734 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
735 since we now return the bitset_bindex type (not int).
736
737 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
738 when computing sizes.
739 * lib/ebitset.c (ebitset_elts_grow): Likewise.
740
741 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
742 and avoid cast to unsigned.
743
7442002-09-30 Akim Demaille <akim@epita.fr>
745
746 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
747 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
748 Updates from Michael Hayes.
749
7502002-09-30 Art Haas <ahaas@neosoft.com>
751
752 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
753 invocations.
754 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
755 defined.
756
7572002-09-27 Akim Demaille <akim@epita.fr>
758
759 Version 1.49c.
760
7612002-09-27 Akim Demaille <akim@epita.fr>
762
763 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
764 (Because of AC_LIBSOURCE).
765
7662002-09-27 Akim Demaille <akim@epita.fr>
767
768 Playing with Autoscan.
769
770 * configure.ac: Remove the old LIBOBJ tweaks.
771 (AC_REPLACE_FUNCS): Add strrchr and strtol.
772 * lib/strrchr.c: New.
773 * lib/strtol.c: New, from the Coreutils 4.5.1.
774
7752002-09-27 Akim Demaille <akim@epita.fr>
776
777 Playing with Autoscan.
778
779 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
780 * lib/Makefile.am (libbison_a_SOURCES): No longer include
781 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
782 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
783 Coreutils 4.5.1.
784
7852002-09-24 Akim Demaille <akim@epita.fr>
786
787 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
788 (Frequently Asked Questions, Parser Stack Overflow): New.
789
7902002-09-13 Akim Demaille <akim@epita.fr>
791
792 Playing with autoscan.
793
794 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
795 * src/files.c (skeleton_find): Remove, unused.
796 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
797 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
798
7992002-09-13 Akim Demaille <akim@epita.fr>
800
801 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
802 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
803
8042002-09-13 Akim Demaille <akim@epita.fr>
805
806 * configure.ac: Require 2.54.
807 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
808 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
809 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
810 Remove, provided by Autoconf macros.
811
8122002-09-12 Akim Demaille <akim@epita.fr>
813
814 * m4/prereq.m4: Update, from Coreutils 4.5.1.
815
8162002-09-12 Akim Demaille <akim@epita.fr>
817
818 * m4/prereq.m4: Update, from Fileutils 4.1.5.
819 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
820 Reported by Martin Mokrejs.
821
8222002-09-10 Akim Demaille <akim@epita.fr>
823
824 * src/parse-gram.y: Associate a human readable string to each
825 token type.
826 * tests/regression.at (Invalid inputs): Adjust.
827
8282002-09-10 Gary V. Vaughan <gary@gnu.org>
829
830 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
831 with an Autoconf-2.5x style configure.ac.
832
8332002-09-06 Paul Eggert <eggert@twinsun.com>
834
835 * doc/bison.texinfo (Conditions): Make explicit that the GPL
836 exception applies only to yacc.c. This is a modification of a
837 patch originally suggested by Akim Demaille.
838
8392002-09-06 Akim Demaille <akim@epita.fr>
840
841 * data/c.m4 (b4_copyright): Move the GPL exception comment from
842 here to...
843 * data/yacc.c: here.
844
845 * data/lalr1.cc (struct yyltype): Don't define it, since we use
846 LocationType.
847 (b4_ltype): Default to yy::Location from location.hh.
848
8492002-09-04 Jim Meyering <jim@meyering.net>
850
851 * data/yacc.c: Guard the declaration of yytoknum also with
852 `#ifdef YYPRINT', so it is declared only when used.
853
8542002-09-04 Akim Demaille <akim@epita.fr>
855
856 * configure.in: Rename as...
857 * configure.ac: this.
858 Bump to 1.49c.
859
8602002-09-04 Akim Demaille <akim@epita.fr>
861
862 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
863 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
864 translate maintainer only messages.
865
8662002-08-12 Paul Eggert <eggert@twinsun.com>
867
868 Version 1.49b.
869
870 * Makefile.am (SUBDIRS): Remove intl.
871 (DISTCLEANFILES): Remove.
872 * NEWS: Mention that GNU M4 is now required. Clarify what is
873 meant by "larger grammars". Mention the pt_BR translation.
874 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
875 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
876 Bump version from 0.11.2 to 0.11.5.
877 (BISON_PREREQ_STAGE): Remove.
878 (AM_GNU_GETTEXT): Use external gettext.
879 (AC_OUTPUT): Remove intl/Makefile.
880
881 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
882
883 * data/glr.c: Include string.h, for strlen.
884 (yyreportParseError): Use size_t for yysize.
885 (yy_yypstack): No longer nested inside yypstates, as nested
886 functions are not portable. Do not assume size_t is the
887 same width as int.
888 (yypstates): Do not assume that ptrdiff_t is the same width
889 as int, and similarly for yyposn and YYINDEX.
890
891 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
892
893 * lib/Makefile.am (INCLUDES): Do not include from the intl
894 directory, which has been removed.
895 * src/Makefile.am (INCLUDES): Likewise.
896
897 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
898 (bitsets_sources, additional_bitsets_sources, timevars_sources):
899 New vars.
900
901 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
902 * tests/Makefile.am (EXTRA_DIST): Likewise.
903
904 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
905 Do not assume that bitset_windex is the same width as unsigned.
906
907 * lib/abitset.c (abitset_unused_clear): Do not assume that
908 bitset_word is the same width as int.
909 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
910 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
911 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
912 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
913 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
914
915 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
916 portability to one's complement hosts!).
917 * lib/ebitset.c (ebitset_op1): Likewise.
918 * lib/lbitset.c (lbitset_op1): Likewise.
919
920 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
921 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
922 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
923 Sync with fileutils.
924 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
925 lib/gettext.h: Sync with diffutils.
926
927 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
928 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
929
930 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
931 PROTOTYPES to check for prototypes, and "defined __STDC__" to
932 check for void *.
933
934 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
935 size_t; the old version tried to do this but casted improperly.
936 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
937 (bitset_test): Now returns int, not unsigned long.
938
939 * lib/bitset_stats.c: Include "gettext.h".
940 (_): New macro.
941 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
942 name locals "index", as it generates unnecessary warnings on some
943 hosts that have an "index" function.
944
945 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
946 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
947 they need translation.
948 * src/LR0.c (state_list_append, new_itemsets, get_state,
949 append_states, generate_states): Likewise.
950 * src/assoc.c (assoc_to_string): Likewise.
951 * src/closure.c (print_closure, set_firsts, closure): Likewise.
952 * src/gram.c (grammar_dump): Likewise.
953 * src/injections.c (injections_compute): Likewise.
954 * src/lalr.c (lookaheads_print): Likewise.
955 * src/relation.c (relation_transpose): Likewise.
956 * src/scan-gram.l: Likewise.
957 * src/tables.c (table_grow, pack_vector): Likewise.
958
959 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
960 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
961 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
962 * m4/mbstate_t.m4: Sync with fileutils.
963 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
964
965 * po/LINGUAS: Add pt_BR.
966 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
967 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
968 lib/timevar.c.
969 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
970 manual recommends.
971 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
972
973 * src/complain.c (strerror_r): Remove decl; not needed.
974 (strerror): Use same pattern as ../lib/error.c.
975
976 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
977
978 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
979
980 * src/main.c (main): Cast result of bindtextdomain and textdomain
981 to void, to avoid a GCC warning when --disable-nls is in effect.
982
983 * src/scan-gram.l: Use strings rather than escapes when possible,
984 to minimize the number of warnings from xgettext.
985 (handle_action_dollar, handle_action_at): Don't use isdigit,
986 as it mishandles negative chars and it may not work as expected
987 outside the C locale.
988
989 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
990 this is a GCC extension and is not portable to other compilers.
991
992 * src/system.h (alloca): Use same pattern as ../lib/error.c.
993 Do not include <ctype.h>; no longer needed.
994 Do not include <malloc.h>; no longer needed (and generates
995 warnings on OpenBSD 3.0).
996
997 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
998 it's not portable.
999
1000 * tests/regression.at: Do not use 'cc -c input.c -o input';
1001 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1002
1003 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1004 exit status as failure, not just exit status 1. Sun C exits
1005 with status 2 sometimes.
1006
1007 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1008 Use it for the two large tests.
1009
10102002-08-02 Akim Demaille <akim@epita.fr>
1011
1012 * src/conflicts.c (conflicts_output): Don't output rules never
1013 reduced here, since anyway that computation doesn't work.
1014 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1015 (rule_useless_p, rule_never_reduced_p): New.
1016 (grammar_rules_partial_print): Use a filter instead of a range.
1017 Display the title only if needed.
1018 (grammar_rules_print): Adjust.
1019 (grammar_rules_never_reduced_report): New.
1020 * src/tables.c (action_row): Move the computation of rules never
1021 reduced to...
1022 (token_actions): here.
1023 * src/main.c (main): Make the parser before making the report, so
1024 that rules never reduced are computed.
1025 Call grammar_rules_never_reduced_report.
1026 * src/print.c (print_results): Report rules never reduced.
1027 * tests/conflicts.at, tests/reduce.at: Adjust.
1028
10292002-08-01 Akim Demaille <akim@epita.fr>
1030
1031 Instead of attaching lookaheads and duplicating the rules being
1032 reduced by a state, attach the lookaheads to the reductions.
1033
1034 * src/state.h (state_t): Remove the `lookaheads',
1035 `lookaheads_rule' member.
1036 (reductions_t): Add a `lookaheads' member.
1037 Use a regular array for the `rules'.
1038 * src/state.c (reductions_new): Initialize the lookaheads member
1039 to 0.
1040 (state_rule_lookaheads_print): Adjust.
1041 * src/state.h, src/state.c (state_reductions_find): New.
1042 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1043 (count_rr_conflicts): Adjust.
1044 * src/lalr.c (LArule): Remove.
1045 (add_lookback_edge): Adjust.
1046 (state_lookaheads_count): New.
1047 (states_lookaheads_initialize): Merge into...
1048 (initialize_LA): this.
1049 (lalr_free): Adjust.
1050 * src/main.c (main): Don't free nullable and derives too early: it
1051 is used by --verbose.
1052 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1053
10542002-08-01 Akim Demaille <akim@epita.fr>
1055
1056 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1057 `rule_number_t**'.
1058 (set_derives, free_derives): Rename as...
1059 (derives_compute, derives_free): this.
1060 Adjust all dependencies.
1061 * src/nullable.c (set_nullable, free_nullable): Rename as...
1062 (nullable_compute, nullable_free): these.
1063 (rule_list_t): Store rule_t *, not rule_number_t.
1064 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1065 pointers, instead of their numbers.
1066 * src/main.c (main): Call nullable_free, and derives_free earlier,
1067 as they were lo longer used.
1068
10692002-08-01 Akim Demaille <akim@epita.fr>
1070
1071 * lib/timevar.c (get_time): Include children time.
1072 * src/lalr.h (LA, LArule): Don't export them: used with the
1073 state_t.
1074 * src/lalr.c (LA, LArule): Static.
1075 * src/lalr.h, src/lalr.c (lalr_free): New.
1076 * src/main.c (main): Call it.
1077 * src/tables.c (pack_vector): Check whether loc is >= to the
1078 table_size, not >.
1079 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1080 (tables_generate): do it, since that's also it which allocates
1081 them.
1082 Don't free LA and LArule, main does.
1083
10842002-07-31 Akim Demaille <akim@epita.fr>
1085
1086 Separate parser tables computation and output.
1087
1088 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1089 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1090 (yydefgoto, yydefact, high): Move to...
1091 * src/tables.h, src/tables.c: here.
1092 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1093 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1094 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1095 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1096 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1097 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1098 (action_row, save_row, token_actions, save_column, default_goto)
1099 (goto_actions, sort_actions, matching_state, pack_vector)
1100 (table_ninf_remap, pack_table, prepare_actions): Move to...
1101 * src/tables.c: here.
1102 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1103 * src/output.c (token_actions, output_base, output_conflicts)
1104 (output_check): Merge into...
1105 (prepare_actions): this.
1106 (actions_output): Rename as...
1107 (user_actions_output): this.
1108 * src/main.c (main): Call tables_generate and tables_free.
1109
11102002-07-31 Akim Demaille <akim@epita.fr>
1111
1112 Steal GCC's --time-report support.
1113
1114 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1115 stolen/adjusted from GCC.
1116 * m4/stage.m4: Remove time related checks.
1117 * m4/timevar.m4: New.
1118 * configure.in: Adjust.
1119 * src/system.h: Adjust to using timevar.h.
1120 * src/getargs.h, src/getargs.c: Support trace_time for
1121 --trace=time.
1122 * src/main.c (stage): Remove.
1123 (main): Replace `stage' invocations with timevar calls.
1124 * src/output.c: Insert pertinent timevar calls.
1125
11262002-07-31 Akim Demaille <akim@epita.fr>
1127
1128 Let --trace have arguments.
1129
1130 * src/getargs.h (enum trace_e): New.
1131 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1132 (long_options, short_options): --trace/-T takes an optional
1133 argument.
1134 Change all the uses of trace_flag to reflect the new flags.
1135 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1136
1137 Strengthen `stage' portability.
1138
1139 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1140 * configure.in: Use it.
1141 Don't check for malloc.h and sys/times.h.
1142 * src/system.h: Include them when appropriate.
1143 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1144 times and struct tms are available.
1145
11462002-07-30 Akim Demaille <akim@epita.fr>
1147
1148 In verbose parse error message, don't report `error' as an
1149 expected token.
1150 * tests/actions.at (Printers and Destructors): Adjust.
1151 * tests/calc.at (Calculator $1): Adjust.
1152 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1153 error message, do not report the parser accepts the error token in
1154 that state.
1155
11562002-07-30 Akim Demaille <akim@epita.fr>
1157
1158 Normalize conflict related messages.
1159
1160 * src/complain.h, src/complain.c (warn, complain): New.
1161 * src/conflicts.c (conflicts_print): Use them.
1162 (conflict_report_yacc): New, extracted from...
1163 (conflicts_print): here.
1164 * tests/conflicts.at, tests/existing.at: Adjust.
1165
11662002-07-30 Akim Demaille <akim@epita.fr>
1167
1168 Report rules which are never reduced by the parser: those hidden
1169 by conflicts.
1170
1171 * src/LR0.c (save_reductions): Don't make the final state too
1172 different: save its reduction (accept) instead of having a state
1173 without any action (no shift or goto, no reduce).
1174 Note: the final state is now a ``regular'' state, i.e., the
1175 parsers now contain `reduce 0' as default reduction.
1176 Nevertheless, since they decide to `accept' when yystate =
1177 final_state, they still will not reduce rule 0.
1178 * src/print.c (print_actions, print_reduction): Adjust.
1179 * src/output.c (action_row): Track reduced rules.
1180 (token_actions): Report rules never reduced.
1181 * tests/conflicts.at, tests/regression.at: Adjust.
1182
11832002-07-30 Akim Demaille <akim@epita.fr>
1184
1185 `stage' was accidently included in a previous patch.
1186 Initiate its autoconfiscation.
1187
1188 * configure.in: Look for malloc.h and sys/times.h.
1189 * src/main.c (stage): Adjust.
1190 Report only when trace_flag.
1191
11922002-07-29 Akim Demaille <akim@epita.fr>
1193
1194 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1195 state_number_t.
1196 (errs_t): symbol_t*, not symbol_number_t.
1197 (reductions_t): rule_t*, not rule_number_t.
1198 (FOR_EACH_SHIFT): New.
1199 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1200 * src/print.c, src/print_graph.c: Adjust.
1201
12022002-07-29 Akim Demaille <akim@epita.fr>
1203
1204 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1205
1206 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1207 (endtoken, accept): these.
1208 * src/reader.c (reader): Set endtoken's default tag to "$end".
1209 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1210 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1211 Adjust.
1212
12132002-07-29 Akim Demaille <akim@epita.fr>
1214
1215 * src/reduce.c (reduce_grammar): When the language is empty,
1216 complain about the start symbol, not the axiom.
1217 Use its location.
1218 * tests/reduce.at (Empty Language): New.
1219
12202002-07-26 Akim Demaille <akim@epita.fr>
1221
1222 * src/reader.h, src/reader.c (gram_error): ... can't get
1223 yycontrol without making too strong assumptions on the parser
1224 itself.
1225 * src/output.c (prepare_tokens): Use the real 0th value of
1226 token_translations instead of `0'.
1227 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1228 visible here.
1229 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1230 for the time being: %locations ought to provide it to yyerror.
1231
12322002-07-25 Akim Demaille <akim@epita.fr>
1233
1234 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1235 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1236 * tests/regression.at (Web2c Actions): Adjust.
1237
12382002-07-25 Akim Demaille <akim@epita.fr>
1239
1240 Stop storing rules from 1 to nrules + 1.
1241
1242 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1243 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1244 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1245 Iterate from 0 to nrules.
1246 Use rule_number_as_item_number and item_number_as_rule_number.
1247 Adjust to `derive' now containing possibly 0.
1248 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1249 Handle the `- 1' part in rule numbers from/to item numbers.
1250 * src/conflicts.c (log_resolution): Fix the message which reversed
1251 shift and reduce.
1252 * src/output.c (action_row): Initialize default_rule to -1.
1253 (token_actions): Adjust.
1254 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1255 expected output.
1256 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1257
12582002-07-25 Akim Demaille <akim@epita.fr>
1259
1260 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1261 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1262 (b4_c_knr_arg_decl): New.
1263 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1264 yyreport_parse_error.
1265
12662002-07-25 Akim Demaille <akim@epita.fr>
1267
1268 * data/yacc.c (yyreport_parse_error): New, extracted from...
1269 (yyparse): here.
1270 (yydestruct, yysymprint): Move above yyparse.
1271 Be K&R compliant.
1272
12732002-07-25 Akim Demaille <akim@epita.fr>
1274
1275 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1276 replace...
1277 (b4_sint_type, b4_uint_type): these.
1278 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1279 * tests/regression.at (Web2c Actions): Adjust.
1280
12812002-07-25 Akim Demaille <akim@epita.fr>
1282
1283 * src/gram.h (TIEM_NUMBER_MAX): New.
1284 (item_number_of_rule_number, rule_number_of_item_number): Rename
1285 as...
1286 (rule_number_as_item_number, item_number_as_rule_number): these.
1287 Adjust dependencies.
1288 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1289 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1290 (symbol_number_to_vector_number): New.
1291 (order): Of vector_number_t* type.
1292 (base_t, BASE_MAX, BASE_MIN): New.
1293 (froms, tos, width, pos, check): Of base_t type.
1294 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1295 (actrow): Of action_number_t type.
1296 (conflrow): Of unsigned int type.
1297 (table_ninf, base_ninf): New.
1298 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1299 (muscle_insert_int_table, muscle_insert_base_table)
1300 (muscle_insert_rule_number_table): New.
1301 (prepare_tokens): Output `toknum' as int_table.
1302 (action_row): Returns a rule_number_t.
1303 Use ACTION_MIN, not SHRT_MIN.
1304 (token_actions): yydefact is rule_number_t*.
1305 (table_ninf_remap): New.
1306 (pack_table): Use it for `base' and `table'.
1307 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1308 replaced with...
1309 (YYPACT_NINF, YYTABLE_NINF): these.
1310 (yypact, yytable): Compute their types instead of hard-coded
1311 `short'.
1312 * tests/regression.at (Web2c Actions): Adjust.
1313
13142002-07-19 Akim Demaille <akim@epita.fr>
1315
1316 * src/scan-gram.l (id): Can start with an underscore.
1317
13182002-07-16 Akim Demaille <akim@epita.fr>
1319
1320 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
1321 Adjust all former `associativity' dependencies.
1322 * src/symtab.c (symbol_new): Default associativity is `undef', not
1323 `right'.
1324 (symbol_check_alias_consistence): Adjust.
1325
13262002-07-09 Akim Demaille <akim@epita.fr>
1327
1328 * doc/bison.texinfo: Properly set the ``header'' part.
1329 Use @dircategory ``GNU programming tools'' as per Texinfo's
1330 documentation.
1331 Use @copying.
1332
13332002-07-09 Akim Demaille <akim@epita.fr>
1334
1335 * lib/quotearg.h: Protect against multiple inclusions.
1336 * src/location.h (location_t): Add a `file' member.
1337 (LOCATION_RESET, LOCATION_PRINT): Adjust.
1338 * src/complain.c (warn_at, complain_at, fatal_at): Drop
1339 `error_one_per_line' support.
1340
13412002-07-09 Akim Demaille <akim@epita.fr>
1342
1343 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
1344 * src/reader.c (lineno): Remove.
1345 Adjust all dependencies.
1346 (get_merge_function): Take a location and use complain_at.
1347 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
1348 * tests/regression.at (Invalid inputs, Mixing %token styles):
1349 Adjust.
1350
13512002-07-09 Akim Demaille <akim@epita.fr>
1352
1353 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
1354 recovery rule, and forbid extensions when --yacc.
1355 (gram_error): Use complain_at.
1356 * src/reader.c (reader): Exit if there were parse errors.
1357
13582002-07-09 Akim Demaille <akim@epita.fr>
1359
1360 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
1361 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
1362 Reported by R Blake <blakers@mac.com>.
1363
13642002-07-09 Akim Demaille <akim@epita.fr>
1365
1366 * data/yacc.c: Output the copyright notive in the header.
1367
13682002-07-03 Akim Demaille <akim@epita.fr>
1369
1370 * src/output.c (froms, tos): Are state_number_t.
1371 (save_column): sp, sp1, and sp2 are state_number_t.
1372 (prepare): Rename `final' as `final_state_number', `nnts' as
1373 `nterms_number', `nrules' as `rules_number', `nstates' as
1374 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
1375 unused.
1376 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
1377 * data/lalr1.cc (nsym_): Remove, unused.
1378
13792002-07-03 Akim Demaille <akim@epita.fr>
1380
1381 * src/lalr.h, src/lalr.c (goto_number_t): New.
1382 * src/lalr.c (goto_list_t): New.
1383 Propagate them.
1384 * src/nullable.c (rule_list_t): New.
1385 Propagate.
1386 * src/types.h: Remove.
1387
13882002-07-03 Akim Demaille <akim@epita.fr>
1389
1390 * src/closure.c (print_fderives): Use rule_rhs_print.
1391 * src/derives.c (print_derives): Use rule_rhs_print.
1392 (rule_list_t): New, replaces `shorts'.
1393 (set_derives): Add comments.
1394 * tests/sets.at (Nullable, Firsts): Adjust.
1395
13962002-07-03 Akim Demaille <akim@epita.fr>
1397
1398 * src/output.c (prepare_actions): Free `tally' and `width'.
1399 (prepare_actions): Allocate and free `order'.
1400 * src/symtab.c (symbols_free): Free `symbols'.
1401 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
1402 * src/output.c (m4_invoke): Move to...
1403 * src/scan-skel.l: here.
1404 (<<EOF>>): Close yyout, and free its name.
1405
14062002-07-03 Akim Demaille <akim@epita.fr>
1407
1408 Fix some memory leaks, and fix a bug: state 0 was examined twice.
1409
1410 * src/LR0.c (new_state): Merge into...
1411 (state_list_append): this.
1412 (new_states): Merge into...
1413 (generate_states): here.
1414 (set_states): Don't ensure a proper `errs' state member here, do it...
1415 * src/conflicts.c (conflicts_solve): here.
1416 * src/state.h, src/state.c: Comment changes.
1417 (state_t): Rename member `shifts' as `transitions'.
1418 Adjust all dependencies.
1419 (errs_new): For consistency, also take the values as argument.
1420 (errs_dup): Remove.
1421 (state_errs_set): New.
1422 (state_reductions_set, state_transitions_set): Assert that no
1423 previous value was assigned.
1424 (state_free): New.
1425 (states_free): Use it.
1426 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
1427 temporary storage: use `errs' and `nerrs' as elsewhere.
1428 (set_conflicts): Allocate and free this `errs'.
1429
14302002-07-02 Akim Demaille <akim@epita.fr>
1431
1432 * lib/libiberty.h: New.
1433 * lib: Update the bitset implementation from upstream.
1434 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
1435 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
1436 * src/main.c: Adjust bitset stats calls.
1437
14382002-07-01 Paul Eggert <eggert@twinsun.com>
1439
1440 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
1441 char, so that negative chars don't collide with $.
1442
14432002-06-30 Akim Demaille <akim@epita.fr>
1444
1445 Have the GLR tests be `warning' checked, and fix the warnings.
1446
1447 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
1448 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
1449 (yyremoveDeletes): `yyi' and `yyj' are size_t.
1450 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
1451 (yyaddDeferredAction): static.
1452 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
1453 (yyreportParseError): yyprefix is const.
1454 yytokenp is used only when verbose.
1455 (yy__GNUC__): Replace with __GNUC__.
1456 (yypdumpstack): yyi is size_t.
1457 (yypreference): Un-yy local variables and arguments, to avoid
1458 clashes with `yyr1'. Anyway, we are not in the user name space.
1459 (yytname_size): be an int, as is compared with ints.
1460 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
1461 Use them.
1462 * tests/cxx-gram.at: Use quotation to protect $1.
1463 Use AT_COMPILE to enable warnings hunts.
1464 Prototype yylex and yyerror.
1465 `Use' argc.
1466 Include `string.h', not `strings.h'.
1467 Produce and prototype stmtMerge only when used.
1468 yylex takes a location.
1469
14702002-06-30 Akim Demaille <akim@epita.fr>
1471
1472 We spend a lot of time in quotearg, in particular when --verbose.
1473
1474 * src/symtab.c (symbol_get): Store a quoted version of the key.
1475 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
1476 Adjust all callers.
1477
14782002-06-30 Akim Demaille <akim@epita.fr>
1479
1480 * src/state.h (reductions_t): Rename member `nreds' as num.
1481 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
1482 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
1483
14842002-06-30 Akim Demaille <akim@epita.fr>
1485
1486 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
1487 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
1488 (shifts_to): Rename as...
1489 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1490 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1491 (TRANSITION_IS_DISABLED, transitions_to): these.
1492
14932002-06-30 Akim Demaille <akim@epita.fr>
1494
1495 * src/print.c (print_shifts, print_gotos): Merge into...
1496 (print_transitions): this.
1497 (print_transitions, print_errs, print_reductions): Align the
1498 lookaheads columns.
1499 (print_core, print_transitions, print_errs, print_state,
1500 print_grammar): Output empty lines separator before, not after.
1501 (state_default_rule_compute): Rename as...
1502 (state_default_rule): this.
1503 * tests/conflicts.at (Defaulted Conflicted Reduction),
1504 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1505 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1506
15072002-06-30 Akim Demaille <akim@epita.fr>
1508
1509 Display items as we display rules.
1510
1511 * src/gram.h, src/gram.c (rule_lhs_print): New.
1512 * src/gram.c (grammar_rules_partial_print): Use it.
1513 * src/print.c (print_core): Likewise.
1514 * tests/conflicts.at (Defaulted Conflicted Reduction),
1515 (Unresolved SR Conflicts): Adjust.
1516 (Unresolved SR Conflicts): Adjust and rename as...
1517 (Resolved SR Conflicts): this, as was meant.
1518 * tests/regression.at (Web2c Report): Adjust.
1519
15202002-06-30 Akim Demaille <akim@epita.fr>
1521
1522 * src/print.c (state_default_rule_compute): New, extracted from...
1523 (print_reductions): here.
1524 Pessimize, but clarify the code.
1525 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1526
15272002-06-30 Akim Demaille <akim@epita.fr>
1528
1529 * src/output.c (action_row): Let default_rule be always a rule
1530 number.
1531
15322002-06-30 Akim Demaille <akim@epita.fr>
1533
1534 * src/closure.c (print_firsts, print_fderives, closure):
1535 Use BITSET_EXECUTE.
1536 * src/lalr.c (lookaheads_print): Likewise.
1537 * src/state.c (state_rule_lookaheads_print): Likewise.
1538 * src/print_graph.c (print_core): Likewise.
1539 * src/print.c (print_reductions): Likewise.
1540 * src/output.c (action_row): Likewise.
1541 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1542
15432002-06-30 Akim Demaille <akim@epita.fr>
1544
1545 * src/print_graph.c: Use report_flag.
1546
15472002-06-30 Akim Demaille <akim@epita.fr>
1548
1549 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1550 to...
1551 * src/relation.h, src/relation.c (traverse, relation_digraph)
1552 (relation_print, relation_transpose): New.
1553
15542002-06-30 Akim Demaille <akim@epita.fr>
1555
1556 * src/state.h, src/state.c (shifts_to): New.
1557 * src/lalr.c (build_relations): Use it.
1558
15592002-06-30 Akim Demaille <akim@epita.fr>
1560
1561 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1562 (item_number_of_rule_number, rule_number_of_item_number): New.
1563 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1564 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1565 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1566 Propagate their use.
1567 Much remains to be done, in particular wrt `shorts' from types.h.
1568
15692002-06-30 Akim Demaille <akim@epita.fr>
1570
1571 * src/symtab.c (symbol_new): Initialize the `printer' member.
1572
15732002-06-30 Akim Demaille <akim@epita.fr>
1574
1575 * src/LR0.c (save_reductions): Remove, replaced by...
1576 * src/state.h, src/state.c (state_reductions_set): New.
1577 (reductions, errs): Rename as...
1578 (reductions_t, errs_t): these.
1579 Adjust all dependencies.
1580
15812002-06-30 Akim Demaille <akim@epita.fr>
1582
1583 * src/LR0.c (state_list_t, state_list_append): New.
1584 (first_state, last_state): Now symbol_list_t.
1585 (this_state): Remove.
1586 (new_itemsets, append_states, save_reductions): Take a state_t as
1587 argument.
1588 (set_states, generate_states): Adjust.
1589 (save_shifts): Remove, replaced by...
1590 * src/state.h, src/state.c (state_shifts_set): New.
1591 (shifts): Rename as...
1592 (shifts_t): this.
1593 Adjust all dependencies.
1594 * src/state.h (state_t): Remove the `next' member.
1595
15962002-06-30 Akim Demaille <akim@epita.fr>
1597
1598 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1599 escaped in slot 0.
1600
16012002-06-30 Akim Demaille <akim@epita.fr>
1602
1603 Use hash.h for the state hash table.
1604
1605 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1606 (allocate_storage): Use state_hash_new.
1607 (free_storage): Use state_hash_free.
1608 (new_state, get_state): Adjust.
1609 * src/lalr.h, src/lalr.c (states): Move to...
1610 * src/states.h (state_t): Remove the `link' member, no longer
1611 used.
1612 * src/states.h, src/states.c: here.
1613 (state_hash_new, state_hash_free, state_hash_lookup)
1614 (state_hash_insert, states_free): New.
1615 * src/states.c (state_table, state_compare, state_hash): New.
1616 * src/output.c (output_actions): Do not free states now, since we
1617 still need to know the final_state number in `prepare', called
1618 afterwards. Do it...
1619 * src/main.c (main): here: call states_free after `output'.
1620
16212002-06-30 Akim Demaille <akim@epita.fr>
1622
1623 * src/state.h, src/state.c (state_new): New, extracted from...
1624 * src/LR0.c (new_state): here.
1625 * src/state.h (STATE_ALLOC): Move to...
1626 * src/state.c: here.
1627 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1628 * src/state.h, src/state.c: here.
1629
16302002-06-30 Akim Demaille <akim@epita.fr>
1631
1632 * src/reader.c (gensym): Rename as...
1633 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1634 (getsym): Rename as...
1635 (symbol_get): this.
1636
16372002-06-30 Akim Demaille <akim@epita.fr>
1638
1639 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1640 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1641 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1642 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1643
16442002-06-30 Akim Demaille <akim@epita.fr>
1645
1646 Make the test suite pass with warnings checked.
1647
1648 * tests/actions.at (Printers and Destructors): Improve.
1649 Avoid unsigned vs. signed issues.
1650 * tests/calc.at: Don't exercise the scanner here, do it...
1651 * tests/input.at (Torturing the Scanner): here.
1652
16532002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1654
1655 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
1656 reorganize first lines parallel to yacc.c.
1657
16582002-06-28 Akim Demaille <akim@epita.fr>
1659
1660 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1661 (b4_token_enum, b4_token_defines): New, factored from...
1662 * data/lalr1.cc, data/yacc.c, glr.c: here.
1663
16642002-06-28 Akim Demaille <akim@epita.fr>
1665
1666 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1667 unused variables.
1668 * src/output.c (merger_output): static.
1669
16702002-06-28 Akim Demaille <akim@epita.fr>
1671
1672 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1673 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1674 pacify GCC.
1675 * src/output.c (save_row): Initialize all the variables to pacify GCC.
1676
16772002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1678
1679 Accumulated changelog for new GLR parsing features.
1680
1681 * src/conflicts.c (count_total_conflicts): Change name to
1682 conflicts_total_count.
1683 * src/conflicts.h: Ditto.
1684 * src/output.c (token_actions): Use the new name.
1685 (output_conflicts): Change conflp => conflict_list_heads, and
1686 confl => conflict_list for better readability.
1687 * data/glr.c: Use the new names.
1688 * NEWS: Add self to GLR announcement.
1689
1690 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1691
1692 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1693 Akim Demaille.
1694
1695 * data/bison.glr: Change name to glr.c
1696 * data/glr.c: Renamed from bison.glr.
1697 * data/Makefile.am: Add glr.c
1698
1699 * src/getargs.c:
1700
1701 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1702 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
1703
1704 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1705
1706 * data/bison.glr: Be sure to restore the
1707 current #line when returning to the skeleton contents after having
1708 exposed the input file's #line.
1709
1710 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1711
1712 * data/bison.glr: Bring up to date with changes to bison.simple.
1713
1714 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1715
1716 * data/bison.glr: Correct definitions that use b4_prefix.
1717 Various reformatting.
1718 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1719 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1720 yytokenp argument; now part of stack.
1721 (yychar): Define to behave as documented.
1722 (yyclearin): Ditto.
1723
1724 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1725
1726 * src/reader.h: Add declaration for free_merger_functions.
1727
1728 * src/reader.c (merge_functions): New variable.
1729 (get_merge_function): New function.
1730 (free_merger_functions): New function.
1731 (readgram): Check for %prec that is not followed by a symbol.
1732 Handle %dprec and %merge declarations.
1733 (packgram): Initialize dprec and merger fields in rules array.
1734
1735 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1736 conflict_list_cnt, conflict_list_free): New variables.
1737 (table_grow): Also grow conflict_table.
1738 (prepare_rules): Output dprec and merger tables.
1739 (conflict_row): New function.
1740 (action_row): Output conflict lists for GLR parser. Don't use
1741 default reduction in conflicted states for GLR parser so that there
1742 are spaces for the conflict lists.
1743 (save_row): Also save conflict information.
1744 (token_actions): Allocate conflict list.
1745 (merger_output): New function.
1746 (pack_vector): Pack conflict table, too.
1747 (output_conflicts): New function to output yyconflp and yyconfl.
1748 (output_check): Allocate conflict_tos.
1749 (output_actions): Output conflict tables, also.
1750 (output_skeleton): Output b4_mergers definition.
1751 (prepare): Output b4_max_rhs_length definition.
1752 Use 'bison.glr' as default skeleton for GLR parsers.
1753
1754 * src/gram.c (glr_parser): New flag.
1755 (grammar_free): Call free_merger_functions.
1756
1757 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1758 all pairs of conflicting reductions, rather than just all tokens
1759 causing conflicts. Needed to size conflict tables.
1760 (conflicts_output): Modify call to count_rr_conflicts for new
1761 interface.
1762 (conflicts_print): Ditto.
1763 (count_total_conflicts): New function.
1764
1765 * src/reader.h (merger_list): New type.
1766 (merge_functions): New variable.
1767
1768 * src/lex.h (tok_dprec, tok_merge): New token types.
1769
1770 * src/gram.h (rule_s): Add dprec and merger fields.
1771 (glr_parser): New flag.
1772
1773 * src/conflicts.h (count_total_conflicts): New function.
1774
1775 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1776
1777 * doc/bison.texinfo (Generalized LR Parsing): New section.
1778 (GLR Parsers): New section.
1779 (Language and Grammar): Mention GLR parsing.
1780 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1781 Correct typo ("tge" -> "the").
1782
1783 * data/bison.glr: New skeleton for GLR parsing.
1784
1785 * tests/cxx-gram.at: New tests for GLR parsing.
1786
1787 * tests/testsuite.at: Include cxx-gram.at.
1788
1789 * tests/Makefile.am: Add cxx-gram.at.
1790
1791 * src/parse-gram.y:
1792
1793 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1794
1795 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
1796
17972002-06-27 Akim Demaille <akim@epita.fr>
1798
1799 * src/options.h, src/options.c: Remove.
1800 * src/getargs.c (short_options, long_options): New.
1801
18022002-06-27 Akim Demaille <akim@epita.fr>
1803
1804 * data/bison.simple, data/bison.c++: Rename as...
1805 * data/yacc.c, data/lalr1.cc: these.
1806 * doc/bison.texinfo (Environment Variables): Remove.
1807
18082002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1809
1810 * src/getargs.c (report_argmatch): Initialize strtok().
1811
18122002-06-20 Akim Demaille <akim@epita.fr>
1813
1814 * data/bison.simple (b4_symbol_actions): New, replaces...
1815 (b4_symbol_destructor, b4_symbol_printer): these.
1816 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1817 user token numbers.
1818
18192002-06-20 Akim Demaille <akim@epita.fr>
1820
1821 * data/bison.simple (yydestructor): Rename as...
1822 (yydestruct): this.
1823
18242002-06-20 Akim Demaille <akim@epita.fr>
1825
1826 * src/symtab.h, src/symtab.c (symbol_type_set)
1827 (symbol_destructor_set, symbol_precedence_set): The location is
1828 the last argument.
1829 Adjust all callers.
1830
18312002-06-20 Akim Demaille <akim@epita.fr>
1832
1833 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1834 internals.
1835 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1836 Takes a location.
1837 * src/symtab.h, src/symtab.c (symbol_class_set)
1838 (symbol_user_token_number_set): Likewise.
1839 Adjust all callers.
1840 Promote complain_at.
1841 * tests/input.at (Type Clashes): Adjust.
1842
18432002-06-20 Akim Demaille <akim@epita.fr>
1844
1845 * data/bison.simple (YYLEX): Fix the declaration when
1846 %pure-parser.
1847
18482002-06-20 Akim Demaille <akim@epita.fr>
1849
1850 * data/bison.simple (yysymprint): Don't print the token number,
1851 just its name.
1852 * tests/actions.at (Destructors): Rename as...
1853 (Printers and Destructors): this.
1854 Also exercise %printer.
1855
18562002-06-20 Akim Demaille <akim@epita.fr>
1857
1858 * data/bison.simple (YYDSYMPRINT): New.
1859 Use it to remove many of the #if YYDEBUG/if (yydebug).
1860
18612002-06-20 Akim Demaille <akim@epita.fr>
1862
1863 * src/symtab.h, src/symtab.c (symbol_t): printer and
1864 printer_location are new members.
1865 (symbol_printer_set): New.
1866 * src/parse-gram.y (PERCENT_PRINTER): New token.
1867 Handle its associated rule.
1868 * src/scan-gram.l: Adjust.
1869 (handle_destructor_at, handle_destructor_dollar): Rename as...
1870 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1871 * src/output.c (symbol_printers_output): New.
1872 (output_skeleton): Call it.
1873 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1874 since there are already many grammar files with a user `yyprint'.
1875 Replace the calls to YYPRINT to calls to yysymprint.
1876 * tests/calc.at: Adjust.
1877 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1878 taking advantage of parser very internal details (stack size!).
1879
18802002-06-20 Akim Demaille <akim@epita.fr>
1881
1882 * src/scan-gram.l: Complete the scanner with the missing patterns
1883 to pacify Flex.
1884 Use `quote' and `symbol_tag_get' where appropriate.
1885
18862002-06-19 Akim Demaille <akim@epita.fr>
1887
1888 * tests/actions.at (Destructors): Augment to test locations.
1889 * data/bison.simple (yydestructor): Pass it the current location
1890 if locations are enabled.
1891 Prototype only when __STDC__ or C++.
1892 Change the argument names to move into the yy name space: there is
1893 user code here.
1894
18952002-06-19 Akim Demaille <akim@epita.fr>
1896
1897 * data/bison.simple (b4_pure_if): New.
1898 Use it instead of #ifdef YYPURE.
1899
19002002-06-19 Akim Demaille <akim@epita.fr>
1901
1902 * data/bison.simple (b4_location_if): New.
1903 Use it instead of #ifdef YYLSP_NEEDED.
1904
19052002-06-19 Akim Demaille <akim@epita.fr>
1906
1907 Prepare @$ in %destructor, but currently don't bind it in the
1908 skeleton, as %location use is not cleaned up yet.
1909
1910 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1911 (handle_action_at): New.
1912 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1913 a braced_code_t and a location as additional arguments.
1914 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1915 unquote one when outputting `b4_dollar_dollar'.
1916 Adjust callers.
1917 * data/bison.simple (b4_eval): Remove.
1918 (b4_symbol_destructor): Adjust.
1919 * tests/input.at (Invalid @n): Adjust.
1920
19212002-06-19 Zack Weinberg <zack@codesourcery.com>
1922
1923 * doc/bison.texinfo: Document ability to have multiple
1924 prologue sections.
1925
19262002-06-18 Akim Demaille <akim@epita.fr>
1927
1928 * src/files.c (compute_base_names): When computing the output file
1929 names from the input file name, strip the directory part.
1930
19312002-06-18 Akim Demaille <akim@epita.fr>
1932
1933 * data/bison.simple.new: Comment changes.
1934 Reported by Andreas Schwab.
1935
19362002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1937
1938 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1939 there are no `label `yyoverflowlab' defined but not used' warnings
1940 when yyoverflow is defined.
1941
19422002-06-18 Akim Demaille <akim@epita.fr>
1943
1944 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1945 new member.
1946 (symbol_destructor_set): Adjust.
1947 * src/output.c (symbol_destructors_output): Output the destructor
1948 locations.
1949 Output the symbol name.
1950 * data/bison.simple (b4_symbol_destructor): Adjust.
1951
19522002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1953 and Akim Demaille <akim@epita.fr>
1954
1955 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1956 what's left on the stack when the error recovery hits EOF.
1957 * tests/actions.at (Destructors): Complete to exercise this case.
1958
19592002-06-17 Akim Demaille <akim@epita.fr>
1960
1961 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1962 arguments is really empty, not only equal to `[]'.
1963 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1964 member.
1965 (symbol_destructor_set): New.
1966 * src/output.c (symbol_destructors_output): New.
1967 * src/reader.h (brace_code_t, current_braced_code): New.
1968 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1969 (handle_dollar): Rename as...
1970 (handle_action_dollar): this.
1971 (handle_destructor_dollar): New.
1972 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1973 (grammar_declaration): Use it.
1974 * data/bison.simple (yystos): Is always defined.
1975 (yydestructor): New.
1976 * tests/actions.at (Destructors): New.
1977 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1978
19792002-06-17 Akim Demaille <akim@epita.fr>
1980
1981 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1982 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1983 rule_length only when needed.
1984 * src/output.c (actions_output, token_definitions_output): Output
1985 the full M4 block.
1986 * src/symtab.c: Don't access directly to the symbol tag, use
1987 symbol_tag_get.
1988 * src/parse-gram.y: Use symbol_list_free.
1989
19902002-06-17 Akim Demaille <akim@epita.fr>
1991
1992 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1993 (symbol_list_prepend, get_type_name): Move to...
1994 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1995 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1996 Adjust all callers.
1997 (symbol_list_free): New.
1998 * src/scan-gram.l (handle_dollar): Takes a location.
1999 * tests/input.at (Invalid $n): Adjust.
2000
20012002-06-17 Akim Demaille <akim@epita.fr>
2002
2003 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2004 (symbol_list_prepend): New.
2005 * src/parse-gram.y (%union): `list' is a new member.
2006 (symbols.1): New, replaces...
2007 (terms_to_prec.1, nterms_to_type.1): these.
2008 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2009 Take a location as additional argument.
2010 Adjust all callers.
2011
20122002-06-15 Akim Demaille <akim@epita.fr>
2013
2014 * src/parse-gram.y: Move %token in the declaration section so that
2015 we don't depend upon CVS Bison.
2016
20172002-06-15 Akim Demaille <akim@epita.fr>
2018
2019 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2020 * src/print.c (print_core): Use it.
2021
20222002-06-15 Akim Demaille <akim@epita.fr>
2023
2024 * src/conflicts.c (log_resolution): Accept the rule involved in
2025 the sr conflicts instead of the lookahead number that points to
2026 that rule.
2027 (flush_reduce): Accept the current lookahead vector as argument,
2028 instead of the index in LA.
2029 (resolve_sr_conflict): Accept the current number of lookahead
2030 bitset to consider for the STATE, instead of the index in LA.
2031 (set_conflicts): Adjust.
2032 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2033
20342002-06-15 Akim Demaille <akim@epita.fr>
2035
2036 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2037 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2038 Adjust all dependencies.
2039 * src/lalr.c (initialize_lookaheads): Split into...
2040 (states_lookaheads_count, states_lookaheads_initialize): these.
2041 (lalr): Adjust.
2042
20432002-06-15 Akim Demaille <akim@epita.fr>
2044
2045 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2046 out of...
2047 (grammar_rules_print): here.
2048 * src/reduce.c (reduce_output): Use it.
2049 * tests/reduce.at (Useless Rules, Reduced Automaton)
2050 (Underivable Rules): Adjust.
2051
20522002-06-15 Akim Demaille <akim@epita.fr>
2053
2054 Copy BYacc's nice way to report the grammar.
2055
2056 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2057 New.
2058 Don't print the rules' location, it is confusing and useless.
2059 (rule_print): Use grammar_rhs_print.
2060 * src/print.c (print_grammar): Use grammar_rules_print.
2061
20622002-06-15 Akim Demaille <akim@epita.fr>
2063
2064 Complete and rationalize `useless thing' warnings.
2065
2066 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2067 (symbol_tag_print): New.
2068 Use them everywhere in place of accessing directly the tag member.
2069 * src/gram.h, src/gram.c (rule_print): New.
2070 Use it where a rule used to be printed `by hand'.
2071 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2072 (reduce_grammar_tables): Report the useless rules.
2073 (reduce_print): Useless things are a warning, not an error.
2074 Report it as such.
2075 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2076 (Reduced Automaton, Underivable Rules): Adjust.
2077 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2078 * tests/conflicts.at (Unresolved SR Conflicts)
2079 (Solved SR Conflicts): Adjust.
2080
20812002-06-15 Akim Demaille <akim@epita.fr>
2082
2083 Let symbols have a location.
2084
2085 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2086 (getsym): Adjust.
2087 Adjust all callers.
2088 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2089 Use location_t, not int.
2090 * src/symtab.c (symbol_check_defined): Take advantage of the
2091 location.
2092 * tests/regression.at (Invalid inputs): Adjust.
2093
20942002-06-15 Akim Demaille <akim@epita.fr>
2095
2096 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2097 (input): Don't try to initialize yylloc here, do it in the
2098 scanner.
2099 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2100 * src/gram.h (rule_t): Change line and action_line into location
2101 and action_location, of location_t type.
2102 Adjust all dependencies.
2103 * src/location.h, src/location.c (empty_location): New.
2104 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2105 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2106 (grammar_current_rule_symbol_append)
2107 (grammar_current_rule_action_append): Expect a location as argument.
2108 * src/reader.c (grammar_midrule_action): Adjust to attach an
2109 action's location as dummy symbol location.
2110 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2111 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2112 the line numbers.
2113
21142002-06-14 Akim Demaille <akim@epita.fr>
2115
2116 Grammar declarations may be found in the grammar section.
2117
2118 * src/parse-gram.y (rules_or_grammar_declaration): New.
2119 (declarations): Each declaration may end with a semicolon, not
2120 just...
2121 (grammar_declaration): `"%union"'.
2122 (grammar): Branch to rules_or_grammar_declaration.
2123
21242002-06-14 Akim Demaille <akim@epita.fr>
2125
2126 * src/main.c (main): Invoke scanner_free.
2127
21282002-06-14 Akim Demaille <akim@epita.fr>
2129
2130 * src/output.c (m4_invoke): Extracted from...
2131 (output_skeleton): here.
2132 Free tempfile.
2133
21342002-06-14 Akim Demaille <akim@epita.fr>
2135
2136 * src/parse-gram.y (directives, directive, gram)
2137 (grammar_directives, precedence_directives, precedence_directive):
2138 Rename as...
2139 (declarations, declaration, grammar, grammar_declaration)
2140 (precedence_declaration, precedence_declarator): these.
2141 (symbol_declaration): New.
2142
21432002-06-14 Akim Demaille <akim@epita.fr>
2144
2145 * src/files.c (action_obstack): Remove, unused.
2146 (output_obstack): Remove it, and all its dependencies, as it is no
2147 longer needed.
2148 * src/reader.c (epilogue_set): Build the epilogue in the
2149 muscle_obstack.
2150 * src/output.h, src/output.c (muscle_obstack): Move to...
2151 * src/muscle_tab.h, src/muscle_tab.h: here.
2152 (muscle_init): Initialize muscle_obstack.
2153 (muscle_free): New.
2154 * src/main.c (main): Call it.
2155
21562002-06-14 Akim Demaille <akim@epita.fr>
2157
2158 * src/location.h: New, extracted from...
2159 * src/reader.h: here.
2160 * src/Makefile.am (noinst_HEADERS): Merge into
2161 (bison_SOURCES): this.
2162 Add location.h.
2163 * src/parse-gram.y: Use location_t instead of Bison's.
2164 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2165 Use location_t instead of ints.
2166
21672002-06-14 Akim Demaille <akim@epita.fr>
2168
2169 * data/bison.simple, data/bison.c++: Be sure to restore the
2170 current #line when returning to the skeleton contents after having
2171 exposed the input file's #line.
2172
21732002-06-12 Akim Demaille <akim@epita.fr>
2174
2175 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2176 eager.
2177 * tests/actions.at (Exotic Dollars): New.
2178
21792002-06-12 Akim Demaille <akim@epita.fr>
2180
2181 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2182 ['"/] too eagerly.
2183 * tests/input.at (Torturing the Scanner): New.
2184
21852002-06-11 Akim Demaille <akim@epita.fr>
2186
2187 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2188 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2189 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2190 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2191 * src/reader.c (reader): Use it.
2192
21932002-06-11 Akim Demaille <akim@epita.fr>
2194
2195 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2196 Adjust all callers.
2197 (scanner_last_string_free): New.
2198
21992002-06-11 Akim Demaille <akim@epita.fr>
2200
2201 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2202 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2203 (last_string, YY_OBS_FREE): New.
2204 Use them when returning an ID.
2205
22062002-06-11 Akim Demaille <akim@epita.fr>
2207
2208 Have Bison grammars parsed by a Bison grammar.
2209
2210 * src/reader.c, src/reader.h (prologue_augment): New.
2211 * src/reader.c (copy_definition): Remove.
2212
2213 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2214 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2215 (grammar_current_rule_prec_set, grammar_current_rule_check)
2216 (grammar_current_rule_symbol_append)
2217 (grammar_current_rule_action_append): Export.
2218 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2219 (symbol_list_action_append): Remove.
2220 Hook the routines from reader.
2221 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2222 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2223
2224 * src/reader.c (read_declarations): Remove, unused.
2225
2226 * src/parse-gram.y: Handle the epilogue.
2227 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2228 (grammar_start_symbol_set): this.
2229 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2230 * src/reader.c (readgram): Remove, unused.
2231 (reader): Adjust to insert eoftoken and axiom where appropriate.
2232
2233 * src/reader.c (copy_dollar): Replace with...
2234 * src/scan-gram.h (handle_dollar): this.
2235 * src/parse-gram.y: Remove `%thong'.
2236
2237 * src/reader.c (copy_at): Replace with...
2238 * src/scan-gram.h (handle_at): this.
2239
2240 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2241 New.
2242
2243 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2244 time being.
2245
2246 * src/reader.h, src/reader.c (grammar_rule_end): New.
2247
2248 * src/parse.y (current_type, current_class): New.
2249 Implement `%nterm', `%token' support.
2250 Merge `%term' into `%token'.
2251 (string_as_id): New.
2252 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2253 type name.
2254
2255 * src/parse-gram.y: Be sure to handle properly the beginning of
2256 rules.
2257
2258 * src/parse-gram.y: Handle %type.
2259 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2260
2261 * src/parse-gram.y: More directives support.
2262 * src/options.c: No longer handle source directives.
2263
2264 * src/parse-gram.y: Fix %output.
2265
2266 * src/parse-gram.y: Handle %union.
2267 Use the prologue locations.
2268 * src/reader.c (parse_union_decl): Remove.
2269
2270 * src/reader.h, src/reader.c (epilogue_set): New.
2271 * src/parse-gram.y: Use it.
2272
2273 * data/bison.simple, data/bison.c++: b4_stype is now either not
2274 defined, then default to int, or to the contents of %union,
2275 without `union' itself.
2276 Adjust.
2277 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2278
2279 * src/output.c (actions_output): Don't output braces, as they are
2280 already handled by the scanner.
2281
2282 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2283 characters to themselves.
2284
2285 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2286 that the epilogue has a proper #line.
2287
2288 * src/parse-gram.y: Handle precedence/associativity.
2289
2290 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2291 a terminal.
2292 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2293 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2294 at all to define terminals that cannot be emitted.
2295
2296 * src/scan-gram.l: Escape M4 characters.
2297
2298 * src/scan-gram.l: Working properly with escapes in user
2299 strings/characters.
2300
2301 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2302 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2303 grammar.
2304 Use more modest sizes, as for the time being the parser does not
2305 release memory, and therefore the process swallows a huge amount
2306 of memory.
2307
2308 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2309 stricter %token grammar.
2310
2311 * src/symtab.h (associativity): Add `undef_assoc'.
2312 (symbol_precedence_set): Do nothing when passed an undef_assoc.
2313 * src/symtab.c (symbol_check_alias_consistence): Adjust.
2314
2315 * tests/regression.at (Invalid %directive): Remove, as it is now
2316 meaningless.
2317 (Invalid inputs): Adjust to the new error messages.
2318 (Token definitions): The new grammar doesn't allow too many
2319 eccentricities.
2320
2321 * src/lex.h, src/lex.c: Remove.
2322 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
2323 (copy_character, copy_string2, copy_string, copy_identifier)
2324 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
2325 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
2326 (parse_action): Remove.
2327 * po/POTFILES.in: Adjust.
2328
23292002-06-11 Akim Demaille <akim@epita.fr>
2330
2331 * src/reader.c (parse_action): Don't store directly into the
2332 rule's action member: return the action as a string.
2333 Don't require `rule_length' as an argument: compute it.
2334 (grammar_current_rule_symbol_append)
2335 (grammar_current_rule_action_append): New, eved out from
2336 (readgram): here.
2337 Remove `action_flag', `rulelength', unused now.
2338
23392002-06-11 Akim Demaille <akim@epita.fr>
2340
2341 * src/reader.c (grammar_current_rule_prec_set).
2342 (grammar_current_rule_check): New, eved out from...
2343 (readgram): here.
2344 Remove `xaction', `first_rhs': useless.
2345 * tests/input.at (Type clashes): New.
2346 * tests/existing.at (GNU Cim Grammar): Adjust.
2347
23482002-06-11 Akim Demaille <akim@epita.fr>
2349
2350 * src/reader.c (grammar_midrule_action): New, Eved out from
2351 (readgram): here.
2352
23532002-06-11 Akim Demaille <akim@epita.fr>
2354
2355 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
2356 New.
2357 (readgram): Use them as replacement of inlined code, crule and
2358 crule1.
2359
23602002-06-11 Akim Demaille <akim@epita.fr>
2361
2362 * src/reader.c (grammar_end, grammar_symbol_append): New.
2363 (readgram): Use them.
2364 Make the use of `p' as local as possible.
2365
23662002-06-10 Akim Demaille <akim@epita.fr>
2367
2368 GCJ's parser requires the tokens to be defined before the prologue.
2369
2370 * data/bison.simple: Output the token definition before the user's
2371 prologue.
2372 * tests/regression.at (Braces parsing, Duplicate string)
2373 (Mixing %token styles): Check the output from bison.
2374 (Early token definitions): New.
2375
23762002-06-10 Akim Demaille <akim@epita.fr>
2377
2378 * src/symtab.c (symbol_user_token_number_set): Don't complain when
2379 assigning twice the same user number to a token, so that we can
2380 use it in...
2381 * src/lex.c (lex): here.
2382 Also use `symbol_class_set' instead of hand written code.
2383 * src/reader.c (parse_assoc_decl): Likewise.
2384
23852002-06-10 Akim Demaille <akim@epita.fr>
2386
2387 * src/symtab.c, src/symtab.c (symbol_class_set)
2388 (symbol_user_token_number_set): New.
2389 * src/reader.c (parse_token_decl): Use them.
2390 Use a switch instead of ifs.
2391 Use a single argument.
2392
23932002-06-10 Akim Demaille <akim@epita.fr>
2394
2395 Remove `%thong' support as it is undocumented, unused, duplicates
2396 `%token's job, and creates useless e-mail traffic with people who
2397 want to know what it is, why it is undocumented, unused, and
2398 duplicates `%token's job.
2399
2400 * src/reader.c (parse_thong_decl): Remove.
2401 * src/options.c (option_table): Remove "thong".
2402 * src/lex.h (tok_thong): Remove.
2403
24042002-06-10 Akim Demaille <akim@epita.fr>
2405
2406 * src/symtab.c, src/symtab.c (symbol_type_set)
2407 (symbol_precedence_set): New.
2408 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
2409 (value_components_used): Remove, unused.
2410
24112002-06-09 Akim Demaille <akim@epita.fr>
2412
2413 Move symbols handling code out of the reader.
2414
2415 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
2416 (axiom): Move to...
2417 * src/symtab.h, src/symtab.c: here.
2418
2419 * src/gram.c (start_symbol): Remove: use startsymbol->number.
2420 * src/reader.c (startval): Rename as...
2421 * src/symtab.h, src/symtab.c (startsymbol): this.
2422 * src/reader.c: Adjust.
2423
2424 * src/reader.c (symbol_check_defined, symbol_make_alias)
2425 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2426 (token_translations_init)
2427 Move to...
2428 * src/symtab.c: here.
2429 * src/reader.c (packsymbols): Move to...
2430 * src/symtab.h, src/symtab.c (symbols_pack): here.
2431 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
2432 argument.
2433
24342002-06-03 Akim Demaille <akim@epita.fr>
2435
2436 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
2437 then statements.
2438
24392002-06-03 Akim Demaille <akim@epita.fr>
2440
2441 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
2442 structs with non literals.
2443 * src/scan-skel.l: never-interactive.
2444 * src/conflicts.c (enum conflict_resolution_e): No trailing
2445 comma.
2446 * src/getargs.c (usage): Split long literal strings.
2447 Reported by Hans Aberg.
2448
24492002-05-28 Akim Demaille <akim@epita.fr>
2450
2451 * data/bison.c++: Use C++ ostreams.
2452 (cdebug_): New member.
2453
24542002-05-28 Akim Demaille <akim@epita.fr>
2455
2456 * src/output.c (output_skeleton): Be sure to allocate enough room
2457 for `/' _and_ for `\0' in full_skeleton.
2458
24592002-05-28 Akim Demaille <akim@epita.fr>
2460
2461 * data/bison.c++: Catch up with bison.simple:
2462 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2463 and Paul Eggert <eggert@twinsun.com>: `error' handing.
2464 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
2465 and popping traces.
2466
24672002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2468
2469 * src/output.c (output_skeleton): Put an explicit path in front of
2470 the skeleton file name, rather than relying on the -I directory,
2471 to partially alleviate effects of having a skeleton file lying around
2472 in the current directory.
2473
24742002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2475
2476 * src/conflicts.c (log_resolution): Correct typo:
2477 obstack_printf should be obstack_fgrow1.
2478
24792002-05-26 Akim Demaille <akim@epita.fr>
2480
2481 * src/state.h (state_t): `solved_conflicts' is a new member.
2482 * src/LR0.c (new_state): Set it to 0.
2483 * src/conflicts.h, src/conflicts.c (print_conflicts)
2484 (free_conflicts, solve_conflicts): Rename as...
2485 (conflicts_print, conflicts_free, conflicts_solve): these.
2486 Adjust callers.
2487 * src/conflicts.c (enum conflict_resolution_e)
2488 (solved_conflicts_obstack): New, used by...
2489 (log_resolution): this.
2490 Adjust to attach the conflict resolution to each state.
2491 Complete the description with the precedence/associativity
2492 information.
2493 (resolve_sr_conflict): Adjust.
2494 * src/print.c (print_state): Output its solved_conflicts.
2495 * tests/conflicts.at (Unresolved SR Conflicts)
2496 (Solved SR Conflicts): Exercise --report=all.
2497
24982002-05-26 Akim Demaille <akim@epita.fr>
2499
2500 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2501 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2502 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2503 (token_number_t, item_number_as_token_number)
2504 (token_number_as_item_number, muscle_insert_token_number_table):
2505 Rename as...
2506 (symbol_number_t, item_number_as_symbol_number)
2507 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2508 these, since it is more appropriate.
2509
25102002-05-26 Akim Demaille <akim@epita.fr>
2511
2512 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2513 `Error:' lines.
2514 * data/bison.simple (yystos) [YYDEBUG]: New.
2515 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2516 error recovery.
2517 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2518
25192002-05-25 Akim Demaille <akim@epita.fr>
2520
2521 * doc/bison.texinfo (Debugging): Split into...
2522 (Tracing): this new section, its former contents, and...
2523 (Understanding): this new section.
2524 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2525 by...
2526 (report_flag): this.
2527 Adjust all dependencies.
2528 (report_args, report_types, report_argmatch): New.
2529 (usage, getargs): Report/support -r, --report.
2530 * src/options.h
2531 (struct option_table_struct): Rename as..,
2532 (struct option_table_s): this.
2533 Rename the `set_flag' member to `flag' to match with getopt_long's
2534 struct.
2535 * src/options.c (option_table): Split verbose into an entry for
2536 %verbose, and another for --verbose.
2537 Support --report/-r, so remove -r from the obsolete --raw.
2538 * src/print.c: Attach full item sets and lookaheads reports to
2539 report_flag instead of trace_flag.
2540 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2541
25422002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2543 and Paul Eggert <eggert@twinsun.com>
2544
2545 * data/bison.simple (yyparse): Correct error handling to conform to
2546 POSIX and yacc. Specifically, after syntax error is discovered,
2547 do not reduce further before shifting the error token.
2548 Clean up the code a bit by removing the labels yyerrdefault,
2549 yyerrhandle, yyerrpop.
2550 * NEWS: Document the above.
2551
25522002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2553
2554 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2555 type; it isn't always big enough, since it doesn't necessarily
2556 include non-terminals.
2557 (yytranslate): Expand definition of yy_token_number_type, so that
2558 the latter can be removed.
2559 (yy_token_number_type): Remove, only one use.
2560 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2561 don't use TokenNumberType as element type.
2562
2563 * tests/regression.at: Modify expected output to agree with change
2564 to yyr1 and yytranslate.
2565
25662002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2567
2568 * src/reader.c (parse_action): Use copy_character instead of
2569 obstack_1grow.
2570
25712002-05-13 Akim Demaille <akim@epita.fr>
2572
2573 * tests/regression.at (Token definitions): Prototype yylex and
2574 yyerror.
2575
25762002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2577
2578 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
2579 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2580 32-bit arithmetic.
2581 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2582
25832002-05-07 Akim Demaille <akim@epita.fr>
2584
2585 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2586 avoid GCC warnings.
2587
25882002-05-07 Akim Demaille <akim@epita.fr>
2589
2590 Kill GCC warnings.
2591
2592 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2593 over the RHS of each rule.
2594 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2595 * src/state.h (state_t): Member `nitems' is unsigned short.
2596 * src/LR0.c (get_state): Adjust.
2597 * src/reader.c (packgram): Likewise.
2598 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2599 `Type'.
2600 (muscle_insert_int_table): Remove, unused.
2601 (prepare_rules): Remove `max'.
2602
26032002-05-06 Akim Demaille <akim@epita.fr>
2604
2605 * src/closure.c (print_firsts): Display of the symbol tags.
2606 (bitmatrix_print): Move to...
2607 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2608 here.
2609 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2610
26112002-05-06 Akim Demaille <akim@epita.fr>
2612
2613 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2614 hash_do_for_each.
2615
26162002-05-06 Akim Demaille <akim@epita.fr>
2617
2618 * src/LR0.c (new_state, get_state): Instead of using the global
2619 `kernel_size' and `kernel_base', have two new arguments:
2620 `core_size' and `core'.
2621 Adjust callers.
2622
26232002-05-06 Akim Demaille <akim@epita.fr>
2624
2625 * src/reader.c (packgram): No longer end `ritem' with a 0
2626 sentinel: it is not used.
2627
26282002-05-05 Akim Demaille <akim@epita.fr>
2629
2630 New experimental feature: display the lookaheads in the report and
2631 graph.
2632
2633 * src/print (print_core): When --trace-flag, display the rules
2634 lookaheads.
2635 * src/print_graph.c (print_core): Likewise.
2636 Swap the arguments.
2637 Adjust caller.
2638
26392002-05-05 Akim Demaille <akim@epita.fr>
2640
2641 * tests/torture.at (Many lookaheads): New test.
2642
26432002-05-05 Akim Demaille <akim@epita.fr>
2644
2645 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2646 (GENERATE_MUSCLE_INSERT_TABLE): this.
2647 (output_int_table, output_unsigned_int_table, output_short_table)
2648 (output_token_number_table, output_item_number_table): Replace with...
2649 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2650 (muscle_insert_short_table, muscle_insert_token_number_table)
2651 (muscle_insert_item_number_table): these.
2652 Adjust all callers.
2653 (prepare_tokens): Don't free `translations', since...
2654 * src/reader.h, src/reader.c (grammar_free): do it.
2655 Move to...
2656 * src/gram.h, src/gram.c (grammar_free): here.
2657 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2658 b4_translate_max.
2659
26602002-05-05 Akim Demaille <akim@epita.fr>
2661
2662 * src/output.c (output_unsigned_int_table): New.
2663 (prepare_rules): `i' is unsigned.
2664 `prhs', `rline', `r2' are unsigned int.
2665 Rename muscle `rhs_number_max' as `rhs_max'.
2666 Output muscles `prhs_max', `rline_max', and `r2_max'.
2667 Free rline and r1.
2668 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2669 to compute types instead of constant types.
2670 * tests/regression.at (Web2c Actions): Adjust.
2671
26722002-05-04 Akim Demaille <akim@epita.fr>
2673
2674 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2675 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2676 Adjust dependencies.
2677 * src/output.c (token_definitions_output): Be sure not to output a
2678 `#define 'a'' when fed with `%token 'a' "a"'.
2679 * tests/regression.at (Token definitions): New.
2680
26812002-05-03 Paul Eggert <eggert@twinsun.com>
2682
2683 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2684 for K&R C.
2685
26862002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2687
2688 * Makefile.am (SUBDIRS): Remove intl.
2689 (EXTRA_DIST): Add config/config.rpath.
2690
26912002-05-03 Akim Demaille <akim@epita.fr>
2692
2693 * data/bison.simple (m4_if): Don't output empty enums.
2694 And actually, output valid enum definitions :(.
2695
26962002-05-03 Akim Demaille <akim@epita.fr>
2697
2698 * configure.bat: Remove, completely obsolete.
2699 * Makefile.am (EXTRA_DIST): Adjust.
2700 Don't distribute config.rpath...
2701 * config/Makefile.am (EXTRA_DIST): Do it.
2702
27032002-05-03 Akim Demaille <akim@epita.fr>
2704
2705 * configure.in (GETTEXT_VERSION): New.
2706 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2707
27082002-05-03 Akim Demaille <akim@epita.fr>
2709
2710 * data/bison.simple (b4_token_enum): New.
2711 (b4_token_defines): Use it to output tokens both as #define and
2712 enums.
2713 Suggested by Paul Eggert.
2714 * src/output.c (token_definitions_output): Don't output spurious
2715 white spaces.
2716
27172002-05-03 Akim Demaille <akim@epita.fr>
2718
2719 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2720
27212002-05-02 Robert Anisko <robert@lrde.epita.fr>
2722
2723 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2724 Update the stack class, give a try to deque as the default container.
2725
27262002-05-02 Akim Demaille <akim@epita.fr>
2727
2728 * data/bison.simple (yyparse): Do not implement @$ = @1.
2729 (YYLLOC_DEFAULT): Adjust to do it.
2730 * doc/bison.texinfo (Location Default Action): Fix.
2731
27322002-05-02 Akim Demaille <akim@epita.fr>
2733
2734 * src/reader.c (parse_braces): Merge into...
2735 (parse_action): this.
2736
27372002-05-02 Akim Demaille <akim@epita.fr>
2738
2739 * configure.in (ALL_LINGUAS): Remove.
2740 * po/LINGUAS, hr.po: New.
2741
27422002-05-02 Akim Demaille <akim@epita.fr>
2743
2744 Remove the so called hairy (semantic) parsers.
2745
2746 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2747 * src/gram.h, src/gram.c (semantic_parser): Remove.
2748 (rule_t): Remove the guard and guard_line members.
2749 * src/lex.h (token_t): remove tok_guard.
2750 * src/options.c (option_table): Remove %guard and %semantic_parser
2751 support.
2752 * src/output.c, src/output.h (guards_output): Remove.
2753 (prepare): Adjust.
2754 (token_definitions_output): Don't output the `T'
2755 tokens (???).
2756 (output_skeleton): Don't output the guards.
2757 * src/files.c, src/files.c (attrsfile): Remove.
2758 * src/reader.c (symbol_list): Remove the guard and guard_line
2759 members.
2760 Adjust dependencies.
2761 (parse_guard): Remove.
2762 * data/bison.hairy: Remove.
2763 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2764 BISON_HAIRY.
2765
27662002-05-02 Akim Demaille <akim@epita.fr>
2767
2768 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2769 (parse_guard): Rename the formal argument `stack_offset' as
2770 `rule_length', which is more readable.
2771 Adjust callers.
2772 (copy_at, copy_dollar): Instead of outputting the hard coded
2773 values of $$, $n and so forth, output invocation to b4_lhs_value,
2774 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
2775 Note: this patch partially drops `semantic-parser' support: it
2776 always does `rule_length - n', where semantic parsers ought to
2777 always use `-n'.
2778 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2779 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2780
27812002-05-02 Akim Demaille <akim@epita.fr>
2782
2783 * configure.in (AC_INIT): Bump to 1.49b.
2784 (AM_INIT_AUTOMAKE): Short invocation.
2785
27862002-05-02 Akim Demaille <akim@epita.fr>
2787
2788 Version 1.49a.
2789
27902002-05-01 Akim Demaille <akim@epita.fr>
2791
2792 * src/skeleton.h: Remove.
2793
27942002-05-01 Akim Demaille <akim@epita.fr>
2795
2796 * src/skeleton.h: Fix the #endif.
2797 Reported by Magnus Fromreide.
2798
27992002-04-26 Paul Eggert <eggert@twinsun.com>
2800
2801 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2802 Define if we define YYSTYPE and YYLTYPE, respectively.
2803 (YYCOPY): Fix [] quoting problem in the non-GCC case.
2804
28052002-04-25 Robert Anisko <robert@lrde.epita.fr>
2806
2807 * src/scan-skel.l: Postprocess quadrigraphs.
2808
2809 * src/reader.c (copy_character): New function, used to output
2810 single characters while replacing `[' and `]' with quadrigraphs, to
2811 avoid troubles with M4 quotes.
2812 (copy_comment): Output characters with copy_character.
2813 (read_additionnal_code): Likewise.
2814 (copy_string2): Likewise.
2815 (copy_definition): Likewise.
2816
2817 * tests/calc.at: Exercise M4 quoting.
2818
28192002-04-25 Akim Demaille <akim@epita.fr>
2820
2821 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2822 between `!' and the command.
2823 Reported by Paul Eggert.
2824
28252002-04-24 Robert Anisko <robert@lrde.epita.fr>
2826
2827 * tests/calc.at: Exercise prologue splitting.
2828
2829 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2830 `b4_post_prologue' instead of `b4_prologue'.
2831
2832 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2833 muscles.
2834 (output): Free pre_prologue_obstack and post_prologue_obstack.
2835 * src/files.h, src/files.c (attrs_obstack): Remove.
2836 (pre_prologue_obstack, post_prologue_obstack): New.
2837 * src/reader.c (copy_definition): Add a parameter to specify the
2838 obstack to fill, instead of using attrs_obstack unconditionally.
2839 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2840 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2841
28422002-04-23 Paul Eggert <eggert@twinsun.com>
2843
2844 * data/bison.simple: Remove unnecessary commentary and white
2845 space differences from 1_29-branch.
2846 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2847
2848 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2849 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2850 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2851 constructors or destructors.
2852
2853 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2854
28552002-04-23 Akim Demaille <akim@epita.fr>
2856
2857 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2858 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2859 location with columns.
2860 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2861 All reported by Paul Eggert.
2862
28632002-04-22 Akim Demaille <akim@epita.fr>
2864
2865 * src/reduce.c (dump_grammar): Move to...
2866 * src/gram.h, src/gram.c (grammar_dump): here.
2867 Be sure to separate long item numbers.
2868 Don't read the members of a rule's prec if its nil.
2869
28702002-04-22 Akim Demaille <akim@epita.fr>
2871
2872 * src/output.c (table_size, table_grow): New.
2873 (MAXTABLE): Remove, replace uses with table_size.
2874 (pack_vector): Instead of dying when the table is too big, grow it.
2875
28762002-04-22 Akim Demaille <akim@epita.fr>
2877
2878 * data/bison.simple (yyr1): Its type is that of a token number.
2879 * data/bison.c++ (r1_): Likewise.
2880 * tests/regression.at (Web2c Actions): Adjust.
2881
28822002-04-22 Akim Demaille <akim@epita.fr>
2883
2884 * src/reader.c (token_translations_init): 256 is now the default
2885 value for the error token, i.e., it will be assigned another
2886 number if the user assigned 256 to one of her tokens.
2887 (reader): Don't force 256 to error.
2888 * doc/bison.texinfo (Symbols): Adjust.
2889 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2890 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2891 etc. instead of 10, 20, 30 (which was used to `jump' over error
2892 (256) and undefined (2)).
2893
28942002-04-22 Akim Demaille <akim@epita.fr>
2895
2896 Propagate more token_number_t.
2897
2898 * src/gram.h (token_number_as_item_number)
2899 (item_number_as_token_number): New.
2900 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2901 Use it to create output_item_number_table and
2902 output_token_number_table.
2903 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2904 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2905 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2906 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2907
29082002-04-22 Akim Demaille <akim@epita.fr>
2909
2910 * src/output.h, src/output.c (get_lines_number): Remove.
2911
29122002-04-19 Akim Demaille <akim@epita.fr>
2913
2914 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2915 as Lex/Flex'.
2916 (Debugging): More details about enabling the debugging features.
2917 (Table of Symbols): Describe $$, $n, @$, and @n.
2918 Suggested by Tim Josling.
2919
29202002-04-19 Akim Demaille <akim@epita.fr>
2921
2922 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2923
29242002-04-10 Akim Demaille <akim@epita.fr>
2925
2926 * src/system.h: Rely on HAVE_LIMITS_H.
2927 Suggested by Paul Eggert.
2928
29292002-04-09 Akim Demaille <akim@epita.fr>
2930
2931 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2932 full stderr, and strip it according to the bison options, instead
2933 of composing the error message from different bits.
2934 This makes it easier to check for several error messages.
2935 Adjust all the invocations.
2936 Add an invocation exercising the error token.
2937 Add an invocation demonstrating a stupid error message.
2938 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2939 Adjust the tests.
2940 Error message are for stderr, not stdout.
2941
29422002-04-09 Akim Demaille <akim@epita.fr>
2943
2944 * src/gram.h, src/gram.c (error_token_number): Remove, use
2945 errtoken->number.
2946 * src/reader.c (reader): Don't specify the user token number (2)
2947 for $undefined, as it uselessly prevents using it.
2948 * src/gram.h (token_number_t): Move to...
2949 * src/symtab.h: here.
2950 (state_t.number): Is a token_number_t.
2951 * src/print.c, src/reader.c: Use undeftoken->number instead of
2952 hard coded 2.
2953 (Even though this 2 is not the same as above: the number of the
2954 undeftoken remains being 2, it is its user token number which
2955 might not be 2).
2956 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2957 `user_token_number_max'.
2958 Output `undef_token_number'.
2959 * data/bison.simple, data/bison.c++: Use them.
2960 Be sure to map invalid yylex return values to
2961 `undef_token_number'. This saves us from gratuitous SEGV.
2962
2963 * tests/conflicts.at (Solved SR Conflicts)
2964 (Unresolved SR Conflicts): Adjust.
2965 * tests/regression.at (Web2c Actions): Adjust.
2966
29672002-04-08 Akim Demaille <akim@epita.fr>
2968
2969 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2970 Adding #line.
2971 Remove the duplicate `typedefs'.
2972 (RhsNumberType): Fix the declaration and various other typos.
2973 Use __ofile__.
2974 * data/bison.simple: Use __ofile__.
2975 * src/scan-skel.l: Handle __ofile__.
2976
29772002-04-08 Akim Demaille <akim@epita.fr>
2978
2979 * src/gram.h (item_number_t): New, the type of item numbers in
2980 RITEM. Note that it must be able to code symbol numbers as
2981 positive number, and the negation of rule numbers as negative
2982 numbers.
2983 Adjust all dependencies (pretty many).
2984 * src/reduce.c (rule): Remove this `short *' pointer: use
2985 item_number_t.
2986 * src/system.h (MINSHORT, MAXSHORT): Remove.
2987 Include `limits.h'.
2988 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2989 (shortcpy): Remove.
2990 (MAXTABLE): Move to...
2991 * src/output.c (MAXTABLE): here.
2992 (prepare_rules): Use output_int_table to output rhs.
2993 * data/bison.simple, data/bison.c++: Adjust.
2994 * tests/torture.at (Big triangle): Move the limit from 254 to
2995 500.
2996 * tests/regression.at (Web2c Actions): Ajust.
2997
2998 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2999 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3000 passes, but produces negative #line number, once fixed, GCC is
3001 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3002 C), it passes.
3003 * src/state.h (state_h): Code input lines on ints, not shorts.
3004
30052002-04-08 Akim Demaille <akim@epita.fr>
3006
3007 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3008 and then the grammar.
3009
30102002-04-08 Akim Demaille <akim@epita.fr>
3011
3012 * src/system.h: No longer using strndup.
3013
30142002-04-07 Akim Demaille <akim@epita.fr>
3015
3016 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3017 * src/output.c (output_table_data): Return the longest number.
3018 (prepare_tokens): Output `token_number_max').
3019 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3020 New.
3021 Use them to define yy_token_number_type/TokenNumberType.
3022 Use this type for yytranslate.
3023 * tests/torture.at (Big triangle): Push the limit from 124 to
3024 253.
3025 * tests/regression.at (Web2c Actions): Adjust.
3026
30272002-04-07 Akim Demaille <akim@epita.fr>
3028
3029 * tests/torture.at (Big triangle): New.
3030 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3031 * tests/existing.at: here.
3032
30332002-04-07 Akim Demaille <akim@epita.fr>
3034
3035 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3036 nritems.
3037 Adjust dependencies.
3038
30392002-04-07 Akim Demaille <akim@epita.fr>
3040
3041 * src/reader.c: Normalize increments to prefix form.
3042
30432002-04-07 Akim Demaille <akim@epita.fr>
3044
3045 * src/reader.c, symtab.c: Remove debugging code.
3046
30472002-04-07 Akim Demaille <akim@epita.fr>
3048
3049 Rename all the `bucket's as `symbol_t'.
3050
3051 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3052 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3053 * src/symtab.c, src/symtab.h (bucket): Rename as...
3054 (symbol_t): this.
3055 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3056 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3057 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3058 (buckets_new, buckets_free, buckets_do): Rename as...
3059 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3060 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3061 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3062 (symbols_new, symbols_free, symbols_do): these.
3063
30642002-04-07 Akim Demaille <akim@epita.fr>
3065
3066 Use lib/hash for the symbol table.
3067
3068 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3069 EOF.
3070 * src/lex.c (lex): Set the `number' member of new terminals.
3071 * src/reader.c (bucket_check_defined, bucket_make_alias)
3072 (bucket_check_alias_consistence, bucket_translation): New.
3073 (reader, grammar_free, readgram, token_translations_init)
3074 (packsymbols): Adjust.
3075 (reader): Number the predefined tokens.
3076 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3077 for predefined tokens.
3078 * src/symtab.h (bucket): Remove all the hash table related
3079 members.
3080 * src/symtab.c (symtab): Replace by...
3081 (bucket_table): this.
3082 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3083 (buckets_new, buckets_do): New.
3084
30852002-04-07 Akim Demaille <akim@epita.fr>
3086
3087 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3088 (start_symbol, max_user_token_number, semantic_parser)
3089 (error_token_number): Initialize.
3090 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3091 Initialize.
3092 (reader): Don't.
3093 (errtoken, eoftoken, undeftoken, axiom): Extern.
3094
30952002-04-07 Akim Demaille <akim@epita.fr>
3096
3097 * src/gram.h (rule_s): prec and precsym are now pointers
3098 to the bucket giving the priority/associativity.
3099 Member `associativity' removed: useless.
3100 * src/reduce.c, src/conflicts.c: Adjust.
3101
31022002-04-07 Akim Demaille <akim@epita.fr>
3103
3104 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3105 Properly escape the symbols' TAG when outputting them.
3106
31072002-04-07 Akim Demaille <akim@epita.fr>
3108
3109 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3110
31112002-04-07 Akim Demaille <akim@epita.fr>
3112
3113 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3114 (LArule): this, which is an array to rule_t*.
3115 * src/print.c, src/conflicts.c: Adjust.
3116
31172002-04-07 Akim Demaille <akim@epita.fr>
3118
3119 * src/gram.h (rule_t): Rename `number' as `user_number'.
3120 `number' is a new member.
3121 Adjust dependencies.
3122 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3123
31242002-04-07 Akim Demaille <akim@epita.fr>
3125
3126 As a result of the previous patch, it is no longer needed
3127 to reorder ritem itself.
3128
3129 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3130
31312002-04-07 Akim Demaille <akim@epita.fr>
3132
3133 Be sure never to walk through RITEMS, but use only data related to
3134 the rules themselves. RITEMS should be banished.
3135
3136 * src/output.c (output_token_translations): Rename as...
3137 (prepare_tokens): this.
3138 In addition to `translate', prepare the muscles `tname' and
3139 `toknum', which were handled by...
3140 (output_rule_data): this.
3141 Remove, and move the remainder of its outputs into...
3142 (prepare_rules): this new routines, which also merges content from
3143 (output_gram): this.
3144 (prepare_rules): Be sure never to walk through RITEMS.
3145 (output_stos): Rename as...
3146 (prepare_stos): this.
3147 (output): Always invoke prepare_states, after all, just don't use it
3148 in the output if you don't need it.
3149
31502002-04-07 Akim Demaille <akim@epita.fr>
3151
3152 * src/LR0.c (new_state): Display `nstates' as the name of the
3153 newly created state.
3154 Adjust to initialize first_state and last_state if needed.
3155 Be sure to distinguish the initial from the final state.
3156 (new_states): Create the itemset of the initial state, and use
3157 new_state.
3158 * src/closure.c (closure): Now that the initial state has its
3159 items properly set, there is no need for a special case when
3160 creating `ruleset'.
3161
3162 As a result, now the rule 0, reducing to $axiom, is visible in the
3163 outputs. Adjust the test suite.
3164
3165 * tests/conflicts.at (Solved SR Conflicts)
3166 (Unresolved SR Conflicts): Adjust.
3167 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3168 * tests/conflicts.at (S/R in initial): New.
3169
31702002-04-07 Akim Demaille <akim@epita.fr>
3171
3172 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3173 the RHS of the rules.
3174 * src/output.c (output_gram): Likewise.
3175
31762002-04-07 Akim Demaille <akim@epita.fr>
3177
3178 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3179 bucket.
3180 Adjust all dependencies.
3181 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3182 `number' of the buckets too.
3183 * src/gram.h: Include `symtab.h'.
3184 (associativity): Move to...
3185 * src/symtab.h: here.
3186 No longer include `gram.h'.
3187
31882002-04-07 Akim Demaille <akim@epita.fr>
3189
3190 * src/gram.h, src/gram.c (rules_rhs_length): New.
3191 (ritem_longest_rhs): Use it.
3192 * src/gram.h (rule_t): `number' is a new member.
3193 * src/reader.c (packgram): Set it.
3194 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3195 the end of `rules', and count them out of `nrules'.
3196 (reduce_output, dump_grammar): Adjust.
3197 * src/print.c (print_grammar): It is no longer needed to check for
3198 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3199 * tests/reduce.at (Reduced Automaton): New test.
3200
32012002-04-07 Akim Demaille <akim@epita.fr>
3202
3203 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3204 lacking `+ 1' to nrules, Bison reported as useless a token if it
3205 was used solely to set the precedence of the last rule...
3206
32072002-04-07 Akim Demaille <akim@epita.fr>
3208
3209 * data/bison.c++, data/bison.simple: Don't output the current file
3210 name in #line, to avoid useless diffs between two identical
3211 outputs under different names.
3212
32132002-04-07 Akim Demaille <akim@epita.fr>
3214
3215 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3216 Normalize loops to using `< nrules + 1', not `<= nrules'.
3217
32182002-04-07 Akim Demaille <akim@epita.fr>
3219
3220 * TODO: Update.
3221
32222002-04-07 Akim Demaille <akim@epita.fr>
3223
3224 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3225 bucket.value as bucket.number.
3226
32272002-04-07 Akim Demaille <akim@epita.fr>
3228
3229 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3230 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3231 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3232 RHS, instead of being an index in RITEMS.
3233
32342002-04-04 Paul Eggert <eggert@twinsun.com>
3235
3236 * doc/bison.texinfo: Update copyright date.
3237 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3238 (Symbols): Warn about running Bison in one character set,
3239 but compiling and/or running in an incompatible one.
3240 Warn about character code 256, too.
3241
32422002-04-03 Paul Eggert <eggert@twinsun.com>
3243
3244 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3245 YYERROR_VERBOSE is nonzero, not whether it is defined.
3246
3247 Merge changes from bison-1_29-branch.
3248
32492002-03-20 Paul Eggert <eggert@twinsun.com>
3250
3251 Merge fixes from Debian bison_1.34-1.diff.
3252
3253 * configure.in (AC_PREREQ): 2.53.
3254
32552002-03-20 Akim Demaille <akim@epita.fr>
3256
3257 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3258
32592002-03-19 Paul Eggert <eggert@twinsun.com>
3260
3261 * src/bison.simple (YYCOPY): New macro.
3262 (YYSTACK_RELOCATE): Use it.
3263 Remove Type arg; no longer needed. All callers changed.
3264 (yymemcpy): Remove; no longer needed.
3265
3266 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3267 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3268
32692002-03-19 Akim Demaille <akim@epita.fr>
3270
3271 Test and fix the #line outputs.
3272
3273 * tests/atlocal.at (GCC): New.
3274 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3275 (Prologue synch line, ,%union synch line, Postprologue synch line)
3276 (Action synch line, Epilogue synch line): New tests.
3277 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3278 * data/bison.simple, data/bison.c++: Use it.
3279
32802002-03-19 Akim Demaille <akim@epita.fr>
3281
3282 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3283 (Solved SR Conflicts, %expect not enough, %expect right)
3284 (%expect too much): Move to...
3285 * tests/conflicts.at: this new file.
3286
32872002-03-19 Akim Demaille <akim@epita.fr>
3288
3289 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3290 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3291 that we can move to enums for instance.
3292 * src/output.c (token_definitions_output): Output a list of
3293 `token-name, token-number' instead of the #define.
3294 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3295
32962002-03-14 Akim Demaille <akim@epita.fr>
3297
3298 Use Gettext 0.11.1.
3299
33002002-03-09 Robert Anisko <robert@lrde.epita.fr>
3301
3302 * data/bison.c++: Make the user able to add members to the generated
3303 parser by subclassing.
3304
33052002-03-05 Robert Anisko <robert@lrde.epita.fr>
3306
3307 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3308 a character.
3309 Reported by Nicolas Tisserand and Nicolas Burrus.
3310
33112002-03-04 Robert Anisko <robert@lrde.epita.fr>
3312
3313 * src/reader.c: Warn about lacking semi-colons, do not complain.
3314
33152002-03-04 Robert Anisko <robert@lrde.epita.fr>
3316
3317 * data/bison.c++: Remove a debug line.
3318
33192002-03-04 Robert Anisko <robert@lrde.epita.fr>
3320
3321 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
3322 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
3323 provide a default implementation.
3324
33252002-03-04 Akim Demaille <akim@epita.fr>
3326
3327 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
3328 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
3329 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
3330 * tests/semantic.at (Parsing Guards): Similarly.
3331 * src/reader.at (readgram): Complain if the last rule is not ended
3332 with a semi-colon.
3333
33342002-03-04 Akim Demaille <akim@epita.fr>
3335
3336 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
3337 * src/closure.c: here.
3338 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
3339 RTC.
3340 * src/warshall.h, src/warshall.c: Remove.
3341 * tests/sets.at (Broken Closure): Adjust.
3342
33432002-03-04 Akim Demaille <akim@epita.fr>
3344
3345 * src/output.c (output_skeleton): tempdir is const.
3346 bytes_read is unused.
3347
33482002-03-04 Akim Demaille <akim@epita.fr>
3349
3350 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3351 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
3352 Update.
3353 From Michael Hayes.
3354
33552002-03-04 Akim Demaille <akim@epita.fr>
3356
3357 * src/closure.c (closure): `r' is unused.
3358
33592002-03-04 Akim Demaille <akim@epita.fr>
3360
3361 * tests/sets.at (Broken Closure): Add the ending `;'.
3362 * src/reader.at (readgram): Complain if a rule is not ended with a
3363 semi-colon.
3364
33652002-03-04 Akim Demaille <akim@epita.fr>
3366
3367 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
3368 (count_sr_conflicts): Use bitset_count.
3369 * src/reduce.c (inaccessable_symbols): Ditto.
3370 (bits_size): Remove.
3371 * src/warshall.h, src/warshall.c: Convert to bitsetv.
3372
33732002-03-04 Akim Demaille <akim@epita.fr>
3374
3375 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
3376 * src/reduce.c: Remove the `bitset_zero's following the
3377 `bitset_create's, as now it is performed by the latter.
3378
33792002-03-04 Akim Demaille <akim@epita.fr>
3380
3381 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
3382 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
3383 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
3384 latest sources from Michael.
3385
33862002-03-04 Akim Demaille <akim@epita.fr>
3387
3388 * src/output.c (output): Don't free the grammar.
3389 * src/reader.c (grammar_free): New.
3390 * src/main.c (main): Call it and don't free symtab here.
3391
33922002-03-04 Akim Demaille <akim@epita.fr>
3393
3394 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
3395 before returning.
3396 Reported by Benoit Perrot.
3397
33982002-03-04 Akim Demaille <akim@epita.fr>
3399
3400 Use bitset operations when possible, not loops over bits.
3401
3402 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
3403 bitset_or.
3404 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
3405 * src/reduce.c (useless_nonterminals): Formatting changes.
3406 * src/warshall.c (TC): Use bitset_or.
3407
34082002-03-04 Akim Demaille <akim@epita.fr>
3409
3410 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
3411 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
3412 Ditto.
3413
34142002-03-04 Akim Demaille <akim@epita.fr>
3415
3416 * src/lalr.c (F): Now a bitset*.
3417 Adjust all dependencies.
3418
34192002-03-04 Akim Demaille <akim@epita.fr>
3420
3421 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
3422 Adjust all dependencies.
3423
34242002-03-04 Akim Demaille <akim@epita.fr>
3425
3426 * src/L0.c, src/LR0.h (nstates): Be size_t.
3427 Adjust comparisons (signed vs unsigned).
3428 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
3429 bitset*.
3430 Adjust all dependencies.
3431
34322002-03-04 Akim Demaille <akim@epita.fr>
3433
3434 * src/closure.c (firsts): Now, also a bitset.
3435 Adjust all dependencies.
3436 (varsetsize): Remove, now unused.
3437 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
3438
34392002-03-04 Akim Demaille <akim@epita.fr>
3440
3441 * src/print.c: Convert to use bitset.h, not hand coded iterations
3442 over ints.
3443
34442002-03-04 Akim Demaille <akim@epita.fr>
3445
3446 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
3447
34482002-03-04 Akim Demaille <akim@epita.fr>
3449
3450 * src/closure.c (ruleset): Be a bitset.
3451 (rulesetsize): Remove.
3452
34532002-03-04 Akim Demaille <akim@epita.fr>
3454
3455 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3456 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
3457 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
3458 * src/closure.c (fderives): Be an array of bitsets.
3459
34602002-02-28 Robert Anisko <robert@lrde.epita.fr>
3461
3462 * data/bison.c++: Merge the two generated headers. Insert a copyright
3463 notice in each output file.
3464
34652002-02-28 Akim Demaille <akim@epita.fr>
3466
3467 * data/bison.c++: Copy the prologue of bison.simple to fetch
3468 useful M4 definitions, such as b4_header_guard.
3469
34702002-02-25 Akim Demaille <akim@epita.fr>
3471
3472 * src/getargs.c (version): Give the name of the authors, and use a
3473 translator friendly scheme for the bgr
3474 copyright notice.
3475
34762002-02-25 Akim Demaille <akim@epita.fr>
3477
3478 * src/output.c (header_output): Remove, now handled completely via
3479 M4.
3480
34812002-02-25 Akim Demaille <akim@epita.fr>
3482
3483 * m4/m4.m4: New, from CVS Autoconf.
3484 * configure.in: Invoke it.
3485 * src/output.c (output_skeleton): Use its result instead of the
3486 hard coded name.
3487
34882002-02-25 Akim Demaille <akim@epita.fr>
3489
3490 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3491 Fileutils 4.1.5.
3492 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3493 * src/output.c (output_skeleton): Use mkstemp to create a real
3494 temporary file.
3495 Move the filling of `skeleton' and its muscle to...
3496 (prepare): here.
3497 (output): Move the definition of the prologue muscle to...
3498 (prepare): here.
3499 * src/system.h (DEFAULT_TMPDIR): New.
3500
35012002-02-14 Paul Eggert <eggert@twinsun.com>
3502
3503 Remove the support for C++ namespace cleanliness; it was
3504 causing more problems than it was curing, since it didn't work
3505 properly on some nonstandard C++ compilers. This can wait
3506 for a proper C++ parser.
3507
3508 * NEWS: Document this.
3509 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3510 of C++, as it's treated like C now.
3511 * src/bison.simple (YYSTD): Remove.
3512 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3513 Treat C++ just like Standard C instead of trying to support
3514 namespace cleanliness.
3515
35162002-02-14 Akim Demaille <akim@epita.fr>
3517
3518 * tests/regression.at (else): Adjust to Andreas' change.
3519
35202002-02-14 Akim Demaille <akim@epita.fr>
3521
3522 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3523
35242002-02-13 Andreas Schwab <schwab@suse.de>
3525
3526 * src/output.c (output_rule_data): Don't output NULL, it might
3527 not be defined yet.
3528
35292002-02-11 Robert Anisko <robert@lrde.epita.fr>
3530
3531 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3532 (Copyright notice): Update.
3533
35342002-02-11 Akim Demaille <akim@epita.fr>
3535
3536 * tests/regression.at (%nonassoc and eof): Don't include
3537 nonportable headers.
3538
35392002-02-08 Robert Anisko <robert@lrde.epita.fr>
3540
3541 * data/bison.c++: Correct error recovery. Make the user able to
3542 initialize the starting location.
3543
35442002-02-07 Akim Demaille <akim@epita.fr>
3545
3546 * tests/input.at: New.
3547
35482002-02-07 Robert Anisko <robert@lrde.epita.fr>
3549
3550 * data/bison.c++: Replace some direct m4 expansions by constants. Be
3551 more consistent when naming methods and variables. Put preprocessor
3552 directives around tables only needed for debugging.
3553
35542002-02-07 Robert Anisko <robert@lrde.epita.fr>
3555
3556 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3557 C++ parsers.
3558 (yy::b4_name::parse): Use print_.
3559
35602002-02-07 Robert Anisko <robert@lrde.epita.fr>
3561
3562 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3563
35642002-02-07 Robert Anisko <robert@lrde.epita.fr>
3565
3566 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3567 C++ parsers.
3568 (yy::b4_name::parse): Build verbose error messages, and use error_.
3569
35702002-02-06 Robert Anisko <robert@lrde.epita.fr>
3571
3572 * data/bison.c++: Fix m4 quoting in comments.
3573
35742002-02-06 Robert Anisko <robert@lrde.epita.fr>
3575
3576 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3577 not expanded by m4.
3578
35792002-02-05 Akim Demaille <akim@epita.fr>
3580
3581 * data/bison.c++: Adjust to the M4 back end.
3582 More is certainly needed.
3583
35842002-02-05 Akim Demaille <akim@epita.fr>
3585
3586 Give a try to M4 as a back end.
3587
3588 * lib/readpipe.c: New, from wdiff.
3589 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3590 BISON_HAIRY.
3591 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3592 specific values. Now it is m4 that performs the lookup.
3593 * src/parse-skel.y: Remove.
3594 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3595 * src/output.c (actions_output, guards_output)
3596 (token_definitions_output): No longer keeps track of the output
3597 line number, hence remove the second argument.
3598 (guards_output): Check against the guard member of a rule, not the
3599 action member.
3600 Adjust callers.
3601 (output_skeleton): Don't look for the skeleton location, let m4 do
3602 that.
3603 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3604 file will be used.
3605 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3606 (prepare): Given that for the time being changesyntax is not
3607 usable in M4, rename the muscles using `-' to `_'.
3608 Define `defines_flag', `output_parser_name' and `output_header_name'.
3609 * src/output.h (actions_output, guards_output)
3610 (token_definitions_output): Adjust prototypes.
3611 * src/scan-skel.l: Instead of scanning the skeletons, it now
3612 processes the output of m4: `__oline__' and `#output'.
3613 * data/bison.simple: Adjust to be used by M4(sugar).
3614 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3615 to date.
3616 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3617 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3618 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3619 shamelessly stolen from CVS Autoconf.
3620
36212002-02-05 Akim Demaille <akim@epita.fr>
3622
3623 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3624 * configure.in: Check for the declarations of free and malloc.
3625 * src/muscle_tab.c: Adjust.
3626
36272002-02-05 Akim Demaille <akim@epita.fr>
3628
3629 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3630 which have no values.
3631
36322002-02-05 Akim Demaille <akim@epita.fr>
3633
3634 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3635 * data/: here.
3636
36372002-01-29 Paul Eggert <eggert@twinsun.com>
3638
3639 * src/bison.simple (YYSIZE_T): Do not define merely because
3640 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3641 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3642
36432002-01-27 Akim Demaille <akim@epita.fr>
3644
3645 Fix `%nonassoc and eof'.
3646
3647 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3648 which were not properly copied! Replace
3649 memcpy (res->errs, src->errs, src->nerrs);
3650 with
3651 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3652 !!!
3653 * tests/regression.at (%nonassoc and eof): Adjust to newest
3654 Autotest: `.' is not in the PATH.
3655
36562002-01-27 Akim Demaille <akim@epita.fr>
3657
3658 * tests/sets.at (AT_EXTRACT_SETS): New.
3659 (Nullable): Use it.
3660 (Firsts): New.
3661
36622002-01-26 Akim Demaille <akim@epita.fr>
3663
3664 * tests/actions.at, tests/calc.at, tests/headers.at,
3665 * tests/torture.at: Adjust to the newest Autotest which no longer
3666 forces `.' in the PATH.
3667
36682002-01-25 Akim Demaille <akim@epita.fr>
3669
3670 * tests/regression.at (%nonassoc and eof): New.
3671 Suggested by Robert Anisko.
3672
36732002-01-24 Akim Demaille <akim@epita.fr>
3674
3675 Bison dumps core when trying to complain about broken input files.
3676 Reported by Cris van Pelt.
3677
3678 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3679 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3680 into...
3681 (Invalid inputs): Strengthen: exercise parse_percent_token.
3682
36832002-01-24 Robert Anisko <robert.anisko@epita.fr>
3684
3685 * src/Makefile.am: Add bison.c++.
3686 * src/bison.c++: New skeleton.
3687
36882002-01-21 Paolo Bonzini <bonzini@gnu.org>
3689
3690 * po/it.po: New.
3691
36922002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3693
3694 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3695
36962002-01-20 Marc Autret <marc@gnu.org>
3697
3698 * src/files.c (compute_output_file_names): Fix
3699
37002002-01-20 Marc Autret <marc@gnu.org>
3701
3702 * tests/output.at: New test.
3703 * src/files.c (compute_base_names): Don't map extensions when
3704 the YACC flag is set, use defaults.
3705 Reported by Evgeny Stambulchik.
3706
37072002-01-20 Marc Autret <marc@gnu.org>
3708
3709 * src/system.h: Need to define __attribute__ away for non-GCC
3710 compilers as well (i.e. the vendor C compiler).
3711 Suggested by Albert Chin-A-Young.
3712
37132002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3714
3715 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3716 canonical definition.
3717 * src/system.h: Use the canonical definition for PARAMS (avoids
3718 a conflict with the macro from lib/hash.h).
3719
37202002-01-11 Akim Demaille <akim@epita.fr>
3721
3722 * configure.in: Use AC_FUNC_STRNLEN.
3723 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
3724
37252002-01-09 Akim Demaille <akim@epita.fr>
3726
3727 * src/files.c, src/files.h (output_infix): New.
3728 (tab_extension): Remove.
3729 (compute_base_names): Compute the former, drop the latter.
3730 * src/output.c (prepare): Insert the muscles `output-infix', and
3731 `output-suffix'.
3732 * src/parse-skel.y (string, string.1): New.
3733 (section.header): Use it.
3734 (section.yacc): Remove.
3735 (prefix): Remove too.
3736 * src/scan-skel.l: Adjust.
3737 * src/bison.simple, src/bison.hairy: Adjust.
3738
37392002-01-09 Akim Demaille <akim@epita.fr>
3740
3741 * configure.in (WERROR_CFLAGS): Compute it.
3742 * src/Makefile.am (CFLAGS): Pass it.
3743 * tests/atlocal.in (CFLAGS): Idem.
3744 * src/files.c: Fix a few warnings.
3745 (get_extension_index): Remove, unused.
3746
37472002-01-08 Akim Demaille <akim@epita.fr>
3748
3749 * src/getargs.c (AS_FILE_NAME): New.
3750 (getargs): Use it to convert DOSish file names.
3751 * src/files.c (base_name): Rename as full_base_name to avoid
3752 clashes with `base_name ()'.
3753 (filename_split): New.
3754 (compute_base_names): N-th rewrite, using filename_split.
3755
37562002-01-08 Akim Demaille <akim@epita.fr>
3757
3758 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3759 New, stolen from the Fileutils 4.1.
3760 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3761 * configure.in: Check for the presence of memrchr, and of its
3762 prototype.
3763
37642002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3765
3766 * lib/hash.h (__P): Added definition for this macro.
3767 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3768 BUILT_SOURCES, to ensure they are generated first.
3769 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3770 %error-verbose to allow bootstrapping with bison 1.30x.
3771
37722002-01-06 Akim Demaille <akim@epita.fr>
3773
3774 * src/reader.c (parse_braces): Don't fetch the next char, the
3775 convention is to fetch on entry.
3776 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3777 'switch' without a following semicolon.
3778 * tests/regression.at (braces parsing): New.
3779
37802002-01-06 Akim Demaille <akim@epita.fr>
3781
3782 Bison is dead wrong in its RR conflict reports.
3783
3784 * tests/torture.at (GNU Cim Grammar): New.
3785 * src/conflicts.c (count_rr_conflicts): Fix.
3786
37872002-01-06 Akim Demaille <akim@epita.fr>
3788
3789 Creating package.m4 from configure.ac causes too many problems.
3790
3791 * tests/Makefile.am (package.m4): Create it by hand,
3792 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3793
37942002-01-06 Akim Demaille <akim@epita.fr>
3795
3796 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3797 skeleton.h.
3798
37992002-01-04 Paul Eggert <eggert@twinsun.com>
3800
3801 * doc/bison.texinfo (Debugging):
3802 Remove YYSTDERR; it's no longer defined or used.
3803 Also, s/cstdio.h/cstdio/.
3804
38052002-01-03 Akim Demaille <akim@epita.fr>
3806
3807 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3808
38092002-01-03 Akim Demaille <akim@epita.fr>
3810
3811 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3812 tracing code to --trace, wait for a better --trace option, with
3813 args.
3814
38152002-01-03 Akim Demaille <akim@epita.fr>
3816
3817 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3818 The ISO C++ standard is extremely clear about it: stderr is
3819 considered a macro, not a regular symbol (see table 94 `Header
3820 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3821 Therefore std:: does not apply to it. It still does with fprintf.
3822 Also, s/cstdio.h/cstdio/.
3823
38242002-01-03 Akim Demaille <akim@epita.fr>
3825
3826 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3827 for non system headers.
3828
38292002-01-02 Akim Demaille <akim@epita.fr>
3830
3831 Equip the skeleton chain with location tracking, runtime trace,
3832 pure parser and scanner.
3833
3834 * src/parse-skel.y: Request a pure parser, locations, and prefix
3835 renaming.
3836 (%union): Having several members with the same type does not help
3837 type mismatches, simplify.
3838 (YYPRINT, yyprint): New.
3839 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3840 (skel_error): this.
3841 Handle locations.
3842 * src/scan-skel.l: Adjust to these changes.
3843 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3844 (LOCATION_PRINT, skel_control_t): New.
3845
38462001-12-30 Akim Demaille <akim@epita.fr>
3847
3848 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3849 replace `gb' with BLANKS.
3850 * src/scan-skel.l: Adjust.
3851
38522001-12-30 Akim Demaille <akim@epita.fr>
3853
3854 * src/system.h: We don't need nor want bcopy.
3855 Throw away MS-DOS crap: we don't need getpid.
3856 * configure.in: We don't need strndup. It was even causing
3857 problems: because Flex includes the headers *before* us,
3858 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3859 not visible.
3860 * lib/xstrndup.c: New.
3861 * src/scan-skel.l: Use it.
3862 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3863 * src/parse-skel.y: Use %directives instead of #defines.
3864
38652001-12-30 Akim Demaille <akim@epita.fr>
3866
3867 * src/skeleton.h: New.
3868 * src/output.c (output_parser, output_master_parser): Remove, dead
3869 code.
3870 * src/output.h (get_lines_number, actions_output, guards_output)
3871 (token_definitions_output): Prototype them.
3872 * src/parse-skel.y: Add the license notice.
3873 Include output.h and skeleton.h.
3874 (process_skeleton): Returns void, and takes a single parameter.
3875 * src/scan-skel.l: Add the license notice.
3876 Include skeleton.h.
3877 Don't use %option yylineno: it seems that then Flex imagines
3878 REJECT has been used, and therefore it won't reallocate its
3879 buffers (which makes no other sense to me than a bug). It results
3880 in warnings for `unused: yy_flex_realloc'.
3881
38822001-12-30 Robert Anisko <robert.anisko@epita.fr>
3883
3884 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3885 (MUSCLE_INSERT_PREFIX): ...to there.
3886 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3887 (MUSCLE_INSERT_PREFIX): Move from here...
3888
3889 * src/bison.hairy: Add a section directive. Put braces around muscle
3890 names. This parser skeleton is still broken, but Bison should not
3891 choke on a bad muscle 'syntax'.
3892 * src/bison.simple: Add a section directive. Put braces around muscle
3893 names.
3894
3895 * src/files.h (strsuffix, stringappend): Add declarations.
3896 (tab_extension): Add declaration.
3897 (short_base_name): Add declaration.
3898
3899 * src/files.c (strsuffix, stringappend): No longer static. These
3900 functions are used in the skeleton parser.
3901 (tab_extension): New.
3902 (compute_base_names): Use the computations done in this function
3903 to guess if the generated parsers should have '.tab' in their
3904 names.
3905 (short_base_name): No longer static.
3906
3907 * src/output.c (output_skeleton): New.
3908 (output): Disable call to output_master_parser, and give a try to
3909 a new skeleton handling system.
3910 (guards_output, actions_output): No longer static.
3911 (token_definitions_output, get_lines_number): No longer static.
3912
3913 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3914
3915 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
3916 parse-skel.y.
3917
3918 * src/parse-skel.y: New file.
3919 * src/scan-skel.l: New file.
3920
39212001-12-29 Akim Demaille <akim@epita.fr>
3922
3923 %name-prefix is broken.
3924
3925 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3926 Adjust all dependencies.
3927 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3928 %name-prefix.
3929
3930 Renaming yylval but not yylloc is not consistent. Now we do.
3931
3932 * src/bison.simple: Prefix yylloc if used.
3933 * doc/bison.texinfo (Decl Summary): Document that.
3934
39352001-12-29 Akim Demaille <akim@epita.fr>
3936
3937 * doc/bison.texinfo: Promote `%long-directive' over
3938 `%long_directive'.
3939 Remove all references to fixed-output-files, yacc is enough.
3940
39412001-12-29 Akim Demaille <akim@epita.fr>
3942
3943 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3944 user prologue. These are defaults.
3945 * tests/actions.at (Mid-rule actions): Make sure the user can
3946 define YYDEBUG and YYERROR_VERBOSE.
3947
39482001-12-29 Akim Demaille <akim@epita.fr>
3949
3950 * src/output.c (header_output): Don't forget to export YYLTYPE and
3951 yylloc.
3952 * tests/headers.at (export YYLTYPE): New, make sure it does.
3953 * tests/regression.at (%union and --defines, Invalid CPP headers):
3954 Move to...
3955 * tests/headers.at: here.
3956
39572001-12-29 Akim Demaille <akim@epita.fr>
3958
3959 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3960
39612001-12-29 Akim Demaille <akim@epita.fr>
3962
3963 * tests/actions.at (Mid-rule actions): Output on a single line
3964 instead of several.
3965
39662001-12-29 Akim Demaille <akim@epita.fr>
3967
3968 * doc/bison.texinfo: Formatting changes.
3969
39702001-12-29 Akim Demaille <akim@epita.fr>
3971
3972 Don't store the token defs in a muscle, just be ready to output it
3973 on command. Now possible via `symbols'. Fixes a memory leak.
3974
3975 * src/output.c (token_definitions_output): New.
3976 (output_parser, header_output): Use it.
3977 * src/reader.c (symbols_save): Remove.
3978
39792001-12-29 Akim Demaille <akim@epita.fr>
3980
3981 * src/bison.simple: Do not provide a default for YYSTYPE and
3982 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3983 default.
3984
39852001-12-29 Akim Demaille <akim@epita.fr>
3986
3987 Mid-rule actions are simply... ignored!
3988
3989 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3990 the empty-rule associated to the dummy symbol, not to the host
3991 rule.
3992 * tests/actions.at (Mid-rule actions): New.
3993
39942001-12-29 Akim Demaille <akim@epita.fr>
3995
3996 Memory leak.
3997
3998 * src/reader.c (reader): Free grammar.
3999
40002001-12-29 Akim Demaille <akim@epita.fr>
4001
4002 Memory leak.
4003
4004 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4005 since it allocates it for each state, although only one is needed.
4006 (allocate_storage): Do it here.
4007
40082001-12-29 Akim Demaille <akim@epita.fr>
4009
4010 * src/options.h, src/options.c (create_long_option_table): Rename
4011 as...
4012 (long_option_table_new): this, with a clearer prototype.
4013 (percent_table): Remove, unused,
4014 * src/getargs.c (getargs): Adjust.
4015
40162001-12-29 Akim Demaille <akim@epita.fr>
4017
4018 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4019 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4020 as states.
4021
40222001-12-29 Akim Demaille <akim@epita.fr>
4023
4024 * src/lalr.c (build_relations): Rename `states' as `states1'.
4025 Sorry, I don't understand exactly what it is, no better name...
4026
40272001-12-29 Akim Demaille <akim@epita.fr>
4028
4029 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4030 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4031 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4032 as rules.
4033
40342001-12-29 Akim Demaille <akim@epita.fr>
4035
4036 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4037 ago.
4038
40392001-12-29 Akim Demaille <akim@epita.fr>
4040
4041 * src/reader.c, src/reader.h (user_toknums): Remove.
4042 Adjust all users to use symbols[i]->user_token_number.
4043
40442001-12-29 Akim Demaille <akim@epita.fr>
4045
4046 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4047 Adjust all users to use symbols[i]->prec or ->assoc.
4048
40492001-12-29 Akim Demaille <akim@epita.fr>
4050
4051 * src/reader.c, src/reader.h (tags): Remove.
4052 Adjust all users to use symbols[i]->tag.
4053
40542001-12-29 Akim Demaille <akim@epita.fr>
4055
4056 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4057 and rule_table.
4058 * src/reader.c (packsymbols): Fill this table.
4059 Drop sprec.
4060 * src/conflicts.c (resolve_sr_conflict): Adjust.
4061 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4062 single table.
4063 Use symbols[i]->tag instead of tags[i].
4064
40652001-12-29 Akim Demaille <akim@epita.fr>
4066
4067 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4068 In addition, put a comment in there, to replace...
4069 * tests/regression.at (%union and C comments): Remove.
4070
40712001-12-29 Akim Demaille <akim@epita.fr>
4072
4073 * tests/regression.at (Web2c Actions): Blindly move the actual
4074 output as expected output. The contents *seem* right to me, but I
4075 can't pretend reading perfectly parser tables... Nonetheless, all
4076 the other tests pass correctly, the table look OK, even though the
4077 presence of `$axiom' is to be noted: AFAICS it is useless (but
4078 harmless).
4079
40802001-12-29 Akim Demaille <akim@epita.fr>
4081
4082 * src/reader.c (readgram): Don't add the rule 0 if there were no
4083 rules read. In other words, add it _after_ having performed
4084 grammar sanity checks.
4085 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4086
40872001-12-29 Akim Demaille <akim@epita.fr>
4088
4089 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4090 visible, and some states have now a different number.
4091
40922001-12-29 Akim Demaille <akim@epita.fr>
4093
4094 * src/reader.c (readgram): Bind the initial rule's lineno to that
4095 of the first rule.
4096 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4097 (Solved SR Conflicts): Adjust rule 0's line number.
4098
40992001-12-29 Akim Demaille <akim@epita.fr>
4100
4101 Fix the `GAWK Grammar' failure.
4102
4103 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4104 the reductions of the first state which was mistakenly confused
4105 with the final state because precisely final_state was initialized
4106 to 0.
4107 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4108 now noticed by Bison.
4109 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4110 have a reduction on $default.
4111
41122001-12-29 Akim Demaille <akim@epita.fr>
4113
4114 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4115 rule line numbers.
4116 * src/closure.c (print_closure): Likewise.
4117 * src/derives.c (print_derives): Likewise.
4118 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4119 now.
4120
41212001-12-29 Akim Demaille <akim@epita.fr>
4122
4123 * src/lalr.c (lookaheads_print): New.
4124 (lalr): Call it when --trace-flag.
4125 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4126 are dumped.
4127
41282001-12-29 Akim Demaille <akim@epita.fr>
4129
4130 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4131 when walking through ritem, even via rule->rhs.
4132 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4133 (useful_production, useless_nonterminals): Likewise.
4134 (reduce_grammar_tables): Likewise, plus update nritems.
4135 * src/nullable.c (set_nullable): Likewise.
4136 * src/lalr.c (build_relations): Likewise.
4137 * tests/sets.at (Nullable): Adjust.
4138 Fortunately, now, the $axiom is no longer nullable.
4139
41402001-12-29 Akim Demaille <akim@epita.fr>
4141
4142 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4143 the 0-sentinel.
4144 * src/gram.c (ritem_longest_rhs): Likewise.
4145 * src/reduce.c (nonterminals_reduce): Likewise.
4146 * src/print_graph.c (print_graph): Likewise.
4147 * src/output.c (output_rule_data): Likewise.
4148 * src/nullable.c (set_nullable): Likewise.
4149
41502001-12-29 Akim Demaille <akim@epita.fr>
4151
4152 * src/output.c: Comment changes.
4153
41542001-12-27 Paul Eggert <eggert@twinsun.com>
4155
4156 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4157 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4158 Sparc, as they were causing more porting problems than the
4159 (minor) performance improvement was worth.
4160
4161 Also, catch up with 1.31's YYSTD.
4162
41632001-12-27 Akim Demaille <akim@epita.fr>
4164
4165 * src/output.c (output_gram): Rely on nritems, not the
4166 0-sentinel. See below.
4167 Use -1 as separator, not 0.
4168 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4169 Rely on -1 as separator in yyrhs, instead of 0.
4170 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4171 twice `Now at end of input', therefore there are two lines less to
4172 expect.
4173
41742001-12-27 Akim Demaille <akim@epita.fr>
4175
4176 * tests/regression.at (Unresolved SR Conflicts):
4177 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4178 below.
4179
41802001-12-27 Akim Demaille <akim@epita.fr>
4181
4182 * src/LR0.c (new_state): Recognize the final state by the fact it
4183 is reached by eoftoken.
4184 (insert_start_shifting_state, insert_eof_shifting_state)
4185 (insert_accepting_state, augment_automaton): Remove, since now
4186 these states are automatically computed from the initial state.
4187 (generate_states): Adjust.
4188 * src/print.c: When reporting a rule number to the user, substract
4189 1, so that the axiom rule is rule 0, and the first user rule is 1.
4190 * src/reduce.c: Likewise.
4191 * src/print_graph.c (print_core): For the time being, just as for
4192 the report, depend upon --trace-flags to dump the full set of
4193 items.
4194 * src/reader.c (readgram): Once the grammar read, insert the rule
4195 0: `$axiom: START-SYMBOL $'.
4196 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4197 number of the states has changed (the final state is no longer
4198 necessarily the last), catch up.
4199
42002001-12-27 Akim Demaille <akim@epita.fr>
4201
4202 Try to make the use of the eoftoken valid. Given that its value
4203 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4204 is used instead of > 0 where appropriate, (ii), depend upon nritems
4205 instead of the 0-sentinel.
4206
4207 * src/gram.h, src/gram.c (nritems): New.
4208 Expected to be duplication of nitems, but for the time being...
4209 * src/reader.c (packgram): Assert nritems and nitems are equal.
4210 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4211 * src/closure.c (print_closure, print_fderives): Likewise.
4212 * src/gram.c (ritem_print): Likewise.
4213 * src/print.c (print_core, print_grammar): Likewise.
4214 * src/print_graph.c: Likewise.
4215
42162001-12-27 Akim Demaille <akim@epita.fr>
4217
4218 * src/main.c (main): If there are complains after grammar
4219 reductions, then output the report anyway if requested, then die.
4220 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4221 * src/reader.c (eoftoken): New.
4222 (parse_token_decl): If the token being defined has value `0', it
4223 is the eoftoken.
4224 (packsymbols): No longer hack `tags' to insert `$' by hand.
4225 Be sure to preserve the value of the eoftoken.
4226 (reader): Make sure eoftoken is defined.
4227 Initialize nsyms to 0: now eoftoken is created just like the others.
4228 * src/print.c (print_grammar): Don't special case the eof token.
4229 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4230 lie anyway, albeit pleasant.
4231 * tests/calc.at: Exercise error messages with eoftoken.
4232 Change the grammar so that empty input is invalid.
4233 Adjust expectations.
4234 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4235
42362001-12-27 Akim Demaille <akim@epita.fr>
4237
4238 * configure.in: Check the protos of strchr ans strspn.
4239 Replace strchr if needed.
4240 * src/system.h: Provide the protos of strchr, strspn and memchr if
4241 missing.
4242 * lib/strchr.c: New.
4243 * src/reader.c (symbols_save): Use strchr.
4244
42452001-12-27 Akim Demaille <akim@epita.fr>
4246
4247 * src/print.c, src/print_graph.c (escape): New.
4248 Use it to quote the TAGS outputs.
4249 * src/print_graph.c (print_state): Now errors are in red, and
4250 reductions in green.
4251 Prefer high to wide: output the state number on a line of its own.
4252
42532001-12-27 Akim Demaille <akim@epita.fr>
4254
4255 * src/state.h, src/state.c (reductions_new): New.
4256 * src/LR0.c (set_state_table): Let all the states have a
4257 `reductions', even if reduced to 0.
4258 (save_reductions): Adjust.
4259 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4260 * src/print.c (print_reductions, print_actions): Adjust.
4261 * src/output.c (action_row): Adjust.
4262
42632001-12-27 Akim Demaille <akim@epita.fr>
4264
4265 * src/state.h, src/state.c (errs_new, errs_dup): New.
4266 * src/LR0.c (set_state_table): Let all the states have an errs,
4267 even if reduced to 0.
4268 * src/print.c (print_errs, print_reductions): Adjust.
4269 * src/output.c (output_actions, action_row): Adjust.
4270 * src/conflicts.c (resolve_sr_conflict): Adjust.
4271
42722001-12-27 Akim Demaille <akim@epita.fr>
4273
4274 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4275
42762001-12-27 Akim Demaille <akim@epita.fr>
4277
4278 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4279 * src/print.c: here.
4280 (lookaheadset, shiftset): New, used as additional storage by
4281 print_reductions.
4282 (print_results): Adjust.
4283 (print_shifts, print_gotos, print_errs): New, extracted from...
4284 (print_actions): here.
4285 * src/print_graph.c (print_actions): Remove dead code.
4286
42872001-12-27 Akim Demaille <akim@epita.fr>
4288
4289 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4290 `$n' and `@n'.
4291
42922001-12-27 Akim Demaille <akim@epita.fr>
4293
4294 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4295 (build_relations): Adjust.
4296
42972001-12-27 Akim Demaille <akim@epita.fr>
4298
4299 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4300 duplication.
4301
43022001-12-27 Akim Demaille <akim@epita.fr>
4303
4304 * src/reader.c (packgram): Catch nitems overflows.
4305
43062001-12-27 Akim Demaille <akim@epita.fr>
4307
4308 * src/files.c, src/files.h (guard_obstack): Remove.
4309 * src/output.c (output): Adjust.
4310 * src/reader.c (parse_braces): New, factoring...
4311 (copy_action, copy_guard): these two which are renamed as...
4312 (parse_action, parse_guard): these.
4313 As a voluntary consequence, using braces around guards is now
4314 mandatory.
4315
43162001-12-27 Akim Demaille <akim@epita.fr>
4317
4318 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
4319 * src/reader.c (symbol_list): `guard' and `guard_line' are new
4320 members.
4321 (symbol_list_new): Adjust.
4322 (copy_action): action_line is the first line, not the last.
4323 (copy_guard): Just as for actions, store the `action' only, not
4324 the switch/case/break flesh.
4325 Don't parse the user action that might follow the guard, let...
4326 (readgram): do it, i.e., now, there can be an action after a
4327 guard.
4328 In other words the guard is just explicitly optional.
4329 (packgram): Adjust.
4330 * src/output.c (guards_output): New.
4331 (output_parser): Call it when needed.
4332 (output): Also free the guard and attrs obstacks.
4333 * src/files.c, src/files.h (obstack_save): Remove.
4334 (output_files): Remove.
4335 As a result, if one needs the former `.act' file, using an
4336 appropriate skeleton which requires actions and guards is now
4337 required.
4338 * src/main.c (main): Adjust.
4339 * tests/semantic.at: New.
4340 * tests/regression.at: Use `input.y' as input file name.
4341 Avoid 8+3 problems by requiring input.c when the test needs the
4342 parser.
4343
43442001-12-27 Akim Demaille <akim@epita.fr>
4345
4346 * src/reader.c (symbol_list_new): Be sure to initialize all the
4347 fields.
4348
43492001-12-27 Akim Demaille <akim@epita.fr>
4350
4351 All the hacks using a final pseudo state are now useless.
4352
4353 * src/LR0.c (set_state_table): state_table holds exactly nstates.
4354 * src/lalr.c (nLA): New.
4355 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
4356 instead of lookaheadsp from the pseudo state (nstate + 1).
4357
43582001-12-27 Akim Demaille <akim@epita.fr>
4359
4360 * src/output.c (action_row, token_actions): Use a state_t instead
4361 of a integer, and nlookaheads instead of the following state's
4362 lookaheadsp.
4363
43642001-12-27 Akim Demaille <akim@epita.fr>
4365
4366 * src/conflicts.c (log_resolution, flush_shift)
4367 (resolve_sr_conflict, set_conflicts, solve_conflicts)
4368 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
4369 (conflicts_print, print_reductions): Use a state_t instead of an
4370 integer when referring to a state.
4371 As much as possible, depend upon nlookaheads, instead of the
4372 `lookaheadsp' member of the following state (since lookaheads of
4373 successive states are successive, the difference between state n + 1
4374 and n served as the number of lookaheads for state n).
4375 * src/lalr.c (add_lookback_edge): Likewise.
4376 * src/print.c (print_core, print_actions, print_state)
4377 (print_results): Likewise.
4378 * src/print_graph.c (print_core, print_actions, print_state)
4379 (print_graph): Likewise.
4380 * src/conflicts.h: Adjust.
4381
43822001-12-27 Akim Demaille <akim@epita.fr>
4383
4384 * src/bison.hairy: Formatting/comment changes.
4385 ANSIfy.
4386 Remove `register' indications.
4387 Add plenty of `static'.
4388
43892001-12-27 Akim Demaille <akim@epita.fr>
4390
4391 * src/output.c (prepare): Drop the muscle `ntbase' which
4392 duplicates ntokens.
4393 * src/bison.simple: Formatting/comment changes.
4394 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
4395 is an undocumented synonym.
4396
43972001-12-22 Akim Demaille <akim@epita.fr>
4398
4399 * src/output.c (output_table_data): Change the prototype to use
4400 `int' for array ranges: some invocations do pass an int, not a
4401 short.
4402 Reported by Wayne Green.
4403
44042001-12-22 Akim Demaille <akim@epita.fr>
4405
4406 Some actions of web2c.y are improperly triggered.
4407 Reported by Mike Castle.
4408
4409 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
4410 * tests/regression.at (Web2c): Rename as...
4411 (Web2c Report): this.
4412 (Web2c Actions): New.
4413
44142001-12-22 Akim Demaille <akim@epita.fr>
4415
4416 Reductions in web2c.y are improperly reported.
4417 Reported by Mike Castle.
4418
4419 * src/conflicts.c (print_reductions): Fix.
4420 * tests/regression.at (Web2c): New.
4421
44222001-12-18 Akim Demaille <akim@epita.fr>
4423
4424 Some host fail on `assert (!"foo")', which expands to
4425 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
4426 Reported by Nelson Beebee.
4427
4428 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
4429 `#define it_succeeded 0' and `assert (it_succeeded)'.
4430
44312001-12-17 Marc Autret <autret_m@epita.fr>
4432
4433 * src/bison.simple: Don't hard code the skeleton line and filename.
4434 * src/output.c (output_parser): Rename 'line' as 'output_line'.
4435 New line counter 'skeleton_line' (skeleton-line muscle).
4436
44372001-12-17 Paul Eggert <eggert@twinsun.com>
4438
4439 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
4440 YYDEBUG must be defined to a nonzero value.
4441
4442 * src/bison.simple (yytname): Do not assume that the user defines
4443 YYDEBUG to a properly parenthesized expression.
4444
44452001-12-17 Akim Demaille <akim@epita.fr>
4446
4447 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
4448 nlookaheads is a new member.
4449 Adjust all users.
4450 * src/lalr.h (nlookaheads): Remove this orphan declaration.
4451 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
4452 state.
4453
44542001-12-17 Akim Demaille <akim@epita.fr>
4455
4456 * src/files.h, src/files.c (open_files, close_files): Remove.
4457 * src/main.c (main): Don't open/close files, nor invoke lex_free,
4458 let...
4459 * src/reader.c (reader): Do it.
4460
44612001-12-17 Akim Demaille <akim@epita.fr>
4462
4463 * src/conflicts.c (print_reductions): Formatting changes.
4464
44652001-12-17 Akim Demaille <akim@epita.fr>
4466
4467 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
4468 (flush_reduce): New.
4469 (resolve_sr_conflict): Adjust.
4470
44712001-12-17 Akim Demaille <akim@epita.fr>
4472
4473 * src/output.c (output_obstack): Be static and rename as...
4474 (format_obstack): this, to avoid any confusion with files.c's
4475 output_obstack.
4476 * src/reader.h (muscle_obstack): Move to...
4477 * src/output.h: here, since it's defined in output.c.
4478
44792001-12-17 Akim Demaille <akim@epita.fr>
4480
4481 * src/output.c (action_row, save_column, default_goto)
4482 (sort_actions, matching_state, pack_vector): Better variable
4483 locality.
4484
44852001-12-17 Akim Demaille <akim@epita.fr>
4486
4487 * src/output.c: Various formatting changes.
4488
44892001-12-17 Akim Demaille <akim@epita.fr>
4490
4491 * src/files.c (output_files): Free the output_obstack.
4492 * src/main.c (main): Call print and print_graph conditionally.
4493 * src/print.c (print): Work unconditionally.
4494 * src/print_graph.c (print_graph): Work unconditionally.
4495 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4496
44972001-12-16 Marc Autret <autret_m@epita.fr>
4498
4499 * src/output.c (actions_output): Fix. When we use %no-lines,
4500 there is one less line per action.
4501
45022001-12-16 Marc Autret <autret_m@epita.fr>
4503
4504 * src/bison.simple: Remove a useless #line directive.
4505 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4506 * src/output.c (get_lines_number): New.
4507 (output_parser): Adjust, now takes care about the lines of a
4508 output muscles.
4509 Fix line numbering.
4510 (actions_output): Computes the number of lines taken by actions.
4511 (output_master_parser): Insert new skeleton which is the name of
4512 the output parser file name.
4513
45142001-12-15 Marc Autret <autret_m@epita.fr>
4515
4516 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4517
45182001-12-15 Marc Autret <autret_m@epita.fr>
4519
4520 * src/output.c (output_gram): Keep track of the hairy one.
4521
45222001-12-15 Akim Demaille <akim@epita.fr>
4523
4524 Make `make distcheck' work.
4525
4526 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4527 system.h which uses libgettext.h.
4528
45292001-12-15 Akim Demaille <akim@epita.fr>
4530
4531 * src/nullable.c (set_nullable): Useless rules must be skipped,
4532 otherwise, since we range over their symbols, we might look at a
4533 nonterminal which no longer ``exists'', i.e., it is not counted in
4534 `nvars', hence we overflow our arrays.
4535
45362001-12-15 Akim Demaille <akim@epita.fr>
4537
4538 The header can also be produced directly, without any obstack!
4539 Yahoo!
4540
4541 * src/files.c, src/files.h (defines_obstack): Remove.
4542 (compute_header_macro): Global.
4543 (defines_obstack_save): Remove.
4544 * src/reader.c (parse_union_decl): No longer output to
4545 defines_obstack: its content can be found in the `stype' muscle
4546 anyway.
4547 (output_token_translations): Merge into...
4548 (symbols_output): this.
4549 Rename as...
4550 (symbols_save): this.
4551 (reader): Adjust.
4552 * src/output.c (header_output): New.
4553 (output): Call it.
4554
45552001-12-15 Akim Demaille <akim@epita.fr>
4556
4557 * src/reader.c (parse_union_decl): Instead of handling two obstack
4558 simultaneously, use one to define the `stype' muscle, and use the
4559 value of the latter to fill defines_obstack.
4560 (copy_comment): Remove.
4561 (copy_comment2): Work for a single obstack.
4562 Rename as...
4563 (copy_comment): this.
4564
45652001-12-15 Akim Demaille <akim@epita.fr>
4566
4567 * src/lex.c, src/lex.h (xgetc): No longer static.
4568 * src/reader.c (parse_union_decl): Revamp.
4569
45702001-12-15 Akim Demaille <akim@epita.fr>
4571
4572 Still making progress in separating Bison into (i) input, (ii)
4573 process, (iii) output: now we can directly output the parser file
4574 without using table_obstack at all.
4575
4576 * src/files.c, src/files.h (table_obstack): Bye bye.
4577 (parser_file_name): New.
4578 * src/files.c (compute_output_file_names): Compute it.
4579 * src/output.c (actions_output, output_parser)
4580 (output_master_parser): To a file instead of an obstack.
4581
45822001-12-15 Akim Demaille <akim@epita.fr>
4583
4584 Attach actions to rules, instead of pre-outputting them to
4585 actions_obstack.
4586
4587 * src/gram.h (rule_t): action and action_line are new members.
4588 * src/reader.c (symbol_list): Likewise.
4589 (copy_action): Save the actions within the rule.
4590 (packgram): Save them in rule_table.
4591 * src/output.c (actions_output): New.
4592 (output_parser): Use it on `%%actions'.
4593 (output_rule_data): Don't free rule_table.
4594 (output): Do it.
4595 (prepare): Don't save the `action' muscle.
4596 * src/bison.simple: s/%%action/%%actions/.
4597
45982001-12-15 Akim Demaille <akim@epita.fr>
4599
4600 * src/reader.c (copy_action): When --yacc, don't append a `;'
4601 to the user action: let it fail if lacking.
4602 Suggested by Arnold Robbins and Tom Tromey.
4603
46042001-12-14 Akim Demaille <akim@epita.fr>
4605
4606 * src/lex.c (literalchar): Simply return the char you decoded, non
4607 longer mess around with obstacks and int pointers.
4608 Adjust all callers.
4609
46102001-12-14 Akim Demaille <akim@epita.fr>
4611
4612 * src/lex.c (literalchar): Don't escape the special characters,
4613 just decode them, and keep them as char (before, eol was output as
4614 the 2 char string `\n' etc.).
4615 * src/output.c (output_rule_data): Use quotearg to output the
4616 token strings.
4617
46182001-12-13 Paul Eggert <eggert@twinsun.com>
4619
4620 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4621 Do not infringe on the global user namespace when using C++.
4622 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4623 All uses of `fprintf' and `stderr' changed.
4624
4625 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4626
46272001-12-13 Akim Demaille <akim@epita.fr>
4628
4629 The computation of nullable is broken: it doesn't handle empty
4630 RHS's properly.
4631
4632 * tests/torture.at (GNU AWK Grammar): New.
4633 * tests/sets.at (Nullable): New.
4634 * src/nullable.c (set_nullable): Instead of blindly looping over
4635 `ritems', loop over the rules, and then over their rhs's.
4636
4637 Work around Autotest bugs.
4638
4639 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4640 frame, because Autotest understand lines starting with a `+' as
4641 traces from the shell. Then, they are not processed properly.
4642 Admittedly an Autotest bug, but we don't have time to wait for
4643 Autotest to catch up.
4644 * tests/regression.at (Broken Closure): Adjust to the new table
4645 frames.
4646 Move to...
4647 * tests/sets.at: here.
4648
46492001-12-13 Akim Demaille <akim@epita.fr>
4650
4651 * src/closure.c (closure): Use nrules instead of playing tricks
4652 with BITS_PER_WORD.
4653
46542001-12-13 Akim Demaille <akim@epita.fr>
4655
4656 * src/print.c (print_actions): Output the handling of `$' as the
4657 traces do: shifting the token EOF. Before EOF was treated as a
4658 nonterminal.
4659 * tests/regression.at: Adjust some tests.
4660 * src/print_graph.c (print_core): Complete the set of items via
4661 closure. The next-to-final and final states are still unsatisfying,
4662 but that's to be addressed elsewhere.
4663 No longer output the rule numbers, but do output the state number.
4664 A single loop for the shifts + gotos is enough, but picked a
4665 distinct color for each.
4666 (print_graph): Initialize and finalize closure.
4667
46682001-12-13 Akim Demaille <akim@epita.fr>
4669
4670 * src/reader.c (readgram): Remove dead code, an strip useless
4671 braces.
4672 (get_type): Remove, unused.
4673
46742001-12-12 Akim Demaille <akim@epita.fr>
4675
4676 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4677 on that of lib/error.c.
4678
46792001-12-12 Akim Demaille <akim@epita.fr>
4680
4681 Some hosts don't like `/' in includes.
4682
4683 * src/system.h: Include libgettext.h without qualifying the path.
4684 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4685 $(top_srcdir).
4686
46872001-12-11 Marc Autret <autret_m@epita.fr>
4688
4689 * src/output.c (output_parser): Remove useless muscle.
4690
46912001-12-11 Marc Autret <autret_m@epita.fr>
4692
4693 * src/bison.simple: Remove #line just before %%epilogue. It
4694 is now handled in ...
4695 * src/reader.c (read_additionnal_code): Add the output of a
4696 #line for the epilogue.
4697
46982001-12-10 Marc Autret <autret_m@epita.fr>
4699
4700 * src/reader.c (copy_definition): Re-use CPP-outed code which
4701 replace precedent remove.
4702 * src/bison.simple: Remove #line before %%prologue because
4703 %%input-line is wrong at this time.
4704
47052001-12-10 Marc Autret <autret_m@epita.fr>
4706
4707 * src/reader.c (symbols_output): Clean up.
4708 * src/output.c (output_gram, output): Clean up.
4709
47102001-12-10 Akim Demaille <akim@epita.fr>
4711
4712 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4713 * src/LR0.c (set_state_table): here.
4714 * src/lalr.c (lalr): Call it.
4715
47162001-12-10 Akim Demaille <akim@epita.fr>
4717
4718 * src/state.h (shifts): Remove the `number' member: shifts are
4719 attached to state, hence no longer need to be labelled with a
4720 state number.
4721
47222001-12-10 Akim Demaille <akim@epita.fr>
4723
4724 Now that states have a complete set of members, the linked list of
4725 shifts is useless: just fill directly the state's shifts member.
4726
4727 * src/state.h (shifts): Remove the `next' member.
4728 * src/LR0.c (first_state, last_state): Remove.
4729 Adjust the callers.
4730 (augment_automaton): Don't look for the shifts that must be added
4731 a shift on EOF: it is those of the state we looked for! But now,
4732 since shifts are attached, it is no longer needed to looking
4733 merely by its id: its number.
4734
47352001-12-10 Akim Demaille <akim@epita.fr>
4736
4737 * src/LR0.c (augment_automaton): Better variable locality.
4738 Remove an impossible branch: if there is a state corresponding to
4739 the start symbol being shifted, then there is shift for the start
4740 symbol from the initial state.
4741
47422001-12-10 Akim Demaille <akim@epita.fr>
4743
4744 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4745 only when appropriate: when insert_start_shifting_state' is not
4746 invoked.
4747 * tests/regression.at (Rule Line Numbers): Adjust.
4748
47492001-12-10 Akim Demaille <akim@epita.fr>
4750
4751 * src/LR0.c (augment_automaton): Now that all states have shifts,
4752 merge the two cases addition shifts to the initial state.
4753
47542001-12-10 Akim Demaille <akim@epita.fr>
4755
4756 * src/lalr.c (set_state_table): Move to...
4757 * src/LR0.c: here.
4758 * src/lalr.c (lalr): Don't call it...
4759 * src/LR0.c (generate_states): do it.
4760 * src/LR0.h (first_state): Remove, only the table is used.
4761
47622001-12-10 Akim Demaille <akim@epita.fr>
4763
4764 * src/LR0.h (first_shift, first_reduction): Remove.
4765 * src/lalr.c: Don't use first_shift: find shifts through the
4766 states.
4767
47682001-12-10 Akim Demaille <akim@epita.fr>
4769
4770 * src/LR0.c: Attach shifts to states as soon as they are
4771 computed.
4772 * src/lalr.c (set_state_table): Instead of assigning shifts to
4773 state, just assert that the mapping was properly done.
4774
47752001-12-10 Akim Demaille <akim@epita.fr>
4776
4777 * src/LR0.c (insert_start_shift): Rename as...
4778 (insert_start_shifting_state): this.
4779 (insert_eof_shifting_state, insert_accepting_state): New.
4780 (augment_automaton): Adjust.
4781 Better locality of the variables.
4782 When looking if the start_symbol is shifted from the initial
4783 state, using `while (... symbol != start_symbol ...)' sounds
4784 better than `while (... symbol < start_symbol ...)': If fail
4785 to see how the order between symbols could be relevant!
4786
47872001-12-10 Akim Demaille <akim@epita.fr>
4788
4789 * src/getargs.h: Don't declare `spec_name_prefix' and
4790 `spec_file_prefix', declared by src/files.h.
4791 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4792 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4793 * src/output.c (prepare): Adjust.
4794 * src/reader.c (symbols_output): Likewise.
4795 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4796
47972001-12-10 Akim Demaille <akim@epita.fr>
4798
4799 * src/muscle_tab.c (muscle_init): NULL is a better default than
4800 `"0"'.
4801
48022001-12-10 Akim Demaille <akim@epita.fr>
4803
4804 * src/reader.c (reader): Calling symbols_output once is enough.
4805
48062001-12-10 Akim Demaille <akim@epita.fr>
4807
4808 Now that states have a complete set of members, the linked list of
4809 reductions is useless: just fill directly the state's reductions
4810 member.
4811
4812 * src/state.h (struct reductions): Remove member `number' and
4813 `next'.
4814 * src/LR0.c (first_reduction, last_reduction): Remove.
4815 (save_reductions): Don't link the new reductions, store them in
4816 this_state.
4817 * src/lalr.c (set_state_table): No need to attach reductions to
4818 states, it's already done.
4819 * src/output.c (output_actions): No longer free the shifts, then
4820 the reductions, then the states: free all the states and their
4821 members.
4822
48232001-12-10 Akim Demaille <akim@epita.fr>
4824
4825 * src/options.c (OPTN, DRTV, BOTH): New.
4826 (option_table): Use them.
4827
4828 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4829 the job of system.h.
4830 * src/options.c: Don't include stdio.h and xalloc.h for the same
4831 reasons.
4832
48332001-12-10 Akim Demaille <akim@epita.fr>
4834
4835 * src/output.c (output, prepare): Make sure the values of the
4836 muscles `action' and `prologue' are 0-terminated.
4837
48382001-12-10 Akim Demaille <akim@epita.fr>
4839
4840 Clean up GCC warnings.
4841
4842 * src/reader.c (copy_action): `buf' is not used.
4843 (parse_skel_decl): Be static.
4844 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4845 * src/options.h (create_long_option_table): Have a real prototype.
4846 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4847 (hash_delete_at): Return const void *.
4848 Adjust casts to preserve the const.
4849
48502001-12-10 Akim Demaille <akim@epita.fr>
4851
4852 * configure.in: Require 2.52g.
4853 M4 is not needed, but AUTOM4TE is.
4854 * m4/m4.m4: Remove.
4855 * tests/Makefile.am: Adjust.
4856
48572001-12-10 Akim Demaille <akim@epita.fr>
4858
4859 One structure for states is enough, even though theoretically
4860 there are LR(0) states and LALR(1) states.
4861
4862 * src/lalr.h (state_t): Remove.
4863 (state_table): Be state_t **, not state_t *.
4864 * src/state.h (core, CORE_ALLOC): Rename as...
4865 (state_t, STATE_ALLOC): this.
4866 Add the LALR(1) members: shifts, reductions, errs.
4867 * src/LR0.c (state_table): Rename as...
4868 (state_hash): this, to avoid name clashes with the global
4869 `state_table'.
4870 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4871 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4872
48732001-12-10 Akim Demaille <akim@epita.fr>
4874
4875 Bison dumps core on bash.y.
4876 Reported by Pascal Bart.
4877
4878 * src/warshall.c (bitmatrix_print): New.
4879 (TC): Use it.
4880 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4881 j must be the outer loop.
4882 * tests/regression.at (Broken Closure): New.
4883
48842001-12-05 Akim Demaille <akim@epita.fr>
4885
4886 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4887 its argument.
4888