]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
(Exotic Dollars): Test for "nonterm: { $$ = 123; } { $$ = $1; };" bug.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-10-12 Paul Eggert <eggert@twinsun.com>
2
3 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
4 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
5 Include <sys/time.h> when checking for clock_t and struct tms.
6 Use same include order as source.
7 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
8 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
9
10 * lib/timevar.c: Update copyright date and clarify comments.
11 (get_time) [IN_GCC]: Keep the GCC version for reference.
12
13 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
14 GCC version as of today, then merge Bison's changes.
15 Change "GCC" to "Bison" in copyright notice. timevar.def's
16 author is Akim, so change that too.
17
18 * src/reader.c (grammar_current_rule_check):
19 Don't worry about the default action if $$ is untyped.
20 Prevents bogus warnings reported by Jim Gifford in
21 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
22
23 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
24 * data/glr.c, data/lalr1.cc, data/yacc.c:
25 Output token definitions before the first part of user declarations.
26 Fixes compatibility problem reported by Jim Gifford for kbd in
27 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
28
292002-10-11 Paul Eggert <eggert@twinsun.com>
30
31 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
32 (yyparse): here. This undoes some of the 2002-07-25 change.
33 Compatibility problem reported by Ralf S. Engelschall with
34 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
35
362002-10-11 Akim Demaille <akim@epita.fr>
37
38 * tests/regression.at Characters Escapes): New.
39 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
40 characters.
41 Reported by Jan Nieuwenhuizen.
42
432002-10-11 Akim Demaille <akim@epita.fr>
44
45 * po/id.po: New.
46
472002-10-10 Paul Eggert <eggert@twinsun.com>
48
49 Portability fixes for bitsets; this also avoids several GCC
50 warnings.
51
52 * lib/abitset.c: Include <stddef.h>, for offsetof.
53 * lib/lbitset.c: Likewise.
54
55 * lib/abitset.c (abitset_bytes): Return a size that is aligned
56 properly for vectors of objects. Do not assume that adding a
57 header size to a multiple of a word size yields a value that is
58 properly aligned for the whole union.
59 * lib/bitsetv.c (bitsetv_alloc): Likewise.
60
61 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
62 unique names for structures.
63 * lib/ebitset.c (ebitset_bytes): Likewise.
64 * lib/lbitset.c (lbitset_bytes): Likewise.
65
66 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
67 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
68 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
69 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
70 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
71 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
72 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
73 to improve the type-checking that GCC can do.
74 * lib/bitset.c (bitset_op4_cmp): Likewise.
75 * lib/bitset_stats.c (bitset_stats_count,
76 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
77 bitset_stats_copy, bitset_stats_disjoint_p,
78 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
79 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
80 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
81 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
82 bitset_stats_and_or_cmp, bitset_stats_andn_or,
83 bitset_stats_andn_or_cmp, bitset_stats_or_and,
84 bitset_stats_or_and_cmp): Likewise.
85 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
86 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
87 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
88 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
89
90 * lib/abitset.h: Include bitset.h, not bbitset.h.
91 * lib/ebitset.h: Likewise.
92 * lib/lbitset.h: Likewise.
93
94 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
95 All instances of parameters of type enum bitset_opts are now of
96 type enum_bitset_opts, to conform to the C Standard, and similarly
97 for enum_bitset_type.
98 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
99 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
100
101 Do not use "struct bitset_struct" to mean different things in
102 different modules. Not only is this confusing, it violates
103 the C Standard, which requires that structure types in different
104 modules must be compatible if one is to be passed to the other.
105 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
106 All instances of "struct bitset_struct *" replaced with "bitset".
107 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
108 (union bitset_union, struct abitset_struct, struct ebitset_struct,
109 struct lbitset_struct, struct bitset_stats_struct): New types.
110 All uses of struct bitset_struct changed to union bitset_union,
111 etc.
112 * lib/abitset.c (struct abitset_struct, abitset,
113 struct bitset_struct): Remove.
114 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
115 struct bitset_struct): Remove.
116 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
117 bitset_struct): Remove.
118 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
119 Likewise.
120
121 Do not call a function of type T using a call that assumes the
122 function is of a different type U. Standard C requires that a
123 function must be called with a type that is compatible with its
124 definition.
125 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
126 New decls.
127 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
128 New functions.
129 * lib/ebitset.c (PFV): Remove.
130 * lib/lbitset.c (PFV): Likewise.
131 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
132 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
133 decls.
134 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
135 (ebitset_vtable): Use them.
136 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
137 lbitset_xor): New functions.
138 (lbitset_vtable): Use them.
139
140 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
141 Declare.
142
143 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
144 GCC warning.
145 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
146 Use offsetof, for simplicity.
147
1482002-10-06 Paul Eggert <eggert@twinsun.com>
149
150 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
151 the same width as int. This reapplies a hunk of the 2002-08-12 patch
152 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
153 which was inadvertently undone by the 2002-09-30 patch.
154 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
155 the same width as int.
156
1572002-10-04 Paul Eggert <eggert@twinsun.com>
158
159 Version 1.50.
160
161 * configure.ac (AC_INIT), NEWS: Increment version number.
162
163 * doc/bison.texinfo: Minor spelling, grammar, and white space
164 fixes.
165 (Symbols): Mention that any negative value returned from yylex
166 signifies end-of-input. Warn about negative chars. Mention
167 the portable Standard C character set.
168
169 The GNU coding standard says CFLAGS and YFLAGS are reserved
170 for the installer to set.
171 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
172 * src/Makefile.am (AM_CFLAGS): Likewise.
173 (AM_YFLAGS): Renamed from YFLAGS.
174
175 Fix some MAX and MIN problems.
176 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
177 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
178 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
179 * src/reader.c (reader): Use it.
180
181 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
182 POSIX 1003.1-2001 has removed fgrep.
183
1842002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
185
186 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
187 interpreted as signed.
188 * lib/ebitset.c (ebitset_list): Fix bug.
189
1902002-10-01 Paul Eggert <eggert@twinsun.com>
191
192 More fixes for 64-bit hosts and large bitsets.
193
194 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
195 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
196 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
197 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
198 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
199 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
200 bitset_count_): Likewise.
201 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
202 bitset_first, bitset_last): Likewise.
203 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
204 bitset_stats_list_reverse, bitset_stats_size,
205 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
206 Likewise.
207 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
208 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
209 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
210 bitsetv_reflexive_transitive_closure): Likewise.
211 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
212 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
213 Likewise.
214 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
215 Likewise.
216
217 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
218 Use size_t, not unsigned int, to count bytes.
219 * lib/abitset.h (abitset_bytes): Likewise.
220 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
221 Likewise.
222 * lib/bitset.h (bitset_bytes): Likewise.
223 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
224 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
225 * lib/bitsetv.c (bitsetv_alloc): Likewise.
226 * lib/ebitset.c (ebitset_bytes): Likewise.
227 * lib/ebitset.h (ebitset_bytes): Likewise.
228 * lib/lbitset.c (lbitset_bytes): Likewise.
229 * lib/lbitset.h (lbitset_bytes): Likewise.
230
231 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
232 abitset_subset_p, abitset_disjoint_p, abitset_and,
233 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
234 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
235 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
236 abitset_or_and, abitset_or_and_cmp):
237 Use bitset_windex instead of unsigned int.
238 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
239 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
240 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
241 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
242 Likewise.
243 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
244
245 * lib/bitset.c (bitset_print):
246 Use proper printf formats for widths of integer types.
247 * lib/bitset_stats.c (bitset_percent_histogram_print,
248 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
249 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
250 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
251 * lib/lbitset.c (lbitset_bytes): Likewise.
252
253 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
254 BITSET_SIZE_MAX): New macros.
255 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
256 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
257 to BITSET_WINDEX_MAX.
258
259 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
260 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
261 since we now return the bitset_bindex type (not int).
262
263 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
264 when computing sizes.
265 * lib/ebitset.c (ebitset_elts_grow): Likewise.
266
267 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
268 and avoid cast to unsigned.
269
2702002-09-30 Akim Demaille <akim@epita.fr>
271
272 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
273 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
274 Updates from Michael Hayes.
275
2762002-09-30 Art Haas <ahaas@neosoft.com>
277
278 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
279 invocations.
280 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
281 defined.
282
2832002-09-27 Akim Demaille <akim@epita.fr>
284
285 Version 1.49c.
286
2872002-09-27 Akim Demaille <akim@epita.fr>
288
289 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
290 (Because of AC_LIBSOURCE).
291
2922002-09-27 Akim Demaille <akim@epita.fr>
293
294 Playing with Autoscan.
295
296 * configure.ac: Remove the old LIBOBJ tweaks.
297 (AC_REPLACE_FUNCS): Add strrchr and strtol.
298 * lib/strrchr.c: New.
299 * lib/strtol.c: New, from the Coreutils 4.5.1.
300
3012002-09-27 Akim Demaille <akim@epita.fr>
302
303 Playing with Autoscan.
304
305 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
306 * lib/Makefile.am (libbison_a_SOURCES): No longer include
307 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
308 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
309 Coreutils 4.5.1.
310
3112002-09-24 Akim Demaille <akim@epita.fr>
312
313 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
314 (Frequently Asked Questions, Parser Stack Overflow): New.
315
3162002-09-13 Akim Demaille <akim@epita.fr>
317
318 Playing with autoscan.
319
320 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
321 * src/files.c (skeleton_find): Remove, unused.
322 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
323 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
324
3252002-09-13 Akim Demaille <akim@epita.fr>
326
327 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
328 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
329
3302002-09-13 Akim Demaille <akim@epita.fr>
331
332 * configure.ac: Require 2.54.
333 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
334 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
335 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
336 Remove, provided by Autoconf macros.
337
3382002-09-12 Akim Demaille <akim@epita.fr>
339
340 * m4/prereq.m4: Update, from Coreutils 4.5.1.
341
3422002-09-12 Akim Demaille <akim@epita.fr>
343
344 * m4/prereq.m4: Update, from Fileutils 4.1.5.
345 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
346 Reported by Martin Mokrejs.
347
3482002-09-10 Akim Demaille <akim@epita.fr>
349
350 * src/parse-gram.y: Associate a human readable string to each
351 token type.
352 * tests/regression.at (Invalid inputs): Adjust.
353
3542002-09-10 Gary V. Vaughan <gary@gnu.org>
355
356 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
357 with an Autoconf-2.5x style configure.ac.
358
3592002-09-06 Paul Eggert <eggert@twinsun.com>
360
361 * doc/bison.texinfo (Conditions): Make explicit that the GPL
362 exception applies only to yacc.c. This is a modification of a
363 patch originally suggested by Akim Demaille.
364
3652002-09-06 Akim Demaille <akim@epita.fr>
366
367 * data/c.m4 (b4_copyright): Move the GPL exception comment from
368 here to...
369 * data/yacc.c: here.
370
371 * data/lalr1.cc (struct yyltype): Don't define it, since we use
372 LocationType.
373 (b4_ltype): Default to yy::Location from location.hh.
374
3752002-09-04 Jim Meyering <jim@meyering.net>
376
377 * data/yacc.c: Guard the declaration of yytoknum also with
378 `#ifdef YYPRINT', so it is declared only when used.
379
3802002-09-04 Akim Demaille <akim@epita.fr>
381
382 * configure.in: Rename as...
383 * configure.ac: this.
384 Bump to 1.49c.
385
3862002-09-04 Akim Demaille <akim@epita.fr>
387
388 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
389 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
390 translate maintainer only messages.
391
3922002-08-12 Paul Eggert <eggert@twinsun.com>
393
394 Version 1.49b.
395
396 * Makefile.am (SUBDIRS): Remove intl.
397 (DISTCLEANFILES): Remove.
398 * NEWS: Mention that GNU M4 is now required. Clarify what is
399 meant by "larger grammars". Mention the pt_BR translation.
400 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
401 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
402 Bump version from 0.11.2 to 0.11.5.
403 (BISON_PREREQ_STAGE): Remove.
404 (AM_GNU_GETTEXT): Use external gettext.
405 (AC_OUTPUT): Remove intl/Makefile.
406
407 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
408
409 * data/glr.c: Include string.h, for strlen.
410 (yyreportParseError): Use size_t for yysize.
411 (yy_yypstack): No longer nested inside yypstates, as nested
412 functions are not portable. Do not assume size_t is the
413 same width as int.
414 (yypstates): Do not assume that ptrdiff_t is the same width
415 as int, and similarly for yyposn and YYINDEX.
416
417 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
418
419 * lib/Makefile.am (INCLUDES): Do not include from the intl
420 directory, which has been removed.
421 * src/Makefile.am (INCLUDES): Likewise.
422
423 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
424 (bitsets_sources, additional_bitsets_sources, timevars_sources):
425 New vars.
426
427 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
428 * tests/Makefile.am (EXTRA_DIST): Likewise.
429
430 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
431 Do not assume that bitset_windex is the same width as unsigned.
432
433 * lib/abitset.c (abitset_unused_clear): Do not assume that
434 bitset_word is the same width as int.
435 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
436 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
437 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
438 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
439 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
440
441 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
442 portability to one's complement hosts!).
443 * lib/ebitset.c (ebitset_op1): Likewise.
444 * lib/lbitset.c (lbitset_op1): Likewise.
445
446 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
447 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
448 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
449 Sync with fileutils.
450 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
451 lib/gettext.h: Sync with diffutils.
452
453 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
454 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
455
456 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
457 PROTOTYPES to check for prototypes, and "defined __STDC__" to
458 check for void *.
459
460 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
461 size_t; the old version tried to do this but casted improperly.
462 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
463 (bitset_test): Now returns int, not unsigned long.
464
465 * lib/bitset_stats.c: Include "gettext.h".
466 (_): New macro.
467 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
468 name locals "index", as it generates unnecessary warnings on some
469 hosts that have an "index" function.
470
471 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
472 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
473 they need translation.
474 * src/LR0.c (state_list_append, new_itemsets, get_state,
475 append_states, generate_states): Likewise.
476 * src/assoc.c (assoc_to_string): Likewise.
477 * src/closure.c (print_closure, set_firsts, closure): Likewise.
478 * src/gram.c (grammar_dump): Likewise.
479 * src/injections.c (injections_compute): Likewise.
480 * src/lalr.c (lookaheads_print): Likewise.
481 * src/relation.c (relation_transpose): Likewise.
482 * src/scan-gram.l: Likewise.
483 * src/tables.c (table_grow, pack_vector): Likewise.
484
485 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
486 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
487 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
488 * m4/mbstate_t.m4: Sync with fileutils.
489 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
490
491 * po/LINGUAS: Add pt_BR.
492 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
493 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
494 lib/timevar.c.
495 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
496 manual recommends.
497 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
498
499 * src/complain.c (strerror_r): Remove decl; not needed.
500 (strerror): Use same pattern as ../lib/error.c.
501
502 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
503
504 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
505
506 * src/main.c (main): Cast result of bindtextdomain and textdomain
507 to void, to avoid a GCC warning when --disable-nls is in effect.
508
509 * src/scan-gram.l: Use strings rather than escapes when possible,
510 to minimize the number of warnings from xgettext.
511 (handle_action_dollar, handle_action_at): Don't use isdigit,
512 as it mishandles negative chars and it may not work as expected
513 outside the C locale.
514
515 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
516 this is a GCC extension and is not portable to other compilers.
517
518 * src/system.h (alloca): Use same pattern as ../lib/error.c.
519 Do not include <ctype.h>; no longer needed.
520 Do not include <malloc.h>; no longer needed (and generates
521 warnings on OpenBSD 3.0).
522
523 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
524 it's not portable.
525
526 * tests/regression.at: Do not use 'cc -c input.c -o input';
527 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
528
529 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
530 exit status as failure, not just exit status 1. Sun C exits
531 with status 2 sometimes.
532
533 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
534 Use it for the two large tests.
535
5362002-08-02 Akim Demaille <akim@epita.fr>
537
538 * src/conflicts.c (conflicts_output): Don't output rules never
539 reduced here, since anyway that computation doesn't work.
540 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
541 (rule_useless_p, rule_never_reduced_p): New.
542 (grammar_rules_partial_print): Use a filter instead of a range.
543 Display the title only if needed.
544 (grammar_rules_print): Adjust.
545 (grammar_rules_never_reduced_report): New.
546 * src/tables.c (action_row): Move the computation of rules never
547 reduced to...
548 (token_actions): here.
549 * src/main.c (main): Make the parser before making the report, so
550 that rules never reduced are computed.
551 Call grammar_rules_never_reduced_report.
552 * src/print.c (print_results): Report rules never reduced.
553 * tests/conflicts.at, tests/reduce.at: Adjust.
554
5552002-08-01 Akim Demaille <akim@epita.fr>
556
557 Instead of attaching lookaheads and duplicating the rules being
558 reduced by a state, attach the lookaheads to the reductions.
559
560 * src/state.h (state_t): Remove the `lookaheads',
561 `lookaheads_rule' member.
562 (reductions_t): Add a `lookaheads' member.
563 Use a regular array for the `rules'.
564 * src/state.c (reductions_new): Initialize the lookaheads member
565 to 0.
566 (state_rule_lookaheads_print): Adjust.
567 * src/state.h, src/state.c (state_reductions_find): New.
568 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
569 (count_rr_conflicts): Adjust.
570 * src/lalr.c (LArule): Remove.
571 (add_lookback_edge): Adjust.
572 (state_lookaheads_count): New.
573 (states_lookaheads_initialize): Merge into...
574 (initialize_LA): this.
575 (lalr_free): Adjust.
576 * src/main.c (main): Don't free nullable and derives too early: it
577 is used by --verbose.
578 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
579
5802002-08-01 Akim Demaille <akim@epita.fr>
581
582 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
583 `rule_number_t**'.
584 (set_derives, free_derives): Rename as...
585 (derives_compute, derives_free): this.
586 Adjust all dependencies.
587 * src/nullable.c (set_nullable, free_nullable): Rename as...
588 (nullable_compute, nullable_free): these.
589 (rule_list_t): Store rule_t *, not rule_number_t.
590 * src/state.c (state_rule_lookaheads_print): Directly compare rule
591 pointers, instead of their numbers.
592 * src/main.c (main): Call nullable_free, and derives_free earlier,
593 as they were lo longer used.
594
5952002-08-01 Akim Demaille <akim@epita.fr>
596
597 * lib/timevar.c (get_time): Include children time.
598 * src/lalr.h (LA, LArule): Don't export them: used with the
599 state_t.
600 * src/lalr.c (LA, LArule): Static.
601 * src/lalr.h, src/lalr.c (lalr_free): New.
602 * src/main.c (main): Call it.
603 * src/tables.c (pack_vector): Check whether loc is >= to the
604 table_size, not >.
605 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
606 (tables_generate): do it, since that's also it which allocates
607 them.
608 Don't free LA and LArule, main does.
609
6102002-07-31 Akim Demaille <akim@epita.fr>
611
612 Separate parser tables computation and output.
613
614 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
615 (conflict_list, conflict_list_cnt, table, check, table_ninf)
616 (yydefgoto, yydefact, high): Move to...
617 * src/tables.h, src/tables.c: here.
618 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
619 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
620 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
621 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
622 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
623 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
624 (action_row, save_row, token_actions, save_column, default_goto)
625 (goto_actions, sort_actions, matching_state, pack_vector)
626 (table_ninf_remap, pack_table, prepare_actions): Move to...
627 * src/tables.c: here.
628 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
629 * src/output.c (token_actions, output_base, output_conflicts)
630 (output_check): Merge into...
631 (prepare_actions): this.
632 (actions_output): Rename as...
633 (user_actions_output): this.
634 * src/main.c (main): Call tables_generate and tables_free.
635
6362002-07-31 Akim Demaille <akim@epita.fr>
637
638 Steal GCC's --time-report support.
639
640 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
641 stolen/adjusted from GCC.
642 * m4/stage.m4: Remove time related checks.
643 * m4/timevar.m4: New.
644 * configure.in: Adjust.
645 * src/system.h: Adjust to using timevar.h.
646 * src/getargs.h, src/getargs.c: Support trace_time for
647 --trace=time.
648 * src/main.c (stage): Remove.
649 (main): Replace `stage' invocations with timevar calls.
650 * src/output.c: Insert pertinent timevar calls.
651
6522002-07-31 Akim Demaille <akim@epita.fr>
653
654 Let --trace have arguments.
655
656 * src/getargs.h (enum trace_e): New.
657 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
658 (long_options, short_options): --trace/-T takes an optional
659 argument.
660 Change all the uses of trace_flag to reflect the new flags.
661 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
662
663 Strengthen `stage' portability.
664
665 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
666 * configure.in: Use it.
667 Don't check for malloc.h and sys/times.h.
668 * src/system.h: Include them when appropriate.
669 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
670 times and struct tms are available.
671
6722002-07-30 Akim Demaille <akim@epita.fr>
673
674 In verbose parse error message, don't report `error' as an
675 expected token.
676 * tests/actions.at (Printers and Destructors): Adjust.
677 * tests/calc.at (Calculator $1): Adjust.
678 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
679 error message, do not report the parser accepts the error token in
680 that state.
681
6822002-07-30 Akim Demaille <akim@epita.fr>
683
684 Normalize conflict related messages.
685
686 * src/complain.h, src/complain.c (warn, complain): New.
687 * src/conflicts.c (conflicts_print): Use them.
688 (conflict_report_yacc): New, extracted from...
689 (conflicts_print): here.
690 * tests/conflicts.at, tests/existing.at: Adjust.
691
6922002-07-30 Akim Demaille <akim@epita.fr>
693
694 Report rules which are never reduced by the parser: those hidden
695 by conflicts.
696
697 * src/LR0.c (save_reductions): Don't make the final state too
698 different: save its reduction (accept) instead of having a state
699 without any action (no shift or goto, no reduce).
700 Note: the final state is now a ``regular'' state, i.e., the
701 parsers now contain `reduce 0' as default reduction.
702 Nevertheless, since they decide to `accept' when yystate =
703 final_state, they still will not reduce rule 0.
704 * src/print.c (print_actions, print_reduction): Adjust.
705 * src/output.c (action_row): Track reduced rules.
706 (token_actions): Report rules never reduced.
707 * tests/conflicts.at, tests/regression.at: Adjust.
708
7092002-07-30 Akim Demaille <akim@epita.fr>
710
711 `stage' was accidently included in a previous patch.
712 Initiate its autoconfiscation.
713
714 * configure.in: Look for malloc.h and sys/times.h.
715 * src/main.c (stage): Adjust.
716 Report only when trace_flag.
717
7182002-07-29 Akim Demaille <akim@epita.fr>
719
720 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
721 state_number_t.
722 (errs_t): symbol_t*, not symbol_number_t.
723 (reductions_t): rule_t*, not rule_number_t.
724 (FOR_EACH_SHIFT): New.
725 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
726 * src/print.c, src/print_graph.c: Adjust.
727
7282002-07-29 Akim Demaille <akim@epita.fr>
729
730 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
731
732 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
733 (endtoken, accept): these.
734 * src/reader.c (reader): Set endtoken's default tag to "$end".
735 Set undeftoken's tag to "$undefined" instead of "$undefined.".
736 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
737 Adjust.
738
7392002-07-29 Akim Demaille <akim@epita.fr>
740
741 * src/reduce.c (reduce_grammar): When the language is empty,
742 complain about the start symbol, not the axiom.
743 Use its location.
744 * tests/reduce.at (Empty Language): New.
745
7462002-07-26 Akim Demaille <akim@epita.fr>
747
748 * src/reader.h, src/reader.c (gram_error): ... can't get
749 yycontrol without making too strong assumptions on the parser
750 itself.
751 * src/output.c (prepare_tokens): Use the real 0th value of
752 token_translations instead of `0'.
753 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
754 visible here.
755 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
756 for the time being: %locations ought to provide it to yyerror.
757
7582002-07-25 Akim Demaille <akim@epita.fr>
759
760 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
761 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
762 * tests/regression.at (Web2c Actions): Adjust.
763
7642002-07-25 Akim Demaille <akim@epita.fr>
765
766 Stop storing rules from 1 to nrules + 1.
767
768 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
769 * src/nullable.c, src/output.c, src/print.c, src/reader.c
770 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
771 Iterate from 0 to nrules.
772 Use rule_number_as_item_number and item_number_as_rule_number.
773 Adjust to `derive' now containing possibly 0.
774 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
775 Handle the `- 1' part in rule numbers from/to item numbers.
776 * src/conflicts.c (log_resolution): Fix the message which reversed
777 shift and reduce.
778 * src/output.c (action_row): Initialize default_rule to -1.
779 (token_actions): Adjust.
780 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
781 expected output.
782 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
783
7842002-07-25 Akim Demaille <akim@epita.fr>
785
786 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
787 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
788 (b4_c_knr_arg_decl): New.
789 * data/yacc.c: Use it to define yysymprint, yydestruct, and
790 yyreport_parse_error.
791
7922002-07-25 Akim Demaille <akim@epita.fr>
793
794 * data/yacc.c (yyreport_parse_error): New, extracted from...
795 (yyparse): here.
796 (yydestruct, yysymprint): Move above yyparse.
797 Be K&R compliant.
798
7992002-07-25 Akim Demaille <akim@epita.fr>
800
801 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
802 replace...
803 (b4_sint_type, b4_uint_type): these.
804 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
805 * tests/regression.at (Web2c Actions): Adjust.
806
8072002-07-25 Akim Demaille <akim@epita.fr>
808
809 * src/gram.h (TIEM_NUMBER_MAX): New.
810 (item_number_of_rule_number, rule_number_of_item_number): Rename
811 as...
812 (rule_number_as_item_number, item_number_as_rule_number): these.
813 Adjust dependencies.
814 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
815 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
816 (symbol_number_to_vector_number): New.
817 (order): Of vector_number_t* type.
818 (base_t, BASE_MAX, BASE_MIN): New.
819 (froms, tos, width, pos, check): Of base_t type.
820 (action_number_t, ACTION_MIN, ACTION_MAX): New.
821 (actrow): Of action_number_t type.
822 (conflrow): Of unsigned int type.
823 (table_ninf, base_ninf): New.
824 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
825 (muscle_insert_int_table, muscle_insert_base_table)
826 (muscle_insert_rule_number_table): New.
827 (prepare_tokens): Output `toknum' as int_table.
828 (action_row): Returns a rule_number_t.
829 Use ACTION_MIN, not SHRT_MIN.
830 (token_actions): yydefact is rule_number_t*.
831 (table_ninf_remap): New.
832 (pack_table): Use it for `base' and `table'.
833 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
834 replaced with...
835 (YYPACT_NINF, YYTABLE_NINF): these.
836 (yypact, yytable): Compute their types instead of hard-coded
837 `short'.
838 * tests/regression.at (Web2c Actions): Adjust.
839
8402002-07-19 Akim Demaille <akim@epita.fr>
841
842 * src/scan-gram.l (id): Can start with an underscore.
843
8442002-07-16 Akim Demaille <akim@epita.fr>
845
846 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
847 Adjust all former `associativity' dependencies.
848 * src/symtab.c (symbol_new): Default associativity is `undef', not
849 `right'.
850 (symbol_check_alias_consistence): Adjust.
851
8522002-07-09 Akim Demaille <akim@epita.fr>
853
854 * doc/bison.texinfo: Properly set the ``header'' part.
855 Use @dircategory ``GNU programming tools'' as per Texinfo's
856 documentation.
857 Use @copying.
858
8592002-07-09 Akim Demaille <akim@epita.fr>
860
861 * lib/quotearg.h: Protect against multiple inclusions.
862 * src/location.h (location_t): Add a `file' member.
863 (LOCATION_RESET, LOCATION_PRINT): Adjust.
864 * src/complain.c (warn_at, complain_at, fatal_at): Drop
865 `error_one_per_line' support.
866
8672002-07-09 Akim Demaille <akim@epita.fr>
868
869 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
870 * src/reader.c (lineno): Remove.
871 Adjust all dependencies.
872 (get_merge_function): Take a location and use complain_at.
873 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
874 * tests/regression.at (Invalid inputs, Mixing %token styles):
875 Adjust.
876
8772002-07-09 Akim Demaille <akim@epita.fr>
878
879 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
880 recovery rule, and forbid extensions when --yacc.
881 (gram_error): Use complain_at.
882 * src/reader.c (reader): Exit if there were parse errors.
883
8842002-07-09 Akim Demaille <akim@epita.fr>
885
886 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
887 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
888 Reported by R Blake <blakers@mac.com>.
889
8902002-07-09 Akim Demaille <akim@epita.fr>
891
892 * data/yacc.c: Output the copyright notive in the header.
893
8942002-07-03 Akim Demaille <akim@epita.fr>
895
896 * src/output.c (froms, tos): Are state_number_t.
897 (save_column): sp, sp1, and sp2 are state_number_t.
898 (prepare): Rename `final' as `final_state_number', `nnts' as
899 `nterms_number', `nrules' as `rules_number', `nstates' as
900 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
901 unused.
902 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
903 * data/lalr1.cc (nsym_): Remove, unused.
904
9052002-07-03 Akim Demaille <akim@epita.fr>
906
907 * src/lalr.h, src/lalr.c (goto_number_t): New.
908 * src/lalr.c (goto_list_t): New.
909 Propagate them.
910 * src/nullable.c (rule_list_t): New.
911 Propagate.
912 * src/types.h: Remove.
913
9142002-07-03 Akim Demaille <akim@epita.fr>
915
916 * src/closure.c (print_fderives): Use rule_rhs_print.
917 * src/derives.c (print_derives): Use rule_rhs_print.
918 (rule_list_t): New, replaces `shorts'.
919 (set_derives): Add comments.
920 * tests/sets.at (Nullable, Firsts): Adjust.
921
9222002-07-03 Akim Demaille <akim@epita.fr>
923
924 * src/output.c (prepare_actions): Free `tally' and `width'.
925 (prepare_actions): Allocate and free `order'.
926 * src/symtab.c (symbols_free): Free `symbols'.
927 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
928 * src/output.c (m4_invoke): Move to...
929 * src/scan-skel.l: here.
930 (<<EOF>>): Close yyout, and free its name.
931
9322002-07-03 Akim Demaille <akim@epita.fr>
933
934 Fix some memory leaks, and fix a bug: state 0 was examined twice.
935
936 * src/LR0.c (new_state): Merge into...
937 (state_list_append): this.
938 (new_states): Merge into...
939 (generate_states): here.
940 (set_states): Don't ensure a proper `errs' state member here, do it...
941 * src/conflicts.c (conflicts_solve): here.
942 * src/state.h, src/state.c: Comment changes.
943 (state_t): Rename member `shifts' as `transitions'.
944 Adjust all dependencies.
945 (errs_new): For consistency, also take the values as argument.
946 (errs_dup): Remove.
947 (state_errs_set): New.
948 (state_reductions_set, state_transitions_set): Assert that no
949 previous value was assigned.
950 (state_free): New.
951 (states_free): Use it.
952 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
953 temporary storage: use `errs' and `nerrs' as elsewhere.
954 (set_conflicts): Allocate and free this `errs'.
955
9562002-07-02 Akim Demaille <akim@epita.fr>
957
958 * lib/libiberty.h: New.
959 * lib: Update the bitset implementation from upstream.
960 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
961 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
962 * src/main.c: Adjust bitset stats calls.
963
9642002-07-01 Paul Eggert <eggert@twinsun.com>
965
966 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
967 char, so that negative chars don't collide with $.
968
9692002-06-30 Akim Demaille <akim@epita.fr>
970
971 Have the GLR tests be `warning' checked, and fix the warnings.
972
973 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
974 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
975 (yyremoveDeletes): `yyi' and `yyj' are size_t.
976 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
977 (yyaddDeferredAction): static.
978 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
979 (yyreportParseError): yyprefix is const.
980 yytokenp is used only when verbose.
981 (yy__GNUC__): Replace with __GNUC__.
982 (yypdumpstack): yyi is size_t.
983 (yypreference): Un-yy local variables and arguments, to avoid
984 clashes with `yyr1'. Anyway, we are not in the user name space.
985 (yytname_size): be an int, as is compared with ints.
986 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
987 Use them.
988 * tests/cxx-gram.at: Use quotation to protect $1.
989 Use AT_COMPILE to enable warnings hunts.
990 Prototype yylex and yyerror.
991 `Use' argc.
992 Include `string.h', not `strings.h'.
993 Produce and prototype stmtMerge only when used.
994 yylex takes a location.
995
9962002-06-30 Akim Demaille <akim@epita.fr>
997
998 We spend a lot of time in quotearg, in particular when --verbose.
999
1000 * src/symtab.c (symbol_get): Store a quoted version of the key.
1001 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
1002 Adjust all callers.
1003
10042002-06-30 Akim Demaille <akim@epita.fr>
1005
1006 * src/state.h (reductions_t): Rename member `nreds' as num.
1007 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
1008 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
1009
10102002-06-30 Akim Demaille <akim@epita.fr>
1011
1012 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
1013 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
1014 (shifts_to): Rename as...
1015 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1016 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1017 (TRANSITION_IS_DISABLED, transitions_to): these.
1018
10192002-06-30 Akim Demaille <akim@epita.fr>
1020
1021 * src/print.c (print_shifts, print_gotos): Merge into...
1022 (print_transitions): this.
1023 (print_transitions, print_errs, print_reductions): Align the
1024 lookaheads columns.
1025 (print_core, print_transitions, print_errs, print_state,
1026 print_grammar): Output empty lines separator before, not after.
1027 (state_default_rule_compute): Rename as...
1028 (state_default_rule): this.
1029 * tests/conflicts.at (Defaulted Conflicted Reduction),
1030 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1031 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1032
10332002-06-30 Akim Demaille <akim@epita.fr>
1034
1035 Display items as we display rules.
1036
1037 * src/gram.h, src/gram.c (rule_lhs_print): New.
1038 * src/gram.c (grammar_rules_partial_print): Use it.
1039 * src/print.c (print_core): Likewise.
1040 * tests/conflicts.at (Defaulted Conflicted Reduction),
1041 (Unresolved SR Conflicts): Adjust.
1042 (Unresolved SR Conflicts): Adjust and rename as...
1043 (Resolved SR Conflicts): this, as was meant.
1044 * tests/regression.at (Web2c Report): Adjust.
1045
10462002-06-30 Akim Demaille <akim@epita.fr>
1047
1048 * src/print.c (state_default_rule_compute): New, extracted from...
1049 (print_reductions): here.
1050 Pessimize, but clarify the code.
1051 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1052
10532002-06-30 Akim Demaille <akim@epita.fr>
1054
1055 * src/output.c (action_row): Let default_rule be always a rule
1056 number.
1057
10582002-06-30 Akim Demaille <akim@epita.fr>
1059
1060 * src/closure.c (print_firsts, print_fderives, closure):
1061 Use BITSET_EXECUTE.
1062 * src/lalr.c (lookaheads_print): Likewise.
1063 * src/state.c (state_rule_lookaheads_print): Likewise.
1064 * src/print_graph.c (print_core): Likewise.
1065 * src/print.c (print_reductions): Likewise.
1066 * src/output.c (action_row): Likewise.
1067 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1068
10692002-06-30 Akim Demaille <akim@epita.fr>
1070
1071 * src/print_graph.c: Use report_flag.
1072
10732002-06-30 Akim Demaille <akim@epita.fr>
1074
1075 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1076 to...
1077 * src/relation.h, src/relation.c (traverse, relation_digraph)
1078 (relation_print, relation_transpose): New.
1079
10802002-06-30 Akim Demaille <akim@epita.fr>
1081
1082 * src/state.h, src/state.c (shifts_to): New.
1083 * src/lalr.c (build_relations): Use it.
1084
10852002-06-30 Akim Demaille <akim@epita.fr>
1086
1087 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1088 (item_number_of_rule_number, rule_number_of_item_number): New.
1089 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1090 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1091 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1092 Propagate their use.
1093 Much remains to be done, in particular wrt `shorts' from types.h.
1094
10952002-06-30 Akim Demaille <akim@epita.fr>
1096
1097 * src/symtab.c (symbol_new): Initialize the `printer' member.
1098
10992002-06-30 Akim Demaille <akim@epita.fr>
1100
1101 * src/LR0.c (save_reductions): Remove, replaced by...
1102 * src/state.h, src/state.c (state_reductions_set): New.
1103 (reductions, errs): Rename as...
1104 (reductions_t, errs_t): these.
1105 Adjust all dependencies.
1106
11072002-06-30 Akim Demaille <akim@epita.fr>
1108
1109 * src/LR0.c (state_list_t, state_list_append): New.
1110 (first_state, last_state): Now symbol_list_t.
1111 (this_state): Remove.
1112 (new_itemsets, append_states, save_reductions): Take a state_t as
1113 argument.
1114 (set_states, generate_states): Adjust.
1115 (save_shifts): Remove, replaced by...
1116 * src/state.h, src/state.c (state_shifts_set): New.
1117 (shifts): Rename as...
1118 (shifts_t): this.
1119 Adjust all dependencies.
1120 * src/state.h (state_t): Remove the `next' member.
1121
11222002-06-30 Akim Demaille <akim@epita.fr>
1123
1124 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1125 escaped in slot 0.
1126
11272002-06-30 Akim Demaille <akim@epita.fr>
1128
1129 Use hash.h for the state hash table.
1130
1131 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1132 (allocate_storage): Use state_hash_new.
1133 (free_storage): Use state_hash_free.
1134 (new_state, get_state): Adjust.
1135 * src/lalr.h, src/lalr.c (states): Move to...
1136 * src/states.h (state_t): Remove the `link' member, no longer
1137 used.
1138 * src/states.h, src/states.c: here.
1139 (state_hash_new, state_hash_free, state_hash_lookup)
1140 (state_hash_insert, states_free): New.
1141 * src/states.c (state_table, state_compare, state_hash): New.
1142 * src/output.c (output_actions): Do not free states now, since we
1143 still need to know the final_state number in `prepare', called
1144 afterwards. Do it...
1145 * src/main.c (main): here: call states_free after `output'.
1146
11472002-06-30 Akim Demaille <akim@epita.fr>
1148
1149 * src/state.h, src/state.c (state_new): New, extracted from...
1150 * src/LR0.c (new_state): here.
1151 * src/state.h (STATE_ALLOC): Move to...
1152 * src/state.c: here.
1153 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1154 * src/state.h, src/state.c: here.
1155
11562002-06-30 Akim Demaille <akim@epita.fr>
1157
1158 * src/reader.c (gensym): Rename as...
1159 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1160 (getsym): Rename as...
1161 (symbol_get): this.
1162
11632002-06-30 Akim Demaille <akim@epita.fr>
1164
1165 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1166 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1167 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1168 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1169
11702002-06-30 Akim Demaille <akim@epita.fr>
1171
1172 Make the test suite pass with warnings checked.
1173
1174 * tests/actions.at (Printers and Destructors): Improve.
1175 Avoid unsigned vs. signed issues.
1176 * tests/calc.at: Don't exercise the scanner here, do it...
1177 * tests/input.at (Torturing the Scanner): here.
1178
11792002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1180
1181 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
1182 reorganize first lines parallel to yacc.c.
1183
11842002-06-28 Akim Demaille <akim@epita.fr>
1185
1186 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1187 (b4_token_enum, b4_token_defines): New, factored from...
1188 * data/lalr1.cc, data/yacc.c, glr.c: here.
1189
11902002-06-28 Akim Demaille <akim@epita.fr>
1191
1192 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1193 unused variables.
1194 * src/output.c (merger_output): static.
1195
11962002-06-28 Akim Demaille <akim@epita.fr>
1197
1198 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1199 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1200 pacify GCC.
1201 * src/output.c (save_row): Initialize all the variables to pacify GCC.
1202
12032002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1204
1205 Accumulated changelog for new GLR parsing features.
1206
1207 * src/conflicts.c (count_total_conflicts): Change name to
1208 conflicts_total_count.
1209 * src/conflicts.h: Ditto.
1210 * src/output.c (token_actions): Use the new name.
1211 (output_conflicts): Change conflp => conflict_list_heads, and
1212 confl => conflict_list for better readability.
1213 * data/glr.c: Use the new names.
1214 * NEWS: Add self to GLR announcement.
1215
1216 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1217
1218 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1219 Akim Demaille.
1220
1221 * data/bison.glr: Change name to glr.c
1222 * data/glr.c: Renamed from bison.glr.
1223 * data/Makefile.am: Add glr.c
1224
1225 * src/getargs.c:
1226
1227 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1228 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
1229
1230 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1231
1232 * data/bison.glr: Be sure to restore the
1233 current #line when returning to the skeleton contents after having
1234 exposed the input file's #line.
1235
1236 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1237
1238 * data/bison.glr: Bring up to date with changes to bison.simple.
1239
1240 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1241
1242 * data/bison.glr: Correct definitions that use b4_prefix.
1243 Various reformatting.
1244 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1245 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1246 yytokenp argument; now part of stack.
1247 (yychar): Define to behave as documented.
1248 (yyclearin): Ditto.
1249
1250 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1251
1252 * src/reader.h: Add declaration for free_merger_functions.
1253
1254 * src/reader.c (merge_functions): New variable.
1255 (get_merge_function): New function.
1256 (free_merger_functions): New function.
1257 (readgram): Check for %prec that is not followed by a symbol.
1258 Handle %dprec and %merge declarations.
1259 (packgram): Initialize dprec and merger fields in rules array.
1260
1261 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1262 conflict_list_cnt, conflict_list_free): New variables.
1263 (table_grow): Also grow conflict_table.
1264 (prepare_rules): Output dprec and merger tables.
1265 (conflict_row): New function.
1266 (action_row): Output conflict lists for GLR parser. Don't use
1267 default reduction in conflicted states for GLR parser so that there
1268 are spaces for the conflict lists.
1269 (save_row): Also save conflict information.
1270 (token_actions): Allocate conflict list.
1271 (merger_output): New function.
1272 (pack_vector): Pack conflict table, too.
1273 (output_conflicts): New function to output yyconflp and yyconfl.
1274 (output_check): Allocate conflict_tos.
1275 (output_actions): Output conflict tables, also.
1276 (output_skeleton): Output b4_mergers definition.
1277 (prepare): Output b4_max_rhs_length definition.
1278 Use 'bison.glr' as default skeleton for GLR parsers.
1279
1280 * src/gram.c (glr_parser): New flag.
1281 (grammar_free): Call free_merger_functions.
1282
1283 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1284 all pairs of conflicting reductions, rather than just all tokens
1285 causing conflicts. Needed to size conflict tables.
1286 (conflicts_output): Modify call to count_rr_conflicts for new
1287 interface.
1288 (conflicts_print): Ditto.
1289 (count_total_conflicts): New function.
1290
1291 * src/reader.h (merger_list): New type.
1292 (merge_functions): New variable.
1293
1294 * src/lex.h (tok_dprec, tok_merge): New token types.
1295
1296 * src/gram.h (rule_s): Add dprec and merger fields.
1297 (glr_parser): New flag.
1298
1299 * src/conflicts.h (count_total_conflicts): New function.
1300
1301 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1302
1303 * doc/bison.texinfo (Generalized LR Parsing): New section.
1304 (GLR Parsers): New section.
1305 (Language and Grammar): Mention GLR parsing.
1306 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1307 Correct typo ("tge" -> "the").
1308
1309 * data/bison.glr: New skeleton for GLR parsing.
1310
1311 * tests/cxx-gram.at: New tests for GLR parsing.
1312
1313 * tests/testsuite.at: Include cxx-gram.at.
1314
1315 * tests/Makefile.am: Add cxx-gram.at.
1316
1317 * src/parse-gram.y:
1318
1319 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1320
1321 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
1322
13232002-06-27 Akim Demaille <akim@epita.fr>
1324
1325 * src/options.h, src/options.c: Remove.
1326 * src/getargs.c (short_options, long_options): New.
1327
13282002-06-27 Akim Demaille <akim@epita.fr>
1329
1330 * data/bison.simple, data/bison.c++: Rename as...
1331 * data/yacc.c, data/lalr1.cc: these.
1332 * doc/bison.texinfo (Environment Variables): Remove.
1333
13342002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1335
1336 * src/getargs.c (report_argmatch): Initialize strtok().
1337
13382002-06-20 Akim Demaille <akim@epita.fr>
1339
1340 * data/bison.simple (b4_symbol_actions): New, replaces...
1341 (b4_symbol_destructor, b4_symbol_printer): these.
1342 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1343 user token numbers.
1344
13452002-06-20 Akim Demaille <akim@epita.fr>
1346
1347 * data/bison.simple (yydestructor): Rename as...
1348 (yydestruct): this.
1349
13502002-06-20 Akim Demaille <akim@epita.fr>
1351
1352 * src/symtab.h, src/symtab.c (symbol_type_set)
1353 (symbol_destructor_set, symbol_precedence_set): The location is
1354 the last argument.
1355 Adjust all callers.
1356
13572002-06-20 Akim Demaille <akim@epita.fr>
1358
1359 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1360 internals.
1361 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1362 Takes a location.
1363 * src/symtab.h, src/symtab.c (symbol_class_set)
1364 (symbol_user_token_number_set): Likewise.
1365 Adjust all callers.
1366 Promote complain_at.
1367 * tests/input.at (Type Clashes): Adjust.
1368
13692002-06-20 Akim Demaille <akim@epita.fr>
1370
1371 * data/bison.simple (YYLEX): Fix the declaration when
1372 %pure-parser.
1373
13742002-06-20 Akim Demaille <akim@epita.fr>
1375
1376 * data/bison.simple (yysymprint): Don't print the token number,
1377 just its name.
1378 * tests/actions.at (Destructors): Rename as...
1379 (Printers and Destructors): this.
1380 Also exercise %printer.
1381
13822002-06-20 Akim Demaille <akim@epita.fr>
1383
1384 * data/bison.simple (YYDSYMPRINT): New.
1385 Use it to remove many of the #if YYDEBUG/if (yydebug).
1386
13872002-06-20 Akim Demaille <akim@epita.fr>
1388
1389 * src/symtab.h, src/symtab.c (symbol_t): printer and
1390 printer_location are new members.
1391 (symbol_printer_set): New.
1392 * src/parse-gram.y (PERCENT_PRINTER): New token.
1393 Handle its associated rule.
1394 * src/scan-gram.l: Adjust.
1395 (handle_destructor_at, handle_destructor_dollar): Rename as...
1396 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1397 * src/output.c (symbol_printers_output): New.
1398 (output_skeleton): Call it.
1399 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1400 since there are already many grammar files with a user `yyprint'.
1401 Replace the calls to YYPRINT to calls to yysymprint.
1402 * tests/calc.at: Adjust.
1403 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1404 taking advantage of parser very internal details (stack size!).
1405
14062002-06-20 Akim Demaille <akim@epita.fr>
1407
1408 * src/scan-gram.l: Complete the scanner with the missing patterns
1409 to pacify Flex.
1410 Use `quote' and `symbol_tag_get' where appropriate.
1411
14122002-06-19 Akim Demaille <akim@epita.fr>
1413
1414 * tests/actions.at (Destructors): Augment to test locations.
1415 * data/bison.simple (yydestructor): Pass it the current location
1416 if locations are enabled.
1417 Prototype only when __STDC__ or C++.
1418 Change the argument names to move into the yy name space: there is
1419 user code here.
1420
14212002-06-19 Akim Demaille <akim@epita.fr>
1422
1423 * data/bison.simple (b4_pure_if): New.
1424 Use it instead of #ifdef YYPURE.
1425
14262002-06-19 Akim Demaille <akim@epita.fr>
1427
1428 * data/bison.simple (b4_location_if): New.
1429 Use it instead of #ifdef YYLSP_NEEDED.
1430
14312002-06-19 Akim Demaille <akim@epita.fr>
1432
1433 Prepare @$ in %destructor, but currently don't bind it in the
1434 skeleton, as %location use is not cleaned up yet.
1435
1436 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1437 (handle_action_at): New.
1438 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1439 a braced_code_t and a location as additional arguments.
1440 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1441 unquote one when outputting `b4_dollar_dollar'.
1442 Adjust callers.
1443 * data/bison.simple (b4_eval): Remove.
1444 (b4_symbol_destructor): Adjust.
1445 * tests/input.at (Invalid @n): Adjust.
1446
14472002-06-19 Zack Weinberg <zack@codesourcery.com>
1448
1449 * doc/bison.texinfo: Document ability to have multiple
1450 prologue sections.
1451
14522002-06-18 Akim Demaille <akim@epita.fr>
1453
1454 * src/files.c (compute_base_names): When computing the output file
1455 names from the input file name, strip the directory part.
1456
14572002-06-18 Akim Demaille <akim@epita.fr>
1458
1459 * data/bison.simple.new: Comment changes.
1460 Reported by Andreas Schwab.
1461
14622002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1463
1464 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1465 there are no `label `yyoverflowlab' defined but not used' warnings
1466 when yyoverflow is defined.
1467
14682002-06-18 Akim Demaille <akim@epita.fr>
1469
1470 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1471 new member.
1472 (symbol_destructor_set): Adjust.
1473 * src/output.c (symbol_destructors_output): Output the destructor
1474 locations.
1475 Output the symbol name.
1476 * data/bison.simple (b4_symbol_destructor): Adjust.
1477
14782002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1479 and Akim Demaille <akim@epita.fr>
1480
1481 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1482 what's left on the stack when the error recovery hits EOF.
1483 * tests/actions.at (Destructors): Complete to exercise this case.
1484
14852002-06-17 Akim Demaille <akim@epita.fr>
1486
1487 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1488 arguments is really empty, not only equal to `[]'.
1489 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1490 member.
1491 (symbol_destructor_set): New.
1492 * src/output.c (symbol_destructors_output): New.
1493 * src/reader.h (brace_code_t, current_braced_code): New.
1494 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1495 (handle_dollar): Rename as...
1496 (handle_action_dollar): this.
1497 (handle_destructor_dollar): New.
1498 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1499 (grammar_declaration): Use it.
1500 * data/bison.simple (yystos): Is always defined.
1501 (yydestructor): New.
1502 * tests/actions.at (Destructors): New.
1503 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1504
15052002-06-17 Akim Demaille <akim@epita.fr>
1506
1507 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1508 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1509 rule_length only when needed.
1510 * src/output.c (actions_output, token_definitions_output): Output
1511 the full M4 block.
1512 * src/symtab.c: Don't access directly to the symbol tag, use
1513 symbol_tag_get.
1514 * src/parse-gram.y: Use symbol_list_free.
1515
15162002-06-17 Akim Demaille <akim@epita.fr>
1517
1518 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1519 (symbol_list_prepend, get_type_name): Move to...
1520 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1521 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1522 Adjust all callers.
1523 (symbol_list_free): New.
1524 * src/scan-gram.l (handle_dollar): Takes a location.
1525 * tests/input.at (Invalid $n): Adjust.
1526
15272002-06-17 Akim Demaille <akim@epita.fr>
1528
1529 * src/reader.h, src/reader.c (symbol_list_new): Export it.
1530 (symbol_list_prepend): New.
1531 * src/parse-gram.y (%union): `list' is a new member.
1532 (symbols.1): New, replaces...
1533 (terms_to_prec.1, nterms_to_type.1): these.
1534 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
1535 Take a location as additional argument.
1536 Adjust all callers.
1537
15382002-06-15 Akim Demaille <akim@epita.fr>
1539
1540 * src/parse-gram.y: Move %token in the declaration section so that
1541 we don't depend upon CVS Bison.
1542
15432002-06-15 Akim Demaille <akim@epita.fr>
1544
1545 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
1546 * src/print.c (print_core): Use it.
1547
15482002-06-15 Akim Demaille <akim@epita.fr>
1549
1550 * src/conflicts.c (log_resolution): Accept the rule involved in
1551 the sr conflicts instead of the lookahead number that points to
1552 that rule.
1553 (flush_reduce): Accept the current lookahead vector as argument,
1554 instead of the index in LA.
1555 (resolve_sr_conflict): Accept the current number of lookahead
1556 bitset to consider for the STATE, instead of the index in LA.
1557 (set_conflicts): Adjust.
1558 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
1559
15602002-06-15 Akim Demaille <akim@epita.fr>
1561
1562 * src/state.h (state_t): Replace the `lookaheadsp' member, a
1563 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
1564 Adjust all dependencies.
1565 * src/lalr.c (initialize_lookaheads): Split into...
1566 (states_lookaheads_count, states_lookaheads_initialize): these.
1567 (lalr): Adjust.
1568
15692002-06-15 Akim Demaille <akim@epita.fr>
1570
1571 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
1572 out of...
1573 (grammar_rules_print): here.
1574 * src/reduce.c (reduce_output): Use it.
1575 * tests/reduce.at (Useless Rules, Reduced Automaton)
1576 (Underivable Rules): Adjust.
1577
15782002-06-15 Akim Demaille <akim@epita.fr>
1579
1580 Copy BYacc's nice way to report the grammar.
1581
1582 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
1583 New.
1584 Don't print the rules' location, it is confusing and useless.
1585 (rule_print): Use grammar_rhs_print.
1586 * src/print.c (print_grammar): Use grammar_rules_print.
1587
15882002-06-15 Akim Demaille <akim@epita.fr>
1589
1590 Complete and rationalize `useless thing' warnings.
1591
1592 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
1593 (symbol_tag_print): New.
1594 Use them everywhere in place of accessing directly the tag member.
1595 * src/gram.h, src/gram.c (rule_print): New.
1596 Use it where a rule used to be printed `by hand'.
1597 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
1598 (reduce_grammar_tables): Report the useless rules.
1599 (reduce_print): Useless things are a warning, not an error.
1600 Report it as such.
1601 * tests/reduce.at (Useless Nonterminals, Useless Rules):
1602 (Reduced Automaton, Underivable Rules): Adjust.
1603 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
1604 * tests/conflicts.at (Unresolved SR Conflicts)
1605 (Solved SR Conflicts): Adjust.
1606
16072002-06-15 Akim Demaille <akim@epita.fr>
1608
1609 Let symbols have a location.
1610
1611 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
1612 (getsym): Adjust.
1613 Adjust all callers.
1614 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
1615 Use location_t, not int.
1616 * src/symtab.c (symbol_check_defined): Take advantage of the
1617 location.
1618 * tests/regression.at (Invalid inputs): Adjust.
1619
16202002-06-15 Akim Demaille <akim@epita.fr>
1621
1622 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
1623 (input): Don't try to initialize yylloc here, do it in the
1624 scanner.
1625 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
1626 * src/gram.h (rule_t): Change line and action_line into location
1627 and action_location, of location_t type.
1628 Adjust all dependencies.
1629 * src/location.h, src/location.c (empty_location): New.
1630 * src/reader.h, src/reader.c (grammar_start_symbol_set)
1631 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
1632 (grammar_current_rule_symbol_append)
1633 (grammar_current_rule_action_append): Expect a location as argument.
1634 * src/reader.c (grammar_midrule_action): Adjust to attach an
1635 action's location as dummy symbol location.
1636 * src/symtab.h, src/symtab.c (startsymbol_location): New.
1637 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
1638 the line numbers.
1639
16402002-06-14 Akim Demaille <akim@epita.fr>
1641
1642 Grammar declarations may be found in the grammar section.
1643
1644 * src/parse-gram.y (rules_or_grammar_declaration): New.
1645 (declarations): Each declaration may end with a semicolon, not
1646 just...
1647 (grammar_declaration): `"%union"'.
1648 (grammar): Branch to rules_or_grammar_declaration.
1649
16502002-06-14 Akim Demaille <akim@epita.fr>
1651
1652 * src/main.c (main): Invoke scanner_free.
1653
16542002-06-14 Akim Demaille <akim@epita.fr>
1655
1656 * src/output.c (m4_invoke): Extracted from...
1657 (output_skeleton): here.
1658 Free tempfile.
1659
16602002-06-14 Akim Demaille <akim@epita.fr>
1661
1662 * src/parse-gram.y (directives, directive, gram)
1663 (grammar_directives, precedence_directives, precedence_directive):
1664 Rename as...
1665 (declarations, declaration, grammar, grammar_declaration)
1666 (precedence_declaration, precedence_declarator): these.
1667 (symbol_declaration): New.
1668
16692002-06-14 Akim Demaille <akim@epita.fr>
1670
1671 * src/files.c (action_obstack): Remove, unused.
1672 (output_obstack): Remove it, and all its dependencies, as it is no
1673 longer needed.
1674 * src/reader.c (epilogue_set): Build the epilogue in the
1675 muscle_obstack.
1676 * src/output.h, src/output.c (muscle_obstack): Move to...
1677 * src/muscle_tab.h, src/muscle_tab.h: here.
1678 (muscle_init): Initialize muscle_obstack.
1679 (muscle_free): New.
1680 * src/main.c (main): Call it.
1681
16822002-06-14 Akim Demaille <akim@epita.fr>
1683
1684 * src/location.h: New, extracted from...
1685 * src/reader.h: here.
1686 * src/Makefile.am (noinst_HEADERS): Merge into
1687 (bison_SOURCES): this.
1688 Add location.h.
1689 * src/parse-gram.y: Use location_t instead of Bison's.
1690 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
1691 Use location_t instead of ints.
1692
16932002-06-14 Akim Demaille <akim@epita.fr>
1694
1695 * data/bison.simple, data/bison.c++: Be sure to restore the
1696 current #line when returning to the skeleton contents after having
1697 exposed the input file's #line.
1698
16992002-06-12 Akim Demaille <akim@epita.fr>
1700
1701 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
1702 eager.
1703 * tests/actions.at (Exotic Dollars): New.
1704
17052002-06-12 Akim Demaille <akim@epita.fr>
1706
1707 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
1708 ['"/] too eagerly.
1709 * tests/input.at (Torturing the Scanner): New.
1710
17112002-06-11 Akim Demaille <akim@epita.fr>
1712
1713 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
1714 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
1715 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
1716 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
1717 * src/reader.c (reader): Use it.
1718
17192002-06-11 Akim Demaille <akim@epita.fr>
1720
1721 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
1722 Adjust all callers.
1723 (scanner_last_string_free): New.
1724
17252002-06-11 Akim Demaille <akim@epita.fr>
1726
1727 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
1728 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
1729 (last_string, YY_OBS_FREE): New.
1730 Use them when returning an ID.
1731
17322002-06-11 Akim Demaille <akim@epita.fr>
1733
1734 Have Bison grammars parsed by a Bison grammar.
1735
1736 * src/reader.c, src/reader.h (prologue_augment): New.
1737 * src/reader.c (copy_definition): Remove.
1738
1739 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
1740 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
1741 (grammar_current_rule_prec_set, grammar_current_rule_check)
1742 (grammar_current_rule_symbol_append)
1743 (grammar_current_rule_action_append): Export.
1744 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
1745 (symbol_list_action_append): Remove.
1746 Hook the routines from reader.
1747 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
1748 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
1749
1750 * src/reader.c (read_declarations): Remove, unused.
1751
1752 * src/parse-gram.y: Handle the epilogue.
1753 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
1754 (grammar_start_symbol_set): this.
1755 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
1756 * src/reader.c (readgram): Remove, unused.
1757 (reader): Adjust to insert eoftoken and axiom where appropriate.
1758
1759 * src/reader.c (copy_dollar): Replace with...
1760 * src/scan-gram.h (handle_dollar): this.
1761 * src/parse-gram.y: Remove `%thong'.
1762
1763 * src/reader.c (copy_at): Replace with...
1764 * src/scan-gram.h (handle_at): this.
1765
1766 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
1767 New.
1768
1769 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
1770 time being.
1771
1772 * src/reader.h, src/reader.c (grammar_rule_end): New.
1773
1774 * src/parse.y (current_type, current_class): New.
1775 Implement `%nterm', `%token' support.
1776 Merge `%term' into `%token'.
1777 (string_as_id): New.
1778 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
1779 type name.
1780
1781 * src/parse-gram.y: Be sure to handle properly the beginning of
1782 rules.
1783
1784 * src/parse-gram.y: Handle %type.
1785 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
1786
1787 * src/parse-gram.y: More directives support.
1788 * src/options.c: No longer handle source directives.
1789
1790 * src/parse-gram.y: Fix %output.
1791
1792 * src/parse-gram.y: Handle %union.
1793 Use the prologue locations.
1794 * src/reader.c (parse_union_decl): Remove.
1795
1796 * src/reader.h, src/reader.c (epilogue_set): New.
1797 * src/parse-gram.y: Use it.
1798
1799 * data/bison.simple, data/bison.c++: b4_stype is now either not
1800 defined, then default to int, or to the contents of %union,
1801 without `union' itself.
1802 Adjust.
1803 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
1804
1805 * src/output.c (actions_output): Don't output braces, as they are
1806 already handled by the scanner.
1807
1808 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
1809 characters to themselves.
1810
1811 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
1812 that the epilogue has a proper #line.
1813
1814 * src/parse-gram.y: Handle precedence/associativity.
1815
1816 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
1817 a terminal.
1818 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
1819 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
1820 at all to define terminals that cannot be emitted.
1821
1822 * src/scan-gram.l: Escape M4 characters.
1823
1824 * src/scan-gram.l: Working properly with escapes in user
1825 strings/characters.
1826
1827 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
1828 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
1829 grammar.
1830 Use more modest sizes, as for the time being the parser does not
1831 release memory, and therefore the process swallows a huge amount
1832 of memory.
1833
1834 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
1835 stricter %token grammar.
1836
1837 * src/symtab.h (associativity): Add `undef_assoc'.
1838 (symbol_precedence_set): Do nothing when passed an undef_assoc.
1839 * src/symtab.c (symbol_check_alias_consistence): Adjust.
1840
1841 * tests/regression.at (Invalid %directive): Remove, as it is now
1842 meaningless.
1843 (Invalid inputs): Adjust to the new error messages.
1844 (Token definitions): The new grammar doesn't allow too many
1845 eccentricities.
1846
1847 * src/lex.h, src/lex.c: Remove.
1848 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1849 (copy_character, copy_string2, copy_string, copy_identifier)
1850 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1851 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1852 (parse_action): Remove.
1853 * po/POTFILES.in: Adjust.
1854
18552002-06-11 Akim Demaille <akim@epita.fr>
1856
1857 * src/reader.c (parse_action): Don't store directly into the
1858 rule's action member: return the action as a string.
1859 Don't require `rule_length' as an argument: compute it.
1860 (grammar_current_rule_symbol_append)
1861 (grammar_current_rule_action_append): New, eved out from
1862 (readgram): here.
1863 Remove `action_flag', `rulelength', unused now.
1864
18652002-06-11 Akim Demaille <akim@epita.fr>
1866
1867 * src/reader.c (grammar_current_rule_prec_set).
1868 (grammar_current_rule_check): New, eved out from...
1869 (readgram): here.
1870 Remove `xaction', `first_rhs': useless.
1871 * tests/input.at (Type clashes): New.
1872 * tests/existing.at (GNU Cim Grammar): Adjust.
1873
18742002-06-11 Akim Demaille <akim@epita.fr>
1875
1876 * src/reader.c (grammar_midrule_action): New, Eved out from
1877 (readgram): here.
1878
18792002-06-11 Akim Demaille <akim@epita.fr>
1880
1881 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1882 New.
1883 (readgram): Use them as replacement of inlined code, crule and
1884 crule1.
1885
18862002-06-11 Akim Demaille <akim@epita.fr>
1887
1888 * src/reader.c (grammar_end, grammar_symbol_append): New.
1889 (readgram): Use them.
1890 Make the use of `p' as local as possible.
1891
18922002-06-10 Akim Demaille <akim@epita.fr>
1893
1894 GCJ's parser requires the tokens to be defined before the prologue.
1895
1896 * data/bison.simple: Output the token definition before the user's
1897 prologue.
1898 * tests/regression.at (Braces parsing, Duplicate string)
1899 (Mixing %token styles): Check the output from bison.
1900 (Early token definitions): New.
1901
19022002-06-10 Akim Demaille <akim@epita.fr>
1903
1904 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1905 assigning twice the same user number to a token, so that we can
1906 use it in...
1907 * src/lex.c (lex): here.
1908 Also use `symbol_class_set' instead of hand written code.
1909 * src/reader.c (parse_assoc_decl): Likewise.
1910
19112002-06-10 Akim Demaille <akim@epita.fr>
1912
1913 * src/symtab.c, src/symtab.c (symbol_class_set)
1914 (symbol_user_token_number_set): New.
1915 * src/reader.c (parse_token_decl): Use them.
1916 Use a switch instead of ifs.
1917 Use a single argument.
1918
19192002-06-10 Akim Demaille <akim@epita.fr>
1920
1921 Remove `%thong' support as it is undocumented, unused, duplicates
1922 `%token's job, and creates useless e-mail traffic with people who
1923 want to know what it is, why it is undocumented, unused, and
1924 duplicates `%token's job.
1925
1926 * src/reader.c (parse_thong_decl): Remove.
1927 * src/options.c (option_table): Remove "thong".
1928 * src/lex.h (tok_thong): Remove.
1929
19302002-06-10 Akim Demaille <akim@epita.fr>
1931
1932 * src/symtab.c, src/symtab.c (symbol_type_set)
1933 (symbol_precedence_set): New.
1934 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1935 (value_components_used): Remove, unused.
1936
19372002-06-09 Akim Demaille <akim@epita.fr>
1938
1939 Move symbols handling code out of the reader.
1940
1941 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1942 (axiom): Move to...
1943 * src/symtab.h, src/symtab.c: here.
1944
1945 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1946 * src/reader.c (startval): Rename as...
1947 * src/symtab.h, src/symtab.c (startsymbol): this.
1948 * src/reader.c: Adjust.
1949
1950 * src/reader.c (symbol_check_defined, symbol_make_alias)
1951 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1952 (token_translations_init)
1953 Move to...
1954 * src/symtab.c: here.
1955 * src/reader.c (packsymbols): Move to...
1956 * src/symtab.h, src/symtab.c (symbols_pack): here.
1957 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1958 argument.
1959
19602002-06-03 Akim Demaille <akim@epita.fr>
1961
1962 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1963 then statements.
1964
19652002-06-03 Akim Demaille <akim@epita.fr>
1966
1967 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1968 structs with non literals.
1969 * src/scan-skel.l: never-interactive.
1970 * src/conflicts.c (enum conflict_resolution_e): No trailing
1971 comma.
1972 * src/getargs.c (usage): Split long literal strings.
1973 Reported by Hans Aberg.
1974
19752002-05-28 Akim Demaille <akim@epita.fr>
1976
1977 * data/bison.c++: Use C++ ostreams.
1978 (cdebug_): New member.
1979
19802002-05-28 Akim Demaille <akim@epita.fr>
1981
1982 * src/output.c (output_skeleton): Be sure to allocate enough room
1983 for `/' _and_ for `\0' in full_skeleton.
1984
19852002-05-28 Akim Demaille <akim@epita.fr>
1986
1987 * data/bison.c++: Catch up with bison.simple:
1988 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1989 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1990 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1991 and popping traces.
1992
19932002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1994
1995 * src/output.c (output_skeleton): Put an explicit path in front of
1996 the skeleton file name, rather than relying on the -I directory,
1997 to partially alleviate effects of having a skeleton file lying around
1998 in the current directory.
1999
20002002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2001
2002 * src/conflicts.c (log_resolution): Correct typo:
2003 obstack_printf should be obstack_fgrow1.
2004
20052002-05-26 Akim Demaille <akim@epita.fr>
2006
2007 * src/state.h (state_t): `solved_conflicts' is a new member.
2008 * src/LR0.c (new_state): Set it to 0.
2009 * src/conflicts.h, src/conflicts.c (print_conflicts)
2010 (free_conflicts, solve_conflicts): Rename as...
2011 (conflicts_print, conflicts_free, conflicts_solve): these.
2012 Adjust callers.
2013 * src/conflicts.c (enum conflict_resolution_e)
2014 (solved_conflicts_obstack): New, used by...
2015 (log_resolution): this.
2016 Adjust to attach the conflict resolution to each state.
2017 Complete the description with the precedence/associativity
2018 information.
2019 (resolve_sr_conflict): Adjust.
2020 * src/print.c (print_state): Output its solved_conflicts.
2021 * tests/conflicts.at (Unresolved SR Conflicts)
2022 (Solved SR Conflicts): Exercise --report=all.
2023
20242002-05-26 Akim Demaille <akim@epita.fr>
2025
2026 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2027 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2028 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2029 (token_number_t, item_number_as_token_number)
2030 (token_number_as_item_number, muscle_insert_token_number_table):
2031 Rename as...
2032 (symbol_number_t, item_number_as_symbol_number)
2033 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2034 these, since it is more appropriate.
2035
20362002-05-26 Akim Demaille <akim@epita.fr>
2037
2038 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2039 `Error:' lines.
2040 * data/bison.simple (yystos) [YYDEBUG]: New.
2041 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2042 error recovery.
2043 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2044
20452002-05-25 Akim Demaille <akim@epita.fr>
2046
2047 * doc/bison.texinfo (Debugging): Split into...
2048 (Tracing): this new section, its former contents, and...
2049 (Understanding): this new section.
2050 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2051 by...
2052 (report_flag): this.
2053 Adjust all dependencies.
2054 (report_args, report_types, report_argmatch): New.
2055 (usage, getargs): Report/support -r, --report.
2056 * src/options.h
2057 (struct option_table_struct): Rename as..,
2058 (struct option_table_s): this.
2059 Rename the `set_flag' member to `flag' to match with getopt_long's
2060 struct.
2061 * src/options.c (option_table): Split verbose into an entry for
2062 %verbose, and another for --verbose.
2063 Support --report/-r, so remove -r from the obsolete --raw.
2064 * src/print.c: Attach full item sets and lookaheads reports to
2065 report_flag instead of trace_flag.
2066 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2067
20682002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2069 and Paul Eggert <eggert@twinsun.com>
2070
2071 * data/bison.simple (yyparse): Correct error handling to conform to
2072 POSIX and yacc. Specifically, after syntax error is discovered,
2073 do not reduce further before shifting the error token.
2074 Clean up the code a bit by removing the labels yyerrdefault,
2075 yyerrhandle, yyerrpop.
2076 * NEWS: Document the above.
2077
20782002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2079
2080 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2081 type; it isn't always big enough, since it doesn't necessarily
2082 include non-terminals.
2083 (yytranslate): Expand definition of yy_token_number_type, so that
2084 the latter can be removed.
2085 (yy_token_number_type): Remove, only one use.
2086 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2087 don't use TokenNumberType as element type.
2088
2089 * tests/regression.at: Modify expected output to agree with change
2090 to yyr1 and yytranslate.
2091
20922002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2093
2094 * src/reader.c (parse_action): Use copy_character instead of
2095 obstack_1grow.
2096
20972002-05-13 Akim Demaille <akim@epita.fr>
2098
2099 * tests/regression.at (Token definitions): Prototype yylex and
2100 yyerror.
2101
21022002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2103
2104 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
2105 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2106 32-bit arithmetic.
2107 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2108
21092002-05-07 Akim Demaille <akim@epita.fr>
2110
2111 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2112 avoid GCC warnings.
2113
21142002-05-07 Akim Demaille <akim@epita.fr>
2115
2116 Kill GCC warnings.
2117
2118 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2119 over the RHS of each rule.
2120 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2121 * src/state.h (state_t): Member `nitems' is unsigned short.
2122 * src/LR0.c (get_state): Adjust.
2123 * src/reader.c (packgram): Likewise.
2124 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2125 `Type'.
2126 (muscle_insert_int_table): Remove, unused.
2127 (prepare_rules): Remove `max'.
2128
21292002-05-06 Akim Demaille <akim@epita.fr>
2130
2131 * src/closure.c (print_firsts): Display of the symbol tags.
2132 (bitmatrix_print): Move to...
2133 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2134 here.
2135 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2136
21372002-05-06 Akim Demaille <akim@epita.fr>
2138
2139 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2140 hash_do_for_each.
2141
21422002-05-06 Akim Demaille <akim@epita.fr>
2143
2144 * src/LR0.c (new_state, get_state): Instead of using the global
2145 `kernel_size' and `kernel_base', have two new arguments:
2146 `core_size' and `core'.
2147 Adjust callers.
2148
21492002-05-06 Akim Demaille <akim@epita.fr>
2150
2151 * src/reader.c (packgram): No longer end `ritem' with a 0
2152 sentinel: it is not used.
2153
21542002-05-05 Akim Demaille <akim@epita.fr>
2155
2156 New experimental feature: display the lookaheads in the report and
2157 graph.
2158
2159 * src/print (print_core): When --trace-flag, display the rules
2160 lookaheads.
2161 * src/print_graph.c (print_core): Likewise.
2162 Swap the arguments.
2163 Adjust caller.
2164
21652002-05-05 Akim Demaille <akim@epita.fr>
2166
2167 * tests/torture.at (Many lookaheads): New test.
2168
21692002-05-05 Akim Demaille <akim@epita.fr>
2170
2171 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2172 (GENERATE_MUSCLE_INSERT_TABLE): this.
2173 (output_int_table, output_unsigned_int_table, output_short_table)
2174 (output_token_number_table, output_item_number_table): Replace with...
2175 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2176 (muscle_insert_short_table, muscle_insert_token_number_table)
2177 (muscle_insert_item_number_table): these.
2178 Adjust all callers.
2179 (prepare_tokens): Don't free `translations', since...
2180 * src/reader.h, src/reader.c (grammar_free): do it.
2181 Move to...
2182 * src/gram.h, src/gram.c (grammar_free): here.
2183 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2184 b4_translate_max.
2185
21862002-05-05 Akim Demaille <akim@epita.fr>
2187
2188 * src/output.c (output_unsigned_int_table): New.
2189 (prepare_rules): `i' is unsigned.
2190 `prhs', `rline', `r2' are unsigned int.
2191 Rename muscle `rhs_number_max' as `rhs_max'.
2192 Output muscles `prhs_max', `rline_max', and `r2_max'.
2193 Free rline and r1.
2194 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2195 to compute types instead of constant types.
2196 * tests/regression.at (Web2c Actions): Adjust.
2197
21982002-05-04 Akim Demaille <akim@epita.fr>
2199
2200 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2201 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2202 Adjust dependencies.
2203 * src/output.c (token_definitions_output): Be sure not to output a
2204 `#define 'a'' when fed with `%token 'a' "a"'.
2205 * tests/regression.at (Token definitions): New.
2206
22072002-05-03 Paul Eggert <eggert@twinsun.com>
2208
2209 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2210 for K&R C.
2211
22122002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2213
2214 * Makefile.am (SUBDIRS): Remove intl.
2215 (EXTRA_DIST): Add config/config.rpath.
2216
22172002-05-03 Akim Demaille <akim@epita.fr>
2218
2219 * data/bison.simple (m4_if): Don't output empty enums.
2220 And actually, output valid enum definitions :(.
2221
22222002-05-03 Akim Demaille <akim@epita.fr>
2223
2224 * configure.bat: Remove, completely obsolete.
2225 * Makefile.am (EXTRA_DIST): Adjust.
2226 Don't distribute config.rpath...
2227 * config/Makefile.am (EXTRA_DIST): Do it.
2228
22292002-05-03 Akim Demaille <akim@epita.fr>
2230
2231 * configure.in (GETTEXT_VERSION): New.
2232 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2233
22342002-05-03 Akim Demaille <akim@epita.fr>
2235
2236 * data/bison.simple (b4_token_enum): New.
2237 (b4_token_defines): Use it to output tokens both as #define and
2238 enums.
2239 Suggested by Paul Eggert.
2240 * src/output.c (token_definitions_output): Don't output spurious
2241 white spaces.
2242
22432002-05-03 Akim Demaille <akim@epita.fr>
2244
2245 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2246
22472002-05-02 Robert Anisko <robert@lrde.epita.fr>
2248
2249 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2250 Update the stack class, give a try to deque as the default container.
2251
22522002-05-02 Akim Demaille <akim@epita.fr>
2253
2254 * data/bison.simple (yyparse): Do not implement @$ = @1.
2255 (YYLLOC_DEFAULT): Adjust to do it.
2256 * doc/bison.texinfo (Location Default Action): Fix.
2257
22582002-05-02 Akim Demaille <akim@epita.fr>
2259
2260 * src/reader.c (parse_braces): Merge into...
2261 (parse_action): this.
2262
22632002-05-02 Akim Demaille <akim@epita.fr>
2264
2265 * configure.in (ALL_LINGUAS): Remove.
2266 * po/LINGUAS, hr.po: New.
2267
22682002-05-02 Akim Demaille <akim@epita.fr>
2269
2270 Remove the so called hairy (semantic) parsers.
2271
2272 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2273 * src/gram.h, src/gram.c (semantic_parser): Remove.
2274 (rule_t): Remove the guard and guard_line members.
2275 * src/lex.h (token_t): remove tok_guard.
2276 * src/options.c (option_table): Remove %guard and %semantic_parser
2277 support.
2278 * src/output.c, src/output.h (guards_output): Remove.
2279 (prepare): Adjust.
2280 (token_definitions_output): Don't output the `T'
2281 tokens (???).
2282 (output_skeleton): Don't output the guards.
2283 * src/files.c, src/files.c (attrsfile): Remove.
2284 * src/reader.c (symbol_list): Remove the guard and guard_line
2285 members.
2286 Adjust dependencies.
2287 (parse_guard): Remove.
2288 * data/bison.hairy: Remove.
2289 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2290 BISON_HAIRY.
2291
22922002-05-02 Akim Demaille <akim@epita.fr>
2293
2294 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2295 (parse_guard): Rename the formal argument `stack_offset' as
2296 `rule_length', which is more readable.
2297 Adjust callers.
2298 (copy_at, copy_dollar): Instead of outputting the hard coded
2299 values of $$, $n and so forth, output invocation to b4_lhs_value,
2300 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
2301 Note: this patch partially drops `semantic-parser' support: it
2302 always does `rule_length - n', where semantic parsers ought to
2303 always use `-n'.
2304 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2305 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2306
23072002-05-02 Akim Demaille <akim@epita.fr>
2308
2309 * configure.in (AC_INIT): Bump to 1.49b.
2310 (AM_INIT_AUTOMAKE): Short invocation.
2311
23122002-05-02 Akim Demaille <akim@epita.fr>
2313
2314 Version 1.49a.
2315
23162002-05-01 Akim Demaille <akim@epita.fr>
2317
2318 * src/skeleton.h: Remove.
2319
23202002-05-01 Akim Demaille <akim@epita.fr>
2321
2322 * src/skeleton.h: Fix the #endif.
2323 Reported by Magnus Fromreide.
2324
23252002-04-26 Paul Eggert <eggert@twinsun.com>
2326
2327 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2328 Define if we define YYSTYPE and YYLTYPE, respectively.
2329 (YYCOPY): Fix [] quoting problem in the non-GCC case.
2330
23312002-04-25 Robert Anisko <robert@lrde.epita.fr>
2332
2333 * src/scan-skel.l: Postprocess quadrigraphs.
2334
2335 * src/reader.c (copy_character): New function, used to output
2336 single characters while replacing `[' and `]' with quadrigraphs, to
2337 avoid troubles with M4 quotes.
2338 (copy_comment): Output characters with copy_character.
2339 (read_additionnal_code): Likewise.
2340 (copy_string2): Likewise.
2341 (copy_definition): Likewise.
2342
2343 * tests/calc.at: Exercise M4 quoting.
2344
23452002-04-25 Akim Demaille <akim@epita.fr>
2346
2347 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2348 between `!' and the command.
2349 Reported by Paul Eggert.
2350
23512002-04-24 Robert Anisko <robert@lrde.epita.fr>
2352
2353 * tests/calc.at: Exercise prologue splitting.
2354
2355 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2356 `b4_post_prologue' instead of `b4_prologue'.
2357
2358 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2359 muscles.
2360 (output): Free pre_prologue_obstack and post_prologue_obstack.
2361 * src/files.h, src/files.c (attrs_obstack): Remove.
2362 (pre_prologue_obstack, post_prologue_obstack): New.
2363 * src/reader.c (copy_definition): Add a parameter to specify the
2364 obstack to fill, instead of using attrs_obstack unconditionally.
2365 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2366 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2367
23682002-04-23 Paul Eggert <eggert@twinsun.com>
2369
2370 * data/bison.simple: Remove unnecessary commentary and white
2371 space differences from 1_29-branch.
2372 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2373
2374 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2375 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2376 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2377 constructors or destructors.
2378
2379 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2380
23812002-04-23 Akim Demaille <akim@epita.fr>
2382
2383 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2384 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2385 location with columns.
2386 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2387 All reported by Paul Eggert.
2388
23892002-04-22 Akim Demaille <akim@epita.fr>
2390
2391 * src/reduce.c (dump_grammar): Move to...
2392 * src/gram.h, src/gram.c (grammar_dump): here.
2393 Be sure to separate long item numbers.
2394 Don't read the members of a rule's prec if its nil.
2395
23962002-04-22 Akim Demaille <akim@epita.fr>
2397
2398 * src/output.c (table_size, table_grow): New.
2399 (MAXTABLE): Remove, replace uses with table_size.
2400 (pack_vector): Instead of dying when the table is too big, grow it.
2401
24022002-04-22 Akim Demaille <akim@epita.fr>
2403
2404 * data/bison.simple (yyr1): Its type is that of a token number.
2405 * data/bison.c++ (r1_): Likewise.
2406 * tests/regression.at (Web2c Actions): Adjust.
2407
24082002-04-22 Akim Demaille <akim@epita.fr>
2409
2410 * src/reader.c (token_translations_init): 256 is now the default
2411 value for the error token, i.e., it will be assigned another
2412 number if the user assigned 256 to one of her tokens.
2413 (reader): Don't force 256 to error.
2414 * doc/bison.texinfo (Symbols): Adjust.
2415 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2416 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2417 etc. instead of 10, 20, 30 (which was used to `jump' over error
2418 (256) and undefined (2)).
2419
24202002-04-22 Akim Demaille <akim@epita.fr>
2421
2422 Propagate more token_number_t.
2423
2424 * src/gram.h (token_number_as_item_number)
2425 (item_number_as_token_number): New.
2426 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2427 Use it to create output_item_number_table and
2428 output_token_number_table.
2429 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2430 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2431 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2432 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2433
24342002-04-22 Akim Demaille <akim@epita.fr>
2435
2436 * src/output.h, src/output.c (get_lines_number): Remove.
2437
24382002-04-19 Akim Demaille <akim@epita.fr>
2439
2440 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2441 as Lex/Flex'.
2442 (Debugging): More details about enabling the debugging features.
2443 (Table of Symbols): Describe $$, $n, @$, and @n.
2444 Suggested by Tim Josling.
2445
24462002-04-19 Akim Demaille <akim@epita.fr>
2447
2448 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2449
24502002-04-10 Akim Demaille <akim@epita.fr>
2451
2452 * src/system.h: Rely on HAVE_LIMITS_H.
2453 Suggested by Paul Eggert.
2454
24552002-04-09 Akim Demaille <akim@epita.fr>
2456
2457 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2458 full stderr, and strip it according to the bison options, instead
2459 of composing the error message from different bits.
2460 This makes it easier to check for several error messages.
2461 Adjust all the invocations.
2462 Add an invocation exercising the error token.
2463 Add an invocation demonstrating a stupid error message.
2464 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2465 Adjust the tests.
2466 Error message are for stderr, not stdout.
2467
24682002-04-09 Akim Demaille <akim@epita.fr>
2469
2470 * src/gram.h, src/gram.c (error_token_number): Remove, use
2471 errtoken->number.
2472 * src/reader.c (reader): Don't specify the user token number (2)
2473 for $undefined, as it uselessly prevents using it.
2474 * src/gram.h (token_number_t): Move to...
2475 * src/symtab.h: here.
2476 (state_t.number): Is a token_number_t.
2477 * src/print.c, src/reader.c: Use undeftoken->number instead of
2478 hard coded 2.
2479 (Even though this 2 is not the same as above: the number of the
2480 undeftoken remains being 2, it is its user token number which
2481 might not be 2).
2482 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2483 `user_token_number_max'.
2484 Output `undef_token_number'.
2485 * data/bison.simple, data/bison.c++: Use them.
2486 Be sure to map invalid yylex return values to
2487 `undef_token_number'. This saves us from gratuitous SEGV.
2488
2489 * tests/conflicts.at (Solved SR Conflicts)
2490 (Unresolved SR Conflicts): Adjust.
2491 * tests/regression.at (Web2c Actions): Adjust.
2492
24932002-04-08 Akim Demaille <akim@epita.fr>
2494
2495 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2496 Adding #line.
2497 Remove the duplicate `typedefs'.
2498 (RhsNumberType): Fix the declaration and various other typos.
2499 Use __ofile__.
2500 * data/bison.simple: Use __ofile__.
2501 * src/scan-skel.l: Handle __ofile__.
2502
25032002-04-08 Akim Demaille <akim@epita.fr>
2504
2505 * src/gram.h (item_number_t): New, the type of item numbers in
2506 RITEM. Note that it must be able to code symbol numbers as
2507 positive number, and the negation of rule numbers as negative
2508 numbers.
2509 Adjust all dependencies (pretty many).
2510 * src/reduce.c (rule): Remove this `short *' pointer: use
2511 item_number_t.
2512 * src/system.h (MINSHORT, MAXSHORT): Remove.
2513 Include `limits.h'.
2514 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2515 (shortcpy): Remove.
2516 (MAXTABLE): Move to...
2517 * src/output.c (MAXTABLE): here.
2518 (prepare_rules): Use output_int_table to output rhs.
2519 * data/bison.simple, data/bison.c++: Adjust.
2520 * tests/torture.at (Big triangle): Move the limit from 254 to
2521 500.
2522 * tests/regression.at (Web2c Actions): Ajust.
2523
2524 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2525 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
2526 passes, but produces negative #line number, once fixed, GCC is
2527 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
2528 C), it passes.
2529 * src/state.h (state_h): Code input lines on ints, not shorts.
2530
25312002-04-08 Akim Demaille <akim@epita.fr>
2532
2533 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
2534 and then the grammar.
2535
25362002-04-08 Akim Demaille <akim@epita.fr>
2537
2538 * src/system.h: No longer using strndup.
2539
25402002-04-07 Akim Demaille <akim@epita.fr>
2541
2542 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
2543 * src/output.c (output_table_data): Return the longest number.
2544 (prepare_tokens): Output `token_number_max').
2545 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
2546 New.
2547 Use them to define yy_token_number_type/TokenNumberType.
2548 Use this type for yytranslate.
2549 * tests/torture.at (Big triangle): Push the limit from 124 to
2550 253.
2551 * tests/regression.at (Web2c Actions): Adjust.
2552
25532002-04-07 Akim Demaille <akim@epita.fr>
2554
2555 * tests/torture.at (Big triangle): New.
2556 (GNU AWK Grammar, GNU Cim Grammar): Move to...
2557 * tests/existing.at: here.
2558
25592002-04-07 Akim Demaille <akim@epita.fr>
2560
2561 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
2562 nritems.
2563 Adjust dependencies.
2564
25652002-04-07 Akim Demaille <akim@epita.fr>
2566
2567 * src/reader.c: Normalize increments to prefix form.
2568
25692002-04-07 Akim Demaille <akim@epita.fr>
2570
2571 * src/reader.c, symtab.c: Remove debugging code.
2572
25732002-04-07 Akim Demaille <akim@epita.fr>
2574
2575 Rename all the `bucket's as `symbol_t'.
2576
2577 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
2578 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
2579 * src/symtab.c, src/symtab.h (bucket): Rename as...
2580 (symbol_t): this.
2581 (symbol_list_new, bucket_check_defined, bucket_make_alias)
2582 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
2583 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2584 (buckets_new, buckets_free, buckets_do): Rename as...
2585 (symbol_list_new, symbol_check_defined, symbol_make_alias)
2586 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2587 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
2588 (symbols_new, symbols_free, symbols_do): these.
2589
25902002-04-07 Akim Demaille <akim@epita.fr>
2591
2592 Use lib/hash for the symbol table.
2593
2594 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
2595 EOF.
2596 * src/lex.c (lex): Set the `number' member of new terminals.
2597 * src/reader.c (bucket_check_defined, bucket_make_alias)
2598 (bucket_check_alias_consistence, bucket_translation): New.
2599 (reader, grammar_free, readgram, token_translations_init)
2600 (packsymbols): Adjust.
2601 (reader): Number the predefined tokens.
2602 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
2603 for predefined tokens.
2604 * src/symtab.h (bucket): Remove all the hash table related
2605 members.
2606 * src/symtab.c (symtab): Replace by...
2607 (bucket_table): this.
2608 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2609 (buckets_new, buckets_do): New.
2610
26112002-04-07 Akim Demaille <akim@epita.fr>
2612
2613 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
2614 (start_symbol, max_user_token_number, semantic_parser)
2615 (error_token_number): Initialize.
2616 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
2617 Initialize.
2618 (reader): Don't.
2619 (errtoken, eoftoken, undeftoken, axiom): Extern.
2620
26212002-04-07 Akim Demaille <akim@epita.fr>
2622
2623 * src/gram.h (rule_s): prec and precsym are now pointers
2624 to the bucket giving the priority/associativity.
2625 Member `associativity' removed: useless.
2626 * src/reduce.c, src/conflicts.c: Adjust.
2627
26282002-04-07 Akim Demaille <akim@epita.fr>
2629
2630 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
2631 Properly escape the symbols' TAG when outputting them.
2632
26332002-04-07 Akim Demaille <akim@epita.fr>
2634
2635 * src/lalr.h (LA): Is a bitsetv, not bitset*.
2636
26372002-04-07 Akim Demaille <akim@epita.fr>
2638
2639 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
2640 (LArule): this, which is an array to rule_t*.
2641 * src/print.c, src/conflicts.c: Adjust.
2642
26432002-04-07 Akim Demaille <akim@epita.fr>
2644
2645 * src/gram.h (rule_t): Rename `number' as `user_number'.
2646 `number' is a new member.
2647 Adjust dependencies.
2648 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
2649
26502002-04-07 Akim Demaille <akim@epita.fr>
2651
2652 As a result of the previous patch, it is no longer needed
2653 to reorder ritem itself.
2654
2655 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
2656
26572002-04-07 Akim Demaille <akim@epita.fr>
2658
2659 Be sure never to walk through RITEMS, but use only data related to
2660 the rules themselves. RITEMS should be banished.
2661
2662 * src/output.c (output_token_translations): Rename as...
2663 (prepare_tokens): this.
2664 In addition to `translate', prepare the muscles `tname' and
2665 `toknum', which were handled by...
2666 (output_rule_data): this.
2667 Remove, and move the remainder of its outputs into...
2668 (prepare_rules): this new routines, which also merges content from
2669 (output_gram): this.
2670 (prepare_rules): Be sure never to walk through RITEMS.
2671 (output_stos): Rename as...
2672 (prepare_stos): this.
2673 (output): Always invoke prepare_states, after all, just don't use it
2674 in the output if you don't need it.
2675
26762002-04-07 Akim Demaille <akim@epita.fr>
2677
2678 * src/LR0.c (new_state): Display `nstates' as the name of the
2679 newly created state.
2680 Adjust to initialize first_state and last_state if needed.
2681 Be sure to distinguish the initial from the final state.
2682 (new_states): Create the itemset of the initial state, and use
2683 new_state.
2684 * src/closure.c (closure): Now that the initial state has its
2685 items properly set, there is no need for a special case when
2686 creating `ruleset'.
2687
2688 As a result, now the rule 0, reducing to $axiom, is visible in the
2689 outputs. Adjust the test suite.
2690
2691 * tests/conflicts.at (Solved SR Conflicts)
2692 (Unresolved SR Conflicts): Adjust.
2693 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
2694 * tests/conflicts.at (S/R in initial): New.
2695
26962002-04-07 Akim Demaille <akim@epita.fr>
2697
2698 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
2699 the RHS of the rules.
2700 * src/output.c (output_gram): Likewise.
2701
27022002-04-07 Akim Demaille <akim@epita.fr>
2703
2704 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
2705 bucket.
2706 Adjust all dependencies.
2707 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
2708 `number' of the buckets too.
2709 * src/gram.h: Include `symtab.h'.
2710 (associativity): Move to...
2711 * src/symtab.h: here.
2712 No longer include `gram.h'.
2713
27142002-04-07 Akim Demaille <akim@epita.fr>
2715
2716 * src/gram.h, src/gram.c (rules_rhs_length): New.
2717 (ritem_longest_rhs): Use it.
2718 * src/gram.h (rule_t): `number' is a new member.
2719 * src/reader.c (packgram): Set it.
2720 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
2721 the end of `rules', and count them out of `nrules'.
2722 (reduce_output, dump_grammar): Adjust.
2723 * src/print.c (print_grammar): It is no longer needed to check for
2724 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
2725 * tests/reduce.at (Reduced Automaton): New test.
2726
27272002-04-07 Akim Demaille <akim@epita.fr>
2728
2729 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
2730 lacking `+ 1' to nrules, Bison reported as useless a token if it
2731 was used solely to set the precedence of the last rule...
2732
27332002-04-07 Akim Demaille <akim@epita.fr>
2734
2735 * data/bison.c++, data/bison.simple: Don't output the current file
2736 name in #line, to avoid useless diffs between two identical
2737 outputs under different names.
2738
27392002-04-07 Akim Demaille <akim@epita.fr>
2740
2741 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
2742 Normalize loops to using `< nrules + 1', not `<= nrules'.
2743
27442002-04-07 Akim Demaille <akim@epita.fr>
2745
2746 * TODO: Update.
2747
27482002-04-07 Akim Demaille <akim@epita.fr>
2749
2750 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
2751 bucket.value as bucket.number.
2752
27532002-04-07 Akim Demaille <akim@epita.fr>
2754
2755 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
2756 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2757 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
2758 RHS, instead of being an index in RITEMS.
2759
27602002-04-04 Paul Eggert <eggert@twinsun.com>
2761
2762 * doc/bison.texinfo: Update copyright date.
2763 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
2764 (Symbols): Warn about running Bison in one character set,
2765 but compiling and/or running in an incompatible one.
2766 Warn about character code 256, too.
2767
27682002-04-03 Paul Eggert <eggert@twinsun.com>
2769
2770 * src/bison.data (YYSTACK_ALLOC): Depend on whether
2771 YYERROR_VERBOSE is nonzero, not whether it is defined.
2772
2773 Merge changes from bison-1_29-branch.
2774
27752002-03-20 Paul Eggert <eggert@twinsun.com>
2776
2777 Merge fixes from Debian bison_1.34-1.diff.
2778
2779 * configure.in (AC_PREREQ): 2.53.
2780
27812002-03-20 Akim Demaille <akim@epita.fr>
2782
2783 * src/conflicts.c (log_resolution): Argument `resolution' is const.
2784
27852002-03-19 Paul Eggert <eggert@twinsun.com>
2786
2787 * src/bison.simple (YYCOPY): New macro.
2788 (YYSTACK_RELOCATE): Use it.
2789 Remove Type arg; no longer needed. All callers changed.
2790 (yymemcpy): Remove; no longer needed.
2791
2792 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
2793 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
2794
27952002-03-19 Akim Demaille <akim@epita.fr>
2796
2797 Test and fix the #line outputs.
2798
2799 * tests/atlocal.at (GCC): New.
2800 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
2801 (Prologue synch line, ,%union synch line, Postprologue synch line)
2802 (Action synch line, Epilogue synch line): New tests.
2803 * src/reader.c (parse_union_decl): Define the muscle stype_line.
2804 * data/bison.simple, data/bison.c++: Use it.
2805
28062002-03-19 Akim Demaille <akim@epita.fr>
2807
2808 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
2809 (Solved SR Conflicts, %expect not enough, %expect right)
2810 (%expect too much): Move to...
2811 * tests/conflicts.at: this new file.
2812
28132002-03-19 Akim Demaille <akim@epita.fr>
2814
2815 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2816 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
2817 that we can move to enums for instance.
2818 * src/output.c (token_definitions_output): Output a list of
2819 `token-name, token-number' instead of the #define.
2820 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
2821
28222002-03-14 Akim Demaille <akim@epita.fr>
2823
2824 Use Gettext 0.11.1.
2825
28262002-03-09 Robert Anisko <robert@lrde.epita.fr>
2827
2828 * data/bison.c++: Make the user able to add members to the generated
2829 parser by subclassing.
2830
28312002-03-05 Robert Anisko <robert@lrde.epita.fr>
2832
2833 * src/reader.c (read_additionnal_code): `c' should be an integer, not
2834 a character.
2835 Reported by Nicolas Tisserand and Nicolas Burrus.
2836
28372002-03-04 Robert Anisko <robert@lrde.epita.fr>
2838
2839 * src/reader.c: Warn about lacking semi-colons, do not complain.
2840
28412002-03-04 Robert Anisko <robert@lrde.epita.fr>
2842
2843 * data/bison.c++: Remove a debug line.
2844
28452002-03-04 Robert Anisko <robert@lrde.epita.fr>
2846
2847 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2848 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2849 provide a default implementation.
2850
28512002-03-04 Akim Demaille <akim@epita.fr>
2852
2853 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2854 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2855 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2856 * tests/semantic.at (Parsing Guards): Similarly.
2857 * src/reader.at (readgram): Complain if the last rule is not ended
2858 with a semi-colon.
2859
28602002-03-04 Akim Demaille <akim@epita.fr>
2861
2862 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2863 * src/closure.c: here.
2864 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2865 RTC.
2866 * src/warshall.h, src/warshall.c: Remove.
2867 * tests/sets.at (Broken Closure): Adjust.
2868
28692002-03-04 Akim Demaille <akim@epita.fr>
2870
2871 * src/output.c (output_skeleton): tempdir is const.
2872 bytes_read is unused.
2873
28742002-03-04 Akim Demaille <akim@epita.fr>
2875
2876 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2877 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2878 Update.
2879 From Michael Hayes.
2880
28812002-03-04 Akim Demaille <akim@epita.fr>
2882
2883 * src/closure.c (closure): `r' is unused.
2884
28852002-03-04 Akim Demaille <akim@epita.fr>
2886
2887 * tests/sets.at (Broken Closure): Add the ending `;'.
2888 * src/reader.at (readgram): Complain if a rule is not ended with a
2889 semi-colon.
2890
28912002-03-04 Akim Demaille <akim@epita.fr>
2892
2893 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2894 (count_sr_conflicts): Use bitset_count.
2895 * src/reduce.c (inaccessable_symbols): Ditto.
2896 (bits_size): Remove.
2897 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2898
28992002-03-04 Akim Demaille <akim@epita.fr>
2900
2901 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2902 * src/reduce.c: Remove the `bitset_zero's following the
2903 `bitset_create's, as now it is performed by the latter.
2904
29052002-03-04 Akim Demaille <akim@epita.fr>
2906
2907 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2908 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2909 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2910 latest sources from Michael.
2911
29122002-03-04 Akim Demaille <akim@epita.fr>
2913
2914 * src/output.c (output): Don't free the grammar.
2915 * src/reader.c (grammar_free): New.
2916 * src/main.c (main): Call it and don't free symtab here.
2917
29182002-03-04 Akim Demaille <akim@epita.fr>
2919
2920 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2921 before returning.
2922 Reported by Benoit Perrot.
2923
29242002-03-04 Akim Demaille <akim@epita.fr>
2925
2926 Use bitset operations when possible, not loops over bits.
2927
2928 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2929 bitset_or.
2930 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2931 * src/reduce.c (useless_nonterminals): Formatting changes.
2932 * src/warshall.c (TC): Use bitset_or.
2933
29342002-03-04 Akim Demaille <akim@epita.fr>
2935
2936 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2937 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2938 Ditto.
2939
29402002-03-04 Akim Demaille <akim@epita.fr>
2941
2942 * src/lalr.c (F): Now a bitset*.
2943 Adjust all dependencies.
2944
29452002-03-04 Akim Demaille <akim@epita.fr>
2946
2947 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2948 Adjust all dependencies.
2949
29502002-03-04 Akim Demaille <akim@epita.fr>
2951
2952 * src/L0.c, src/LR0.h (nstates): Be size_t.
2953 Adjust comparisons (signed vs unsigned).
2954 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2955 bitset*.
2956 Adjust all dependencies.
2957
29582002-03-04 Akim Demaille <akim@epita.fr>
2959
2960 * src/closure.c (firsts): Now, also a bitset.
2961 Adjust all dependencies.
2962 (varsetsize): Remove, now unused.
2963 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2964
29652002-03-04 Akim Demaille <akim@epita.fr>
2966
2967 * src/print.c: Convert to use bitset.h, not hand coded iterations
2968 over ints.
2969
29702002-03-04 Akim Demaille <akim@epita.fr>
2971
2972 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2973
29742002-03-04 Akim Demaille <akim@epita.fr>
2975
2976 * src/closure.c (ruleset): Be a bitset.
2977 (rulesetsize): Remove.
2978
29792002-03-04 Akim Demaille <akim@epita.fr>
2980
2981 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2982 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2983 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2984 * src/closure.c (fderives): Be an array of bitsets.
2985
29862002-02-28 Robert Anisko <robert@lrde.epita.fr>
2987
2988 * data/bison.c++: Merge the two generated headers. Insert a copyright
2989 notice in each output file.
2990
29912002-02-28 Akim Demaille <akim@epita.fr>
2992
2993 * data/bison.c++: Copy the prologue of bison.simple to fetch
2994 useful M4 definitions, such as b4_header_guard.
2995
29962002-02-25 Akim Demaille <akim@epita.fr>
2997
2998 * src/getargs.c (version): Give the name of the authors, and use a
2999 translator friendly scheme for the bgr
3000 copyright notice.
3001
30022002-02-25 Akim Demaille <akim@epita.fr>
3003
3004 * src/output.c (header_output): Remove, now handled completely via
3005 M4.
3006
30072002-02-25 Akim Demaille <akim@epita.fr>
3008
3009 * m4/m4.m4: New, from CVS Autoconf.
3010 * configure.in: Invoke it.
3011 * src/output.c (output_skeleton): Use its result instead of the
3012 hard coded name.
3013
30142002-02-25 Akim Demaille <akim@epita.fr>
3015
3016 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3017 Fileutils 4.1.5.
3018 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3019 * src/output.c (output_skeleton): Use mkstemp to create a real
3020 temporary file.
3021 Move the filling of `skeleton' and its muscle to...
3022 (prepare): here.
3023 (output): Move the definition of the prologue muscle to...
3024 (prepare): here.
3025 * src/system.h (DEFAULT_TMPDIR): New.
3026
30272002-02-14 Paul Eggert <eggert@twinsun.com>
3028
3029 Remove the support for C++ namespace cleanliness; it was
3030 causing more problems than it was curing, since it didn't work
3031 properly on some nonstandard C++ compilers. This can wait
3032 for a proper C++ parser.
3033
3034 * NEWS: Document this.
3035 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3036 of C++, as it's treated like C now.
3037 * src/bison.simple (YYSTD): Remove.
3038 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3039 Treat C++ just like Standard C instead of trying to support
3040 namespace cleanliness.
3041
30422002-02-14 Akim Demaille <akim@epita.fr>
3043
3044 * tests/regression.at (else): Adjust to Andreas' change.
3045
30462002-02-14 Akim Demaille <akim@epita.fr>
3047
3048 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3049
30502002-02-13 Andreas Schwab <schwab@suse.de>
3051
3052 * src/output.c (output_rule_data): Don't output NULL, it might
3053 not be defined yet.
3054
30552002-02-11 Robert Anisko <robert@lrde.epita.fr>
3056
3057 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3058 (Copyright notice): Update.
3059
30602002-02-11 Akim Demaille <akim@epita.fr>
3061
3062 * tests/regression.at (%nonassoc and eof): Don't include
3063 nonportable headers.
3064
30652002-02-08 Robert Anisko <robert@lrde.epita.fr>
3066
3067 * data/bison.c++: Correct error recovery. Make the user able to
3068 initialize the starting location.
3069
30702002-02-07 Akim Demaille <akim@epita.fr>
3071
3072 * tests/input.at: New.
3073
30742002-02-07 Robert Anisko <robert@lrde.epita.fr>
3075
3076 * data/bison.c++: Replace some direct m4 expansions by constants. Be
3077 more consistent when naming methods and variables. Put preprocessor
3078 directives around tables only needed for debugging.
3079
30802002-02-07 Robert Anisko <robert@lrde.epita.fr>
3081
3082 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3083 C++ parsers.
3084 (yy::b4_name::parse): Use print_.
3085
30862002-02-07 Robert Anisko <robert@lrde.epita.fr>
3087
3088 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3089
30902002-02-07 Robert Anisko <robert@lrde.epita.fr>
3091
3092 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3093 C++ parsers.
3094 (yy::b4_name::parse): Build verbose error messages, and use error_.
3095
30962002-02-06 Robert Anisko <robert@lrde.epita.fr>
3097
3098 * data/bison.c++: Fix m4 quoting in comments.
3099
31002002-02-06 Robert Anisko <robert@lrde.epita.fr>
3101
3102 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3103 not expanded by m4.
3104
31052002-02-05 Akim Demaille <akim@epita.fr>
3106
3107 * data/bison.c++: Adjust to the M4 back end.
3108 More is certainly needed.
3109
31102002-02-05 Akim Demaille <akim@epita.fr>
3111
3112 Give a try to M4 as a back end.
3113
3114 * lib/readpipe.c: New, from wdiff.
3115 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3116 BISON_HAIRY.
3117 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3118 specific values. Now it is m4 that performs the lookup.
3119 * src/parse-skel.y: Remove.
3120 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3121 * src/output.c (actions_output, guards_output)
3122 (token_definitions_output): No longer keeps track of the output
3123 line number, hence remove the second argument.
3124 (guards_output): Check against the guard member of a rule, not the
3125 action member.
3126 Adjust callers.
3127 (output_skeleton): Don't look for the skeleton location, let m4 do
3128 that.
3129 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3130 file will be used.
3131 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3132 (prepare): Given that for the time being changesyntax is not
3133 usable in M4, rename the muscles using `-' to `_'.
3134 Define `defines_flag', `output_parser_name' and `output_header_name'.
3135 * src/output.h (actions_output, guards_output)
3136 (token_definitions_output): Adjust prototypes.
3137 * src/scan-skel.l: Instead of scanning the skeletons, it now
3138 processes the output of m4: `__oline__' and `#output'.
3139 * data/bison.simple: Adjust to be used by M4(sugar).
3140 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3141 to date.
3142 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3143 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3144 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3145 shamelessly stolen from CVS Autoconf.
3146
31472002-02-05 Akim Demaille <akim@epita.fr>
3148
3149 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3150 * configure.in: Check for the declarations of free and malloc.
3151 * src/muscle_tab.c: Adjust.
3152
31532002-02-05 Akim Demaille <akim@epita.fr>
3154
3155 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3156 which have no values.
3157
31582002-02-05 Akim Demaille <akim@epita.fr>
3159
3160 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3161 * data/: here.
3162
31632002-01-29 Paul Eggert <eggert@twinsun.com>
3164
3165 * src/bison.simple (YYSIZE_T): Do not define merely because
3166 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3167 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3168
31692002-01-27 Akim Demaille <akim@epita.fr>
3170
3171 Fix `%nonassoc and eof'.
3172
3173 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3174 which were not properly copied! Replace
3175 memcpy (res->errs, src->errs, src->nerrs);
3176 with
3177 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3178 !!!
3179 * tests/regression.at (%nonassoc and eof): Adjust to newest
3180 Autotest: `.' is not in the PATH.
3181
31822002-01-27 Akim Demaille <akim@epita.fr>
3183
3184 * tests/sets.at (AT_EXTRACT_SETS): New.
3185 (Nullable): Use it.
3186 (Firsts): New.
3187
31882002-01-26 Akim Demaille <akim@epita.fr>
3189
3190 * tests/actions.at, tests/calc.at, tests/headers.at,
3191 * tests/torture.at: Adjust to the newest Autotest which no longer
3192 forces `.' in the PATH.
3193
31942002-01-25 Akim Demaille <akim@epita.fr>
3195
3196 * tests/regression.at (%nonassoc and eof): New.
3197 Suggested by Robert Anisko.
3198
31992002-01-24 Akim Demaille <akim@epita.fr>
3200
3201 Bison dumps core when trying to complain about broken input files.
3202 Reported by Cris van Pelt.
3203
3204 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3205 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3206 into...
3207 (Invalid inputs): Strengthen: exercise parse_percent_token.
3208
32092002-01-24 Robert Anisko <robert.anisko@epita.fr>
3210
3211 * src/Makefile.am: Add bison.c++.
3212 * src/bison.c++: New skeleton.
3213
32142002-01-21 Paolo Bonzini <bonzini@gnu.org>
3215
3216 * po/it.po: New.
3217
32182002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3219
3220 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3221
32222002-01-20 Marc Autret <marc@gnu.org>
3223
3224 * src/files.c (compute_output_file_names): Fix
3225
32262002-01-20 Marc Autret <marc@gnu.org>
3227
3228 * tests/output.at: New test.
3229 * src/files.c (compute_base_names): Don't map extensions when
3230 the YACC flag is set, use defaults.
3231 Reported by Evgeny Stambulchik.
3232
32332002-01-20 Marc Autret <marc@gnu.org>
3234
3235 * src/system.h: Need to define __attribute__ away for non-GCC
3236 compilers as well (i.e. the vendor C compiler).
3237 Suggested by Albert Chin-A-Young.
3238
32392002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3240
3241 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3242 canonical definition.
3243 * src/system.h: Use the canonical definition for PARAMS (avoids
3244 a conflict with the macro from lib/hash.h).
3245
32462002-01-11 Akim Demaille <akim@epita.fr>
3247
3248 * configure.in: Use AC_FUNC_STRNLEN.
3249 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
3250
32512002-01-09 Akim Demaille <akim@epita.fr>
3252
3253 * src/files.c, src/files.h (output_infix): New.
3254 (tab_extension): Remove.
3255 (compute_base_names): Compute the former, drop the latter.
3256 * src/output.c (prepare): Insert the muscles `output-infix', and
3257 `output-suffix'.
3258 * src/parse-skel.y (string, string.1): New.
3259 (section.header): Use it.
3260 (section.yacc): Remove.
3261 (prefix): Remove too.
3262 * src/scan-skel.l: Adjust.
3263 * src/bison.simple, src/bison.hairy: Adjust.
3264
32652002-01-09 Akim Demaille <akim@epita.fr>
3266
3267 * configure.in (WERROR_CFLAGS): Compute it.
3268 * src/Makefile.am (CFLAGS): Pass it.
3269 * tests/atlocal.in (CFLAGS): Idem.
3270 * src/files.c: Fix a few warnings.
3271 (get_extension_index): Remove, unused.
3272
32732002-01-08 Akim Demaille <akim@epita.fr>
3274
3275 * src/getargs.c (AS_FILE_NAME): New.
3276 (getargs): Use it to convert DOSish file names.
3277 * src/files.c (base_name): Rename as full_base_name to avoid
3278 clashes with `base_name ()'.
3279 (filename_split): New.
3280 (compute_base_names): N-th rewrite, using filename_split.
3281
32822002-01-08 Akim Demaille <akim@epita.fr>
3283
3284 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3285 New, stolen from the Fileutils 4.1.
3286 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3287 * configure.in: Check for the presence of memrchr, and of its
3288 prototype.
3289
32902002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3291
3292 * lib/hash.h (__P): Added definition for this macro.
3293 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3294 BUILT_SOURCES, to ensure they are generated first.
3295 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3296 %error-verbose to allow bootstrapping with bison 1.30x.
3297
32982002-01-06 Akim Demaille <akim@epita.fr>
3299
3300 * src/reader.c (parse_braces): Don't fetch the next char, the
3301 convention is to fetch on entry.
3302 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3303 'switch' without a following semicolon.
3304 * tests/regression.at (braces parsing): New.
3305
33062002-01-06 Akim Demaille <akim@epita.fr>
3307
3308 Bison is dead wrong in its RR conflict reports.
3309
3310 * tests/torture.at (GNU Cim Grammar): New.
3311 * src/conflicts.c (count_rr_conflicts): Fix.
3312
33132002-01-06 Akim Demaille <akim@epita.fr>
3314
3315 Creating package.m4 from configure.ac causes too many problems.
3316
3317 * tests/Makefile.am (package.m4): Create it by hand,
3318 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3319
33202002-01-06 Akim Demaille <akim@epita.fr>
3321
3322 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3323 skeleton.h.
3324
33252002-01-04 Paul Eggert <eggert@twinsun.com>
3326
3327 * doc/bison.texinfo (Debugging):
3328 Remove YYSTDERR; it's no longer defined or used.
3329 Also, s/cstdio.h/cstdio/.
3330
33312002-01-03 Akim Demaille <akim@epita.fr>
3332
3333 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3334
33352002-01-03 Akim Demaille <akim@epita.fr>
3336
3337 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3338 tracing code to --trace, wait for a better --trace option, with
3339 args.
3340
33412002-01-03 Akim Demaille <akim@epita.fr>
3342
3343 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3344 The ISO C++ standard is extremely clear about it: stderr is
3345 considered a macro, not a regular symbol (see table 94 `Header
3346 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3347 Therefore std:: does not apply to it. It still does with fprintf.
3348 Also, s/cstdio.h/cstdio/.
3349
33502002-01-03 Akim Demaille <akim@epita.fr>
3351
3352 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3353 for non system headers.
3354
33552002-01-02 Akim Demaille <akim@epita.fr>
3356
3357 Equip the skeleton chain with location tracking, runtime trace,
3358 pure parser and scanner.
3359
3360 * src/parse-skel.y: Request a pure parser, locations, and prefix
3361 renaming.
3362 (%union): Having several members with the same type does not help
3363 type mismatches, simplify.
3364 (YYPRINT, yyprint): New.
3365 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3366 (skel_error): this.
3367 Handle locations.
3368 * src/scan-skel.l: Adjust to these changes.
3369 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3370 (LOCATION_PRINT, skel_control_t): New.
3371
33722001-12-30 Akim Demaille <akim@epita.fr>
3373
3374 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3375 replace `gb' with BLANKS.
3376 * src/scan-skel.l: Adjust.
3377
33782001-12-30 Akim Demaille <akim@epita.fr>
3379
3380 * src/system.h: We don't need nor want bcopy.
3381 Throw away MS-DOS crap: we don't need getpid.
3382 * configure.in: We don't need strndup. It was even causing
3383 problems: because Flex includes the headers *before* us,
3384 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3385 not visible.
3386 * lib/xstrndup.c: New.
3387 * src/scan-skel.l: Use it.
3388 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3389 * src/parse-skel.y: Use %directives instead of #defines.
3390
33912001-12-30 Akim Demaille <akim@epita.fr>
3392
3393 * src/skeleton.h: New.
3394 * src/output.c (output_parser, output_master_parser): Remove, dead
3395 code.
3396 * src/output.h (get_lines_number, actions_output, guards_output)
3397 (token_definitions_output): Prototype them.
3398 * src/parse-skel.y: Add the license notice.
3399 Include output.h and skeleton.h.
3400 (process_skeleton): Returns void, and takes a single parameter.
3401 * src/scan-skel.l: Add the license notice.
3402 Include skeleton.h.
3403 Don't use %option yylineno: it seems that then Flex imagines
3404 REJECT has been used, and therefore it won't reallocate its
3405 buffers (which makes no other sense to me than a bug). It results
3406 in warnings for `unused: yy_flex_realloc'.
3407
34082001-12-30 Robert Anisko <robert.anisko@epita.fr>
3409
3410 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3411 (MUSCLE_INSERT_PREFIX): ...to there.
3412 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3413 (MUSCLE_INSERT_PREFIX): Move from here...
3414
3415 * src/bison.hairy: Add a section directive. Put braces around muscle
3416 names. This parser skeleton is still broken, but Bison should not
3417 choke on a bad muscle 'syntax'.
3418 * src/bison.simple: Add a section directive. Put braces around muscle
3419 names.
3420
3421 * src/files.h (strsuffix, stringappend): Add declarations.
3422 (tab_extension): Add declaration.
3423 (short_base_name): Add declaration.
3424
3425 * src/files.c (strsuffix, stringappend): No longer static. These
3426 functions are used in the skeleton parser.
3427 (tab_extension): New.
3428 (compute_base_names): Use the computations done in this function
3429 to guess if the generated parsers should have '.tab' in their
3430 names.
3431 (short_base_name): No longer static.
3432
3433 * src/output.c (output_skeleton): New.
3434 (output): Disable call to output_master_parser, and give a try to
3435 a new skeleton handling system.
3436 (guards_output, actions_output): No longer static.
3437 (token_definitions_output, get_lines_number): No longer static.
3438
3439 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3440
3441 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
3442 parse-skel.y.
3443
3444 * src/parse-skel.y: New file.
3445 * src/scan-skel.l: New file.
3446
34472001-12-29 Akim Demaille <akim@epita.fr>
3448
3449 %name-prefix is broken.
3450
3451 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3452 Adjust all dependencies.
3453 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3454 %name-prefix.
3455
3456 Renaming yylval but not yylloc is not consistent. Now we do.
3457
3458 * src/bison.simple: Prefix yylloc if used.
3459 * doc/bison.texinfo (Decl Summary): Document that.
3460
34612001-12-29 Akim Demaille <akim@epita.fr>
3462
3463 * doc/bison.texinfo: Promote `%long-directive' over
3464 `%long_directive'.
3465 Remove all references to fixed-output-files, yacc is enough.
3466
34672001-12-29 Akim Demaille <akim@epita.fr>
3468
3469 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3470 user prologue. These are defaults.
3471 * tests/actions.at (Mid-rule actions): Make sure the user can
3472 define YYDEBUG and YYERROR_VERBOSE.
3473
34742001-12-29 Akim Demaille <akim@epita.fr>
3475
3476 * src/output.c (header_output): Don't forget to export YYLTYPE and
3477 yylloc.
3478 * tests/headers.at (export YYLTYPE): New, make sure it does.
3479 * tests/regression.at (%union and --defines, Invalid CPP headers):
3480 Move to...
3481 * tests/headers.at: here.
3482
34832001-12-29 Akim Demaille <akim@epita.fr>
3484
3485 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3486
34872001-12-29 Akim Demaille <akim@epita.fr>
3488
3489 * tests/actions.at (Mid-rule actions): Output on a single line
3490 instead of several.
3491
34922001-12-29 Akim Demaille <akim@epita.fr>
3493
3494 * doc/bison.texinfo: Formatting changes.
3495
34962001-12-29 Akim Demaille <akim@epita.fr>
3497
3498 Don't store the token defs in a muscle, just be ready to output it
3499 on command. Now possible via `symbols'. Fixes a memory leak.
3500
3501 * src/output.c (token_definitions_output): New.
3502 (output_parser, header_output): Use it.
3503 * src/reader.c (symbols_save): Remove.
3504
35052001-12-29 Akim Demaille <akim@epita.fr>
3506
3507 * src/bison.simple: Do not provide a default for YYSTYPE and
3508 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3509 default.
3510
35112001-12-29 Akim Demaille <akim@epita.fr>
3512
3513 Mid-rule actions are simply... ignored!
3514
3515 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3516 the empty-rule associated to the dummy symbol, not to the host
3517 rule.
3518 * tests/actions.at (Mid-rule actions): New.
3519
35202001-12-29 Akim Demaille <akim@epita.fr>
3521
3522 Memory leak.
3523
3524 * src/reader.c (reader): Free grammar.
3525
35262001-12-29 Akim Demaille <akim@epita.fr>
3527
3528 Memory leak.
3529
3530 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
3531 since it allocates it for each state, although only one is needed.
3532 (allocate_storage): Do it here.
3533
35342001-12-29 Akim Demaille <akim@epita.fr>
3535
3536 * src/options.h, src/options.c (create_long_option_table): Rename
3537 as...
3538 (long_option_table_new): this, with a clearer prototype.
3539 (percent_table): Remove, unused,
3540 * src/getargs.c (getargs): Adjust.
3541
35422001-12-29 Akim Demaille <akim@epita.fr>
3543
3544 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
3545 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
3546 as states.
3547
35482001-12-29 Akim Demaille <akim@epita.fr>
3549
3550 * src/lalr.c (build_relations): Rename `states' as `states1'.
3551 Sorry, I don't understand exactly what it is, no better name...
3552
35532001-12-29 Akim Demaille <akim@epita.fr>
3554
3555 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
3556 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
3557 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
3558 as rules.
3559
35602001-12-29 Akim Demaille <akim@epita.fr>
3561
3562 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
3563 ago.
3564
35652001-12-29 Akim Demaille <akim@epita.fr>
3566
3567 * src/reader.c, src/reader.h (user_toknums): Remove.
3568 Adjust all users to use symbols[i]->user_token_number.
3569
35702001-12-29 Akim Demaille <akim@epita.fr>
3571
3572 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
3573 Adjust all users to use symbols[i]->prec or ->assoc.
3574
35752001-12-29 Akim Demaille <akim@epita.fr>
3576
3577 * src/reader.c, src/reader.h (tags): Remove.
3578 Adjust all users to use symbols[i]->tag.
3579
35802001-12-29 Akim Demaille <akim@epita.fr>
3581
3582 * src/gram.h, src/gram.c (symbols): New, similar to state_table
3583 and rule_table.
3584 * src/reader.c (packsymbols): Fill this table.
3585 Drop sprec.
3586 * src/conflicts.c (resolve_sr_conflict): Adjust.
3587 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
3588 single table.
3589 Use symbols[i]->tag instead of tags[i].
3590
35912001-12-29 Akim Demaille <akim@epita.fr>
3592
3593 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
3594 In addition, put a comment in there, to replace...
3595 * tests/regression.at (%union and C comments): Remove.
3596
35972001-12-29 Akim Demaille <akim@epita.fr>
3598
3599 * tests/regression.at (Web2c Actions): Blindly move the actual
3600 output as expected output. The contents *seem* right to me, but I
3601 can't pretend reading perfectly parser tables... Nonetheless, all
3602 the other tests pass correctly, the table look OK, even though the
3603 presence of `$axiom' is to be noted: AFAICS it is useless (but
3604 harmless).
3605
36062001-12-29 Akim Demaille <akim@epita.fr>
3607
3608 * src/reader.c (readgram): Don't add the rule 0 if there were no
3609 rules read. In other words, add it _after_ having performed
3610 grammar sanity checks.
3611 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
3612
36132001-12-29 Akim Demaille <akim@epita.fr>
3614
3615 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
3616 visible, and some states have now a different number.
3617
36182001-12-29 Akim Demaille <akim@epita.fr>
3619
3620 * src/reader.c (readgram): Bind the initial rule's lineno to that
3621 of the first rule.
3622 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
3623 (Solved SR Conflicts): Adjust rule 0's line number.
3624
36252001-12-29 Akim Demaille <akim@epita.fr>
3626
3627 Fix the `GAWK Grammar' failure.
3628
3629 * src/LR0.c (final_state): Initialize to -1 so that we do compute
3630 the reductions of the first state which was mistakenly confused
3631 with the final state because precisely final_state was initialized
3632 to 0.
3633 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
3634 now noticed by Bison.
3635 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
3636 have a reduction on $default.
3637
36382001-12-29 Akim Demaille <akim@epita.fr>
3639
3640 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
3641 rule line numbers.
3642 * src/closure.c (print_closure): Likewise.
3643 * src/derives.c (print_derives): Likewise.
3644 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
3645 now.
3646
36472001-12-29 Akim Demaille <akim@epita.fr>
3648
3649 * src/lalr.c (lookaheads_print): New.
3650 (lalr): Call it when --trace-flag.
3651 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
3652 are dumped.
3653
36542001-12-29 Akim Demaille <akim@epita.fr>
3655
3656 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
3657 when walking through ritem, even via rule->rhs.
3658 * src/reduce.c (dump_grammar, useful_production, reduce_output)
3659 (useful_production, useless_nonterminals): Likewise.
3660 (reduce_grammar_tables): Likewise, plus update nritems.
3661 * src/nullable.c (set_nullable): Likewise.
3662 * src/lalr.c (build_relations): Likewise.
3663 * tests/sets.at (Nullable): Adjust.
3664 Fortunately, now, the $axiom is no longer nullable.
3665
36662001-12-29 Akim Demaille <akim@epita.fr>
3667
3668 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
3669 the 0-sentinel.
3670 * src/gram.c (ritem_longest_rhs): Likewise.
3671 * src/reduce.c (nonterminals_reduce): Likewise.
3672 * src/print_graph.c (print_graph): Likewise.
3673 * src/output.c (output_rule_data): Likewise.
3674 * src/nullable.c (set_nullable): Likewise.
3675
36762001-12-29 Akim Demaille <akim@epita.fr>
3677
3678 * src/output.c: Comment changes.
3679
36802001-12-27 Paul Eggert <eggert@twinsun.com>
3681
3682 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
3683 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
3684 Sparc, as they were causing more porting problems than the
3685 (minor) performance improvement was worth.
3686
3687 Also, catch up with 1.31's YYSTD.
3688
36892001-12-27 Akim Demaille <akim@epita.fr>
3690
3691 * src/output.c (output_gram): Rely on nritems, not the
3692 0-sentinel. See below.
3693 Use -1 as separator, not 0.
3694 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
3695 Rely on -1 as separator in yyrhs, instead of 0.
3696 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
3697 twice `Now at end of input', therefore there are two lines less to
3698 expect.
3699
37002001-12-27 Akim Demaille <akim@epita.fr>
3701
3702 * tests/regression.at (Unresolved SR Conflicts):
3703 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
3704 below.
3705
37062001-12-27 Akim Demaille <akim@epita.fr>
3707
3708 * src/LR0.c (new_state): Recognize the final state by the fact it
3709 is reached by eoftoken.
3710 (insert_start_shifting_state, insert_eof_shifting_state)
3711 (insert_accepting_state, augment_automaton): Remove, since now
3712 these states are automatically computed from the initial state.
3713 (generate_states): Adjust.
3714 * src/print.c: When reporting a rule number to the user, substract
3715 1, so that the axiom rule is rule 0, and the first user rule is 1.
3716 * src/reduce.c: Likewise.
3717 * src/print_graph.c (print_core): For the time being, just as for
3718 the report, depend upon --trace-flags to dump the full set of
3719 items.
3720 * src/reader.c (readgram): Once the grammar read, insert the rule
3721 0: `$axiom: START-SYMBOL $'.
3722 * tests/set.at: Adjust: rule 0 is now displayed, and since the
3723 number of the states has changed (the final state is no longer
3724 necessarily the last), catch up.
3725
37262001-12-27 Akim Demaille <akim@epita.fr>
3727
3728 Try to make the use of the eoftoken valid. Given that its value
3729 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
3730 is used instead of > 0 where appropriate, (ii), depend upon nritems
3731 instead of the 0-sentinel.
3732
3733 * src/gram.h, src/gram.c (nritems): New.
3734 Expected to be duplication of nitems, but for the time being...
3735 * src/reader.c (packgram): Assert nritems and nitems are equal.
3736 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
3737 * src/closure.c (print_closure, print_fderives): Likewise.
3738 * src/gram.c (ritem_print): Likewise.
3739 * src/print.c (print_core, print_grammar): Likewise.
3740 * src/print_graph.c: Likewise.
3741
37422001-12-27 Akim Demaille <akim@epita.fr>
3743
3744 * src/main.c (main): If there are complains after grammar
3745 reductions, then output the report anyway if requested, then die.
3746 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
3747 * src/reader.c (eoftoken): New.
3748 (parse_token_decl): If the token being defined has value `0', it
3749 is the eoftoken.
3750 (packsymbols): No longer hack `tags' to insert `$' by hand.
3751 Be sure to preserve the value of the eoftoken.
3752 (reader): Make sure eoftoken is defined.
3753 Initialize nsyms to 0: now eoftoken is created just like the others.
3754 * src/print.c (print_grammar): Don't special case the eof token.
3755 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
3756 lie anyway, albeit pleasant.
3757 * tests/calc.at: Exercise error messages with eoftoken.
3758 Change the grammar so that empty input is invalid.
3759 Adjust expectations.
3760 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
3761
37622001-12-27 Akim Demaille <akim@epita.fr>
3763
3764 * configure.in: Check the protos of strchr ans strspn.
3765 Replace strchr if needed.
3766 * src/system.h: Provide the protos of strchr, strspn and memchr if
3767 missing.
3768 * lib/strchr.c: New.
3769 * src/reader.c (symbols_save): Use strchr.
3770
37712001-12-27 Akim Demaille <akim@epita.fr>
3772
3773 * src/print.c, src/print_graph.c (escape): New.
3774 Use it to quote the TAGS outputs.
3775 * src/print_graph.c (print_state): Now errors are in red, and
3776 reductions in green.
3777 Prefer high to wide: output the state number on a line of its own.
3778
37792001-12-27 Akim Demaille <akim@epita.fr>
3780
3781 * src/state.h, src/state.c (reductions_new): New.
3782 * src/LR0.c (set_state_table): Let all the states have a
3783 `reductions', even if reduced to 0.
3784 (save_reductions): Adjust.
3785 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
3786 * src/print.c (print_reductions, print_actions): Adjust.
3787 * src/output.c (action_row): Adjust.
3788
37892001-12-27 Akim Demaille <akim@epita.fr>
3790
3791 * src/state.h, src/state.c (errs_new, errs_dup): New.
3792 * src/LR0.c (set_state_table): Let all the states have an errs,
3793 even if reduced to 0.
3794 * src/print.c (print_errs, print_reductions): Adjust.
3795 * src/output.c (output_actions, action_row): Adjust.
3796 * src/conflicts.c (resolve_sr_conflict): Adjust.
3797
37982001-12-27 Akim Demaille <akim@epita.fr>
3799
3800 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
3801
38022001-12-27 Akim Demaille <akim@epita.fr>
3803
3804 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
3805 * src/print.c: here.
3806 (lookaheadset, shiftset): New, used as additional storage by
3807 print_reductions.
3808 (print_results): Adjust.
3809 (print_shifts, print_gotos, print_errs): New, extracted from...
3810 (print_actions): here.
3811 * src/print_graph.c (print_actions): Remove dead code.
3812
38132001-12-27 Akim Demaille <akim@epita.fr>
3814
3815 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
3816 `$n' and `@n'.
3817
38182001-12-27 Akim Demaille <akim@epita.fr>
3819
3820 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
3821 (build_relations): Adjust.
3822
38232001-12-27 Akim Demaille <akim@epita.fr>
3824
3825 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
3826 duplication.
3827
38282001-12-27 Akim Demaille <akim@epita.fr>
3829
3830 * src/reader.c (packgram): Catch nitems overflows.
3831
38322001-12-27 Akim Demaille <akim@epita.fr>
3833
3834 * src/files.c, src/files.h (guard_obstack): Remove.
3835 * src/output.c (output): Adjust.
3836 * src/reader.c (parse_braces): New, factoring...
3837 (copy_action, copy_guard): these two which are renamed as...
3838 (parse_action, parse_guard): these.
3839 As a voluntary consequence, using braces around guards is now
3840 mandatory.
3841
38422001-12-27 Akim Demaille <akim@epita.fr>
3843
3844 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3845 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3846 members.
3847 (symbol_list_new): Adjust.
3848 (copy_action): action_line is the first line, not the last.
3849 (copy_guard): Just as for actions, store the `action' only, not
3850 the switch/case/break flesh.
3851 Don't parse the user action that might follow the guard, let...
3852 (readgram): do it, i.e., now, there can be an action after a
3853 guard.
3854 In other words the guard is just explicitly optional.
3855 (packgram): Adjust.
3856 * src/output.c (guards_output): New.
3857 (output_parser): Call it when needed.
3858 (output): Also free the guard and attrs obstacks.
3859 * src/files.c, src/files.h (obstack_save): Remove.
3860 (output_files): Remove.
3861 As a result, if one needs the former `.act' file, using an
3862 appropriate skeleton which requires actions and guards is now
3863 required.
3864 * src/main.c (main): Adjust.
3865 * tests/semantic.at: New.
3866 * tests/regression.at: Use `input.y' as input file name.
3867 Avoid 8+3 problems by requiring input.c when the test needs the
3868 parser.
3869
38702001-12-27 Akim Demaille <akim@epita.fr>
3871
3872 * src/reader.c (symbol_list_new): Be sure to initialize all the
3873 fields.
3874
38752001-12-27 Akim Demaille <akim@epita.fr>
3876
3877 All the hacks using a final pseudo state are now useless.
3878
3879 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3880 * src/lalr.c (nLA): New.
3881 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3882 instead of lookaheadsp from the pseudo state (nstate + 1).
3883
38842001-12-27 Akim Demaille <akim@epita.fr>
3885
3886 * src/output.c (action_row, token_actions): Use a state_t instead
3887 of a integer, and nlookaheads instead of the following state's
3888 lookaheadsp.
3889
38902001-12-27 Akim Demaille <akim@epita.fr>
3891
3892 * src/conflicts.c (log_resolution, flush_shift)
3893 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3894 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3895 (conflicts_print, print_reductions): Use a state_t instead of an
3896 integer when referring to a state.
3897 As much as possible, depend upon nlookaheads, instead of the
3898 `lookaheadsp' member of the following state (since lookaheads of
3899 successive states are successive, the difference between state n + 1
3900 and n served as the number of lookaheads for state n).
3901 * src/lalr.c (add_lookback_edge): Likewise.
3902 * src/print.c (print_core, print_actions, print_state)
3903 (print_results): Likewise.
3904 * src/print_graph.c (print_core, print_actions, print_state)
3905 (print_graph): Likewise.
3906 * src/conflicts.h: Adjust.
3907
39082001-12-27 Akim Demaille <akim@epita.fr>
3909
3910 * src/bison.hairy: Formatting/comment changes.
3911 ANSIfy.
3912 Remove `register' indications.
3913 Add plenty of `static'.
3914
39152001-12-27 Akim Demaille <akim@epita.fr>
3916
3917 * src/output.c (prepare): Drop the muscle `ntbase' which
3918 duplicates ntokens.
3919 * src/bison.simple: Formatting/comment changes.
3920 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3921 is an undocumented synonym.
3922
39232001-12-22 Akim Demaille <akim@epita.fr>
3924
3925 * src/output.c (output_table_data): Change the prototype to use
3926 `int' for array ranges: some invocations do pass an int, not a
3927 short.
3928 Reported by Wayne Green.
3929
39302001-12-22 Akim Demaille <akim@epita.fr>
3931
3932 Some actions of web2c.y are improperly triggered.
3933 Reported by Mike Castle.
3934
3935 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3936 * tests/regression.at (Web2c): Rename as...
3937 (Web2c Report): this.
3938 (Web2c Actions): New.
3939
39402001-12-22 Akim Demaille <akim@epita.fr>
3941
3942 Reductions in web2c.y are improperly reported.
3943 Reported by Mike Castle.
3944
3945 * src/conflicts.c (print_reductions): Fix.
3946 * tests/regression.at (Web2c): New.
3947
39482001-12-18 Akim Demaille <akim@epita.fr>
3949
3950 Some host fail on `assert (!"foo")', which expands to
3951 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3952 Reported by Nelson Beebee.
3953
3954 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3955 `#define it_succeeded 0' and `assert (it_succeeded)'.
3956
39572001-12-17 Marc Autret <autret_m@epita.fr>
3958
3959 * src/bison.simple: Don't hard code the skeleton line and filename.
3960 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3961 New line counter 'skeleton_line' (skeleton-line muscle).
3962
39632001-12-17 Paul Eggert <eggert@twinsun.com>
3964
3965 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3966 YYDEBUG must be defined to a nonzero value.
3967
3968 * src/bison.simple (yytname): Do not assume that the user defines
3969 YYDEBUG to a properly parenthesized expression.
3970
39712001-12-17 Akim Demaille <akim@epita.fr>
3972
3973 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3974 nlookaheads is a new member.
3975 Adjust all users.
3976 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3977 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3978 state.
3979
39802001-12-17 Akim Demaille <akim@epita.fr>
3981
3982 * src/files.h, src/files.c (open_files, close_files): Remove.
3983 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3984 let...
3985 * src/reader.c (reader): Do it.
3986
39872001-12-17 Akim Demaille <akim@epita.fr>
3988
3989 * src/conflicts.c (print_reductions): Formatting changes.
3990
39912001-12-17 Akim Demaille <akim@epita.fr>
3992
3993 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3994 (flush_reduce): New.
3995 (resolve_sr_conflict): Adjust.
3996
39972001-12-17 Akim Demaille <akim@epita.fr>
3998
3999 * src/output.c (output_obstack): Be static and rename as...
4000 (format_obstack): this, to avoid any confusion with files.c's
4001 output_obstack.
4002 * src/reader.h (muscle_obstack): Move to...
4003 * src/output.h: here, since it's defined in output.c.
4004
40052001-12-17 Akim Demaille <akim@epita.fr>
4006
4007 * src/output.c (action_row, save_column, default_goto)
4008 (sort_actions, matching_state, pack_vector): Better variable
4009 locality.
4010
40112001-12-17 Akim Demaille <akim@epita.fr>
4012
4013 * src/output.c: Various formatting changes.
4014
40152001-12-17 Akim Demaille <akim@epita.fr>
4016
4017 * src/files.c (output_files): Free the output_obstack.
4018 * src/main.c (main): Call print and print_graph conditionally.
4019 * src/print.c (print): Work unconditionally.
4020 * src/print_graph.c (print_graph): Work unconditionally.
4021 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4022
40232001-12-16 Marc Autret <autret_m@epita.fr>
4024
4025 * src/output.c (actions_output): Fix. When we use %no-lines,
4026 there is one less line per action.
4027
40282001-12-16 Marc Autret <autret_m@epita.fr>
4029
4030 * src/bison.simple: Remove a useless #line directive.
4031 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4032 * src/output.c (get_lines_number): New.
4033 (output_parser): Adjust, now takes care about the lines of a
4034 output muscles.
4035 Fix line numbering.
4036 (actions_output): Computes the number of lines taken by actions.
4037 (output_master_parser): Insert new skeleton which is the name of
4038 the output parser file name.
4039
40402001-12-15 Marc Autret <autret_m@epita.fr>
4041
4042 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4043
40442001-12-15 Marc Autret <autret_m@epita.fr>
4045
4046 * src/output.c (output_gram): Keep track of the hairy one.
4047
40482001-12-15 Akim Demaille <akim@epita.fr>
4049
4050 Make `make distcheck' work.
4051
4052 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4053 system.h which uses libgettext.h.
4054
40552001-12-15 Akim Demaille <akim@epita.fr>
4056
4057 * src/nullable.c (set_nullable): Useless rules must be skipped,
4058 otherwise, since we range over their symbols, we might look at a
4059 nonterminal which no longer ``exists'', i.e., it is not counted in
4060 `nvars', hence we overflow our arrays.
4061
40622001-12-15 Akim Demaille <akim@epita.fr>
4063
4064 The header can also be produced directly, without any obstack!
4065 Yahoo!
4066
4067 * src/files.c, src/files.h (defines_obstack): Remove.
4068 (compute_header_macro): Global.
4069 (defines_obstack_save): Remove.
4070 * src/reader.c (parse_union_decl): No longer output to
4071 defines_obstack: its content can be found in the `stype' muscle
4072 anyway.
4073 (output_token_translations): Merge into...
4074 (symbols_output): this.
4075 Rename as...
4076 (symbols_save): this.
4077 (reader): Adjust.
4078 * src/output.c (header_output): New.
4079 (output): Call it.
4080
40812001-12-15 Akim Demaille <akim@epita.fr>
4082
4083 * src/reader.c (parse_union_decl): Instead of handling two obstack
4084 simultaneously, use one to define the `stype' muscle, and use the
4085 value of the latter to fill defines_obstack.
4086 (copy_comment): Remove.
4087 (copy_comment2): Work for a single obstack.
4088 Rename as...
4089 (copy_comment): this.
4090
40912001-12-15 Akim Demaille <akim@epita.fr>
4092
4093 * src/lex.c, src/lex.h (xgetc): No longer static.
4094 * src/reader.c (parse_union_decl): Revamp.
4095
40962001-12-15 Akim Demaille <akim@epita.fr>
4097
4098 Still making progress in separating Bison into (i) input, (ii)
4099 process, (iii) output: now we can directly output the parser file
4100 without using table_obstack at all.
4101
4102 * src/files.c, src/files.h (table_obstack): Bye bye.
4103 (parser_file_name): New.
4104 * src/files.c (compute_output_file_names): Compute it.
4105 * src/output.c (actions_output, output_parser)
4106 (output_master_parser): To a file instead of an obstack.
4107
41082001-12-15 Akim Demaille <akim@epita.fr>
4109
4110 Attach actions to rules, instead of pre-outputting them to
4111 actions_obstack.
4112
4113 * src/gram.h (rule_t): action and action_line are new members.
4114 * src/reader.c (symbol_list): Likewise.
4115 (copy_action): Save the actions within the rule.
4116 (packgram): Save them in rule_table.
4117 * src/output.c (actions_output): New.
4118 (output_parser): Use it on `%%actions'.
4119 (output_rule_data): Don't free rule_table.
4120 (output): Do it.
4121 (prepare): Don't save the `action' muscle.
4122 * src/bison.simple: s/%%action/%%actions/.
4123
41242001-12-15 Akim Demaille <akim@epita.fr>
4125
4126 * src/reader.c (copy_action): When --yacc, don't append a `;'
4127 to the user action: let it fail if lacking.
4128 Suggested by Arnold Robbins and Tom Tromey.
4129
41302001-12-14 Akim Demaille <akim@epita.fr>
4131
4132 * src/lex.c (literalchar): Simply return the char you decoded, non
4133 longer mess around with obstacks and int pointers.
4134 Adjust all callers.
4135
41362001-12-14 Akim Demaille <akim@epita.fr>
4137
4138 * src/lex.c (literalchar): Don't escape the special characters,
4139 just decode them, and keep them as char (before, eol was output as
4140 the 2 char string `\n' etc.).
4141 * src/output.c (output_rule_data): Use quotearg to output the
4142 token strings.
4143
41442001-12-13 Paul Eggert <eggert@twinsun.com>
4145
4146 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4147 Do not infringe on the global user namespace when using C++.
4148 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4149 All uses of `fprintf' and `stderr' changed.
4150
4151 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4152
41532001-12-13 Akim Demaille <akim@epita.fr>
4154
4155 The computation of nullable is broken: it doesn't handle empty
4156 RHS's properly.
4157
4158 * tests/torture.at (GNU AWK Grammar): New.
4159 * tests/sets.at (Nullable): New.
4160 * src/nullable.c (set_nullable): Instead of blindly looping over
4161 `ritems', loop over the rules, and then over their rhs's.
4162
4163 Work around Autotest bugs.
4164
4165 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4166 frame, because Autotest understand lines starting with a `+' as
4167 traces from the shell. Then, they are not processed properly.
4168 Admittedly an Autotest bug, but we don't have time to wait for
4169 Autotest to catch up.
4170 * tests/regression.at (Broken Closure): Adjust to the new table
4171 frames.
4172 Move to...
4173 * tests/sets.at: here.
4174
41752001-12-13 Akim Demaille <akim@epita.fr>
4176
4177 * src/closure.c (closure): Use nrules instead of playing tricks
4178 with BITS_PER_WORD.
4179
41802001-12-13 Akim Demaille <akim@epita.fr>
4181
4182 * src/print.c (print_actions): Output the handling of `$' as the
4183 traces do: shifting the token EOF. Before EOF was treated as a
4184 nonterminal.
4185 * tests/regression.at: Adjust some tests.
4186 * src/print_graph.c (print_core): Complete the set of items via
4187 closure. The next-to-final and final states are still unsatisfying,
4188 but that's to be addressed elsewhere.
4189 No longer output the rule numbers, but do output the state number.
4190 A single loop for the shifts + gotos is enough, but picked a
4191 distinct color for each.
4192 (print_graph): Initialize and finalize closure.
4193
41942001-12-13 Akim Demaille <akim@epita.fr>
4195
4196 * src/reader.c (readgram): Remove dead code, an strip useless
4197 braces.
4198 (get_type): Remove, unused.
4199
42002001-12-12 Akim Demaille <akim@epita.fr>
4201
4202 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4203 on that of lib/error.c.
4204
42052001-12-12 Akim Demaille <akim@epita.fr>
4206
4207 Some hosts don't like `/' in includes.
4208
4209 * src/system.h: Include libgettext.h without qualifying the path.
4210 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4211 $(top_srcdir).
4212
42132001-12-11 Marc Autret <autret_m@epita.fr>
4214
4215 * src/output.c (output_parser): Remove useless muscle.
4216
42172001-12-11 Marc Autret <autret_m@epita.fr>
4218
4219 * src/bison.simple: Remove #line just before %%epilogue. It
4220 is now handled in ...
4221 * src/reader.c (read_additionnal_code): Add the output of a
4222 #line for the epilogue.
4223
42242001-12-10 Marc Autret <autret_m@epita.fr>
4225
4226 * src/reader.c (copy_definition): Re-use CPP-outed code which
4227 replace precedent remove.
4228 * src/bison.simple: Remove #line before %%prologue because
4229 %%input-line is wrong at this time.
4230
42312001-12-10 Marc Autret <autret_m@epita.fr>
4232
4233 * src/reader.c (symbols_output): Clean up.
4234 * src/output.c (output_gram, output): Clean up.
4235
42362001-12-10 Akim Demaille <akim@epita.fr>
4237
4238 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4239 * src/LR0.c (set_state_table): here.
4240 * src/lalr.c (lalr): Call it.
4241
42422001-12-10 Akim Demaille <akim@epita.fr>
4243
4244 * src/state.h (shifts): Remove the `number' member: shifts are
4245 attached to state, hence no longer need to be labelled with a
4246 state number.
4247
42482001-12-10 Akim Demaille <akim@epita.fr>
4249
4250 Now that states have a complete set of members, the linked list of
4251 shifts is useless: just fill directly the state's shifts member.
4252
4253 * src/state.h (shifts): Remove the `next' member.
4254 * src/LR0.c (first_state, last_state): Remove.
4255 Adjust the callers.
4256 (augment_automaton): Don't look for the shifts that must be added
4257 a shift on EOF: it is those of the state we looked for! But now,
4258 since shifts are attached, it is no longer needed to looking
4259 merely by its id: its number.
4260
42612001-12-10 Akim Demaille <akim@epita.fr>
4262
4263 * src/LR0.c (augment_automaton): Better variable locality.
4264 Remove an impossible branch: if there is a state corresponding to
4265 the start symbol being shifted, then there is shift for the start
4266 symbol from the initial state.
4267
42682001-12-10 Akim Demaille <akim@epita.fr>
4269
4270 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4271 only when appropriate: when insert_start_shifting_state' is not
4272 invoked.
4273 * tests/regression.at (Rule Line Numbers): Adjust.
4274
42752001-12-10 Akim Demaille <akim@epita.fr>
4276
4277 * src/LR0.c (augment_automaton): Now that all states have shifts,
4278 merge the two cases addition shifts to the initial state.
4279
42802001-12-10 Akim Demaille <akim@epita.fr>
4281
4282 * src/lalr.c (set_state_table): Move to...
4283 * src/LR0.c: here.
4284 * src/lalr.c (lalr): Don't call it...
4285 * src/LR0.c (generate_states): do it.
4286 * src/LR0.h (first_state): Remove, only the table is used.
4287
42882001-12-10 Akim Demaille <akim@epita.fr>
4289
4290 * src/LR0.h (first_shift, first_reduction): Remove.
4291 * src/lalr.c: Don't use first_shift: find shifts through the
4292 states.
4293
42942001-12-10 Akim Demaille <akim@epita.fr>
4295
4296 * src/LR0.c: Attach shifts to states as soon as they are
4297 computed.
4298 * src/lalr.c (set_state_table): Instead of assigning shifts to
4299 state, just assert that the mapping was properly done.
4300
43012001-12-10 Akim Demaille <akim@epita.fr>
4302
4303 * src/LR0.c (insert_start_shift): Rename as...
4304 (insert_start_shifting_state): this.
4305 (insert_eof_shifting_state, insert_accepting_state): New.
4306 (augment_automaton): Adjust.
4307 Better locality of the variables.
4308 When looking if the start_symbol is shifted from the initial
4309 state, using `while (... symbol != start_symbol ...)' sounds
4310 better than `while (... symbol < start_symbol ...)': If fail
4311 to see how the order between symbols could be relevant!
4312
43132001-12-10 Akim Demaille <akim@epita.fr>
4314
4315 * src/getargs.h: Don't declare `spec_name_prefix' and
4316 `spec_file_prefix', declared by src/files.h.
4317 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4318 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4319 * src/output.c (prepare): Adjust.
4320 * src/reader.c (symbols_output): Likewise.
4321 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4322
43232001-12-10 Akim Demaille <akim@epita.fr>
4324
4325 * src/muscle_tab.c (muscle_init): NULL is a better default than
4326 `"0"'.
4327
43282001-12-10 Akim Demaille <akim@epita.fr>
4329
4330 * src/reader.c (reader): Calling symbols_output once is enough.
4331
43322001-12-10 Akim Demaille <akim@epita.fr>
4333
4334 Now that states have a complete set of members, the linked list of
4335 reductions is useless: just fill directly the state's reductions
4336 member.
4337
4338 * src/state.h (struct reductions): Remove member `number' and
4339 `next'.
4340 * src/LR0.c (first_reduction, last_reduction): Remove.
4341 (save_reductions): Don't link the new reductions, store them in
4342 this_state.
4343 * src/lalr.c (set_state_table): No need to attach reductions to
4344 states, it's already done.
4345 * src/output.c (output_actions): No longer free the shifts, then
4346 the reductions, then the states: free all the states and their
4347 members.
4348
43492001-12-10 Akim Demaille <akim@epita.fr>
4350
4351 * src/options.c (OPTN, DRTV, BOTH): New.
4352 (option_table): Use them.
4353
4354 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4355 the job of system.h.
4356 * src/options.c: Don't include stdio.h and xalloc.h for the same
4357 reasons.
4358
43592001-12-10 Akim Demaille <akim@epita.fr>
4360
4361 * src/output.c (output, prepare): Make sure the values of the
4362 muscles `action' and `prologue' are 0-terminated.
4363
43642001-12-10 Akim Demaille <akim@epita.fr>
4365
4366 Clean up GCC warnings.
4367
4368 * src/reader.c (copy_action): `buf' is not used.
4369 (parse_skel_decl): Be static.
4370 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4371 * src/options.h (create_long_option_table): Have a real prototype.
4372 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4373 (hash_delete_at): Return const void *.
4374 Adjust casts to preserve the const.
4375
43762001-12-10 Akim Demaille <akim@epita.fr>
4377
4378 * configure.in: Require 2.52g.
4379 M4 is not needed, but AUTOM4TE is.
4380 * m4/m4.m4: Remove.
4381 * tests/Makefile.am: Adjust.
4382
43832001-12-10 Akim Demaille <akim@epita.fr>
4384
4385 One structure for states is enough, even though theoretically
4386 there are LR(0) states and LALR(1) states.
4387
4388 * src/lalr.h (state_t): Remove.
4389 (state_table): Be state_t **, not state_t *.
4390 * src/state.h (core, CORE_ALLOC): Rename as...
4391 (state_t, STATE_ALLOC): this.
4392 Add the LALR(1) members: shifts, reductions, errs.
4393 * src/LR0.c (state_table): Rename as...
4394 (state_hash): this, to avoid name clashes with the global
4395 `state_table'.
4396 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4397 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4398
43992001-12-10 Akim Demaille <akim@epita.fr>
4400
4401 Bison dumps core on bash.y.
4402 Reported by Pascal Bart.
4403
4404 * src/warshall.c (bitmatrix_print): New.
4405 (TC): Use it.
4406 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4407 j must be the outer loop.
4408 * tests/regression.at (Broken Closure): New.
4409
44102001-12-05 Akim Demaille <akim@epita.fr>
4411
4412 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4413 its argument.
4414