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