]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
Version 1.50.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-10-04 Paul Eggert <eggert@twinsun.com>
2
3 Version 1.50.
4
5 * configure.ac (AC_INIT), NEWS: Increment version number.
6
7 * doc/bison.texinfo: Minor spelling, grammar, and white space
8 fixes.
9 (Symbols): Mention that any negative value returned from yylex
10 signifies end-of-input. Warn about negative chars. Mention
11 the portable Standard C character set.
12
13 The GNU coding standard says CFLAGS and YFLAGS are reserved
14 for the installer to set.
15 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
16 * src/Makefile.am (AM_CFLAGS): Likewise.
17 (AM_YFLAGS): Renamed from YFLAGS.
18
19 Fix some MAX and MIN problems.
20 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
21 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
22 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
23 * src/reader.c (reader): Use it.
24
25 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
26 POSIX 1003.1-2001 has removed fgrep.
27
282002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
29
30 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
31 interpreted as signed.
32 * lib/ebitset.c (ebitset_list): Fix bug.
33
342002-10-01 Paul Eggert <eggert@twinsun.com>
35
36 More fixes for 64-bit hosts and large bitsets.
37
38 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
39 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
40 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
41 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
42 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
43 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
44 bitset_count_): Likewise.
45 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
46 bitset_first, bitset_last): Likewise.
47 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
48 bitset_stats_list_reverse, bitset_stats_size,
49 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
50 Likewise.
51 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
52 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
53 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
54 bitsetv_reflexive_transitive_closure): Likewise.
55 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
56 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
57 Likewise.
58 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
59 Likewise.
60
61 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
62 Use size_t, not unsigned int, to count bytes.
63 * lib/abitset.h (abitset_bytes): Likewise.
64 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
65 Likewise.
66 * lib/bitset.h (bitset_bytes): Likewise.
67 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
68 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
69 * lib/bitsetv.c (bitsetv_alloc): Likewise.
70 * lib/ebitset.c (ebitset_bytes): Likewise.
71 * lib/ebitset.h (ebitset_bytes): Likewise.
72 * lib/lbitset.c (lbitset_bytes): Likewise.
73 * lib/lbitset.h (lbitset_bytes): Likewise.
74
75 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
76 abitset_subset_p, abitset_disjoint_p, abitset_and,
77 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
78 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
79 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
80 abitset_or_and, abitset_or_and_cmp):
81 Use bitset_windex instead of unsigned int.
82 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
83 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
84 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
85 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
86 Likewise.
87 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
88
89 * lib/bitset.c (bitset_print):
90 Use proper printf formats for widths of integer types.
91 * lib/bitset_stats.c (bitset_percent_histogram_print,
92 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
93 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
94 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
95 * lib/lbitset.c (lbitset_bytes): Likewise.
96
97 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
98 BITSET_SIZE_MAX): New macros.
99 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
100 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
101 to BITSET_WINDEX_MAX.
102
103 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
104 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
105 since we now return the bitset_bindex type (not int).
106
107 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
108 when computing sizes.
109 * lib/ebitset.c (ebitset_elts_grow): Likewise.
110
111 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
112 and avoid cast to unsigned.
113
1142002-09-30 Akim Demaille <akim@epita.fr>
115
116 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
117 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
118 Updates from Michael Hayes.
119
1202002-09-30 Art Haas <ahaas@neosoft.com>
121
122 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
123 invocations.
124 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
125 defined.
126
1272002-09-27 Akim Demaille <akim@epita.fr>
128
129 Version 1.49c.
130
1312002-09-27 Akim Demaille <akim@epita.fr>
132
133 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
134 (Because of AC_LIBSOURCE).
135
1362002-09-27 Akim Demaille <akim@epita.fr>
137
138 Playing with Autoscan.
139
140 * configure.ac: Remove the old LIBOBJ tweaks.
141 (AC_REPLACE_FUNCS): Add strrchr and strtol.
142 * lib/strrchr.c: New.
143 * lib/strtol.c: New, from the Coreutils 4.5.1.
144
1452002-09-27 Akim Demaille <akim@epita.fr>
146
147 Playing with Autoscan.
148
149 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
150 * lib/Makefile.am (libbison_a_SOURCES): No longer include
151 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
152 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
153 Coreutils 4.5.1.
154
1552002-09-24 Akim Demaille <akim@epita.fr>
156
157 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
158 (Frequently Asked Questions, Parser Stack Overflow): New.
159
1602002-09-13 Akim Demaille <akim@epita.fr>
161
162 Playing with autoscan.
163
164 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
165 * src/files.c (skeleton_find): Remove, unused.
166 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
167 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
168
1692002-09-13 Akim Demaille <akim@epita.fr>
170
171 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
172 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
173
1742002-09-13 Akim Demaille <akim@epita.fr>
175
176 * configure.ac: Require 2.54.
177 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
178 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
179 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
180 Remove, provided by Autoconf macros.
181
1822002-09-12 Akim Demaille <akim@epita.fr>
183
184 * m4/prereq.m4: Update, from Coreutils 4.5.1.
185
1862002-09-12 Akim Demaille <akim@epita.fr>
187
188 * m4/prereq.m4: Update, from Fileutils 4.1.5.
189 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
190 Reported by Martin Mokrejs.
191
1922002-09-10 Akim Demaille <akim@epita.fr>
193
194 * src/parse-gram.y: Associate a human readable string to each
195 token type.
196 * tests/regression.at (Invalid inputs): Adjust.
197
1982002-09-10 Gary V. Vaughan <gary@gnu.org>
199
200 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
201 with an Autoconf-2.5x style configure.ac.
202
2032002-09-06 Paul Eggert <eggert@twinsun.com>
204
205 * doc/bison.texinfo (Conditions): Make explicit that the GPL
206 exception applies only to yacc.c. This is a modification of a
207 patch originally suggested by Akim Demaille.
208
2092002-09-06 Akim Demaille <akim@epita.fr>
210
211 * data/c.m4 (b4_copyright): Move the GPL exception comment from
212 here to...
213 * data/yacc.c: here.
214
215 * data/lalr1.cc (struct yyltype): Don't define it, since we use
216 LocationType.
217 (b4_ltype): Default to yy::Location from location.hh.
218
2192002-09-04 Jim Meyering <jim@meyering.net>
220
221 * data/yacc.c: Guard the declaration of yytoknum also with
222 `#ifdef YYPRINT', so it is declared only when used.
223
2242002-09-04 Akim Demaille <akim@epita.fr>
225
226 * configure.in: Rename as...
227 * configure.ac: this.
228 Bump to 1.49c.
229
2302002-09-04 Akim Demaille <akim@epita.fr>
231
232 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
233 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
234 translate maintainer only messages.
235
2362002-08-12 Paul Eggert <eggert@twinsun.com>
237
238 Version 1.49b.
239
240 * Makefile.am (SUBDIRS): Remove intl.
241 (DISTCLEANFILES): Remove.
242 * NEWS: Mention that GNU M4 is now required. Clarify what is
243 meant by "larger grammars". Mention the pt_BR translation.
244 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
245 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
246 Bump version from 0.11.2 to 0.11.5.
247 (BISON_PREREQ_STAGE): Remove.
248 (AM_GNU_GETTEXT): Use external gettext.
249 (AC_OUTPUT): Remove intl/Makefile.
250
251 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
252
253 * data/glr.c: Include string.h, for strlen.
254 (yyreportParseError): Use size_t for yysize.
255 (yy_yypstack): No longer nested inside yypstates, as nested
256 functions are not portable. Do not assume size_t is the
257 same width as int.
258 (yypstates): Do not assume that ptrdiff_t is the same width
259 as int, and similarly for yyposn and YYINDEX.
260
261 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
262
263 * lib/Makefile.am (INCLUDES): Do not include from the intl
264 directory, which has been removed.
265 * src/Makefile.am (INCLUDES): Likewise.
266
267 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
268 (bitsets_sources, additional_bitsets_sources, timevars_sources):
269 New vars.
270
271 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
272 * tests/Makefile.am (EXTRA_DIST): Likewise.
273
274 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
275 Do not assume that bitset_windex is the same width as unsigned.
276
277 * lib/abitset.c (abitset_unused_clear): Do not assume that
278 bitset_word is the same width as int.
279 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
280 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
281 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
282 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
283 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
284
285 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
286 portability to one's complement hosts!).
287 * lib/ebitset.c (ebitset_op1): Likewise.
288 * lib/lbitset.c (lbitset_op1): Likewise.
289
290 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
291 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
292 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
293 Sync with fileutils.
294 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
295 lib/gettext.h: Sync with diffutils.
296
297 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
298 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
299
300 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
301 PROTOTYPES to check for prototypes, and "defined __STDC__" to
302 check for void *.
303
304 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
305 size_t; the old version tried to do this but casted improperly.
306 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
307 (bitset_test): Now returns int, not unsigned long.
308
309 * lib/bitset_stats.c: Include "gettext.h".
310 (_): New macro.
311 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
312 name locals "index", as it generates unnecessary warnings on some
313 hosts that have an "index" function.
314
315 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
316 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
317 they need translation.
318 * src/LR0.c (state_list_append, new_itemsets, get_state,
319 append_states, generate_states): Likewise.
320 * src/assoc.c (assoc_to_string): Likewise.
321 * src/closure.c (print_closure, set_firsts, closure): Likewise.
322 * src/gram.c (grammar_dump): Likewise.
323 * src/injections.c (injections_compute): Likewise.
324 * src/lalr.c (lookaheads_print): Likewise.
325 * src/relation.c (relation_transpose): Likewise.
326 * src/scan-gram.l: Likewise.
327 * src/tables.c (table_grow, pack_vector): Likewise.
328
329 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
330 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
331 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
332 * m4/mbstate_t.m4: Sync with fileutils.
333 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
334
335 * po/LINGUAS: Add pt_BR.
336 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
337 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
338 lib/timevar.c.
339 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
340 manual recommends.
341 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
342
343 * src/complain.c (strerror_r): Remove decl; not needed.
344 (strerror): Use same pattern as ../lib/error.c.
345
346 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
347
348 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
349
350 * src/main.c (main): Cast result of bindtextdomain and textdomain
351 to void, to avoid a GCC warning when --disable-nls is in effect.
352
353 * src/scan-gram.l: Use strings rather than escapes when possible,
354 to minimize the number of warnings from xgettext.
355 (handle_action_dollar, handle_action_at): Don't use isdigit,
356 as it mishandles negative chars and it may not work as expected
357 outside the C locale.
358
359 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
360 this is a GCC extension and is not portable to other compilers.
361
362 * src/system.h (alloca): Use same pattern as ../lib/error.c.
363 Do not include <ctype.h>; no longer needed.
364 Do not include <malloc.h>; no longer needed (and generates
365 warnings on OpenBSD 3.0).
366
367 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
368 it's not portable.
369
370 * tests/regression.at: Do not use 'cc -c input.c -o input';
371 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
372
373 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
374 exit status as failure, not just exit status 1. Sun C exits
375 with status 2 sometimes.
376
377 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
378 Use it for the two large tests.
379
3802002-08-02 Akim Demaille <akim@epita.fr>
381
382 * src/conflicts.c (conflicts_output): Don't output rules never
383 reduced here, since anyway that computation doesn't work.
384 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
385 (rule_useless_p, rule_never_reduced_p): New.
386 (grammar_rules_partial_print): Use a filter instead of a range.
387 Display the title only if needed.
388 (grammar_rules_print): Adjust.
389 (grammar_rules_never_reduced_report): New.
390 * src/tables.c (action_row): Move the computation of rules never
391 reduced to...
392 (token_actions): here.
393 * src/main.c (main): Make the parser before making the report, so
394 that rules never reduced are computed.
395 Call grammar_rules_never_reduced_report.
396 * src/print.c (print_results): Report rules never reduced.
397 * tests/conflicts.at, tests/reduce.at: Adjust.
398
3992002-08-01 Akim Demaille <akim@epita.fr>
400
401 Instead of attaching lookaheads and duplicating the rules being
402 reduced by a state, attach the lookaheads to the reductions.
403
404 * src/state.h (state_t): Remove the `lookaheads',
405 `lookaheads_rule' member.
406 (reductions_t): Add a `lookaheads' member.
407 Use a regular array for the `rules'.
408 * src/state.c (reductions_new): Initialize the lookaheads member
409 to 0.
410 (state_rule_lookaheads_print): Adjust.
411 * src/state.h, src/state.c (state_reductions_find): New.
412 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
413 (count_rr_conflicts): Adjust.
414 * src/lalr.c (LArule): Remove.
415 (add_lookback_edge): Adjust.
416 (state_lookaheads_count): New.
417 (states_lookaheads_initialize): Merge into...
418 (initialize_LA): this.
419 (lalr_free): Adjust.
420 * src/main.c (main): Don't free nullable and derives too early: it
421 is used by --verbose.
422 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
423
4242002-08-01 Akim Demaille <akim@epita.fr>
425
426 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
427 `rule_number_t**'.
428 (set_derives, free_derives): Rename as...
429 (derives_compute, derives_free): this.
430 Adjust all dependencies.
431 * src/nullable.c (set_nullable, free_nullable): Rename as...
432 (nullable_compute, nullable_free): these.
433 (rule_list_t): Store rule_t *, not rule_number_t.
434 * src/state.c (state_rule_lookaheads_print): Directly compare rule
435 pointers, instead of their numbers.
436 * src/main.c (main): Call nullable_free, and derives_free earlier,
437 as they were lo longer used.
438
4392002-08-01 Akim Demaille <akim@epita.fr>
440
441 * lib/timevar.c (get_time): Include children time.
442 * src/lalr.h (LA, LArule): Don't export them: used with the
443 state_t.
444 * src/lalr.c (LA, LArule): Static.
445 * src/lalr.h, src/lalr.c (lalr_free): New.
446 * src/main.c (main): Call it.
447 * src/tables.c (pack_vector): Check whether loc is >= to the
448 table_size, not >.
449 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
450 (tables_generate): do it, since that's also it which allocates
451 them.
452 Don't free LA and LArule, main does.
453
4542002-07-31 Akim Demaille <akim@epita.fr>
455
456 Separate parser tables computation and output.
457
458 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
459 (conflict_list, conflict_list_cnt, table, check, table_ninf)
460 (yydefgoto, yydefact, high): Move to...
461 * src/tables.h, src/tables.c: here.
462 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
463 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
464 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
465 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
466 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
467 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
468 (action_row, save_row, token_actions, save_column, default_goto)
469 (goto_actions, sort_actions, matching_state, pack_vector)
470 (table_ninf_remap, pack_table, prepare_actions): Move to...
471 * src/tables.c: here.
472 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
473 * src/output.c (token_actions, output_base, output_conflicts)
474 (output_check): Merge into...
475 (prepare_actions): this.
476 (actions_output): Rename as...
477 (user_actions_output): this.
478 * src/main.c (main): Call tables_generate and tables_free.
479
4802002-07-31 Akim Demaille <akim@epita.fr>
481
482 Steal GCC's --time-report support.
483
484 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
485 stolen/adjusted from GCC.
486 * m4/stage.m4: Remove time related checks.
487 * m4/timevar.m4: New.
488 * configure.in: Adjust.
489 * src/system.h: Adjust to using timevar.h.
490 * src/getargs.h, src/getargs.c: Support trace_time for
491 --trace=time.
492 * src/main.c (stage): Remove.
493 (main): Replace `stage' invocations with timevar calls.
494 * src/output.c: Insert pertinent timevar calls.
495
4962002-07-31 Akim Demaille <akim@epita.fr>
497
498 Let --trace have arguments.
499
500 * src/getargs.h (enum trace_e): New.
501 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
502 (long_options, short_options): --trace/-T takes an optional
503 argument.
504 Change all the uses of trace_flag to reflect the new flags.
505 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
506
507 Strengthen `stage' portability.
508
509 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
510 * configure.in: Use it.
511 Don't check for malloc.h and sys/times.h.
512 * src/system.h: Include them when appropriate.
513 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
514 times and struct tms are available.
515
5162002-07-30 Akim Demaille <akim@epita.fr>
517
518 In verbose parse error message, don't report `error' as an
519 expected token.
520 * tests/actions.at (Printers and Destructors): Adjust.
521 * tests/calc.at (Calculator $1): Adjust.
522 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
523 error message, do not report the parser accepts the error token in
524 that state.
525
5262002-07-30 Akim Demaille <akim@epita.fr>
527
528 Normalize conflict related messages.
529
530 * src/complain.h, src/complain.c (warn, complain): New.
531 * src/conflicts.c (conflicts_print): Use them.
532 (conflict_report_yacc): New, extracted from...
533 (conflicts_print): here.
534 * tests/conflicts.at, tests/existing.at: Adjust.
535
5362002-07-30 Akim Demaille <akim@epita.fr>
537
538 Report rules which are never reduced by the parser: those hidden
539 by conflicts.
540
541 * src/LR0.c (save_reductions): Don't make the final state too
542 different: save its reduction (accept) instead of having a state
543 without any action (no shift or goto, no reduce).
544 Note: the final state is now a ``regular'' state, i.e., the
545 parsers now contain `reduce 0' as default reduction.
546 Nevertheless, since they decide to `accept' when yystate =
547 final_state, they still will not reduce rule 0.
548 * src/print.c (print_actions, print_reduction): Adjust.
549 * src/output.c (action_row): Track reduced rules.
550 (token_actions): Report rules never reduced.
551 * tests/conflicts.at, tests/regression.at: Adjust.
552
5532002-07-30 Akim Demaille <akim@epita.fr>
554
555 `stage' was accidently included in a previous patch.
556 Initiate its autoconfiscation.
557
558 * configure.in: Look for malloc.h and sys/times.h.
559 * src/main.c (stage): Adjust.
560 Report only when trace_flag.
561
5622002-07-29 Akim Demaille <akim@epita.fr>
563
564 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
565 state_number_t.
566 (errs_t): symbol_t*, not symbol_number_t.
567 (reductions_t): rule_t*, not rule_number_t.
568 (FOR_EACH_SHIFT): New.
569 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
570 * src/print.c, src/print_graph.c: Adjust.
571
5722002-07-29 Akim Demaille <akim@epita.fr>
573
574 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
575
576 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
577 (endtoken, accept): these.
578 * src/reader.c (reader): Set endtoken's default tag to "$end".
579 Set undeftoken's tag to "$undefined" instead of "$undefined.".
580 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
581 Adjust.
582
5832002-07-29 Akim Demaille <akim@epita.fr>
584
585 * src/reduce.c (reduce_grammar): When the language is empty,
586 complain about the start symbol, not the axiom.
587 Use its location.
588 * tests/reduce.at (Empty Language): New.
589
5902002-07-26 Akim Demaille <akim@epita.fr>
591
592 * src/reader.h, src/reader.c (gram_error): ... can't get
593 yycontrol without making too strong assumptions on the parser
594 itself.
595 * src/output.c (prepare_tokens): Use the real 0th value of
596 token_translations instead of `0'.
597 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
598 visible here.
599 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
600 for the time being: %locations ought to provide it to yyerror.
601
6022002-07-25 Akim Demaille <akim@epita.fr>
603
604 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
605 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
606 * tests/regression.at (Web2c Actions): Adjust.
607
6082002-07-25 Akim Demaille <akim@epita.fr>
609
610 Stop storing rules from 1 to nrules + 1.
611
612 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
613 * src/nullable.c, src/output.c, src/print.c, src/reader.c
614 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
615 Iterate from 0 to nrules.
616 Use rule_number_as_item_number and item_number_as_rule_number.
617 Adjust to `derive' now containing possibly 0.
618 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
619 Handle the `- 1' part in rule numbers from/to item numbers.
620 * src/conflicts.c (log_resolution): Fix the message which reversed
621 shift and reduce.
622 * src/output.c (action_row): Initialize default_rule to -1.
623 (token_actions): Adjust.
624 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
625 expected output.
626 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
627
6282002-07-25 Akim Demaille <akim@epita.fr>
629
630 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
631 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
632 (b4_c_knr_arg_decl): New.
633 * data/yacc.c: Use it to define yysymprint, yydestruct, and
634 yyreport_parse_error.
635
6362002-07-25 Akim Demaille <akim@epita.fr>
637
638 * data/yacc.c (yyreport_parse_error): New, extracted from...
639 (yyparse): here.
640 (yydestruct, yysymprint): Move above yyparse.
641 Be K&R compliant.
642
6432002-07-25 Akim Demaille <akim@epita.fr>
644
645 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
646 replace...
647 (b4_sint_type, b4_uint_type): these.
648 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
649 * tests/regression.at (Web2c Actions): Adjust.
650
6512002-07-25 Akim Demaille <akim@epita.fr>
652
653 * src/gram.h (TIEM_NUMBER_MAX): New.
654 (item_number_of_rule_number, rule_number_of_item_number): Rename
655 as...
656 (rule_number_as_item_number, item_number_as_rule_number): these.
657 Adjust dependencies.
658 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
659 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
660 (symbol_number_to_vector_number): New.
661 (order): Of vector_number_t* type.
662 (base_t, BASE_MAX, BASE_MIN): New.
663 (froms, tos, width, pos, check): Of base_t type.
664 (action_number_t, ACTION_MIN, ACTION_MAX): New.
665 (actrow): Of action_number_t type.
666 (conflrow): Of unsigned int type.
667 (table_ninf, base_ninf): New.
668 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
669 (muscle_insert_int_table, muscle_insert_base_table)
670 (muscle_insert_rule_number_table): New.
671 (prepare_tokens): Output `toknum' as int_table.
672 (action_row): Returns a rule_number_t.
673 Use ACTION_MIN, not SHRT_MIN.
674 (token_actions): yydefact is rule_number_t*.
675 (table_ninf_remap): New.
676 (pack_table): Use it for `base' and `table'.
677 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
678 replaced with...
679 (YYPACT_NINF, YYTABLE_NINF): these.
680 (yypact, yytable): Compute their types instead of hard-coded
681 `short'.
682 * tests/regression.at (Web2c Actions): Adjust.
683
6842002-07-19 Akim Demaille <akim@epita.fr>
685
686 * src/scan-gram.l (id): Can start with an underscore.
687
6882002-07-16 Akim Demaille <akim@epita.fr>
689
690 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
691 Adjust all former `associativity' dependencies.
692 * src/symtab.c (symbol_new): Default associativity is `undef', not
693 `right'.
694 (symbol_check_alias_consistence): Adjust.
695
6962002-07-09 Akim Demaille <akim@epita.fr>
697
698 * doc/bison.texinfo: Properly set the ``header'' part.
699 Use @dircategory ``GNU programming tools'' as per Texinfo's
700 documentation.
701 Use @copying.
702
7032002-07-09 Akim Demaille <akim@epita.fr>
704
705 * lib/quotearg.h: Protect against multiple inclusions.
706 * src/location.h (location_t): Add a `file' member.
707 (LOCATION_RESET, LOCATION_PRINT): Adjust.
708 * src/complain.c (warn_at, complain_at, fatal_at): Drop
709 `error_one_per_line' support.
710
7112002-07-09 Akim Demaille <akim@epita.fr>
712
713 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
714 * src/reader.c (lineno): Remove.
715 Adjust all dependencies.
716 (get_merge_function): Take a location and use complain_at.
717 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
718 * tests/regression.at (Invalid inputs, Mixing %token styles):
719 Adjust.
720
7212002-07-09 Akim Demaille <akim@epita.fr>
722
723 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
724 recovery rule, and forbid extensions when --yacc.
725 (gram_error): Use complain_at.
726 * src/reader.c (reader): Exit if there were parse errors.
727
7282002-07-09 Akim Demaille <akim@epita.fr>
729
730 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
731 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
732 Reported by R Blake <blakers@mac.com>.
733
7342002-07-09 Akim Demaille <akim@epita.fr>
735
736 * data/yacc.c: Output the copyright notive in the header.
737
7382002-07-03 Akim Demaille <akim@epita.fr>
739
740 * src/output.c (froms, tos): Are state_number_t.
741 (save_column): sp, sp1, and sp2 are state_number_t.
742 (prepare): Rename `final' as `final_state_number', `nnts' as
743 `nterms_number', `nrules' as `rules_number', `nstates' as
744 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
745 unused.
746 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
747 * data/lalr1.cc (nsym_): Remove, unused.
748
7492002-07-03 Akim Demaille <akim@epita.fr>
750
751 * src/lalr.h, src/lalr.c (goto_number_t): New.
752 * src/lalr.c (goto_list_t): New.
753 Propagate them.
754 * src/nullable.c (rule_list_t): New.
755 Propagate.
756 * src/types.h: Remove.
757
7582002-07-03 Akim Demaille <akim@epita.fr>
759
760 * src/closure.c (print_fderives): Use rule_rhs_print.
761 * src/derives.c (print_derives): Use rule_rhs_print.
762 (rule_list_t): New, replaces `shorts'.
763 (set_derives): Add comments.
764 * tests/sets.at (Nullable, Firsts): Adjust.
765
7662002-07-03 Akim Demaille <akim@epita.fr>
767
768 * src/output.c (prepare_actions): Free `tally' and `width'.
769 (prepare_actions): Allocate and free `order'.
770 * src/symtab.c (symbols_free): Free `symbols'.
771 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
772 * src/output.c (m4_invoke): Move to...
773 * src/scan-skel.l: here.
774 (<<EOF>>): Close yyout, and free its name.
775
7762002-07-03 Akim Demaille <akim@epita.fr>
777
778 Fix some memory leaks, and fix a bug: state 0 was examined twice.
779
780 * src/LR0.c (new_state): Merge into...
781 (state_list_append): this.
782 (new_states): Merge into...
783 (generate_states): here.
784 (set_states): Don't ensure a proper `errs' state member here, do it...
785 * src/conflicts.c (conflicts_solve): here.
786 * src/state.h, src/state.c: Comment changes.
787 (state_t): Rename member `shifts' as `transitions'.
788 Adjust all dependencies.
789 (errs_new): For consistency, also take the values as argument.
790 (errs_dup): Remove.
791 (state_errs_set): New.
792 (state_reductions_set, state_transitions_set): Assert that no
793 previous value was assigned.
794 (state_free): New.
795 (states_free): Use it.
796 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
797 temporary storage: use `errs' and `nerrs' as elsewhere.
798 (set_conflicts): Allocate and free this `errs'.
799
8002002-07-02 Akim Demaille <akim@epita.fr>
801
802 * lib/libiberty.h: New.
803 * lib: Update the bitset implementation from upstream.
804 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
805 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
806 * src/main.c: Adjust bitset stats calls.
807
8082002-07-01 Paul Eggert <eggert@twinsun.com>
809
810 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
811 char, so that negative chars don't collide with $.
812
8132002-06-30 Akim Demaille <akim@epita.fr>
814
815 Have the GLR tests be `warning' checked, and fix the warnings.
816
817 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
818 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
819 (yyremoveDeletes): `yyi' and `yyj' are size_t.
820 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
821 (yyaddDeferredAction): static.
822 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
823 (yyreportParseError): yyprefix is const.
824 yytokenp is used only when verbose.
825 (yy__GNUC__): Replace with __GNUC__.
826 (yypdumpstack): yyi is size_t.
827 (yypreference): Un-yy local variables and arguments, to avoid
828 clashes with `yyr1'. Anyway, we are not in the user name space.
829 (yytname_size): be an int, as is compared with ints.
830 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
831 Use them.
832 * tests/cxx-gram.at: Use quotation to protect $1.
833 Use AT_COMPILE to enable warnings hunts.
834 Prototype yylex and yyerror.
835 `Use' argc.
836 Include `string.h', not `strings.h'.
837 Produce and prototype stmtMerge only when used.
838 yylex takes a location.
839
8402002-06-30 Akim Demaille <akim@epita.fr>
841
842 We spend a lot of time in quotearg, in particular when --verbose.
843
844 * src/symtab.c (symbol_get): Store a quoted version of the key.
845 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
846 Adjust all callers.
847
8482002-06-30 Akim Demaille <akim@epita.fr>
849
850 * src/state.h (reductions_t): Rename member `nreds' as num.
851 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
852 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
853
8542002-06-30 Akim Demaille <akim@epita.fr>
855
856 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
857 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
858 (shifts_to): Rename as...
859 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
860 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
861 (TRANSITION_IS_DISABLED, transitions_to): these.
862
8632002-06-30 Akim Demaille <akim@epita.fr>
864
865 * src/print.c (print_shifts, print_gotos): Merge into...
866 (print_transitions): this.
867 (print_transitions, print_errs, print_reductions): Align the
868 lookaheads columns.
869 (print_core, print_transitions, print_errs, print_state,
870 print_grammar): Output empty lines separator before, not after.
871 (state_default_rule_compute): Rename as...
872 (state_default_rule): this.
873 * tests/conflicts.at (Defaulted Conflicted Reduction),
874 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
875 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
876
8772002-06-30 Akim Demaille <akim@epita.fr>
878
879 Display items as we display rules.
880
881 * src/gram.h, src/gram.c (rule_lhs_print): New.
882 * src/gram.c (grammar_rules_partial_print): Use it.
883 * src/print.c (print_core): Likewise.
884 * tests/conflicts.at (Defaulted Conflicted Reduction),
885 (Unresolved SR Conflicts): Adjust.
886 (Unresolved SR Conflicts): Adjust and rename as...
887 (Resolved SR Conflicts): this, as was meant.
888 * tests/regression.at (Web2c Report): Adjust.
889
8902002-06-30 Akim Demaille <akim@epita.fr>
891
892 * src/print.c (state_default_rule_compute): New, extracted from...
893 (print_reductions): here.
894 Pessimize, but clarify the code.
895 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
896
8972002-06-30 Akim Demaille <akim@epita.fr>
898
899 * src/output.c (action_row): Let default_rule be always a rule
900 number.
901
9022002-06-30 Akim Demaille <akim@epita.fr>
903
904 * src/closure.c (print_firsts, print_fderives, closure):
905 Use BITSET_EXECUTE.
906 * src/lalr.c (lookaheads_print): Likewise.
907 * src/state.c (state_rule_lookaheads_print): Likewise.
908 * src/print_graph.c (print_core): Likewise.
909 * src/print.c (print_reductions): Likewise.
910 * src/output.c (action_row): Likewise.
911 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
912
9132002-06-30 Akim Demaille <akim@epita.fr>
914
915 * src/print_graph.c: Use report_flag.
916
9172002-06-30 Akim Demaille <akim@epita.fr>
918
919 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
920 to...
921 * src/relation.h, src/relation.c (traverse, relation_digraph)
922 (relation_print, relation_transpose): New.
923
9242002-06-30 Akim Demaille <akim@epita.fr>
925
926 * src/state.h, src/state.c (shifts_to): New.
927 * src/lalr.c (build_relations): Use it.
928
9292002-06-30 Akim Demaille <akim@epita.fr>
930
931 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
932 (item_number_of_rule_number, rule_number_of_item_number): New.
933 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
934 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
935 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
936 Propagate their use.
937 Much remains to be done, in particular wrt `shorts' from types.h.
938
9392002-06-30 Akim Demaille <akim@epita.fr>
940
941 * src/symtab.c (symbol_new): Initialize the `printer' member.
942
9432002-06-30 Akim Demaille <akim@epita.fr>
944
945 * src/LR0.c (save_reductions): Remove, replaced by...
946 * src/state.h, src/state.c (state_reductions_set): New.
947 (reductions, errs): Rename as...
948 (reductions_t, errs_t): these.
949 Adjust all dependencies.
950
9512002-06-30 Akim Demaille <akim@epita.fr>
952
953 * src/LR0.c (state_list_t, state_list_append): New.
954 (first_state, last_state): Now symbol_list_t.
955 (this_state): Remove.
956 (new_itemsets, append_states, save_reductions): Take a state_t as
957 argument.
958 (set_states, generate_states): Adjust.
959 (save_shifts): Remove, replaced by...
960 * src/state.h, src/state.c (state_shifts_set): New.
961 (shifts): Rename as...
962 (shifts_t): this.
963 Adjust all dependencies.
964 * src/state.h (state_t): Remove the `next' member.
965
9662002-06-30 Akim Demaille <akim@epita.fr>
967
968 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
969 escaped in slot 0.
970
9712002-06-30 Akim Demaille <akim@epita.fr>
972
973 Use hash.h for the state hash table.
974
975 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
976 (allocate_storage): Use state_hash_new.
977 (free_storage): Use state_hash_free.
978 (new_state, get_state): Adjust.
979 * src/lalr.h, src/lalr.c (states): Move to...
980 * src/states.h (state_t): Remove the `link' member, no longer
981 used.
982 * src/states.h, src/states.c: here.
983 (state_hash_new, state_hash_free, state_hash_lookup)
984 (state_hash_insert, states_free): New.
985 * src/states.c (state_table, state_compare, state_hash): New.
986 * src/output.c (output_actions): Do not free states now, since we
987 still need to know the final_state number in `prepare', called
988 afterwards. Do it...
989 * src/main.c (main): here: call states_free after `output'.
990
9912002-06-30 Akim Demaille <akim@epita.fr>
992
993 * src/state.h, src/state.c (state_new): New, extracted from...
994 * src/LR0.c (new_state): here.
995 * src/state.h (STATE_ALLOC): Move to...
996 * src/state.c: here.
997 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
998 * src/state.h, src/state.c: here.
999
10002002-06-30 Akim Demaille <akim@epita.fr>
1001
1002 * src/reader.c (gensym): Rename as...
1003 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1004 (getsym): Rename as...
1005 (symbol_get): this.
1006
10072002-06-30 Akim Demaille <akim@epita.fr>
1008
1009 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1010 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1011 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1012 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1013
10142002-06-30 Akim Demaille <akim@epita.fr>
1015
1016 Make the test suite pass with warnings checked.
1017
1018 * tests/actions.at (Printers and Destructors): Improve.
1019 Avoid unsigned vs. signed issues.
1020 * tests/calc.at: Don't exercise the scanner here, do it...
1021 * tests/input.at (Torturing the Scanner): here.
1022
10232002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1024
1025 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
1026 reorganize first lines parallel to yacc.c.
1027
10282002-06-28 Akim Demaille <akim@epita.fr>
1029
1030 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1031 (b4_token_enum, b4_token_defines): New, factored from...
1032 * data/lalr1.cc, data/yacc.c, glr.c: here.
1033
10342002-06-28 Akim Demaille <akim@epita.fr>
1035
1036 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1037 unused variables.
1038 * src/output.c (merger_output): static.
1039
10402002-06-28 Akim Demaille <akim@epita.fr>
1041
1042 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1043 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1044 pacify GCC.
1045 * src/output.c (save_row): Initialize all the variables to pacify GCC.
1046
10472002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1048
1049 Accumulated changelog for new GLR parsing features.
1050
1051 * src/conflicts.c (count_total_conflicts): Change name to
1052 conflicts_total_count.
1053 * src/conflicts.h: Ditto.
1054 * src/output.c (token_actions): Use the new name.
1055 (output_conflicts): Change conflp => conflict_list_heads, and
1056 confl => conflict_list for better readability.
1057 * data/glr.c: Use the new names.
1058 * NEWS: Add self to GLR announcement.
1059
1060 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1061
1062 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1063 Akim Demaille.
1064
1065 * data/bison.glr: Change name to glr.c
1066 * data/glr.c: Renamed from bison.glr.
1067 * data/Makefile.am: Add glr.c
1068
1069 * src/getargs.c:
1070
1071 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1072 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
1073
1074 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1075
1076 * data/bison.glr: Be sure to restore the
1077 current #line when returning to the skeleton contents after having
1078 exposed the input file's #line.
1079
1080 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1081
1082 * data/bison.glr: Bring up to date with changes to bison.simple.
1083
1084 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1085
1086 * data/bison.glr: Correct definitions that use b4_prefix.
1087 Various reformatting.
1088 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1089 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1090 yytokenp argument; now part of stack.
1091 (yychar): Define to behave as documented.
1092 (yyclearin): Ditto.
1093
1094 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1095
1096 * src/reader.h: Add declaration for free_merger_functions.
1097
1098 * src/reader.c (merge_functions): New variable.
1099 (get_merge_function): New function.
1100 (free_merger_functions): New function.
1101 (readgram): Check for %prec that is not followed by a symbol.
1102 Handle %dprec and %merge declarations.
1103 (packgram): Initialize dprec and merger fields in rules array.
1104
1105 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1106 conflict_list_cnt, conflict_list_free): New variables.
1107 (table_grow): Also grow conflict_table.
1108 (prepare_rules): Output dprec and merger tables.
1109 (conflict_row): New function.
1110 (action_row): Output conflict lists for GLR parser. Don't use
1111 default reduction in conflicted states for GLR parser so that there
1112 are spaces for the conflict lists.
1113 (save_row): Also save conflict information.
1114 (token_actions): Allocate conflict list.
1115 (merger_output): New function.
1116 (pack_vector): Pack conflict table, too.
1117 (output_conflicts): New function to output yyconflp and yyconfl.
1118 (output_check): Allocate conflict_tos.
1119 (output_actions): Output conflict tables, also.
1120 (output_skeleton): Output b4_mergers definition.
1121 (prepare): Output b4_max_rhs_length definition.
1122 Use 'bison.glr' as default skeleton for GLR parsers.
1123
1124 * src/gram.c (glr_parser): New flag.
1125 (grammar_free): Call free_merger_functions.
1126
1127 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1128 all pairs of conflicting reductions, rather than just all tokens
1129 causing conflicts. Needed to size conflict tables.
1130 (conflicts_output): Modify call to count_rr_conflicts for new
1131 interface.
1132 (conflicts_print): Ditto.
1133 (count_total_conflicts): New function.
1134
1135 * src/reader.h (merger_list): New type.
1136 (merge_functions): New variable.
1137
1138 * src/lex.h (tok_dprec, tok_merge): New token types.
1139
1140 * src/gram.h (rule_s): Add dprec and merger fields.
1141 (glr_parser): New flag.
1142
1143 * src/conflicts.h (count_total_conflicts): New function.
1144
1145 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1146
1147 * doc/bison.texinfo (Generalized LR Parsing): New section.
1148 (GLR Parsers): New section.
1149 (Language and Grammar): Mention GLR parsing.
1150 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1151 Correct typo ("tge" -> "the").
1152
1153 * data/bison.glr: New skeleton for GLR parsing.
1154
1155 * tests/cxx-gram.at: New tests for GLR parsing.
1156
1157 * tests/testsuite.at: Include cxx-gram.at.
1158
1159 * tests/Makefile.am: Add cxx-gram.at.
1160
1161 * src/parse-gram.y:
1162
1163 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1164
1165 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
1166
11672002-06-27 Akim Demaille <akim@epita.fr>
1168
1169 * src/options.h, src/options.c: Remove.
1170 * src/getargs.c (short_options, long_options): New.
1171
11722002-06-27 Akim Demaille <akim@epita.fr>
1173
1174 * data/bison.simple, data/bison.c++: Rename as...
1175 * data/yacc.c, data/lalr1.cc: these.
1176 * doc/bison.texinfo (Environment Variables): Remove.
1177
11782002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1179
1180 * src/getargs.c (report_argmatch): Initialize strtok().
1181
11822002-06-20 Akim Demaille <akim@epita.fr>
1183
1184 * data/bison.simple (b4_symbol_actions): New, replaces...
1185 (b4_symbol_destructor, b4_symbol_printer): these.
1186 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1187 user token numbers.
1188
11892002-06-20 Akim Demaille <akim@epita.fr>
1190
1191 * data/bison.simple (yydestructor): Rename as...
1192 (yydestruct): this.
1193
11942002-06-20 Akim Demaille <akim@epita.fr>
1195
1196 * src/symtab.h, src/symtab.c (symbol_type_set)
1197 (symbol_destructor_set, symbol_precedence_set): The location is
1198 the last argument.
1199 Adjust all callers.
1200
12012002-06-20 Akim Demaille <akim@epita.fr>
1202
1203 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1204 internals.
1205 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1206 Takes a location.
1207 * src/symtab.h, src/symtab.c (symbol_class_set)
1208 (symbol_user_token_number_set): Likewise.
1209 Adjust all callers.
1210 Promote complain_at.
1211 * tests/input.at (Type Clashes): Adjust.
1212
12132002-06-20 Akim Demaille <akim@epita.fr>
1214
1215 * data/bison.simple (YYLEX): Fix the declaration when
1216 %pure-parser.
1217
12182002-06-20 Akim Demaille <akim@epita.fr>
1219
1220 * data/bison.simple (yysymprint): Don't print the token number,
1221 just its name.
1222 * tests/actions.at (Destructors): Rename as...
1223 (Printers and Destructors): this.
1224 Also exercise %printer.
1225
12262002-06-20 Akim Demaille <akim@epita.fr>
1227
1228 * data/bison.simple (YYDSYMPRINT): New.
1229 Use it to remove many of the #if YYDEBUG/if (yydebug).
1230
12312002-06-20 Akim Demaille <akim@epita.fr>
1232
1233 * src/symtab.h, src/symtab.c (symbol_t): printer and
1234 printer_location are new members.
1235 (symbol_printer_set): New.
1236 * src/parse-gram.y (PERCENT_PRINTER): New token.
1237 Handle its associated rule.
1238 * src/scan-gram.l: Adjust.
1239 (handle_destructor_at, handle_destructor_dollar): Rename as...
1240 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1241 * src/output.c (symbol_printers_output): New.
1242 (output_skeleton): Call it.
1243 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1244 since there are already many grammar files with a user `yyprint'.
1245 Replace the calls to YYPRINT to calls to yysymprint.
1246 * tests/calc.at: Adjust.
1247 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1248 taking advantage of parser very internal details (stack size!).
1249
12502002-06-20 Akim Demaille <akim@epita.fr>
1251
1252 * src/scan-gram.l: Complete the scanner with the missing patterns
1253 to pacify Flex.
1254 Use `quote' and `symbol_tag_get' where appropriate.
1255
12562002-06-19 Akim Demaille <akim@epita.fr>
1257
1258 * tests/actions.at (Destructors): Augment to test locations.
1259 * data/bison.simple (yydestructor): Pass it the current location
1260 if locations are enabled.
1261 Prototype only when __STDC__ or C++.
1262 Change the argument names to move into the yy name space: there is
1263 user code here.
1264
12652002-06-19 Akim Demaille <akim@epita.fr>
1266
1267 * data/bison.simple (b4_pure_if): New.
1268 Use it instead of #ifdef YYPURE.
1269
12702002-06-19 Akim Demaille <akim@epita.fr>
1271
1272 * data/bison.simple (b4_location_if): New.
1273 Use it instead of #ifdef YYLSP_NEEDED.
1274
12752002-06-19 Akim Demaille <akim@epita.fr>
1276
1277 Prepare @$ in %destructor, but currently don't bind it in the
1278 skeleton, as %location use is not cleaned up yet.
1279
1280 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1281 (handle_action_at): New.
1282 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1283 a braced_code_t and a location as additional arguments.
1284 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1285 unquote one when outputting `b4_dollar_dollar'.
1286 Adjust callers.
1287 * data/bison.simple (b4_eval): Remove.
1288 (b4_symbol_destructor): Adjust.
1289 * tests/input.at (Invalid @n): Adjust.
1290
12912002-06-19 Zack Weinberg <zack@codesourcery.com>
1292
1293 * doc/bison.texinfo: Document ability to have multiple
1294 prologue sections.
1295
12962002-06-18 Akim Demaille <akim@epita.fr>
1297
1298 * src/files.c (compute_base_names): When computing the output file
1299 names from the input file name, strip the directory part.
1300
13012002-06-18 Akim Demaille <akim@epita.fr>
1302
1303 * data/bison.simple.new: Comment changes.
1304 Reported by Andreas Schwab.
1305
13062002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1307
1308 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1309 there are no `label `yyoverflowlab' defined but not used' warnings
1310 when yyoverflow is defined.
1311
13122002-06-18 Akim Demaille <akim@epita.fr>
1313
1314 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1315 new member.
1316 (symbol_destructor_set): Adjust.
1317 * src/output.c (symbol_destructors_output): Output the destructor
1318 locations.
1319 Output the symbol name.
1320 * data/bison.simple (b4_symbol_destructor): Adjust.
1321
13222002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1323 and Akim Demaille <akim@epita.fr>
1324
1325 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1326 what's left on the stack when the error recovery hits EOF.
1327 * tests/actions.at (Destructors): Complete to exercise this case.
1328
13292002-06-17 Akim Demaille <akim@epita.fr>
1330
1331 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1332 arguments is really empty, not only equal to `[]'.
1333 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1334 member.
1335 (symbol_destructor_set): New.
1336 * src/output.c (symbol_destructors_output): New.
1337 * src/reader.h (brace_code_t, current_braced_code): New.
1338 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1339 (handle_dollar): Rename as...
1340 (handle_action_dollar): this.
1341 (handle_destructor_dollar): New.
1342 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1343 (grammar_declaration): Use it.
1344 * data/bison.simple (yystos): Is always defined.
1345 (yydestructor): New.
1346 * tests/actions.at (Destructors): New.
1347 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1348
13492002-06-17 Akim Demaille <akim@epita.fr>
1350
1351 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1352 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1353 rule_length only when needed.
1354 * src/output.c (actions_output, token_definitions_output): Output
1355 the full M4 block.
1356 * src/symtab.c: Don't access directly to the symbol tag, use
1357 symbol_tag_get.
1358 * src/parse-gram.y: Use symbol_list_free.
1359
13602002-06-17 Akim Demaille <akim@epita.fr>
1361
1362 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1363 (symbol_list_prepend, get_type_name): Move to...
1364 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1365 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1366 Adjust all callers.
1367 (symbol_list_free): New.
1368 * src/scan-gram.l (handle_dollar): Takes a location.
1369 * tests/input.at (Invalid $n): Adjust.
1370
13712002-06-17 Akim Demaille <akim@epita.fr>
1372
1373 * src/reader.h, src/reader.c (symbol_list_new): Export it.
1374 (symbol_list_prepend): New.
1375 * src/parse-gram.y (%union): `list' is a new member.
1376 (symbols.1): New, replaces...
1377 (terms_to_prec.1, nterms_to_type.1): these.
1378 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
1379 Take a location as additional argument.
1380 Adjust all callers.
1381
13822002-06-15 Akim Demaille <akim@epita.fr>
1383
1384 * src/parse-gram.y: Move %token in the declaration section so that
1385 we don't depend upon CVS Bison.
1386
13872002-06-15 Akim Demaille <akim@epita.fr>
1388
1389 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
1390 * src/print.c (print_core): Use it.
1391
13922002-06-15 Akim Demaille <akim@epita.fr>
1393
1394 * src/conflicts.c (log_resolution): Accept the rule involved in
1395 the sr conflicts instead of the lookahead number that points to
1396 that rule.
1397 (flush_reduce): Accept the current lookahead vector as argument,
1398 instead of the index in LA.
1399 (resolve_sr_conflict): Accept the current number of lookahead
1400 bitset to consider for the STATE, instead of the index in LA.
1401 (set_conflicts): Adjust.
1402 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
1403
14042002-06-15 Akim Demaille <akim@epita.fr>
1405
1406 * src/state.h (state_t): Replace the `lookaheadsp' member, a
1407 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
1408 Adjust all dependencies.
1409 * src/lalr.c (initialize_lookaheads): Split into...
1410 (states_lookaheads_count, states_lookaheads_initialize): these.
1411 (lalr): Adjust.
1412
14132002-06-15 Akim Demaille <akim@epita.fr>
1414
1415 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
1416 out of...
1417 (grammar_rules_print): here.
1418 * src/reduce.c (reduce_output): Use it.
1419 * tests/reduce.at (Useless Rules, Reduced Automaton)
1420 (Underivable Rules): Adjust.
1421
14222002-06-15 Akim Demaille <akim@epita.fr>
1423
1424 Copy BYacc's nice way to report the grammar.
1425
1426 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
1427 New.
1428 Don't print the rules' location, it is confusing and useless.
1429 (rule_print): Use grammar_rhs_print.
1430 * src/print.c (print_grammar): Use grammar_rules_print.
1431
14322002-06-15 Akim Demaille <akim@epita.fr>
1433
1434 Complete and rationalize `useless thing' warnings.
1435
1436 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
1437 (symbol_tag_print): New.
1438 Use them everywhere in place of accessing directly the tag member.
1439 * src/gram.h, src/gram.c (rule_print): New.
1440 Use it where a rule used to be printed `by hand'.
1441 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
1442 (reduce_grammar_tables): Report the useless rules.
1443 (reduce_print): Useless things are a warning, not an error.
1444 Report it as such.
1445 * tests/reduce.at (Useless Nonterminals, Useless Rules):
1446 (Reduced Automaton, Underivable Rules): Adjust.
1447 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
1448 * tests/conflicts.at (Unresolved SR Conflicts)
1449 (Solved SR Conflicts): Adjust.
1450
14512002-06-15 Akim Demaille <akim@epita.fr>
1452
1453 Let symbols have a location.
1454
1455 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
1456 (getsym): Adjust.
1457 Adjust all callers.
1458 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
1459 Use location_t, not int.
1460 * src/symtab.c (symbol_check_defined): Take advantage of the
1461 location.
1462 * tests/regression.at (Invalid inputs): Adjust.
1463
14642002-06-15 Akim Demaille <akim@epita.fr>
1465
1466 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
1467 (input): Don't try to initialize yylloc here, do it in the
1468 scanner.
1469 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
1470 * src/gram.h (rule_t): Change line and action_line into location
1471 and action_location, of location_t type.
1472 Adjust all dependencies.
1473 * src/location.h, src/location.c (empty_location): New.
1474 * src/reader.h, src/reader.c (grammar_start_symbol_set)
1475 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
1476 (grammar_current_rule_symbol_append)
1477 (grammar_current_rule_action_append): Expect a location as argument.
1478 * src/reader.c (grammar_midrule_action): Adjust to attach an
1479 action's location as dummy symbol location.
1480 * src/symtab.h, src/symtab.c (startsymbol_location): New.
1481 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
1482 the line numbers.
1483
14842002-06-14 Akim Demaille <akim@epita.fr>
1485
1486 Grammar declarations may be found in the grammar section.
1487
1488 * src/parse-gram.y (rules_or_grammar_declaration): New.
1489 (declarations): Each declaration may end with a semicolon, not
1490 just...
1491 (grammar_declaration): `"%union"'.
1492 (grammar): Branch to rules_or_grammar_declaration.
1493
14942002-06-14 Akim Demaille <akim@epita.fr>
1495
1496 * src/main.c (main): Invoke scanner_free.
1497
14982002-06-14 Akim Demaille <akim@epita.fr>
1499
1500 * src/output.c (m4_invoke): Extracted from...
1501 (output_skeleton): here.
1502 Free tempfile.
1503
15042002-06-14 Akim Demaille <akim@epita.fr>
1505
1506 * src/parse-gram.y (directives, directive, gram)
1507 (grammar_directives, precedence_directives, precedence_directive):
1508 Rename as...
1509 (declarations, declaration, grammar, grammar_declaration)
1510 (precedence_declaration, precedence_declarator): these.
1511 (symbol_declaration): New.
1512
15132002-06-14 Akim Demaille <akim@epita.fr>
1514
1515 * src/files.c (action_obstack): Remove, unused.
1516 (output_obstack): Remove it, and all its dependencies, as it is no
1517 longer needed.
1518 * src/reader.c (epilogue_set): Build the epilogue in the
1519 muscle_obstack.
1520 * src/output.h, src/output.c (muscle_obstack): Move to...
1521 * src/muscle_tab.h, src/muscle_tab.h: here.
1522 (muscle_init): Initialize muscle_obstack.
1523 (muscle_free): New.
1524 * src/main.c (main): Call it.
1525
15262002-06-14 Akim Demaille <akim@epita.fr>
1527
1528 * src/location.h: New, extracted from...
1529 * src/reader.h: here.
1530 * src/Makefile.am (noinst_HEADERS): Merge into
1531 (bison_SOURCES): this.
1532 Add location.h.
1533 * src/parse-gram.y: Use location_t instead of Bison's.
1534 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
1535 Use location_t instead of ints.
1536
15372002-06-14 Akim Demaille <akim@epita.fr>
1538
1539 * data/bison.simple, data/bison.c++: Be sure to restore the
1540 current #line when returning to the skeleton contents after having
1541 exposed the input file's #line.
1542
15432002-06-12 Akim Demaille <akim@epita.fr>
1544
1545 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
1546 eager.
1547 * tests/actions.at (Exotic Dollars): New.
1548
15492002-06-12 Akim Demaille <akim@epita.fr>
1550
1551 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
1552 ['"/] too eagerly.
1553 * tests/input.at (Torturing the Scanner): New.
1554
15552002-06-11 Akim Demaille <akim@epita.fr>
1556
1557 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
1558 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
1559 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
1560 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
1561 * src/reader.c (reader): Use it.
1562
15632002-06-11 Akim Demaille <akim@epita.fr>
1564
1565 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
1566 Adjust all callers.
1567 (scanner_last_string_free): New.
1568
15692002-06-11 Akim Demaille <akim@epita.fr>
1570
1571 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
1572 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
1573 (last_string, YY_OBS_FREE): New.
1574 Use them when returning an ID.
1575
15762002-06-11 Akim Demaille <akim@epita.fr>
1577
1578 Have Bison grammars parsed by a Bison grammar.
1579
1580 * src/reader.c, src/reader.h (prologue_augment): New.
1581 * src/reader.c (copy_definition): Remove.
1582
1583 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
1584 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
1585 (grammar_current_rule_prec_set, grammar_current_rule_check)
1586 (grammar_current_rule_symbol_append)
1587 (grammar_current_rule_action_append): Export.
1588 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
1589 (symbol_list_action_append): Remove.
1590 Hook the routines from reader.
1591 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
1592 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
1593
1594 * src/reader.c (read_declarations): Remove, unused.
1595
1596 * src/parse-gram.y: Handle the epilogue.
1597 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
1598 (grammar_start_symbol_set): this.
1599 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
1600 * src/reader.c (readgram): Remove, unused.
1601 (reader): Adjust to insert eoftoken and axiom where appropriate.
1602
1603 * src/reader.c (copy_dollar): Replace with...
1604 * src/scan-gram.h (handle_dollar): this.
1605 * src/parse-gram.y: Remove `%thong'.
1606
1607 * src/reader.c (copy_at): Replace with...
1608 * src/scan-gram.h (handle_at): this.
1609
1610 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
1611 New.
1612
1613 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
1614 time being.
1615
1616 * src/reader.h, src/reader.c (grammar_rule_end): New.
1617
1618 * src/parse.y (current_type, current_class): New.
1619 Implement `%nterm', `%token' support.
1620 Merge `%term' into `%token'.
1621 (string_as_id): New.
1622 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
1623 type name.
1624
1625 * src/parse-gram.y: Be sure to handle properly the beginning of
1626 rules.
1627
1628 * src/parse-gram.y: Handle %type.
1629 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
1630
1631 * src/parse-gram.y: More directives support.
1632 * src/options.c: No longer handle source directives.
1633
1634 * src/parse-gram.y: Fix %output.
1635
1636 * src/parse-gram.y: Handle %union.
1637 Use the prologue locations.
1638 * src/reader.c (parse_union_decl): Remove.
1639
1640 * src/reader.h, src/reader.c (epilogue_set): New.
1641 * src/parse-gram.y: Use it.
1642
1643 * data/bison.simple, data/bison.c++: b4_stype is now either not
1644 defined, then default to int, or to the contents of %union,
1645 without `union' itself.
1646 Adjust.
1647 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
1648
1649 * src/output.c (actions_output): Don't output braces, as they are
1650 already handled by the scanner.
1651
1652 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
1653 characters to themselves.
1654
1655 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
1656 that the epilogue has a proper #line.
1657
1658 * src/parse-gram.y: Handle precedence/associativity.
1659
1660 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
1661 a terminal.
1662 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
1663 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
1664 at all to define terminals that cannot be emitted.
1665
1666 * src/scan-gram.l: Escape M4 characters.
1667
1668 * src/scan-gram.l: Working properly with escapes in user
1669 strings/characters.
1670
1671 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
1672 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
1673 grammar.
1674 Use more modest sizes, as for the time being the parser does not
1675 release memory, and therefore the process swallows a huge amount
1676 of memory.
1677
1678 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
1679 stricter %token grammar.
1680
1681 * src/symtab.h (associativity): Add `undef_assoc'.
1682 (symbol_precedence_set): Do nothing when passed an undef_assoc.
1683 * src/symtab.c (symbol_check_alias_consistence): Adjust.
1684
1685 * tests/regression.at (Invalid %directive): Remove, as it is now
1686 meaningless.
1687 (Invalid inputs): Adjust to the new error messages.
1688 (Token definitions): The new grammar doesn't allow too many
1689 eccentricities.
1690
1691 * src/lex.h, src/lex.c: Remove.
1692 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1693 (copy_character, copy_string2, copy_string, copy_identifier)
1694 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1695 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1696 (parse_action): Remove.
1697 * po/POTFILES.in: Adjust.
1698
16992002-06-11 Akim Demaille <akim@epita.fr>
1700
1701 * src/reader.c (parse_action): Don't store directly into the
1702 rule's action member: return the action as a string.
1703 Don't require `rule_length' as an argument: compute it.
1704 (grammar_current_rule_symbol_append)
1705 (grammar_current_rule_action_append): New, eved out from
1706 (readgram): here.
1707 Remove `action_flag', `rulelength', unused now.
1708
17092002-06-11 Akim Demaille <akim@epita.fr>
1710
1711 * src/reader.c (grammar_current_rule_prec_set).
1712 (grammar_current_rule_check): New, eved out from...
1713 (readgram): here.
1714 Remove `xaction', `first_rhs': useless.
1715 * tests/input.at (Type clashes): New.
1716 * tests/existing.at (GNU Cim Grammar): Adjust.
1717
17182002-06-11 Akim Demaille <akim@epita.fr>
1719
1720 * src/reader.c (grammar_midrule_action): New, Eved out from
1721 (readgram): here.
1722
17232002-06-11 Akim Demaille <akim@epita.fr>
1724
1725 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1726 New.
1727 (readgram): Use them as replacement of inlined code, crule and
1728 crule1.
1729
17302002-06-11 Akim Demaille <akim@epita.fr>
1731
1732 * src/reader.c (grammar_end, grammar_symbol_append): New.
1733 (readgram): Use them.
1734 Make the use of `p' as local as possible.
1735
17362002-06-10 Akim Demaille <akim@epita.fr>
1737
1738 GCJ's parser requires the tokens to be defined before the prologue.
1739
1740 * data/bison.simple: Output the token definition before the user's
1741 prologue.
1742 * tests/regression.at (Braces parsing, Duplicate string)
1743 (Mixing %token styles): Check the output from bison.
1744 (Early token definitions): New.
1745
17462002-06-10 Akim Demaille <akim@epita.fr>
1747
1748 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1749 assigning twice the same user number to a token, so that we can
1750 use it in...
1751 * src/lex.c (lex): here.
1752 Also use `symbol_class_set' instead of hand written code.
1753 * src/reader.c (parse_assoc_decl): Likewise.
1754
17552002-06-10 Akim Demaille <akim@epita.fr>
1756
1757 * src/symtab.c, src/symtab.c (symbol_class_set)
1758 (symbol_user_token_number_set): New.
1759 * src/reader.c (parse_token_decl): Use them.
1760 Use a switch instead of ifs.
1761 Use a single argument.
1762
17632002-06-10 Akim Demaille <akim@epita.fr>
1764
1765 Remove `%thong' support as it is undocumented, unused, duplicates
1766 `%token's job, and creates useless e-mail traffic with people who
1767 want to know what it is, why it is undocumented, unused, and
1768 duplicates `%token's job.
1769
1770 * src/reader.c (parse_thong_decl): Remove.
1771 * src/options.c (option_table): Remove "thong".
1772 * src/lex.h (tok_thong): Remove.
1773
17742002-06-10 Akim Demaille <akim@epita.fr>
1775
1776 * src/symtab.c, src/symtab.c (symbol_type_set)
1777 (symbol_precedence_set): New.
1778 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1779 (value_components_used): Remove, unused.
1780
17812002-06-09 Akim Demaille <akim@epita.fr>
1782
1783 Move symbols handling code out of the reader.
1784
1785 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1786 (axiom): Move to...
1787 * src/symtab.h, src/symtab.c: here.
1788
1789 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1790 * src/reader.c (startval): Rename as...
1791 * src/symtab.h, src/symtab.c (startsymbol): this.
1792 * src/reader.c: Adjust.
1793
1794 * src/reader.c (symbol_check_defined, symbol_make_alias)
1795 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1796 (token_translations_init)
1797 Move to...
1798 * src/symtab.c: here.
1799 * src/reader.c (packsymbols): Move to...
1800 * src/symtab.h, src/symtab.c (symbols_pack): here.
1801 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1802 argument.
1803
18042002-06-03 Akim Demaille <akim@epita.fr>
1805
1806 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1807 then statements.
1808
18092002-06-03 Akim Demaille <akim@epita.fr>
1810
1811 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1812 structs with non literals.
1813 * src/scan-skel.l: never-interactive.
1814 * src/conflicts.c (enum conflict_resolution_e): No trailing
1815 comma.
1816 * src/getargs.c (usage): Split long literal strings.
1817 Reported by Hans Aberg.
1818
18192002-05-28 Akim Demaille <akim@epita.fr>
1820
1821 * data/bison.c++: Use C++ ostreams.
1822 (cdebug_): New member.
1823
18242002-05-28 Akim Demaille <akim@epita.fr>
1825
1826 * src/output.c (output_skeleton): Be sure to allocate enough room
1827 for `/' _and_ for `\0' in full_skeleton.
1828
18292002-05-28 Akim Demaille <akim@epita.fr>
1830
1831 * data/bison.c++: Catch up with bison.simple:
1832 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1833 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1834 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1835 and popping traces.
1836
18372002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1838
1839 * src/output.c (output_skeleton): Put an explicit path in front of
1840 the skeleton file name, rather than relying on the -I directory,
1841 to partially alleviate effects of having a skeleton file lying around
1842 in the current directory.
1843
18442002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1845
1846 * src/conflicts.c (log_resolution): Correct typo:
1847 obstack_printf should be obstack_fgrow1.
1848
18492002-05-26 Akim Demaille <akim@epita.fr>
1850
1851 * src/state.h (state_t): `solved_conflicts' is a new member.
1852 * src/LR0.c (new_state): Set it to 0.
1853 * src/conflicts.h, src/conflicts.c (print_conflicts)
1854 (free_conflicts, solve_conflicts): Rename as...
1855 (conflicts_print, conflicts_free, conflicts_solve): these.
1856 Adjust callers.
1857 * src/conflicts.c (enum conflict_resolution_e)
1858 (solved_conflicts_obstack): New, used by...
1859 (log_resolution): this.
1860 Adjust to attach the conflict resolution to each state.
1861 Complete the description with the precedence/associativity
1862 information.
1863 (resolve_sr_conflict): Adjust.
1864 * src/print.c (print_state): Output its solved_conflicts.
1865 * tests/conflicts.at (Unresolved SR Conflicts)
1866 (Solved SR Conflicts): Exercise --report=all.
1867
18682002-05-26 Akim Demaille <akim@epita.fr>
1869
1870 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1871 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1872 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1873 (token_number_t, item_number_as_token_number)
1874 (token_number_as_item_number, muscle_insert_token_number_table):
1875 Rename as...
1876 (symbol_number_t, item_number_as_symbol_number)
1877 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1878 these, since it is more appropriate.
1879
18802002-05-26 Akim Demaille <akim@epita.fr>
1881
1882 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1883 `Error:' lines.
1884 * data/bison.simple (yystos) [YYDEBUG]: New.
1885 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1886 error recovery.
1887 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1888
18892002-05-25 Akim Demaille <akim@epita.fr>
1890
1891 * doc/bison.texinfo (Debugging): Split into...
1892 (Tracing): this new section, its former contents, and...
1893 (Understanding): this new section.
1894 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1895 by...
1896 (report_flag): this.
1897 Adjust all dependencies.
1898 (report_args, report_types, report_argmatch): New.
1899 (usage, getargs): Report/support -r, --report.
1900 * src/options.h
1901 (struct option_table_struct): Rename as..,
1902 (struct option_table_s): this.
1903 Rename the `set_flag' member to `flag' to match with getopt_long's
1904 struct.
1905 * src/options.c (option_table): Split verbose into an entry for
1906 %verbose, and another for --verbose.
1907 Support --report/-r, so remove -r from the obsolete --raw.
1908 * src/print.c: Attach full item sets and lookaheads reports to
1909 report_flag instead of trace_flag.
1910 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1911
19122002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1913 and Paul Eggert <eggert@twinsun.com>
1914
1915 * data/bison.simple (yyparse): Correct error handling to conform to
1916 POSIX and yacc. Specifically, after syntax error is discovered,
1917 do not reduce further before shifting the error token.
1918 Clean up the code a bit by removing the labels yyerrdefault,
1919 yyerrhandle, yyerrpop.
1920 * NEWS: Document the above.
1921
19222002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1923
1924 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1925 type; it isn't always big enough, since it doesn't necessarily
1926 include non-terminals.
1927 (yytranslate): Expand definition of yy_token_number_type, so that
1928 the latter can be removed.
1929 (yy_token_number_type): Remove, only one use.
1930 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1931 don't use TokenNumberType as element type.
1932
1933 * tests/regression.at: Modify expected output to agree with change
1934 to yyr1 and yytranslate.
1935
19362002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1937
1938 * src/reader.c (parse_action): Use copy_character instead of
1939 obstack_1grow.
1940
19412002-05-13 Akim Demaille <akim@epita.fr>
1942
1943 * tests/regression.at (Token definitions): Prototype yylex and
1944 yyerror.
1945
19462002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1947
1948 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
1949 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1950 32-bit arithmetic.
1951 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1952
19532002-05-07 Akim Demaille <akim@epita.fr>
1954
1955 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1956 avoid GCC warnings.
1957
19582002-05-07 Akim Demaille <akim@epita.fr>
1959
1960 Kill GCC warnings.
1961
1962 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1963 over the RHS of each rule.
1964 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1965 * src/state.h (state_t): Member `nitems' is unsigned short.
1966 * src/LR0.c (get_state): Adjust.
1967 * src/reader.c (packgram): Likewise.
1968 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1969 `Type'.
1970 (muscle_insert_int_table): Remove, unused.
1971 (prepare_rules): Remove `max'.
1972
19732002-05-06 Akim Demaille <akim@epita.fr>
1974
1975 * src/closure.c (print_firsts): Display of the symbol tags.
1976 (bitmatrix_print): Move to...
1977 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1978 here.
1979 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1980
19812002-05-06 Akim Demaille <akim@epita.fr>
1982
1983 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1984 hash_do_for_each.
1985
19862002-05-06 Akim Demaille <akim@epita.fr>
1987
1988 * src/LR0.c (new_state, get_state): Instead of using the global
1989 `kernel_size' and `kernel_base', have two new arguments:
1990 `core_size' and `core'.
1991 Adjust callers.
1992
19932002-05-06 Akim Demaille <akim@epita.fr>
1994
1995 * src/reader.c (packgram): No longer end `ritem' with a 0
1996 sentinel: it is not used.
1997
19982002-05-05 Akim Demaille <akim@epita.fr>
1999
2000 New experimental feature: display the lookaheads in the report and
2001 graph.
2002
2003 * src/print (print_core): When --trace-flag, display the rules
2004 lookaheads.
2005 * src/print_graph.c (print_core): Likewise.
2006 Swap the arguments.
2007 Adjust caller.
2008
20092002-05-05 Akim Demaille <akim@epita.fr>
2010
2011 * tests/torture.at (Many lookaheads): New test.
2012
20132002-05-05 Akim Demaille <akim@epita.fr>
2014
2015 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2016 (GENERATE_MUSCLE_INSERT_TABLE): this.
2017 (output_int_table, output_unsigned_int_table, output_short_table)
2018 (output_token_number_table, output_item_number_table): Replace with...
2019 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2020 (muscle_insert_short_table, muscle_insert_token_number_table)
2021 (muscle_insert_item_number_table): these.
2022 Adjust all callers.
2023 (prepare_tokens): Don't free `translations', since...
2024 * src/reader.h, src/reader.c (grammar_free): do it.
2025 Move to...
2026 * src/gram.h, src/gram.c (grammar_free): here.
2027 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2028 b4_translate_max.
2029
20302002-05-05 Akim Demaille <akim@epita.fr>
2031
2032 * src/output.c (output_unsigned_int_table): New.
2033 (prepare_rules): `i' is unsigned.
2034 `prhs', `rline', `r2' are unsigned int.
2035 Rename muscle `rhs_number_max' as `rhs_max'.
2036 Output muscles `prhs_max', `rline_max', and `r2_max'.
2037 Free rline and r1.
2038 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2039 to compute types instead of constant types.
2040 * tests/regression.at (Web2c Actions): Adjust.
2041
20422002-05-04 Akim Demaille <akim@epita.fr>
2043
2044 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2045 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2046 Adjust dependencies.
2047 * src/output.c (token_definitions_output): Be sure not to output a
2048 `#define 'a'' when fed with `%token 'a' "a"'.
2049 * tests/regression.at (Token definitions): New.
2050
20512002-05-03 Paul Eggert <eggert@twinsun.com>
2052
2053 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2054 for K&R C.
2055
20562002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2057
2058 * Makefile.am (SUBDIRS): Remove intl.
2059 (EXTRA_DIST): Add config/config.rpath.
2060
20612002-05-03 Akim Demaille <akim@epita.fr>
2062
2063 * data/bison.simple (m4_if): Don't output empty enums.
2064 And actually, output valid enum definitions :(.
2065
20662002-05-03 Akim Demaille <akim@epita.fr>
2067
2068 * configure.bat: Remove, completely obsolete.
2069 * Makefile.am (EXTRA_DIST): Adjust.
2070 Don't distribute config.rpath...
2071 * config/Makefile.am (EXTRA_DIST): Do it.
2072
20732002-05-03 Akim Demaille <akim@epita.fr>
2074
2075 * configure.in (GETTEXT_VERSION): New.
2076 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2077
20782002-05-03 Akim Demaille <akim@epita.fr>
2079
2080 * data/bison.simple (b4_token_enum): New.
2081 (b4_token_defines): Use it to output tokens both as #define and
2082 enums.
2083 Suggested by Paul Eggert.
2084 * src/output.c (token_definitions_output): Don't output spurious
2085 white spaces.
2086
20872002-05-03 Akim Demaille <akim@epita.fr>
2088
2089 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2090
20912002-05-02 Robert Anisko <robert@lrde.epita.fr>
2092
2093 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2094 Update the stack class, give a try to deque as the default container.
2095
20962002-05-02 Akim Demaille <akim@epita.fr>
2097
2098 * data/bison.simple (yyparse): Do not implement @$ = @1.
2099 (YYLLOC_DEFAULT): Adjust to do it.
2100 * doc/bison.texinfo (Location Default Action): Fix.
2101
21022002-05-02 Akim Demaille <akim@epita.fr>
2103
2104 * src/reader.c (parse_braces): Merge into...
2105 (parse_action): this.
2106
21072002-05-02 Akim Demaille <akim@epita.fr>
2108
2109 * configure.in (ALL_LINGUAS): Remove.
2110 * po/LINGUAS, hr.po: New.
2111
21122002-05-02 Akim Demaille <akim@epita.fr>
2113
2114 Remove the so called hairy (semantic) parsers.
2115
2116 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2117 * src/gram.h, src/gram.c (semantic_parser): Remove.
2118 (rule_t): Remove the guard and guard_line members.
2119 * src/lex.h (token_t): remove tok_guard.
2120 * src/options.c (option_table): Remove %guard and %semantic_parser
2121 support.
2122 * src/output.c, src/output.h (guards_output): Remove.
2123 (prepare): Adjust.
2124 (token_definitions_output): Don't output the `T'
2125 tokens (???).
2126 (output_skeleton): Don't output the guards.
2127 * src/files.c, src/files.c (attrsfile): Remove.
2128 * src/reader.c (symbol_list): Remove the guard and guard_line
2129 members.
2130 Adjust dependencies.
2131 (parse_guard): Remove.
2132 * data/bison.hairy: Remove.
2133 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2134 BISON_HAIRY.
2135
21362002-05-02 Akim Demaille <akim@epita.fr>
2137
2138 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2139 (parse_guard): Rename the formal argument `stack_offset' as
2140 `rule_length', which is more readable.
2141 Adjust callers.
2142 (copy_at, copy_dollar): Instead of outputting the hard coded
2143 values of $$, $n and so forth, output invocation to b4_lhs_value,
2144 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
2145 Note: this patch partially drops `semantic-parser' support: it
2146 always does `rule_length - n', where semantic parsers ought to
2147 always use `-n'.
2148 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2149 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2150
21512002-05-02 Akim Demaille <akim@epita.fr>
2152
2153 * configure.in (AC_INIT): Bump to 1.49b.
2154 (AM_INIT_AUTOMAKE): Short invocation.
2155
21562002-05-02 Akim Demaille <akim@epita.fr>
2157
2158 Version 1.49a.
2159
21602002-05-01 Akim Demaille <akim@epita.fr>
2161
2162 * src/skeleton.h: Remove.
2163
21642002-05-01 Akim Demaille <akim@epita.fr>
2165
2166 * src/skeleton.h: Fix the #endif.
2167 Reported by Magnus Fromreide.
2168
21692002-04-26 Paul Eggert <eggert@twinsun.com>
2170
2171 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2172 Define if we define YYSTYPE and YYLTYPE, respectively.
2173 (YYCOPY): Fix [] quoting problem in the non-GCC case.
2174
21752002-04-25 Robert Anisko <robert@lrde.epita.fr>
2176
2177 * src/scan-skel.l: Postprocess quadrigraphs.
2178
2179 * src/reader.c (copy_character): New function, used to output
2180 single characters while replacing `[' and `]' with quadrigraphs, to
2181 avoid troubles with M4 quotes.
2182 (copy_comment): Output characters with copy_character.
2183 (read_additionnal_code): Likewise.
2184 (copy_string2): Likewise.
2185 (copy_definition): Likewise.
2186
2187 * tests/calc.at: Exercise M4 quoting.
2188
21892002-04-25 Akim Demaille <akim@epita.fr>
2190
2191 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2192 between `!' and the command.
2193 Reported by Paul Eggert.
2194
21952002-04-24 Robert Anisko <robert@lrde.epita.fr>
2196
2197 * tests/calc.at: Exercise prologue splitting.
2198
2199 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2200 `b4_post_prologue' instead of `b4_prologue'.
2201
2202 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2203 muscles.
2204 (output): Free pre_prologue_obstack and post_prologue_obstack.
2205 * src/files.h, src/files.c (attrs_obstack): Remove.
2206 (pre_prologue_obstack, post_prologue_obstack): New.
2207 * src/reader.c (copy_definition): Add a parameter to specify the
2208 obstack to fill, instead of using attrs_obstack unconditionally.
2209 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2210 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2211
22122002-04-23 Paul Eggert <eggert@twinsun.com>
2213
2214 * data/bison.simple: Remove unnecessary commentary and white
2215 space differences from 1_29-branch.
2216 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2217
2218 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2219 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2220 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2221 constructors or destructors.
2222
2223 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2224
22252002-04-23 Akim Demaille <akim@epita.fr>
2226
2227 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2228 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2229 location with columns.
2230 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2231 All reported by Paul Eggert.
2232
22332002-04-22 Akim Demaille <akim@epita.fr>
2234
2235 * src/reduce.c (dump_grammar): Move to...
2236 * src/gram.h, src/gram.c (grammar_dump): here.
2237 Be sure to separate long item numbers.
2238 Don't read the members of a rule's prec if its nil.
2239
22402002-04-22 Akim Demaille <akim@epita.fr>
2241
2242 * src/output.c (table_size, table_grow): New.
2243 (MAXTABLE): Remove, replace uses with table_size.
2244 (pack_vector): Instead of dying when the table is too big, grow it.
2245
22462002-04-22 Akim Demaille <akim@epita.fr>
2247
2248 * data/bison.simple (yyr1): Its type is that of a token number.
2249 * data/bison.c++ (r1_): Likewise.
2250 * tests/regression.at (Web2c Actions): Adjust.
2251
22522002-04-22 Akim Demaille <akim@epita.fr>
2253
2254 * src/reader.c (token_translations_init): 256 is now the default
2255 value for the error token, i.e., it will be assigned another
2256 number if the user assigned 256 to one of her tokens.
2257 (reader): Don't force 256 to error.
2258 * doc/bison.texinfo (Symbols): Adjust.
2259 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2260 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2261 etc. instead of 10, 20, 30 (which was used to `jump' over error
2262 (256) and undefined (2)).
2263
22642002-04-22 Akim Demaille <akim@epita.fr>
2265
2266 Propagate more token_number_t.
2267
2268 * src/gram.h (token_number_as_item_number)
2269 (item_number_as_token_number): New.
2270 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2271 Use it to create output_item_number_table and
2272 output_token_number_table.
2273 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2274 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2275 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2276 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2277
22782002-04-22 Akim Demaille <akim@epita.fr>
2279
2280 * src/output.h, src/output.c (get_lines_number): Remove.
2281
22822002-04-19 Akim Demaille <akim@epita.fr>
2283
2284 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2285 as Lex/Flex'.
2286 (Debugging): More details about enabling the debugging features.
2287 (Table of Symbols): Describe $$, $n, @$, and @n.
2288 Suggested by Tim Josling.
2289
22902002-04-19 Akim Demaille <akim@epita.fr>
2291
2292 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2293
22942002-04-10 Akim Demaille <akim@epita.fr>
2295
2296 * src/system.h: Rely on HAVE_LIMITS_H.
2297 Suggested by Paul Eggert.
2298
22992002-04-09 Akim Demaille <akim@epita.fr>
2300
2301 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2302 full stderr, and strip it according to the bison options, instead
2303 of composing the error message from different bits.
2304 This makes it easier to check for several error messages.
2305 Adjust all the invocations.
2306 Add an invocation exercising the error token.
2307 Add an invocation demonstrating a stupid error message.
2308 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2309 Adjust the tests.
2310 Error message are for stderr, not stdout.
2311
23122002-04-09 Akim Demaille <akim@epita.fr>
2313
2314 * src/gram.h, src/gram.c (error_token_number): Remove, use
2315 errtoken->number.
2316 * src/reader.c (reader): Don't specify the user token number (2)
2317 for $undefined, as it uselessly prevents using it.
2318 * src/gram.h (token_number_t): Move to...
2319 * src/symtab.h: here.
2320 (state_t.number): Is a token_number_t.
2321 * src/print.c, src/reader.c: Use undeftoken->number instead of
2322 hard coded 2.
2323 (Even though this 2 is not the same as above: the number of the
2324 undeftoken remains being 2, it is its user token number which
2325 might not be 2).
2326 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2327 `user_token_number_max'.
2328 Output `undef_token_number'.
2329 * data/bison.simple, data/bison.c++: Use them.
2330 Be sure to map invalid yylex return values to
2331 `undef_token_number'. This saves us from gratuitous SEGV.
2332
2333 * tests/conflicts.at (Solved SR Conflicts)
2334 (Unresolved SR Conflicts): Adjust.
2335 * tests/regression.at (Web2c Actions): Adjust.
2336
23372002-04-08 Akim Demaille <akim@epita.fr>
2338
2339 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2340 Adding #line.
2341 Remove the duplicate `typedefs'.
2342 (RhsNumberType): Fix the declaration and various other typos.
2343 Use __ofile__.
2344 * data/bison.simple: Use __ofile__.
2345 * src/scan-skel.l: Handle __ofile__.
2346
23472002-04-08 Akim Demaille <akim@epita.fr>
2348
2349 * src/gram.h (item_number_t): New, the type of item numbers in
2350 RITEM. Note that it must be able to code symbol numbers as
2351 positive number, and the negation of rule numbers as negative
2352 numbers.
2353 Adjust all dependencies (pretty many).
2354 * src/reduce.c (rule): Remove this `short *' pointer: use
2355 item_number_t.
2356 * src/system.h (MINSHORT, MAXSHORT): Remove.
2357 Include `limits.h'.
2358 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2359 (shortcpy): Remove.
2360 (MAXTABLE): Move to...
2361 * src/output.c (MAXTABLE): here.
2362 (prepare_rules): Use output_int_table to output rhs.
2363 * data/bison.simple, data/bison.c++: Adjust.
2364 * tests/torture.at (Big triangle): Move the limit from 254 to
2365 500.
2366 * tests/regression.at (Web2c Actions): Ajust.
2367
2368 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2369 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
2370 passes, but produces negative #line number, once fixed, GCC is
2371 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
2372 C), it passes.
2373 * src/state.h (state_h): Code input lines on ints, not shorts.
2374
23752002-04-08 Akim Demaille <akim@epita.fr>
2376
2377 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
2378 and then the grammar.
2379
23802002-04-08 Akim Demaille <akim@epita.fr>
2381
2382 * src/system.h: No longer using strndup.
2383
23842002-04-07 Akim Demaille <akim@epita.fr>
2385
2386 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
2387 * src/output.c (output_table_data): Return the longest number.
2388 (prepare_tokens): Output `token_number_max').
2389 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
2390 New.
2391 Use them to define yy_token_number_type/TokenNumberType.
2392 Use this type for yytranslate.
2393 * tests/torture.at (Big triangle): Push the limit from 124 to
2394 253.
2395 * tests/regression.at (Web2c Actions): Adjust.
2396
23972002-04-07 Akim Demaille <akim@epita.fr>
2398
2399 * tests/torture.at (Big triangle): New.
2400 (GNU AWK Grammar, GNU Cim Grammar): Move to...
2401 * tests/existing.at: here.
2402
24032002-04-07 Akim Demaille <akim@epita.fr>
2404
2405 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
2406 nritems.
2407 Adjust dependencies.
2408
24092002-04-07 Akim Demaille <akim@epita.fr>
2410
2411 * src/reader.c: Normalize increments to prefix form.
2412
24132002-04-07 Akim Demaille <akim@epita.fr>
2414
2415 * src/reader.c, symtab.c: Remove debugging code.
2416
24172002-04-07 Akim Demaille <akim@epita.fr>
2418
2419 Rename all the `bucket's as `symbol_t'.
2420
2421 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
2422 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
2423 * src/symtab.c, src/symtab.h (bucket): Rename as...
2424 (symbol_t): this.
2425 (symbol_list_new, bucket_check_defined, bucket_make_alias)
2426 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
2427 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2428 (buckets_new, buckets_free, buckets_do): Rename as...
2429 (symbol_list_new, symbol_check_defined, symbol_make_alias)
2430 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2431 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
2432 (symbols_new, symbols_free, symbols_do): these.
2433
24342002-04-07 Akim Demaille <akim@epita.fr>
2435
2436 Use lib/hash for the symbol table.
2437
2438 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
2439 EOF.
2440 * src/lex.c (lex): Set the `number' member of new terminals.
2441 * src/reader.c (bucket_check_defined, bucket_make_alias)
2442 (bucket_check_alias_consistence, bucket_translation): New.
2443 (reader, grammar_free, readgram, token_translations_init)
2444 (packsymbols): Adjust.
2445 (reader): Number the predefined tokens.
2446 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
2447 for predefined tokens.
2448 * src/symtab.h (bucket): Remove all the hash table related
2449 members.
2450 * src/symtab.c (symtab): Replace by...
2451 (bucket_table): this.
2452 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2453 (buckets_new, buckets_do): New.
2454
24552002-04-07 Akim Demaille <akim@epita.fr>
2456
2457 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
2458 (start_symbol, max_user_token_number, semantic_parser)
2459 (error_token_number): Initialize.
2460 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
2461 Initialize.
2462 (reader): Don't.
2463 (errtoken, eoftoken, undeftoken, axiom): Extern.
2464
24652002-04-07 Akim Demaille <akim@epita.fr>
2466
2467 * src/gram.h (rule_s): prec and precsym are now pointers
2468 to the bucket giving the priority/associativity.
2469 Member `associativity' removed: useless.
2470 * src/reduce.c, src/conflicts.c: Adjust.
2471
24722002-04-07 Akim Demaille <akim@epita.fr>
2473
2474 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
2475 Properly escape the symbols' TAG when outputting them.
2476
24772002-04-07 Akim Demaille <akim@epita.fr>
2478
2479 * src/lalr.h (LA): Is a bitsetv, not bitset*.
2480
24812002-04-07 Akim Demaille <akim@epita.fr>
2482
2483 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
2484 (LArule): this, which is an array to rule_t*.
2485 * src/print.c, src/conflicts.c: Adjust.
2486
24872002-04-07 Akim Demaille <akim@epita.fr>
2488
2489 * src/gram.h (rule_t): Rename `number' as `user_number'.
2490 `number' is a new member.
2491 Adjust dependencies.
2492 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
2493
24942002-04-07 Akim Demaille <akim@epita.fr>
2495
2496 As a result of the previous patch, it is no longer needed
2497 to reorder ritem itself.
2498
2499 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
2500
25012002-04-07 Akim Demaille <akim@epita.fr>
2502
2503 Be sure never to walk through RITEMS, but use only data related to
2504 the rules themselves. RITEMS should be banished.
2505
2506 * src/output.c (output_token_translations): Rename as...
2507 (prepare_tokens): this.
2508 In addition to `translate', prepare the muscles `tname' and
2509 `toknum', which were handled by...
2510 (output_rule_data): this.
2511 Remove, and move the remainder of its outputs into...
2512 (prepare_rules): this new routines, which also merges content from
2513 (output_gram): this.
2514 (prepare_rules): Be sure never to walk through RITEMS.
2515 (output_stos): Rename as...
2516 (prepare_stos): this.
2517 (output): Always invoke prepare_states, after all, just don't use it
2518 in the output if you don't need it.
2519
25202002-04-07 Akim Demaille <akim@epita.fr>
2521
2522 * src/LR0.c (new_state): Display `nstates' as the name of the
2523 newly created state.
2524 Adjust to initialize first_state and last_state if needed.
2525 Be sure to distinguish the initial from the final state.
2526 (new_states): Create the itemset of the initial state, and use
2527 new_state.
2528 * src/closure.c (closure): Now that the initial state has its
2529 items properly set, there is no need for a special case when
2530 creating `ruleset'.
2531
2532 As a result, now the rule 0, reducing to $axiom, is visible in the
2533 outputs. Adjust the test suite.
2534
2535 * tests/conflicts.at (Solved SR Conflicts)
2536 (Unresolved SR Conflicts): Adjust.
2537 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
2538 * tests/conflicts.at (S/R in initial): New.
2539
25402002-04-07 Akim Demaille <akim@epita.fr>
2541
2542 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
2543 the RHS of the rules.
2544 * src/output.c (output_gram): Likewise.
2545
25462002-04-07 Akim Demaille <akim@epita.fr>
2547
2548 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
2549 bucket.
2550 Adjust all dependencies.
2551 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
2552 `number' of the buckets too.
2553 * src/gram.h: Include `symtab.h'.
2554 (associativity): Move to...
2555 * src/symtab.h: here.
2556 No longer include `gram.h'.
2557
25582002-04-07 Akim Demaille <akim@epita.fr>
2559
2560 * src/gram.h, src/gram.c (rules_rhs_length): New.
2561 (ritem_longest_rhs): Use it.
2562 * src/gram.h (rule_t): `number' is a new member.
2563 * src/reader.c (packgram): Set it.
2564 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
2565 the end of `rules', and count them out of `nrules'.
2566 (reduce_output, dump_grammar): Adjust.
2567 * src/print.c (print_grammar): It is no longer needed to check for
2568 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
2569 * tests/reduce.at (Reduced Automaton): New test.
2570
25712002-04-07 Akim Demaille <akim@epita.fr>
2572
2573 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
2574 lacking `+ 1' to nrules, Bison reported as useless a token if it
2575 was used solely to set the precedence of the last rule...
2576
25772002-04-07 Akim Demaille <akim@epita.fr>
2578
2579 * data/bison.c++, data/bison.simple: Don't output the current file
2580 name in #line, to avoid useless diffs between two identical
2581 outputs under different names.
2582
25832002-04-07 Akim Demaille <akim@epita.fr>
2584
2585 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
2586 Normalize loops to using `< nrules + 1', not `<= nrules'.
2587
25882002-04-07 Akim Demaille <akim@epita.fr>
2589
2590 * TODO: Update.
2591
25922002-04-07 Akim Demaille <akim@epita.fr>
2593
2594 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
2595 bucket.value as bucket.number.
2596
25972002-04-07 Akim Demaille <akim@epita.fr>
2598
2599 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
2600 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2601 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
2602 RHS, instead of being an index in RITEMS.
2603
26042002-04-04 Paul Eggert <eggert@twinsun.com>
2605
2606 * doc/bison.texinfo: Update copyright date.
2607 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
2608 (Symbols): Warn about running Bison in one character set,
2609 but compiling and/or running in an incompatible one.
2610 Warn about character code 256, too.
2611
26122002-04-03 Paul Eggert <eggert@twinsun.com>
2613
2614 * src/bison.data (YYSTACK_ALLOC): Depend on whether
2615 YYERROR_VERBOSE is nonzero, not whether it is defined.
2616
2617 Merge changes from bison-1_29-branch.
2618
26192002-03-20 Paul Eggert <eggert@twinsun.com>
2620
2621 Merge fixes from Debian bison_1.34-1.diff.
2622
2623 * configure.in (AC_PREREQ): 2.53.
2624
26252002-03-20 Akim Demaille <akim@epita.fr>
2626
2627 * src/conflicts.c (log_resolution): Argument `resolution' is const.
2628
26292002-03-19 Paul Eggert <eggert@twinsun.com>
2630
2631 * src/bison.simple (YYCOPY): New macro.
2632 (YYSTACK_RELOCATE): Use it.
2633 Remove Type arg; no longer needed. All callers changed.
2634 (yymemcpy): Remove; no longer needed.
2635
2636 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
2637 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
2638
26392002-03-19 Akim Demaille <akim@epita.fr>
2640
2641 Test and fix the #line outputs.
2642
2643 * tests/atlocal.at (GCC): New.
2644 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
2645 (Prologue synch line, ,%union synch line, Postprologue synch line)
2646 (Action synch line, Epilogue synch line): New tests.
2647 * src/reader.c (parse_union_decl): Define the muscle stype_line.
2648 * data/bison.simple, data/bison.c++: Use it.
2649
26502002-03-19 Akim Demaille <akim@epita.fr>
2651
2652 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
2653 (Solved SR Conflicts, %expect not enough, %expect right)
2654 (%expect too much): Move to...
2655 * tests/conflicts.at: this new file.
2656
26572002-03-19 Akim Demaille <akim@epita.fr>
2658
2659 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2660 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
2661 that we can move to enums for instance.
2662 * src/output.c (token_definitions_output): Output a list of
2663 `token-name, token-number' instead of the #define.
2664 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
2665
26662002-03-14 Akim Demaille <akim@epita.fr>
2667
2668 Use Gettext 0.11.1.
2669
26702002-03-09 Robert Anisko <robert@lrde.epita.fr>
2671
2672 * data/bison.c++: Make the user able to add members to the generated
2673 parser by subclassing.
2674
26752002-03-05 Robert Anisko <robert@lrde.epita.fr>
2676
2677 * src/reader.c (read_additionnal_code): `c' should be an integer, not
2678 a character.
2679 Reported by Nicolas Tisserand and Nicolas Burrus.
2680
26812002-03-04 Robert Anisko <robert@lrde.epita.fr>
2682
2683 * src/reader.c: Warn about lacking semi-colons, do not complain.
2684
26852002-03-04 Robert Anisko <robert@lrde.epita.fr>
2686
2687 * data/bison.c++: Remove a debug line.
2688
26892002-03-04 Robert Anisko <robert@lrde.epita.fr>
2690
2691 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2692 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2693 provide a default implementation.
2694
26952002-03-04 Akim Demaille <akim@epita.fr>
2696
2697 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2698 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2699 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2700 * tests/semantic.at (Parsing Guards): Similarly.
2701 * src/reader.at (readgram): Complain if the last rule is not ended
2702 with a semi-colon.
2703
27042002-03-04 Akim Demaille <akim@epita.fr>
2705
2706 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2707 * src/closure.c: here.
2708 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2709 RTC.
2710 * src/warshall.h, src/warshall.c: Remove.
2711 * tests/sets.at (Broken Closure): Adjust.
2712
27132002-03-04 Akim Demaille <akim@epita.fr>
2714
2715 * src/output.c (output_skeleton): tempdir is const.
2716 bytes_read is unused.
2717
27182002-03-04 Akim Demaille <akim@epita.fr>
2719
2720 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2721 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2722 Update.
2723 From Michael Hayes.
2724
27252002-03-04 Akim Demaille <akim@epita.fr>
2726
2727 * src/closure.c (closure): `r' is unused.
2728
27292002-03-04 Akim Demaille <akim@epita.fr>
2730
2731 * tests/sets.at (Broken Closure): Add the ending `;'.
2732 * src/reader.at (readgram): Complain if a rule is not ended with a
2733 semi-colon.
2734
27352002-03-04 Akim Demaille <akim@epita.fr>
2736
2737 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2738 (count_sr_conflicts): Use bitset_count.
2739 * src/reduce.c (inaccessable_symbols): Ditto.
2740 (bits_size): Remove.
2741 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2742
27432002-03-04 Akim Demaille <akim@epita.fr>
2744
2745 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2746 * src/reduce.c: Remove the `bitset_zero's following the
2747 `bitset_create's, as now it is performed by the latter.
2748
27492002-03-04 Akim Demaille <akim@epita.fr>
2750
2751 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2752 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2753 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2754 latest sources from Michael.
2755
27562002-03-04 Akim Demaille <akim@epita.fr>
2757
2758 * src/output.c (output): Don't free the grammar.
2759 * src/reader.c (grammar_free): New.
2760 * src/main.c (main): Call it and don't free symtab here.
2761
27622002-03-04 Akim Demaille <akim@epita.fr>
2763
2764 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2765 before returning.
2766 Reported by Benoit Perrot.
2767
27682002-03-04 Akim Demaille <akim@epita.fr>
2769
2770 Use bitset operations when possible, not loops over bits.
2771
2772 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2773 bitset_or.
2774 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2775 * src/reduce.c (useless_nonterminals): Formatting changes.
2776 * src/warshall.c (TC): Use bitset_or.
2777
27782002-03-04 Akim Demaille <akim@epita.fr>
2779
2780 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2781 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2782 Ditto.
2783
27842002-03-04 Akim Demaille <akim@epita.fr>
2785
2786 * src/lalr.c (F): Now a bitset*.
2787 Adjust all dependencies.
2788
27892002-03-04 Akim Demaille <akim@epita.fr>
2790
2791 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2792 Adjust all dependencies.
2793
27942002-03-04 Akim Demaille <akim@epita.fr>
2795
2796 * src/L0.c, src/LR0.h (nstates): Be size_t.
2797 Adjust comparisons (signed vs unsigned).
2798 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2799 bitset*.
2800 Adjust all dependencies.
2801
28022002-03-04 Akim Demaille <akim@epita.fr>
2803
2804 * src/closure.c (firsts): Now, also a bitset.
2805 Adjust all dependencies.
2806 (varsetsize): Remove, now unused.
2807 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2808
28092002-03-04 Akim Demaille <akim@epita.fr>
2810
2811 * src/print.c: Convert to use bitset.h, not hand coded iterations
2812 over ints.
2813
28142002-03-04 Akim Demaille <akim@epita.fr>
2815
2816 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2817
28182002-03-04 Akim Demaille <akim@epita.fr>
2819
2820 * src/closure.c (ruleset): Be a bitset.
2821 (rulesetsize): Remove.
2822
28232002-03-04 Akim Demaille <akim@epita.fr>
2824
2825 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2826 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2827 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2828 * src/closure.c (fderives): Be an array of bitsets.
2829
28302002-02-28 Robert Anisko <robert@lrde.epita.fr>
2831
2832 * data/bison.c++: Merge the two generated headers. Insert a copyright
2833 notice in each output file.
2834
28352002-02-28 Akim Demaille <akim@epita.fr>
2836
2837 * data/bison.c++: Copy the prologue of bison.simple to fetch
2838 useful M4 definitions, such as b4_header_guard.
2839
28402002-02-25 Akim Demaille <akim@epita.fr>
2841
2842 * src/getargs.c (version): Give the name of the authors, and use a
2843 translator friendly scheme for the bgr
2844 copyright notice.
2845
28462002-02-25 Akim Demaille <akim@epita.fr>
2847
2848 * src/output.c (header_output): Remove, now handled completely via
2849 M4.
2850
28512002-02-25 Akim Demaille <akim@epita.fr>
2852
2853 * m4/m4.m4: New, from CVS Autoconf.
2854 * configure.in: Invoke it.
2855 * src/output.c (output_skeleton): Use its result instead of the
2856 hard coded name.
2857
28582002-02-25 Akim Demaille <akim@epita.fr>
2859
2860 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2861 Fileutils 4.1.5.
2862 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2863 * src/output.c (output_skeleton): Use mkstemp to create a real
2864 temporary file.
2865 Move the filling of `skeleton' and its muscle to...
2866 (prepare): here.
2867 (output): Move the definition of the prologue muscle to...
2868 (prepare): here.
2869 * src/system.h (DEFAULT_TMPDIR): New.
2870
28712002-02-14 Paul Eggert <eggert@twinsun.com>
2872
2873 Remove the support for C++ namespace cleanliness; it was
2874 causing more problems than it was curing, since it didn't work
2875 properly on some nonstandard C++ compilers. This can wait
2876 for a proper C++ parser.
2877
2878 * NEWS: Document this.
2879 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2880 of C++, as it's treated like C now.
2881 * src/bison.simple (YYSTD): Remove.
2882 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2883 Treat C++ just like Standard C instead of trying to support
2884 namespace cleanliness.
2885
28862002-02-14 Akim Demaille <akim@epita.fr>
2887
2888 * tests/regression.at (else): Adjust to Andreas' change.
2889
28902002-02-14 Akim Demaille <akim@epita.fr>
2891
2892 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2893
28942002-02-13 Andreas Schwab <schwab@suse.de>
2895
2896 * src/output.c (output_rule_data): Don't output NULL, it might
2897 not be defined yet.
2898
28992002-02-11 Robert Anisko <robert@lrde.epita.fr>
2900
2901 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2902 (Copyright notice): Update.
2903
29042002-02-11 Akim Demaille <akim@epita.fr>
2905
2906 * tests/regression.at (%nonassoc and eof): Don't include
2907 nonportable headers.
2908
29092002-02-08 Robert Anisko <robert@lrde.epita.fr>
2910
2911 * data/bison.c++: Correct error recovery. Make the user able to
2912 initialize the starting location.
2913
29142002-02-07 Akim Demaille <akim@epita.fr>
2915
2916 * tests/input.at: New.
2917
29182002-02-07 Robert Anisko <robert@lrde.epita.fr>
2919
2920 * data/bison.c++: Replace some direct m4 expansions by constants. Be
2921 more consistent when naming methods and variables. Put preprocessor
2922 directives around tables only needed for debugging.
2923
29242002-02-07 Robert Anisko <robert@lrde.epita.fr>
2925
2926 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2927 C++ parsers.
2928 (yy::b4_name::parse): Use print_.
2929
29302002-02-07 Robert Anisko <robert@lrde.epita.fr>
2931
2932 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2933
29342002-02-07 Robert Anisko <robert@lrde.epita.fr>
2935
2936 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2937 C++ parsers.
2938 (yy::b4_name::parse): Build verbose error messages, and use error_.
2939
29402002-02-06 Robert Anisko <robert@lrde.epita.fr>
2941
2942 * data/bison.c++: Fix m4 quoting in comments.
2943
29442002-02-06 Robert Anisko <robert@lrde.epita.fr>
2945
2946 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2947 not expanded by m4.
2948
29492002-02-05 Akim Demaille <akim@epita.fr>
2950
2951 * data/bison.c++: Adjust to the M4 back end.
2952 More is certainly needed.
2953
29542002-02-05 Akim Demaille <akim@epita.fr>
2955
2956 Give a try to M4 as a back end.
2957
2958 * lib/readpipe.c: New, from wdiff.
2959 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2960 BISON_HAIRY.
2961 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2962 specific values. Now it is m4 that performs the lookup.
2963 * src/parse-skel.y: Remove.
2964 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2965 * src/output.c (actions_output, guards_output)
2966 (token_definitions_output): No longer keeps track of the output
2967 line number, hence remove the second argument.
2968 (guards_output): Check against the guard member of a rule, not the
2969 action member.
2970 Adjust callers.
2971 (output_skeleton): Don't look for the skeleton location, let m4 do
2972 that.
2973 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2974 file will be used.
2975 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2976 (prepare): Given that for the time being changesyntax is not
2977 usable in M4, rename the muscles using `-' to `_'.
2978 Define `defines_flag', `output_parser_name' and `output_header_name'.
2979 * src/output.h (actions_output, guards_output)
2980 (token_definitions_output): Adjust prototypes.
2981 * src/scan-skel.l: Instead of scanning the skeletons, it now
2982 processes the output of m4: `__oline__' and `#output'.
2983 * data/bison.simple: Adjust to be used by M4(sugar).
2984 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2985 to date.
2986 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2987 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2988 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2989 shamelessly stolen from CVS Autoconf.
2990
29912002-02-05 Akim Demaille <akim@epita.fr>
2992
2993 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2994 * configure.in: Check for the declarations of free and malloc.
2995 * src/muscle_tab.c: Adjust.
2996
29972002-02-05 Akim Demaille <akim@epita.fr>
2998
2999 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3000 which have no values.
3001
30022002-02-05 Akim Demaille <akim@epita.fr>
3003
3004 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3005 * data/: here.
3006
30072002-01-29 Paul Eggert <eggert@twinsun.com>
3008
3009 * src/bison.simple (YYSIZE_T): Do not define merely because
3010 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3011 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3012
30132002-01-27 Akim Demaille <akim@epita.fr>
3014
3015 Fix `%nonassoc and eof'.
3016
3017 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3018 which were not properly copied! Replace
3019 memcpy (res->errs, src->errs, src->nerrs);
3020 with
3021 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3022 !!!
3023 * tests/regression.at (%nonassoc and eof): Adjust to newest
3024 Autotest: `.' is not in the PATH.
3025
30262002-01-27 Akim Demaille <akim@epita.fr>
3027
3028 * tests/sets.at (AT_EXTRACT_SETS): New.
3029 (Nullable): Use it.
3030 (Firsts): New.
3031
30322002-01-26 Akim Demaille <akim@epita.fr>
3033
3034 * tests/actions.at, tests/calc.at, tests/headers.at,
3035 * tests/torture.at: Adjust to the newest Autotest which no longer
3036 forces `.' in the PATH.
3037
30382002-01-25 Akim Demaille <akim@epita.fr>
3039
3040 * tests/regression.at (%nonassoc and eof): New.
3041 Suggested by Robert Anisko.
3042
30432002-01-24 Akim Demaille <akim@epita.fr>
3044
3045 Bison dumps core when trying to complain about broken input files.
3046 Reported by Cris van Pelt.
3047
3048 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3049 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3050 into...
3051 (Invalid inputs): Strengthen: exercise parse_percent_token.
3052
30532002-01-24 Robert Anisko <robert.anisko@epita.fr>
3054
3055 * src/Makefile.am: Add bison.c++.
3056 * src/bison.c++: New skeleton.
3057
30582002-01-21 Paolo Bonzini <bonzini@gnu.org>
3059
3060 * po/it.po: New.
3061
30622002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3063
3064 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3065
30662002-01-20 Marc Autret <marc@gnu.org>
3067
3068 * src/files.c (compute_output_file_names): Fix
3069
30702002-01-20 Marc Autret <marc@gnu.org>
3071
3072 * tests/output.at: New test.
3073 * src/files.c (compute_base_names): Don't map extensions when
3074 the YACC flag is set, use defaults.
3075 Reported by Evgeny Stambulchik.
3076
30772002-01-20 Marc Autret <marc@gnu.org>
3078
3079 * src/system.h: Need to define __attribute__ away for non-GCC
3080 compilers as well (i.e. the vendor C compiler).
3081 Suggested by Albert Chin-A-Young.
3082
30832002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3084
3085 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3086 canonical definition.
3087 * src/system.h: Use the canonical definition for PARAMS (avoids
3088 a conflict with the macro from lib/hash.h).
3089
30902002-01-11 Akim Demaille <akim@epita.fr>
3091
3092 * configure.in: Use AC_FUNC_STRNLEN.
3093 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
3094
30952002-01-09 Akim Demaille <akim@epita.fr>
3096
3097 * src/files.c, src/files.h (output_infix): New.
3098 (tab_extension): Remove.
3099 (compute_base_names): Compute the former, drop the latter.
3100 * src/output.c (prepare): Insert the muscles `output-infix', and
3101 `output-suffix'.
3102 * src/parse-skel.y (string, string.1): New.
3103 (section.header): Use it.
3104 (section.yacc): Remove.
3105 (prefix): Remove too.
3106 * src/scan-skel.l: Adjust.
3107 * src/bison.simple, src/bison.hairy: Adjust.
3108
31092002-01-09 Akim Demaille <akim@epita.fr>
3110
3111 * configure.in (WERROR_CFLAGS): Compute it.
3112 * src/Makefile.am (CFLAGS): Pass it.
3113 * tests/atlocal.in (CFLAGS): Idem.
3114 * src/files.c: Fix a few warnings.
3115 (get_extension_index): Remove, unused.
3116
31172002-01-08 Akim Demaille <akim@epita.fr>
3118
3119 * src/getargs.c (AS_FILE_NAME): New.
3120 (getargs): Use it to convert DOSish file names.
3121 * src/files.c (base_name): Rename as full_base_name to avoid
3122 clashes with `base_name ()'.
3123 (filename_split): New.
3124 (compute_base_names): N-th rewrite, using filename_split.
3125
31262002-01-08 Akim Demaille <akim@epita.fr>
3127
3128 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3129 New, stolen from the Fileutils 4.1.
3130 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3131 * configure.in: Check for the presence of memrchr, and of its
3132 prototype.
3133
31342002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3135
3136 * lib/hash.h (__P): Added definition for this macro.
3137 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3138 BUILT_SOURCES, to ensure they are generated first.
3139 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3140 %error-verbose to allow bootstrapping with bison 1.30x.
3141
31422002-01-06 Akim Demaille <akim@epita.fr>
3143
3144 * src/reader.c (parse_braces): Don't fetch the next char, the
3145 convention is to fetch on entry.
3146 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3147 'switch' without a following semicolon.
3148 * tests/regression.at (braces parsing): New.
3149
31502002-01-06 Akim Demaille <akim@epita.fr>
3151
3152 Bison is dead wrong in its RR conflict reports.
3153
3154 * tests/torture.at (GNU Cim Grammar): New.
3155 * src/conflicts.c (count_rr_conflicts): Fix.
3156
31572002-01-06 Akim Demaille <akim@epita.fr>
3158
3159 Creating package.m4 from configure.ac causes too many problems.
3160
3161 * tests/Makefile.am (package.m4): Create it by hand,
3162 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3163
31642002-01-06 Akim Demaille <akim@epita.fr>
3165
3166 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3167 skeleton.h.
3168
31692002-01-04 Paul Eggert <eggert@twinsun.com>
3170
3171 * doc/bison.texinfo (Debugging):
3172 Remove YYSTDERR; it's no longer defined or used.
3173 Also, s/cstdio.h/cstdio/.
3174
31752002-01-03 Akim Demaille <akim@epita.fr>
3176
3177 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3178
31792002-01-03 Akim Demaille <akim@epita.fr>
3180
3181 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3182 tracing code to --trace, wait for a better --trace option, with
3183 args.
3184
31852002-01-03 Akim Demaille <akim@epita.fr>
3186
3187 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3188 The ISO C++ standard is extremely clear about it: stderr is
3189 considered a macro, not a regular symbol (see table 94 `Header
3190 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3191 Therefore std:: does not apply to it. It still does with fprintf.
3192 Also, s/cstdio.h/cstdio/.
3193
31942002-01-03 Akim Demaille <akim@epita.fr>
3195
3196 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3197 for non system headers.
3198
31992002-01-02 Akim Demaille <akim@epita.fr>
3200
3201 Equip the skeleton chain with location tracking, runtime trace,
3202 pure parser and scanner.
3203
3204 * src/parse-skel.y: Request a pure parser, locations, and prefix
3205 renaming.
3206 (%union): Having several members with the same type does not help
3207 type mismatches, simplify.
3208 (YYPRINT, yyprint): New.
3209 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3210 (skel_error): this.
3211 Handle locations.
3212 * src/scan-skel.l: Adjust to these changes.
3213 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3214 (LOCATION_PRINT, skel_control_t): New.
3215
32162001-12-30 Akim Demaille <akim@epita.fr>
3217
3218 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3219 replace `gb' with BLANKS.
3220 * src/scan-skel.l: Adjust.
3221
32222001-12-30 Akim Demaille <akim@epita.fr>
3223
3224 * src/system.h: We don't need nor want bcopy.
3225 Throw away MS-DOS crap: we don't need getpid.
3226 * configure.in: We don't need strndup. It was even causing
3227 problems: because Flex includes the headers *before* us,
3228 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3229 not visible.
3230 * lib/xstrndup.c: New.
3231 * src/scan-skel.l: Use it.
3232 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3233 * src/parse-skel.y: Use %directives instead of #defines.
3234
32352001-12-30 Akim Demaille <akim@epita.fr>
3236
3237 * src/skeleton.h: New.
3238 * src/output.c (output_parser, output_master_parser): Remove, dead
3239 code.
3240 * src/output.h (get_lines_number, actions_output, guards_output)
3241 (token_definitions_output): Prototype them.
3242 * src/parse-skel.y: Add the license notice.
3243 Include output.h and skeleton.h.
3244 (process_skeleton): Returns void, and takes a single parameter.
3245 * src/scan-skel.l: Add the license notice.
3246 Include skeleton.h.
3247 Don't use %option yylineno: it seems that then Flex imagines
3248 REJECT has been used, and therefore it won't reallocate its
3249 buffers (which makes no other sense to me than a bug). It results
3250 in warnings for `unused: yy_flex_realloc'.
3251
32522001-12-30 Robert Anisko <robert.anisko@epita.fr>
3253
3254 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3255 (MUSCLE_INSERT_PREFIX): ...to there.
3256 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3257 (MUSCLE_INSERT_PREFIX): Move from here...
3258
3259 * src/bison.hairy: Add a section directive. Put braces around muscle
3260 names. This parser skeleton is still broken, but Bison should not
3261 choke on a bad muscle 'syntax'.
3262 * src/bison.simple: Add a section directive. Put braces around muscle
3263 names.
3264
3265 * src/files.h (strsuffix, stringappend): Add declarations.
3266 (tab_extension): Add declaration.
3267 (short_base_name): Add declaration.
3268
3269 * src/files.c (strsuffix, stringappend): No longer static. These
3270 functions are used in the skeleton parser.
3271 (tab_extension): New.
3272 (compute_base_names): Use the computations done in this function
3273 to guess if the generated parsers should have '.tab' in their
3274 names.
3275 (short_base_name): No longer static.
3276
3277 * src/output.c (output_skeleton): New.
3278 (output): Disable call to output_master_parser, and give a try to
3279 a new skeleton handling system.
3280 (guards_output, actions_output): No longer static.
3281 (token_definitions_output, get_lines_number): No longer static.
3282
3283 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3284
3285 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
3286 parse-skel.y.
3287
3288 * src/parse-skel.y: New file.
3289 * src/scan-skel.l: New file.
3290
32912001-12-29 Akim Demaille <akim@epita.fr>
3292
3293 %name-prefix is broken.
3294
3295 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3296 Adjust all dependencies.
3297 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3298 %name-prefix.
3299
3300 Renaming yylval but not yylloc is not consistent. Now we do.
3301
3302 * src/bison.simple: Prefix yylloc if used.
3303 * doc/bison.texinfo (Decl Summary): Document that.
3304
33052001-12-29 Akim Demaille <akim@epita.fr>
3306
3307 * doc/bison.texinfo: Promote `%long-directive' over
3308 `%long_directive'.
3309 Remove all references to fixed-output-files, yacc is enough.
3310
33112001-12-29 Akim Demaille <akim@epita.fr>
3312
3313 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3314 user prologue. These are defaults.
3315 * tests/actions.at (Mid-rule actions): Make sure the user can
3316 define YYDEBUG and YYERROR_VERBOSE.
3317
33182001-12-29 Akim Demaille <akim@epita.fr>
3319
3320 * src/output.c (header_output): Don't forget to export YYLTYPE and
3321 yylloc.
3322 * tests/headers.at (export YYLTYPE): New, make sure it does.
3323 * tests/regression.at (%union and --defines, Invalid CPP headers):
3324 Move to...
3325 * tests/headers.at: here.
3326
33272001-12-29 Akim Demaille <akim@epita.fr>
3328
3329 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3330
33312001-12-29 Akim Demaille <akim@epita.fr>
3332
3333 * tests/actions.at (Mid-rule actions): Output on a single line
3334 instead of several.
3335
33362001-12-29 Akim Demaille <akim@epita.fr>
3337
3338 * doc/bison.texinfo: Formatting changes.
3339
33402001-12-29 Akim Demaille <akim@epita.fr>
3341
3342 Don't store the token defs in a muscle, just be ready to output it
3343 on command. Now possible via `symbols'. Fixes a memory leak.
3344
3345 * src/output.c (token_definitions_output): New.
3346 (output_parser, header_output): Use it.
3347 * src/reader.c (symbols_save): Remove.
3348
33492001-12-29 Akim Demaille <akim@epita.fr>
3350
3351 * src/bison.simple: Do not provide a default for YYSTYPE and
3352 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3353 default.
3354
33552001-12-29 Akim Demaille <akim@epita.fr>
3356
3357 Mid-rule actions are simply... ignored!
3358
3359 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3360 the empty-rule associated to the dummy symbol, not to the host
3361 rule.
3362 * tests/actions.at (Mid-rule actions): New.
3363
33642001-12-29 Akim Demaille <akim@epita.fr>
3365
3366 Memory leak.
3367
3368 * src/reader.c (reader): Free grammar.
3369
33702001-12-29 Akim Demaille <akim@epita.fr>
3371
3372 Memory leak.
3373
3374 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
3375 since it allocates it for each state, although only one is needed.
3376 (allocate_storage): Do it here.
3377
33782001-12-29 Akim Demaille <akim@epita.fr>
3379
3380 * src/options.h, src/options.c (create_long_option_table): Rename
3381 as...
3382 (long_option_table_new): this, with a clearer prototype.
3383 (percent_table): Remove, unused,
3384 * src/getargs.c (getargs): Adjust.
3385
33862001-12-29 Akim Demaille <akim@epita.fr>
3387
3388 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
3389 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
3390 as states.
3391
33922001-12-29 Akim Demaille <akim@epita.fr>
3393
3394 * src/lalr.c (build_relations): Rename `states' as `states1'.
3395 Sorry, I don't understand exactly what it is, no better name...
3396
33972001-12-29 Akim Demaille <akim@epita.fr>
3398
3399 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
3400 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
3401 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
3402 as rules.
3403
34042001-12-29 Akim Demaille <akim@epita.fr>
3405
3406 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
3407 ago.
3408
34092001-12-29 Akim Demaille <akim@epita.fr>
3410
3411 * src/reader.c, src/reader.h (user_toknums): Remove.
3412 Adjust all users to use symbols[i]->user_token_number.
3413
34142001-12-29 Akim Demaille <akim@epita.fr>
3415
3416 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
3417 Adjust all users to use symbols[i]->prec or ->assoc.
3418
34192001-12-29 Akim Demaille <akim@epita.fr>
3420
3421 * src/reader.c, src/reader.h (tags): Remove.
3422 Adjust all users to use symbols[i]->tag.
3423
34242001-12-29 Akim Demaille <akim@epita.fr>
3425
3426 * src/gram.h, src/gram.c (symbols): New, similar to state_table
3427 and rule_table.
3428 * src/reader.c (packsymbols): Fill this table.
3429 Drop sprec.
3430 * src/conflicts.c (resolve_sr_conflict): Adjust.
3431 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
3432 single table.
3433 Use symbols[i]->tag instead of tags[i].
3434
34352001-12-29 Akim Demaille <akim@epita.fr>
3436
3437 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
3438 In addition, put a comment in there, to replace...
3439 * tests/regression.at (%union and C comments): Remove.
3440
34412001-12-29 Akim Demaille <akim@epita.fr>
3442
3443 * tests/regression.at (Web2c Actions): Blindly move the actual
3444 output as expected output. The contents *seem* right to me, but I
3445 can't pretend reading perfectly parser tables... Nonetheless, all
3446 the other tests pass correctly, the table look OK, even though the
3447 presence of `$axiom' is to be noted: AFAICS it is useless (but
3448 harmless).
3449
34502001-12-29 Akim Demaille <akim@epita.fr>
3451
3452 * src/reader.c (readgram): Don't add the rule 0 if there were no
3453 rules read. In other words, add it _after_ having performed
3454 grammar sanity checks.
3455 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
3456
34572001-12-29 Akim Demaille <akim@epita.fr>
3458
3459 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
3460 visible, and some states have now a different number.
3461
34622001-12-29 Akim Demaille <akim@epita.fr>
3463
3464 * src/reader.c (readgram): Bind the initial rule's lineno to that
3465 of the first rule.
3466 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
3467 (Solved SR Conflicts): Adjust rule 0's line number.
3468
34692001-12-29 Akim Demaille <akim@epita.fr>
3470
3471 Fix the `GAWK Grammar' failure.
3472
3473 * src/LR0.c (final_state): Initialize to -1 so that we do compute
3474 the reductions of the first state which was mistakenly confused
3475 with the final state because precisely final_state was initialized
3476 to 0.
3477 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
3478 now noticed by Bison.
3479 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
3480 have a reduction on $default.
3481
34822001-12-29 Akim Demaille <akim@epita.fr>
3483
3484 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
3485 rule line numbers.
3486 * src/closure.c (print_closure): Likewise.
3487 * src/derives.c (print_derives): Likewise.
3488 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
3489 now.
3490
34912001-12-29 Akim Demaille <akim@epita.fr>
3492
3493 * src/lalr.c (lookaheads_print): New.
3494 (lalr): Call it when --trace-flag.
3495 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
3496 are dumped.
3497
34982001-12-29 Akim Demaille <akim@epita.fr>
3499
3500 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
3501 when walking through ritem, even via rule->rhs.
3502 * src/reduce.c (dump_grammar, useful_production, reduce_output)
3503 (useful_production, useless_nonterminals): Likewise.
3504 (reduce_grammar_tables): Likewise, plus update nritems.
3505 * src/nullable.c (set_nullable): Likewise.
3506 * src/lalr.c (build_relations): Likewise.
3507 * tests/sets.at (Nullable): Adjust.
3508 Fortunately, now, the $axiom is no longer nullable.
3509
35102001-12-29 Akim Demaille <akim@epita.fr>
3511
3512 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
3513 the 0-sentinel.
3514 * src/gram.c (ritem_longest_rhs): Likewise.
3515 * src/reduce.c (nonterminals_reduce): Likewise.
3516 * src/print_graph.c (print_graph): Likewise.
3517 * src/output.c (output_rule_data): Likewise.
3518 * src/nullable.c (set_nullable): Likewise.
3519
35202001-12-29 Akim Demaille <akim@epita.fr>
3521
3522 * src/output.c: Comment changes.
3523
35242001-12-27 Paul Eggert <eggert@twinsun.com>
3525
3526 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
3527 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
3528 Sparc, as they were causing more porting problems than the
3529 (minor) performance improvement was worth.
3530
3531 Also, catch up with 1.31's YYSTD.
3532
35332001-12-27 Akim Demaille <akim@epita.fr>
3534
3535 * src/output.c (output_gram): Rely on nritems, not the
3536 0-sentinel. See below.
3537 Use -1 as separator, not 0.
3538 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
3539 Rely on -1 as separator in yyrhs, instead of 0.
3540 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
3541 twice `Now at end of input', therefore there are two lines less to
3542 expect.
3543
35442001-12-27 Akim Demaille <akim@epita.fr>
3545
3546 * tests/regression.at (Unresolved SR Conflicts):
3547 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
3548 below.
3549
35502001-12-27 Akim Demaille <akim@epita.fr>
3551
3552 * src/LR0.c (new_state): Recognize the final state by the fact it
3553 is reached by eoftoken.
3554 (insert_start_shifting_state, insert_eof_shifting_state)
3555 (insert_accepting_state, augment_automaton): Remove, since now
3556 these states are automatically computed from the initial state.
3557 (generate_states): Adjust.
3558 * src/print.c: When reporting a rule number to the user, substract
3559 1, so that the axiom rule is rule 0, and the first user rule is 1.
3560 * src/reduce.c: Likewise.
3561 * src/print_graph.c (print_core): For the time being, just as for
3562 the report, depend upon --trace-flags to dump the full set of
3563 items.
3564 * src/reader.c (readgram): Once the grammar read, insert the rule
3565 0: `$axiom: START-SYMBOL $'.
3566 * tests/set.at: Adjust: rule 0 is now displayed, and since the
3567 number of the states has changed (the final state is no longer
3568 necessarily the last), catch up.
3569
35702001-12-27 Akim Demaille <akim@epita.fr>
3571
3572 Try to make the use of the eoftoken valid. Given that its value
3573 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
3574 is used instead of > 0 where appropriate, (ii), depend upon nritems
3575 instead of the 0-sentinel.
3576
3577 * src/gram.h, src/gram.c (nritems): New.
3578 Expected to be duplication of nitems, but for the time being...
3579 * src/reader.c (packgram): Assert nritems and nitems are equal.
3580 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
3581 * src/closure.c (print_closure, print_fderives): Likewise.
3582 * src/gram.c (ritem_print): Likewise.
3583 * src/print.c (print_core, print_grammar): Likewise.
3584 * src/print_graph.c: Likewise.
3585
35862001-12-27 Akim Demaille <akim@epita.fr>
3587
3588 * src/main.c (main): If there are complains after grammar
3589 reductions, then output the report anyway if requested, then die.
3590 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
3591 * src/reader.c (eoftoken): New.
3592 (parse_token_decl): If the token being defined has value `0', it
3593 is the eoftoken.
3594 (packsymbols): No longer hack `tags' to insert `$' by hand.
3595 Be sure to preserve the value of the eoftoken.
3596 (reader): Make sure eoftoken is defined.
3597 Initialize nsyms to 0: now eoftoken is created just like the others.
3598 * src/print.c (print_grammar): Don't special case the eof token.
3599 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
3600 lie anyway, albeit pleasant.
3601 * tests/calc.at: Exercise error messages with eoftoken.
3602 Change the grammar so that empty input is invalid.
3603 Adjust expectations.
3604 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
3605
36062001-12-27 Akim Demaille <akim@epita.fr>
3607
3608 * configure.in: Check the protos of strchr ans strspn.
3609 Replace strchr if needed.
3610 * src/system.h: Provide the protos of strchr, strspn and memchr if
3611 missing.
3612 * lib/strchr.c: New.
3613 * src/reader.c (symbols_save): Use strchr.
3614
36152001-12-27 Akim Demaille <akim@epita.fr>
3616
3617 * src/print.c, src/print_graph.c (escape): New.
3618 Use it to quote the TAGS outputs.
3619 * src/print_graph.c (print_state): Now errors are in red, and
3620 reductions in green.
3621 Prefer high to wide: output the state number on a line of its own.
3622
36232001-12-27 Akim Demaille <akim@epita.fr>
3624
3625 * src/state.h, src/state.c (reductions_new): New.
3626 * src/LR0.c (set_state_table): Let all the states have a
3627 `reductions', even if reduced to 0.
3628 (save_reductions): Adjust.
3629 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
3630 * src/print.c (print_reductions, print_actions): Adjust.
3631 * src/output.c (action_row): Adjust.
3632
36332001-12-27 Akim Demaille <akim@epita.fr>
3634
3635 * src/state.h, src/state.c (errs_new, errs_dup): New.
3636 * src/LR0.c (set_state_table): Let all the states have an errs,
3637 even if reduced to 0.
3638 * src/print.c (print_errs, print_reductions): Adjust.
3639 * src/output.c (output_actions, action_row): Adjust.
3640 * src/conflicts.c (resolve_sr_conflict): Adjust.
3641
36422001-12-27 Akim Demaille <akim@epita.fr>
3643
3644 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
3645
36462001-12-27 Akim Demaille <akim@epita.fr>
3647
3648 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
3649 * src/print.c: here.
3650 (lookaheadset, shiftset): New, used as additional storage by
3651 print_reductions.
3652 (print_results): Adjust.
3653 (print_shifts, print_gotos, print_errs): New, extracted from...
3654 (print_actions): here.
3655 * src/print_graph.c (print_actions): Remove dead code.
3656
36572001-12-27 Akim Demaille <akim@epita.fr>
3658
3659 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
3660 `$n' and `@n'.
3661
36622001-12-27 Akim Demaille <akim@epita.fr>
3663
3664 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
3665 (build_relations): Adjust.
3666
36672001-12-27 Akim Demaille <akim@epita.fr>
3668
3669 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
3670 duplication.
3671
36722001-12-27 Akim Demaille <akim@epita.fr>
3673
3674 * src/reader.c (packgram): Catch nitems overflows.
3675
36762001-12-27 Akim Demaille <akim@epita.fr>
3677
3678 * src/files.c, src/files.h (guard_obstack): Remove.
3679 * src/output.c (output): Adjust.
3680 * src/reader.c (parse_braces): New, factoring...
3681 (copy_action, copy_guard): these two which are renamed as...
3682 (parse_action, parse_guard): these.
3683 As a voluntary consequence, using braces around guards is now
3684 mandatory.
3685
36862001-12-27 Akim Demaille <akim@epita.fr>
3687
3688 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3689 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3690 members.
3691 (symbol_list_new): Adjust.
3692 (copy_action): action_line is the first line, not the last.
3693 (copy_guard): Just as for actions, store the `action' only, not
3694 the switch/case/break flesh.
3695 Don't parse the user action that might follow the guard, let...
3696 (readgram): do it, i.e., now, there can be an action after a
3697 guard.
3698 In other words the guard is just explicitly optional.
3699 (packgram): Adjust.
3700 * src/output.c (guards_output): New.
3701 (output_parser): Call it when needed.
3702 (output): Also free the guard and attrs obstacks.
3703 * src/files.c, src/files.h (obstack_save): Remove.
3704 (output_files): Remove.
3705 As a result, if one needs the former `.act' file, using an
3706 appropriate skeleton which requires actions and guards is now
3707 required.
3708 * src/main.c (main): Adjust.
3709 * tests/semantic.at: New.
3710 * tests/regression.at: Use `input.y' as input file name.
3711 Avoid 8+3 problems by requiring input.c when the test needs the
3712 parser.
3713
37142001-12-27 Akim Demaille <akim@epita.fr>
3715
3716 * src/reader.c (symbol_list_new): Be sure to initialize all the
3717 fields.
3718
37192001-12-27 Akim Demaille <akim@epita.fr>
3720
3721 All the hacks using a final pseudo state are now useless.
3722
3723 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3724 * src/lalr.c (nLA): New.
3725 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3726 instead of lookaheadsp from the pseudo state (nstate + 1).
3727
37282001-12-27 Akim Demaille <akim@epita.fr>
3729
3730 * src/output.c (action_row, token_actions): Use a state_t instead
3731 of a integer, and nlookaheads instead of the following state's
3732 lookaheadsp.
3733
37342001-12-27 Akim Demaille <akim@epita.fr>
3735
3736 * src/conflicts.c (log_resolution, flush_shift)
3737 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3738 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3739 (conflicts_print, print_reductions): Use a state_t instead of an
3740 integer when referring to a state.
3741 As much as possible, depend upon nlookaheads, instead of the
3742 `lookaheadsp' member of the following state (since lookaheads of
3743 successive states are successive, the difference between state n + 1
3744 and n served as the number of lookaheads for state n).
3745 * src/lalr.c (add_lookback_edge): Likewise.
3746 * src/print.c (print_core, print_actions, print_state)
3747 (print_results): Likewise.
3748 * src/print_graph.c (print_core, print_actions, print_state)
3749 (print_graph): Likewise.
3750 * src/conflicts.h: Adjust.
3751
37522001-12-27 Akim Demaille <akim@epita.fr>
3753
3754 * src/bison.hairy: Formatting/comment changes.
3755 ANSIfy.
3756 Remove `register' indications.
3757 Add plenty of `static'.
3758
37592001-12-27 Akim Demaille <akim@epita.fr>
3760
3761 * src/output.c (prepare): Drop the muscle `ntbase' which
3762 duplicates ntokens.
3763 * src/bison.simple: Formatting/comment changes.
3764 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3765 is an undocumented synonym.
3766
37672001-12-22 Akim Demaille <akim@epita.fr>
3768
3769 * src/output.c (output_table_data): Change the prototype to use
3770 `int' for array ranges: some invocations do pass an int, not a
3771 short.
3772 Reported by Wayne Green.
3773
37742001-12-22 Akim Demaille <akim@epita.fr>
3775
3776 Some actions of web2c.y are improperly triggered.
3777 Reported by Mike Castle.
3778
3779 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3780 * tests/regression.at (Web2c): Rename as...
3781 (Web2c Report): this.
3782 (Web2c Actions): New.
3783
37842001-12-22 Akim Demaille <akim@epita.fr>
3785
3786 Reductions in web2c.y are improperly reported.
3787 Reported by Mike Castle.
3788
3789 * src/conflicts.c (print_reductions): Fix.
3790 * tests/regression.at (Web2c): New.
3791
37922001-12-18 Akim Demaille <akim@epita.fr>
3793
3794 Some host fail on `assert (!"foo")', which expands to
3795 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3796 Reported by Nelson Beebee.
3797
3798 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3799 `#define it_succeeded 0' and `assert (it_succeeded)'.
3800
38012001-12-17 Marc Autret <autret_m@epita.fr>
3802
3803 * src/bison.simple: Don't hard code the skeleton line and filename.
3804 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3805 New line counter 'skeleton_line' (skeleton-line muscle).
3806
38072001-12-17 Paul Eggert <eggert@twinsun.com>
3808
3809 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3810 YYDEBUG must be defined to a nonzero value.
3811
3812 * src/bison.simple (yytname): Do not assume that the user defines
3813 YYDEBUG to a properly parenthesized expression.
3814
38152001-12-17 Akim Demaille <akim@epita.fr>
3816
3817 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3818 nlookaheads is a new member.
3819 Adjust all users.
3820 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3821 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3822 state.
3823
38242001-12-17 Akim Demaille <akim@epita.fr>
3825
3826 * src/files.h, src/files.c (open_files, close_files): Remove.
3827 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3828 let...
3829 * src/reader.c (reader): Do it.
3830
38312001-12-17 Akim Demaille <akim@epita.fr>
3832
3833 * src/conflicts.c (print_reductions): Formatting changes.
3834
38352001-12-17 Akim Demaille <akim@epita.fr>
3836
3837 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3838 (flush_reduce): New.
3839 (resolve_sr_conflict): Adjust.
3840
38412001-12-17 Akim Demaille <akim@epita.fr>
3842
3843 * src/output.c (output_obstack): Be static and rename as...
3844 (format_obstack): this, to avoid any confusion with files.c's
3845 output_obstack.
3846 * src/reader.h (muscle_obstack): Move to...
3847 * src/output.h: here, since it's defined in output.c.
3848
38492001-12-17 Akim Demaille <akim@epita.fr>
3850
3851 * src/output.c (action_row, save_column, default_goto)
3852 (sort_actions, matching_state, pack_vector): Better variable
3853 locality.
3854
38552001-12-17 Akim Demaille <akim@epita.fr>
3856
3857 * src/output.c: Various formatting changes.
3858
38592001-12-17 Akim Demaille <akim@epita.fr>
3860
3861 * src/files.c (output_files): Free the output_obstack.
3862 * src/main.c (main): Call print and print_graph conditionally.
3863 * src/print.c (print): Work unconditionally.
3864 * src/print_graph.c (print_graph): Work unconditionally.
3865 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3866
38672001-12-16 Marc Autret <autret_m@epita.fr>
3868
3869 * src/output.c (actions_output): Fix. When we use %no-lines,
3870 there is one less line per action.
3871
38722001-12-16 Marc Autret <autret_m@epita.fr>
3873
3874 * src/bison.simple: Remove a useless #line directive.
3875 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3876 * src/output.c (get_lines_number): New.
3877 (output_parser): Adjust, now takes care about the lines of a
3878 output muscles.
3879 Fix line numbering.
3880 (actions_output): Computes the number of lines taken by actions.
3881 (output_master_parser): Insert new skeleton which is the name of
3882 the output parser file name.
3883
38842001-12-15 Marc Autret <autret_m@epita.fr>
3885
3886 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3887
38882001-12-15 Marc Autret <autret_m@epita.fr>
3889
3890 * src/output.c (output_gram): Keep track of the hairy one.
3891
38922001-12-15 Akim Demaille <akim@epita.fr>
3893
3894 Make `make distcheck' work.
3895
3896 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3897 system.h which uses libgettext.h.
3898
38992001-12-15 Akim Demaille <akim@epita.fr>
3900
3901 * src/nullable.c (set_nullable): Useless rules must be skipped,
3902 otherwise, since we range over their symbols, we might look at a
3903 nonterminal which no longer ``exists'', i.e., it is not counted in
3904 `nvars', hence we overflow our arrays.
3905
39062001-12-15 Akim Demaille <akim@epita.fr>
3907
3908 The header can also be produced directly, without any obstack!
3909 Yahoo!
3910
3911 * src/files.c, src/files.h (defines_obstack): Remove.
3912 (compute_header_macro): Global.
3913 (defines_obstack_save): Remove.
3914 * src/reader.c (parse_union_decl): No longer output to
3915 defines_obstack: its content can be found in the `stype' muscle
3916 anyway.
3917 (output_token_translations): Merge into...
3918 (symbols_output): this.
3919 Rename as...
3920 (symbols_save): this.
3921 (reader): Adjust.
3922 * src/output.c (header_output): New.
3923 (output): Call it.
3924
39252001-12-15 Akim Demaille <akim@epita.fr>
3926
3927 * src/reader.c (parse_union_decl): Instead of handling two obstack
3928 simultaneously, use one to define the `stype' muscle, and use the
3929 value of the latter to fill defines_obstack.
3930 (copy_comment): Remove.
3931 (copy_comment2): Work for a single obstack.
3932 Rename as...
3933 (copy_comment): this.
3934
39352001-12-15 Akim Demaille <akim@epita.fr>
3936
3937 * src/lex.c, src/lex.h (xgetc): No longer static.
3938 * src/reader.c (parse_union_decl): Revamp.
3939
39402001-12-15 Akim Demaille <akim@epita.fr>
3941
3942 Still making progress in separating Bison into (i) input, (ii)
3943 process, (iii) output: now we can directly output the parser file
3944 without using table_obstack at all.
3945
3946 * src/files.c, src/files.h (table_obstack): Bye bye.
3947 (parser_file_name): New.
3948 * src/files.c (compute_output_file_names): Compute it.
3949 * src/output.c (actions_output, output_parser)
3950 (output_master_parser): To a file instead of an obstack.
3951
39522001-12-15 Akim Demaille <akim@epita.fr>
3953
3954 Attach actions to rules, instead of pre-outputting them to
3955 actions_obstack.
3956
3957 * src/gram.h (rule_t): action and action_line are new members.
3958 * src/reader.c (symbol_list): Likewise.
3959 (copy_action): Save the actions within the rule.
3960 (packgram): Save them in rule_table.
3961 * src/output.c (actions_output): New.
3962 (output_parser): Use it on `%%actions'.
3963 (output_rule_data): Don't free rule_table.
3964 (output): Do it.
3965 (prepare): Don't save the `action' muscle.
3966 * src/bison.simple: s/%%action/%%actions/.
3967
39682001-12-15 Akim Demaille <akim@epita.fr>
3969
3970 * src/reader.c (copy_action): When --yacc, don't append a `;'
3971 to the user action: let it fail if lacking.
3972 Suggested by Arnold Robbins and Tom Tromey.
3973
39742001-12-14 Akim Demaille <akim@epita.fr>
3975
3976 * src/lex.c (literalchar): Simply return the char you decoded, non
3977 longer mess around with obstacks and int pointers.
3978 Adjust all callers.
3979
39802001-12-14 Akim Demaille <akim@epita.fr>
3981
3982 * src/lex.c (literalchar): Don't escape the special characters,
3983 just decode them, and keep them as char (before, eol was output as
3984 the 2 char string `\n' etc.).
3985 * src/output.c (output_rule_data): Use quotearg to output the
3986 token strings.
3987
39882001-12-13 Paul Eggert <eggert@twinsun.com>
3989
3990 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3991 Do not infringe on the global user namespace when using C++.
3992 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3993 All uses of `fprintf' and `stderr' changed.
3994
3995 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3996
39972001-12-13 Akim Demaille <akim@epita.fr>
3998
3999 The computation of nullable is broken: it doesn't handle empty
4000 RHS's properly.
4001
4002 * tests/torture.at (GNU AWK Grammar): New.
4003 * tests/sets.at (Nullable): New.
4004 * src/nullable.c (set_nullable): Instead of blindly looping over
4005 `ritems', loop over the rules, and then over their rhs's.
4006
4007 Work around Autotest bugs.
4008
4009 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4010 frame, because Autotest understand lines starting with a `+' as
4011 traces from the shell. Then, they are not processed properly.
4012 Admittedly an Autotest bug, but we don't have time to wait for
4013 Autotest to catch up.
4014 * tests/regression.at (Broken Closure): Adjust to the new table
4015 frames.
4016 Move to...
4017 * tests/sets.at: here.
4018
40192001-12-13 Akim Demaille <akim@epita.fr>
4020
4021 * src/closure.c (closure): Use nrules instead of playing tricks
4022 with BITS_PER_WORD.
4023
40242001-12-13 Akim Demaille <akim@epita.fr>
4025
4026 * src/print.c (print_actions): Output the handling of `$' as the
4027 traces do: shifting the token EOF. Before EOF was treated as a
4028 nonterminal.
4029 * tests/regression.at: Adjust some tests.
4030 * src/print_graph.c (print_core): Complete the set of items via
4031 closure. The next-to-final and final states are still unsatisfying,
4032 but that's to be addressed elsewhere.
4033 No longer output the rule numbers, but do output the state number.
4034 A single loop for the shifts + gotos is enough, but picked a
4035 distinct color for each.
4036 (print_graph): Initialize and finalize closure.
4037
40382001-12-13 Akim Demaille <akim@epita.fr>
4039
4040 * src/reader.c (readgram): Remove dead code, an strip useless
4041 braces.
4042 (get_type): Remove, unused.
4043
40442001-12-12 Akim Demaille <akim@epita.fr>
4045
4046 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4047 on that of lib/error.c.
4048
40492001-12-12 Akim Demaille <akim@epita.fr>
4050
4051 Some hosts don't like `/' in includes.
4052
4053 * src/system.h: Include libgettext.h without qualifying the path.
4054 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4055 $(top_srcdir).
4056
40572001-12-11 Marc Autret <autret_m@epita.fr>
4058
4059 * src/output.c (output_parser): Remove useless muscle.
4060
40612001-12-11 Marc Autret <autret_m@epita.fr>
4062
4063 * src/bison.simple: Remove #line just before %%epilogue. It
4064 is now handled in ...
4065 * src/reader.c (read_additionnal_code): Add the output of a
4066 #line for the epilogue.
4067
40682001-12-10 Marc Autret <autret_m@epita.fr>
4069
4070 * src/reader.c (copy_definition): Re-use CPP-outed code which
4071 replace precedent remove.
4072 * src/bison.simple: Remove #line before %%prologue because
4073 %%input-line is wrong at this time.
4074
40752001-12-10 Marc Autret <autret_m@epita.fr>
4076
4077 * src/reader.c (symbols_output): Clean up.
4078 * src/output.c (output_gram, output): Clean up.
4079
40802001-12-10 Akim Demaille <akim@epita.fr>
4081
4082 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4083 * src/LR0.c (set_state_table): here.
4084 * src/lalr.c (lalr): Call it.
4085
40862001-12-10 Akim Demaille <akim@epita.fr>
4087
4088 * src/state.h (shifts): Remove the `number' member: shifts are
4089 attached to state, hence no longer need to be labelled with a
4090 state number.
4091
40922001-12-10 Akim Demaille <akim@epita.fr>
4093
4094 Now that states have a complete set of members, the linked list of
4095 shifts is useless: just fill directly the state's shifts member.
4096
4097 * src/state.h (shifts): Remove the `next' member.
4098 * src/LR0.c (first_state, last_state): Remove.
4099 Adjust the callers.
4100 (augment_automaton): Don't look for the shifts that must be added
4101 a shift on EOF: it is those of the state we looked for! But now,
4102 since shifts are attached, it is no longer needed to looking
4103 merely by its id: its number.
4104
41052001-12-10 Akim Demaille <akim@epita.fr>
4106
4107 * src/LR0.c (augment_automaton): Better variable locality.
4108 Remove an impossible branch: if there is a state corresponding to
4109 the start symbol being shifted, then there is shift for the start
4110 symbol from the initial state.
4111
41122001-12-10 Akim Demaille <akim@epita.fr>
4113
4114 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4115 only when appropriate: when insert_start_shifting_state' is not
4116 invoked.
4117 * tests/regression.at (Rule Line Numbers): Adjust.
4118
41192001-12-10 Akim Demaille <akim@epita.fr>
4120
4121 * src/LR0.c (augment_automaton): Now that all states have shifts,
4122 merge the two cases addition shifts to the initial state.
4123
41242001-12-10 Akim Demaille <akim@epita.fr>
4125
4126 * src/lalr.c (set_state_table): Move to...
4127 * src/LR0.c: here.
4128 * src/lalr.c (lalr): Don't call it...
4129 * src/LR0.c (generate_states): do it.
4130 * src/LR0.h (first_state): Remove, only the table is used.
4131
41322001-12-10 Akim Demaille <akim@epita.fr>
4133
4134 * src/LR0.h (first_shift, first_reduction): Remove.
4135 * src/lalr.c: Don't use first_shift: find shifts through the
4136 states.
4137
41382001-12-10 Akim Demaille <akim@epita.fr>
4139
4140 * src/LR0.c: Attach shifts to states as soon as they are
4141 computed.
4142 * src/lalr.c (set_state_table): Instead of assigning shifts to
4143 state, just assert that the mapping was properly done.
4144
41452001-12-10 Akim Demaille <akim@epita.fr>
4146
4147 * src/LR0.c (insert_start_shift): Rename as...
4148 (insert_start_shifting_state): this.
4149 (insert_eof_shifting_state, insert_accepting_state): New.
4150 (augment_automaton): Adjust.
4151 Better locality of the variables.
4152 When looking if the start_symbol is shifted from the initial
4153 state, using `while (... symbol != start_symbol ...)' sounds
4154 better than `while (... symbol < start_symbol ...)': If fail
4155 to see how the order between symbols could be relevant!
4156
41572001-12-10 Akim Demaille <akim@epita.fr>
4158
4159 * src/getargs.h: Don't declare `spec_name_prefix' and
4160 `spec_file_prefix', declared by src/files.h.
4161 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4162 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4163 * src/output.c (prepare): Adjust.
4164 * src/reader.c (symbols_output): Likewise.
4165 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4166
41672001-12-10 Akim Demaille <akim@epita.fr>
4168
4169 * src/muscle_tab.c (muscle_init): NULL is a better default than
4170 `"0"'.
4171
41722001-12-10 Akim Demaille <akim@epita.fr>
4173
4174 * src/reader.c (reader): Calling symbols_output once is enough.
4175
41762001-12-10 Akim Demaille <akim@epita.fr>
4177
4178 Now that states have a complete set of members, the linked list of
4179 reductions is useless: just fill directly the state's reductions
4180 member.
4181
4182 * src/state.h (struct reductions): Remove member `number' and
4183 `next'.
4184 * src/LR0.c (first_reduction, last_reduction): Remove.
4185 (save_reductions): Don't link the new reductions, store them in
4186 this_state.
4187 * src/lalr.c (set_state_table): No need to attach reductions to
4188 states, it's already done.
4189 * src/output.c (output_actions): No longer free the shifts, then
4190 the reductions, then the states: free all the states and their
4191 members.
4192
41932001-12-10 Akim Demaille <akim@epita.fr>
4194
4195 * src/options.c (OPTN, DRTV, BOTH): New.
4196 (option_table): Use them.
4197
4198 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4199 the job of system.h.
4200 * src/options.c: Don't include stdio.h and xalloc.h for the same
4201 reasons.
4202
42032001-12-10 Akim Demaille <akim@epita.fr>
4204
4205 * src/output.c (output, prepare): Make sure the values of the
4206 muscles `action' and `prologue' are 0-terminated.
4207
42082001-12-10 Akim Demaille <akim@epita.fr>
4209
4210 Clean up GCC warnings.
4211
4212 * src/reader.c (copy_action): `buf' is not used.
4213 (parse_skel_decl): Be static.
4214 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4215 * src/options.h (create_long_option_table): Have a real prototype.
4216 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4217 (hash_delete_at): Return const void *.
4218 Adjust casts to preserve the const.
4219
42202001-12-10 Akim Demaille <akim@epita.fr>
4221
4222 * configure.in: Require 2.52g.
4223 M4 is not needed, but AUTOM4TE is.
4224 * m4/m4.m4: Remove.
4225 * tests/Makefile.am: Adjust.
4226
42272001-12-10 Akim Demaille <akim@epita.fr>
4228
4229 One structure for states is enough, even though theoretically
4230 there are LR(0) states and LALR(1) states.
4231
4232 * src/lalr.h (state_t): Remove.
4233 (state_table): Be state_t **, not state_t *.
4234 * src/state.h (core, CORE_ALLOC): Rename as...
4235 (state_t, STATE_ALLOC): this.
4236 Add the LALR(1) members: shifts, reductions, errs.
4237 * src/LR0.c (state_table): Rename as...
4238 (state_hash): this, to avoid name clashes with the global
4239 `state_table'.
4240 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4241 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4242
42432001-12-10 Akim Demaille <akim@epita.fr>
4244
4245 Bison dumps core on bash.y.
4246 Reported by Pascal Bart.
4247
4248 * src/warshall.c (bitmatrix_print): New.
4249 (TC): Use it.
4250 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4251 j must be the outer loop.
4252 * tests/regression.at (Broken Closure): New.
4253
42542001-12-05 Akim Demaille <akim@epita.fr>
4255
4256 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4257 its argument.
4258