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