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