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