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