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