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