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