]> git.saurik.com Git - bison.git/blame - ChangeLog
* src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
[bison.git] / ChangeLog
CommitLineData
56100c60
AD
12002-10-30 Akim Demaille <akim@epita.fr>
2
3 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
4 #if.
5
bf1ebda2
PE
62002-10-24 Paul Eggert <eggert@twinsun.com>
7
5c16c6b1
PE
8 Version 1.75a.
9
bf1ebda2
PE
10 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
11 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
12 we use malloc. Don't assume 'A' through 'Z' are contiguous.
13 Don't assume strdup exists; POSIX says its an XSI extension.
14 Check for buffer overflow on input.
15
b526ee61
AD
162002-10-24 Akim Demaille <akim@epita.fr>
17
18 * src/output.c (output_skeleton): Don't disable M4sugar comments
19 too soon: it results in comments being expanded.
20 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
21 first output.
22
f1886bb2
AD
232002-10-24 Akim Demaille <akim@epita.fr>
24
25 * data/yacc.c (m4_int_type): New.
26 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
27 char' as only yacc.c wants K&R portability.
28 * data/glr.c (yysigned_char): Remove.
29 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
30 Reported by Quoc Peyrot.
31
c5576256
PE
322002-10-23 Paul Eggert <eggert@twinsun.com>
33
34 * src/main.c (main): With --trace=time, report times even if a
35 non-fatal error occurs. Formerly, the times were reported in some
36 such cases but not in others.
37 * src/reader.c (reader): Just return if a complaint has been issued,
38 instead of exiting, so that 'main' can report times.
39
27b0ffea
AD
402002-10-22 Akim Demaille <akim@epita.fr>
41
42 * src/system.h: Include sys/types.
43 Reported by Bert Deknuydt.
44
223a7883
PE
452002-10-23 Paul Eggert <eggert@twinsun.com>
46
47 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
48 Suggested by Art Haas.
49
502002-10-22 Paul Eggert <eggert@twinsun.com>
51
52 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
53 decl; not needed any more.
54 * src/main.c (main): Use return to exit, undoing yesterday's change.
55 The last OS that we could find where this wouldn't work is
56 SunOS 3.5, and that's too old to worry about now.
57
58 * data/glr.c (struct yyltype): Define members even when not
59 doing locations. This is more consistent with yacc.c, and it
60 works around the following bug reports:
61 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
62 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
63 and I hope it also fixes this bug report:
64 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
27b0ffea 65
223a7883
PE
66 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
67 @acronym consistently. Standardize on "Yacc" instead of "YACC",
68 "Algol" instead of "ALGOL". Give a bit more history about BNF.
69
8b76775a
AD
702002-10-22 Akim Demaille <akim@epita.fr>
71
72 * data/README: New.
73
6db10d14
PE
742002-10-21 Paul Eggert <eggert@twinsun.com>
75
76 Be consistent about 'bool'; the old code used an enum in one
77 module and an int in another, and this violates the C standard.
78 * m4/stdbool.m4: New file, from coreutils 4.5.3.
79 * configure.ac (AC_HEADER_STDBOOL): Add.
80 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
81 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
82 * src/symtab.c (hash_compare_symbol_t): Likewise.
83 * src/system.h (bool, false, true): Use a definition consistent
84 with ../lib/hash.c. All uses changed.
85
86 * src/complain.c (warning_issued): Renamed from warn_message_count,
87 so that we needn't worry about integer overflow (!).
88 Now of type bool. All uses changed.
89 (complaint_issued): Renamed from complain_message_count; likewise.
90
91 * src/main.c (main): Use exit to exit with failure.
27b0ffea 92
6db10d14
PE
93 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
94 rather than 1 and 0.
95 * src/main.c (main): Likewise.
96 * src/getargs.c (getargs): Likewise.
97 * src/reader.c (reader): Likewise.
98
99 * src/getarg.c (getargs): Remove duplicate code for
100 "Try `bison --help'".
101
102 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
103 What was that "2" for?
104
105 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
106 * src/getargs.c (usage): Likewise.
107
108 * src/getargs.c (getargs): When there are too few operands, report
109 the last one. When there are too many, report the first extra
110 one. This is how diffutils does it.
111
92a060fd
PE
1122002-10-20 Paul Eggert <eggert@twinsun.com>
113
114 Remove K&R vestiges.
115 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
116 * src/complain.c (VA_START): Remove. Assume prototypes.
117 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
118 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
119 fatal): Assume prototypes.
120 * src/complain.h: Assume prototypes.
121 * src/system.h (PARAMS): Remove.
122 Include <limits.h> unconditionally, since it's guaranteeed even
123 for a freestanding C89 compiler.
124 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
125 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 126
e7cb57c0
AD
1272002-10-20 Akim Demaille <akim@epita.fr>
128
129 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
130 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
131 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
132 (yyresolveStates, yyresolveAction, yyresolveStack)
133 (yyprocessOneStack): Use them.
134 (yy_reduce_print): New.
135 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
136
0245f82d
AD
1372002-10-20 Akim Demaille <akim@epita.fr>
138
139 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
140 arguments and output `void'.
141 (b4_c_function): Rename as...
142 (b4_c_function_def): this.
143 (b4_c_function_decl, b4_c_ansi_function_def)
144 (b4_c_ansi_function_decl): New.
145 Change the interpretation of the arguments: before `int, foo', now
146 `int foo, foo'.
147 * data/yacc.c (yyparse): Prototype and define thanks to these.
148 Adjust b4_c_function_def uses.
149 * data/glr.c (yyparse): Likewise, but ANSI only.
150
39912f52
AD
1512002-10-20 Akim Demaille <akim@epita.fr>
152
153 * src/output.c (prepare): Move the definition of `tokens_number',
154 `nterms_number', `undef_token_number', `user_token_number_max'
155 to...
156 (prepare_tokens): Here.
157 (prepare_tokens): Rename as...
158 (prepare_symbols): this.
159 (prepare): Move the definition of `rules_number' to...
160 (prepare_rules): here.
161 (prepare): Move the definition of `last', `final_state_number',
162 `states_number' to...
163 (prepare_states): here.
164 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
165
20c1e2ad
AD
1662002-10-20 Akim Demaille <akim@epita.fr>
167
168 * src/tables.h, src/tables.c, src/output.c: Comment changes.
169
21964f43
AD
1702002-10-20 Akim Demaille <akim@epita.fr>
171
172 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
173 * data/c.m4: here.
174
66d30cd4
AD
1752002-10-20 Akim Demaille <akim@epita.fr>
176
177 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
178 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
179 `pair'.
180 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
181 `name' to...
182 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
183 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
184 These.
185
95f2c9fe
PE
1862002-10-19 Paul Eggert <eggert@twinsun.com>
187
188 Do not create a temporary file, as that involves security and
189 cleanup headaches. Instead, use a pair of pipes.
190 Derived from a suggestion by Florian Krohm.
191 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
192 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
193 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
194 (BISON_PREREQ_SUBPIPE): Add.
195 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
196 Add subpipe.h, subpipe.c.
197 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
198 * po/POTFILES.in: Add lib/subpipe.c.
199 * src/output.c: Include "subpipe.h".
200 (m4_invoke): Remove decl.
201 (scan_skel): New decl.
202 (output_skeleton): Use pipe rather than temporary file for m4 input.
203 Check that m4sugar.m4 is readable, to avoid deadlock.
204 Check for pipe I/O error.
205 * src/scan-skel.l (readpipe): Remove decl.
206 (scan_skel): New function, to be used in place of m4_invoke.
207 Read from stream rather than file.
66d30cd4 208
95f2c9fe
PE
209 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
210 float, as this generates a warning on Solaris 8 + GCC 3.2 with
211 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
212 this generates a more-accurate value anyway.
213
214 * lib/timevar.c (timervar_accumulate): Rename locals to
215 avoid confusion with similarly-named more-global.
216 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
217
218 * src/output.c (prepare): Use xstrdup to convert char const *
219 to char *, to avoid GCC warning.
220
c19988b7
AD
2212002-10-19 Akim Demaille <akim@epita.fr>
222
223 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
224 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
225 Use them to have `calc.y' ready for %pure-parser.
226 * data/yacc.c (YYLEX): Pass a yylex return type to
227 b4_c_function_call.
228
ae7453f2
AD
2292002-10-19 Akim Demaille <akim@epita.fr>
230
231 Prototype support of %lex-param and %parse-param.
232
233 * src/parse-gram.y: Add the definition of the %lex-param and
234 %parse-param tokens, plus their rules.
235 Drop the `_' version of %glr-parser.
236 Add the "," token.
237 * src/scan-gram.l (INITIAL): Scan them.
238 * src/muscle_tab.c: Comment changes.
239 (muscle_insert, muscle_find): Rename `pair' as `probe'.
240 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
241 (muscle_entry_s): The `value' member is no longer const.
242 Adjust all dependencies.
243 * src/muscle_tab.c (muscle_init): Adjust: use
244 MUSCLE_INSERT_STRING.
245 Initialize the obstack earlier.
246 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
247 (muscle_pair_list_grow): New.
248 * data/c.m4 (b4_c_function_call, b4_c_args): New.
249 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
250 * tests/calc.at: Use %locations, not --locations.
251 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
252
0e575721
AD
2532002-10-19 Akim Demaille <akim@epita.fr>
254
255 * src/getargs.c (usage): Take status as argument and exit
256 accordingly.
257 Report the traditional `Try ... --help' message when status != 0.
258 (usage, version): Don't take a FILE * as arg, it is pointless.
259 (getargs): When there is an incorrect number of arguments, make it
260 an error, and report it GNUlically thanks to `usage ()'.
261
724ce7f5
PE
2622002-10-18 Paul Eggert <eggert@twinsun.com>
263
3a781eb2
PE
264 * data/glr.c (yyreportParseError): Don't assume that sprintf
265 yields the length of the printed string, as this is not true
266 on SunOS 4.1.4. Reported by Peter Klein.
267
724ce7f5
PE
268 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
269 * tests/conflicts.at (%nonassoc and eof): Likewise.
270 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
271
473d0a75
AD
2722002-10-17 Akim Demaille <akim@epita.fr>
273
274 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
275 * src/getargs.c (trace_types, trace_args): Adjust.
276 * src/reader.c (grammar_current_rule_prec_set)
277 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
278 Standardize error messages.
279 And s/@prec/%prec/!
280 (reader): Use trace_flag to enable scanner/parser debugging,
281 instead of an adhoc scheme.
282 * src/scan-gram.l: Remove trailing debugging code.
283
e76d2469
PE
2842002-10-16 Paul Eggert <eggert@twinsun.com>
285
93e2236a
PE
286 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
287 MUSCLE_TAB_H.
288
e76d2469
PE
289 * NEWS: Officially drop support for building Bison with K&R C,
290 since it didn't work anyway and it's not worth worrying about.
291 * Makefile.maint (wget_files): Remove ansi2knr.c.
292 (ansi2knr.c-url_prefix): Remove.
293 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
294 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
295 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
296
5bd1c419
PE
2972002-10-15 Paul Eggert <eggert@twinsun.com>
298
299 Stop using the "enum_" trick for K&R-style function definitions;
300 it confused me, and I was the author! Instead, assume that people
301 who want to use K&R C compilers (when using these modules in GCC,
302 perhaps?) will run ansi2knr.
303
304 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
305 All uses of "enum_" changed to "enum ".
306 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
307 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 308
5bd1c419
PE
309 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
310 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
311 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
312 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
313 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
314 abitset_not, abitset_ones, abitset_or, abitset_or_and,
315 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
316 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
317 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
318 Use function prototypes; this removes the need for declaring
319 static functions simply to provide their prototypes.
320 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
321 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
322 bitset_count_, bitset_create, bitset_dump, bitset_first,
323 bitset_free, bitset_init, bitset_last, bitset_next,
324 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
325 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
326 bitset_print, bitset_release_memory, bitset_toggle_,
327 bitset_type_choose, bitset_type_get, bitset_type_name_get,
328 debug_bitset): Likewise.
329 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
330 * lib/bitset_stats.c (bitset_log_histogram_print,
331 bitset_percent_histogram_print, bitset_stats_and,
332 bitset_stats_and_cmp, bitset_stats_and_or,
333 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
334 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
335 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
336 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
337 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
338 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
339 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
340 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
341 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
342 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
343 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
344 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
345 bitset_stats_zero): Likewise.
346 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
347 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
348 bitsetv_dump, debug_bitsetv): Likewise.
349 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
350 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
351 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
352 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
353 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
354 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
355 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
356 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
357 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
358 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
359 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
360 Likewise.
361 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
362 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
363 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
364 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
365 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
366 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
367 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
368 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
369 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
370 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
371 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 372
ae26e1f0
AD
3732002-10-14 Akim Demaille <akim@epita.fr>
374
375 Version 1.75.
376
d43baf71
AD
3772002-10-14 Akim Demaille <akim@epita.fr>
378
379 * tests/Makefile.am (maintainer-check-posix): New.
380
7ebc83e3
AD
3812002-10-14 Akim Demaille <akim@epita.fr>
382
383 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
384 member.
385
05846dae
AD
3862002-10-14 Akim Demaille <akim@epita.fr>
387
388 * src/tables.c (table_ninf_remap): base -> tab.
389 Reported by Matt Rosing.
390
1318e37d
PE
3912002-10-14 Paul Eggert <eggert@twinsun.com>
392
447fbb17
PE
393 * tests/action.at, tests/calc.at, tests/conflicts.at,
394 tests/cxx-type.at, tests/headers.at, tests/input.at,
395 tests/regression.at, tests/synclines.at, tests/torture.at:
396 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
397 so that the tests still work even if POSIXLY_CORRECT is set.
398 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 399
1318e37d
PE
400 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
401 for portability to K&R hosts. Fix typo: signed char is guaranteed
402 only to 127, not to 128.
403 * data/glr.c (yysigned_char): New type.
404 * data/yacc.c (yysigned_char): Likewise.
405 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
406
cc0f0794
PE
4072002-10-13 Paul Eggert <eggert@twinsun.com>
408
5038f418
PE
409 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
410 true due to limited range of data type" warning from GCC.
411
cc0f0794
PE
412 * data/c.m4 (b4_token_defines): Protect against double-inclusion
413 by wrapping enum yytokentype's definition inside #ifndef
414 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
415
6fed0802
AD
4162002-10-13 Akim Demaille <akim@epita.fr>
417
418 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
419 Un yy- yyrhs to avoid the name clash with the global YYRHS.
420
32f0598d
AD
4212002-10-13 Akim Demaille <akim@epita.fr>
422
423 * Makefile.maint: Update from Autoconf 2.54.
424 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
425
7ea9a33f
AD
4262002-10-13 Akim Demaille <akim@epita.fr>
427
428 * src/print.c (print_state): Separate the list of solved conflicts
429 from the other items.
430 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
431
ea99527d
AD
4322002-10-13 Akim Demaille <akim@epita.fr>
433
434 Let nondeterministic skeletons be usable with deterministic
435 tables.
436
437 With the patch, GAWK compiled by GCC without -O2 passes its test
438 suite using a GLR parser driven by LALR tables. It fails with -O2
439 because `struct stat' gives two different answers on my machine:
440 88 (definition of an auto var) and later 96 (memset on this var).
441 Hence the stack is badly corrumpted. The headers inclusion is to
442 blame: if I move the awk.h inclusion before GLR's system header
443 inclusion, the two struct stat have the same size.
444
445 * src/tables.c (pack_table): Always create conflict_table.
446 (token_actions): Always create conflict_list.
447 * data/glr.c (YYFLAG): Remove, unused.
448
f377f69f
AD
4492002-10-13 Akim Demaille <akim@epita.fr>
450
451 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
452 (O0FLAGS): New.
453 (VALGRIND, GXX): New.
454 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
455 * tests/bison.in: Run $PREBISON a pre-command.
456 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
457 (maintainer-check-g++): New.
458 * Makefile.am (maintainer-check): New.
459
2a1fe6ed
AD
4602002-10-13 Akim Demaille <akim@epita.fr>
461
462 * data/glr.c: Formatting changes.
463 Tweak some trace messages to match yacc.c's.
464
f50adbbd
AD
4652002-10-13 Akim Demaille <akim@epita.fr>
466
467 GLR parsers sometimes raise parse errors instead of performing the
468 default reduction.
469 Reported by Charles-Henry de Boysson.
470
471 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
472 check the length of the traces when %glr.
473 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
474 GLR's traces.
475 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
476 Test GLR parsers.
477 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
478 (yyltype): Remove the yy prefix from the member names.
479 (yytable): Complete its comment.
480 (yygetLRActions): Map error action number from YYTABLE from
481 YYTABLE_NINF to 0.
482 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
483 (which was a bug: it should have been YYTABEL_NINF, and yet it was
484 not satisfying as we could compare an YYACTION computed from
485 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
486 only value for error actions.
487 (yyreportParseError): In verbose parse error messages, don't issue
488 `error' in the list of expected tokens.
489 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
490 next action to perform to match glr.c's decoding.
491 (yytable): Complete its comment.
492
bcbad5b9
PE
4932002-10-13 Paul Eggert <eggert@twinsun.com>
494
495 Fix problem reported by Henrik Grubbstroem in
496 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
497 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
498 because the Bison parser reads the second action before reducing
499 the first one.
500 * src/scan-gram.l (rule_length): New static var.
501 Use it to keep track of the rule length in the scanner, since
502 we can't expect the parser to be in lock-step sync with the scanner.
503 (handle_action_dollar, handle_action_at): Use this var.
504 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 505
14904b89
PE
5062002-10-12 Paul Eggert <eggert@twinsun.com>
507
1fe611e5
PE
508 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
509 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
510 Include <sys/time.h> when checking for clock_t and struct tms.
511 Use same include order as source.
512 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
513 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
05846dae 514
1fe611e5
PE
515 * lib/timevar.c: Update copyright date and clarify comments.
516 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 517
1fe611e5
PE
518 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
519 GCC version as of today, then merge Bison's changes.
520 Change "GCC" to "Bison" in copyright notice. timevar.def's
521 author is Akim, so change that too.
522
98194095
PE
523 * src/reader.c (grammar_current_rule_check):
524 Don't worry about the default action if $$ is untyped.
525 Prevents bogus warnings reported by Jim Gifford in
526 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
527
14904b89
PE
528 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
529 * data/glr.c, data/lalr1.cc, data/yacc.c:
530 Output token definitions before the first part of user declarations.
531 Fixes compatibility problem reported by Jim Gifford for kbd in
532 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
533
ff6dca18
PE
5342002-10-11 Paul Eggert <eggert@twinsun.com>
535
536 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
537 (yyparse): here. This undoes some of the 2002-07-25 change.
538 Compatibility problem reported by Ralf S. Engelschall with
539 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
540
eb714592
AD
5412002-10-11 Akim Demaille <akim@epita.fr>
542
543 * tests/regression.at Characters Escapes): New.
544 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
545 characters.
546 Reported by Jan Nieuwenhuizen.
547
b7195100
AD
5482002-10-11 Akim Demaille <akim@epita.fr>
549
550 * po/id.po: New.
551
f28a0f2d
PE
5522002-10-10 Paul Eggert <eggert@twinsun.com>
553
554 Portability fixes for bitsets; this also avoids several GCC
555 warnings.
556
557 * lib/abitset.c: Include <stddef.h>, for offsetof.
558 * lib/lbitset.c: Likewise.
559
560 * lib/abitset.c (abitset_bytes): Return a size that is aligned
561 properly for vectors of objects. Do not assume that adding a
562 header size to a multiple of a word size yields a value that is
563 properly aligned for the whole union.
564 * lib/bitsetv.c (bitsetv_alloc): Likewise.
565
566 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
567 unique names for structures.
568 * lib/ebitset.c (ebitset_bytes): Likewise.
569 * lib/lbitset.c (lbitset_bytes): Likewise.
570
571 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
572 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
573 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
574 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
575 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
576 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
577 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
578 to improve the type-checking that GCC can do.
579 * lib/bitset.c (bitset_op4_cmp): Likewise.
580 * lib/bitset_stats.c (bitset_stats_count,
581 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
582 bitset_stats_copy, bitset_stats_disjoint_p,
583 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
584 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
585 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
586 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
587 bitset_stats_and_or_cmp, bitset_stats_andn_or,
588 bitset_stats_andn_or_cmp, bitset_stats_or_and,
589 bitset_stats_or_and_cmp): Likewise.
590 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
591 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
592 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
593 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
594
595 * lib/abitset.h: Include bitset.h, not bbitset.h.
596 * lib/ebitset.h: Likewise.
597 * lib/lbitset.h: Likewise.
598
599 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
600 All instances of parameters of type enum bitset_opts are now of
601 type enum_bitset_opts, to conform to the C Standard, and similarly
602 for enum_bitset_type.
603 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
604 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
605
606 Do not use "struct bitset_struct" to mean different things in
607 different modules. Not only is this confusing, it violates
608 the C Standard, which requires that structure types in different
609 modules must be compatible if one is to be passed to the other.
610 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
611 All instances of "struct bitset_struct *" replaced with "bitset".
612 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
613 (union bitset_union, struct abitset_struct, struct ebitset_struct,
614 struct lbitset_struct, struct bitset_stats_struct): New types.
615 All uses of struct bitset_struct changed to union bitset_union,
616 etc.
617 * lib/abitset.c (struct abitset_struct, abitset,
618 struct bitset_struct): Remove.
619 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
620 struct bitset_struct): Remove.
621 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
622 bitset_struct): Remove.
623 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
624 Likewise.
625
626 Do not call a function of type T using a call that assumes the
627 function is of a different type U. Standard C requires that a
628 function must be called with a type that is compatible with its
629 definition.
630 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
631 New decls.
632 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
633 New functions.
634 * lib/ebitset.c (PFV): Remove.
635 * lib/lbitset.c (PFV): Likewise.
636 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
637 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
638 decls.
639 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
640 (ebitset_vtable): Use them.
641 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
642 lbitset_xor): New functions.
643 (lbitset_vtable): Use them.
644
645 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
646 Declare.
647
648 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
649 GCC warning.
650 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
651 Use offsetof, for simplicity.
652
6fbe4984
PE
6532002-10-06 Paul Eggert <eggert@twinsun.com>
654
655 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
656 the same width as int. This reapplies a hunk of the 2002-08-12 patch
657 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
658 which was inadvertently undone by the 2002-09-30 patch.
659 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
660 the same width as int.
661
420f93c8
PE
6622002-10-04 Paul Eggert <eggert@twinsun.com>
663
664 Version 1.50.
665
666 * configure.ac (AC_INIT), NEWS: Increment version number.
667
668 * doc/bison.texinfo: Minor spelling, grammar, and white space
669 fixes.
670 (Symbols): Mention that any negative value returned from yylex
671 signifies end-of-input. Warn about negative chars. Mention
672 the portable Standard C character set.
673
674 The GNU coding standard says CFLAGS and YFLAGS are reserved
675 for the installer to set.
676 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
677 * src/Makefile.am (AM_CFLAGS): Likewise.
678 (AM_YFLAGS): Renamed from YFLAGS.
679
680 Fix some MAX and MIN problems.
681 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
682 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
683 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
684 * src/reader.c (reader): Use it.
685
686 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
687 POSIX 1003.1-2001 has removed fgrep.
688
6892002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
690
691 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
692 interpreted as signed.
693 * lib/ebitset.c (ebitset_list): Fix bug.
694
ff68026d
PE
6952002-10-01 Paul Eggert <eggert@twinsun.com>
696
697 More fixes for 64-bit hosts and large bitsets.
698
699 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
700 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
701 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
702 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
703 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
704 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
705 bitset_count_): Likewise.
706 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
707 bitset_first, bitset_last): Likewise.
708 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
709 bitset_stats_list_reverse, bitset_stats_size,
710 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
711 Likewise.
712 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
713 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
714 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
715 bitsetv_reflexive_transitive_closure): Likewise.
716 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
717 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
718 Likewise.
719 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
720 Likewise.
420f93c8 721
ff68026d
PE
722 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
723 Use size_t, not unsigned int, to count bytes.
724 * lib/abitset.h (abitset_bytes): Likewise.
725 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
726 Likewise.
727 * lib/bitset.h (bitset_bytes): Likewise.
728 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
729 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
730 * lib/bitsetv.c (bitsetv_alloc): Likewise.
731 * lib/ebitset.c (ebitset_bytes): Likewise.
732 * lib/ebitset.h (ebitset_bytes): Likewise.
733 * lib/lbitset.c (lbitset_bytes): Likewise.
734 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 735
ff68026d
PE
736 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
737 abitset_subset_p, abitset_disjoint_p, abitset_and,
738 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
739 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
740 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
741 abitset_or_and, abitset_or_and_cmp):
742 Use bitset_windex instead of unsigned int.
743 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
744 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
745 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
746 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
747 Likewise.
748 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 749
ff68026d
PE
750 * lib/bitset.c (bitset_print):
751 Use proper printf formats for widths of integer types.
752 * lib/bitset_stats.c (bitset_percent_histogram_print,
753 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
754 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
755 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
756 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 757
ff68026d
PE
758 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
759 BITSET_SIZE_MAX): New macros.
760 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
761 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
762 to BITSET_WINDEX_MAX.
763
764 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
765 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
766 since we now return the bitset_bindex type (not int).
767
768 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
769 when computing sizes.
770 * lib/ebitset.c (ebitset_elts_grow): Likewise.
771
772 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
773 and avoid cast to unsigned.
774
6aa452a6
AD
7752002-09-30 Akim Demaille <akim@epita.fr>
776
777 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
778 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
779 Updates from Michael Hayes.
780
927f7817
AD
7812002-09-30 Art Haas <ahaas@neosoft.com>
782
783 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
784 invocations.
785 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
786 defined.
787
9738f41e
AD
7882002-09-27 Akim Demaille <akim@epita.fr>
789
790 Version 1.49c.
791
a5c75d7f
AD
7922002-09-27 Akim Demaille <akim@epita.fr>
793
794 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
795 (Because of AC_LIBSOURCE).
796
8280e179
AD
7972002-09-27 Akim Demaille <akim@epita.fr>
798
799 Playing with Autoscan.
800
801 * configure.ac: Remove the old LIBOBJ tweaks.
802 (AC_REPLACE_FUNCS): Add strrchr and strtol.
803 * lib/strrchr.c: New.
804 * lib/strtol.c: New, from the Coreutils 4.5.1.
805
ae64af35
AD
8062002-09-27 Akim Demaille <akim@epita.fr>
807
808 Playing with Autoscan.
809
810 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
811 * lib/Makefile.am (libbison_a_SOURCES): No longer include
812 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
813 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
814 Coreutils 4.5.1.
815
d1a1114f
AD
8162002-09-24 Akim Demaille <akim@epita.fr>
817
818 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
819 (Frequently Asked Questions, Parser Stack Overflow): New.
820
b906441c
AD
8212002-09-13 Akim Demaille <akim@epita.fr>
822
823 Playing with autoscan.
824
825 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
826 * src/files.c (skeleton_find): Remove, unused.
827 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
828 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
829
bd701811
AD
8302002-09-13 Akim Demaille <akim@epita.fr>
831
832 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
833 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
834
e0a13e7b
AD
8352002-09-13 Akim Demaille <akim@epita.fr>
836
837 * configure.ac: Require 2.54.
838 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
839 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
840 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
841 Remove, provided by Autoconf macros.
842
c97011bf
AD
8432002-09-12 Akim Demaille <akim@epita.fr>
844
845 * m4/prereq.m4: Update, from Coreutils 4.5.1.
846
d862b1be
AD
8472002-09-12 Akim Demaille <akim@epita.fr>
848
849 * m4/prereq.m4: Update, from Fileutils 4.1.5.
850 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
851 Reported by Martin Mokrejs.
852
3d38c03a
AD
8532002-09-10 Akim Demaille <akim@epita.fr>
854
855 * src/parse-gram.y: Associate a human readable string to each
856 token type.
857 * tests/regression.at (Invalid inputs): Adjust.
858
b6347355
AD
8592002-09-10 Gary V. Vaughan <gary@gnu.org>
860
861 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
862 with an Autoconf-2.5x style configure.ac.
863
09ba4ab2
PE
8642002-09-06 Paul Eggert <eggert@twinsun.com>
865
866 * doc/bison.texinfo (Conditions): Make explicit that the GPL
867 exception applies only to yacc.c. This is a modification of a
868 patch originally suggested by Akim Demaille.
869
21846f69
AD
8702002-09-06 Akim Demaille <akim@epita.fr>
871
09ba4ab2
PE
872 * data/c.m4 (b4_copyright): Move the GPL exception comment from
873 here to...
874 * data/yacc.c: here.
875
21846f69
AD
876 * data/lalr1.cc (struct yyltype): Don't define it, since we use
877 LocationType.
878 (b4_ltype): Default to yy::Location from location.hh.
879
c0ad8bf3
AD
8802002-09-04 Jim Meyering <jim@meyering.net>
881
882 * data/yacc.c: Guard the declaration of yytoknum also with
883 `#ifdef YYPRINT', so it is declared only when used.
884
3a93251e
AD
8852002-09-04 Akim Demaille <akim@epita.fr>
886
887 * configure.in: Rename as...
888 * configure.ac: this.
889 Bump to 1.49c.
890
427c0dda
AD
8912002-09-04 Akim Demaille <akim@epita.fr>
892
893 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
894 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
895 translate maintainer only messages.
896
6a254321
PE
8972002-08-12 Paul Eggert <eggert@twinsun.com>
898
645e30d1
PE
899 Version 1.49b.
900
6a254321
PE
901 * Makefile.am (SUBDIRS): Remove intl.
902 (DISTCLEANFILES): Remove.
903 * NEWS: Mention that GNU M4 is now required. Clarify what is
904 meant by "larger grammars". Mention the pt_BR translation.
905 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
906 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
907 Bump version from 0.11.2 to 0.11.5.
908 (BISON_PREREQ_STAGE): Remove.
909 (AM_GNU_GETTEXT): Use external gettext.
910 (AC_OUTPUT): Remove intl/Makefile.
911
912 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
913
914 * data/glr.c: Include string.h, for strlen.
915 (yyreportParseError): Use size_t for yysize.
916 (yy_yypstack): No longer nested inside yypstates, as nested
917 functions are not portable. Do not assume size_t is the
918 same width as int.
919 (yypstates): Do not assume that ptrdiff_t is the same width
920 as int, and similarly for yyposn and YYINDEX.
921
922 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
923
924 * lib/Makefile.am (INCLUDES): Do not include from the intl
925 directory, which has been removed.
926 * src/Makefile.am (INCLUDES): Likewise.
927
928 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
929 (bitsets_sources, additional_bitsets_sources, timevars_sources):
930 New vars.
931
932 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
933 * tests/Makefile.am (EXTRA_DIST): Likewise.
934
935 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
936 Do not assume that bitset_windex is the same width as unsigned.
937
938 * lib/abitset.c (abitset_unused_clear): Do not assume that
939 bitset_word is the same width as int.
940 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
941 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
942 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
943 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
944 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
945
946 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
947 portability to one's complement hosts!).
948 * lib/ebitset.c (ebitset_op1): Likewise.
949 * lib/lbitset.c (lbitset_op1): Likewise.
950
951 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
952 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
953 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
954 Sync with fileutils.
955 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
956 lib/gettext.h: Sync with diffutils.
957
958 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
959 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
960
961 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
962 PROTOTYPES to check for prototypes, and "defined __STDC__" to
963 check for void *.
964
965 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
966 size_t; the old version tried to do this but casted improperly.
967 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
968 (bitset_test): Now returns int, not unsigned long.
969
970 * lib/bitset_stats.c: Include "gettext.h".
971 (_): New macro.
972 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
973 name locals "index", as it generates unnecessary warnings on some
974 hosts that have an "index" function.
975
976 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
977 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
978 they need translation.
979 * src/LR0.c (state_list_append, new_itemsets, get_state,
980 append_states, generate_states): Likewise.
981 * src/assoc.c (assoc_to_string): Likewise.
982 * src/closure.c (print_closure, set_firsts, closure): Likewise.
983 * src/gram.c (grammar_dump): Likewise.
984 * src/injections.c (injections_compute): Likewise.
985 * src/lalr.c (lookaheads_print): Likewise.
986 * src/relation.c (relation_transpose): Likewise.
987 * src/scan-gram.l: Likewise.
988 * src/tables.c (table_grow, pack_vector): Likewise.
989
990 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
991 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
992 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
993 * m4/mbstate_t.m4: Sync with fileutils.
994 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
995
996 * po/LINGUAS: Add pt_BR.
997 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
998 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
999 lib/timevar.c.
1000 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
1001 manual recommends.
1002 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
1003
1004 * src/complain.c (strerror_r): Remove decl; not needed.
1005 (strerror): Use same pattern as ../lib/error.c.
1006
1007 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
1008
1009 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
1010
1011 * src/main.c (main): Cast result of bindtextdomain and textdomain
1012 to void, to avoid a GCC warning when --disable-nls is in effect.
1013
1014 * src/scan-gram.l: Use strings rather than escapes when possible,
1015 to minimize the number of warnings from xgettext.
1016 (handle_action_dollar, handle_action_at): Don't use isdigit,
1017 as it mishandles negative chars and it may not work as expected
1018 outside the C locale.
1019
1020 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
1021 this is a GCC extension and is not portable to other compilers.
1022
1023 * src/system.h (alloca): Use same pattern as ../lib/error.c.
1024 Do not include <ctype.h>; no longer needed.
1025 Do not include <malloc.h>; no longer needed (and generates
1026 warnings on OpenBSD 3.0).
1027
1028 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
1029 it's not portable.
1030
1031 * tests/regression.at: Do not use 'cc -c input.c -o input';
1032 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1033
1034 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1035 exit status as failure, not just exit status 1. Sun C exits
1036 with status 2 sometimes.
1037
1038 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1039 Use it for the two large tests.
1040
c8f002c7
AD
10412002-08-02 Akim Demaille <akim@epita.fr>
1042
1043 * src/conflicts.c (conflicts_output): Don't output rules never
1044 reduced here, since anyway that computation doesn't work.
1045 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1046 (rule_useless_p, rule_never_reduced_p): New.
1047 (grammar_rules_partial_print): Use a filter instead of a range.
1048 Display the title only if needed.
1049 (grammar_rules_print): Adjust.
1050 (grammar_rules_never_reduced_report): New.
1051 * src/tables.c (action_row): Move the computation of rules never
1052 reduced to...
1053 (token_actions): here.
1054 * src/main.c (main): Make the parser before making the report, so
1055 that rules never reduced are computed.
1056 Call grammar_rules_never_reduced_report.
1057 * src/print.c (print_results): Report rules never reduced.
1058 * tests/conflicts.at, tests/reduce.at: Adjust.
1059
cd08e51e
AD
10602002-08-01 Akim Demaille <akim@epita.fr>
1061
1062 Instead of attaching lookaheads and duplicating the rules being
1063 reduced by a state, attach the lookaheads to the reductions.
1064
1065 * src/state.h (state_t): Remove the `lookaheads',
1066 `lookaheads_rule' member.
1067 (reductions_t): Add a `lookaheads' member.
1068 Use a regular array for the `rules'.
1069 * src/state.c (reductions_new): Initialize the lookaheads member
1070 to 0.
1071 (state_rule_lookaheads_print): Adjust.
1072 * src/state.h, src/state.c (state_reductions_find): New.
1073 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1074 (count_rr_conflicts): Adjust.
1075 * src/lalr.c (LArule): Remove.
1076 (add_lookback_edge): Adjust.
1077 (state_lookaheads_count): New.
1078 (states_lookaheads_initialize): Merge into...
1079 (initialize_LA): this.
1080 (lalr_free): Adjust.
1081 * src/main.c (main): Don't free nullable and derives too early: it
1082 is used by --verbose.
1083 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1084
bb0027a9
AD
10852002-08-01 Akim Demaille <akim@epita.fr>
1086
1087 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1088 `rule_number_t**'.
1089 (set_derives, free_derives): Rename as...
1090 (derives_compute, derives_free): this.
1091 Adjust all dependencies.
1092 * src/nullable.c (set_nullable, free_nullable): Rename as...
1093 (nullable_compute, nullable_free): these.
1094 (rule_list_t): Store rule_t *, not rule_number_t.
1095 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1096 pointers, instead of their numbers.
1097 * src/main.c (main): Call nullable_free, and derives_free earlier,
1098 as they were lo longer used.
1099
3325ddc4
AD
11002002-08-01 Akim Demaille <akim@epita.fr>
1101
1102 * lib/timevar.c (get_time): Include children time.
1103 * src/lalr.h (LA, LArule): Don't export them: used with the
1104 state_t.
1105 * src/lalr.c (LA, LArule): Static.
1106 * src/lalr.h, src/lalr.c (lalr_free): New.
1107 * src/main.c (main): Call it.
1108 * src/tables.c (pack_vector): Check whether loc is >= to the
1109 table_size, not >.
1110 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1111 (tables_generate): do it, since that's also it which allocates
1112 them.
1113 Don't free LA and LArule, main does.
1114
c6f1a33c
AD
11152002-07-31 Akim Demaille <akim@epita.fr>
1116
1117 Separate parser tables computation and output.
1118
1119 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1120 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1121 (yydefgoto, yydefact, high): Move to...
1122 * src/tables.h, src/tables.c: here.
1123 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1124 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1125 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1126 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1127 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1128 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1129 (action_row, save_row, token_actions, save_column, default_goto)
1130 (goto_actions, sort_actions, matching_state, pack_vector)
1131 (table_ninf_remap, pack_table, prepare_actions): Move to...
1132 * src/tables.c: here.
1133 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1134 * src/output.c (token_actions, output_base, output_conflicts)
1135 (output_check): Merge into...
1136 (prepare_actions): this.
1137 (actions_output): Rename as...
1138 (user_actions_output): this.
1139 * src/main.c (main): Call tables_generate and tables_free.
1140
1509d42f
AD
11412002-07-31 Akim Demaille <akim@epita.fr>
1142
1143 Steal GCC's --time-report support.
1144
1145 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1146 stolen/adjusted from GCC.
1147 * m4/stage.m4: Remove time related checks.
1148 * m4/timevar.m4: New.
1149 * configure.in: Adjust.
1150 * src/system.h: Adjust to using timevar.h.
1151 * src/getargs.h, src/getargs.c: Support trace_time for
1152 --trace=time.
1153 * src/main.c (stage): Remove.
1154 (main): Replace `stage' invocations with timevar calls.
1155 * src/output.c: Insert pertinent timevar calls.
1156
273a74fa
AD
11572002-07-31 Akim Demaille <akim@epita.fr>
1158
1159 Let --trace have arguments.
1160
1161 * src/getargs.h (enum trace_e): New.
1162 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1163 (long_options, short_options): --trace/-T takes an optional
1164 argument.
1165 Change all the uses of trace_flag to reflect the new flags.
1166 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1167
1168 Strengthen `stage' portability.
1169
1170 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1171 * configure.in: Use it.
1172 Don't check for malloc.h and sys/times.h.
1173 * src/system.h: Include them when appropriate.
1174 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1175 times and struct tms are available.
1176
217598da
AD
11772002-07-30 Akim Demaille <akim@epita.fr>
1178
1179 In verbose parse error message, don't report `error' as an
1180 expected token.
1181 * tests/actions.at (Printers and Destructors): Adjust.
1182 * tests/calc.at (Calculator $1): Adjust.
1183 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1184 error message, do not report the parser accepts the error token in
1185 that state.
1186
52489d44
AD
11872002-07-30 Akim Demaille <akim@epita.fr>
1188
1189 Normalize conflict related messages.
1190
1191 * src/complain.h, src/complain.c (warn, complain): New.
1192 * src/conflicts.c (conflicts_print): Use them.
1193 (conflict_report_yacc): New, extracted from...
1194 (conflicts_print): here.
1195 * tests/conflicts.at, tests/existing.at: Adjust.
1196
e8832397
AD
11972002-07-30 Akim Demaille <akim@epita.fr>
1198
1199 Report rules which are never reduced by the parser: those hidden
1200 by conflicts.
1201
1202 * src/LR0.c (save_reductions): Don't make the final state too
1203 different: save its reduction (accept) instead of having a state
1204 without any action (no shift or goto, no reduce).
1205 Note: the final state is now a ``regular'' state, i.e., the
1206 parsers now contain `reduce 0' as default reduction.
1207 Nevertheless, since they decide to `accept' when yystate =
1208 final_state, they still will not reduce rule 0.
1209 * src/print.c (print_actions, print_reduction): Adjust.
1210 * src/output.c (action_row): Track reduced rules.
1211 (token_actions): Report rules never reduced.
1212 * tests/conflicts.at, tests/regression.at: Adjust.
1213
caf23d24
AD
12142002-07-30 Akim Demaille <akim@epita.fr>
1215
1216 `stage' was accidently included in a previous patch.
1217 Initiate its autoconfiscation.
1218
1219 * configure.in: Look for malloc.h and sys/times.h.
1220 * src/main.c (stage): Adjust.
1221 Report only when trace_flag.
1222
640748ee
AD
12232002-07-29 Akim Demaille <akim@epita.fr>
1224
1225 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1226 state_number_t.
1227 (errs_t): symbol_t*, not symbol_number_t.
1228 (reductions_t): rule_t*, not rule_number_t.
1229 (FOR_EACH_SHIFT): New.
1230 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1231 * src/print.c, src/print_graph.c: Adjust.
1232
88bce5a2
AD
12332002-07-29 Akim Demaille <akim@epita.fr>
1234
1235 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1236
1237 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1238 (endtoken, accept): these.
1239 * src/reader.c (reader): Set endtoken's default tag to "$end".
1240 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1241 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1242 Adjust.
1243
1bfb97db
AD
12442002-07-29 Akim Demaille <akim@epita.fr>
1245
1246 * src/reduce.c (reduce_grammar): When the language is empty,
1247 complain about the start symbol, not the axiom.
1248 Use its location.
1249 * tests/reduce.at (Empty Language): New.
1250
fc5734fe
AD
12512002-07-26 Akim Demaille <akim@epita.fr>
1252
1253 * src/reader.h, src/reader.c (gram_error): ... can't get
1254 yycontrol without making too strong assumptions on the parser
1255 itself.
1256 * src/output.c (prepare_tokens): Use the real 0th value of
1257 token_translations instead of `0'.
1258 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1259 visible here.
1260 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1261 for the time being: %locations ought to provide it to yyerror.
1262
3650b4b8
AD
12632002-07-25 Akim Demaille <akim@epita.fr>
1264
1265 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1266 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1267 * tests/regression.at (Web2c Actions): Adjust.
1268
4b3d3a8e
AD
12692002-07-25 Akim Demaille <akim@epita.fr>
1270
1271 Stop storing rules from 1 to nrules + 1.
1272
1273 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1274 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1275 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1276 Iterate from 0 to nrules.
1277 Use rule_number_as_item_number and item_number_as_rule_number.
1278 Adjust to `derive' now containing possibly 0.
1279 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1280 Handle the `- 1' part in rule numbers from/to item numbers.
1281 * src/conflicts.c (log_resolution): Fix the message which reversed
1282 shift and reduce.
1283 * src/output.c (action_row): Initialize default_rule to -1.
1284 (token_actions): Adjust.
1285 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1286 expected output.
1287 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1288
4a2a22f4
AD
12892002-07-25 Akim Demaille <akim@epita.fr>
1290
1291 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1292 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1293 (b4_c_knr_arg_decl): New.
1294 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1295 yyreport_parse_error.
1296
b8df3223
AD
12972002-07-25 Akim Demaille <akim@epita.fr>
1298
1299 * data/yacc.c (yyreport_parse_error): New, extracted from...
1300 (yyparse): here.
1301 (yydestruct, yysymprint): Move above yyparse.
1302 Be K&R compliant.
1303
a762e609
AD
13042002-07-25 Akim Demaille <akim@epita.fr>
1305
1306 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1307 replace...
1308 (b4_sint_type, b4_uint_type): these.
1309 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1310 * tests/regression.at (Web2c Actions): Adjust.
1311
12b0043a
AD
13122002-07-25 Akim Demaille <akim@epita.fr>
1313
1314 * src/gram.h (TIEM_NUMBER_MAX): New.
1315 (item_number_of_rule_number, rule_number_of_item_number): Rename
1316 as...
1317 (rule_number_as_item_number, item_number_as_rule_number): these.
1318 Adjust dependencies.
1319 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1320 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1321 (symbol_number_to_vector_number): New.
1322 (order): Of vector_number_t* type.
1323 (base_t, BASE_MAX, BASE_MIN): New.
1324 (froms, tos, width, pos, check): Of base_t type.
1325 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1326 (actrow): Of action_number_t type.
1327 (conflrow): Of unsigned int type.
1328 (table_ninf, base_ninf): New.
1329 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1330 (muscle_insert_int_table, muscle_insert_base_table)
1331 (muscle_insert_rule_number_table): New.
1332 (prepare_tokens): Output `toknum' as int_table.
1333 (action_row): Returns a rule_number_t.
1334 Use ACTION_MIN, not SHRT_MIN.
1335 (token_actions): yydefact is rule_number_t*.
1336 (table_ninf_remap): New.
1337 (pack_table): Use it for `base' and `table'.
1338 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1339 replaced with...
1340 (YYPACT_NINF, YYTABLE_NINF): these.
1341 (yypact, yytable): Compute their types instead of hard-coded
1342 `short'.
1343 * tests/regression.at (Web2c Actions): Adjust.
1344
5dde258a
AD
13452002-07-19 Akim Demaille <akim@epita.fr>
1346
1347 * src/scan-gram.l (id): Can start with an underscore.
1348
a945ec39
AD
13492002-07-16 Akim Demaille <akim@epita.fr>
1350
1351 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
1352 Adjust all former `associativity' dependencies.
1353 * src/symtab.c (symbol_new): Default associativity is `undef', not
1354 `right'.
1355 (symbol_check_alias_consistence): Adjust.
1356
fae437e8
AD
13572002-07-09 Akim Demaille <akim@epita.fr>
1358
1359 * doc/bison.texinfo: Properly set the ``header'' part.
1360 Use @dircategory ``GNU programming tools'' as per Texinfo's
1361 documentation.
1362 Use @copying.
1363
1a715ef2
AD
13642002-07-09 Akim Demaille <akim@epita.fr>
1365
1366 * lib/quotearg.h: Protect against multiple inclusions.
1367 * src/location.h (location_t): Add a `file' member.
1368 (LOCATION_RESET, LOCATION_PRINT): Adjust.
1369 * src/complain.c (warn_at, complain_at, fatal_at): Drop
1370 `error_one_per_line' support.
1371
a5d50994
AD
13722002-07-09 Akim Demaille <akim@epita.fr>
1373
1374 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
1375 * src/reader.c (lineno): Remove.
1376 Adjust all dependencies.
1377 (get_merge_function): Take a location and use complain_at.
1378 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
1379 * tests/regression.at (Invalid inputs, Mixing %token styles):
1380 Adjust.
1381
b275314e
AD
13822002-07-09 Akim Demaille <akim@epita.fr>
1383
1384 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
1385 recovery rule, and forbid extensions when --yacc.
1386 (gram_error): Use complain_at.
1387 * src/reader.c (reader): Exit if there were parse errors.
1388
865b9df1
AD
13892002-07-09 Akim Demaille <akim@epita.fr>
1390
1391 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
1392 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
1393 Reported by R Blake <blakers@mac.com>.
1394
c76e14da
AD
13952002-07-09 Akim Demaille <akim@epita.fr>
1396
1397 * data/yacc.c: Output the copyright notive in the header.
1398
7db2ed2d
AD
13992002-07-03 Akim Demaille <akim@epita.fr>
1400
1401 * src/output.c (froms, tos): Are state_number_t.
1402 (save_column): sp, sp1, and sp2 are state_number_t.
1403 (prepare): Rename `final' as `final_state_number', `nnts' as
1404 `nterms_number', `nrules' as `rules_number', `nstates' as
1405 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
1406 unused.
1407 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
1408 * data/lalr1.cc (nsym_): Remove, unused.
1409
e68e0410
AD
14102002-07-03 Akim Demaille <akim@epita.fr>
1411
1412 * src/lalr.h, src/lalr.c (goto_number_t): New.
1413 * src/lalr.c (goto_list_t): New.
1414 Propagate them.
1415 * src/nullable.c (rule_list_t): New.
1416 Propagate.
1417 * src/types.h: Remove.
1418
e1a4f3a4
AD
14192002-07-03 Akim Demaille <akim@epita.fr>
1420
1421 * src/closure.c (print_fderives): Use rule_rhs_print.
1422 * src/derives.c (print_derives): Use rule_rhs_print.
1423 (rule_list_t): New, replaces `shorts'.
1424 (set_derives): Add comments.
1425 * tests/sets.at (Nullable, Firsts): Adjust.
1426
536545f3
AD
14272002-07-03 Akim Demaille <akim@epita.fr>
1428
1429 * src/output.c (prepare_actions): Free `tally' and `width'.
1430 (prepare_actions): Allocate and free `order'.
1431 * src/symtab.c (symbols_free): Free `symbols'.
1432 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
1433 * src/output.c (m4_invoke): Move to...
1434 * src/scan-skel.l: here.
1435 (<<EOF>>): Close yyout, and free its name.
1436
8b752b00
AD
14372002-07-03 Akim Demaille <akim@epita.fr>
1438
1439 Fix some memory leaks, and fix a bug: state 0 was examined twice.
1440
1441 * src/LR0.c (new_state): Merge into...
1442 (state_list_append): this.
1443 (new_states): Merge into...
1444 (generate_states): here.
1445 (set_states): Don't ensure a proper `errs' state member here, do it...
1446 * src/conflicts.c (conflicts_solve): here.
1447 * src/state.h, src/state.c: Comment changes.
1448 (state_t): Rename member `shifts' as `transitions'.
1449 Adjust all dependencies.
1450 (errs_new): For consistency, also take the values as argument.
1451 (errs_dup): Remove.
1452 (state_errs_set): New.
1453 (state_reductions_set, state_transitions_set): Assert that no
1454 previous value was assigned.
1455 (state_free): New.
1456 (states_free): Use it.
1457 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
1458 temporary storage: use `errs' and `nerrs' as elsewhere.
1459 (set_conflicts): Allocate and free this `errs'.
1460
613f5e1a
AD
14612002-07-02 Akim Demaille <akim@epita.fr>
1462
1463 * lib/libiberty.h: New.
1464 * lib: Update the bitset implementation from upstream.
1465 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
1466 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
1467 * src/main.c: Adjust bitset stats calls.
1468
26e0cadc
PE
14692002-07-01 Paul Eggert <eggert@twinsun.com>
1470
1471 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
1472 char, so that negative chars don't collide with $.
1473
1154cced
AD
14742002-06-30 Akim Demaille <akim@epita.fr>
1475
1476 Have the GLR tests be `warning' checked, and fix the warnings.
1477
1478 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
1479 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
1480 (yyremoveDeletes): `yyi' and `yyj' are size_t.
1481 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
1482 (yyaddDeferredAction): static.
1483 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
1484 (yyreportParseError): yyprefix is const.
1485 yytokenp is used only when verbose.
1486 (yy__GNUC__): Replace with __GNUC__.
1487 (yypdumpstack): yyi is size_t.
1488 (yypreference): Un-yy local variables and arguments, to avoid
1489 clashes with `yyr1'. Anyway, we are not in the user name space.
1490 (yytname_size): be an int, as is compared with ints.
1491 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
1492 Use them.
1493 * tests/cxx-gram.at: Use quotation to protect $1.
1494 Use AT_COMPILE to enable warnings hunts.
1495 Prototype yylex and yyerror.
1496 `Use' argc.
1497 Include `string.h', not `strings.h'.
1498 Produce and prototype stmtMerge only when used.
1499 yylex takes a location.
1500
97650f4e
AD
15012002-06-30 Akim Demaille <akim@epita.fr>
1502
1503 We spend a lot of time in quotearg, in particular when --verbose.
1504
1505 * src/symtab.c (symbol_get): Store a quoted version of the key.
1506 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
1507 Adjust all callers.
1508
d2576365
AD
15092002-06-30 Akim Demaille <akim@epita.fr>
1510
1511 * src/state.h (reductions_t): Rename member `nreds' as num.
1512 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
1513 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
1514
ccaf65bc
AD
15152002-06-30 Akim Demaille <akim@epita.fr>
1516
1517 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
1518 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
1519 (shifts_to): Rename as...
1520 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1521 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1522 (TRANSITION_IS_DISABLED, transitions_to): these.
1523
87675353
AD
15242002-06-30 Akim Demaille <akim@epita.fr>
1525
1526 * src/print.c (print_shifts, print_gotos): Merge into...
1527 (print_transitions): this.
1528 (print_transitions, print_errs, print_reductions): Align the
1529 lookaheads columns.
1530 (print_core, print_transitions, print_errs, print_state,
1531 print_grammar): Output empty lines separator before, not after.
1532 (state_default_rule_compute): Rename as...
1533 (state_default_rule): this.
1534 * tests/conflicts.at (Defaulted Conflicted Reduction),
1535 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1536 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1537
ce4ccb4b
AD
15382002-06-30 Akim Demaille <akim@epita.fr>
1539
1540 Display items as we display rules.
1541
1542 * src/gram.h, src/gram.c (rule_lhs_print): New.
1543 * src/gram.c (grammar_rules_partial_print): Use it.
1544 * src/print.c (print_core): Likewise.
1545 * tests/conflicts.at (Defaulted Conflicted Reduction),
1546 (Unresolved SR Conflicts): Adjust.
1547 (Unresolved SR Conflicts): Adjust and rename as...
1548 (Resolved SR Conflicts): this, as was meant.
1549 * tests/regression.at (Web2c Report): Adjust.
1550
bc933ef1
AD
15512002-06-30 Akim Demaille <akim@epita.fr>
1552
1553 * src/print.c (state_default_rule_compute): New, extracted from...
1554 (print_reductions): here.
1555 Pessimize, but clarify the code.
1556 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1557
53d4308d
AD
15582002-06-30 Akim Demaille <akim@epita.fr>
1559
1560 * src/output.c (action_row): Let default_rule be always a rule
1561 number.
1562
574fb2d5
AD
15632002-06-30 Akim Demaille <akim@epita.fr>
1564
1565 * src/closure.c (print_firsts, print_fderives, closure):
1566 Use BITSET_EXECUTE.
1567 * src/lalr.c (lookaheads_print): Likewise.
1568 * src/state.c (state_rule_lookaheads_print): Likewise.
1569 * src/print_graph.c (print_core): Likewise.
1570 * src/print.c (print_reductions): Likewise.
1571 * src/output.c (action_row): Likewise.
1572 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1573
05811fd7
AD
15742002-06-30 Akim Demaille <akim@epita.fr>
1575
1576 * src/print_graph.c: Use report_flag.
1577
0e4d5753
AD
15782002-06-30 Akim Demaille <akim@epita.fr>
1579
1580 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1581 to...
1582 * src/relation.h, src/relation.c (traverse, relation_digraph)
1583 (relation_print, relation_transpose): New.
1584
24c7d800
AD
15852002-06-30 Akim Demaille <akim@epita.fr>
1586
1587 * src/state.h, src/state.c (shifts_to): New.
1588 * src/lalr.c (build_relations): Use it.
1589
9222837b
AD
15902002-06-30 Akim Demaille <akim@epita.fr>
1591
1592 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1593 (item_number_of_rule_number, rule_number_of_item_number): New.
1594 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1595 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1596 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1597 Propagate their use.
1598 Much remains to be done, in particular wrt `shorts' from types.h.
1599
260008e5
AD
16002002-06-30 Akim Demaille <akim@epita.fr>
1601
1602 * src/symtab.c (symbol_new): Initialize the `printer' member.
1603
8a731ca8
AD
16042002-06-30 Akim Demaille <akim@epita.fr>
1605
1606 * src/LR0.c (save_reductions): Remove, replaced by...
1607 * src/state.h, src/state.c (state_reductions_set): New.
1608 (reductions, errs): Rename as...
1609 (reductions_t, errs_t): these.
1610 Adjust all dependencies.
1611
32e1e0a4
AD
16122002-06-30 Akim Demaille <akim@epita.fr>
1613
1614 * src/LR0.c (state_list_t, state_list_append): New.
1615 (first_state, last_state): Now symbol_list_t.
1616 (this_state): Remove.
1617 (new_itemsets, append_states, save_reductions): Take a state_t as
1618 argument.
1619 (set_states, generate_states): Adjust.
1620 (save_shifts): Remove, replaced by...
1621 * src/state.h, src/state.c (state_shifts_set): New.
1622 (shifts): Rename as...
1623 (shifts_t): this.
1624 Adjust all dependencies.
1625 * src/state.h (state_t): Remove the `next' member.
1626
e5fb6710
AD
16272002-06-30 Akim Demaille <akim@epita.fr>
1628
1629 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1630 escaped in slot 0.
1631
c7ca99d4
AD
16322002-06-30 Akim Demaille <akim@epita.fr>
1633
1634 Use hash.h for the state hash table.
1635
1636 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1637 (allocate_storage): Use state_hash_new.
1638 (free_storage): Use state_hash_free.
1639 (new_state, get_state): Adjust.
1640 * src/lalr.h, src/lalr.c (states): Move to...
1641 * src/states.h (state_t): Remove the `link' member, no longer
1642 used.
1643 * src/states.h, src/states.c: here.
1644 (state_hash_new, state_hash_free, state_hash_lookup)
1645 (state_hash_insert, states_free): New.
1646 * src/states.c (state_table, state_compare, state_hash): New.
1647 * src/output.c (output_actions): Do not free states now, since we
1648 still need to know the final_state number in `prepare', called
1649 afterwards. Do it...
1650 * src/main.c (main): here: call states_free after `output'.
1651
df0e7316
AD
16522002-06-30 Akim Demaille <akim@epita.fr>
1653
1654 * src/state.h, src/state.c (state_new): New, extracted from...
1655 * src/LR0.c (new_state): here.
1656 * src/state.h (STATE_ALLOC): Move to...
1657 * src/state.c: here.
1658 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1659 * src/state.h, src/state.c: here.
1660
39f41916
AD
16612002-06-30 Akim Demaille <akim@epita.fr>
1662
1663 * src/reader.c (gensym): Rename as...
1664 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1665 (getsym): Rename as...
1666 (symbol_get): this.
1667
d57650a5
AD
16682002-06-30 Akim Demaille <akim@epita.fr>
1669
1670 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1671 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1672 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1673 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1674
5a08f1ce
AD
16752002-06-30 Akim Demaille <akim@epita.fr>
1676
1677 Make the test suite pass with warnings checked.
1678
1679 * tests/actions.at (Printers and Destructors): Improve.
1680 Avoid unsigned vs. signed issues.
1681 * tests/calc.at: Don't exercise the scanner here, do it...
1682 * tests/input.at (Torturing the Scanner): here.
1683
720623af
PH
16842002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1685
88e7e941 1686 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
1687 reorganize first lines parallel to yacc.c.
1688
fb8135fa
AD
16892002-06-28 Akim Demaille <akim@epita.fr>
1690
1691 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1692 (b4_token_enum, b4_token_defines): New, factored from...
1693 * data/lalr1.cc, data/yacc.c, glr.c: here.
1694
41442480
AD
16952002-06-28 Akim Demaille <akim@epita.fr>
1696
1697 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1698 unused variables.
1699 * src/output.c (merger_output): static.
1700
e0e5bf84
AD
17012002-06-28 Akim Demaille <akim@epita.fr>
1702
1703 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1704 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1705 pacify GCC.
1706 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 1707
676385e2
PH
17082002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1709
1710 Accumulated changelog for new GLR parsing features.
1711
6a254321 1712 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
1713 conflicts_total_count.
1714 * src/conflicts.h: Ditto.
1715 * src/output.c (token_actions): Use the new name.
1716 (output_conflicts): Change conflp => conflict_list_heads, and
1717 confl => conflict_list for better readability.
1718 * data/glr.c: Use the new names.
1719 * NEWS: Add self to GLR announcement.
e0e5bf84 1720
676385e2
PH
1721 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1722
1723 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1724 Akim Demaille.
1725
1726 * data/bison.glr: Change name to glr.c
1727 * data/glr.c: Renamed from bison.glr.
1728 * data/Makefile.am: Add glr.c
e0e5bf84
AD
1729
1730 * src/getargs.c:
1731
676385e2
PH
1732 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1733 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 1734
676385e2
PH
1735 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1736
1737 * data/bison.glr: Be sure to restore the
1738 current #line when returning to the skeleton contents after having
1739 exposed the input file's #line.
1740
1741 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1742
1743 * data/bison.glr: Bring up to date with changes to bison.simple.
1744
1745 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1746
1747 * data/bison.glr: Correct definitions that use b4_prefix.
1748 Various reformatting.
1749 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1750 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1751 yytokenp argument; now part of stack.
1752 (yychar): Define to behave as documented.
1753 (yyclearin): Ditto.
e0e5bf84 1754
676385e2
PH
1755 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1756
1757 * src/reader.h: Add declaration for free_merger_functions.
1758
1759 * src/reader.c (merge_functions): New variable.
1760 (get_merge_function): New function.
1761 (free_merger_functions): New function.
1762 (readgram): Check for %prec that is not followed by a symbol.
1763 Handle %dprec and %merge declarations.
1764 (packgram): Initialize dprec and merger fields in rules array.
1765
1766 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1767 conflict_list_cnt, conflict_list_free): New variables.
1768 (table_grow): Also grow conflict_table.
e0e5bf84 1769 (prepare_rules): Output dprec and merger tables.
676385e2 1770 (conflict_row): New function.
e0e5bf84 1771 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
1772 default reduction in conflicted states for GLR parser so that there
1773 are spaces for the conflict lists.
1774 (save_row): Also save conflict information.
1775 (token_actions): Allocate conflict list.
1776 (merger_output): New function.
1777 (pack_vector): Pack conflict table, too.
1778 (output_conflicts): New function to output yyconflp and yyconfl.
1779 (output_check): Allocate conflict_tos.
1780 (output_actions): Output conflict tables, also.
1781 (output_skeleton): Output b4_mergers definition.
1782 (prepare): Output b4_max_rhs_length definition.
1783 Use 'bison.glr' as default skeleton for GLR parsers.
1784
1785 * src/gram.c (glr_parser): New flag.
1786 (grammar_free): Call free_merger_functions.
1787
1788 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1789 all pairs of conflicting reductions, rather than just all tokens
1790 causing conflicts. Needed to size conflict tables.
e0e5bf84 1791 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
1792 interface.
1793 (conflicts_print): Ditto.
1794 (count_total_conflicts): New function.
1795
1796 * src/reader.h (merger_list): New type.
1797 (merge_functions): New variable.
1798
1799 * src/lex.h (tok_dprec, tok_merge): New token types.
1800
1801 * src/gram.h (rule_s): Add dprec and merger fields.
1802 (glr_parser): New flag.
1803
1804 * src/conflicts.h (count_total_conflicts): New function.
1805
1806 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1807
1808 * doc/bison.texinfo (Generalized LR Parsing): New section.
1809 (GLR Parsers): New section.
1810 (Language and Grammar): Mention GLR parsing.
1811 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1812 Correct typo ("tge" -> "the").
1813
1814 * data/bison.glr: New skeleton for GLR parsing.
1815
1816 * tests/cxx-gram.at: New tests for GLR parsing.
1817
1818 * tests/testsuite.at: Include cxx-gram.at.
1819
1820 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 1821
676385e2
PH
1822 * src/parse-gram.y:
1823
1824 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1825
1826 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 1827
b5480d74 18282002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
1829
1830 * src/options.h, src/options.c: Remove.
1831 * src/getargs.c (short_options, long_options): New.
1832
60491a94
AD
18332002-06-27 Akim Demaille <akim@epita.fr>
1834
1835 * data/bison.simple, data/bison.c++: Rename as...
1836 * data/yacc.c, data/lalr1.cc: these.
1837 * doc/bison.texinfo (Environment Variables): Remove.
1838
9be0c25b
AD
18392002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1840
1841 * src/getargs.c (report_argmatch): Initialize strtok().
1842
1ae72863
AD
18432002-06-20 Akim Demaille <akim@epita.fr>
1844
1845 * data/bison.simple (b4_symbol_actions): New, replaces...
1846 (b4_symbol_destructor, b4_symbol_printer): these.
1847 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1848 user token numbers.
1849
87542d29
AD
18502002-06-20 Akim Demaille <akim@epita.fr>
1851
1852 * data/bison.simple (yydestructor): Rename as...
1853 (yydestruct): this.
1854
1a31ed21
AD
18552002-06-20 Akim Demaille <akim@epita.fr>
1856
1857 * src/symtab.h, src/symtab.c (symbol_type_set)
1858 (symbol_destructor_set, symbol_precedence_set): The location is
1859 the last argument.
1860 Adjust all callers.
1861
e776192e
AD
18622002-06-20 Akim Demaille <akim@epita.fr>
1863
1864 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1865 internals.
1866 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1867 Takes a location.
1868 * src/symtab.h, src/symtab.c (symbol_class_set)
1869 (symbol_user_token_number_set): Likewise.
1870 Adjust all callers.
1871 Promote complain_at.
1872 * tests/input.at (Type Clashes): Adjust.
1873
5c1180b3
AD
18742002-06-20 Akim Demaille <akim@epita.fr>
1875
1876 * data/bison.simple (YYLEX): Fix the declaration when
1877 %pure-parser.
1878
e3170060
AD
18792002-06-20 Akim Demaille <akim@epita.fr>
1880
1881 * data/bison.simple (yysymprint): Don't print the token number,
1882 just its name.
1883 * tests/actions.at (Destructors): Rename as...
1884 (Printers and Destructors): this.
1885 Also exercise %printer.
1886
253862fd
AD
18872002-06-20 Akim Demaille <akim@epita.fr>
1888
1889 * data/bison.simple (YYDSYMPRINT): New.
1890 Use it to remove many of the #if YYDEBUG/if (yydebug).
1891
366eea36
AD
18922002-06-20 Akim Demaille <akim@epita.fr>
1893
1894 * src/symtab.h, src/symtab.c (symbol_t): printer and
1895 printer_location are new members.
1896 (symbol_printer_set): New.
1897 * src/parse-gram.y (PERCENT_PRINTER): New token.
1898 Handle its associated rule.
1899 * src/scan-gram.l: Adjust.
1900 (handle_destructor_at, handle_destructor_dollar): Rename as...
1901 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1902 * src/output.c (symbol_printers_output): New.
1903 (output_skeleton): Call it.
1904 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1905 since there are already many grammar files with a user `yyprint'.
1906 Replace the calls to YYPRINT to calls to yysymprint.
1907 * tests/calc.at: Adjust.
1908 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1909 taking advantage of parser very internal details (stack size!).
1910
4f25ebb0
AD
19112002-06-20 Akim Demaille <akim@epita.fr>
1912
1913 * src/scan-gram.l: Complete the scanner with the missing patterns
1914 to pacify Flex.
1915 Use `quote' and `symbol_tag_get' where appropriate.
1916
93b68a0e
AD
19172002-06-19 Akim Demaille <akim@epita.fr>
1918
1919 * tests/actions.at (Destructors): Augment to test locations.
1920 * data/bison.simple (yydestructor): Pass it the current location
1921 if locations are enabled.
1922 Prototype only when __STDC__ or C++.
1923 Change the argument names to move into the yy name space: there is
1924 user code here.
1925
58612f1d
AD
19262002-06-19 Akim Demaille <akim@epita.fr>
1927
74310291
AD
1928 * data/bison.simple (b4_pure_if): New.
1929 Use it instead of #ifdef YYPURE.
1930
19312002-06-19 Akim Demaille <akim@epita.fr>
1932
1933 * data/bison.simple (b4_location_if): New.
58612f1d
AD
1934 Use it instead of #ifdef YYLSP_NEEDED.
1935
f25bfb75
AD
19362002-06-19 Akim Demaille <akim@epita.fr>
1937
1938 Prepare @$ in %destructor, but currently don't bind it in the
1939 skeleton, as %location use is not cleaned up yet.
1940
1941 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1942 (handle_action_at): New.
1943 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1944 a braced_code_t and a location as additional arguments.
1945 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1946 unquote one when outputting `b4_dollar_dollar'.
1947 Adjust callers.
1948 * data/bison.simple (b4_eval): Remove.
1949 (b4_symbol_destructor): Adjust.
1950 * tests/input.at (Invalid @n): Adjust.
1951
c732d2c6
AD
19522002-06-19 Zack Weinberg <zack@codesourcery.com>
1953
1954 * doc/bison.texinfo: Document ability to have multiple
1955 prologue sections.
1956
8c165d89
AD
19572002-06-18 Akim Demaille <akim@epita.fr>
1958
1959 * src/files.c (compute_base_names): When computing the output file
1960 names from the input file name, strip the directory part.
1961
ca98bf57
AD
19622002-06-18 Akim Demaille <akim@epita.fr>
1963
1964 * data/bison.simple.new: Comment changes.
1965 Reported by Andreas Schwab.
1966
0bfb02ff
AD
19672002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1968
1969 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1970 there are no `label `yyoverflowlab' defined but not used' warnings
1971 when yyoverflow is defined.
1972
24c0aad7
AD
19732002-06-18 Akim Demaille <akim@epita.fr>
1974
1975 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1976 new member.
1977 (symbol_destructor_set): Adjust.
1978 * src/output.c (symbol_destructors_output): Output the destructor
1979 locations.
1980 Output the symbol name.
1981 * data/bison.simple (b4_symbol_destructor): Adjust.
1982
5719c109
AD
19832002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1984 and Akim Demaille <akim@epita.fr>
1985
1986 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1987 what's left on the stack when the error recovery hits EOF.
1988 * tests/actions.at (Destructors): Complete to exercise this case.
1989
9280d3ef
AD
19902002-06-17 Akim Demaille <akim@epita.fr>
1991
1992 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1993 arguments is really empty, not only equal to `[]'.
1994 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1995 member.
1996 (symbol_destructor_set): New.
1997 * src/output.c (symbol_destructors_output): New.
1998 * src/reader.h (brace_code_t, current_braced_code): New.
1999 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
2000 (handle_dollar): Rename as...
2001 (handle_action_dollar): this.
2002 (handle_destructor_dollar): New.
2003 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
2004 (grammar_declaration): Use it.
2005 * data/bison.simple (yystos): Is always defined.
2006 (yydestructor): New.
2007 * tests/actions.at (Destructors): New.
2008 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
2009
dafdc66f
AD
20102002-06-17 Akim Demaille <akim@epita.fr>
2011
2012 * src/symlist.h, src/symlist.c (symbol_list_length): New.
2013 * src/scan-gram.l (handle_dollar, handle_at): Compute the
2014 rule_length only when needed.
2015 * src/output.c (actions_output, token_definitions_output): Output
2016 the full M4 block.
2017 * src/symtab.c: Don't access directly to the symbol tag, use
2018 symbol_tag_get.
2019 * src/parse-gram.y: Use symbol_list_free.
2020
56c47203
AD
20212002-06-17 Akim Demaille <akim@epita.fr>
2022
2023 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
2024 (symbol_list_prepend, get_type_name): Move to...
2025 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
2026 (symbol_list_prepend, symbol_list_n_type_name_get): here.
2027 Adjust all callers.
2028 (symbol_list_free): New.
2029 * src/scan-gram.l (handle_dollar): Takes a location.
2030 * tests/input.at (Invalid $n): Adjust.
2031
1e0bab92
AD
20322002-06-17 Akim Demaille <akim@epita.fr>
2033
2034 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2035 (symbol_list_prepend): New.
2036 * src/parse-gram.y (%union): `list' is a new member.
2037 (symbols.1): New, replaces...
2038 (terms_to_prec.1, nterms_to_type.1): these.
2039 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2040 Take a location as additional argument.
2041 Adjust all callers.
2042
04e60654
AD
20432002-06-15 Akim Demaille <akim@epita.fr>
2044
2045 * src/parse-gram.y: Move %token in the declaration section so that
2046 we don't depend upon CVS Bison.
2047
10e5b8bd
AD
20482002-06-15 Akim Demaille <akim@epita.fr>
2049
2050 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2051 * src/print.c (print_core): Use it.
2052
9801d40c
AD
20532002-06-15 Akim Demaille <akim@epita.fr>
2054
2055 * src/conflicts.c (log_resolution): Accept the rule involved in
2056 the sr conflicts instead of the lookahead number that points to
2057 that rule.
2058 (flush_reduce): Accept the current lookahead vector as argument,
2059 instead of the index in LA.
2060 (resolve_sr_conflict): Accept the current number of lookahead
2061 bitset to consider for the STATE, instead of the index in LA.
2062 (set_conflicts): Adjust.
2063 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2064
c0263492
AD
20652002-06-15 Akim Demaille <akim@epita.fr>
2066
2067 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2068 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2069 Adjust all dependencies.
2070 * src/lalr.c (initialize_lookaheads): Split into...
2071 (states_lookaheads_count, states_lookaheads_initialize): these.
2072 (lalr): Adjust.
2073
9757c359
AD
20742002-06-15 Akim Demaille <akim@epita.fr>
2075
2076 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2077 out of...
2078 (grammar_rules_print): here.
2079 * src/reduce.c (reduce_output): Use it.
2080 * tests/reduce.at (Useless Rules, Reduced Automaton)
2081 (Underivable Rules): Adjust.
2082
6b98e4b5
AD
20832002-06-15 Akim Demaille <akim@epita.fr>
2084
2085 Copy BYacc's nice way to report the grammar.
2086
2087 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2088 New.
2089 Don't print the rules' location, it is confusing and useless.
2090 (rule_print): Use grammar_rhs_print.
2091 * src/print.c (print_grammar): Use grammar_rules_print.
2092
6b98e4b5
AD
20932002-06-15 Akim Demaille <akim@epita.fr>
2094
2095 Complete and rationalize `useless thing' warnings.
2096
2097 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2098 (symbol_tag_print): New.
2099 Use them everywhere in place of accessing directly the tag member.
2100 * src/gram.h, src/gram.c (rule_print): New.
2101 Use it where a rule used to be printed `by hand'.
2102 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2103 (reduce_grammar_tables): Report the useless rules.
2104 (reduce_print): Useless things are a warning, not an error.
2105 Report it as such.
2106 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2107 (Reduced Automaton, Underivable Rules): Adjust.
2108 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2109 * tests/conflicts.at (Unresolved SR Conflicts)
2110 (Solved SR Conflicts): Adjust.
2111
ee000ba4
AD
21122002-06-15 Akim Demaille <akim@epita.fr>
2113
2114 Let symbols have a location.
2115
2116 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2117 (getsym): Adjust.
2118 Adjust all callers.
2119 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2120 Use location_t, not int.
2121 * src/symtab.c (symbol_check_defined): Take advantage of the
2122 location.
2123 * tests/regression.at (Invalid inputs): Adjust.
2124
8efe435c
AD
21252002-06-15 Akim Demaille <akim@epita.fr>
2126
2127 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2128 (input): Don't try to initialize yylloc here, do it in the
2129 scanner.
2130 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2131 * src/gram.h (rule_t): Change line and action_line into location
2132 and action_location, of location_t type.
2133 Adjust all dependencies.
2134 * src/location.h, src/location.c (empty_location): New.
2135 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2136 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2137 (grammar_current_rule_symbol_append)
2138 (grammar_current_rule_action_append): Expect a location as argument.
2139 * src/reader.c (grammar_midrule_action): Adjust to attach an
2140 action's location as dummy symbol location.
2141 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2142 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2143 the line numbers.
2144
1921f1d7
AD
21452002-06-14 Akim Demaille <akim@epita.fr>
2146
2147 Grammar declarations may be found in the grammar section.
2148
2149 * src/parse-gram.y (rules_or_grammar_declaration): New.
2150 (declarations): Each declaration may end with a semicolon, not
2151 just...
2152 (grammar_declaration): `"%union"'.
2153 (grammar): Branch to rules_or_grammar_declaration.
2154
4515534c
AD
21552002-06-14 Akim Demaille <akim@epita.fr>
2156
2157 * src/main.c (main): Invoke scanner_free.
2158
f958596b
AD
21592002-06-14 Akim Demaille <akim@epita.fr>
2160
2161 * src/output.c (m4_invoke): Extracted from...
2162 (output_skeleton): here.
2163 Free tempfile.
2164
2c569025
AD
21652002-06-14 Akim Demaille <akim@epita.fr>
2166
2167 * src/parse-gram.y (directives, directive, gram)
2168 (grammar_directives, precedence_directives, precedence_directive):
2169 Rename as...
2170 (declarations, declaration, grammar, grammar_declaration)
2171 (precedence_declaration, precedence_declarator): these.
2172 (symbol_declaration): New.
2173
592e8d4d
AD
21742002-06-14 Akim Demaille <akim@epita.fr>
2175
2176 * src/files.c (action_obstack): Remove, unused.
2177 (output_obstack): Remove it, and all its dependencies, as it is no
2178 longer needed.
2179 * src/reader.c (epilogue_set): Build the epilogue in the
2180 muscle_obstack.
2181 * src/output.h, src/output.c (muscle_obstack): Move to...
2182 * src/muscle_tab.h, src/muscle_tab.h: here.
2183 (muscle_init): Initialize muscle_obstack.
2184 (muscle_free): New.
2185 * src/main.c (main): Call it.
2186
0c15323d
AD
21872002-06-14 Akim Demaille <akim@epita.fr>
2188
2189 * src/location.h: New, extracted from...
2190 * src/reader.h: here.
2191 * src/Makefile.am (noinst_HEADERS): Merge into
2192 (bison_SOURCES): this.
2193 Add location.h.
2194 * src/parse-gram.y: Use location_t instead of Bison's.
2195 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2196 Use location_t instead of ints.
2197
e96c9728
AD
21982002-06-14 Akim Demaille <akim@epita.fr>
2199
2200 * data/bison.simple, data/bison.c++: Be sure to restore the
2201 current #line when returning to the skeleton contents after having
2202 exposed the input file's #line.
2203
75d1fe16
AD
22042002-06-12 Akim Demaille <akim@epita.fr>
2205
2206 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2207 eager.
2208 * tests/actions.at (Exotic Dollars): New.
2209
6c35d22c
AD
22102002-06-12 Akim Demaille <akim@epita.fr>
2211
2212 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2213 ['"/] too eagerly.
2214 * tests/input.at (Torturing the Scanner): New.
2215
1d6412ad
AD
22162002-06-11 Akim Demaille <akim@epita.fr>
2217
2218 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2219 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2220 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2221 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2222 * src/reader.c (reader): Use it.
2223
4cdb01db
AD
22242002-06-11 Akim Demaille <akim@epita.fr>
2225
2226 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2227 Adjust all callers.
2228 (scanner_last_string_free): New.
2229
44995b2e
AD
22302002-06-11 Akim Demaille <akim@epita.fr>
2231
2232 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2233 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2234 (last_string, YY_OBS_FREE): New.
2235 Use them when returning an ID.
2236
e9955c83
AD
22372002-06-11 Akim Demaille <akim@epita.fr>
2238
2239 Have Bison grammars parsed by a Bison grammar.
2240
2241 * src/reader.c, src/reader.h (prologue_augment): New.
2242 * src/reader.c (copy_definition): Remove.
2243
2244 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2245 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2246 (grammar_current_rule_prec_set, grammar_current_rule_check)
2247 (grammar_current_rule_symbol_append)
2248 (grammar_current_rule_action_append): Export.
2249 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2250 (symbol_list_action_append): Remove.
2251 Hook the routines from reader.
2252 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2253 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2254
2255 * src/reader.c (read_declarations): Remove, unused.
2256
2257 * src/parse-gram.y: Handle the epilogue.
2258 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2259 (grammar_start_symbol_set): this.
2260 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2261 * src/reader.c (readgram): Remove, unused.
2262 (reader): Adjust to insert eoftoken and axiom where appropriate.
2263
2264 * src/reader.c (copy_dollar): Replace with...
2265 * src/scan-gram.h (handle_dollar): this.
2266 * src/parse-gram.y: Remove `%thong'.
2267
2268 * src/reader.c (copy_at): Replace with...
2269 * src/scan-gram.h (handle_at): this.
2270
2271 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2272 New.
2273
2274 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2275 time being.
2276
2277 * src/reader.h, src/reader.c (grammar_rule_end): New.
2278
2279 * src/parse.y (current_type, current_class): New.
2280 Implement `%nterm', `%token' support.
2281 Merge `%term' into `%token'.
2282 (string_as_id): New.
2283 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2284 type name.
2285
2286 * src/parse-gram.y: Be sure to handle properly the beginning of
2287 rules.
2288
2289 * src/parse-gram.y: Handle %type.
2290 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2291
2292 * src/parse-gram.y: More directives support.
2293 * src/options.c: No longer handle source directives.
2294
2295 * src/parse-gram.y: Fix %output.
2296
2297 * src/parse-gram.y: Handle %union.
2298 Use the prologue locations.
2299 * src/reader.c (parse_union_decl): Remove.
2300
2301 * src/reader.h, src/reader.c (epilogue_set): New.
2302 * src/parse-gram.y: Use it.
2303
2304 * data/bison.simple, data/bison.c++: b4_stype is now either not
2305 defined, then default to int, or to the contents of %union,
2306 without `union' itself.
2307 Adjust.
2308 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2309
2310 * src/output.c (actions_output): Don't output braces, as they are
2311 already handled by the scanner.
2312
2313 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2314 characters to themselves.
2315
2316 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2317 that the epilogue has a proper #line.
2318
2319 * src/parse-gram.y: Handle precedence/associativity.
2320
2321 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2322 a terminal.
2323 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2324 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2325 at all to define terminals that cannot be emitted.
2326
2327 * src/scan-gram.l: Escape M4 characters.
2328
2329 * src/scan-gram.l: Working properly with escapes in user
2330 strings/characters.
2331
2332 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2333 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2334 grammar.
2335 Use more modest sizes, as for the time being the parser does not
2336 release memory, and therefore the process swallows a huge amount
2337 of memory.
2338
2339 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2340 stricter %token grammar.
2341
2342 * src/symtab.h (associativity): Add `undef_assoc'.
2343 (symbol_precedence_set): Do nothing when passed an undef_assoc.
2344 * src/symtab.c (symbol_check_alias_consistence): Adjust.
2345
2346 * tests/regression.at (Invalid %directive): Remove, as it is now
2347 meaningless.
2348 (Invalid inputs): Adjust to the new error messages.
2349 (Token definitions): The new grammar doesn't allow too many
2350 eccentricities.
2351
2352 * src/lex.h, src/lex.c: Remove.
2353 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
2354 (copy_character, copy_string2, copy_string, copy_identifier)
2355 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
2356 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
2357 (parse_action): Remove.
2358 * po/POTFILES.in: Adjust.
2359
2e047461
AD
23602002-06-11 Akim Demaille <akim@epita.fr>
2361
2362 * src/reader.c (parse_action): Don't store directly into the
2363 rule's action member: return the action as a string.
2364 Don't require `rule_length' as an argument: compute it.
2365 (grammar_current_rule_symbol_append)
2366 (grammar_current_rule_action_append): New, eved out from
2367 (readgram): here.
2368 Remove `action_flag', `rulelength', unused now.
2369
9af3fbce
AD
23702002-06-11 Akim Demaille <akim@epita.fr>
2371
2372 * src/reader.c (grammar_current_rule_prec_set).
2373 (grammar_current_rule_check): New, eved out from...
2374 (readgram): here.
2375 Remove `xaction', `first_rhs': useless.
2376 * tests/input.at (Type clashes): New.
2377 * tests/existing.at (GNU Cim Grammar): Adjust.
2378
1485e106
AD
23792002-06-11 Akim Demaille <akim@epita.fr>
2380
2381 * src/reader.c (grammar_midrule_action): New, Eved out from
2382 (readgram): here.
2383
da4160c3
AD
23842002-06-11 Akim Demaille <akim@epita.fr>
2385
2386 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
2387 New.
2388 (readgram): Use them as replacement of inlined code, crule and
2389 crule1.
2390
f6d0f937
AD
23912002-06-11 Akim Demaille <akim@epita.fr>
2392
2393 * src/reader.c (grammar_end, grammar_symbol_append): New.
2394 (readgram): Use them.
2395 Make the use of `p' as local as possible.
2396
69078d4b
AD
23972002-06-10 Akim Demaille <akim@epita.fr>
2398
2399 GCJ's parser requires the tokens to be defined before the prologue.
2400
2401 * data/bison.simple: Output the token definition before the user's
2402 prologue.
2403 * tests/regression.at (Braces parsing, Duplicate string)
2404 (Mixing %token styles): Check the output from bison.
2405 (Early token definitions): New.
2406
5e424082
AD
24072002-06-10 Akim Demaille <akim@epita.fr>
2408
2409 * src/symtab.c (symbol_user_token_number_set): Don't complain when
2410 assigning twice the same user number to a token, so that we can
2411 use it in...
2412 * src/lex.c (lex): here.
2413 Also use `symbol_class_set' instead of hand written code.
2414 * src/reader.c (parse_assoc_decl): Likewise.
2415
44536b35
AD
24162002-06-10 Akim Demaille <akim@epita.fr>
2417
2418 * src/symtab.c, src/symtab.c (symbol_class_set)
2419 (symbol_user_token_number_set): New.
2420 * src/reader.c (parse_token_decl): Use them.
2421 Use a switch instead of ifs.
2422 Use a single argument.
2423
8b9f2372
AD
24242002-06-10 Akim Demaille <akim@epita.fr>
2425
2426 Remove `%thong' support as it is undocumented, unused, duplicates
2427 `%token's job, and creates useless e-mail traffic with people who
2428 want to know what it is, why it is undocumented, unused, and
2429 duplicates `%token's job.
2430
2431 * src/reader.c (parse_thong_decl): Remove.
2432 * src/options.c (option_table): Remove "thong".
2433 * src/lex.h (tok_thong): Remove.
2434
3ae2b51f
AD
24352002-06-10 Akim Demaille <akim@epita.fr>
2436
2437 * src/symtab.c, src/symtab.c (symbol_type_set)
2438 (symbol_precedence_set): New.
2439 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
2440 (value_components_used): Remove, unused.
2441
2f1afb73
AD
24422002-06-09 Akim Demaille <akim@epita.fr>
2443
2444 Move symbols handling code out of the reader.
2445
2446 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
2447 (axiom): Move to...
2448 * src/symtab.h, src/symtab.c: here.
2449
2450 * src/gram.c (start_symbol): Remove: use startsymbol->number.
2451 * src/reader.c (startval): Rename as...
2452 * src/symtab.h, src/symtab.c (startsymbol): this.
2453 * src/reader.c: Adjust.
2454
2455 * src/reader.c (symbol_check_defined, symbol_make_alias)
2456 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2457 (token_translations_init)
2458 Move to...
2459 * src/symtab.c: here.
2460 * src/reader.c (packsymbols): Move to...
2461 * src/symtab.h, src/symtab.c (symbols_pack): here.
2462 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
2463 argument.
2464
e9bca3ad
AD
24652002-06-03 Akim Demaille <akim@epita.fr>
2466
2467 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
2468 then statements.
2469
86eff183
AD
24702002-06-03 Akim Demaille <akim@epita.fr>
2471
2472 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
2473 structs with non literals.
2474 * src/scan-skel.l: never-interactive.
2475 * src/conflicts.c (enum conflict_resolution_e): No trailing
2476 comma.
2477 * src/getargs.c (usage): Split long literal strings.
2478 Reported by Hans Aberg.
2479
717be197
AD
24802002-05-28 Akim Demaille <akim@epita.fr>
2481
2482 * data/bison.c++: Use C++ ostreams.
2483 (cdebug_): New member.
2484
670ddffd
AD
24852002-05-28 Akim Demaille <akim@epita.fr>
2486
2487 * src/output.c (output_skeleton): Be sure to allocate enough room
2488 for `/' _and_ for `\0' in full_skeleton.
2489
769b430f
AD
24902002-05-28 Akim Demaille <akim@epita.fr>
2491
2492 * data/bison.c++: Catch up with bison.simple:
2493 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2494 and Paul Eggert <eggert@twinsun.com>: `error' handing.
2495 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
2496 and popping traces.
2497
7067cb36
PH
24982002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2499
2500 * src/output.c (output_skeleton): Put an explicit path in front of
2501 the skeleton file name, rather than relying on the -I directory,
2502 to partially alleviate effects of having a skeleton file lying around
2503 in the current directory.
769b430f 2504
4a713ec2
PH
25052002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2506
769b430f 2507 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
2508 obstack_printf should be obstack_fgrow1.
2509
b408954b
AD
25102002-05-26 Akim Demaille <akim@epita.fr>
2511
2512 * src/state.h (state_t): `solved_conflicts' is a new member.
2513 * src/LR0.c (new_state): Set it to 0.
2514 * src/conflicts.h, src/conflicts.c (print_conflicts)
2515 (free_conflicts, solve_conflicts): Rename as...
2516 (conflicts_print, conflicts_free, conflicts_solve): these.
2517 Adjust callers.
2518 * src/conflicts.c (enum conflict_resolution_e)
2519 (solved_conflicts_obstack): New, used by...
2520 (log_resolution): this.
2521 Adjust to attach the conflict resolution to each state.
2522 Complete the description with the precedence/associativity
2523 information.
2524 (resolve_sr_conflict): Adjust.
2525 * src/print.c (print_state): Output its solved_conflicts.
2526 * tests/conflicts.at (Unresolved SR Conflicts)
2527 (Solved SR Conflicts): Exercise --report=all.
2528
a49aecd5
AD
25292002-05-26 Akim Demaille <akim@epita.fr>
2530
2531 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2532 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2533 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2534 (token_number_t, item_number_as_token_number)
2535 (token_number_as_item_number, muscle_insert_token_number_table):
2536 Rename as...
2537 (symbol_number_t, item_number_as_symbol_number)
2538 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2539 these, since it is more appropriate.
2540
5504898e
AD
25412002-05-26 Akim Demaille <akim@epita.fr>
2542
2543 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2544 `Error:' lines.
2545 * data/bison.simple (yystos) [YYDEBUG]: New.
2546 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2547 error recovery.
2548 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2549
ec3bc396
AD
25502002-05-25 Akim Demaille <akim@epita.fr>
2551
2552 * doc/bison.texinfo (Debugging): Split into...
2553 (Tracing): this new section, its former contents, and...
2554 (Understanding): this new section.
2555 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2556 by...
2557 (report_flag): this.
2558 Adjust all dependencies.
2559 (report_args, report_types, report_argmatch): New.
2560 (usage, getargs): Report/support -r, --report.
2561 * src/options.h
2562 (struct option_table_struct): Rename as..,
2563 (struct option_table_s): this.
2564 Rename the `set_flag' member to `flag' to match with getopt_long's
2565 struct.
2566 * src/options.c (option_table): Split verbose into an entry for
2567 %verbose, and another for --verbose.
2568 Support --report/-r, so remove -r from the obsolete --raw.
2569 * src/print.c: Attach full item sets and lookaheads reports to
2570 report_flag instead of trace_flag.
2571 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2572
78df8250
PE
25732002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2574 and Paul Eggert <eggert@twinsun.com>
769b430f 2575
78df8250
PE
2576 * data/bison.simple (yyparse): Correct error handling to conform to
2577 POSIX and yacc. Specifically, after syntax error is discovered,
2578 do not reduce further before shifting the error token.
2579 Clean up the code a bit by removing the labels yyerrdefault,
2580 yyerrhandle, yyerrpop.
2581 * NEWS: Document the above.
2582
c0c9ea05
PH
25832002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2584
2585 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2586 type; it isn't always big enough, since it doesn't necessarily
2587 include non-terminals.
769b430f 2588 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
2589 the latter can be removed.
2590 (yy_token_number_type): Remove, only one use.
2591 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2592 don't use TokenNumberType as element type.
769b430f 2593
c0c9ea05
PH
2594 * tests/regression.at: Modify expected output to agree with change
2595 to yyr1 and yytranslate.
769b430f 2596
6390a83f
FK
25972002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2598
2599 * src/reader.c (parse_action): Use copy_character instead of
2600 obstack_1grow.
2601
db7c8e9a
AD
26022002-05-13 Akim Demaille <akim@epita.fr>
2603
2604 * tests/regression.at (Token definitions): Prototype yylex and
2605 yyerror.
2606
fcc61800
PH
26072002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2608
158c687b 2609 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
2610 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2611 32-bit arithmetic.
2612 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2613
5683e9b2
AD
26142002-05-07 Akim Demaille <akim@epita.fr>
2615
2616 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2617 avoid GCC warnings.
2618
0c2d3f4c
AD
26192002-05-07 Akim Demaille <akim@epita.fr>
2620
2621 Kill GCC warnings.
2622
2623 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2624 over the RHS of each rule.
2625 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2626 * src/state.h (state_t): Member `nitems' is unsigned short.
2627 * src/LR0.c (get_state): Adjust.
2628 * src/reader.c (packgram): Likewise.
2629 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2630 `Type'.
2631 (muscle_insert_int_table): Remove, unused.
2632 (prepare_rules): Remove `max'.
2633
1565b720
AD
26342002-05-06 Akim Demaille <akim@epita.fr>
2635
2636 * src/closure.c (print_firsts): Display of the symbol tags.
2637 (bitmatrix_print): Move to...
2638 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2639 here.
2640 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2641
cfaee611
AD
26422002-05-06 Akim Demaille <akim@epita.fr>
2643
2644 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2645 hash_do_for_each.
2646
458be8e0
AD
26472002-05-06 Akim Demaille <akim@epita.fr>
2648
2649 * src/LR0.c (new_state, get_state): Instead of using the global
2650 `kernel_size' and `kernel_base', have two new arguments:
2651 `core_size' and `core'.
2652 Adjust callers.
2653
a900a624
AD
26542002-05-06 Akim Demaille <akim@epita.fr>
2655
2656 * src/reader.c (packgram): No longer end `ritem' with a 0
2657 sentinel: it is not used.
2658
d4e7d3a1
AD
26592002-05-05 Akim Demaille <akim@epita.fr>
2660
2661 New experimental feature: display the lookaheads in the report and
2662 graph.
2663
2664 * src/print (print_core): When --trace-flag, display the rules
2665 lookaheads.
2666 * src/print_graph.c (print_core): Likewise.
2667 Swap the arguments.
2668 Adjust caller.
2669
39ceb25b
AD
26702002-05-05 Akim Demaille <akim@epita.fr>
2671
2672 * tests/torture.at (Many lookaheads): New test.
2673
5372019f
AD
26742002-05-05 Akim Demaille <akim@epita.fr>
2675
2676 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2677 (GENERATE_MUSCLE_INSERT_TABLE): this.
2678 (output_int_table, output_unsigned_int_table, output_short_table)
2679 (output_token_number_table, output_item_number_table): Replace with...
2680 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2681 (muscle_insert_short_table, muscle_insert_token_number_table)
2682 (muscle_insert_item_number_table): these.
2683 Adjust all callers.
2684 (prepare_tokens): Don't free `translations', since...
2685 * src/reader.h, src/reader.c (grammar_free): do it.
2686 Move to...
2687 * src/gram.h, src/gram.c (grammar_free): here.
2688 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2689 b4_translate_max.
2690
5df5f6d5
AD
26912002-05-05 Akim Demaille <akim@epita.fr>
2692
2693 * src/output.c (output_unsigned_int_table): New.
2694 (prepare_rules): `i' is unsigned.
2695 `prhs', `rline', `r2' are unsigned int.
2696 Rename muscle `rhs_number_max' as `rhs_max'.
2697 Output muscles `prhs_max', `rline_max', and `r2_max'.
2698 Free rline and r1.
2699 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2700 to compute types instead of constant types.
2701 * tests/regression.at (Web2c Actions): Adjust.
2702
b87f8b21
AD
27032002-05-04 Akim Demaille <akim@epita.fr>
2704
2705 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2706 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2707 Adjust dependencies.
2708 * src/output.c (token_definitions_output): Be sure not to output a
2709 `#define 'a'' when fed with `%token 'a' "a"'.
2710 * tests/regression.at (Token definitions): New.
2711
8bb936e4
PE
27122002-05-03 Paul Eggert <eggert@twinsun.com>
2713
2714 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2715 for K&R C.
2716
27172002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2718
2719 * Makefile.am (SUBDIRS): Remove intl.
2720 (EXTRA_DIST): Add config/config.rpath.
2721
53c71a12
AD
27222002-05-03 Akim Demaille <akim@epita.fr>
2723
2724 * data/bison.simple (m4_if): Don't output empty enums.
2725 And actually, output valid enum definitions :(.
2726
289dd0cf
AD
27272002-05-03 Akim Demaille <akim@epita.fr>
2728
2729 * configure.bat: Remove, completely obsolete.
2730 * Makefile.am (EXTRA_DIST): Adjust.
2731 Don't distribute config.rpath...
2732 * config/Makefile.am (EXTRA_DIST): Do it.
2733
db85e524
AD
27342002-05-03 Akim Demaille <akim@epita.fr>
2735
2736 * configure.in (GETTEXT_VERSION): New.
2737 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2738
83ccf991
AD
27392002-05-03 Akim Demaille <akim@epita.fr>
2740
2741 * data/bison.simple (b4_token_enum): New.
2742 (b4_token_defines): Use it to output tokens both as #define and
2743 enums.
2744 Suggested by Paul Eggert.
2745 * src/output.c (token_definitions_output): Don't output spurious
2746 white spaces.
2747
1f418995
AD
27482002-05-03 Akim Demaille <akim@epita.fr>
2749
2750 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2751
45119f04
RA
27522002-05-02 Robert Anisko <robert@lrde.epita.fr>
2753
2754 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2755 Update the stack class, give a try to deque as the default container.
2756
b2d52318
AD
27572002-05-02 Akim Demaille <akim@epita.fr>
2758
2759 * data/bison.simple (yyparse): Do not implement @$ = @1.
2760 (YYLLOC_DEFAULT): Adjust to do it.
2761 * doc/bison.texinfo (Location Default Action): Fix.
2762
3a8b4109
AD
27632002-05-02 Akim Demaille <akim@epita.fr>
2764
2765 * src/reader.c (parse_braces): Merge into...
2766 (parse_action): this.
2767
84614e13
AD
27682002-05-02 Akim Demaille <akim@epita.fr>
2769
2770 * configure.in (ALL_LINGUAS): Remove.
2771 * po/LINGUAS, hr.po: New.
2772
fdbcd8e2
AD
27732002-05-02 Akim Demaille <akim@epita.fr>
2774
2775 Remove the so called hairy (semantic) parsers.
2776
2777 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2778 * src/gram.h, src/gram.c (semantic_parser): Remove.
2779 (rule_t): Remove the guard and guard_line members.
2780 * src/lex.h (token_t): remove tok_guard.
2781 * src/options.c (option_table): Remove %guard and %semantic_parser
2782 support.
2783 * src/output.c, src/output.h (guards_output): Remove.
2784 (prepare): Adjust.
2785 (token_definitions_output): Don't output the `T'
2786 tokens (???).
2787 (output_skeleton): Don't output the guards.
2788 * src/files.c, src/files.c (attrsfile): Remove.
2789 * src/reader.c (symbol_list): Remove the guard and guard_line
2790 members.
2791 Adjust dependencies.
2792 (parse_guard): Remove.
2793 * data/bison.hairy: Remove.
2794 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2795 BISON_HAIRY.
2796
82b6cb3f
AD
27972002-05-02 Akim Demaille <akim@epita.fr>
2798
2799 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2800 (parse_guard): Rename the formal argument `stack_offset' as
2801 `rule_length', which is more readable.
2802 Adjust callers.
2803 (copy_at, copy_dollar): Instead of outputting the hard coded
2804 values of $$, $n and so forth, output invocation to b4_lhs_value,
2805 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
2806 Note: this patch partially drops `semantic-parser' support: it
2807 always does `rule_length - n', where semantic parsers ought to
2808 always use `-n'.
82b6cb3f
AD
2809 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2810 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2811
6cbfbcc5
AD
28122002-05-02 Akim Demaille <akim@epita.fr>
2813
2814 * configure.in (AC_INIT): Bump to 1.49b.
2815 (AM_INIT_AUTOMAKE): Short invocation.
2816
b8548114
AD
28172002-05-02 Akim Demaille <akim@epita.fr>
2818
2819 Version 1.49a.
2820
c20cd1fa
AD
28212002-05-01 Akim Demaille <akim@epita.fr>
2822
2823 * src/skeleton.h: Remove.
2824
8a9566d4
AD
28252002-05-01 Akim Demaille <akim@epita.fr>
2826
2827 * src/skeleton.h: Fix the #endif.
2828 Reported by Magnus Fromreide.
2829
8c6d399a
PE
28302002-04-26 Paul Eggert <eggert@twinsun.com>
2831
2832 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2833 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 2834 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 2835
2b7ed18a
RA
28362002-04-25 Robert Anisko <robert@lrde.epita.fr>
2837
2838 * src/scan-skel.l: Postprocess quadrigraphs.
2839
2840 * src/reader.c (copy_character): New function, used to output
2841 single characters while replacing `[' and `]' with quadrigraphs, to
2842 avoid troubles with M4 quotes.
2843 (copy_comment): Output characters with copy_character.
2844 (read_additionnal_code): Likewise.
2845 (copy_string2): Likewise.
2846 (copy_definition): Likewise.
2847
2848 * tests/calc.at: Exercise M4 quoting.
2849
34a89c50
AD
28502002-04-25 Akim Demaille <akim@epita.fr>
2851
2852 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2853 between `!' and the command.
2854 Reported by Paul Eggert.
2855
0dd1580a
RA
28562002-04-24 Robert Anisko <robert@lrde.epita.fr>
2857
2858 * tests/calc.at: Exercise prologue splitting.
2859
2860 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2861 `b4_post_prologue' instead of `b4_prologue'.
2862
2863 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2864 muscles.
2865 (output): Free pre_prologue_obstack and post_prologue_obstack.
2866 * src/files.h, src/files.c (attrs_obstack): Remove.
2867 (pre_prologue_obstack, post_prologue_obstack): New.
2868 * src/reader.c (copy_definition): Add a parameter to specify the
2869 obstack to fill, instead of using attrs_obstack unconditionally.
2870 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2871 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2872
83c1796f
PE
28732002-04-23 Paul Eggert <eggert@twinsun.com>
2874
2875 * data/bison.simple: Remove unnecessary commentary and white
2876 space differences from 1_29-branch.
2877 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2878
2879 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2880 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2881 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2882 constructors or destructors.
2883
2884 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2885
1207eeac
AD
28862002-04-23 Akim Demaille <akim@epita.fr>
2887
2888 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2889 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2890 location with columns.
2891 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2892 All reported by Paul Eggert.
2893
78ab8f67
AD
28942002-04-22 Akim Demaille <akim@epita.fr>
2895
2896 * src/reduce.c (dump_grammar): Move to...
2897 * src/gram.h, src/gram.c (grammar_dump): here.
2898 Be sure to separate long item numbers.
2899 Don't read the members of a rule's prec if its nil.
2900
133c20e2
AD
29012002-04-22 Akim Demaille <akim@epita.fr>
2902
2903 * src/output.c (table_size, table_grow): New.
2904 (MAXTABLE): Remove, replace uses with table_size.
2905 (pack_vector): Instead of dying when the table is too big, grow it.
2906
9515e8a7
AD
29072002-04-22 Akim Demaille <akim@epita.fr>
2908
2909 * data/bison.simple (yyr1): Its type is that of a token number.
2910 * data/bison.c++ (r1_): Likewise.
2911 * tests/regression.at (Web2c Actions): Adjust.
2912
23c5a174
AD
29132002-04-22 Akim Demaille <akim@epita.fr>
2914
2915 * src/reader.c (token_translations_init): 256 is now the default
2916 value for the error token, i.e., it will be assigned another
2917 number if the user assigned 256 to one of her tokens.
2918 (reader): Don't force 256 to error.
2919 * doc/bison.texinfo (Symbols): Adjust.
2920 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2921 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2922 etc. instead of 10, 20, 30 (which was used to `jump' over error
2923 (256) and undefined (2)).
2924
5fbb0954
AD
29252002-04-22 Akim Demaille <akim@epita.fr>
2926
2927 Propagate more token_number_t.
2928
2929 * src/gram.h (token_number_as_item_number)
2930 (item_number_as_token_number): New.
2931 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2932 Use it to create output_item_number_table and
2933 output_token_number_table.
2934 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2935 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2936 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2937 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2938
4f940944
AD
29392002-04-22 Akim Demaille <akim@epita.fr>
2940
2941 * src/output.h, src/output.c (get_lines_number): Remove.
2942
3ded9a63
AD
29432002-04-19 Akim Demaille <akim@epita.fr>
2944
2945 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2946 as Lex/Flex'.
2947 (Debugging): More details about enabling the debugging features.
2948 (Table of Symbols): Describe $$, $n, @$, and @n.
2949 Suggested by Tim Josling.
2950
e0c471a9
AD
29512002-04-19 Akim Demaille <akim@epita.fr>
2952
2953 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2954
fecc10cd
AD
29552002-04-10 Akim Demaille <akim@epita.fr>
2956
2957 * src/system.h: Rely on HAVE_LIMITS_H.
2958 Suggested by Paul Eggert.
2959
51dec47b
AD
29602002-04-09 Akim Demaille <akim@epita.fr>
2961
2962 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2963 full stderr, and strip it according to the bison options, instead
2964 of composing the error message from different bits.
2965 This makes it easier to check for several error messages.
2966 Adjust all the invocations.
2967 Add an invocation exercising the error token.
2968 Add an invocation demonstrating a stupid error message.
2969 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2970 Adjust the tests.
2971 Error message are for stderr, not stdout.
2972
007a50a4
AD
29732002-04-09 Akim Demaille <akim@epita.fr>
2974
2975 * src/gram.h, src/gram.c (error_token_number): Remove, use
2976 errtoken->number.
2977 * src/reader.c (reader): Don't specify the user token number (2)
2978 for $undefined, as it uselessly prevents using it.
2979 * src/gram.h (token_number_t): Move to...
2980 * src/symtab.h: here.
2981 (state_t.number): Is a token_number_t.
2982 * src/print.c, src/reader.c: Use undeftoken->number instead of
2983 hard coded 2.
2984 (Even though this 2 is not the same as above: the number of the
2985 undeftoken remains being 2, it is its user token number which
2986 might not be 2).
2987 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2988 `user_token_number_max'.
2989 Output `undef_token_number'.
2990 * data/bison.simple, data/bison.c++: Use them.
2991 Be sure to map invalid yylex return values to
2992 `undef_token_number'. This saves us from gratuitous SEGV.
2993
2994 * tests/conflicts.at (Solved SR Conflicts)
2995 (Unresolved SR Conflicts): Adjust.
2996 * tests/regression.at (Web2c Actions): Adjust.
2997
06446ccf
AD
29982002-04-08 Akim Demaille <akim@epita.fr>
2999
3000 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
3001 Adding #line.
3002 Remove the duplicate `typedefs'.
3003 (RhsNumberType): Fix the declaration and various other typos.
3004 Use __ofile__.
3005 * data/bison.simple: Use __ofile__.
3006 * src/scan-skel.l: Handle __ofile__.
3007
62a3e4f0
AD
30082002-04-08 Akim Demaille <akim@epita.fr>
3009
3010 * src/gram.h (item_number_t): New, the type of item numbers in
3011 RITEM. Note that it must be able to code symbol numbers as
3012 positive number, and the negation of rule numbers as negative
3013 numbers.
3014 Adjust all dependencies (pretty many).
3015 * src/reduce.c (rule): Remove this `short *' pointer: use
3016 item_number_t.
3017 * src/system.h (MINSHORT, MAXSHORT): Remove.
3018 Include `limits.h'.
3019 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
3020 (shortcpy): Remove.
3021 (MAXTABLE): Move to...
3022 * src/output.c (MAXTABLE): here.
3023 (prepare_rules): Use output_int_table to output rhs.
3024 * data/bison.simple, data/bison.c++: Adjust.
3025 * tests/torture.at (Big triangle): Move the limit from 254 to
3026 500.
3027 * tests/regression.at (Web2c Actions): Ajust.
3028
3029 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
3030 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3031 passes, but produces negative #line number, once fixed, GCC is
3032 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3033 C), it passes.
3034 * src/state.h (state_h): Code input lines on ints, not shorts.
3035
bb88b0fc
AD
30362002-04-08 Akim Demaille <akim@epita.fr>
3037
3038 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3039 and then the grammar.
3040
9a636f47
AD
30412002-04-08 Akim Demaille <akim@epita.fr>
3042
3043 * src/system.h: No longer using strndup.
3044
680e8701
AD
30452002-04-07 Akim Demaille <akim@epita.fr>
3046
3047 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3048 * src/output.c (output_table_data): Return the longest number.
3049 (prepare_tokens): Output `token_number_max').
3050 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3051 New.
3052 Use them to define yy_token_number_type/TokenNumberType.
3053 Use this type for yytranslate.
3054 * tests/torture.at (Big triangle): Push the limit from 124 to
3055 253.
3056 * tests/regression.at (Web2c Actions): Adjust.
3057
817e9f41
AD
30582002-04-07 Akim Demaille <akim@epita.fr>
3059
3060 * tests/torture.at (Big triangle): New.
3061 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3062 * tests/existing.at: here.
3063
5123689b
AD
30642002-04-07 Akim Demaille <akim@epita.fr>
3065
3066 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3067 nritems.
3068 Adjust dependencies.
3069
f3849179
AD
30702002-04-07 Akim Demaille <akim@epita.fr>
3071
3072 * src/reader.c: Normalize increments to prefix form.
3073
bd02036a
AD
30742002-04-07 Akim Demaille <akim@epita.fr>
3075
3076 * src/reader.c, symtab.c: Remove debugging code.
3077
db8837cb
AD
30782002-04-07 Akim Demaille <akim@epita.fr>
3079
3080 Rename all the `bucket's as `symbol_t'.
3081
3082 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3083 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3084 * src/symtab.c, src/symtab.h (bucket): Rename as...
3085 (symbol_t): this.
3086 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3087 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3088 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3089 (buckets_new, buckets_free, buckets_do): Rename as...
3090 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3091 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3092 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3093 (symbols_new, symbols_free, symbols_do): these.
3094
72a23c97
AD
30952002-04-07 Akim Demaille <akim@epita.fr>
3096
3097 Use lib/hash for the symbol table.
3098
3099 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3100 EOF.
3101 * src/lex.c (lex): Set the `number' member of new terminals.
3102 * src/reader.c (bucket_check_defined, bucket_make_alias)
3103 (bucket_check_alias_consistence, bucket_translation): New.
3104 (reader, grammar_free, readgram, token_translations_init)
3105 (packsymbols): Adjust.
3106 (reader): Number the predefined tokens.
3107 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3108 for predefined tokens.
3109 * src/symtab.h (bucket): Remove all the hash table related
3110 members.
3111 * src/symtab.c (symtab): Replace by...
3112 (bucket_table): this.
3113 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3114 (buckets_new, buckets_do): New.
3115
280a38c3
AD
31162002-04-07 Akim Demaille <akim@epita.fr>
3117
3118 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3119 (start_symbol, max_user_token_number, semantic_parser)
3120 (error_token_number): Initialize.
3121 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3122 Initialize.
3123 (reader): Don't.
3124 (errtoken, eoftoken, undeftoken, axiom): Extern.
3125
03b31c0c
AD
31262002-04-07 Akim Demaille <akim@epita.fr>
3127
3128 * src/gram.h (rule_s): prec and precsym are now pointers
3129 to the bucket giving the priority/associativity.
3130 Member `associativity' removed: useless.
3131 * src/reduce.c, src/conflicts.c: Adjust.
3132
8b3df748
AD
31332002-04-07 Akim Demaille <akim@epita.fr>
3134
3135 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3136 Properly escape the symbols' TAG when outputting them.
3137
e601aa1d
AD
31382002-04-07 Akim Demaille <akim@epita.fr>
3139
3140 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3141
b0299a2e
AD
31422002-04-07 Akim Demaille <akim@epita.fr>
3143
3144 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3145 (LArule): this, which is an array to rule_t*.
3146 * src/print.c, src/conflicts.c: Adjust.
3147
d7e1f00c
AD
31482002-04-07 Akim Demaille <akim@epita.fr>
3149
3150 * src/gram.h (rule_t): Rename `number' as `user_number'.
3151 `number' is a new member.
3152 Adjust dependencies.
3153 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3154
cc9305dd
AD
31552002-04-07 Akim Demaille <akim@epita.fr>
3156
3157 As a result of the previous patch, it is no longer needed
3158 to reorder ritem itself.
3159
3160 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3161
b0940840
AD
31622002-04-07 Akim Demaille <akim@epita.fr>
3163
3164 Be sure never to walk through RITEMS, but use only data related to
3165 the rules themselves. RITEMS should be banished.
3166
3167 * src/output.c (output_token_translations): Rename as...
3168 (prepare_tokens): this.
3169 In addition to `translate', prepare the muscles `tname' and
3170 `toknum', which were handled by...
3171 (output_rule_data): this.
3172 Remove, and move the remainder of its outputs into...
3173 (prepare_rules): this new routines, which also merges content from
3174 (output_gram): this.
3175 (prepare_rules): Be sure never to walk through RITEMS.
3176 (output_stos): Rename as...
3177 (prepare_stos): this.
3178 (output): Always invoke prepare_states, after all, just don't use it
3179 in the output if you don't need it.
3180
643a5994
AD
31812002-04-07 Akim Demaille <akim@epita.fr>
3182
3183 * src/LR0.c (new_state): Display `nstates' as the name of the
3184 newly created state.
3185 Adjust to initialize first_state and last_state if needed.
3186 Be sure to distinguish the initial from the final state.
3187 (new_states): Create the itemset of the initial state, and use
3188 new_state.
3189 * src/closure.c (closure): Now that the initial state has its
3190 items properly set, there is no need for a special case when
3191 creating `ruleset'.
3192
3193 As a result, now the rule 0, reducing to $axiom, is visible in the
3194 outputs. Adjust the test suite.
3195
3196 * tests/conflicts.at (Solved SR Conflicts)
3197 (Unresolved SR Conflicts): Adjust.
3198 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3199 * tests/conflicts.at (S/R in initial): New.
3200
b4c4ccc2
AD
32012002-04-07 Akim Demaille <akim@epita.fr>
3202
3203 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3204 the RHS of the rules.
3205 * src/output.c (output_gram): Likewise.
3206
bba97eb2
AD
32072002-04-07 Akim Demaille <akim@epita.fr>
3208
3209 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3210 bucket.
3211 Adjust all dependencies.
3212 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3213 `number' of the buckets too.
3214 * src/gram.h: Include `symtab.h'.
3215 (associativity): Move to...
3216 * src/symtab.h: here.
3217 No longer include `gram.h'.
3218
c3b407f4
AD
32192002-04-07 Akim Demaille <akim@epita.fr>
3220
3221 * src/gram.h, src/gram.c (rules_rhs_length): New.
3222 (ritem_longest_rhs): Use it.
3223 * src/gram.h (rule_t): `number' is a new member.
3224 * src/reader.c (packgram): Set it.
3225 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3226 the end of `rules', and count them out of `nrules'.
3227 (reduce_output, dump_grammar): Adjust.
3228 * src/print.c (print_grammar): It is no longer needed to check for
3229 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3230 * tests/reduce.at (Reduced Automaton): New test.
3231
11652ab3
AD
32322002-04-07 Akim Demaille <akim@epita.fr>
3233
3234 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3235 lacking `+ 1' to nrules, Bison reported as useless a token if it
3236 was used solely to set the precedence of the last rule...
3237
26b23c1a
AD
32382002-04-07 Akim Demaille <akim@epita.fr>
3239
3240 * data/bison.c++, data/bison.simple: Don't output the current file
3241 name in #line, to avoid useless diffs between two identical
3242 outputs under different names.
3243
18bcecb0
AD
32442002-04-07 Akim Demaille <akim@epita.fr>
3245
3246 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3247 Normalize loops to using `< nrules + 1', not `<= nrules'.
3248
fa770c86
AD
32492002-04-07 Akim Demaille <akim@epita.fr>
3250
3251 * TODO: Update.
3252
d9b739c3
AD
32532002-04-07 Akim Demaille <akim@epita.fr>
3254
3255 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3256 bucket.value as bucket.number.
3257
99013900
AD
32582002-04-07 Akim Demaille <akim@epita.fr>
3259
3260 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3261 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3262 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3263 RHS, instead of being an index in RITEMS.
3264
e966383b
PE
32652002-04-04 Paul Eggert <eggert@twinsun.com>
3266
3267 * doc/bison.texinfo: Update copyright date.
3268 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3269 (Symbols): Warn about running Bison in one character set,
3270 but compiling and/or running in an incompatible one.
3271 Warn about character code 256, too.
3272
32732002-04-03 Paul Eggert <eggert@twinsun.com>
3274
3275 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3276 YYERROR_VERBOSE is nonzero, not whether it is defined.
3277
3278 Merge changes from bison-1_29-branch.
c307773e 3279
8d6c48b9
PE
32802002-03-20 Paul Eggert <eggert@twinsun.com>
3281
3282 Merge fixes from Debian bison_1.34-1.diff.
3283
3284 * configure.in (AC_PREREQ): 2.53.
3285
e53c6322
AD
32862002-03-20 Akim Demaille <akim@epita.fr>
3287
3288 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3289
9ffbeca7
PE
32902002-03-19 Paul Eggert <eggert@twinsun.com>
3291
21db0b2a
PE
3292 * src/bison.simple (YYCOPY): New macro.
3293 (YYSTACK_RELOCATE): Use it.
3294 Remove Type arg; no longer needed. All callers changed.
3295 (yymemcpy): Remove; no longer needed.
3296
9ffbeca7
PE
3297 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3298 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3299
642cb8f8
AD
33002002-03-19 Akim Demaille <akim@epita.fr>
3301
3302 Test and fix the #line outputs.
3303
3304 * tests/atlocal.at (GCC): New.
3305 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3306 (Prologue synch line, ,%union synch line, Postprologue synch line)
3307 (Action synch line, Epilogue synch line): New tests.
3308 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3309 * data/bison.simple, data/bison.c++: Use it.
3310
3c31a486
AD
33112002-03-19 Akim Demaille <akim@epita.fr>
3312
3313 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3314 (Solved SR Conflicts, %expect not enough, %expect right)
3315 (%expect too much): Move to...
3316 * tests/conflicts.at: this new file.
3317
0d8bed56
AD
33182002-03-19 Akim Demaille <akim@epita.fr>
3319
3320 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3321 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3322 that we can move to enums for instance.
3323 * src/output.c (token_definitions_output): Output a list of
3324 `token-name, token-number' instead of the #define.
3325 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3326
9208d17f
AD
33272002-03-14 Akim Demaille <akim@epita.fr>
3328
3329 Use Gettext 0.11.1.
3330
af27eacb
RA
33312002-03-09 Robert Anisko <robert@lrde.epita.fr>
3332
3333 * data/bison.c++: Make the user able to add members to the generated
3334 parser by subclassing.
3335
9101a310
RA
33362002-03-05 Robert Anisko <robert@lrde.epita.fr>
3337
3338 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3339 a character.
3340 Reported by Nicolas Tisserand and Nicolas Burrus.
3341
fff9bf0b
RA
33422002-03-04 Robert Anisko <robert@lrde.epita.fr>
3343
3344 * src/reader.c: Warn about lacking semi-colons, do not complain.
3345
64dba31e
RA
33462002-03-04 Robert Anisko <robert@lrde.epita.fr>
3347
3348 * data/bison.c++: Remove a debug line.
3349
374f5a14
RA
33502002-03-04 Robert Anisko <robert@lrde.epita.fr>
3351
3352 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
3353 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
3354 provide a default implementation.
3355
bfcf1f3a
AD
33562002-03-04 Akim Demaille <akim@epita.fr>
3357
3358 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
3359 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
3360 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
3361 * tests/semantic.at (Parsing Guards): Similarly.
3362 * src/reader.at (readgram): Complain if the last rule is not ended
3363 with a semi-colon.
3364
65ccf9fc
AD
33652002-03-04 Akim Demaille <akim@epita.fr>
3366
3367 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
3368 * src/closure.c: here.
3369 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
3370 RTC.
3371 * src/warshall.h, src/warshall.c: Remove.
3372 * tests/sets.at (Broken Closure): Adjust.
3373
d0039cbc
AD
33742002-03-04 Akim Demaille <akim@epita.fr>
3375
3376 * src/output.c (output_skeleton): tempdir is const.
3377 bytes_read is unused.
3378
345cea78
AD
33792002-03-04 Akim Demaille <akim@epita.fr>
3380
3381 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3382 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
3383 Update.
3384 From Michael Hayes.
3385
564801f7
AD
33862002-03-04 Akim Demaille <akim@epita.fr>
3387
3388 * src/closure.c (closure): `r' is unused.
3389
e5352bc7
AD
33902002-03-04 Akim Demaille <akim@epita.fr>
3391
3392 * tests/sets.at (Broken Closure): Add the ending `;'.
3393 * src/reader.at (readgram): Complain if a rule is not ended with a
3394 semi-colon.
3395
914feea9
AD
33962002-03-04 Akim Demaille <akim@epita.fr>
3397
3398 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
3399 (count_sr_conflicts): Use bitset_count.
3400 * src/reduce.c (inaccessable_symbols): Ditto.
3401 (bits_size): Remove.
3402 * src/warshall.h, src/warshall.c: Convert to bitsetv.
3403
f0250de6
AD
34042002-03-04 Akim Demaille <akim@epita.fr>
3405
3406 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
3407 * src/reduce.c: Remove the `bitset_zero's following the
3408 `bitset_create's, as now it is performed by the latter.
3409
ef017502
AD
34102002-03-04 Akim Demaille <akim@epita.fr>
3411
3412 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
3413 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
3414 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
3415 latest sources from Michael.
3416
76514394
AD
34172002-03-04 Akim Demaille <akim@epita.fr>
3418
3419 * src/output.c (output): Don't free the grammar.
3420 * src/reader.c (grammar_free): New.
3421 * src/main.c (main): Call it and don't free symtab here.
3422
55024580
AD
34232002-03-04 Akim Demaille <akim@epita.fr>
3424
3425 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
3426 before returning.
3427 Reported by Benoit Perrot.
3428
f9abaa2c
AD
34292002-03-04 Akim Demaille <akim@epita.fr>
3430
3431 Use bitset operations when possible, not loops over bits.
3432
3433 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
3434 bitset_or.
3435 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
3436 * src/reduce.c (useless_nonterminals): Formatting changes.
3437 * src/warshall.c (TC): Use bitset_or.
3438
0e721e75
AD
34392002-03-04 Akim Demaille <akim@epita.fr>
3440
3441 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
3442 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
3443 Ditto.
3444
0fb1ffb1
AD
34452002-03-04 Akim Demaille <akim@epita.fr>
3446
3447 * src/lalr.c (F): Now a bitset*.
3448 Adjust all dependencies.
3449
b86796bf
AD
34502002-03-04 Akim Demaille <akim@epita.fr>
3451
3452 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
3453 Adjust all dependencies.
3454
602bbf31
AD
34552002-03-04 Akim Demaille <akim@epita.fr>
3456
3457 * src/L0.c, src/LR0.h (nstates): Be size_t.
3458 Adjust comparisons (signed vs unsigned).
3459 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
3460 bitset*.
3461 Adjust all dependencies.
3462
d8a0245c
AD
34632002-03-04 Akim Demaille <akim@epita.fr>
3464
3465 * src/closure.c (firsts): Now, also a bitset.
3466 Adjust all dependencies.
3467 (varsetsize): Remove, now unused.
3468 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
3469
34ba9743
AD
34702002-03-04 Akim Demaille <akim@epita.fr>
3471
3472 * src/print.c: Convert to use bitset.h, not hand coded iterations
3473 over ints.
3474
ed86e78c
AD
34752002-03-04 Akim Demaille <akim@epita.fr>
3476
3477 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
3478
dfdb1797
AD
34792002-03-04 Akim Demaille <akim@epita.fr>
3480
3481 * src/closure.c (ruleset): Be a bitset.
3482 (rulesetsize): Remove.
3483
7086e707
AD
34842002-03-04 Akim Demaille <akim@epita.fr>
3485
3486 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3487 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
3488 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
3489 * src/closure.c (fderives): Be an array of bitsets.
3490
98254360
RA
34912002-02-28 Robert Anisko <robert@lrde.epita.fr>
3492
3493 * data/bison.c++: Merge the two generated headers. Insert a copyright
3494 notice in each output file.
3495
a75c057f
AD
34962002-02-28 Akim Demaille <akim@epita.fr>
3497
3498 * data/bison.c++: Copy the prologue of bison.simple to fetch
3499 useful M4 definitions, such as b4_header_guard.
3500
06b00abc
AD
35012002-02-25 Akim Demaille <akim@epita.fr>
3502
3503 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
3504 translator friendly scheme for the bgr
3505 copyright notice.
06b00abc 3506
70e7d534
AD
35072002-02-25 Akim Demaille <akim@epita.fr>
3508
3509 * src/output.c (header_output): Remove, now handled completely via
3510 M4.
3511
abe017f6
AD
35122002-02-25 Akim Demaille <akim@epita.fr>
3513
3514 * m4/m4.m4: New, from CVS Autoconf.
3515 * configure.in: Invoke it.
3516 * src/output.c (output_skeleton): Use its result instead of the
3517 hard coded name.
3518
381fb12e
AD
35192002-02-25 Akim Demaille <akim@epita.fr>
3520
3521 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3522 Fileutils 4.1.5.
3523 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3524 * src/output.c (output_skeleton): Use mkstemp to create a real
3525 temporary file.
3526 Move the filling of `skeleton' and its muscle to...
3527 (prepare): here.
3528 (output): Move the definition of the prologue muscle to...
3529 (prepare): here.
3530 * src/system.h (DEFAULT_TMPDIR): New.
3531
6f38107f
PE
35322002-02-14 Paul Eggert <eggert@twinsun.com>
3533
3534 Remove the support for C++ namespace cleanliness; it was
3535 causing more problems than it was curing, since it didn't work
3536 properly on some nonstandard C++ compilers. This can wait
3537 for a proper C++ parser.
3538
3539 * NEWS: Document this.
3540 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3541 of C++, as it's treated like C now.
3542 * src/bison.simple (YYSTD): Remove.
3543 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3544 Treat C++ just like Standard C instead of trying to support
3545 namespace cleanliness.
3546
80cce3da
AD
35472002-02-14 Akim Demaille <akim@epita.fr>
3548
3549 * tests/regression.at (else): Adjust to Andreas' change.
3550
842e8679
AD
35512002-02-14 Akim Demaille <akim@epita.fr>
3552
3553 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3554
4bda3f10
AD
35552002-02-13 Andreas Schwab <schwab@suse.de>
3556
3557 * src/output.c (output_rule_data): Don't output NULL, it might
3558 not be defined yet.
3559
4162fa07 35602002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 3561
4162fa07
RA
3562 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3563 (Copyright notice): Update.
b418ecd8 3564
bd16a5dc
AD
35652002-02-11 Akim Demaille <akim@epita.fr>
3566
3567 * tests/regression.at (%nonassoc and eof): Don't include
3568 nonportable headers.
3569
8d69a1a3
RA
35702002-02-08 Robert Anisko <robert@lrde.epita.fr>
3571
3572 * data/bison.c++: Correct error recovery. Make the user able to
3573 initialize the starting location.
3574
9b2d0677
AD
35752002-02-07 Akim Demaille <akim@epita.fr>
3576
3577 * tests/input.at: New.
3578
69e2658b
RA
35792002-02-07 Robert Anisko <robert@lrde.epita.fr>
3580
3581 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 3582 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
3583 directives around tables only needed for debugging.
3584
4aacc3a7
RA
35852002-02-07 Robert Anisko <robert@lrde.epita.fr>
3586
3587 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3588 C++ parsers.
3589 (yy::b4_name::parse): Use print_.
3590
762a801e
RA
35912002-02-07 Robert Anisko <robert@lrde.epita.fr>
3592
3593 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3594
4bb2bc3f
RA
35952002-02-07 Robert Anisko <robert@lrde.epita.fr>
3596
3597 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3598 C++ parsers.
3599 (yy::b4_name::parse): Build verbose error messages, and use error_.
3600
6b45a3ca
RA
36012002-02-06 Robert Anisko <robert@lrde.epita.fr>
3602
3603 * data/bison.c++: Fix m4 quoting in comments.
3604
50997c6e
RA
36052002-02-06 Robert Anisko <robert@lrde.epita.fr>
3606
3607 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3608 not expanded by m4.
3609
3f3eed27
AD
36102002-02-05 Akim Demaille <akim@epita.fr>
3611
3612 * data/bison.c++: Adjust to the M4 back end.
3613 More is certainly needed.
3614
be2a1a68
AD
36152002-02-05 Akim Demaille <akim@epita.fr>
3616
3617 Give a try to M4 as a back end.
3618
3619 * lib/readpipe.c: New, from wdiff.
3620 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3621 BISON_HAIRY.
3622 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3623 specific values. Now it is m4 that performs the lookup.
3624 * src/parse-skel.y: Remove.
3625 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3626 * src/output.c (actions_output, guards_output)
3627 (token_definitions_output): No longer keeps track of the output
3628 line number, hence remove the second argument.
3629 (guards_output): Check against the guard member of a rule, not the
3630 action member.
3631 Adjust callers.
3632 (output_skeleton): Don't look for the skeleton location, let m4 do
3633 that.
3634 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3635 file will be used.
3636 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3637 (prepare): Given that for the time being changesyntax is not
3638 usable in M4, rename the muscles using `-' to `_'.
3639 Define `defines_flag', `output_parser_name' and `output_header_name'.
3640 * src/output.h (actions_output, guards_output)
3641 (token_definitions_output): Adjust prototypes.
3642 * src/scan-skel.l: Instead of scanning the skeletons, it now
3643 processes the output of m4: `__oline__' and `#output'.
3644 * data/bison.simple: Adjust to be used by M4(sugar).
3645 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3646 to date.
3647 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3648 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3649 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3650 shamelessly stolen from CVS Autoconf.
3651
beda758b
AD
36522002-02-05 Akim Demaille <akim@epita.fr>
3653
3654 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3655 * configure.in: Check for the declarations of free and malloc.
3656 * src/muscle_tab.c: Adjust.
3657
5ece6d43
AD
36582002-02-05 Akim Demaille <akim@epita.fr>
3659
3660 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3661 which have no values.
3662
5bb18f9a
AD
36632002-02-05 Akim Demaille <akim@epita.fr>
3664
3665 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3666 * data/: here.
3667
894dd62e
PE
36682002-01-29 Paul Eggert <eggert@twinsun.com>
3669
3670 * src/bison.simple (YYSIZE_T): Do not define merely because
3671 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3672 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3673
82841af7
AD
36742002-01-27 Akim Demaille <akim@epita.fr>
3675
3676 Fix `%nonassoc and eof'.
3677
3678 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3679 which were not properly copied! Replace
3680 memcpy (res->errs, src->errs, src->nerrs);
3681 with
3682 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3683 !!!
3684 * tests/regression.at (%nonassoc and eof): Adjust to newest
3685 Autotest: `.' is not in the PATH.
3686
318b76e9
AD
36872002-01-27 Akim Demaille <akim@epita.fr>
3688
3689 * tests/sets.at (AT_EXTRACT_SETS): New.
3690 (Nullable): Use it.
3691 (Firsts): New.
3692
30d2f3d5
AD
36932002-01-26 Akim Demaille <akim@epita.fr>
3694
3695 * tests/actions.at, tests/calc.at, tests/headers.at,
3696 * tests/torture.at: Adjust to the newest Autotest which no longer
3697 forces `.' in the PATH.
3698
30f8c395
AD
36992002-01-25 Akim Demaille <akim@epita.fr>
3700
3701 * tests/regression.at (%nonassoc and eof): New.
3702 Suggested by Robert Anisko.
3703
29ae55f1
AD
37042002-01-24 Akim Demaille <akim@epita.fr>
3705
3706 Bison dumps core when trying to complain about broken input files.
3707 Reported by Cris van Pelt.
3708
3709 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3710 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3711 into...
3712 (Invalid inputs): Strengthen: exercise parse_percent_token.
3713
2b548aa6
RA
37142002-01-24 Robert Anisko <robert.anisko@epita.fr>
3715
3716 * src/Makefile.am: Add bison.c++.
3717 * src/bison.c++: New skeleton.
3718
bb0146c2
AD
37192002-01-21 Paolo Bonzini <bonzini@gnu.org>
3720
3721 * po/it.po: New.
3722
bec30531
AD
37232002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3724
3725 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3726
fc6edc45
MA
37272002-01-20 Marc Autret <marc@gnu.org>
3728
3729 * src/files.c (compute_output_file_names): Fix
3730
5e5d5415
MA
37312002-01-20 Marc Autret <marc@gnu.org>
3732
3733 * tests/output.at: New test.
3734 * src/files.c (compute_base_names): Don't map extensions when
3735 the YACC flag is set, use defaults.
3736 Reported by Evgeny Stambulchik.
3737
44ea3fbd
MA
37382002-01-20 Marc Autret <marc@gnu.org>
3739
bb0146c2 3740 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
3741 compilers as well (i.e. the vendor C compiler).
3742 Suggested by Albert Chin-A-Young.
3743
338963d1
TVH
37442002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3745
3746 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3747 canonical definition.
3748 * src/system.h: Use the canonical definition for PARAMS (avoids
3749 a conflict with the macro from lib/hash.h).
3750
c57b2479
AD
37512002-01-11 Akim Demaille <akim@epita.fr>
3752
3753 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 3754 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 3755
b85810ae
AD
37562002-01-09 Akim Demaille <akim@epita.fr>
3757
3758 * src/files.c, src/files.h (output_infix): New.
3759 (tab_extension): Remove.
3760 (compute_base_names): Compute the former, drop the latter.
3761 * src/output.c (prepare): Insert the muscles `output-infix', and
3762 `output-suffix'.
3763 * src/parse-skel.y (string, string.1): New.
3764 (section.header): Use it.
3765 (section.yacc): Remove.
3766 (prefix): Remove too.
3767 * src/scan-skel.l: Adjust.
3768 * src/bison.simple, src/bison.hairy: Adjust.
3769
cae60122
AD
37702002-01-09 Akim Demaille <akim@epita.fr>
3771
3772 * configure.in (WERROR_CFLAGS): Compute it.
3773 * src/Makefile.am (CFLAGS): Pass it.
3774 * tests/atlocal.in (CFLAGS): Idem.
3775 * src/files.c: Fix a few warnings.
3776 (get_extension_index): Remove, unused.
3777
ae404801
AD
37782002-01-08 Akim Demaille <akim@epita.fr>
3779
3780 * src/getargs.c (AS_FILE_NAME): New.
3781 (getargs): Use it to convert DOSish file names.
3782 * src/files.c (base_name): Rename as full_base_name to avoid
3783 clashes with `base_name ()'.
3784 (filename_split): New.
3785 (compute_base_names): N-th rewrite, using filename_split.
3786
22312b71
AD
37872002-01-08 Akim Demaille <akim@epita.fr>
3788
3789 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3790 New, stolen from the Fileutils 4.1.
3791 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3792 * configure.in: Check for the presence of memrchr, and of its
3793 prototype.
3794
a67cef01
TVH
37952002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3796
3797 * lib/hash.h (__P): Added definition for this macro.
3798 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3799 BUILT_SOURCES, to ensure they are generated first.
3800 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3801 %error-verbose to allow bootstrapping with bison 1.30x.
3802
2b25d624
AD
38032002-01-06 Akim Demaille <akim@epita.fr>
3804
3805 * src/reader.c (parse_braces): Don't fetch the next char, the
3806 convention is to fetch on entry.
3807 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3808 'switch' without a following semicolon.
3809 * tests/regression.at (braces parsing): New.
3810
3460813b
AD
38112002-01-06 Akim Demaille <akim@epita.fr>
3812
3813 Bison is dead wrong in its RR conflict reports.
3814
3815 * tests/torture.at (GNU Cim Grammar): New.
3816 * src/conflicts.c (count_rr_conflicts): Fix.
3817
73784c64
AD
38182002-01-06 Akim Demaille <akim@epita.fr>
3819
3820 Creating package.m4 from configure.ac causes too many problems.
3821
3822 * tests/Makefile.am (package.m4): Create it by hand,
3823 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3824
25d81090
AD
38252002-01-06 Akim Demaille <akim@epita.fr>
3826
3827 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3828 skeleton.h.
3829
a9b8959e
PE
38302002-01-04 Paul Eggert <eggert@twinsun.com>
3831
3832 * doc/bison.texinfo (Debugging):
3833 Remove YYSTDERR; it's no longer defined or used.
3834 Also, s/cstdio.h/cstdio/.
3835
25d81090
AD
38362002-01-03 Akim Demaille <akim@epita.fr>
3837
3838 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3839
1109455c
AD
38402002-01-03 Akim Demaille <akim@epita.fr>
3841
3842 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3843 tracing code to --trace, wait for a better --trace option, with
3844 args.
3845
7ea5e977
AD
38462002-01-03 Akim Demaille <akim@epita.fr>
3847
3848 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3849 The ISO C++ standard is extremely clear about it: stderr is
3850 considered a macro, not a regular symbol (see table 94 `Header
3851 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3852 Therefore std:: does not apply to it. It still does with fprintf.
3853 Also, s/cstdio.h/cstdio/.
3854
fab5b110
AD
38552002-01-03 Akim Demaille <akim@epita.fr>
3856
3857 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3858 for non system headers.
3859
aed7fd9b
AD
38602002-01-02 Akim Demaille <akim@epita.fr>
3861
3862 Equip the skeleton chain with location tracking, runtime trace,
3863 pure parser and scanner.
3864
3865 * src/parse-skel.y: Request a pure parser, locations, and prefix
3866 renaming.
3867 (%union): Having several members with the same type does not help
3868 type mismatches, simplify.
3869 (YYPRINT, yyprint): New.
3870 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3871 (skel_error): this.
3872 Handle locations.
3873 * src/scan-skel.l: Adjust to these changes.
3874 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3875 (LOCATION_PRINT, skel_control_t): New.
3876
24fad99e
AD
38772001-12-30 Akim Demaille <akim@epita.fr>
3878
3879 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3880 replace `gb' with BLANKS.
3881 * src/scan-skel.l: Adjust.
3882
a4b36db4
AD
38832001-12-30 Akim Demaille <akim@epita.fr>
3884
3885 * src/system.h: We don't need nor want bcopy.
3886 Throw away MS-DOS crap: we don't need getpid.
3887 * configure.in: We don't need strndup. It was even causing
3888 problems: because Flex includes the headers *before* us,
3889 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3890 not visible.
3891 * lib/xstrndup.c: New.
3892 * src/scan-skel.l: Use it.
3893 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3894 * src/parse-skel.y: Use %directives instead of #defines.
3895
1239777d
AD
38962001-12-30 Akim Demaille <akim@epita.fr>
3897
3898 * src/skeleton.h: New.
3899 * src/output.c (output_parser, output_master_parser): Remove, dead
3900 code.
3901 * src/output.h (get_lines_number, actions_output, guards_output)
3902 (token_definitions_output): Prototype them.
3903 * src/parse-skel.y: Add the license notice.
3904 Include output.h and skeleton.h.
3905 (process_skeleton): Returns void, and takes a single parameter.
3906 * src/scan-skel.l: Add the license notice.
3907 Include skeleton.h.
3908 Don't use %option yylineno: it seems that then Flex imagines
3909 REJECT has been used, and therefore it won't reallocate its
3910 buffers (which makes no other sense to me than a bug). It results
3911 in warnings for `unused: yy_flex_realloc'.
3912
9b3add5b
RA
39132001-12-30 Robert Anisko <robert.anisko@epita.fr>
3914
3915 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3916 (MUSCLE_INSERT_PREFIX): ...to there.
3917 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3918 (MUSCLE_INSERT_PREFIX): Move from here...
3919
3920 * src/bison.hairy: Add a section directive. Put braces around muscle
3921 names. This parser skeleton is still broken, but Bison should not
3922 choke on a bad muscle 'syntax'.
3923 * src/bison.simple: Add a section directive. Put braces around muscle
3924 names.
3925
3926 * src/files.h (strsuffix, stringappend): Add declarations.
3927 (tab_extension): Add declaration.
3928 (short_base_name): Add declaration.
3929
3930 * src/files.c (strsuffix, stringappend): No longer static. These
3931 functions are used in the skeleton parser.
3932 (tab_extension): New.
3933 (compute_base_names): Use the computations done in this function
fab5b110 3934 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
3935 names.
3936 (short_base_name): No longer static.
3937
3938 * src/output.c (output_skeleton): New.
3939 (output): Disable call to output_master_parser, and give a try to
3940 a new skeleton handling system.
3941 (guards_output, actions_output): No longer static.
3942 (token_definitions_output, get_lines_number): No longer static.
3943
3944 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3945
fab5b110 3946 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
3947 parse-skel.y.
3948
3949 * src/parse-skel.y: New file.
3950 * src/scan-skel.l: New file.
3951
b5b61c61
AD
39522001-12-29 Akim Demaille <akim@epita.fr>
3953
3954 %name-prefix is broken.
3955
3956 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3957 Adjust all dependencies.
3958 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3959 %name-prefix.
3960
3961 Renaming yylval but not yylloc is not consistent. Now we do.
3962
3963 * src/bison.simple: Prefix yylloc if used.
3964 * doc/bison.texinfo (Decl Summary): Document that.
3965
8c9a50be
AD
39662001-12-29 Akim Demaille <akim@epita.fr>
3967
3968 * doc/bison.texinfo: Promote `%long-directive' over
3969 `%long_directive'.
3970 Remove all references to fixed-output-files, yacc is enough.
3971
d99361e6
AD
39722001-12-29 Akim Demaille <akim@epita.fr>
3973
3974 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3975 user prologue. These are defaults.
3976 * tests/actions.at (Mid-rule actions): Make sure the user can
3977 define YYDEBUG and YYERROR_VERBOSE.
3978
b9cecb91
AD
39792001-12-29 Akim Demaille <akim@epita.fr>
3980
3981 * src/output.c (header_output): Don't forget to export YYLTYPE and
3982 yylloc.
3983 * tests/headers.at (export YYLTYPE): New, make sure it does.
3984 * tests/regression.at (%union and --defines, Invalid CPP headers):
3985 Move to...
3986 * tests/headers.at: here.
3987
aea13e97
AD
39882001-12-29 Akim Demaille <akim@epita.fr>
3989
3990 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3991
931394cb
AD
39922001-12-29 Akim Demaille <akim@epita.fr>
3993
3994 * tests/actions.at (Mid-rule actions): Output on a single line
3995 instead of several.
3996
704a47c4
AD
39972001-12-29 Akim Demaille <akim@epita.fr>
3998
3999 * doc/bison.texinfo: Formatting changes.
4000
091e20bb
AD
40012001-12-29 Akim Demaille <akim@epita.fr>
4002
4003 Don't store the token defs in a muscle, just be ready to output it
4004 on command. Now possible via `symbols'. Fixes a memory leak.
4005
4006 * src/output.c (token_definitions_output): New.
4007 (output_parser, header_output): Use it.
4008 * src/reader.c (symbols_save): Remove.
4009
cce71710
AD
40102001-12-29 Akim Demaille <akim@epita.fr>
4011
4012 * src/bison.simple: Do not provide a default for YYSTYPE and
4013 YYLTYPE before the user's prologue. Otherwise it's hardly... a
4014 default.
4015
82c035a8
AD
40162001-12-29 Akim Demaille <akim@epita.fr>
4017
4018 Mid-rule actions are simply... ignored!
4019
4020 * src/reader.c (readgram): Be sure to attach mid-rule actions to
4021 the empty-rule associated to the dummy symbol, not to the host
4022 rule.
4023 * tests/actions.at (Mid-rule actions): New.
4024
8419d367
AD
40252001-12-29 Akim Demaille <akim@epita.fr>
4026
4027 Memory leak.
4028
4029 * src/reader.c (reader): Free grammar.
4030
375d5806
AD
40312001-12-29 Akim Demaille <akim@epita.fr>
4032
4033 Memory leak.
4034
4035 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4036 since it allocates it for each state, although only one is needed.
4037 (allocate_storage): Do it here.
4038
f51cb8ff
AD
40392001-12-29 Akim Demaille <akim@epita.fr>
4040
4041 * src/options.h, src/options.c (create_long_option_table): Rename
4042 as...
4043 (long_option_table_new): this, with a clearer prototype.
4044 (percent_table): Remove, unused,
4045 * src/getargs.c (getargs): Adjust.
4046
29e88316
AD
40472001-12-29 Akim Demaille <akim@epita.fr>
4048
4049 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4050 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4051 as states.
4052
b9f71f19
AD
40532001-12-29 Akim Demaille <akim@epita.fr>
4054
4055 * src/lalr.c (build_relations): Rename `states' as `states1'.
4056 Sorry, I don't understand exactly what it is, no better name...
4057
1a2b5d37
AD
40582001-12-29 Akim Demaille <akim@epita.fr>
4059
4060 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4061 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4062 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4063 as rules.
4064
1cca533e
AD
40652001-12-29 Akim Demaille <akim@epita.fr>
4066
4067 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4068 ago.
4069
c03ae966
AD
40702001-12-29 Akim Demaille <akim@epita.fr>
4071
4072 * src/reader.c, src/reader.h (user_toknums): Remove.
4073 Adjust all users to use symbols[i]->user_token_number.
4074
5a670b1e
AD
40752001-12-29 Akim Demaille <akim@epita.fr>
4076
4077 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4078 Adjust all users to use symbols[i]->prec or ->assoc.
4079
ad949da9
AD
40802001-12-29 Akim Demaille <akim@epita.fr>
4081
4082 * src/reader.c, src/reader.h (tags): Remove.
4083 Adjust all users to use symbols[i]->tag.
4084
0e78e603
AD
40852001-12-29 Akim Demaille <akim@epita.fr>
4086
4087 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4088 and rule_table.
4089 * src/reader.c (packsymbols): Fill this table.
4090 Drop sprec.
4091 * src/conflicts.c (resolve_sr_conflict): Adjust.
4092 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4093 single table.
4094 Use symbols[i]->tag instead of tags[i].
4095
213e640e
AD
40962001-12-29 Akim Demaille <akim@epita.fr>
4097
4098 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4099 In addition, put a comment in there, to replace...
4100 * tests/regression.at (%union and C comments): Remove.
4101
e7b8bef1
AD
41022001-12-29 Akim Demaille <akim@epita.fr>
4103
4104 * tests/regression.at (Web2c Actions): Blindly move the actual
4105 output as expected output. The contents *seem* right to me, but I
4106 can't pretend reading perfectly parser tables... Nonetheless, all
4107 the other tests pass correctly, the table look OK, even though the
4108 presence of `$axiom' is to be noted: AFAICS it is useless (but
4109 harmless).
4110
b68e7744
AD
41112001-12-29 Akim Demaille <akim@epita.fr>
4112
4113 * src/reader.c (readgram): Don't add the rule 0 if there were no
4114 rules read. In other words, add it _after_ having performed
4115 grammar sanity checks.
4116 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4117
78d5bae9
AD
41182001-12-29 Akim Demaille <akim@epita.fr>
4119
4120 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4121 visible, and some states have now a different number.
4122
ff442794
AD
41232001-12-29 Akim Demaille <akim@epita.fr>
4124
4125 * src/reader.c (readgram): Bind the initial rule's lineno to that
4126 of the first rule.
4127 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4128 (Solved SR Conflicts): Adjust rule 0's line number.
4129
610ab194
AD
41302001-12-29 Akim Demaille <akim@epita.fr>
4131
4132 Fix the `GAWK Grammar' failure.
4133
4134 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4135 the reductions of the first state which was mistakenly confused
4136 with the final state because precisely final_state was initialized
4137 to 0.
4138 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4139 now noticed by Bison.
4140 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4141 have a reduction on $default.
4142
29d29c8f
AD
41432001-12-29 Akim Demaille <akim@epita.fr>
4144
4145 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4146 rule line numbers.
4147 * src/closure.c (print_closure): Likewise.
4148 * src/derives.c (print_derives): Likewise.
4149 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4150 now.
4151
7c6b64d0
AD
41522001-12-29 Akim Demaille <akim@epita.fr>
4153
4154 * src/lalr.c (lookaheads_print): New.
4155 (lalr): Call it when --trace-flag.
4156 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4157 are dumped.
4158
3d4daee3
AD
41592001-12-29 Akim Demaille <akim@epita.fr>
4160
4161 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4162 when walking through ritem, even via rule->rhs.
4163 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4164 (useful_production, useless_nonterminals): Likewise.
4165 (reduce_grammar_tables): Likewise, plus update nritems.
4166 * src/nullable.c (set_nullable): Likewise.
4167 * src/lalr.c (build_relations): Likewise.
4168 * tests/sets.at (Nullable): Adjust.
4169 Fortunately, now, the $axiom is no longer nullable.
4170
9e7f6bbd
AD
41712001-12-29 Akim Demaille <akim@epita.fr>
4172
4173 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4174 the 0-sentinel.
4175 * src/gram.c (ritem_longest_rhs): Likewise.
4176 * src/reduce.c (nonterminals_reduce): Likewise.
4177 * src/print_graph.c (print_graph): Likewise.
4178 * src/output.c (output_rule_data): Likewise.
4179 * src/nullable.c (set_nullable): Likewise.
4180
255ef638
AD
41812001-12-29 Akim Demaille <akim@epita.fr>
4182
4183 * src/output.c: Comment changes.
4184
0d8a7363
AD
41852001-12-27 Paul Eggert <eggert@twinsun.com>
4186
4187 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4188 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4189 Sparc, as they were causing more porting problems than the
4190 (minor) performance improvement was worth.
4191
4192 Also, catch up with 1.31's YYSTD.
4193
3db472b9
AD
41942001-12-27 Akim Demaille <akim@epita.fr>
4195
4196 * src/output.c (output_gram): Rely on nritems, not the
4197 0-sentinel. See below.
4198 Use -1 as separator, not 0.
4199 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4200 Rely on -1 as separator in yyrhs, instead of 0.
4201 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4202 twice `Now at end of input', therefore there are two lines less to
4203 expect.
4204
b365aa05
AD
42052001-12-27 Akim Demaille <akim@epita.fr>
4206
4207 * tests/regression.at (Unresolved SR Conflicts):
4208 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4209 below.
4210
30171f79
AD
42112001-12-27 Akim Demaille <akim@epita.fr>
4212
4213 * src/LR0.c (new_state): Recognize the final state by the fact it
4214 is reached by eoftoken.
4215 (insert_start_shifting_state, insert_eof_shifting_state)
4216 (insert_accepting_state, augment_automaton): Remove, since now
4217 these states are automatically computed from the initial state.
4218 (generate_states): Adjust.
4219 * src/print.c: When reporting a rule number to the user, substract
4220 1, so that the axiom rule is rule 0, and the first user rule is 1.
4221 * src/reduce.c: Likewise.
4222 * src/print_graph.c (print_core): For the time being, just as for
4223 the report, depend upon --trace-flags to dump the full set of
4224 items.
4225 * src/reader.c (readgram): Once the grammar read, insert the rule
4226 0: `$axiom: START-SYMBOL $'.
4227 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4228 number of the states has changed (the final state is no longer
4229 necessarily the last), catch up.
4230
75142d45
AD
42312001-12-27 Akim Demaille <akim@epita.fr>
4232
4233 Try to make the use of the eoftoken valid. Given that its value
4234 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4235 is used instead of > 0 where appropriate, (ii), depend upon nritems
4236 instead of the 0-sentinel.
4237
4238 * src/gram.h, src/gram.c (nritems): New.
4239 Expected to be duplication of nitems, but for the time being...
4240 * src/reader.c (packgram): Assert nritems and nitems are equal.
4241 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4242 * src/closure.c (print_closure, print_fderives): Likewise.
4243 * src/gram.c (ritem_print): Likewise.
4244 * src/print.c (print_core, print_grammar): Likewise.
4245 * src/print_graph.c: Likewise.
4246
b7c49edf
AD
42472001-12-27 Akim Demaille <akim@epita.fr>
4248
4249 * src/main.c (main): If there are complains after grammar
4250 reductions, then output the report anyway if requested, then die.
4251 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4252 * src/reader.c (eoftoken): New.
4253 (parse_token_decl): If the token being defined has value `0', it
4254 is the eoftoken.
4255 (packsymbols): No longer hack `tags' to insert `$' by hand.
4256 Be sure to preserve the value of the eoftoken.
4257 (reader): Make sure eoftoken is defined.
4258 Initialize nsyms to 0: now eoftoken is created just like the others.
4259 * src/print.c (print_grammar): Don't special case the eof token.
4260 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4261 lie anyway, albeit pleasant.
4262 * tests/calc.at: Exercise error messages with eoftoken.
4263 Change the grammar so that empty input is invalid.
4264 Adjust expectations.
4265 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4266
ec2da99f
AD
42672001-12-27 Akim Demaille <akim@epita.fr>
4268
4269 * configure.in: Check the protos of strchr ans strspn.
4270 Replace strchr if needed.
4271 * src/system.h: Provide the protos of strchr, strspn and memchr if
4272 missing.
4273 * lib/strchr.c: New.
4274 * src/reader.c (symbols_save): Use strchr.
4275
8adfa272
AD
42762001-12-27 Akim Demaille <akim@epita.fr>
4277
4278 * src/print.c, src/print_graph.c (escape): New.
4279 Use it to quote the TAGS outputs.
4280 * src/print_graph.c (print_state): Now errors are in red, and
4281 reductions in green.
4282 Prefer high to wide: output the state number on a line of its own.
4283
80dac38c
AD
42842001-12-27 Akim Demaille <akim@epita.fr>
4285
4286 * src/state.h, src/state.c (reductions_new): New.
4287 * src/LR0.c (set_state_table): Let all the states have a
4288 `reductions', even if reduced to 0.
4289 (save_reductions): Adjust.
4290 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4291 * src/print.c (print_reductions, print_actions): Adjust.
4292 * src/output.c (action_row): Adjust.
4293
2cec70b9
AD
42942001-12-27 Akim Demaille <akim@epita.fr>
4295
4296 * src/state.h, src/state.c (errs_new, errs_dup): New.
4297 * src/LR0.c (set_state_table): Let all the states have an errs,
4298 even if reduced to 0.
4299 * src/print.c (print_errs, print_reductions): Adjust.
4300 * src/output.c (output_actions, action_row): Adjust.
4301 * src/conflicts.c (resolve_sr_conflict): Adjust.
4302
13ca549a
AD
43032001-12-27 Akim Demaille <akim@epita.fr>
4304
4305 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4306
5092aba5
AD
43072001-12-27 Akim Demaille <akim@epita.fr>
4308
4309 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4310 * src/print.c: here.
4311 (lookaheadset, shiftset): New, used as additional storage by
4312 print_reductions.
4313 (print_results): Adjust.
4314 (print_shifts, print_gotos, print_errs): New, extracted from...
4315 (print_actions): here.
4316 * src/print_graph.c (print_actions): Remove dead code.
4317
11e2beca
AD
43182001-12-27 Akim Demaille <akim@epita.fr>
4319
4320 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4321 `$n' and `@n'.
4322
dac3c910
AD
43232001-12-27 Akim Demaille <akim@epita.fr>
4324
4325 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4326 (build_relations): Adjust.
4327
d0b0fefa
AD
43282001-12-27 Akim Demaille <akim@epita.fr>
4329
4330 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4331 duplication.
4332
adc8c848
AD
43332001-12-27 Akim Demaille <akim@epita.fr>
4334
4335 * src/reader.c (packgram): Catch nitems overflows.
4336
14d293ac
AD
43372001-12-27 Akim Demaille <akim@epita.fr>
4338
4339 * src/files.c, src/files.h (guard_obstack): Remove.
4340 * src/output.c (output): Adjust.
4341 * src/reader.c (parse_braces): New, factoring...
4342 (copy_action, copy_guard): these two which are renamed as...
4343 (parse_action, parse_guard): these.
4344 As a voluntary consequence, using braces around guards is now
4345 mandatory.
4346
f499b062
AD
43472001-12-27 Akim Demaille <akim@epita.fr>
4348
4349 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
4350 * src/reader.c (symbol_list): `guard' and `guard_line' are new
4351 members.
4352 (symbol_list_new): Adjust.
4353 (copy_action): action_line is the first line, not the last.
4354 (copy_guard): Just as for actions, store the `action' only, not
4355 the switch/case/break flesh.
4356 Don't parse the user action that might follow the guard, let...
4357 (readgram): do it, i.e., now, there can be an action after a
4358 guard.
4359 In other words the guard is just explicitly optional.
4360 (packgram): Adjust.
4361 * src/output.c (guards_output): New.
4362 (output_parser): Call it when needed.
4363 (output): Also free the guard and attrs obstacks.
4364 * src/files.c, src/files.h (obstack_save): Remove.
4365 (output_files): Remove.
4366 As a result, if one needs the former `.act' file, using an
4367 appropriate skeleton which requires actions and guards is now
4368 required.
4369 * src/main.c (main): Adjust.
4370 * tests/semantic.at: New.
4371 * tests/regression.at: Use `input.y' as input file name.
4372 Avoid 8+3 problems by requiring input.c when the test needs the
4373 parser.
4374
d945f5cd
AD
43752001-12-27 Akim Demaille <akim@epita.fr>
4376
4377 * src/reader.c (symbol_list_new): Be sure to initialize all the
4378 fields.
4379
d200e455
AD
43802001-12-27 Akim Demaille <akim@epita.fr>
4381
4382 All the hacks using a final pseudo state are now useless.
4383
4384 * src/LR0.c (set_state_table): state_table holds exactly nstates.
4385 * src/lalr.c (nLA): New.
4386 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
4387 instead of lookaheadsp from the pseudo state (nstate + 1).
4388
f9507c28
AD
43892001-12-27 Akim Demaille <akim@epita.fr>
4390
4391 * src/output.c (action_row, token_actions): Use a state_t instead
4392 of a integer, and nlookaheads instead of the following state's
4393 lookaheadsp.
4394
065fbd27
AD
43952001-12-27 Akim Demaille <akim@epita.fr>
4396
4397 * src/conflicts.c (log_resolution, flush_shift)
4398 (resolve_sr_conflict, set_conflicts, solve_conflicts)
4399 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
4400 (conflicts_print, print_reductions): Use a state_t instead of an
4401 integer when referring to a state.
4402 As much as possible, depend upon nlookaheads, instead of the
4403 `lookaheadsp' member of the following state (since lookaheads of
4404 successive states are successive, the difference between state n + 1
4405 and n served as the number of lookaheads for state n).
4406 * src/lalr.c (add_lookback_edge): Likewise.
4407 * src/print.c (print_core, print_actions, print_state)
4408 (print_results): Likewise.
4409 * src/print_graph.c (print_core, print_actions, print_state)
4410 (print_graph): Likewise.
4411 * src/conflicts.h: Adjust.
4412
1b177bd7
AD
44132001-12-27 Akim Demaille <akim@epita.fr>
4414
4415 * src/bison.hairy: Formatting/comment changes.
4416 ANSIfy.
4417 Remove `register' indications.
4418 Add plenty of `static'.
4419
7742ddeb
AD
44202001-12-27 Akim Demaille <akim@epita.fr>
4421
4422 * src/output.c (prepare): Drop the muscle `ntbase' which
4423 duplicates ntokens.
4424 * src/bison.simple: Formatting/comment changes.
4425 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
4426 is an undocumented synonym.
4427
1fa14068
AD
44282001-12-22 Akim Demaille <akim@epita.fr>
4429
4430 * src/output.c (output_table_data): Change the prototype to use
4431 `int' for array ranges: some invocations do pass an int, not a
4432 short.
4433 Reported by Wayne Green.
4434
b9752825
AD
44352001-12-22 Akim Demaille <akim@epita.fr>
4436
4437 Some actions of web2c.y are improperly triggered.
4438 Reported by Mike Castle.
4439
4440 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
4441 * tests/regression.at (Web2c): Rename as...
4442 (Web2c Report): this.
4443 (Web2c Actions): New.
4444
776209d6
AD
44452001-12-22 Akim Demaille <akim@epita.fr>
4446
4447 Reductions in web2c.y are improperly reported.
4448 Reported by Mike Castle.
4449
4450 * src/conflicts.c (print_reductions): Fix.
4451 * tests/regression.at (Web2c): New.
4452
275fc3ad
AD
44532001-12-18 Akim Demaille <akim@epita.fr>
4454
4455 Some host fail on `assert (!"foo")', which expands to
4456 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
4457 Reported by Nelson Beebee.
4458
4459 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
4460 `#define it_succeeded 0' and `assert (it_succeeded)'.
4461
897668ee
MA
44622001-12-17 Marc Autret <autret_m@epita.fr>
4463
4464 * src/bison.simple: Don't hard code the skeleton line and filename.
4465 * src/output.c (output_parser): Rename 'line' as 'output_line'.
4466 New line counter 'skeleton_line' (skeleton-line muscle).
4467
ab3399e0
PE
44682001-12-17 Paul Eggert <eggert@twinsun.com>
4469
4470 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
4471 YYDEBUG must be defined to a nonzero value.
4472
4473 * src/bison.simple (yytname): Do not assume that the user defines
4474 YYDEBUG to a properly parenthesized expression.
4475
3877f72b
AD
44762001-12-17 Akim Demaille <akim@epita.fr>
4477
4478 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
4479 nlookaheads is a new member.
4480 Adjust all users.
4481 * src/lalr.h (nlookaheads): Remove this orphan declaration.
4482 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
4483 state.
776209d6 4484
331dbc1b
AD
44852001-12-17 Akim Demaille <akim@epita.fr>
4486
4487 * src/files.h, src/files.c (open_files, close_files): Remove.
4488 * src/main.c (main): Don't open/close files, nor invoke lex_free,
4489 let...
4490 * src/reader.c (reader): Do it.
776209d6 4491
be750e4c
AD
44922001-12-17 Akim Demaille <akim@epita.fr>
4493
4494 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 4495
709ae8c6
AD
44962001-12-17 Akim Demaille <akim@epita.fr>
4497
4498 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
4499 (flush_reduce): New.
4500 (resolve_sr_conflict): Adjust.
776209d6 4501
f87685c3
AD
45022001-12-17 Akim Demaille <akim@epita.fr>
4503
4504 * src/output.c (output_obstack): Be static and rename as...
4505 (format_obstack): this, to avoid any confusion with files.c's
4506 output_obstack.
4507 * src/reader.h (muscle_obstack): Move to...
4508 * src/output.h: here, since it's defined in output.c.
4509
837491d8
AD
45102001-12-17 Akim Demaille <akim@epita.fr>
4511
4512 * src/output.c (action_row, save_column, default_goto)
4513 (sort_actions, matching_state, pack_vector): Better variable
4514 locality.
4515
796d61fb
AD
45162001-12-17 Akim Demaille <akim@epita.fr>
4517
4518 * src/output.c: Various formatting changes.
776209d6 4519
64d15509
AD
45202001-12-17 Akim Demaille <akim@epita.fr>
4521
4522 * src/files.c (output_files): Free the output_obstack.
4523 * src/main.c (main): Call print and print_graph conditionally.
4524 * src/print.c (print): Work unconditionally.
4525 * src/print_graph.c (print_graph): Work unconditionally.
4526 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4527
fbc8ecb7
MA
45282001-12-16 Marc Autret <autret_m@epita.fr>
4529
4530 * src/output.c (actions_output): Fix. When we use %no-lines,
4531 there is one less line per action.
4532
f0440388
MA
45332001-12-16 Marc Autret <autret_m@epita.fr>
4534
4535 * src/bison.simple: Remove a useless #line directive.
4536 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4537 * src/output.c (get_lines_number): New.
776209d6 4538 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
4539 output muscles.
4540 Fix line numbering.
4541 (actions_output): Computes the number of lines taken by actions.
4542 (output_master_parser): Insert new skeleton which is the name of
4543 the output parser file name.
4544
a79986b8
MA
45452001-12-15 Marc Autret <autret_m@epita.fr>
4546
4547 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4548
4ec8e00f
MA
45492001-12-15 Marc Autret <autret_m@epita.fr>
4550
4551 * src/output.c (output_gram): Keep track of the hairy one.
4552
1a4648ff
AD
45532001-12-15 Akim Demaille <akim@epita.fr>
4554
4555 Make `make distcheck' work.
4556
4557 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4558 system.h which uses libgettext.h.
4559
9c2c67e6
AD
45602001-12-15 Akim Demaille <akim@epita.fr>
4561
4562 * src/nullable.c (set_nullable): Useless rules must be skipped,
4563 otherwise, since we range over their symbols, we might look at a
4564 nonterminal which no longer ``exists'', i.e., it is not counted in
4565 `nvars', hence we overflow our arrays.
4566
93ede233
AD
45672001-12-15 Akim Demaille <akim@epita.fr>
4568
4569 The header can also be produced directly, without any obstack!
4570 Yahoo!
4571
4572 * src/files.c, src/files.h (defines_obstack): Remove.
4573 (compute_header_macro): Global.
4574 (defines_obstack_save): Remove.
4575 * src/reader.c (parse_union_decl): No longer output to
4576 defines_obstack: its content can be found in the `stype' muscle
4577 anyway.
4578 (output_token_translations): Merge into...
4579 (symbols_output): this.
4580 Rename as...
4581 (symbols_save): this.
4582 (reader): Adjust.
4583 * src/output.c (header_output): New.
4584 (output): Call it.
4585
2666f928
AD
45862001-12-15 Akim Demaille <akim@epita.fr>
4587
4588 * src/reader.c (parse_union_decl): Instead of handling two obstack
4589 simultaneously, use one to define the `stype' muscle, and use the
4590 value of the latter to fill defines_obstack.
4591 (copy_comment): Remove.
4592 (copy_comment2): Work for a single obstack.
4593 Rename as...
4594 (copy_comment): this.
4595
428046f8
AD
45962001-12-15 Akim Demaille <akim@epita.fr>
4597
4598 * src/lex.c, src/lex.h (xgetc): No longer static.
4599 * src/reader.c (parse_union_decl): Revamp.
4600
ea52d706
AD
46012001-12-15 Akim Demaille <akim@epita.fr>
4602
4603 Still making progress in separating Bison into (i) input, (ii)
4604 process, (iii) output: now we can directly output the parser file
4605 without using table_obstack at all.
4606
4607 * src/files.c, src/files.h (table_obstack): Bye bye.
4608 (parser_file_name): New.
4609 * src/files.c (compute_output_file_names): Compute it.
4610 * src/output.c (actions_output, output_parser)
4611 (output_master_parser): To a file instead of an obstack.
4612
3f96f4dc
AD
46132001-12-15 Akim Demaille <akim@epita.fr>
4614
4615 Attach actions to rules, instead of pre-outputting them to
4616 actions_obstack.
4617
4618 * src/gram.h (rule_t): action and action_line are new members.
4619 * src/reader.c (symbol_list): Likewise.
4620 (copy_action): Save the actions within the rule.
4621 (packgram): Save them in rule_table.
4622 * src/output.c (actions_output): New.
4623 (output_parser): Use it on `%%actions'.
4624 (output_rule_data): Don't free rule_table.
4625 (output): Do it.
4626 (prepare): Don't save the `action' muscle.
4627 * src/bison.simple: s/%%action/%%actions/.
4628
51576fb3
AD
46292001-12-15 Akim Demaille <akim@epita.fr>
4630
4631 * src/reader.c (copy_action): When --yacc, don't append a `;'
4632 to the user action: let it fail if lacking.
dee049eb 4633 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 4634
2648a72d
AD
46352001-12-14 Akim Demaille <akim@epita.fr>
4636
4637 * src/lex.c (literalchar): Simply return the char you decoded, non
4638 longer mess around with obstacks and int pointers.
4639 Adjust all callers.
4640
92790e5b
AD
46412001-12-14 Akim Demaille <akim@epita.fr>
4642
4643 * src/lex.c (literalchar): Don't escape the special characters,
4644 just decode them, and keep them as char (before, eol was output as
4645 the 2 char string `\n' etc.).
4646 * src/output.c (output_rule_data): Use quotearg to output the
4647 token strings.
4648
927c1557
PE
46492001-12-13 Paul Eggert <eggert@twinsun.com>
4650
4651 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4652 Do not infringe on the global user namespace when using C++.
4653 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4654 All uses of `fprintf' and `stderr' changed.
4655
4656 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4657
ed8e1f68
AD
46582001-12-13 Akim Demaille <akim@epita.fr>
4659
4660 The computation of nullable is broken: it doesn't handle empty
4661 RHS's properly.
4662
4663 * tests/torture.at (GNU AWK Grammar): New.
4664 * tests/sets.at (Nullable): New.
4665 * src/nullable.c (set_nullable): Instead of blindly looping over
4666 `ritems', loop over the rules, and then over their rhs's.
4667
4668 Work around Autotest bugs.
4669
4670 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4671 frame, because Autotest understand lines starting with a `+' as
4672 traces from the shell. Then, they are not processed properly.
4673 Admittedly an Autotest bug, but we don't have time to wait for
4674 Autotest to catch up.
4675 * tests/regression.at (Broken Closure): Adjust to the new table
4676 frames.
4677 Move to...
4678 * tests/sets.at: here.
4679
cb581495
AD
46802001-12-13 Akim Demaille <akim@epita.fr>
4681
4682 * src/closure.c (closure): Use nrules instead of playing tricks
4683 with BITS_PER_WORD.
4684
2e729273
AD
46852001-12-13 Akim Demaille <akim@epita.fr>
4686
4687 * src/print.c (print_actions): Output the handling of `$' as the
4688 traces do: shifting the token EOF. Before EOF was treated as a
4689 nonterminal.
4690 * tests/regression.at: Adjust some tests.
4691 * src/print_graph.c (print_core): Complete the set of items via
4692 closure. The next-to-final and final states are still unsatisfying,
4693 but that's to be addressed elsewhere.
4694 No longer output the rule numbers, but do output the state number.
4695 A single loop for the shifts + gotos is enough, but picked a
4696 distinct color for each.
4697 (print_graph): Initialize and finalize closure.
4698
107f7dfb
AD
46992001-12-13 Akim Demaille <akim@epita.fr>
4700
4701 * src/reader.c (readgram): Remove dead code, an strip useless
4702 braces.
4703 (get_type): Remove, unused.
4704
9b53a24f
AD
47052001-12-12 Akim Demaille <akim@epita.fr>
4706
4707 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4708 on that of lib/error.c.
4709
dbfb6dcd
AD
47102001-12-12 Akim Demaille <akim@epita.fr>
4711
4712 Some hosts don't like `/' in includes.
4713
4714 * src/system.h: Include libgettext.h without qualifying the path.
4715 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4716 $(top_srcdir).
4717
c25fb648
MA
47182001-12-11 Marc Autret <autret_m@epita.fr>
4719
4720 * src/output.c (output_parser): Remove useless muscle.
4721
710ddc4f
MA
47222001-12-11 Marc Autret <autret_m@epita.fr>
4723
4724 * src/bison.simple: Remove #line just before %%epilogue. It
4725 is now handled in ...
4726 * src/reader.c (read_additionnal_code): Add the output of a
4727 #line for the epilogue.
4728
e83d80b8
MA
47292001-12-10 Marc Autret <autret_m@epita.fr>
4730
927c1557 4731 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
4732 replace precedent remove.
4733 * src/bison.simple: Remove #line before %%prologue because
4734 %%input-line is wrong at this time.
4735
971d5158
MA
47362001-12-10 Marc Autret <autret_m@epita.fr>
4737
4738 * src/reader.c (symbols_output): Clean up.
927c1557 4739 * src/output.c (output_gram, output): Clean up.
971d5158 4740
5edafffd
AD
47412001-12-10 Akim Demaille <akim@epita.fr>
4742
4743 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4744 * src/LR0.c (set_state_table): here.
4745 * src/lalr.c (lalr): Call it.
4746
0279f8e9
AD
47472001-12-10 Akim Demaille <akim@epita.fr>
4748
4749 * src/state.h (shifts): Remove the `number' member: shifts are
4750 attached to state, hence no longer need to be labelled with a
4751 state number.
4752
190c4f5f
AD
47532001-12-10 Akim Demaille <akim@epita.fr>
4754
4755 Now that states have a complete set of members, the linked list of
4756 shifts is useless: just fill directly the state's shifts member.
4757
4758 * src/state.h (shifts): Remove the `next' member.
4759 * src/LR0.c (first_state, last_state): Remove.
4760 Adjust the callers.
4761 (augment_automaton): Don't look for the shifts that must be added
4762 a shift on EOF: it is those of the state we looked for! But now,
4763 since shifts are attached, it is no longer needed to looking
4764 merely by its id: its number.
4765
2a73b93d
AD
47662001-12-10 Akim Demaille <akim@epita.fr>
4767
4768 * src/LR0.c (augment_automaton): Better variable locality.
4769 Remove an impossible branch: if there is a state corresponding to
4770 the start symbol being shifted, then there is shift for the start
4771 symbol from the initial state.
4772
74392f6a
AD
47732001-12-10 Akim Demaille <akim@epita.fr>
4774
4775 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4776 only when appropriate: when insert_start_shifting_state' is not
4777 invoked.
4778 * tests/regression.at (Rule Line Numbers): Adjust.
4779
37c82725
AD
47802001-12-10 Akim Demaille <akim@epita.fr>
4781
4782 * src/LR0.c (augment_automaton): Now that all states have shifts,
4783 merge the two cases addition shifts to the initial state.
4784
6a164e0c
AD
47852001-12-10 Akim Demaille <akim@epita.fr>
4786
4787 * src/lalr.c (set_state_table): Move to...
4788 * src/LR0.c: here.
4789 * src/lalr.c (lalr): Don't call it...
4790 * src/LR0.c (generate_states): do it.
4791 * src/LR0.h (first_state): Remove, only the table is used.
4792
7215de24
AD
47932001-12-10 Akim Demaille <akim@epita.fr>
4794
4795 * src/LR0.h (first_shift, first_reduction): Remove.
4796 * src/lalr.c: Don't use first_shift: find shifts through the
4797 states.
4798
80e25d4d
AD
47992001-12-10 Akim Demaille <akim@epita.fr>
4800
4801 * src/LR0.c: Attach shifts to states as soon as they are
4802 computed.
4803 * src/lalr.c (set_state_table): Instead of assigning shifts to
4804 state, just assert that the mapping was properly done.
4805
0ab3728b
AD
48062001-12-10 Akim Demaille <akim@epita.fr>
4807
4808 * src/LR0.c (insert_start_shift): Rename as...
4809 (insert_start_shifting_state): this.
4810 (insert_eof_shifting_state, insert_accepting_state): New.
4811 (augment_automaton): Adjust.
4812 Better locality of the variables.
4813 When looking if the start_symbol is shifted from the initial
4814 state, using `while (... symbol != start_symbol ...)' sounds
4815 better than `while (... symbol < start_symbol ...)': If fail
4816 to see how the order between symbols could be relevant!
4817
78af9bbc
AD
48182001-12-10 Akim Demaille <akim@epita.fr>
4819
4820 * src/getargs.h: Don't declare `spec_name_prefix' and
4821 `spec_file_prefix', declared by src/files.h.
4822 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4823 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4824 * src/output.c (prepare): Adjust.
4825 * src/reader.c (symbols_output): Likewise.
4826 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4827
bdef2a41
AD
48282001-12-10 Akim Demaille <akim@epita.fr>
4829
4830 * src/muscle_tab.c (muscle_init): NULL is a better default than
4831 `"0"'.
4832
3735969c
AD
48332001-12-10 Akim Demaille <akim@epita.fr>
4834
4835 * src/reader.c (reader): Calling symbols_output once is enough.
4836
49701457
AD
48372001-12-10 Akim Demaille <akim@epita.fr>
4838
4839 Now that states have a complete set of members, the linked list of
4840 reductions is useless: just fill directly the state's reductions
4841 member.
4842
4843 * src/state.h (struct reductions): Remove member `number' and
4844 `next'.
4845 * src/LR0.c (first_reduction, last_reduction): Remove.
4846 (save_reductions): Don't link the new reductions, store them in
4847 this_state.
4848 * src/lalr.c (set_state_table): No need to attach reductions to
4849 states, it's already done.
4850 * src/output.c (output_actions): No longer free the shifts, then
4851 the reductions, then the states: free all the states and their
4852 members.
4853
0edad749
AD
48542001-12-10 Akim Demaille <akim@epita.fr>
4855
4856 * src/options.c (OPTN, DRTV, BOTH): New.
4857 (option_table): Use them.
4858
0edad749
AD
4859 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4860 the job of system.h.
4861 * src/options.c: Don't include stdio.h and xalloc.h for the same
4862 reasons.
4863
5449dd0f
AD
48642001-12-10 Akim Demaille <akim@epita.fr>
4865
4866 * src/output.c (output, prepare): Make sure the values of the
4867 muscles `action' and `prologue' are 0-terminated.
4868
a870c567
AD
48692001-12-10 Akim Demaille <akim@epita.fr>
4870
4871 Clean up GCC warnings.
4872
4873 * src/reader.c (copy_action): `buf' is not used.
4874 (parse_skel_decl): Be static.
4875 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4876 * src/options.h (create_long_option_table): Have a real prototype.
4877 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4878 (hash_delete_at): Return const void *.
4879 Adjust casts to preserve the const.
4880
80df8768
AD
48812001-12-10 Akim Demaille <akim@epita.fr>
4882
4883 * configure.in: Require 2.52g.
4884 M4 is not needed, but AUTOM4TE is.
4885 * m4/m4.m4: Remove.
4886 * tests/Makefile.am: Adjust.
4887
f693ad14
AD
48882001-12-10 Akim Demaille <akim@epita.fr>
4889
4890 One structure for states is enough, even though theoretically
4891 there are LR(0) states and LALR(1) states.
4892
4893 * src/lalr.h (state_t): Remove.
4894 (state_table): Be state_t **, not state_t *.
4895 * src/state.h (core, CORE_ALLOC): Rename as...
4896 (state_t, STATE_ALLOC): this.
4897 Add the LALR(1) members: shifts, reductions, errs.
4898 * src/LR0.c (state_table): Rename as...
4899 (state_hash): this, to avoid name clashes with the global
4900 `state_table'.
4901 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4902 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4903
74ffbcb6
AD
49042001-12-10 Akim Demaille <akim@epita.fr>
4905
4906 Bison dumps core on bash.y.
4907 Reported by Pascal Bart.
4908
4909 * src/warshall.c (bitmatrix_print): New.
4910 (TC): Use it.
4911 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4912 j must be the outer loop.
4913 * tests/regression.at (Broken Closure): New.
4914
07708e19
AD
49152001-12-05 Akim Demaille <akim@epita.fr>
4916
4917 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4918 its argument.
4919