]> git.saurik.com Git - bison.git/blame - ChangeLog
(BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
[bison.git] / ChangeLog
CommitLineData
14904b89
PE
12002-10-12 Paul Eggert <eggert@twinsun.com>
2
98194095
PE
3 * src/reader.c (grammar_current_rule_check):
4 Don't worry about the default action if $$ is untyped.
5 Prevents bogus warnings reported by Jim Gifford in
6 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
7
14904b89
PE
8 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
9 * data/glr.c, data/lalr1.cc, data/yacc.c:
10 Output token definitions before the first part of user declarations.
11 Fixes compatibility problem reported by Jim Gifford for kbd in
12 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
13
ff6dca18
PE
142002-10-11 Paul Eggert <eggert@twinsun.com>
15
16 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
17 (yyparse): here. This undoes some of the 2002-07-25 change.
18 Compatibility problem reported by Ralf S. Engelschall with
19 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
20
eb714592
AD
212002-10-11 Akim Demaille <akim@epita.fr>
22
23 * tests/regression.at Characters Escapes): New.
24 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
25 characters.
26 Reported by Jan Nieuwenhuizen.
27
b7195100
AD
282002-10-11 Akim Demaille <akim@epita.fr>
29
30 * po/id.po: New.
31
f28a0f2d
PE
322002-10-10 Paul Eggert <eggert@twinsun.com>
33
34 Portability fixes for bitsets; this also avoids several GCC
35 warnings.
36
37 * lib/abitset.c: Include <stddef.h>, for offsetof.
38 * lib/lbitset.c: Likewise.
39
40 * lib/abitset.c (abitset_bytes): Return a size that is aligned
41 properly for vectors of objects. Do not assume that adding a
42 header size to a multiple of a word size yields a value that is
43 properly aligned for the whole union.
44 * lib/bitsetv.c (bitsetv_alloc): Likewise.
45
46 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
47 unique names for structures.
48 * lib/ebitset.c (ebitset_bytes): Likewise.
49 * lib/lbitset.c (lbitset_bytes): Likewise.
50
51 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
52 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
53 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
54 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
55 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
56 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
57 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
58 to improve the type-checking that GCC can do.
59 * lib/bitset.c (bitset_op4_cmp): Likewise.
60 * lib/bitset_stats.c (bitset_stats_count,
61 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
62 bitset_stats_copy, bitset_stats_disjoint_p,
63 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
64 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
65 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
66 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
67 bitset_stats_and_or_cmp, bitset_stats_andn_or,
68 bitset_stats_andn_or_cmp, bitset_stats_or_and,
69 bitset_stats_or_and_cmp): Likewise.
70 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
71 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
72 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
73 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
74
75 * lib/abitset.h: Include bitset.h, not bbitset.h.
76 * lib/ebitset.h: Likewise.
77 * lib/lbitset.h: Likewise.
78
79 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
80 All instances of parameters of type enum bitset_opts are now of
81 type enum_bitset_opts, to conform to the C Standard, and similarly
82 for enum_bitset_type.
83 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
84 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
85
86 Do not use "struct bitset_struct" to mean different things in
87 different modules. Not only is this confusing, it violates
88 the C Standard, which requires that structure types in different
89 modules must be compatible if one is to be passed to the other.
90 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
91 All instances of "struct bitset_struct *" replaced with "bitset".
92 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
93 (union bitset_union, struct abitset_struct, struct ebitset_struct,
94 struct lbitset_struct, struct bitset_stats_struct): New types.
95 All uses of struct bitset_struct changed to union bitset_union,
96 etc.
97 * lib/abitset.c (struct abitset_struct, abitset,
98 struct bitset_struct): Remove.
99 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
100 struct bitset_struct): Remove.
101 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
102 bitset_struct): Remove.
103 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
104 Likewise.
105
106 Do not call a function of type T using a call that assumes the
107 function is of a different type U. Standard C requires that a
108 function must be called with a type that is compatible with its
109 definition.
110 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
111 New decls.
112 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
113 New functions.
114 * lib/ebitset.c (PFV): Remove.
115 * lib/lbitset.c (PFV): Likewise.
116 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
117 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
118 decls.
119 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
120 (ebitset_vtable): Use them.
121 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
122 lbitset_xor): New functions.
123 (lbitset_vtable): Use them.
124
125 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
126 Declare.
127
128 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
129 GCC warning.
130 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
131 Use offsetof, for simplicity.
132
6fbe4984
PE
1332002-10-06 Paul Eggert <eggert@twinsun.com>
134
135 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
136 the same width as int. This reapplies a hunk of the 2002-08-12 patch
137 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
138 which was inadvertently undone by the 2002-09-30 patch.
139 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
140 the same width as int.
141
420f93c8
PE
1422002-10-04 Paul Eggert <eggert@twinsun.com>
143
144 Version 1.50.
145
146 * configure.ac (AC_INIT), NEWS: Increment version number.
147
148 * doc/bison.texinfo: Minor spelling, grammar, and white space
149 fixes.
150 (Symbols): Mention that any negative value returned from yylex
151 signifies end-of-input. Warn about negative chars. Mention
152 the portable Standard C character set.
153
154 The GNU coding standard says CFLAGS and YFLAGS are reserved
155 for the installer to set.
156 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
157 * src/Makefile.am (AM_CFLAGS): Likewise.
158 (AM_YFLAGS): Renamed from YFLAGS.
159
160 Fix some MAX and MIN problems.
161 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
162 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
163 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
164 * src/reader.c (reader): Use it.
165
166 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
167 POSIX 1003.1-2001 has removed fgrep.
168
1692002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
170
171 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
172 interpreted as signed.
173 * lib/ebitset.c (ebitset_list): Fix bug.
174
ff68026d
PE
1752002-10-01 Paul Eggert <eggert@twinsun.com>
176
177 More fixes for 64-bit hosts and large bitsets.
178
179 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
180 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
181 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
182 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
183 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
184 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
185 bitset_count_): Likewise.
186 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
187 bitset_first, bitset_last): Likewise.
188 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
189 bitset_stats_list_reverse, bitset_stats_size,
190 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
191 Likewise.
192 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
193 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
194 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
195 bitsetv_reflexive_transitive_closure): Likewise.
196 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
197 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
198 Likewise.
199 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
200 Likewise.
420f93c8 201
ff68026d
PE
202 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
203 Use size_t, not unsigned int, to count bytes.
204 * lib/abitset.h (abitset_bytes): Likewise.
205 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
206 Likewise.
207 * lib/bitset.h (bitset_bytes): Likewise.
208 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
209 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
210 * lib/bitsetv.c (bitsetv_alloc): Likewise.
211 * lib/ebitset.c (ebitset_bytes): Likewise.
212 * lib/ebitset.h (ebitset_bytes): Likewise.
213 * lib/lbitset.c (lbitset_bytes): Likewise.
214 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 215
ff68026d
PE
216 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
217 abitset_subset_p, abitset_disjoint_p, abitset_and,
218 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
219 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
220 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
221 abitset_or_and, abitset_or_and_cmp):
222 Use bitset_windex instead of unsigned int.
223 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
224 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
225 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
226 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
227 Likewise.
228 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 229
ff68026d
PE
230 * lib/bitset.c (bitset_print):
231 Use proper printf formats for widths of integer types.
232 * lib/bitset_stats.c (bitset_percent_histogram_print,
233 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
234 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
235 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
236 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 237
ff68026d
PE
238 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
239 BITSET_SIZE_MAX): New macros.
240 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
241 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
242 to BITSET_WINDEX_MAX.
243
244 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
245 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
246 since we now return the bitset_bindex type (not int).
247
248 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
249 when computing sizes.
250 * lib/ebitset.c (ebitset_elts_grow): Likewise.
251
252 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
253 and avoid cast to unsigned.
254
6aa452a6
AD
2552002-09-30 Akim Demaille <akim@epita.fr>
256
257 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
258 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
259 Updates from Michael Hayes.
260
927f7817
AD
2612002-09-30 Art Haas <ahaas@neosoft.com>
262
263 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
264 invocations.
265 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
266 defined.
267
9738f41e
AD
2682002-09-27 Akim Demaille <akim@epita.fr>
269
270 Version 1.49c.
271
a5c75d7f
AD
2722002-09-27 Akim Demaille <akim@epita.fr>
273
274 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
275 (Because of AC_LIBSOURCE).
276
8280e179
AD
2772002-09-27 Akim Demaille <akim@epita.fr>
278
279 Playing with Autoscan.
280
281 * configure.ac: Remove the old LIBOBJ tweaks.
282 (AC_REPLACE_FUNCS): Add strrchr and strtol.
283 * lib/strrchr.c: New.
284 * lib/strtol.c: New, from the Coreutils 4.5.1.
285
ae64af35
AD
2862002-09-27 Akim Demaille <akim@epita.fr>
287
288 Playing with Autoscan.
289
290 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
291 * lib/Makefile.am (libbison_a_SOURCES): No longer include
292 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
293 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
294 Coreutils 4.5.1.
295
d1a1114f
AD
2962002-09-24 Akim Demaille <akim@epita.fr>
297
298 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
299 (Frequently Asked Questions, Parser Stack Overflow): New.
300
b906441c
AD
3012002-09-13 Akim Demaille <akim@epita.fr>
302
303 Playing with autoscan.
304
305 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
306 * src/files.c (skeleton_find): Remove, unused.
307 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
308 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
309
bd701811
AD
3102002-09-13 Akim Demaille <akim@epita.fr>
311
312 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
313 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
314
e0a13e7b
AD
3152002-09-13 Akim Demaille <akim@epita.fr>
316
317 * configure.ac: Require 2.54.
318 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
319 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
320 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
321 Remove, provided by Autoconf macros.
322
c97011bf
AD
3232002-09-12 Akim Demaille <akim@epita.fr>
324
325 * m4/prereq.m4: Update, from Coreutils 4.5.1.
326
d862b1be
AD
3272002-09-12 Akim Demaille <akim@epita.fr>
328
329 * m4/prereq.m4: Update, from Fileutils 4.1.5.
330 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
331 Reported by Martin Mokrejs.
332
3d38c03a
AD
3332002-09-10 Akim Demaille <akim@epita.fr>
334
335 * src/parse-gram.y: Associate a human readable string to each
336 token type.
337 * tests/regression.at (Invalid inputs): Adjust.
338
b6347355
AD
3392002-09-10 Gary V. Vaughan <gary@gnu.org>
340
341 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
342 with an Autoconf-2.5x style configure.ac.
343
09ba4ab2
PE
3442002-09-06 Paul Eggert <eggert@twinsun.com>
345
346 * doc/bison.texinfo (Conditions): Make explicit that the GPL
347 exception applies only to yacc.c. This is a modification of a
348 patch originally suggested by Akim Demaille.
349
21846f69
AD
3502002-09-06 Akim Demaille <akim@epita.fr>
351
09ba4ab2
PE
352 * data/c.m4 (b4_copyright): Move the GPL exception comment from
353 here to...
354 * data/yacc.c: here.
355
21846f69
AD
356 * data/lalr1.cc (struct yyltype): Don't define it, since we use
357 LocationType.
358 (b4_ltype): Default to yy::Location from location.hh.
359
c0ad8bf3
AD
3602002-09-04 Jim Meyering <jim@meyering.net>
361
362 * data/yacc.c: Guard the declaration of yytoknum also with
363 `#ifdef YYPRINT', so it is declared only when used.
364
3a93251e
AD
3652002-09-04 Akim Demaille <akim@epita.fr>
366
367 * configure.in: Rename as...
368 * configure.ac: this.
369 Bump to 1.49c.
370
427c0dda
AD
3712002-09-04 Akim Demaille <akim@epita.fr>
372
373 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
374 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
375 translate maintainer only messages.
376
6a254321
PE
3772002-08-12 Paul Eggert <eggert@twinsun.com>
378
645e30d1
PE
379 Version 1.49b.
380
6a254321
PE
381 * Makefile.am (SUBDIRS): Remove intl.
382 (DISTCLEANFILES): Remove.
383 * NEWS: Mention that GNU M4 is now required. Clarify what is
384 meant by "larger grammars". Mention the pt_BR translation.
385 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
386 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
387 Bump version from 0.11.2 to 0.11.5.
388 (BISON_PREREQ_STAGE): Remove.
389 (AM_GNU_GETTEXT): Use external gettext.
390 (AC_OUTPUT): Remove intl/Makefile.
391
392 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
393
394 * data/glr.c: Include string.h, for strlen.
395 (yyreportParseError): Use size_t for yysize.
396 (yy_yypstack): No longer nested inside yypstates, as nested
397 functions are not portable. Do not assume size_t is the
398 same width as int.
399 (yypstates): Do not assume that ptrdiff_t is the same width
400 as int, and similarly for yyposn and YYINDEX.
401
402 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
403
404 * lib/Makefile.am (INCLUDES): Do not include from the intl
405 directory, which has been removed.
406 * src/Makefile.am (INCLUDES): Likewise.
407
408 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
409 (bitsets_sources, additional_bitsets_sources, timevars_sources):
410 New vars.
411
412 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
413 * tests/Makefile.am (EXTRA_DIST): Likewise.
414
415 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
416 Do not assume that bitset_windex is the same width as unsigned.
417
418 * lib/abitset.c (abitset_unused_clear): Do not assume that
419 bitset_word is the same width as int.
420 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
421 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
422 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
423 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
424 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
425
426 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
427 portability to one's complement hosts!).
428 * lib/ebitset.c (ebitset_op1): Likewise.
429 * lib/lbitset.c (lbitset_op1): Likewise.
430
431 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
432 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
433 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
434 Sync with fileutils.
435 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
436 lib/gettext.h: Sync with diffutils.
437
438 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
439 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
440
441 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
442 PROTOTYPES to check for prototypes, and "defined __STDC__" to
443 check for void *.
444
445 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
446 size_t; the old version tried to do this but casted improperly.
447 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
448 (bitset_test): Now returns int, not unsigned long.
449
450 * lib/bitset_stats.c: Include "gettext.h".
451 (_): New macro.
452 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
453 name locals "index", as it generates unnecessary warnings on some
454 hosts that have an "index" function.
455
456 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
457 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
458 they need translation.
459 * src/LR0.c (state_list_append, new_itemsets, get_state,
460 append_states, generate_states): Likewise.
461 * src/assoc.c (assoc_to_string): Likewise.
462 * src/closure.c (print_closure, set_firsts, closure): Likewise.
463 * src/gram.c (grammar_dump): Likewise.
464 * src/injections.c (injections_compute): Likewise.
465 * src/lalr.c (lookaheads_print): Likewise.
466 * src/relation.c (relation_transpose): Likewise.
467 * src/scan-gram.l: Likewise.
468 * src/tables.c (table_grow, pack_vector): Likewise.
469
470 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
471 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
472 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
473 * m4/mbstate_t.m4: Sync with fileutils.
474 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
475
476 * po/LINGUAS: Add pt_BR.
477 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
478 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
479 lib/timevar.c.
480 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
481 manual recommends.
482 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
483
484 * src/complain.c (strerror_r): Remove decl; not needed.
485 (strerror): Use same pattern as ../lib/error.c.
486
487 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
488
489 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
490
491 * src/main.c (main): Cast result of bindtextdomain and textdomain
492 to void, to avoid a GCC warning when --disable-nls is in effect.
493
494 * src/scan-gram.l: Use strings rather than escapes when possible,
495 to minimize the number of warnings from xgettext.
496 (handle_action_dollar, handle_action_at): Don't use isdigit,
497 as it mishandles negative chars and it may not work as expected
498 outside the C locale.
499
500 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
501 this is a GCC extension and is not portable to other compilers.
502
503 * src/system.h (alloca): Use same pattern as ../lib/error.c.
504 Do not include <ctype.h>; no longer needed.
505 Do not include <malloc.h>; no longer needed (and generates
506 warnings on OpenBSD 3.0).
507
508 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
509 it's not portable.
510
511 * tests/regression.at: Do not use 'cc -c input.c -o input';
512 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
513
514 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
515 exit status as failure, not just exit status 1. Sun C exits
516 with status 2 sometimes.
517
518 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
519 Use it for the two large tests.
520
c8f002c7
AD
5212002-08-02 Akim Demaille <akim@epita.fr>
522
523 * src/conflicts.c (conflicts_output): Don't output rules never
524 reduced here, since anyway that computation doesn't work.
525 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
526 (rule_useless_p, rule_never_reduced_p): New.
527 (grammar_rules_partial_print): Use a filter instead of a range.
528 Display the title only if needed.
529 (grammar_rules_print): Adjust.
530 (grammar_rules_never_reduced_report): New.
531 * src/tables.c (action_row): Move the computation of rules never
532 reduced to...
533 (token_actions): here.
534 * src/main.c (main): Make the parser before making the report, so
535 that rules never reduced are computed.
536 Call grammar_rules_never_reduced_report.
537 * src/print.c (print_results): Report rules never reduced.
538 * tests/conflicts.at, tests/reduce.at: Adjust.
539
cd08e51e
AD
5402002-08-01 Akim Demaille <akim@epita.fr>
541
542 Instead of attaching lookaheads and duplicating the rules being
543 reduced by a state, attach the lookaheads to the reductions.
544
545 * src/state.h (state_t): Remove the `lookaheads',
546 `lookaheads_rule' member.
547 (reductions_t): Add a `lookaheads' member.
548 Use a regular array for the `rules'.
549 * src/state.c (reductions_new): Initialize the lookaheads member
550 to 0.
551 (state_rule_lookaheads_print): Adjust.
552 * src/state.h, src/state.c (state_reductions_find): New.
553 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
554 (count_rr_conflicts): Adjust.
555 * src/lalr.c (LArule): Remove.
556 (add_lookback_edge): Adjust.
557 (state_lookaheads_count): New.
558 (states_lookaheads_initialize): Merge into...
559 (initialize_LA): this.
560 (lalr_free): Adjust.
561 * src/main.c (main): Don't free nullable and derives too early: it
562 is used by --verbose.
563 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
564
bb0027a9
AD
5652002-08-01 Akim Demaille <akim@epita.fr>
566
567 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
568 `rule_number_t**'.
569 (set_derives, free_derives): Rename as...
570 (derives_compute, derives_free): this.
571 Adjust all dependencies.
572 * src/nullable.c (set_nullable, free_nullable): Rename as...
573 (nullable_compute, nullable_free): these.
574 (rule_list_t): Store rule_t *, not rule_number_t.
575 * src/state.c (state_rule_lookaheads_print): Directly compare rule
576 pointers, instead of their numbers.
577 * src/main.c (main): Call nullable_free, and derives_free earlier,
578 as they were lo longer used.
579
3325ddc4
AD
5802002-08-01 Akim Demaille <akim@epita.fr>
581
582 * lib/timevar.c (get_time): Include children time.
583 * src/lalr.h (LA, LArule): Don't export them: used with the
584 state_t.
585 * src/lalr.c (LA, LArule): Static.
586 * src/lalr.h, src/lalr.c (lalr_free): New.
587 * src/main.c (main): Call it.
588 * src/tables.c (pack_vector): Check whether loc is >= to the
589 table_size, not >.
590 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
591 (tables_generate): do it, since that's also it which allocates
592 them.
593 Don't free LA and LArule, main does.
594
c6f1a33c
AD
5952002-07-31 Akim Demaille <akim@epita.fr>
596
597 Separate parser tables computation and output.
598
599 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
600 (conflict_list, conflict_list_cnt, table, check, table_ninf)
601 (yydefgoto, yydefact, high): Move to...
602 * src/tables.h, src/tables.c: here.
603 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
604 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
605 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
606 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
607 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
608 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
609 (action_row, save_row, token_actions, save_column, default_goto)
610 (goto_actions, sort_actions, matching_state, pack_vector)
611 (table_ninf_remap, pack_table, prepare_actions): Move to...
612 * src/tables.c: here.
613 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
614 * src/output.c (token_actions, output_base, output_conflicts)
615 (output_check): Merge into...
616 (prepare_actions): this.
617 (actions_output): Rename as...
618 (user_actions_output): this.
619 * src/main.c (main): Call tables_generate and tables_free.
620
1509d42f
AD
6212002-07-31 Akim Demaille <akim@epita.fr>
622
623 Steal GCC's --time-report support.
624
625 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
626 stolen/adjusted from GCC.
627 * m4/stage.m4: Remove time related checks.
628 * m4/timevar.m4: New.
629 * configure.in: Adjust.
630 * src/system.h: Adjust to using timevar.h.
631 * src/getargs.h, src/getargs.c: Support trace_time for
632 --trace=time.
633 * src/main.c (stage): Remove.
634 (main): Replace `stage' invocations with timevar calls.
635 * src/output.c: Insert pertinent timevar calls.
636
273a74fa
AD
6372002-07-31 Akim Demaille <akim@epita.fr>
638
639 Let --trace have arguments.
640
641 * src/getargs.h (enum trace_e): New.
642 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
643 (long_options, short_options): --trace/-T takes an optional
644 argument.
645 Change all the uses of trace_flag to reflect the new flags.
646 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
647
648 Strengthen `stage' portability.
649
650 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
651 * configure.in: Use it.
652 Don't check for malloc.h and sys/times.h.
653 * src/system.h: Include them when appropriate.
654 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
655 times and struct tms are available.
656
217598da
AD
6572002-07-30 Akim Demaille <akim@epita.fr>
658
659 In verbose parse error message, don't report `error' as an
660 expected token.
661 * tests/actions.at (Printers and Destructors): Adjust.
662 * tests/calc.at (Calculator $1): Adjust.
663 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
664 error message, do not report the parser accepts the error token in
665 that state.
666
52489d44
AD
6672002-07-30 Akim Demaille <akim@epita.fr>
668
669 Normalize conflict related messages.
670
671 * src/complain.h, src/complain.c (warn, complain): New.
672 * src/conflicts.c (conflicts_print): Use them.
673 (conflict_report_yacc): New, extracted from...
674 (conflicts_print): here.
675 * tests/conflicts.at, tests/existing.at: Adjust.
676
e8832397
AD
6772002-07-30 Akim Demaille <akim@epita.fr>
678
679 Report rules which are never reduced by the parser: those hidden
680 by conflicts.
681
682 * src/LR0.c (save_reductions): Don't make the final state too
683 different: save its reduction (accept) instead of having a state
684 without any action (no shift or goto, no reduce).
685 Note: the final state is now a ``regular'' state, i.e., the
686 parsers now contain `reduce 0' as default reduction.
687 Nevertheless, since they decide to `accept' when yystate =
688 final_state, they still will not reduce rule 0.
689 * src/print.c (print_actions, print_reduction): Adjust.
690 * src/output.c (action_row): Track reduced rules.
691 (token_actions): Report rules never reduced.
692 * tests/conflicts.at, tests/regression.at: Adjust.
693
caf23d24
AD
6942002-07-30 Akim Demaille <akim@epita.fr>
695
696 `stage' was accidently included in a previous patch.
697 Initiate its autoconfiscation.
698
699 * configure.in: Look for malloc.h and sys/times.h.
700 * src/main.c (stage): Adjust.
701 Report only when trace_flag.
702
640748ee
AD
7032002-07-29 Akim Demaille <akim@epita.fr>
704
705 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
706 state_number_t.
707 (errs_t): symbol_t*, not symbol_number_t.
708 (reductions_t): rule_t*, not rule_number_t.
709 (FOR_EACH_SHIFT): New.
710 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
711 * src/print.c, src/print_graph.c: Adjust.
712
88bce5a2
AD
7132002-07-29 Akim Demaille <akim@epita.fr>
714
715 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
716
717 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
718 (endtoken, accept): these.
719 * src/reader.c (reader): Set endtoken's default tag to "$end".
720 Set undeftoken's tag to "$undefined" instead of "$undefined.".
721 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
722 Adjust.
723
1bfb97db
AD
7242002-07-29 Akim Demaille <akim@epita.fr>
725
726 * src/reduce.c (reduce_grammar): When the language is empty,
727 complain about the start symbol, not the axiom.
728 Use its location.
729 * tests/reduce.at (Empty Language): New.
730
fc5734fe
AD
7312002-07-26 Akim Demaille <akim@epita.fr>
732
733 * src/reader.h, src/reader.c (gram_error): ... can't get
734 yycontrol without making too strong assumptions on the parser
735 itself.
736 * src/output.c (prepare_tokens): Use the real 0th value of
737 token_translations instead of `0'.
738 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
739 visible here.
740 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
741 for the time being: %locations ought to provide it to yyerror.
742
3650b4b8
AD
7432002-07-25 Akim Demaille <akim@epita.fr>
744
745 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
746 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
747 * tests/regression.at (Web2c Actions): Adjust.
748
4b3d3a8e
AD
7492002-07-25 Akim Demaille <akim@epita.fr>
750
751 Stop storing rules from 1 to nrules + 1.
752
753 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
754 * src/nullable.c, src/output.c, src/print.c, src/reader.c
755 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
756 Iterate from 0 to nrules.
757 Use rule_number_as_item_number and item_number_as_rule_number.
758 Adjust to `derive' now containing possibly 0.
759 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
760 Handle the `- 1' part in rule numbers from/to item numbers.
761 * src/conflicts.c (log_resolution): Fix the message which reversed
762 shift and reduce.
763 * src/output.c (action_row): Initialize default_rule to -1.
764 (token_actions): Adjust.
765 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
766 expected output.
767 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
768
4a2a22f4
AD
7692002-07-25 Akim Demaille <akim@epita.fr>
770
771 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
772 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
773 (b4_c_knr_arg_decl): New.
774 * data/yacc.c: Use it to define yysymprint, yydestruct, and
775 yyreport_parse_error.
776
b8df3223
AD
7772002-07-25 Akim Demaille <akim@epita.fr>
778
779 * data/yacc.c (yyreport_parse_error): New, extracted from...
780 (yyparse): here.
781 (yydestruct, yysymprint): Move above yyparse.
782 Be K&R compliant.
783
a762e609
AD
7842002-07-25 Akim Demaille <akim@epita.fr>
785
786 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
787 replace...
788 (b4_sint_type, b4_uint_type): these.
789 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
790 * tests/regression.at (Web2c Actions): Adjust.
791
12b0043a
AD
7922002-07-25 Akim Demaille <akim@epita.fr>
793
794 * src/gram.h (TIEM_NUMBER_MAX): New.
795 (item_number_of_rule_number, rule_number_of_item_number): Rename
796 as...
797 (rule_number_as_item_number, item_number_as_rule_number): these.
798 Adjust dependencies.
799 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
800 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
801 (symbol_number_to_vector_number): New.
802 (order): Of vector_number_t* type.
803 (base_t, BASE_MAX, BASE_MIN): New.
804 (froms, tos, width, pos, check): Of base_t type.
805 (action_number_t, ACTION_MIN, ACTION_MAX): New.
806 (actrow): Of action_number_t type.
807 (conflrow): Of unsigned int type.
808 (table_ninf, base_ninf): New.
809 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
810 (muscle_insert_int_table, muscle_insert_base_table)
811 (muscle_insert_rule_number_table): New.
812 (prepare_tokens): Output `toknum' as int_table.
813 (action_row): Returns a rule_number_t.
814 Use ACTION_MIN, not SHRT_MIN.
815 (token_actions): yydefact is rule_number_t*.
816 (table_ninf_remap): New.
817 (pack_table): Use it for `base' and `table'.
818 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
819 replaced with...
820 (YYPACT_NINF, YYTABLE_NINF): these.
821 (yypact, yytable): Compute their types instead of hard-coded
822 `short'.
823 * tests/regression.at (Web2c Actions): Adjust.
824
5dde258a
AD
8252002-07-19 Akim Demaille <akim@epita.fr>
826
827 * src/scan-gram.l (id): Can start with an underscore.
828
a945ec39
AD
8292002-07-16 Akim Demaille <akim@epita.fr>
830
831 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
832 Adjust all former `associativity' dependencies.
833 * src/symtab.c (symbol_new): Default associativity is `undef', not
834 `right'.
835 (symbol_check_alias_consistence): Adjust.
836
fae437e8
AD
8372002-07-09 Akim Demaille <akim@epita.fr>
838
839 * doc/bison.texinfo: Properly set the ``header'' part.
840 Use @dircategory ``GNU programming tools'' as per Texinfo's
841 documentation.
842 Use @copying.
843
1a715ef2
AD
8442002-07-09 Akim Demaille <akim@epita.fr>
845
846 * lib/quotearg.h: Protect against multiple inclusions.
847 * src/location.h (location_t): Add a `file' member.
848 (LOCATION_RESET, LOCATION_PRINT): Adjust.
849 * src/complain.c (warn_at, complain_at, fatal_at): Drop
850 `error_one_per_line' support.
851
a5d50994
AD
8522002-07-09 Akim Demaille <akim@epita.fr>
853
854 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
855 * src/reader.c (lineno): Remove.
856 Adjust all dependencies.
857 (get_merge_function): Take a location and use complain_at.
858 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
859 * tests/regression.at (Invalid inputs, Mixing %token styles):
860 Adjust.
861
b275314e
AD
8622002-07-09 Akim Demaille <akim@epita.fr>
863
864 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
865 recovery rule, and forbid extensions when --yacc.
866 (gram_error): Use complain_at.
867 * src/reader.c (reader): Exit if there were parse errors.
868
865b9df1
AD
8692002-07-09 Akim Demaille <akim@epita.fr>
870
871 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
872 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
873 Reported by R Blake <blakers@mac.com>.
874
c76e14da
AD
8752002-07-09 Akim Demaille <akim@epita.fr>
876
877 * data/yacc.c: Output the copyright notive in the header.
878
7db2ed2d
AD
8792002-07-03 Akim Demaille <akim@epita.fr>
880
881 * src/output.c (froms, tos): Are state_number_t.
882 (save_column): sp, sp1, and sp2 are state_number_t.
883 (prepare): Rename `final' as `final_state_number', `nnts' as
884 `nterms_number', `nrules' as `rules_number', `nstates' as
885 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
886 unused.
887 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
888 * data/lalr1.cc (nsym_): Remove, unused.
889
e68e0410
AD
8902002-07-03 Akim Demaille <akim@epita.fr>
891
892 * src/lalr.h, src/lalr.c (goto_number_t): New.
893 * src/lalr.c (goto_list_t): New.
894 Propagate them.
895 * src/nullable.c (rule_list_t): New.
896 Propagate.
897 * src/types.h: Remove.
898
e1a4f3a4
AD
8992002-07-03 Akim Demaille <akim@epita.fr>
900
901 * src/closure.c (print_fderives): Use rule_rhs_print.
902 * src/derives.c (print_derives): Use rule_rhs_print.
903 (rule_list_t): New, replaces `shorts'.
904 (set_derives): Add comments.
905 * tests/sets.at (Nullable, Firsts): Adjust.
906
536545f3
AD
9072002-07-03 Akim Demaille <akim@epita.fr>
908
909 * src/output.c (prepare_actions): Free `tally' and `width'.
910 (prepare_actions): Allocate and free `order'.
911 * src/symtab.c (symbols_free): Free `symbols'.
912 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
913 * src/output.c (m4_invoke): Move to...
914 * src/scan-skel.l: here.
915 (<<EOF>>): Close yyout, and free its name.
916
8b752b00
AD
9172002-07-03 Akim Demaille <akim@epita.fr>
918
919 Fix some memory leaks, and fix a bug: state 0 was examined twice.
920
921 * src/LR0.c (new_state): Merge into...
922 (state_list_append): this.
923 (new_states): Merge into...
924 (generate_states): here.
925 (set_states): Don't ensure a proper `errs' state member here, do it...
926 * src/conflicts.c (conflicts_solve): here.
927 * src/state.h, src/state.c: Comment changes.
928 (state_t): Rename member `shifts' as `transitions'.
929 Adjust all dependencies.
930 (errs_new): For consistency, also take the values as argument.
931 (errs_dup): Remove.
932 (state_errs_set): New.
933 (state_reductions_set, state_transitions_set): Assert that no
934 previous value was assigned.
935 (state_free): New.
936 (states_free): Use it.
937 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
938 temporary storage: use `errs' and `nerrs' as elsewhere.
939 (set_conflicts): Allocate and free this `errs'.
940
613f5e1a
AD
9412002-07-02 Akim Demaille <akim@epita.fr>
942
943 * lib/libiberty.h: New.
944 * lib: Update the bitset implementation from upstream.
945 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
946 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
947 * src/main.c: Adjust bitset stats calls.
948
26e0cadc
PE
9492002-07-01 Paul Eggert <eggert@twinsun.com>
950
951 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
952 char, so that negative chars don't collide with $.
953
1154cced
AD
9542002-06-30 Akim Demaille <akim@epita.fr>
955
956 Have the GLR tests be `warning' checked, and fix the warnings.
957
958 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
959 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
960 (yyremoveDeletes): `yyi' and `yyj' are size_t.
961 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
962 (yyaddDeferredAction): static.
963 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
964 (yyreportParseError): yyprefix is const.
965 yytokenp is used only when verbose.
966 (yy__GNUC__): Replace with __GNUC__.
967 (yypdumpstack): yyi is size_t.
968 (yypreference): Un-yy local variables and arguments, to avoid
969 clashes with `yyr1'. Anyway, we are not in the user name space.
970 (yytname_size): be an int, as is compared with ints.
971 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
972 Use them.
973 * tests/cxx-gram.at: Use quotation to protect $1.
974 Use AT_COMPILE to enable warnings hunts.
975 Prototype yylex and yyerror.
976 `Use' argc.
977 Include `string.h', not `strings.h'.
978 Produce and prototype stmtMerge only when used.
979 yylex takes a location.
980
97650f4e
AD
9812002-06-30 Akim Demaille <akim@epita.fr>
982
983 We spend a lot of time in quotearg, in particular when --verbose.
984
985 * src/symtab.c (symbol_get): Store a quoted version of the key.
986 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
987 Adjust all callers.
988
d2576365
AD
9892002-06-30 Akim Demaille <akim@epita.fr>
990
991 * src/state.h (reductions_t): Rename member `nreds' as num.
992 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
993 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
994
ccaf65bc
AD
9952002-06-30 Akim Demaille <akim@epita.fr>
996
997 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
998 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
999 (shifts_to): Rename as...
1000 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1001 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1002 (TRANSITION_IS_DISABLED, transitions_to): these.
1003
87675353
AD
10042002-06-30 Akim Demaille <akim@epita.fr>
1005
1006 * src/print.c (print_shifts, print_gotos): Merge into...
1007 (print_transitions): this.
1008 (print_transitions, print_errs, print_reductions): Align the
1009 lookaheads columns.
1010 (print_core, print_transitions, print_errs, print_state,
1011 print_grammar): Output empty lines separator before, not after.
1012 (state_default_rule_compute): Rename as...
1013 (state_default_rule): this.
1014 * tests/conflicts.at (Defaulted Conflicted Reduction),
1015 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1016 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1017
ce4ccb4b
AD
10182002-06-30 Akim Demaille <akim@epita.fr>
1019
1020 Display items as we display rules.
1021
1022 * src/gram.h, src/gram.c (rule_lhs_print): New.
1023 * src/gram.c (grammar_rules_partial_print): Use it.
1024 * src/print.c (print_core): Likewise.
1025 * tests/conflicts.at (Defaulted Conflicted Reduction),
1026 (Unresolved SR Conflicts): Adjust.
1027 (Unresolved SR Conflicts): Adjust and rename as...
1028 (Resolved SR Conflicts): this, as was meant.
1029 * tests/regression.at (Web2c Report): Adjust.
1030
bc933ef1
AD
10312002-06-30 Akim Demaille <akim@epita.fr>
1032
1033 * src/print.c (state_default_rule_compute): New, extracted from...
1034 (print_reductions): here.
1035 Pessimize, but clarify the code.
1036 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1037
53d4308d
AD
10382002-06-30 Akim Demaille <akim@epita.fr>
1039
1040 * src/output.c (action_row): Let default_rule be always a rule
1041 number.
1042
574fb2d5
AD
10432002-06-30 Akim Demaille <akim@epita.fr>
1044
1045 * src/closure.c (print_firsts, print_fderives, closure):
1046 Use BITSET_EXECUTE.
1047 * src/lalr.c (lookaheads_print): Likewise.
1048 * src/state.c (state_rule_lookaheads_print): Likewise.
1049 * src/print_graph.c (print_core): Likewise.
1050 * src/print.c (print_reductions): Likewise.
1051 * src/output.c (action_row): Likewise.
1052 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1053
05811fd7
AD
10542002-06-30 Akim Demaille <akim@epita.fr>
1055
1056 * src/print_graph.c: Use report_flag.
1057
0e4d5753
AD
10582002-06-30 Akim Demaille <akim@epita.fr>
1059
1060 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1061 to...
1062 * src/relation.h, src/relation.c (traverse, relation_digraph)
1063 (relation_print, relation_transpose): New.
1064
24c7d800
AD
10652002-06-30 Akim Demaille <akim@epita.fr>
1066
1067 * src/state.h, src/state.c (shifts_to): New.
1068 * src/lalr.c (build_relations): Use it.
1069
9222837b
AD
10702002-06-30 Akim Demaille <akim@epita.fr>
1071
1072 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1073 (item_number_of_rule_number, rule_number_of_item_number): New.
1074 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1075 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1076 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1077 Propagate their use.
1078 Much remains to be done, in particular wrt `shorts' from types.h.
1079
260008e5
AD
10802002-06-30 Akim Demaille <akim@epita.fr>
1081
1082 * src/symtab.c (symbol_new): Initialize the `printer' member.
1083
8a731ca8
AD
10842002-06-30 Akim Demaille <akim@epita.fr>
1085
1086 * src/LR0.c (save_reductions): Remove, replaced by...
1087 * src/state.h, src/state.c (state_reductions_set): New.
1088 (reductions, errs): Rename as...
1089 (reductions_t, errs_t): these.
1090 Adjust all dependencies.
1091
32e1e0a4
AD
10922002-06-30 Akim Demaille <akim@epita.fr>
1093
1094 * src/LR0.c (state_list_t, state_list_append): New.
1095 (first_state, last_state): Now symbol_list_t.
1096 (this_state): Remove.
1097 (new_itemsets, append_states, save_reductions): Take a state_t as
1098 argument.
1099 (set_states, generate_states): Adjust.
1100 (save_shifts): Remove, replaced by...
1101 * src/state.h, src/state.c (state_shifts_set): New.
1102 (shifts): Rename as...
1103 (shifts_t): this.
1104 Adjust all dependencies.
1105 * src/state.h (state_t): Remove the `next' member.
1106
e5fb6710
AD
11072002-06-30 Akim Demaille <akim@epita.fr>
1108
1109 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1110 escaped in slot 0.
1111
c7ca99d4
AD
11122002-06-30 Akim Demaille <akim@epita.fr>
1113
1114 Use hash.h for the state hash table.
1115
1116 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1117 (allocate_storage): Use state_hash_new.
1118 (free_storage): Use state_hash_free.
1119 (new_state, get_state): Adjust.
1120 * src/lalr.h, src/lalr.c (states): Move to...
1121 * src/states.h (state_t): Remove the `link' member, no longer
1122 used.
1123 * src/states.h, src/states.c: here.
1124 (state_hash_new, state_hash_free, state_hash_lookup)
1125 (state_hash_insert, states_free): New.
1126 * src/states.c (state_table, state_compare, state_hash): New.
1127 * src/output.c (output_actions): Do not free states now, since we
1128 still need to know the final_state number in `prepare', called
1129 afterwards. Do it...
1130 * src/main.c (main): here: call states_free after `output'.
1131
df0e7316
AD
11322002-06-30 Akim Demaille <akim@epita.fr>
1133
1134 * src/state.h, src/state.c (state_new): New, extracted from...
1135 * src/LR0.c (new_state): here.
1136 * src/state.h (STATE_ALLOC): Move to...
1137 * src/state.c: here.
1138 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1139 * src/state.h, src/state.c: here.
1140
39f41916
AD
11412002-06-30 Akim Demaille <akim@epita.fr>
1142
1143 * src/reader.c (gensym): Rename as...
1144 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1145 (getsym): Rename as...
1146 (symbol_get): this.
1147
d57650a5
AD
11482002-06-30 Akim Demaille <akim@epita.fr>
1149
1150 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1151 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1152 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1153 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1154
5a08f1ce
AD
11552002-06-30 Akim Demaille <akim@epita.fr>
1156
1157 Make the test suite pass with warnings checked.
1158
1159 * tests/actions.at (Printers and Destructors): Improve.
1160 Avoid unsigned vs. signed issues.
1161 * tests/calc.at: Don't exercise the scanner here, do it...
1162 * tests/input.at (Torturing the Scanner): here.
1163
720623af
PH
11642002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1165
88e7e941 1166 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
1167 reorganize first lines parallel to yacc.c.
1168
fb8135fa
AD
11692002-06-28 Akim Demaille <akim@epita.fr>
1170
1171 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1172 (b4_token_enum, b4_token_defines): New, factored from...
1173 * data/lalr1.cc, data/yacc.c, glr.c: here.
1174
41442480
AD
11752002-06-28 Akim Demaille <akim@epita.fr>
1176
1177 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1178 unused variables.
1179 * src/output.c (merger_output): static.
1180
e0e5bf84
AD
11812002-06-28 Akim Demaille <akim@epita.fr>
1182
1183 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1184 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1185 pacify GCC.
1186 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 1187
676385e2
PH
11882002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1189
1190 Accumulated changelog for new GLR parsing features.
1191
6a254321 1192 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
1193 conflicts_total_count.
1194 * src/conflicts.h: Ditto.
1195 * src/output.c (token_actions): Use the new name.
1196 (output_conflicts): Change conflp => conflict_list_heads, and
1197 confl => conflict_list for better readability.
1198 * data/glr.c: Use the new names.
1199 * NEWS: Add self to GLR announcement.
e0e5bf84 1200
676385e2
PH
1201 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1202
1203 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1204 Akim Demaille.
1205
1206 * data/bison.glr: Change name to glr.c
1207 * data/glr.c: Renamed from bison.glr.
1208 * data/Makefile.am: Add glr.c
e0e5bf84
AD
1209
1210 * src/getargs.c:
1211
676385e2
PH
1212 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1213 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 1214
676385e2
PH
1215 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1216
1217 * data/bison.glr: Be sure to restore the
1218 current #line when returning to the skeleton contents after having
1219 exposed the input file's #line.
1220
1221 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1222
1223 * data/bison.glr: Bring up to date with changes to bison.simple.
1224
1225 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1226
1227 * data/bison.glr: Correct definitions that use b4_prefix.
1228 Various reformatting.
1229 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1230 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1231 yytokenp argument; now part of stack.
1232 (yychar): Define to behave as documented.
1233 (yyclearin): Ditto.
e0e5bf84 1234
676385e2
PH
1235 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1236
1237 * src/reader.h: Add declaration for free_merger_functions.
1238
1239 * src/reader.c (merge_functions): New variable.
1240 (get_merge_function): New function.
1241 (free_merger_functions): New function.
1242 (readgram): Check for %prec that is not followed by a symbol.
1243 Handle %dprec and %merge declarations.
1244 (packgram): Initialize dprec and merger fields in rules array.
1245
1246 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1247 conflict_list_cnt, conflict_list_free): New variables.
1248 (table_grow): Also grow conflict_table.
e0e5bf84 1249 (prepare_rules): Output dprec and merger tables.
676385e2 1250 (conflict_row): New function.
e0e5bf84 1251 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
1252 default reduction in conflicted states for GLR parser so that there
1253 are spaces for the conflict lists.
1254 (save_row): Also save conflict information.
1255 (token_actions): Allocate conflict list.
1256 (merger_output): New function.
1257 (pack_vector): Pack conflict table, too.
1258 (output_conflicts): New function to output yyconflp and yyconfl.
1259 (output_check): Allocate conflict_tos.
1260 (output_actions): Output conflict tables, also.
1261 (output_skeleton): Output b4_mergers definition.
1262 (prepare): Output b4_max_rhs_length definition.
1263 Use 'bison.glr' as default skeleton for GLR parsers.
1264
1265 * src/gram.c (glr_parser): New flag.
1266 (grammar_free): Call free_merger_functions.
1267
1268 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1269 all pairs of conflicting reductions, rather than just all tokens
1270 causing conflicts. Needed to size conflict tables.
e0e5bf84 1271 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
1272 interface.
1273 (conflicts_print): Ditto.
1274 (count_total_conflicts): New function.
1275
1276 * src/reader.h (merger_list): New type.
1277 (merge_functions): New variable.
1278
1279 * src/lex.h (tok_dprec, tok_merge): New token types.
1280
1281 * src/gram.h (rule_s): Add dprec and merger fields.
1282 (glr_parser): New flag.
1283
1284 * src/conflicts.h (count_total_conflicts): New function.
1285
1286 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1287
1288 * doc/bison.texinfo (Generalized LR Parsing): New section.
1289 (GLR Parsers): New section.
1290 (Language and Grammar): Mention GLR parsing.
1291 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1292 Correct typo ("tge" -> "the").
1293
1294 * data/bison.glr: New skeleton for GLR parsing.
1295
1296 * tests/cxx-gram.at: New tests for GLR parsing.
1297
1298 * tests/testsuite.at: Include cxx-gram.at.
1299
1300 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 1301
676385e2
PH
1302 * src/parse-gram.y:
1303
1304 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1305
1306 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 1307
b5480d74 13082002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
1309
1310 * src/options.h, src/options.c: Remove.
1311 * src/getargs.c (short_options, long_options): New.
1312
60491a94
AD
13132002-06-27 Akim Demaille <akim@epita.fr>
1314
1315 * data/bison.simple, data/bison.c++: Rename as...
1316 * data/yacc.c, data/lalr1.cc: these.
1317 * doc/bison.texinfo (Environment Variables): Remove.
1318
9be0c25b
AD
13192002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1320
1321 * src/getargs.c (report_argmatch): Initialize strtok().
1322
1ae72863
AD
13232002-06-20 Akim Demaille <akim@epita.fr>
1324
1325 * data/bison.simple (b4_symbol_actions): New, replaces...
1326 (b4_symbol_destructor, b4_symbol_printer): these.
1327 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1328 user token numbers.
1329
87542d29
AD
13302002-06-20 Akim Demaille <akim@epita.fr>
1331
1332 * data/bison.simple (yydestructor): Rename as...
1333 (yydestruct): this.
1334
1a31ed21
AD
13352002-06-20 Akim Demaille <akim@epita.fr>
1336
1337 * src/symtab.h, src/symtab.c (symbol_type_set)
1338 (symbol_destructor_set, symbol_precedence_set): The location is
1339 the last argument.
1340 Adjust all callers.
1341
e776192e
AD
13422002-06-20 Akim Demaille <akim@epita.fr>
1343
1344 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1345 internals.
1346 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1347 Takes a location.
1348 * src/symtab.h, src/symtab.c (symbol_class_set)
1349 (symbol_user_token_number_set): Likewise.
1350 Adjust all callers.
1351 Promote complain_at.
1352 * tests/input.at (Type Clashes): Adjust.
1353
5c1180b3
AD
13542002-06-20 Akim Demaille <akim@epita.fr>
1355
1356 * data/bison.simple (YYLEX): Fix the declaration when
1357 %pure-parser.
1358
e3170060
AD
13592002-06-20 Akim Demaille <akim@epita.fr>
1360
1361 * data/bison.simple (yysymprint): Don't print the token number,
1362 just its name.
1363 * tests/actions.at (Destructors): Rename as...
1364 (Printers and Destructors): this.
1365 Also exercise %printer.
1366
253862fd
AD
13672002-06-20 Akim Demaille <akim@epita.fr>
1368
1369 * data/bison.simple (YYDSYMPRINT): New.
1370 Use it to remove many of the #if YYDEBUG/if (yydebug).
1371
366eea36
AD
13722002-06-20 Akim Demaille <akim@epita.fr>
1373
1374 * src/symtab.h, src/symtab.c (symbol_t): printer and
1375 printer_location are new members.
1376 (symbol_printer_set): New.
1377 * src/parse-gram.y (PERCENT_PRINTER): New token.
1378 Handle its associated rule.
1379 * src/scan-gram.l: Adjust.
1380 (handle_destructor_at, handle_destructor_dollar): Rename as...
1381 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1382 * src/output.c (symbol_printers_output): New.
1383 (output_skeleton): Call it.
1384 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1385 since there are already many grammar files with a user `yyprint'.
1386 Replace the calls to YYPRINT to calls to yysymprint.
1387 * tests/calc.at: Adjust.
1388 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1389 taking advantage of parser very internal details (stack size!).
1390
4f25ebb0
AD
13912002-06-20 Akim Demaille <akim@epita.fr>
1392
1393 * src/scan-gram.l: Complete the scanner with the missing patterns
1394 to pacify Flex.
1395 Use `quote' and `symbol_tag_get' where appropriate.
1396
93b68a0e
AD
13972002-06-19 Akim Demaille <akim@epita.fr>
1398
1399 * tests/actions.at (Destructors): Augment to test locations.
1400 * data/bison.simple (yydestructor): Pass it the current location
1401 if locations are enabled.
1402 Prototype only when __STDC__ or C++.
1403 Change the argument names to move into the yy name space: there is
1404 user code here.
1405
58612f1d
AD
14062002-06-19 Akim Demaille <akim@epita.fr>
1407
74310291
AD
1408 * data/bison.simple (b4_pure_if): New.
1409 Use it instead of #ifdef YYPURE.
1410
14112002-06-19 Akim Demaille <akim@epita.fr>
1412
1413 * data/bison.simple (b4_location_if): New.
58612f1d
AD
1414 Use it instead of #ifdef YYLSP_NEEDED.
1415
f25bfb75
AD
14162002-06-19 Akim Demaille <akim@epita.fr>
1417
1418 Prepare @$ in %destructor, but currently don't bind it in the
1419 skeleton, as %location use is not cleaned up yet.
1420
1421 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1422 (handle_action_at): New.
1423 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1424 a braced_code_t and a location as additional arguments.
1425 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1426 unquote one when outputting `b4_dollar_dollar'.
1427 Adjust callers.
1428 * data/bison.simple (b4_eval): Remove.
1429 (b4_symbol_destructor): Adjust.
1430 * tests/input.at (Invalid @n): Adjust.
1431
c732d2c6
AD
14322002-06-19 Zack Weinberg <zack@codesourcery.com>
1433
1434 * doc/bison.texinfo: Document ability to have multiple
1435 prologue sections.
1436
8c165d89
AD
14372002-06-18 Akim Demaille <akim@epita.fr>
1438
1439 * src/files.c (compute_base_names): When computing the output file
1440 names from the input file name, strip the directory part.
1441
ca98bf57
AD
14422002-06-18 Akim Demaille <akim@epita.fr>
1443
1444 * data/bison.simple.new: Comment changes.
1445 Reported by Andreas Schwab.
1446
0bfb02ff
AD
14472002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1448
1449 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1450 there are no `label `yyoverflowlab' defined but not used' warnings
1451 when yyoverflow is defined.
1452
24c0aad7
AD
14532002-06-18 Akim Demaille <akim@epita.fr>
1454
1455 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1456 new member.
1457 (symbol_destructor_set): Adjust.
1458 * src/output.c (symbol_destructors_output): Output the destructor
1459 locations.
1460 Output the symbol name.
1461 * data/bison.simple (b4_symbol_destructor): Adjust.
1462
5719c109
AD
14632002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1464 and Akim Demaille <akim@epita.fr>
1465
1466 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1467 what's left on the stack when the error recovery hits EOF.
1468 * tests/actions.at (Destructors): Complete to exercise this case.
1469
9280d3ef
AD
14702002-06-17 Akim Demaille <akim@epita.fr>
1471
1472 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1473 arguments is really empty, not only equal to `[]'.
1474 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1475 member.
1476 (symbol_destructor_set): New.
1477 * src/output.c (symbol_destructors_output): New.
1478 * src/reader.h (brace_code_t, current_braced_code): New.
1479 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1480 (handle_dollar): Rename as...
1481 (handle_action_dollar): this.
1482 (handle_destructor_dollar): New.
1483 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1484 (grammar_declaration): Use it.
1485 * data/bison.simple (yystos): Is always defined.
1486 (yydestructor): New.
1487 * tests/actions.at (Destructors): New.
1488 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1489
dafdc66f
AD
14902002-06-17 Akim Demaille <akim@epita.fr>
1491
1492 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1493 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1494 rule_length only when needed.
1495 * src/output.c (actions_output, token_definitions_output): Output
1496 the full M4 block.
1497 * src/symtab.c: Don't access directly to the symbol tag, use
1498 symbol_tag_get.
1499 * src/parse-gram.y: Use symbol_list_free.
1500
56c47203
AD
15012002-06-17 Akim Demaille <akim@epita.fr>
1502
1503 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1504 (symbol_list_prepend, get_type_name): Move to...
1505 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1506 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1507 Adjust all callers.
1508 (symbol_list_free): New.
1509 * src/scan-gram.l (handle_dollar): Takes a location.
1510 * tests/input.at (Invalid $n): Adjust.
1511
1e0bab92
AD
15122002-06-17 Akim Demaille <akim@epita.fr>
1513
1514 * src/reader.h, src/reader.c (symbol_list_new): Export it.
1515 (symbol_list_prepend): New.
1516 * src/parse-gram.y (%union): `list' is a new member.
1517 (symbols.1): New, replaces...
1518 (terms_to_prec.1, nterms_to_type.1): these.
1519 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
1520 Take a location as additional argument.
1521 Adjust all callers.
1522
04e60654
AD
15232002-06-15 Akim Demaille <akim@epita.fr>
1524
1525 * src/parse-gram.y: Move %token in the declaration section so that
1526 we don't depend upon CVS Bison.
1527
10e5b8bd
AD
15282002-06-15 Akim Demaille <akim@epita.fr>
1529
1530 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
1531 * src/print.c (print_core): Use it.
1532
9801d40c
AD
15332002-06-15 Akim Demaille <akim@epita.fr>
1534
1535 * src/conflicts.c (log_resolution): Accept the rule involved in
1536 the sr conflicts instead of the lookahead number that points to
1537 that rule.
1538 (flush_reduce): Accept the current lookahead vector as argument,
1539 instead of the index in LA.
1540 (resolve_sr_conflict): Accept the current number of lookahead
1541 bitset to consider for the STATE, instead of the index in LA.
1542 (set_conflicts): Adjust.
1543 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
1544
c0263492
AD
15452002-06-15 Akim Demaille <akim@epita.fr>
1546
1547 * src/state.h (state_t): Replace the `lookaheadsp' member, a
1548 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
1549 Adjust all dependencies.
1550 * src/lalr.c (initialize_lookaheads): Split into...
1551 (states_lookaheads_count, states_lookaheads_initialize): these.
1552 (lalr): Adjust.
1553
9757c359
AD
15542002-06-15 Akim Demaille <akim@epita.fr>
1555
1556 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
1557 out of...
1558 (grammar_rules_print): here.
1559 * src/reduce.c (reduce_output): Use it.
1560 * tests/reduce.at (Useless Rules, Reduced Automaton)
1561 (Underivable Rules): Adjust.
1562
6b98e4b5
AD
15632002-06-15 Akim Demaille <akim@epita.fr>
1564
1565 Copy BYacc's nice way to report the grammar.
1566
1567 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
1568 New.
1569 Don't print the rules' location, it is confusing and useless.
1570 (rule_print): Use grammar_rhs_print.
1571 * src/print.c (print_grammar): Use grammar_rules_print.
1572
6b98e4b5
AD
15732002-06-15 Akim Demaille <akim@epita.fr>
1574
1575 Complete and rationalize `useless thing' warnings.
1576
1577 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
1578 (symbol_tag_print): New.
1579 Use them everywhere in place of accessing directly the tag member.
1580 * src/gram.h, src/gram.c (rule_print): New.
1581 Use it where a rule used to be printed `by hand'.
1582 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
1583 (reduce_grammar_tables): Report the useless rules.
1584 (reduce_print): Useless things are a warning, not an error.
1585 Report it as such.
1586 * tests/reduce.at (Useless Nonterminals, Useless Rules):
1587 (Reduced Automaton, Underivable Rules): Adjust.
1588 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
1589 * tests/conflicts.at (Unresolved SR Conflicts)
1590 (Solved SR Conflicts): Adjust.
1591
ee000ba4
AD
15922002-06-15 Akim Demaille <akim@epita.fr>
1593
1594 Let symbols have a location.
1595
1596 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
1597 (getsym): Adjust.
1598 Adjust all callers.
1599 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
1600 Use location_t, not int.
1601 * src/symtab.c (symbol_check_defined): Take advantage of the
1602 location.
1603 * tests/regression.at (Invalid inputs): Adjust.
1604
8efe435c
AD
16052002-06-15 Akim Demaille <akim@epita.fr>
1606
1607 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
1608 (input): Don't try to initialize yylloc here, do it in the
1609 scanner.
1610 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
1611 * src/gram.h (rule_t): Change line and action_line into location
1612 and action_location, of location_t type.
1613 Adjust all dependencies.
1614 * src/location.h, src/location.c (empty_location): New.
1615 * src/reader.h, src/reader.c (grammar_start_symbol_set)
1616 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
1617 (grammar_current_rule_symbol_append)
1618 (grammar_current_rule_action_append): Expect a location as argument.
1619 * src/reader.c (grammar_midrule_action): Adjust to attach an
1620 action's location as dummy symbol location.
1621 * src/symtab.h, src/symtab.c (startsymbol_location): New.
1622 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
1623 the line numbers.
1624
1921f1d7
AD
16252002-06-14 Akim Demaille <akim@epita.fr>
1626
1627 Grammar declarations may be found in the grammar section.
1628
1629 * src/parse-gram.y (rules_or_grammar_declaration): New.
1630 (declarations): Each declaration may end with a semicolon, not
1631 just...
1632 (grammar_declaration): `"%union"'.
1633 (grammar): Branch to rules_or_grammar_declaration.
1634
4515534c
AD
16352002-06-14 Akim Demaille <akim@epita.fr>
1636
1637 * src/main.c (main): Invoke scanner_free.
1638
f958596b
AD
16392002-06-14 Akim Demaille <akim@epita.fr>
1640
1641 * src/output.c (m4_invoke): Extracted from...
1642 (output_skeleton): here.
1643 Free tempfile.
1644
2c569025
AD
16452002-06-14 Akim Demaille <akim@epita.fr>
1646
1647 * src/parse-gram.y (directives, directive, gram)
1648 (grammar_directives, precedence_directives, precedence_directive):
1649 Rename as...
1650 (declarations, declaration, grammar, grammar_declaration)
1651 (precedence_declaration, precedence_declarator): these.
1652 (symbol_declaration): New.
1653
592e8d4d
AD
16542002-06-14 Akim Demaille <akim@epita.fr>
1655
1656 * src/files.c (action_obstack): Remove, unused.
1657 (output_obstack): Remove it, and all its dependencies, as it is no
1658 longer needed.
1659 * src/reader.c (epilogue_set): Build the epilogue in the
1660 muscle_obstack.
1661 * src/output.h, src/output.c (muscle_obstack): Move to...
1662 * src/muscle_tab.h, src/muscle_tab.h: here.
1663 (muscle_init): Initialize muscle_obstack.
1664 (muscle_free): New.
1665 * src/main.c (main): Call it.
1666
0c15323d
AD
16672002-06-14 Akim Demaille <akim@epita.fr>
1668
1669 * src/location.h: New, extracted from...
1670 * src/reader.h: here.
1671 * src/Makefile.am (noinst_HEADERS): Merge into
1672 (bison_SOURCES): this.
1673 Add location.h.
1674 * src/parse-gram.y: Use location_t instead of Bison's.
1675 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
1676 Use location_t instead of ints.
1677
e96c9728
AD
16782002-06-14 Akim Demaille <akim@epita.fr>
1679
1680 * data/bison.simple, data/bison.c++: Be sure to restore the
1681 current #line when returning to the skeleton contents after having
1682 exposed the input file's #line.
1683
75d1fe16
AD
16842002-06-12 Akim Demaille <akim@epita.fr>
1685
1686 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
1687 eager.
1688 * tests/actions.at (Exotic Dollars): New.
1689
6c35d22c
AD
16902002-06-12 Akim Demaille <akim@epita.fr>
1691
1692 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
1693 ['"/] too eagerly.
1694 * tests/input.at (Torturing the Scanner): New.
1695
1d6412ad
AD
16962002-06-11 Akim Demaille <akim@epita.fr>
1697
1698 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
1699 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
1700 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
1701 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
1702 * src/reader.c (reader): Use it.
1703
4cdb01db
AD
17042002-06-11 Akim Demaille <akim@epita.fr>
1705
1706 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
1707 Adjust all callers.
1708 (scanner_last_string_free): New.
1709
44995b2e
AD
17102002-06-11 Akim Demaille <akim@epita.fr>
1711
1712 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
1713 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
1714 (last_string, YY_OBS_FREE): New.
1715 Use them when returning an ID.
1716
e9955c83
AD
17172002-06-11 Akim Demaille <akim@epita.fr>
1718
1719 Have Bison grammars parsed by a Bison grammar.
1720
1721 * src/reader.c, src/reader.h (prologue_augment): New.
1722 * src/reader.c (copy_definition): Remove.
1723
1724 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
1725 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
1726 (grammar_current_rule_prec_set, grammar_current_rule_check)
1727 (grammar_current_rule_symbol_append)
1728 (grammar_current_rule_action_append): Export.
1729 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
1730 (symbol_list_action_append): Remove.
1731 Hook the routines from reader.
1732 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
1733 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
1734
1735 * src/reader.c (read_declarations): Remove, unused.
1736
1737 * src/parse-gram.y: Handle the epilogue.
1738 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
1739 (grammar_start_symbol_set): this.
1740 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
1741 * src/reader.c (readgram): Remove, unused.
1742 (reader): Adjust to insert eoftoken and axiom where appropriate.
1743
1744 * src/reader.c (copy_dollar): Replace with...
1745 * src/scan-gram.h (handle_dollar): this.
1746 * src/parse-gram.y: Remove `%thong'.
1747
1748 * src/reader.c (copy_at): Replace with...
1749 * src/scan-gram.h (handle_at): this.
1750
1751 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
1752 New.
1753
1754 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
1755 time being.
1756
1757 * src/reader.h, src/reader.c (grammar_rule_end): New.
1758
1759 * src/parse.y (current_type, current_class): New.
1760 Implement `%nterm', `%token' support.
1761 Merge `%term' into `%token'.
1762 (string_as_id): New.
1763 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
1764 type name.
1765
1766 * src/parse-gram.y: Be sure to handle properly the beginning of
1767 rules.
1768
1769 * src/parse-gram.y: Handle %type.
1770 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
1771
1772 * src/parse-gram.y: More directives support.
1773 * src/options.c: No longer handle source directives.
1774
1775 * src/parse-gram.y: Fix %output.
1776
1777 * src/parse-gram.y: Handle %union.
1778 Use the prologue locations.
1779 * src/reader.c (parse_union_decl): Remove.
1780
1781 * src/reader.h, src/reader.c (epilogue_set): New.
1782 * src/parse-gram.y: Use it.
1783
1784 * data/bison.simple, data/bison.c++: b4_stype is now either not
1785 defined, then default to int, or to the contents of %union,
1786 without `union' itself.
1787 Adjust.
1788 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
1789
1790 * src/output.c (actions_output): Don't output braces, as they are
1791 already handled by the scanner.
1792
1793 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
1794 characters to themselves.
1795
1796 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
1797 that the epilogue has a proper #line.
1798
1799 * src/parse-gram.y: Handle precedence/associativity.
1800
1801 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
1802 a terminal.
1803 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
1804 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
1805 at all to define terminals that cannot be emitted.
1806
1807 * src/scan-gram.l: Escape M4 characters.
1808
1809 * src/scan-gram.l: Working properly with escapes in user
1810 strings/characters.
1811
1812 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
1813 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
1814 grammar.
1815 Use more modest sizes, as for the time being the parser does not
1816 release memory, and therefore the process swallows a huge amount
1817 of memory.
1818
1819 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
1820 stricter %token grammar.
1821
1822 * src/symtab.h (associativity): Add `undef_assoc'.
1823 (symbol_precedence_set): Do nothing when passed an undef_assoc.
1824 * src/symtab.c (symbol_check_alias_consistence): Adjust.
1825
1826 * tests/regression.at (Invalid %directive): Remove, as it is now
1827 meaningless.
1828 (Invalid inputs): Adjust to the new error messages.
1829 (Token definitions): The new grammar doesn't allow too many
1830 eccentricities.
1831
1832 * src/lex.h, src/lex.c: Remove.
1833 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1834 (copy_character, copy_string2, copy_string, copy_identifier)
1835 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1836 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1837 (parse_action): Remove.
1838 * po/POTFILES.in: Adjust.
1839
2e047461
AD
18402002-06-11 Akim Demaille <akim@epita.fr>
1841
1842 * src/reader.c (parse_action): Don't store directly into the
1843 rule's action member: return the action as a string.
1844 Don't require `rule_length' as an argument: compute it.
1845 (grammar_current_rule_symbol_append)
1846 (grammar_current_rule_action_append): New, eved out from
1847 (readgram): here.
1848 Remove `action_flag', `rulelength', unused now.
1849
9af3fbce
AD
18502002-06-11 Akim Demaille <akim@epita.fr>
1851
1852 * src/reader.c (grammar_current_rule_prec_set).
1853 (grammar_current_rule_check): New, eved out from...
1854 (readgram): here.
1855 Remove `xaction', `first_rhs': useless.
1856 * tests/input.at (Type clashes): New.
1857 * tests/existing.at (GNU Cim Grammar): Adjust.
1858
1485e106
AD
18592002-06-11 Akim Demaille <akim@epita.fr>
1860
1861 * src/reader.c (grammar_midrule_action): New, Eved out from
1862 (readgram): here.
1863
da4160c3
AD
18642002-06-11 Akim Demaille <akim@epita.fr>
1865
1866 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1867 New.
1868 (readgram): Use them as replacement of inlined code, crule and
1869 crule1.
1870
f6d0f937
AD
18712002-06-11 Akim Demaille <akim@epita.fr>
1872
1873 * src/reader.c (grammar_end, grammar_symbol_append): New.
1874 (readgram): Use them.
1875 Make the use of `p' as local as possible.
1876
69078d4b
AD
18772002-06-10 Akim Demaille <akim@epita.fr>
1878
1879 GCJ's parser requires the tokens to be defined before the prologue.
1880
1881 * data/bison.simple: Output the token definition before the user's
1882 prologue.
1883 * tests/regression.at (Braces parsing, Duplicate string)
1884 (Mixing %token styles): Check the output from bison.
1885 (Early token definitions): New.
1886
5e424082
AD
18872002-06-10 Akim Demaille <akim@epita.fr>
1888
1889 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1890 assigning twice the same user number to a token, so that we can
1891 use it in...
1892 * src/lex.c (lex): here.
1893 Also use `symbol_class_set' instead of hand written code.
1894 * src/reader.c (parse_assoc_decl): Likewise.
1895
44536b35
AD
18962002-06-10 Akim Demaille <akim@epita.fr>
1897
1898 * src/symtab.c, src/symtab.c (symbol_class_set)
1899 (symbol_user_token_number_set): New.
1900 * src/reader.c (parse_token_decl): Use them.
1901 Use a switch instead of ifs.
1902 Use a single argument.
1903
8b9f2372
AD
19042002-06-10 Akim Demaille <akim@epita.fr>
1905
1906 Remove `%thong' support as it is undocumented, unused, duplicates
1907 `%token's job, and creates useless e-mail traffic with people who
1908 want to know what it is, why it is undocumented, unused, and
1909 duplicates `%token's job.
1910
1911 * src/reader.c (parse_thong_decl): Remove.
1912 * src/options.c (option_table): Remove "thong".
1913 * src/lex.h (tok_thong): Remove.
1914
3ae2b51f
AD
19152002-06-10 Akim Demaille <akim@epita.fr>
1916
1917 * src/symtab.c, src/symtab.c (symbol_type_set)
1918 (symbol_precedence_set): New.
1919 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1920 (value_components_used): Remove, unused.
1921
2f1afb73
AD
19222002-06-09 Akim Demaille <akim@epita.fr>
1923
1924 Move symbols handling code out of the reader.
1925
1926 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1927 (axiom): Move to...
1928 * src/symtab.h, src/symtab.c: here.
1929
1930 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1931 * src/reader.c (startval): Rename as...
1932 * src/symtab.h, src/symtab.c (startsymbol): this.
1933 * src/reader.c: Adjust.
1934
1935 * src/reader.c (symbol_check_defined, symbol_make_alias)
1936 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1937 (token_translations_init)
1938 Move to...
1939 * src/symtab.c: here.
1940 * src/reader.c (packsymbols): Move to...
1941 * src/symtab.h, src/symtab.c (symbols_pack): here.
1942 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1943 argument.
1944
e9bca3ad
AD
19452002-06-03 Akim Demaille <akim@epita.fr>
1946
1947 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1948 then statements.
1949
86eff183
AD
19502002-06-03 Akim Demaille <akim@epita.fr>
1951
1952 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1953 structs with non literals.
1954 * src/scan-skel.l: never-interactive.
1955 * src/conflicts.c (enum conflict_resolution_e): No trailing
1956 comma.
1957 * src/getargs.c (usage): Split long literal strings.
1958 Reported by Hans Aberg.
1959
717be197
AD
19602002-05-28 Akim Demaille <akim@epita.fr>
1961
1962 * data/bison.c++: Use C++ ostreams.
1963 (cdebug_): New member.
1964
670ddffd
AD
19652002-05-28 Akim Demaille <akim@epita.fr>
1966
1967 * src/output.c (output_skeleton): Be sure to allocate enough room
1968 for `/' _and_ for `\0' in full_skeleton.
1969
769b430f
AD
19702002-05-28 Akim Demaille <akim@epita.fr>
1971
1972 * data/bison.c++: Catch up with bison.simple:
1973 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1974 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1975 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1976 and popping traces.
1977
7067cb36
PH
19782002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1979
1980 * src/output.c (output_skeleton): Put an explicit path in front of
1981 the skeleton file name, rather than relying on the -I directory,
1982 to partially alleviate effects of having a skeleton file lying around
1983 in the current directory.
769b430f 1984
4a713ec2
PH
19852002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1986
769b430f 1987 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
1988 obstack_printf should be obstack_fgrow1.
1989
b408954b
AD
19902002-05-26 Akim Demaille <akim@epita.fr>
1991
1992 * src/state.h (state_t): `solved_conflicts' is a new member.
1993 * src/LR0.c (new_state): Set it to 0.
1994 * src/conflicts.h, src/conflicts.c (print_conflicts)
1995 (free_conflicts, solve_conflicts): Rename as...
1996 (conflicts_print, conflicts_free, conflicts_solve): these.
1997 Adjust callers.
1998 * src/conflicts.c (enum conflict_resolution_e)
1999 (solved_conflicts_obstack): New, used by...
2000 (log_resolution): this.
2001 Adjust to attach the conflict resolution to each state.
2002 Complete the description with the precedence/associativity
2003 information.
2004 (resolve_sr_conflict): Adjust.
2005 * src/print.c (print_state): Output its solved_conflicts.
2006 * tests/conflicts.at (Unresolved SR Conflicts)
2007 (Solved SR Conflicts): Exercise --report=all.
2008
a49aecd5
AD
20092002-05-26 Akim Demaille <akim@epita.fr>
2010
2011 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2012 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2013 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2014 (token_number_t, item_number_as_token_number)
2015 (token_number_as_item_number, muscle_insert_token_number_table):
2016 Rename as...
2017 (symbol_number_t, item_number_as_symbol_number)
2018 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2019 these, since it is more appropriate.
2020
5504898e
AD
20212002-05-26 Akim Demaille <akim@epita.fr>
2022
2023 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2024 `Error:' lines.
2025 * data/bison.simple (yystos) [YYDEBUG]: New.
2026 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2027 error recovery.
2028 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2029
ec3bc396
AD
20302002-05-25 Akim Demaille <akim@epita.fr>
2031
2032 * doc/bison.texinfo (Debugging): Split into...
2033 (Tracing): this new section, its former contents, and...
2034 (Understanding): this new section.
2035 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2036 by...
2037 (report_flag): this.
2038 Adjust all dependencies.
2039 (report_args, report_types, report_argmatch): New.
2040 (usage, getargs): Report/support -r, --report.
2041 * src/options.h
2042 (struct option_table_struct): Rename as..,
2043 (struct option_table_s): this.
2044 Rename the `set_flag' member to `flag' to match with getopt_long's
2045 struct.
2046 * src/options.c (option_table): Split verbose into an entry for
2047 %verbose, and another for --verbose.
2048 Support --report/-r, so remove -r from the obsolete --raw.
2049 * src/print.c: Attach full item sets and lookaheads reports to
2050 report_flag instead of trace_flag.
2051 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2052
78df8250
PE
20532002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2054 and Paul Eggert <eggert@twinsun.com>
769b430f 2055
78df8250
PE
2056 * data/bison.simple (yyparse): Correct error handling to conform to
2057 POSIX and yacc. Specifically, after syntax error is discovered,
2058 do not reduce further before shifting the error token.
2059 Clean up the code a bit by removing the labels yyerrdefault,
2060 yyerrhandle, yyerrpop.
2061 * NEWS: Document the above.
2062
c0c9ea05
PH
20632002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2064
2065 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2066 type; it isn't always big enough, since it doesn't necessarily
2067 include non-terminals.
769b430f 2068 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
2069 the latter can be removed.
2070 (yy_token_number_type): Remove, only one use.
2071 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2072 don't use TokenNumberType as element type.
769b430f 2073
c0c9ea05
PH
2074 * tests/regression.at: Modify expected output to agree with change
2075 to yyr1 and yytranslate.
769b430f 2076
6390a83f
FK
20772002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2078
2079 * src/reader.c (parse_action): Use copy_character instead of
2080 obstack_1grow.
2081
db7c8e9a
AD
20822002-05-13 Akim Demaille <akim@epita.fr>
2083
2084 * tests/regression.at (Token definitions): Prototype yylex and
2085 yyerror.
2086
fcc61800
PH
20872002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2088
158c687b 2089 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
2090 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2091 32-bit arithmetic.
2092 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2093
5683e9b2
AD
20942002-05-07 Akim Demaille <akim@epita.fr>
2095
2096 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2097 avoid GCC warnings.
2098
0c2d3f4c
AD
20992002-05-07 Akim Demaille <akim@epita.fr>
2100
2101 Kill GCC warnings.
2102
2103 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2104 over the RHS of each rule.
2105 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2106 * src/state.h (state_t): Member `nitems' is unsigned short.
2107 * src/LR0.c (get_state): Adjust.
2108 * src/reader.c (packgram): Likewise.
2109 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2110 `Type'.
2111 (muscle_insert_int_table): Remove, unused.
2112 (prepare_rules): Remove `max'.
2113
1565b720
AD
21142002-05-06 Akim Demaille <akim@epita.fr>
2115
2116 * src/closure.c (print_firsts): Display of the symbol tags.
2117 (bitmatrix_print): Move to...
2118 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2119 here.
2120 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2121
cfaee611
AD
21222002-05-06 Akim Demaille <akim@epita.fr>
2123
2124 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2125 hash_do_for_each.
2126
458be8e0
AD
21272002-05-06 Akim Demaille <akim@epita.fr>
2128
2129 * src/LR0.c (new_state, get_state): Instead of using the global
2130 `kernel_size' and `kernel_base', have two new arguments:
2131 `core_size' and `core'.
2132 Adjust callers.
2133
a900a624
AD
21342002-05-06 Akim Demaille <akim@epita.fr>
2135
2136 * src/reader.c (packgram): No longer end `ritem' with a 0
2137 sentinel: it is not used.
2138
d4e7d3a1
AD
21392002-05-05 Akim Demaille <akim@epita.fr>
2140
2141 New experimental feature: display the lookaheads in the report and
2142 graph.
2143
2144 * src/print (print_core): When --trace-flag, display the rules
2145 lookaheads.
2146 * src/print_graph.c (print_core): Likewise.
2147 Swap the arguments.
2148 Adjust caller.
2149
39ceb25b
AD
21502002-05-05 Akim Demaille <akim@epita.fr>
2151
2152 * tests/torture.at (Many lookaheads): New test.
2153
5372019f
AD
21542002-05-05 Akim Demaille <akim@epita.fr>
2155
2156 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2157 (GENERATE_MUSCLE_INSERT_TABLE): this.
2158 (output_int_table, output_unsigned_int_table, output_short_table)
2159 (output_token_number_table, output_item_number_table): Replace with...
2160 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2161 (muscle_insert_short_table, muscle_insert_token_number_table)
2162 (muscle_insert_item_number_table): these.
2163 Adjust all callers.
2164 (prepare_tokens): Don't free `translations', since...
2165 * src/reader.h, src/reader.c (grammar_free): do it.
2166 Move to...
2167 * src/gram.h, src/gram.c (grammar_free): here.
2168 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2169 b4_translate_max.
2170
5df5f6d5
AD
21712002-05-05 Akim Demaille <akim@epita.fr>
2172
2173 * src/output.c (output_unsigned_int_table): New.
2174 (prepare_rules): `i' is unsigned.
2175 `prhs', `rline', `r2' are unsigned int.
2176 Rename muscle `rhs_number_max' as `rhs_max'.
2177 Output muscles `prhs_max', `rline_max', and `r2_max'.
2178 Free rline and r1.
2179 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2180 to compute types instead of constant types.
2181 * tests/regression.at (Web2c Actions): Adjust.
2182
b87f8b21
AD
21832002-05-04 Akim Demaille <akim@epita.fr>
2184
2185 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2186 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2187 Adjust dependencies.
2188 * src/output.c (token_definitions_output): Be sure not to output a
2189 `#define 'a'' when fed with `%token 'a' "a"'.
2190 * tests/regression.at (Token definitions): New.
2191
8bb936e4
PE
21922002-05-03 Paul Eggert <eggert@twinsun.com>
2193
2194 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2195 for K&R C.
2196
21972002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2198
2199 * Makefile.am (SUBDIRS): Remove intl.
2200 (EXTRA_DIST): Add config/config.rpath.
2201
53c71a12
AD
22022002-05-03 Akim Demaille <akim@epita.fr>
2203
2204 * data/bison.simple (m4_if): Don't output empty enums.
2205 And actually, output valid enum definitions :(.
2206
289dd0cf
AD
22072002-05-03 Akim Demaille <akim@epita.fr>
2208
2209 * configure.bat: Remove, completely obsolete.
2210 * Makefile.am (EXTRA_DIST): Adjust.
2211 Don't distribute config.rpath...
2212 * config/Makefile.am (EXTRA_DIST): Do it.
2213
db85e524
AD
22142002-05-03 Akim Demaille <akim@epita.fr>
2215
2216 * configure.in (GETTEXT_VERSION): New.
2217 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2218
83ccf991
AD
22192002-05-03 Akim Demaille <akim@epita.fr>
2220
2221 * data/bison.simple (b4_token_enum): New.
2222 (b4_token_defines): Use it to output tokens both as #define and
2223 enums.
2224 Suggested by Paul Eggert.
2225 * src/output.c (token_definitions_output): Don't output spurious
2226 white spaces.
2227
1f418995
AD
22282002-05-03 Akim Demaille <akim@epita.fr>
2229
2230 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2231
45119f04
RA
22322002-05-02 Robert Anisko <robert@lrde.epita.fr>
2233
2234 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2235 Update the stack class, give a try to deque as the default container.
2236
b2d52318
AD
22372002-05-02 Akim Demaille <akim@epita.fr>
2238
2239 * data/bison.simple (yyparse): Do not implement @$ = @1.
2240 (YYLLOC_DEFAULT): Adjust to do it.
2241 * doc/bison.texinfo (Location Default Action): Fix.
2242
3a8b4109
AD
22432002-05-02 Akim Demaille <akim@epita.fr>
2244
2245 * src/reader.c (parse_braces): Merge into...
2246 (parse_action): this.
2247
84614e13
AD
22482002-05-02 Akim Demaille <akim@epita.fr>
2249
2250 * configure.in (ALL_LINGUAS): Remove.
2251 * po/LINGUAS, hr.po: New.
2252
fdbcd8e2
AD
22532002-05-02 Akim Demaille <akim@epita.fr>
2254
2255 Remove the so called hairy (semantic) parsers.
2256
2257 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2258 * src/gram.h, src/gram.c (semantic_parser): Remove.
2259 (rule_t): Remove the guard and guard_line members.
2260 * src/lex.h (token_t): remove tok_guard.
2261 * src/options.c (option_table): Remove %guard and %semantic_parser
2262 support.
2263 * src/output.c, src/output.h (guards_output): Remove.
2264 (prepare): Adjust.
2265 (token_definitions_output): Don't output the `T'
2266 tokens (???).
2267 (output_skeleton): Don't output the guards.
2268 * src/files.c, src/files.c (attrsfile): Remove.
2269 * src/reader.c (symbol_list): Remove the guard and guard_line
2270 members.
2271 Adjust dependencies.
2272 (parse_guard): Remove.
2273 * data/bison.hairy: Remove.
2274 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2275 BISON_HAIRY.
2276
82b6cb3f
AD
22772002-05-02 Akim Demaille <akim@epita.fr>
2278
2279 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2280 (parse_guard): Rename the formal argument `stack_offset' as
2281 `rule_length', which is more readable.
2282 Adjust callers.
2283 (copy_at, copy_dollar): Instead of outputting the hard coded
2284 values of $$, $n and so forth, output invocation to b4_lhs_value,
2285 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
2286 Note: this patch partially drops `semantic-parser' support: it
2287 always does `rule_length - n', where semantic parsers ought to
2288 always use `-n'.
82b6cb3f
AD
2289 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2290 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2291
6cbfbcc5
AD
22922002-05-02 Akim Demaille <akim@epita.fr>
2293
2294 * configure.in (AC_INIT): Bump to 1.49b.
2295 (AM_INIT_AUTOMAKE): Short invocation.
2296
b8548114
AD
22972002-05-02 Akim Demaille <akim@epita.fr>
2298
2299 Version 1.49a.
2300
c20cd1fa
AD
23012002-05-01 Akim Demaille <akim@epita.fr>
2302
2303 * src/skeleton.h: Remove.
2304
8a9566d4
AD
23052002-05-01 Akim Demaille <akim@epita.fr>
2306
2307 * src/skeleton.h: Fix the #endif.
2308 Reported by Magnus Fromreide.
2309
8c6d399a
PE
23102002-04-26 Paul Eggert <eggert@twinsun.com>
2311
2312 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2313 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 2314 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 2315
2b7ed18a
RA
23162002-04-25 Robert Anisko <robert@lrde.epita.fr>
2317
2318 * src/scan-skel.l: Postprocess quadrigraphs.
2319
2320 * src/reader.c (copy_character): New function, used to output
2321 single characters while replacing `[' and `]' with quadrigraphs, to
2322 avoid troubles with M4 quotes.
2323 (copy_comment): Output characters with copy_character.
2324 (read_additionnal_code): Likewise.
2325 (copy_string2): Likewise.
2326 (copy_definition): Likewise.
2327
2328 * tests/calc.at: Exercise M4 quoting.
2329
34a89c50
AD
23302002-04-25 Akim Demaille <akim@epita.fr>
2331
2332 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2333 between `!' and the command.
2334 Reported by Paul Eggert.
2335
0dd1580a
RA
23362002-04-24 Robert Anisko <robert@lrde.epita.fr>
2337
2338 * tests/calc.at: Exercise prologue splitting.
2339
2340 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2341 `b4_post_prologue' instead of `b4_prologue'.
2342
2343 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2344 muscles.
2345 (output): Free pre_prologue_obstack and post_prologue_obstack.
2346 * src/files.h, src/files.c (attrs_obstack): Remove.
2347 (pre_prologue_obstack, post_prologue_obstack): New.
2348 * src/reader.c (copy_definition): Add a parameter to specify the
2349 obstack to fill, instead of using attrs_obstack unconditionally.
2350 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2351 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2352
83c1796f
PE
23532002-04-23 Paul Eggert <eggert@twinsun.com>
2354
2355 * data/bison.simple: Remove unnecessary commentary and white
2356 space differences from 1_29-branch.
2357 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2358
2359 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2360 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2361 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2362 constructors or destructors.
2363
2364 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2365
1207eeac
AD
23662002-04-23 Akim Demaille <akim@epita.fr>
2367
2368 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2369 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2370 location with columns.
2371 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2372 All reported by Paul Eggert.
2373
78ab8f67
AD
23742002-04-22 Akim Demaille <akim@epita.fr>
2375
2376 * src/reduce.c (dump_grammar): Move to...
2377 * src/gram.h, src/gram.c (grammar_dump): here.
2378 Be sure to separate long item numbers.
2379 Don't read the members of a rule's prec if its nil.
2380
133c20e2
AD
23812002-04-22 Akim Demaille <akim@epita.fr>
2382
2383 * src/output.c (table_size, table_grow): New.
2384 (MAXTABLE): Remove, replace uses with table_size.
2385 (pack_vector): Instead of dying when the table is too big, grow it.
2386
9515e8a7
AD
23872002-04-22 Akim Demaille <akim@epita.fr>
2388
2389 * data/bison.simple (yyr1): Its type is that of a token number.
2390 * data/bison.c++ (r1_): Likewise.
2391 * tests/regression.at (Web2c Actions): Adjust.
2392
23c5a174
AD
23932002-04-22 Akim Demaille <akim@epita.fr>
2394
2395 * src/reader.c (token_translations_init): 256 is now the default
2396 value for the error token, i.e., it will be assigned another
2397 number if the user assigned 256 to one of her tokens.
2398 (reader): Don't force 256 to error.
2399 * doc/bison.texinfo (Symbols): Adjust.
2400 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2401 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2402 etc. instead of 10, 20, 30 (which was used to `jump' over error
2403 (256) and undefined (2)).
2404
5fbb0954
AD
24052002-04-22 Akim Demaille <akim@epita.fr>
2406
2407 Propagate more token_number_t.
2408
2409 * src/gram.h (token_number_as_item_number)
2410 (item_number_as_token_number): New.
2411 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2412 Use it to create output_item_number_table and
2413 output_token_number_table.
2414 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2415 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2416 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2417 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2418
4f940944
AD
24192002-04-22 Akim Demaille <akim@epita.fr>
2420
2421 * src/output.h, src/output.c (get_lines_number): Remove.
2422
3ded9a63
AD
24232002-04-19 Akim Demaille <akim@epita.fr>
2424
2425 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2426 as Lex/Flex'.
2427 (Debugging): More details about enabling the debugging features.
2428 (Table of Symbols): Describe $$, $n, @$, and @n.
2429 Suggested by Tim Josling.
2430
e0c471a9
AD
24312002-04-19 Akim Demaille <akim@epita.fr>
2432
2433 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2434
fecc10cd
AD
24352002-04-10 Akim Demaille <akim@epita.fr>
2436
2437 * src/system.h: Rely on HAVE_LIMITS_H.
2438 Suggested by Paul Eggert.
2439
51dec47b
AD
24402002-04-09 Akim Demaille <akim@epita.fr>
2441
2442 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2443 full stderr, and strip it according to the bison options, instead
2444 of composing the error message from different bits.
2445 This makes it easier to check for several error messages.
2446 Adjust all the invocations.
2447 Add an invocation exercising the error token.
2448 Add an invocation demonstrating a stupid error message.
2449 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2450 Adjust the tests.
2451 Error message are for stderr, not stdout.
2452
007a50a4
AD
24532002-04-09 Akim Demaille <akim@epita.fr>
2454
2455 * src/gram.h, src/gram.c (error_token_number): Remove, use
2456 errtoken->number.
2457 * src/reader.c (reader): Don't specify the user token number (2)
2458 for $undefined, as it uselessly prevents using it.
2459 * src/gram.h (token_number_t): Move to...
2460 * src/symtab.h: here.
2461 (state_t.number): Is a token_number_t.
2462 * src/print.c, src/reader.c: Use undeftoken->number instead of
2463 hard coded 2.
2464 (Even though this 2 is not the same as above: the number of the
2465 undeftoken remains being 2, it is its user token number which
2466 might not be 2).
2467 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2468 `user_token_number_max'.
2469 Output `undef_token_number'.
2470 * data/bison.simple, data/bison.c++: Use them.
2471 Be sure to map invalid yylex return values to
2472 `undef_token_number'. This saves us from gratuitous SEGV.
2473
2474 * tests/conflicts.at (Solved SR Conflicts)
2475 (Unresolved SR Conflicts): Adjust.
2476 * tests/regression.at (Web2c Actions): Adjust.
2477
06446ccf
AD
24782002-04-08 Akim Demaille <akim@epita.fr>
2479
2480 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2481 Adding #line.
2482 Remove the duplicate `typedefs'.
2483 (RhsNumberType): Fix the declaration and various other typos.
2484 Use __ofile__.
2485 * data/bison.simple: Use __ofile__.
2486 * src/scan-skel.l: Handle __ofile__.
2487
62a3e4f0
AD
24882002-04-08 Akim Demaille <akim@epita.fr>
2489
2490 * src/gram.h (item_number_t): New, the type of item numbers in
2491 RITEM. Note that it must be able to code symbol numbers as
2492 positive number, and the negation of rule numbers as negative
2493 numbers.
2494 Adjust all dependencies (pretty many).
2495 * src/reduce.c (rule): Remove this `short *' pointer: use
2496 item_number_t.
2497 * src/system.h (MINSHORT, MAXSHORT): Remove.
2498 Include `limits.h'.
2499 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2500 (shortcpy): Remove.
2501 (MAXTABLE): Move to...
2502 * src/output.c (MAXTABLE): here.
2503 (prepare_rules): Use output_int_table to output rhs.
2504 * data/bison.simple, data/bison.c++: Adjust.
2505 * tests/torture.at (Big triangle): Move the limit from 254 to
2506 500.
2507 * tests/regression.at (Web2c Actions): Ajust.
2508
2509 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2510 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
2511 passes, but produces negative #line number, once fixed, GCC is
2512 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
2513 C), it passes.
2514 * src/state.h (state_h): Code input lines on ints, not shorts.
2515
bb88b0fc
AD
25162002-04-08 Akim Demaille <akim@epita.fr>
2517
2518 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
2519 and then the grammar.
2520
9a636f47
AD
25212002-04-08 Akim Demaille <akim@epita.fr>
2522
2523 * src/system.h: No longer using strndup.
2524
680e8701
AD
25252002-04-07 Akim Demaille <akim@epita.fr>
2526
2527 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
2528 * src/output.c (output_table_data): Return the longest number.
2529 (prepare_tokens): Output `token_number_max').
2530 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
2531 New.
2532 Use them to define yy_token_number_type/TokenNumberType.
2533 Use this type for yytranslate.
2534 * tests/torture.at (Big triangle): Push the limit from 124 to
2535 253.
2536 * tests/regression.at (Web2c Actions): Adjust.
2537
817e9f41
AD
25382002-04-07 Akim Demaille <akim@epita.fr>
2539
2540 * tests/torture.at (Big triangle): New.
2541 (GNU AWK Grammar, GNU Cim Grammar): Move to...
2542 * tests/existing.at: here.
2543
5123689b
AD
25442002-04-07 Akim Demaille <akim@epita.fr>
2545
2546 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
2547 nritems.
2548 Adjust dependencies.
2549
f3849179
AD
25502002-04-07 Akim Demaille <akim@epita.fr>
2551
2552 * src/reader.c: Normalize increments to prefix form.
2553
bd02036a
AD
25542002-04-07 Akim Demaille <akim@epita.fr>
2555
2556 * src/reader.c, symtab.c: Remove debugging code.
2557
db8837cb
AD
25582002-04-07 Akim Demaille <akim@epita.fr>
2559
2560 Rename all the `bucket's as `symbol_t'.
2561
2562 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
2563 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
2564 * src/symtab.c, src/symtab.h (bucket): Rename as...
2565 (symbol_t): this.
2566 (symbol_list_new, bucket_check_defined, bucket_make_alias)
2567 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
2568 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2569 (buckets_new, buckets_free, buckets_do): Rename as...
2570 (symbol_list_new, symbol_check_defined, symbol_make_alias)
2571 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2572 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
2573 (symbols_new, symbols_free, symbols_do): these.
2574
72a23c97
AD
25752002-04-07 Akim Demaille <akim@epita.fr>
2576
2577 Use lib/hash for the symbol table.
2578
2579 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
2580 EOF.
2581 * src/lex.c (lex): Set the `number' member of new terminals.
2582 * src/reader.c (bucket_check_defined, bucket_make_alias)
2583 (bucket_check_alias_consistence, bucket_translation): New.
2584 (reader, grammar_free, readgram, token_translations_init)
2585 (packsymbols): Adjust.
2586 (reader): Number the predefined tokens.
2587 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
2588 for predefined tokens.
2589 * src/symtab.h (bucket): Remove all the hash table related
2590 members.
2591 * src/symtab.c (symtab): Replace by...
2592 (bucket_table): this.
2593 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2594 (buckets_new, buckets_do): New.
2595
280a38c3
AD
25962002-04-07 Akim Demaille <akim@epita.fr>
2597
2598 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
2599 (start_symbol, max_user_token_number, semantic_parser)
2600 (error_token_number): Initialize.
2601 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
2602 Initialize.
2603 (reader): Don't.
2604 (errtoken, eoftoken, undeftoken, axiom): Extern.
2605
03b31c0c
AD
26062002-04-07 Akim Demaille <akim@epita.fr>
2607
2608 * src/gram.h (rule_s): prec and precsym are now pointers
2609 to the bucket giving the priority/associativity.
2610 Member `associativity' removed: useless.
2611 * src/reduce.c, src/conflicts.c: Adjust.
2612
8b3df748
AD
26132002-04-07 Akim Demaille <akim@epita.fr>
2614
2615 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
2616 Properly escape the symbols' TAG when outputting them.
2617
e601aa1d
AD
26182002-04-07 Akim Demaille <akim@epita.fr>
2619
2620 * src/lalr.h (LA): Is a bitsetv, not bitset*.
2621
b0299a2e
AD
26222002-04-07 Akim Demaille <akim@epita.fr>
2623
2624 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
2625 (LArule): this, which is an array to rule_t*.
2626 * src/print.c, src/conflicts.c: Adjust.
2627
d7e1f00c
AD
26282002-04-07 Akim Demaille <akim@epita.fr>
2629
2630 * src/gram.h (rule_t): Rename `number' as `user_number'.
2631 `number' is a new member.
2632 Adjust dependencies.
2633 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
2634
cc9305dd
AD
26352002-04-07 Akim Demaille <akim@epita.fr>
2636
2637 As a result of the previous patch, it is no longer needed
2638 to reorder ritem itself.
2639
2640 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
2641
b0940840
AD
26422002-04-07 Akim Demaille <akim@epita.fr>
2643
2644 Be sure never to walk through RITEMS, but use only data related to
2645 the rules themselves. RITEMS should be banished.
2646
2647 * src/output.c (output_token_translations): Rename as...
2648 (prepare_tokens): this.
2649 In addition to `translate', prepare the muscles `tname' and
2650 `toknum', which were handled by...
2651 (output_rule_data): this.
2652 Remove, and move the remainder of its outputs into...
2653 (prepare_rules): this new routines, which also merges content from
2654 (output_gram): this.
2655 (prepare_rules): Be sure never to walk through RITEMS.
2656 (output_stos): Rename as...
2657 (prepare_stos): this.
2658 (output): Always invoke prepare_states, after all, just don't use it
2659 in the output if you don't need it.
2660
643a5994
AD
26612002-04-07 Akim Demaille <akim@epita.fr>
2662
2663 * src/LR0.c (new_state): Display `nstates' as the name of the
2664 newly created state.
2665 Adjust to initialize first_state and last_state if needed.
2666 Be sure to distinguish the initial from the final state.
2667 (new_states): Create the itemset of the initial state, and use
2668 new_state.
2669 * src/closure.c (closure): Now that the initial state has its
2670 items properly set, there is no need for a special case when
2671 creating `ruleset'.
2672
2673 As a result, now the rule 0, reducing to $axiom, is visible in the
2674 outputs. Adjust the test suite.
2675
2676 * tests/conflicts.at (Solved SR Conflicts)
2677 (Unresolved SR Conflicts): Adjust.
2678 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
2679 * tests/conflicts.at (S/R in initial): New.
2680
b4c4ccc2
AD
26812002-04-07 Akim Demaille <akim@epita.fr>
2682
2683 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
2684 the RHS of the rules.
2685 * src/output.c (output_gram): Likewise.
2686
bba97eb2
AD
26872002-04-07 Akim Demaille <akim@epita.fr>
2688
2689 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
2690 bucket.
2691 Adjust all dependencies.
2692 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
2693 `number' of the buckets too.
2694 * src/gram.h: Include `symtab.h'.
2695 (associativity): Move to...
2696 * src/symtab.h: here.
2697 No longer include `gram.h'.
2698
c3b407f4
AD
26992002-04-07 Akim Demaille <akim@epita.fr>
2700
2701 * src/gram.h, src/gram.c (rules_rhs_length): New.
2702 (ritem_longest_rhs): Use it.
2703 * src/gram.h (rule_t): `number' is a new member.
2704 * src/reader.c (packgram): Set it.
2705 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
2706 the end of `rules', and count them out of `nrules'.
2707 (reduce_output, dump_grammar): Adjust.
2708 * src/print.c (print_grammar): It is no longer needed to check for
2709 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
2710 * tests/reduce.at (Reduced Automaton): New test.
2711
11652ab3
AD
27122002-04-07 Akim Demaille <akim@epita.fr>
2713
2714 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
2715 lacking `+ 1' to nrules, Bison reported as useless a token if it
2716 was used solely to set the precedence of the last rule...
2717
26b23c1a
AD
27182002-04-07 Akim Demaille <akim@epita.fr>
2719
2720 * data/bison.c++, data/bison.simple: Don't output the current file
2721 name in #line, to avoid useless diffs between two identical
2722 outputs under different names.
2723
18bcecb0
AD
27242002-04-07 Akim Demaille <akim@epita.fr>
2725
2726 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
2727 Normalize loops to using `< nrules + 1', not `<= nrules'.
2728
fa770c86
AD
27292002-04-07 Akim Demaille <akim@epita.fr>
2730
2731 * TODO: Update.
2732
d9b739c3
AD
27332002-04-07 Akim Demaille <akim@epita.fr>
2734
2735 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
2736 bucket.value as bucket.number.
2737
99013900
AD
27382002-04-07 Akim Demaille <akim@epita.fr>
2739
2740 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
2741 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2742 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
2743 RHS, instead of being an index in RITEMS.
2744
e966383b
PE
27452002-04-04 Paul Eggert <eggert@twinsun.com>
2746
2747 * doc/bison.texinfo: Update copyright date.
2748 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
2749 (Symbols): Warn about running Bison in one character set,
2750 but compiling and/or running in an incompatible one.
2751 Warn about character code 256, too.
2752
27532002-04-03 Paul Eggert <eggert@twinsun.com>
2754
2755 * src/bison.data (YYSTACK_ALLOC): Depend on whether
2756 YYERROR_VERBOSE is nonzero, not whether it is defined.
2757
2758 Merge changes from bison-1_29-branch.
c307773e 2759
8d6c48b9
PE
27602002-03-20 Paul Eggert <eggert@twinsun.com>
2761
2762 Merge fixes from Debian bison_1.34-1.diff.
2763
2764 * configure.in (AC_PREREQ): 2.53.
2765
e53c6322
AD
27662002-03-20 Akim Demaille <akim@epita.fr>
2767
2768 * src/conflicts.c (log_resolution): Argument `resolution' is const.
2769
9ffbeca7
PE
27702002-03-19 Paul Eggert <eggert@twinsun.com>
2771
21db0b2a
PE
2772 * src/bison.simple (YYCOPY): New macro.
2773 (YYSTACK_RELOCATE): Use it.
2774 Remove Type arg; no longer needed. All callers changed.
2775 (yymemcpy): Remove; no longer needed.
2776
9ffbeca7
PE
2777 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
2778 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
2779
642cb8f8
AD
27802002-03-19 Akim Demaille <akim@epita.fr>
2781
2782 Test and fix the #line outputs.
2783
2784 * tests/atlocal.at (GCC): New.
2785 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
2786 (Prologue synch line, ,%union synch line, Postprologue synch line)
2787 (Action synch line, Epilogue synch line): New tests.
2788 * src/reader.c (parse_union_decl): Define the muscle stype_line.
2789 * data/bison.simple, data/bison.c++: Use it.
2790
3c31a486
AD
27912002-03-19 Akim Demaille <akim@epita.fr>
2792
2793 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
2794 (Solved SR Conflicts, %expect not enough, %expect right)
2795 (%expect too much): Move to...
2796 * tests/conflicts.at: this new file.
2797
0d8bed56
AD
27982002-03-19 Akim Demaille <akim@epita.fr>
2799
2800 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2801 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
2802 that we can move to enums for instance.
2803 * src/output.c (token_definitions_output): Output a list of
2804 `token-name, token-number' instead of the #define.
2805 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
2806
9208d17f
AD
28072002-03-14 Akim Demaille <akim@epita.fr>
2808
2809 Use Gettext 0.11.1.
2810
af27eacb
RA
28112002-03-09 Robert Anisko <robert@lrde.epita.fr>
2812
2813 * data/bison.c++: Make the user able to add members to the generated
2814 parser by subclassing.
2815
9101a310
RA
28162002-03-05 Robert Anisko <robert@lrde.epita.fr>
2817
2818 * src/reader.c (read_additionnal_code): `c' should be an integer, not
2819 a character.
2820 Reported by Nicolas Tisserand and Nicolas Burrus.
2821
fff9bf0b
RA
28222002-03-04 Robert Anisko <robert@lrde.epita.fr>
2823
2824 * src/reader.c: Warn about lacking semi-colons, do not complain.
2825
64dba31e
RA
28262002-03-04 Robert Anisko <robert@lrde.epita.fr>
2827
2828 * data/bison.c++: Remove a debug line.
2829
374f5a14
RA
28302002-03-04 Robert Anisko <robert@lrde.epita.fr>
2831
2832 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2833 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2834 provide a default implementation.
2835
bfcf1f3a
AD
28362002-03-04 Akim Demaille <akim@epita.fr>
2837
2838 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2839 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2840 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2841 * tests/semantic.at (Parsing Guards): Similarly.
2842 * src/reader.at (readgram): Complain if the last rule is not ended
2843 with a semi-colon.
2844
65ccf9fc
AD
28452002-03-04 Akim Demaille <akim@epita.fr>
2846
2847 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2848 * src/closure.c: here.
2849 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2850 RTC.
2851 * src/warshall.h, src/warshall.c: Remove.
2852 * tests/sets.at (Broken Closure): Adjust.
2853
d0039cbc
AD
28542002-03-04 Akim Demaille <akim@epita.fr>
2855
2856 * src/output.c (output_skeleton): tempdir is const.
2857 bytes_read is unused.
2858
345cea78
AD
28592002-03-04 Akim Demaille <akim@epita.fr>
2860
2861 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2862 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2863 Update.
2864 From Michael Hayes.
2865
564801f7
AD
28662002-03-04 Akim Demaille <akim@epita.fr>
2867
2868 * src/closure.c (closure): `r' is unused.
2869
e5352bc7
AD
28702002-03-04 Akim Demaille <akim@epita.fr>
2871
2872 * tests/sets.at (Broken Closure): Add the ending `;'.
2873 * src/reader.at (readgram): Complain if a rule is not ended with a
2874 semi-colon.
2875
914feea9
AD
28762002-03-04 Akim Demaille <akim@epita.fr>
2877
2878 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2879 (count_sr_conflicts): Use bitset_count.
2880 * src/reduce.c (inaccessable_symbols): Ditto.
2881 (bits_size): Remove.
2882 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2883
f0250de6
AD
28842002-03-04 Akim Demaille <akim@epita.fr>
2885
2886 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2887 * src/reduce.c: Remove the `bitset_zero's following the
2888 `bitset_create's, as now it is performed by the latter.
2889
ef017502
AD
28902002-03-04 Akim Demaille <akim@epita.fr>
2891
2892 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2893 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2894 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2895 latest sources from Michael.
2896
76514394
AD
28972002-03-04 Akim Demaille <akim@epita.fr>
2898
2899 * src/output.c (output): Don't free the grammar.
2900 * src/reader.c (grammar_free): New.
2901 * src/main.c (main): Call it and don't free symtab here.
2902
55024580
AD
29032002-03-04 Akim Demaille <akim@epita.fr>
2904
2905 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2906 before returning.
2907 Reported by Benoit Perrot.
2908
f9abaa2c
AD
29092002-03-04 Akim Demaille <akim@epita.fr>
2910
2911 Use bitset operations when possible, not loops over bits.
2912
2913 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2914 bitset_or.
2915 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2916 * src/reduce.c (useless_nonterminals): Formatting changes.
2917 * src/warshall.c (TC): Use bitset_or.
2918
0e721e75
AD
29192002-03-04 Akim Demaille <akim@epita.fr>
2920
2921 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2922 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2923 Ditto.
2924
0fb1ffb1
AD
29252002-03-04 Akim Demaille <akim@epita.fr>
2926
2927 * src/lalr.c (F): Now a bitset*.
2928 Adjust all dependencies.
2929
b86796bf
AD
29302002-03-04 Akim Demaille <akim@epita.fr>
2931
2932 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2933 Adjust all dependencies.
2934
602bbf31
AD
29352002-03-04 Akim Demaille <akim@epita.fr>
2936
2937 * src/L0.c, src/LR0.h (nstates): Be size_t.
2938 Adjust comparisons (signed vs unsigned).
2939 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2940 bitset*.
2941 Adjust all dependencies.
2942
d8a0245c
AD
29432002-03-04 Akim Demaille <akim@epita.fr>
2944
2945 * src/closure.c (firsts): Now, also a bitset.
2946 Adjust all dependencies.
2947 (varsetsize): Remove, now unused.
2948 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2949
34ba9743
AD
29502002-03-04 Akim Demaille <akim@epita.fr>
2951
2952 * src/print.c: Convert to use bitset.h, not hand coded iterations
2953 over ints.
2954
ed86e78c
AD
29552002-03-04 Akim Demaille <akim@epita.fr>
2956
2957 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2958
dfdb1797
AD
29592002-03-04 Akim Demaille <akim@epita.fr>
2960
2961 * src/closure.c (ruleset): Be a bitset.
2962 (rulesetsize): Remove.
2963
7086e707
AD
29642002-03-04 Akim Demaille <akim@epita.fr>
2965
2966 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2967 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2968 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2969 * src/closure.c (fderives): Be an array of bitsets.
2970
98254360
RA
29712002-02-28 Robert Anisko <robert@lrde.epita.fr>
2972
2973 * data/bison.c++: Merge the two generated headers. Insert a copyright
2974 notice in each output file.
2975
a75c057f
AD
29762002-02-28 Akim Demaille <akim@epita.fr>
2977
2978 * data/bison.c++: Copy the prologue of bison.simple to fetch
2979 useful M4 definitions, such as b4_header_guard.
2980
06b00abc
AD
29812002-02-25 Akim Demaille <akim@epita.fr>
2982
2983 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
2984 translator friendly scheme for the bgr
2985 copyright notice.
06b00abc 2986
70e7d534
AD
29872002-02-25 Akim Demaille <akim@epita.fr>
2988
2989 * src/output.c (header_output): Remove, now handled completely via
2990 M4.
2991
abe017f6
AD
29922002-02-25 Akim Demaille <akim@epita.fr>
2993
2994 * m4/m4.m4: New, from CVS Autoconf.
2995 * configure.in: Invoke it.
2996 * src/output.c (output_skeleton): Use its result instead of the
2997 hard coded name.
2998
381fb12e
AD
29992002-02-25 Akim Demaille <akim@epita.fr>
3000
3001 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3002 Fileutils 4.1.5.
3003 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3004 * src/output.c (output_skeleton): Use mkstemp to create a real
3005 temporary file.
3006 Move the filling of `skeleton' and its muscle to...
3007 (prepare): here.
3008 (output): Move the definition of the prologue muscle to...
3009 (prepare): here.
3010 * src/system.h (DEFAULT_TMPDIR): New.
3011
6f38107f
PE
30122002-02-14 Paul Eggert <eggert@twinsun.com>
3013
3014 Remove the support for C++ namespace cleanliness; it was
3015 causing more problems than it was curing, since it didn't work
3016 properly on some nonstandard C++ compilers. This can wait
3017 for a proper C++ parser.
3018
3019 * NEWS: Document this.
3020 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3021 of C++, as it's treated like C now.
3022 * src/bison.simple (YYSTD): Remove.
3023 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3024 Treat C++ just like Standard C instead of trying to support
3025 namespace cleanliness.
3026
80cce3da
AD
30272002-02-14 Akim Demaille <akim@epita.fr>
3028
3029 * tests/regression.at (else): Adjust to Andreas' change.
3030
842e8679
AD
30312002-02-14 Akim Demaille <akim@epita.fr>
3032
3033 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3034
4bda3f10
AD
30352002-02-13 Andreas Schwab <schwab@suse.de>
3036
3037 * src/output.c (output_rule_data): Don't output NULL, it might
3038 not be defined yet.
3039
4162fa07 30402002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 3041
4162fa07
RA
3042 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3043 (Copyright notice): Update.
b418ecd8 3044
bd16a5dc
AD
30452002-02-11 Akim Demaille <akim@epita.fr>
3046
3047 * tests/regression.at (%nonassoc and eof): Don't include
3048 nonportable headers.
3049
8d69a1a3
RA
30502002-02-08 Robert Anisko <robert@lrde.epita.fr>
3051
3052 * data/bison.c++: Correct error recovery. Make the user able to
3053 initialize the starting location.
3054
9b2d0677
AD
30552002-02-07 Akim Demaille <akim@epita.fr>
3056
3057 * tests/input.at: New.
3058
69e2658b
RA
30592002-02-07 Robert Anisko <robert@lrde.epita.fr>
3060
3061 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 3062 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
3063 directives around tables only needed for debugging.
3064
4aacc3a7
RA
30652002-02-07 Robert Anisko <robert@lrde.epita.fr>
3066
3067 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3068 C++ parsers.
3069 (yy::b4_name::parse): Use print_.
3070
762a801e
RA
30712002-02-07 Robert Anisko <robert@lrde.epita.fr>
3072
3073 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3074
4bb2bc3f
RA
30752002-02-07 Robert Anisko <robert@lrde.epita.fr>
3076
3077 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3078 C++ parsers.
3079 (yy::b4_name::parse): Build verbose error messages, and use error_.
3080
6b45a3ca
RA
30812002-02-06 Robert Anisko <robert@lrde.epita.fr>
3082
3083 * data/bison.c++: Fix m4 quoting in comments.
3084
50997c6e
RA
30852002-02-06 Robert Anisko <robert@lrde.epita.fr>
3086
3087 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3088 not expanded by m4.
3089
3f3eed27
AD
30902002-02-05 Akim Demaille <akim@epita.fr>
3091
3092 * data/bison.c++: Adjust to the M4 back end.
3093 More is certainly needed.
3094
be2a1a68
AD
30952002-02-05 Akim Demaille <akim@epita.fr>
3096
3097 Give a try to M4 as a back end.
3098
3099 * lib/readpipe.c: New, from wdiff.
3100 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3101 BISON_HAIRY.
3102 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3103 specific values. Now it is m4 that performs the lookup.
3104 * src/parse-skel.y: Remove.
3105 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3106 * src/output.c (actions_output, guards_output)
3107 (token_definitions_output): No longer keeps track of the output
3108 line number, hence remove the second argument.
3109 (guards_output): Check against the guard member of a rule, not the
3110 action member.
3111 Adjust callers.
3112 (output_skeleton): Don't look for the skeleton location, let m4 do
3113 that.
3114 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3115 file will be used.
3116 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3117 (prepare): Given that for the time being changesyntax is not
3118 usable in M4, rename the muscles using `-' to `_'.
3119 Define `defines_flag', `output_parser_name' and `output_header_name'.
3120 * src/output.h (actions_output, guards_output)
3121 (token_definitions_output): Adjust prototypes.
3122 * src/scan-skel.l: Instead of scanning the skeletons, it now
3123 processes the output of m4: `__oline__' and `#output'.
3124 * data/bison.simple: Adjust to be used by M4(sugar).
3125 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3126 to date.
3127 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3128 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3129 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3130 shamelessly stolen from CVS Autoconf.
3131
beda758b
AD
31322002-02-05 Akim Demaille <akim@epita.fr>
3133
3134 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3135 * configure.in: Check for the declarations of free and malloc.
3136 * src/muscle_tab.c: Adjust.
3137
5ece6d43
AD
31382002-02-05 Akim Demaille <akim@epita.fr>
3139
3140 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3141 which have no values.
3142
5bb18f9a
AD
31432002-02-05 Akim Demaille <akim@epita.fr>
3144
3145 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3146 * data/: here.
3147
894dd62e
PE
31482002-01-29 Paul Eggert <eggert@twinsun.com>
3149
3150 * src/bison.simple (YYSIZE_T): Do not define merely because
3151 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3152 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3153
82841af7
AD
31542002-01-27 Akim Demaille <akim@epita.fr>
3155
3156 Fix `%nonassoc and eof'.
3157
3158 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3159 which were not properly copied! Replace
3160 memcpy (res->errs, src->errs, src->nerrs);
3161 with
3162 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3163 !!!
3164 * tests/regression.at (%nonassoc and eof): Adjust to newest
3165 Autotest: `.' is not in the PATH.
3166
318b76e9
AD
31672002-01-27 Akim Demaille <akim@epita.fr>
3168
3169 * tests/sets.at (AT_EXTRACT_SETS): New.
3170 (Nullable): Use it.
3171 (Firsts): New.
3172
30d2f3d5
AD
31732002-01-26 Akim Demaille <akim@epita.fr>
3174
3175 * tests/actions.at, tests/calc.at, tests/headers.at,
3176 * tests/torture.at: Adjust to the newest Autotest which no longer
3177 forces `.' in the PATH.
3178
30f8c395
AD
31792002-01-25 Akim Demaille <akim@epita.fr>
3180
3181 * tests/regression.at (%nonassoc and eof): New.
3182 Suggested by Robert Anisko.
3183
29ae55f1
AD
31842002-01-24 Akim Demaille <akim@epita.fr>
3185
3186 Bison dumps core when trying to complain about broken input files.
3187 Reported by Cris van Pelt.
3188
3189 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3190 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3191 into...
3192 (Invalid inputs): Strengthen: exercise parse_percent_token.
3193
2b548aa6
RA
31942002-01-24 Robert Anisko <robert.anisko@epita.fr>
3195
3196 * src/Makefile.am: Add bison.c++.
3197 * src/bison.c++: New skeleton.
3198
bb0146c2
AD
31992002-01-21 Paolo Bonzini <bonzini@gnu.org>
3200
3201 * po/it.po: New.
3202
bec30531
AD
32032002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3204
3205 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3206
fc6edc45
MA
32072002-01-20 Marc Autret <marc@gnu.org>
3208
3209 * src/files.c (compute_output_file_names): Fix
3210
5e5d5415
MA
32112002-01-20 Marc Autret <marc@gnu.org>
3212
3213 * tests/output.at: New test.
3214 * src/files.c (compute_base_names): Don't map extensions when
3215 the YACC flag is set, use defaults.
3216 Reported by Evgeny Stambulchik.
3217
44ea3fbd
MA
32182002-01-20 Marc Autret <marc@gnu.org>
3219
bb0146c2 3220 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
3221 compilers as well (i.e. the vendor C compiler).
3222 Suggested by Albert Chin-A-Young.
3223
338963d1
TVH
32242002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3225
3226 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3227 canonical definition.
3228 * src/system.h: Use the canonical definition for PARAMS (avoids
3229 a conflict with the macro from lib/hash.h).
3230
c57b2479
AD
32312002-01-11 Akim Demaille <akim@epita.fr>
3232
3233 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 3234 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 3235
b85810ae
AD
32362002-01-09 Akim Demaille <akim@epita.fr>
3237
3238 * src/files.c, src/files.h (output_infix): New.
3239 (tab_extension): Remove.
3240 (compute_base_names): Compute the former, drop the latter.
3241 * src/output.c (prepare): Insert the muscles `output-infix', and
3242 `output-suffix'.
3243 * src/parse-skel.y (string, string.1): New.
3244 (section.header): Use it.
3245 (section.yacc): Remove.
3246 (prefix): Remove too.
3247 * src/scan-skel.l: Adjust.
3248 * src/bison.simple, src/bison.hairy: Adjust.
3249
cae60122
AD
32502002-01-09 Akim Demaille <akim@epita.fr>
3251
3252 * configure.in (WERROR_CFLAGS): Compute it.
3253 * src/Makefile.am (CFLAGS): Pass it.
3254 * tests/atlocal.in (CFLAGS): Idem.
3255 * src/files.c: Fix a few warnings.
3256 (get_extension_index): Remove, unused.
3257
ae404801
AD
32582002-01-08 Akim Demaille <akim@epita.fr>
3259
3260 * src/getargs.c (AS_FILE_NAME): New.
3261 (getargs): Use it to convert DOSish file names.
3262 * src/files.c (base_name): Rename as full_base_name to avoid
3263 clashes with `base_name ()'.
3264 (filename_split): New.
3265 (compute_base_names): N-th rewrite, using filename_split.
3266
22312b71
AD
32672002-01-08 Akim Demaille <akim@epita.fr>
3268
3269 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3270 New, stolen from the Fileutils 4.1.
3271 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3272 * configure.in: Check for the presence of memrchr, and of its
3273 prototype.
3274
a67cef01
TVH
32752002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3276
3277 * lib/hash.h (__P): Added definition for this macro.
3278 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3279 BUILT_SOURCES, to ensure they are generated first.
3280 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3281 %error-verbose to allow bootstrapping with bison 1.30x.
3282
2b25d624
AD
32832002-01-06 Akim Demaille <akim@epita.fr>
3284
3285 * src/reader.c (parse_braces): Don't fetch the next char, the
3286 convention is to fetch on entry.
3287 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3288 'switch' without a following semicolon.
3289 * tests/regression.at (braces parsing): New.
3290
3460813b
AD
32912002-01-06 Akim Demaille <akim@epita.fr>
3292
3293 Bison is dead wrong in its RR conflict reports.
3294
3295 * tests/torture.at (GNU Cim Grammar): New.
3296 * src/conflicts.c (count_rr_conflicts): Fix.
3297
73784c64
AD
32982002-01-06 Akim Demaille <akim@epita.fr>
3299
3300 Creating package.m4 from configure.ac causes too many problems.
3301
3302 * tests/Makefile.am (package.m4): Create it by hand,
3303 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3304
25d81090
AD
33052002-01-06 Akim Demaille <akim@epita.fr>
3306
3307 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3308 skeleton.h.
3309
a9b8959e
PE
33102002-01-04 Paul Eggert <eggert@twinsun.com>
3311
3312 * doc/bison.texinfo (Debugging):
3313 Remove YYSTDERR; it's no longer defined or used.
3314 Also, s/cstdio.h/cstdio/.
3315
25d81090
AD
33162002-01-03 Akim Demaille <akim@epita.fr>
3317
3318 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3319
1109455c
AD
33202002-01-03 Akim Demaille <akim@epita.fr>
3321
3322 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3323 tracing code to --trace, wait for a better --trace option, with
3324 args.
3325
7ea5e977
AD
33262002-01-03 Akim Demaille <akim@epita.fr>
3327
3328 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3329 The ISO C++ standard is extremely clear about it: stderr is
3330 considered a macro, not a regular symbol (see table 94 `Header
3331 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3332 Therefore std:: does not apply to it. It still does with fprintf.
3333 Also, s/cstdio.h/cstdio/.
3334
fab5b110
AD
33352002-01-03 Akim Demaille <akim@epita.fr>
3336
3337 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3338 for non system headers.
3339
aed7fd9b
AD
33402002-01-02 Akim Demaille <akim@epita.fr>
3341
3342 Equip the skeleton chain with location tracking, runtime trace,
3343 pure parser and scanner.
3344
3345 * src/parse-skel.y: Request a pure parser, locations, and prefix
3346 renaming.
3347 (%union): Having several members with the same type does not help
3348 type mismatches, simplify.
3349 (YYPRINT, yyprint): New.
3350 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3351 (skel_error): this.
3352 Handle locations.
3353 * src/scan-skel.l: Adjust to these changes.
3354 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3355 (LOCATION_PRINT, skel_control_t): New.
3356
24fad99e
AD
33572001-12-30 Akim Demaille <akim@epita.fr>
3358
3359 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3360 replace `gb' with BLANKS.
3361 * src/scan-skel.l: Adjust.
3362
a4b36db4
AD
33632001-12-30 Akim Demaille <akim@epita.fr>
3364
3365 * src/system.h: We don't need nor want bcopy.
3366 Throw away MS-DOS crap: we don't need getpid.
3367 * configure.in: We don't need strndup. It was even causing
3368 problems: because Flex includes the headers *before* us,
3369 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3370 not visible.
3371 * lib/xstrndup.c: New.
3372 * src/scan-skel.l: Use it.
3373 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3374 * src/parse-skel.y: Use %directives instead of #defines.
3375
1239777d
AD
33762001-12-30 Akim Demaille <akim@epita.fr>
3377
3378 * src/skeleton.h: New.
3379 * src/output.c (output_parser, output_master_parser): Remove, dead
3380 code.
3381 * src/output.h (get_lines_number, actions_output, guards_output)
3382 (token_definitions_output): Prototype them.
3383 * src/parse-skel.y: Add the license notice.
3384 Include output.h and skeleton.h.
3385 (process_skeleton): Returns void, and takes a single parameter.
3386 * src/scan-skel.l: Add the license notice.
3387 Include skeleton.h.
3388 Don't use %option yylineno: it seems that then Flex imagines
3389 REJECT has been used, and therefore it won't reallocate its
3390 buffers (which makes no other sense to me than a bug). It results
3391 in warnings for `unused: yy_flex_realloc'.
3392
9b3add5b
RA
33932001-12-30 Robert Anisko <robert.anisko@epita.fr>
3394
3395 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3396 (MUSCLE_INSERT_PREFIX): ...to there.
3397 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3398 (MUSCLE_INSERT_PREFIX): Move from here...
3399
3400 * src/bison.hairy: Add a section directive. Put braces around muscle
3401 names. This parser skeleton is still broken, but Bison should not
3402 choke on a bad muscle 'syntax'.
3403 * src/bison.simple: Add a section directive. Put braces around muscle
3404 names.
3405
3406 * src/files.h (strsuffix, stringappend): Add declarations.
3407 (tab_extension): Add declaration.
3408 (short_base_name): Add declaration.
3409
3410 * src/files.c (strsuffix, stringappend): No longer static. These
3411 functions are used in the skeleton parser.
3412 (tab_extension): New.
3413 (compute_base_names): Use the computations done in this function
fab5b110 3414 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
3415 names.
3416 (short_base_name): No longer static.
3417
3418 * src/output.c (output_skeleton): New.
3419 (output): Disable call to output_master_parser, and give a try to
3420 a new skeleton handling system.
3421 (guards_output, actions_output): No longer static.
3422 (token_definitions_output, get_lines_number): No longer static.
3423
3424 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3425
fab5b110 3426 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
3427 parse-skel.y.
3428
3429 * src/parse-skel.y: New file.
3430 * src/scan-skel.l: New file.
3431
b5b61c61
AD
34322001-12-29 Akim Demaille <akim@epita.fr>
3433
3434 %name-prefix is broken.
3435
3436 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3437 Adjust all dependencies.
3438 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3439 %name-prefix.
3440
3441 Renaming yylval but not yylloc is not consistent. Now we do.
3442
3443 * src/bison.simple: Prefix yylloc if used.
3444 * doc/bison.texinfo (Decl Summary): Document that.
3445
8c9a50be
AD
34462001-12-29 Akim Demaille <akim@epita.fr>
3447
3448 * doc/bison.texinfo: Promote `%long-directive' over
3449 `%long_directive'.
3450 Remove all references to fixed-output-files, yacc is enough.
3451
d99361e6
AD
34522001-12-29 Akim Demaille <akim@epita.fr>
3453
3454 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3455 user prologue. These are defaults.
3456 * tests/actions.at (Mid-rule actions): Make sure the user can
3457 define YYDEBUG and YYERROR_VERBOSE.
3458
b9cecb91
AD
34592001-12-29 Akim Demaille <akim@epita.fr>
3460
3461 * src/output.c (header_output): Don't forget to export YYLTYPE and
3462 yylloc.
3463 * tests/headers.at (export YYLTYPE): New, make sure it does.
3464 * tests/regression.at (%union and --defines, Invalid CPP headers):
3465 Move to...
3466 * tests/headers.at: here.
3467
aea13e97
AD
34682001-12-29 Akim Demaille <akim@epita.fr>
3469
3470 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3471
931394cb
AD
34722001-12-29 Akim Demaille <akim@epita.fr>
3473
3474 * tests/actions.at (Mid-rule actions): Output on a single line
3475 instead of several.
3476
704a47c4
AD
34772001-12-29 Akim Demaille <akim@epita.fr>
3478
3479 * doc/bison.texinfo: Formatting changes.
3480
091e20bb
AD
34812001-12-29 Akim Demaille <akim@epita.fr>
3482
3483 Don't store the token defs in a muscle, just be ready to output it
3484 on command. Now possible via `symbols'. Fixes a memory leak.
3485
3486 * src/output.c (token_definitions_output): New.
3487 (output_parser, header_output): Use it.
3488 * src/reader.c (symbols_save): Remove.
3489
cce71710
AD
34902001-12-29 Akim Demaille <akim@epita.fr>
3491
3492 * src/bison.simple: Do not provide a default for YYSTYPE and
3493 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3494 default.
3495
82c035a8
AD
34962001-12-29 Akim Demaille <akim@epita.fr>
3497
3498 Mid-rule actions are simply... ignored!
3499
3500 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3501 the empty-rule associated to the dummy symbol, not to the host
3502 rule.
3503 * tests/actions.at (Mid-rule actions): New.
3504
8419d367
AD
35052001-12-29 Akim Demaille <akim@epita.fr>
3506
3507 Memory leak.
3508
3509 * src/reader.c (reader): Free grammar.
3510
375d5806
AD
35112001-12-29 Akim Demaille <akim@epita.fr>
3512
3513 Memory leak.
3514
3515 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
3516 since it allocates it for each state, although only one is needed.
3517 (allocate_storage): Do it here.
3518
f51cb8ff
AD
35192001-12-29 Akim Demaille <akim@epita.fr>
3520
3521 * src/options.h, src/options.c (create_long_option_table): Rename
3522 as...
3523 (long_option_table_new): this, with a clearer prototype.
3524 (percent_table): Remove, unused,
3525 * src/getargs.c (getargs): Adjust.
3526
29e88316
AD
35272001-12-29 Akim Demaille <akim@epita.fr>
3528
3529 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
3530 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
3531 as states.
3532
b9f71f19
AD
35332001-12-29 Akim Demaille <akim@epita.fr>
3534
3535 * src/lalr.c (build_relations): Rename `states' as `states1'.
3536 Sorry, I don't understand exactly what it is, no better name...
3537
1a2b5d37
AD
35382001-12-29 Akim Demaille <akim@epita.fr>
3539
3540 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
3541 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
3542 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
3543 as rules.
3544
1cca533e
AD
35452001-12-29 Akim Demaille <akim@epita.fr>
3546
3547 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
3548 ago.
3549
c03ae966
AD
35502001-12-29 Akim Demaille <akim@epita.fr>
3551
3552 * src/reader.c, src/reader.h (user_toknums): Remove.
3553 Adjust all users to use symbols[i]->user_token_number.
3554
5a670b1e
AD
35552001-12-29 Akim Demaille <akim@epita.fr>
3556
3557 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
3558 Adjust all users to use symbols[i]->prec or ->assoc.
3559
ad949da9
AD
35602001-12-29 Akim Demaille <akim@epita.fr>
3561
3562 * src/reader.c, src/reader.h (tags): Remove.
3563 Adjust all users to use symbols[i]->tag.
3564
0e78e603
AD
35652001-12-29 Akim Demaille <akim@epita.fr>
3566
3567 * src/gram.h, src/gram.c (symbols): New, similar to state_table
3568 and rule_table.
3569 * src/reader.c (packsymbols): Fill this table.
3570 Drop sprec.
3571 * src/conflicts.c (resolve_sr_conflict): Adjust.
3572 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
3573 single table.
3574 Use symbols[i]->tag instead of tags[i].
3575
213e640e
AD
35762001-12-29 Akim Demaille <akim@epita.fr>
3577
3578 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
3579 In addition, put a comment in there, to replace...
3580 * tests/regression.at (%union and C comments): Remove.
3581
e7b8bef1
AD
35822001-12-29 Akim Demaille <akim@epita.fr>
3583
3584 * tests/regression.at (Web2c Actions): Blindly move the actual
3585 output as expected output. The contents *seem* right to me, but I
3586 can't pretend reading perfectly parser tables... Nonetheless, all
3587 the other tests pass correctly, the table look OK, even though the
3588 presence of `$axiom' is to be noted: AFAICS it is useless (but
3589 harmless).
3590
b68e7744
AD
35912001-12-29 Akim Demaille <akim@epita.fr>
3592
3593 * src/reader.c (readgram): Don't add the rule 0 if there were no
3594 rules read. In other words, add it _after_ having performed
3595 grammar sanity checks.
3596 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
3597
78d5bae9
AD
35982001-12-29 Akim Demaille <akim@epita.fr>
3599
3600 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
3601 visible, and some states have now a different number.
3602
ff442794
AD
36032001-12-29 Akim Demaille <akim@epita.fr>
3604
3605 * src/reader.c (readgram): Bind the initial rule's lineno to that
3606 of the first rule.
3607 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
3608 (Solved SR Conflicts): Adjust rule 0's line number.
3609
610ab194
AD
36102001-12-29 Akim Demaille <akim@epita.fr>
3611
3612 Fix the `GAWK Grammar' failure.
3613
3614 * src/LR0.c (final_state): Initialize to -1 so that we do compute
3615 the reductions of the first state which was mistakenly confused
3616 with the final state because precisely final_state was initialized
3617 to 0.
3618 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
3619 now noticed by Bison.
3620 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
3621 have a reduction on $default.
3622
29d29c8f
AD
36232001-12-29 Akim Demaille <akim@epita.fr>
3624
3625 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
3626 rule line numbers.
3627 * src/closure.c (print_closure): Likewise.
3628 * src/derives.c (print_derives): Likewise.
3629 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
3630 now.
3631
7c6b64d0
AD
36322001-12-29 Akim Demaille <akim@epita.fr>
3633
3634 * src/lalr.c (lookaheads_print): New.
3635 (lalr): Call it when --trace-flag.
3636 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
3637 are dumped.
3638
3d4daee3
AD
36392001-12-29 Akim Demaille <akim@epita.fr>
3640
3641 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
3642 when walking through ritem, even via rule->rhs.
3643 * src/reduce.c (dump_grammar, useful_production, reduce_output)
3644 (useful_production, useless_nonterminals): Likewise.
3645 (reduce_grammar_tables): Likewise, plus update nritems.
3646 * src/nullable.c (set_nullable): Likewise.
3647 * src/lalr.c (build_relations): Likewise.
3648 * tests/sets.at (Nullable): Adjust.
3649 Fortunately, now, the $axiom is no longer nullable.
3650
9e7f6bbd
AD
36512001-12-29 Akim Demaille <akim@epita.fr>
3652
3653 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
3654 the 0-sentinel.
3655 * src/gram.c (ritem_longest_rhs): Likewise.
3656 * src/reduce.c (nonterminals_reduce): Likewise.
3657 * src/print_graph.c (print_graph): Likewise.
3658 * src/output.c (output_rule_data): Likewise.
3659 * src/nullable.c (set_nullable): Likewise.
3660
255ef638
AD
36612001-12-29 Akim Demaille <akim@epita.fr>
3662
3663 * src/output.c: Comment changes.
3664
0d8a7363
AD
36652001-12-27 Paul Eggert <eggert@twinsun.com>
3666
3667 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
3668 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
3669 Sparc, as they were causing more porting problems than the
3670 (minor) performance improvement was worth.
3671
3672 Also, catch up with 1.31's YYSTD.
3673
3db472b9
AD
36742001-12-27 Akim Demaille <akim@epita.fr>
3675
3676 * src/output.c (output_gram): Rely on nritems, not the
3677 0-sentinel. See below.
3678 Use -1 as separator, not 0.
3679 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
3680 Rely on -1 as separator in yyrhs, instead of 0.
3681 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
3682 twice `Now at end of input', therefore there are two lines less to
3683 expect.
3684
b365aa05
AD
36852001-12-27 Akim Demaille <akim@epita.fr>
3686
3687 * tests/regression.at (Unresolved SR Conflicts):
3688 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
3689 below.
3690
30171f79
AD
36912001-12-27 Akim Demaille <akim@epita.fr>
3692
3693 * src/LR0.c (new_state): Recognize the final state by the fact it
3694 is reached by eoftoken.
3695 (insert_start_shifting_state, insert_eof_shifting_state)
3696 (insert_accepting_state, augment_automaton): Remove, since now
3697 these states are automatically computed from the initial state.
3698 (generate_states): Adjust.
3699 * src/print.c: When reporting a rule number to the user, substract
3700 1, so that the axiom rule is rule 0, and the first user rule is 1.
3701 * src/reduce.c: Likewise.
3702 * src/print_graph.c (print_core): For the time being, just as for
3703 the report, depend upon --trace-flags to dump the full set of
3704 items.
3705 * src/reader.c (readgram): Once the grammar read, insert the rule
3706 0: `$axiom: START-SYMBOL $'.
3707 * tests/set.at: Adjust: rule 0 is now displayed, and since the
3708 number of the states has changed (the final state is no longer
3709 necessarily the last), catch up.
3710
75142d45
AD
37112001-12-27 Akim Demaille <akim@epita.fr>
3712
3713 Try to make the use of the eoftoken valid. Given that its value
3714 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
3715 is used instead of > 0 where appropriate, (ii), depend upon nritems
3716 instead of the 0-sentinel.
3717
3718 * src/gram.h, src/gram.c (nritems): New.
3719 Expected to be duplication of nitems, but for the time being...
3720 * src/reader.c (packgram): Assert nritems and nitems are equal.
3721 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
3722 * src/closure.c (print_closure, print_fderives): Likewise.
3723 * src/gram.c (ritem_print): Likewise.
3724 * src/print.c (print_core, print_grammar): Likewise.
3725 * src/print_graph.c: Likewise.
3726
b7c49edf
AD
37272001-12-27 Akim Demaille <akim@epita.fr>
3728
3729 * src/main.c (main): If there are complains after grammar
3730 reductions, then output the report anyway if requested, then die.
3731 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
3732 * src/reader.c (eoftoken): New.
3733 (parse_token_decl): If the token being defined has value `0', it
3734 is the eoftoken.
3735 (packsymbols): No longer hack `tags' to insert `$' by hand.
3736 Be sure to preserve the value of the eoftoken.
3737 (reader): Make sure eoftoken is defined.
3738 Initialize nsyms to 0: now eoftoken is created just like the others.
3739 * src/print.c (print_grammar): Don't special case the eof token.
3740 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
3741 lie anyway, albeit pleasant.
3742 * tests/calc.at: Exercise error messages with eoftoken.
3743 Change the grammar so that empty input is invalid.
3744 Adjust expectations.
3745 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
3746
ec2da99f
AD
37472001-12-27 Akim Demaille <akim@epita.fr>
3748
3749 * configure.in: Check the protos of strchr ans strspn.
3750 Replace strchr if needed.
3751 * src/system.h: Provide the protos of strchr, strspn and memchr if
3752 missing.
3753 * lib/strchr.c: New.
3754 * src/reader.c (symbols_save): Use strchr.
3755
8adfa272
AD
37562001-12-27 Akim Demaille <akim@epita.fr>
3757
3758 * src/print.c, src/print_graph.c (escape): New.
3759 Use it to quote the TAGS outputs.
3760 * src/print_graph.c (print_state): Now errors are in red, and
3761 reductions in green.
3762 Prefer high to wide: output the state number on a line of its own.
3763
80dac38c
AD
37642001-12-27 Akim Demaille <akim@epita.fr>
3765
3766 * src/state.h, src/state.c (reductions_new): New.
3767 * src/LR0.c (set_state_table): Let all the states have a
3768 `reductions', even if reduced to 0.
3769 (save_reductions): Adjust.
3770 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
3771 * src/print.c (print_reductions, print_actions): Adjust.
3772 * src/output.c (action_row): Adjust.
3773
2cec70b9
AD
37742001-12-27 Akim Demaille <akim@epita.fr>
3775
3776 * src/state.h, src/state.c (errs_new, errs_dup): New.
3777 * src/LR0.c (set_state_table): Let all the states have an errs,
3778 even if reduced to 0.
3779 * src/print.c (print_errs, print_reductions): Adjust.
3780 * src/output.c (output_actions, action_row): Adjust.
3781 * src/conflicts.c (resolve_sr_conflict): Adjust.
3782
13ca549a
AD
37832001-12-27 Akim Demaille <akim@epita.fr>
3784
3785 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
3786
5092aba5
AD
37872001-12-27 Akim Demaille <akim@epita.fr>
3788
3789 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
3790 * src/print.c: here.
3791 (lookaheadset, shiftset): New, used as additional storage by
3792 print_reductions.
3793 (print_results): Adjust.
3794 (print_shifts, print_gotos, print_errs): New, extracted from...
3795 (print_actions): here.
3796 * src/print_graph.c (print_actions): Remove dead code.
3797
11e2beca
AD
37982001-12-27 Akim Demaille <akim@epita.fr>
3799
3800 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
3801 `$n' and `@n'.
3802
dac3c910
AD
38032001-12-27 Akim Demaille <akim@epita.fr>
3804
3805 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
3806 (build_relations): Adjust.
3807
d0b0fefa
AD
38082001-12-27 Akim Demaille <akim@epita.fr>
3809
3810 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
3811 duplication.
3812
adc8c848
AD
38132001-12-27 Akim Demaille <akim@epita.fr>
3814
3815 * src/reader.c (packgram): Catch nitems overflows.
3816
14d293ac
AD
38172001-12-27 Akim Demaille <akim@epita.fr>
3818
3819 * src/files.c, src/files.h (guard_obstack): Remove.
3820 * src/output.c (output): Adjust.
3821 * src/reader.c (parse_braces): New, factoring...
3822 (copy_action, copy_guard): these two which are renamed as...
3823 (parse_action, parse_guard): these.
3824 As a voluntary consequence, using braces around guards is now
3825 mandatory.
3826
f499b062
AD
38272001-12-27 Akim Demaille <akim@epita.fr>
3828
3829 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3830 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3831 members.
3832 (symbol_list_new): Adjust.
3833 (copy_action): action_line is the first line, not the last.
3834 (copy_guard): Just as for actions, store the `action' only, not
3835 the switch/case/break flesh.
3836 Don't parse the user action that might follow the guard, let...
3837 (readgram): do it, i.e., now, there can be an action after a
3838 guard.
3839 In other words the guard is just explicitly optional.
3840 (packgram): Adjust.
3841 * src/output.c (guards_output): New.
3842 (output_parser): Call it when needed.
3843 (output): Also free the guard and attrs obstacks.
3844 * src/files.c, src/files.h (obstack_save): Remove.
3845 (output_files): Remove.
3846 As a result, if one needs the former `.act' file, using an
3847 appropriate skeleton which requires actions and guards is now
3848 required.
3849 * src/main.c (main): Adjust.
3850 * tests/semantic.at: New.
3851 * tests/regression.at: Use `input.y' as input file name.
3852 Avoid 8+3 problems by requiring input.c when the test needs the
3853 parser.
3854
d945f5cd
AD
38552001-12-27 Akim Demaille <akim@epita.fr>
3856
3857 * src/reader.c (symbol_list_new): Be sure to initialize all the
3858 fields.
3859
d200e455
AD
38602001-12-27 Akim Demaille <akim@epita.fr>
3861
3862 All the hacks using a final pseudo state are now useless.
3863
3864 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3865 * src/lalr.c (nLA): New.
3866 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3867 instead of lookaheadsp from the pseudo state (nstate + 1).
3868
f9507c28
AD
38692001-12-27 Akim Demaille <akim@epita.fr>
3870
3871 * src/output.c (action_row, token_actions): Use a state_t instead
3872 of a integer, and nlookaheads instead of the following state's
3873 lookaheadsp.
3874
065fbd27
AD
38752001-12-27 Akim Demaille <akim@epita.fr>
3876
3877 * src/conflicts.c (log_resolution, flush_shift)
3878 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3879 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3880 (conflicts_print, print_reductions): Use a state_t instead of an
3881 integer when referring to a state.
3882 As much as possible, depend upon nlookaheads, instead of the
3883 `lookaheadsp' member of the following state (since lookaheads of
3884 successive states are successive, the difference between state n + 1
3885 and n served as the number of lookaheads for state n).
3886 * src/lalr.c (add_lookback_edge): Likewise.
3887 * src/print.c (print_core, print_actions, print_state)
3888 (print_results): Likewise.
3889 * src/print_graph.c (print_core, print_actions, print_state)
3890 (print_graph): Likewise.
3891 * src/conflicts.h: Adjust.
3892
1b177bd7
AD
38932001-12-27 Akim Demaille <akim@epita.fr>
3894
3895 * src/bison.hairy: Formatting/comment changes.
3896 ANSIfy.
3897 Remove `register' indications.
3898 Add plenty of `static'.
3899
7742ddeb
AD
39002001-12-27 Akim Demaille <akim@epita.fr>
3901
3902 * src/output.c (prepare): Drop the muscle `ntbase' which
3903 duplicates ntokens.
3904 * src/bison.simple: Formatting/comment changes.
3905 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3906 is an undocumented synonym.
3907
1fa14068
AD
39082001-12-22 Akim Demaille <akim@epita.fr>
3909
3910 * src/output.c (output_table_data): Change the prototype to use
3911 `int' for array ranges: some invocations do pass an int, not a
3912 short.
3913 Reported by Wayne Green.
3914
b9752825
AD
39152001-12-22 Akim Demaille <akim@epita.fr>
3916
3917 Some actions of web2c.y are improperly triggered.
3918 Reported by Mike Castle.
3919
3920 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3921 * tests/regression.at (Web2c): Rename as...
3922 (Web2c Report): this.
3923 (Web2c Actions): New.
3924
776209d6
AD
39252001-12-22 Akim Demaille <akim@epita.fr>
3926
3927 Reductions in web2c.y are improperly reported.
3928 Reported by Mike Castle.
3929
3930 * src/conflicts.c (print_reductions): Fix.
3931 * tests/regression.at (Web2c): New.
3932
275fc3ad
AD
39332001-12-18 Akim Demaille <akim@epita.fr>
3934
3935 Some host fail on `assert (!"foo")', which expands to
3936 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3937 Reported by Nelson Beebee.
3938
3939 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3940 `#define it_succeeded 0' and `assert (it_succeeded)'.
3941
897668ee
MA
39422001-12-17 Marc Autret <autret_m@epita.fr>
3943
3944 * src/bison.simple: Don't hard code the skeleton line and filename.
3945 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3946 New line counter 'skeleton_line' (skeleton-line muscle).
3947
ab3399e0
PE
39482001-12-17 Paul Eggert <eggert@twinsun.com>
3949
3950 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3951 YYDEBUG must be defined to a nonzero value.
3952
3953 * src/bison.simple (yytname): Do not assume that the user defines
3954 YYDEBUG to a properly parenthesized expression.
3955
3877f72b
AD
39562001-12-17 Akim Demaille <akim@epita.fr>
3957
3958 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3959 nlookaheads is a new member.
3960 Adjust all users.
3961 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3962 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3963 state.
776209d6 3964
331dbc1b
AD
39652001-12-17 Akim Demaille <akim@epita.fr>
3966
3967 * src/files.h, src/files.c (open_files, close_files): Remove.
3968 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3969 let...
3970 * src/reader.c (reader): Do it.
776209d6 3971
be750e4c
AD
39722001-12-17 Akim Demaille <akim@epita.fr>
3973
3974 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 3975
709ae8c6
AD
39762001-12-17 Akim Demaille <akim@epita.fr>
3977
3978 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3979 (flush_reduce): New.
3980 (resolve_sr_conflict): Adjust.
776209d6 3981
f87685c3
AD
39822001-12-17 Akim Demaille <akim@epita.fr>
3983
3984 * src/output.c (output_obstack): Be static and rename as...
3985 (format_obstack): this, to avoid any confusion with files.c's
3986 output_obstack.
3987 * src/reader.h (muscle_obstack): Move to...
3988 * src/output.h: here, since it's defined in output.c.
3989
837491d8
AD
39902001-12-17 Akim Demaille <akim@epita.fr>
3991
3992 * src/output.c (action_row, save_column, default_goto)
3993 (sort_actions, matching_state, pack_vector): Better variable
3994 locality.
3995
796d61fb
AD
39962001-12-17 Akim Demaille <akim@epita.fr>
3997
3998 * src/output.c: Various formatting changes.
776209d6 3999
64d15509
AD
40002001-12-17 Akim Demaille <akim@epita.fr>
4001
4002 * src/files.c (output_files): Free the output_obstack.
4003 * src/main.c (main): Call print and print_graph conditionally.
4004 * src/print.c (print): Work unconditionally.
4005 * src/print_graph.c (print_graph): Work unconditionally.
4006 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4007
fbc8ecb7
MA
40082001-12-16 Marc Autret <autret_m@epita.fr>
4009
4010 * src/output.c (actions_output): Fix. When we use %no-lines,
4011 there is one less line per action.
4012
f0440388
MA
40132001-12-16 Marc Autret <autret_m@epita.fr>
4014
4015 * src/bison.simple: Remove a useless #line directive.
4016 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4017 * src/output.c (get_lines_number): New.
776209d6 4018 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
4019 output muscles.
4020 Fix line numbering.
4021 (actions_output): Computes the number of lines taken by actions.
4022 (output_master_parser): Insert new skeleton which is the name of
4023 the output parser file name.
4024
a79986b8
MA
40252001-12-15 Marc Autret <autret_m@epita.fr>
4026
4027 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4028
4ec8e00f
MA
40292001-12-15 Marc Autret <autret_m@epita.fr>
4030
4031 * src/output.c (output_gram): Keep track of the hairy one.
4032
1a4648ff
AD
40332001-12-15 Akim Demaille <akim@epita.fr>
4034
4035 Make `make distcheck' work.
4036
4037 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4038 system.h which uses libgettext.h.
4039
9c2c67e6
AD
40402001-12-15 Akim Demaille <akim@epita.fr>
4041
4042 * src/nullable.c (set_nullable): Useless rules must be skipped,
4043 otherwise, since we range over their symbols, we might look at a
4044 nonterminal which no longer ``exists'', i.e., it is not counted in
4045 `nvars', hence we overflow our arrays.
4046
93ede233
AD
40472001-12-15 Akim Demaille <akim@epita.fr>
4048
4049 The header can also be produced directly, without any obstack!
4050 Yahoo!
4051
4052 * src/files.c, src/files.h (defines_obstack): Remove.
4053 (compute_header_macro): Global.
4054 (defines_obstack_save): Remove.
4055 * src/reader.c (parse_union_decl): No longer output to
4056 defines_obstack: its content can be found in the `stype' muscle
4057 anyway.
4058 (output_token_translations): Merge into...
4059 (symbols_output): this.
4060 Rename as...
4061 (symbols_save): this.
4062 (reader): Adjust.
4063 * src/output.c (header_output): New.
4064 (output): Call it.
4065
2666f928
AD
40662001-12-15 Akim Demaille <akim@epita.fr>
4067
4068 * src/reader.c (parse_union_decl): Instead of handling two obstack
4069 simultaneously, use one to define the `stype' muscle, and use the
4070 value of the latter to fill defines_obstack.
4071 (copy_comment): Remove.
4072 (copy_comment2): Work for a single obstack.
4073 Rename as...
4074 (copy_comment): this.
4075
428046f8
AD
40762001-12-15 Akim Demaille <akim@epita.fr>
4077
4078 * src/lex.c, src/lex.h (xgetc): No longer static.
4079 * src/reader.c (parse_union_decl): Revamp.
4080
ea52d706
AD
40812001-12-15 Akim Demaille <akim@epita.fr>
4082
4083 Still making progress in separating Bison into (i) input, (ii)
4084 process, (iii) output: now we can directly output the parser file
4085 without using table_obstack at all.
4086
4087 * src/files.c, src/files.h (table_obstack): Bye bye.
4088 (parser_file_name): New.
4089 * src/files.c (compute_output_file_names): Compute it.
4090 * src/output.c (actions_output, output_parser)
4091 (output_master_parser): To a file instead of an obstack.
4092
3f96f4dc
AD
40932001-12-15 Akim Demaille <akim@epita.fr>
4094
4095 Attach actions to rules, instead of pre-outputting them to
4096 actions_obstack.
4097
4098 * src/gram.h (rule_t): action and action_line are new members.
4099 * src/reader.c (symbol_list): Likewise.
4100 (copy_action): Save the actions within the rule.
4101 (packgram): Save them in rule_table.
4102 * src/output.c (actions_output): New.
4103 (output_parser): Use it on `%%actions'.
4104 (output_rule_data): Don't free rule_table.
4105 (output): Do it.
4106 (prepare): Don't save the `action' muscle.
4107 * src/bison.simple: s/%%action/%%actions/.
4108
51576fb3
AD
41092001-12-15 Akim Demaille <akim@epita.fr>
4110
4111 * src/reader.c (copy_action): When --yacc, don't append a `;'
4112 to the user action: let it fail if lacking.
dee049eb 4113 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 4114
2648a72d
AD
41152001-12-14 Akim Demaille <akim@epita.fr>
4116
4117 * src/lex.c (literalchar): Simply return the char you decoded, non
4118 longer mess around with obstacks and int pointers.
4119 Adjust all callers.
4120
92790e5b
AD
41212001-12-14 Akim Demaille <akim@epita.fr>
4122
4123 * src/lex.c (literalchar): Don't escape the special characters,
4124 just decode them, and keep them as char (before, eol was output as
4125 the 2 char string `\n' etc.).
4126 * src/output.c (output_rule_data): Use quotearg to output the
4127 token strings.
4128
927c1557
PE
41292001-12-13 Paul Eggert <eggert@twinsun.com>
4130
4131 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4132 Do not infringe on the global user namespace when using C++.
4133 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4134 All uses of `fprintf' and `stderr' changed.
4135
4136 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4137
ed8e1f68
AD
41382001-12-13 Akim Demaille <akim@epita.fr>
4139
4140 The computation of nullable is broken: it doesn't handle empty
4141 RHS's properly.
4142
4143 * tests/torture.at (GNU AWK Grammar): New.
4144 * tests/sets.at (Nullable): New.
4145 * src/nullable.c (set_nullable): Instead of blindly looping over
4146 `ritems', loop over the rules, and then over their rhs's.
4147
4148 Work around Autotest bugs.
4149
4150 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4151 frame, because Autotest understand lines starting with a `+' as
4152 traces from the shell. Then, they are not processed properly.
4153 Admittedly an Autotest bug, but we don't have time to wait for
4154 Autotest to catch up.
4155 * tests/regression.at (Broken Closure): Adjust to the new table
4156 frames.
4157 Move to...
4158 * tests/sets.at: here.
4159
cb581495
AD
41602001-12-13 Akim Demaille <akim@epita.fr>
4161
4162 * src/closure.c (closure): Use nrules instead of playing tricks
4163 with BITS_PER_WORD.
4164
2e729273
AD
41652001-12-13 Akim Demaille <akim@epita.fr>
4166
4167 * src/print.c (print_actions): Output the handling of `$' as the
4168 traces do: shifting the token EOF. Before EOF was treated as a
4169 nonterminal.
4170 * tests/regression.at: Adjust some tests.
4171 * src/print_graph.c (print_core): Complete the set of items via
4172 closure. The next-to-final and final states are still unsatisfying,
4173 but that's to be addressed elsewhere.
4174 No longer output the rule numbers, but do output the state number.
4175 A single loop for the shifts + gotos is enough, but picked a
4176 distinct color for each.
4177 (print_graph): Initialize and finalize closure.
4178
107f7dfb
AD
41792001-12-13 Akim Demaille <akim@epita.fr>
4180
4181 * src/reader.c (readgram): Remove dead code, an strip useless
4182 braces.
4183 (get_type): Remove, unused.
4184
9b53a24f
AD
41852001-12-12 Akim Demaille <akim@epita.fr>
4186
4187 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4188 on that of lib/error.c.
4189
dbfb6dcd
AD
41902001-12-12 Akim Demaille <akim@epita.fr>
4191
4192 Some hosts don't like `/' in includes.
4193
4194 * src/system.h: Include libgettext.h without qualifying the path.
4195 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4196 $(top_srcdir).
4197
c25fb648
MA
41982001-12-11 Marc Autret <autret_m@epita.fr>
4199
4200 * src/output.c (output_parser): Remove useless muscle.
4201
710ddc4f
MA
42022001-12-11 Marc Autret <autret_m@epita.fr>
4203
4204 * src/bison.simple: Remove #line just before %%epilogue. It
4205 is now handled in ...
4206 * src/reader.c (read_additionnal_code): Add the output of a
4207 #line for the epilogue.
4208
e83d80b8
MA
42092001-12-10 Marc Autret <autret_m@epita.fr>
4210
927c1557 4211 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
4212 replace precedent remove.
4213 * src/bison.simple: Remove #line before %%prologue because
4214 %%input-line is wrong at this time.
4215
971d5158
MA
42162001-12-10 Marc Autret <autret_m@epita.fr>
4217
4218 * src/reader.c (symbols_output): Clean up.
927c1557 4219 * src/output.c (output_gram, output): Clean up.
971d5158 4220
5edafffd
AD
42212001-12-10 Akim Demaille <akim@epita.fr>
4222
4223 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4224 * src/LR0.c (set_state_table): here.
4225 * src/lalr.c (lalr): Call it.
4226
0279f8e9
AD
42272001-12-10 Akim Demaille <akim@epita.fr>
4228
4229 * src/state.h (shifts): Remove the `number' member: shifts are
4230 attached to state, hence no longer need to be labelled with a
4231 state number.
4232
190c4f5f
AD
42332001-12-10 Akim Demaille <akim@epita.fr>
4234
4235 Now that states have a complete set of members, the linked list of
4236 shifts is useless: just fill directly the state's shifts member.
4237
4238 * src/state.h (shifts): Remove the `next' member.
4239 * src/LR0.c (first_state, last_state): Remove.
4240 Adjust the callers.
4241 (augment_automaton): Don't look for the shifts that must be added
4242 a shift on EOF: it is those of the state we looked for! But now,
4243 since shifts are attached, it is no longer needed to looking
4244 merely by its id: its number.
4245
2a73b93d
AD
42462001-12-10 Akim Demaille <akim@epita.fr>
4247
4248 * src/LR0.c (augment_automaton): Better variable locality.
4249 Remove an impossible branch: if there is a state corresponding to
4250 the start symbol being shifted, then there is shift for the start
4251 symbol from the initial state.
4252
74392f6a
AD
42532001-12-10 Akim Demaille <akim@epita.fr>
4254
4255 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4256 only when appropriate: when insert_start_shifting_state' is not
4257 invoked.
4258 * tests/regression.at (Rule Line Numbers): Adjust.
4259
37c82725
AD
42602001-12-10 Akim Demaille <akim@epita.fr>
4261
4262 * src/LR0.c (augment_automaton): Now that all states have shifts,
4263 merge the two cases addition shifts to the initial state.
4264
6a164e0c
AD
42652001-12-10 Akim Demaille <akim@epita.fr>
4266
4267 * src/lalr.c (set_state_table): Move to...
4268 * src/LR0.c: here.
4269 * src/lalr.c (lalr): Don't call it...
4270 * src/LR0.c (generate_states): do it.
4271 * src/LR0.h (first_state): Remove, only the table is used.
4272
7215de24
AD
42732001-12-10 Akim Demaille <akim@epita.fr>
4274
4275 * src/LR0.h (first_shift, first_reduction): Remove.
4276 * src/lalr.c: Don't use first_shift: find shifts through the
4277 states.
4278
80e25d4d
AD
42792001-12-10 Akim Demaille <akim@epita.fr>
4280
4281 * src/LR0.c: Attach shifts to states as soon as they are
4282 computed.
4283 * src/lalr.c (set_state_table): Instead of assigning shifts to
4284 state, just assert that the mapping was properly done.
4285
0ab3728b
AD
42862001-12-10 Akim Demaille <akim@epita.fr>
4287
4288 * src/LR0.c (insert_start_shift): Rename as...
4289 (insert_start_shifting_state): this.
4290 (insert_eof_shifting_state, insert_accepting_state): New.
4291 (augment_automaton): Adjust.
4292 Better locality of the variables.
4293 When looking if the start_symbol is shifted from the initial
4294 state, using `while (... symbol != start_symbol ...)' sounds
4295 better than `while (... symbol < start_symbol ...)': If fail
4296 to see how the order between symbols could be relevant!
4297
78af9bbc
AD
42982001-12-10 Akim Demaille <akim@epita.fr>
4299
4300 * src/getargs.h: Don't declare `spec_name_prefix' and
4301 `spec_file_prefix', declared by src/files.h.
4302 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4303 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4304 * src/output.c (prepare): Adjust.
4305 * src/reader.c (symbols_output): Likewise.
4306 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4307
bdef2a41
AD
43082001-12-10 Akim Demaille <akim@epita.fr>
4309
4310 * src/muscle_tab.c (muscle_init): NULL is a better default than
4311 `"0"'.
4312
3735969c
AD
43132001-12-10 Akim Demaille <akim@epita.fr>
4314
4315 * src/reader.c (reader): Calling symbols_output once is enough.
4316
49701457
AD
43172001-12-10 Akim Demaille <akim@epita.fr>
4318
4319 Now that states have a complete set of members, the linked list of
4320 reductions is useless: just fill directly the state's reductions
4321 member.
4322
4323 * src/state.h (struct reductions): Remove member `number' and
4324 `next'.
4325 * src/LR0.c (first_reduction, last_reduction): Remove.
4326 (save_reductions): Don't link the new reductions, store them in
4327 this_state.
4328 * src/lalr.c (set_state_table): No need to attach reductions to
4329 states, it's already done.
4330 * src/output.c (output_actions): No longer free the shifts, then
4331 the reductions, then the states: free all the states and their
4332 members.
4333
0edad749
AD
43342001-12-10 Akim Demaille <akim@epita.fr>
4335
4336 * src/options.c (OPTN, DRTV, BOTH): New.
4337 (option_table): Use them.
4338
0edad749
AD
4339 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4340 the job of system.h.
4341 * src/options.c: Don't include stdio.h and xalloc.h for the same
4342 reasons.
4343
5449dd0f
AD
43442001-12-10 Akim Demaille <akim@epita.fr>
4345
4346 * src/output.c (output, prepare): Make sure the values of the
4347 muscles `action' and `prologue' are 0-terminated.
4348
a870c567
AD
43492001-12-10 Akim Demaille <akim@epita.fr>
4350
4351 Clean up GCC warnings.
4352
4353 * src/reader.c (copy_action): `buf' is not used.
4354 (parse_skel_decl): Be static.
4355 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4356 * src/options.h (create_long_option_table): Have a real prototype.
4357 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4358 (hash_delete_at): Return const void *.
4359 Adjust casts to preserve the const.
4360
80df8768
AD
43612001-12-10 Akim Demaille <akim@epita.fr>
4362
4363 * configure.in: Require 2.52g.
4364 M4 is not needed, but AUTOM4TE is.
4365 * m4/m4.m4: Remove.
4366 * tests/Makefile.am: Adjust.
4367
f693ad14
AD
43682001-12-10 Akim Demaille <akim@epita.fr>
4369
4370 One structure for states is enough, even though theoretically
4371 there are LR(0) states and LALR(1) states.
4372
4373 * src/lalr.h (state_t): Remove.
4374 (state_table): Be state_t **, not state_t *.
4375 * src/state.h (core, CORE_ALLOC): Rename as...
4376 (state_t, STATE_ALLOC): this.
4377 Add the LALR(1) members: shifts, reductions, errs.
4378 * src/LR0.c (state_table): Rename as...
4379 (state_hash): this, to avoid name clashes with the global
4380 `state_table'.
4381 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4382 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4383
74ffbcb6
AD
43842001-12-10 Akim Demaille <akim@epita.fr>
4385
4386 Bison dumps core on bash.y.
4387 Reported by Pascal Bart.
4388
4389 * src/warshall.c (bitmatrix_print): New.
4390 (TC): Use it.
4391 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4392 j must be the outer loop.
4393 * tests/regression.at (Broken Closure): New.
4394
07708e19
AD
43952001-12-05 Akim Demaille <akim@epita.fr>
4396
4397 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4398 its argument.
4399