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