]> git.saurik.com Git - bison.git/blame - ChangeLog
* configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
[bison.git] / ChangeLog
CommitLineData
927f7817
AD
12002-09-30 Art Haas <ahaas@neosoft.com>
2
3 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
4 invocations.
5 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
6 defined.
7
9738f41e
AD
82002-09-27 Akim Demaille <akim@epita.fr>
9
10 Version 1.49c.
11
a5c75d7f
AD
122002-09-27 Akim Demaille <akim@epita.fr>
13
14 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
15 (Because of AC_LIBSOURCE).
16
8280e179
AD
172002-09-27 Akim Demaille <akim@epita.fr>
18
19 Playing with Autoscan.
20
21 * configure.ac: Remove the old LIBOBJ tweaks.
22 (AC_REPLACE_FUNCS): Add strrchr and strtol.
23 * lib/strrchr.c: New.
24 * lib/strtol.c: New, from the Coreutils 4.5.1.
25
ae64af35
AD
262002-09-27 Akim Demaille <akim@epita.fr>
27
28 Playing with Autoscan.
29
30 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
31 * lib/Makefile.am (libbison_a_SOURCES): No longer include
32 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
33 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
34 Coreutils 4.5.1.
35
d1a1114f
AD
362002-09-24 Akim Demaille <akim@epita.fr>
37
38 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
39 (Frequently Asked Questions, Parser Stack Overflow): New.
40
b906441c
AD
412002-09-13 Akim Demaille <akim@epita.fr>
42
43 Playing with autoscan.
44
45 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
46 * src/files.c (skeleton_find): Remove, unused.
47 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
48 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
49
bd701811
AD
502002-09-13 Akim Demaille <akim@epita.fr>
51
52 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
53 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
54
e0a13e7b
AD
552002-09-13 Akim Demaille <akim@epita.fr>
56
57 * configure.ac: Require 2.54.
58 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
59 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
60 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
61 Remove, provided by Autoconf macros.
62
c97011bf
AD
632002-09-12 Akim Demaille <akim@epita.fr>
64
65 * m4/prereq.m4: Update, from Coreutils 4.5.1.
66
d862b1be
AD
672002-09-12 Akim Demaille <akim@epita.fr>
68
69 * m4/prereq.m4: Update, from Fileutils 4.1.5.
70 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
71 Reported by Martin Mokrejs.
72
3d38c03a
AD
732002-09-10 Akim Demaille <akim@epita.fr>
74
75 * src/parse-gram.y: Associate a human readable string to each
76 token type.
77 * tests/regression.at (Invalid inputs): Adjust.
78
b6347355
AD
792002-09-10 Gary V. Vaughan <gary@gnu.org>
80
81 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
82 with an Autoconf-2.5x style configure.ac.
83
09ba4ab2
PE
842002-09-06 Paul Eggert <eggert@twinsun.com>
85
86 * doc/bison.texinfo (Conditions): Make explicit that the GPL
87 exception applies only to yacc.c. This is a modification of a
88 patch originally suggested by Akim Demaille.
89
21846f69
AD
902002-09-06 Akim Demaille <akim@epita.fr>
91
09ba4ab2
PE
92 * data/c.m4 (b4_copyright): Move the GPL exception comment from
93 here to...
94 * data/yacc.c: here.
95
21846f69
AD
96 * data/lalr1.cc (struct yyltype): Don't define it, since we use
97 LocationType.
98 (b4_ltype): Default to yy::Location from location.hh.
99
c0ad8bf3
AD
1002002-09-04 Jim Meyering <jim@meyering.net>
101
102 * data/yacc.c: Guard the declaration of yytoknum also with
103 `#ifdef YYPRINT', so it is declared only when used.
104
3a93251e
AD
1052002-09-04 Akim Demaille <akim@epita.fr>
106
107 * configure.in: Rename as...
108 * configure.ac: this.
109 Bump to 1.49c.
110
427c0dda
AD
1112002-09-04 Akim Demaille <akim@epita.fr>
112
113 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
114 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
115 translate maintainer only messages.
116
6a254321
PE
1172002-08-12 Paul Eggert <eggert@twinsun.com>
118
645e30d1
PE
119 Version 1.49b.
120
6a254321
PE
121 * Makefile.am (SUBDIRS): Remove intl.
122 (DISTCLEANFILES): Remove.
123 * NEWS: Mention that GNU M4 is now required. Clarify what is
124 meant by "larger grammars". Mention the pt_BR translation.
125 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
126 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
127 Bump version from 0.11.2 to 0.11.5.
128 (BISON_PREREQ_STAGE): Remove.
129 (AM_GNU_GETTEXT): Use external gettext.
130 (AC_OUTPUT): Remove intl/Makefile.
131
132 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
133
134 * data/glr.c: Include string.h, for strlen.
135 (yyreportParseError): Use size_t for yysize.
136 (yy_yypstack): No longer nested inside yypstates, as nested
137 functions are not portable. Do not assume size_t is the
138 same width as int.
139 (yypstates): Do not assume that ptrdiff_t is the same width
140 as int, and similarly for yyposn and YYINDEX.
141
142 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
143
144 * lib/Makefile.am (INCLUDES): Do not include from the intl
145 directory, which has been removed.
146 * src/Makefile.am (INCLUDES): Likewise.
147
148 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
149 (bitsets_sources, additional_bitsets_sources, timevars_sources):
150 New vars.
151
152 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
153 * tests/Makefile.am (EXTRA_DIST): Likewise.
154
155 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
156 Do not assume that bitset_windex is the same width as unsigned.
157
158 * lib/abitset.c (abitset_unused_clear): Do not assume that
159 bitset_word is the same width as int.
160 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
161 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
162 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
163 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
164 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
165
166 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
167 portability to one's complement hosts!).
168 * lib/ebitset.c (ebitset_op1): Likewise.
169 * lib/lbitset.c (lbitset_op1): Likewise.
170
171 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
172 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
173 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
174 Sync with fileutils.
175 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
176 lib/gettext.h: Sync with diffutils.
177
178 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
179 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
180
181 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
182 PROTOTYPES to check for prototypes, and "defined __STDC__" to
183 check for void *.
184
185 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
186 size_t; the old version tried to do this but casted improperly.
187 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
188 (bitset_test): Now returns int, not unsigned long.
189
190 * lib/bitset_stats.c: Include "gettext.h".
191 (_): New macro.
192 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
193 name locals "index", as it generates unnecessary warnings on some
194 hosts that have an "index" function.
195
196 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
197 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
198 they need translation.
199 * src/LR0.c (state_list_append, new_itemsets, get_state,
200 append_states, generate_states): Likewise.
201 * src/assoc.c (assoc_to_string): Likewise.
202 * src/closure.c (print_closure, set_firsts, closure): Likewise.
203 * src/gram.c (grammar_dump): Likewise.
204 * src/injections.c (injections_compute): Likewise.
205 * src/lalr.c (lookaheads_print): Likewise.
206 * src/relation.c (relation_transpose): Likewise.
207 * src/scan-gram.l: Likewise.
208 * src/tables.c (table_grow, pack_vector): Likewise.
209
210 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
211 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
212 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
213 * m4/mbstate_t.m4: Sync with fileutils.
214 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
215
216 * po/LINGUAS: Add pt_BR.
217 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
218 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
219 lib/timevar.c.
220 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
221 manual recommends.
222 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
223
224 * src/complain.c (strerror_r): Remove decl; not needed.
225 (strerror): Use same pattern as ../lib/error.c.
226
227 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
228
229 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
230
231 * src/main.c (main): Cast result of bindtextdomain and textdomain
232 to void, to avoid a GCC warning when --disable-nls is in effect.
233
234 * src/scan-gram.l: Use strings rather than escapes when possible,
235 to minimize the number of warnings from xgettext.
236 (handle_action_dollar, handle_action_at): Don't use isdigit,
237 as it mishandles negative chars and it may not work as expected
238 outside the C locale.
239
240 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
241 this is a GCC extension and is not portable to other compilers.
242
243 * src/system.h (alloca): Use same pattern as ../lib/error.c.
244 Do not include <ctype.h>; no longer needed.
245 Do not include <malloc.h>; no longer needed (and generates
246 warnings on OpenBSD 3.0).
247
248 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
249 it's not portable.
250
251 * tests/regression.at: Do not use 'cc -c input.c -o input';
252 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
253
254 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
255 exit status as failure, not just exit status 1. Sun C exits
256 with status 2 sometimes.
257
258 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
259 Use it for the two large tests.
260
c8f002c7
AD
2612002-08-02 Akim Demaille <akim@epita.fr>
262
263 * src/conflicts.c (conflicts_output): Don't output rules never
264 reduced here, since anyway that computation doesn't work.
265 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
266 (rule_useless_p, rule_never_reduced_p): New.
267 (grammar_rules_partial_print): Use a filter instead of a range.
268 Display the title only if needed.
269 (grammar_rules_print): Adjust.
270 (grammar_rules_never_reduced_report): New.
271 * src/tables.c (action_row): Move the computation of rules never
272 reduced to...
273 (token_actions): here.
274 * src/main.c (main): Make the parser before making the report, so
275 that rules never reduced are computed.
276 Call grammar_rules_never_reduced_report.
277 * src/print.c (print_results): Report rules never reduced.
278 * tests/conflicts.at, tests/reduce.at: Adjust.
279
cd08e51e
AD
2802002-08-01 Akim Demaille <akim@epita.fr>
281
282 Instead of attaching lookaheads and duplicating the rules being
283 reduced by a state, attach the lookaheads to the reductions.
284
285 * src/state.h (state_t): Remove the `lookaheads',
286 `lookaheads_rule' member.
287 (reductions_t): Add a `lookaheads' member.
288 Use a regular array for the `rules'.
289 * src/state.c (reductions_new): Initialize the lookaheads member
290 to 0.
291 (state_rule_lookaheads_print): Adjust.
292 * src/state.h, src/state.c (state_reductions_find): New.
293 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
294 (count_rr_conflicts): Adjust.
295 * src/lalr.c (LArule): Remove.
296 (add_lookback_edge): Adjust.
297 (state_lookaheads_count): New.
298 (states_lookaheads_initialize): Merge into...
299 (initialize_LA): this.
300 (lalr_free): Adjust.
301 * src/main.c (main): Don't free nullable and derives too early: it
302 is used by --verbose.
303 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
304
bb0027a9
AD
3052002-08-01 Akim Demaille <akim@epita.fr>
306
307 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
308 `rule_number_t**'.
309 (set_derives, free_derives): Rename as...
310 (derives_compute, derives_free): this.
311 Adjust all dependencies.
312 * src/nullable.c (set_nullable, free_nullable): Rename as...
313 (nullable_compute, nullable_free): these.
314 (rule_list_t): Store rule_t *, not rule_number_t.
315 * src/state.c (state_rule_lookaheads_print): Directly compare rule
316 pointers, instead of their numbers.
317 * src/main.c (main): Call nullable_free, and derives_free earlier,
318 as they were lo longer used.
319
3325ddc4
AD
3202002-08-01 Akim Demaille <akim@epita.fr>
321
322 * lib/timevar.c (get_time): Include children time.
323 * src/lalr.h (LA, LArule): Don't export them: used with the
324 state_t.
325 * src/lalr.c (LA, LArule): Static.
326 * src/lalr.h, src/lalr.c (lalr_free): New.
327 * src/main.c (main): Call it.
328 * src/tables.c (pack_vector): Check whether loc is >= to the
329 table_size, not >.
330 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
331 (tables_generate): do it, since that's also it which allocates
332 them.
333 Don't free LA and LArule, main does.
334
c6f1a33c
AD
3352002-07-31 Akim Demaille <akim@epita.fr>
336
337 Separate parser tables computation and output.
338
339 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
340 (conflict_list, conflict_list_cnt, table, check, table_ninf)
341 (yydefgoto, yydefact, high): Move to...
342 * src/tables.h, src/tables.c: here.
343 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
344 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
345 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
346 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
347 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
348 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
349 (action_row, save_row, token_actions, save_column, default_goto)
350 (goto_actions, sort_actions, matching_state, pack_vector)
351 (table_ninf_remap, pack_table, prepare_actions): Move to...
352 * src/tables.c: here.
353 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
354 * src/output.c (token_actions, output_base, output_conflicts)
355 (output_check): Merge into...
356 (prepare_actions): this.
357 (actions_output): Rename as...
358 (user_actions_output): this.
359 * src/main.c (main): Call tables_generate and tables_free.
360
1509d42f
AD
3612002-07-31 Akim Demaille <akim@epita.fr>
362
363 Steal GCC's --time-report support.
364
365 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
366 stolen/adjusted from GCC.
367 * m4/stage.m4: Remove time related checks.
368 * m4/timevar.m4: New.
369 * configure.in: Adjust.
370 * src/system.h: Adjust to using timevar.h.
371 * src/getargs.h, src/getargs.c: Support trace_time for
372 --trace=time.
373 * src/main.c (stage): Remove.
374 (main): Replace `stage' invocations with timevar calls.
375 * src/output.c: Insert pertinent timevar calls.
376
273a74fa
AD
3772002-07-31 Akim Demaille <akim@epita.fr>
378
379 Let --trace have arguments.
380
381 * src/getargs.h (enum trace_e): New.
382 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
383 (long_options, short_options): --trace/-T takes an optional
384 argument.
385 Change all the uses of trace_flag to reflect the new flags.
386 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
387
388 Strengthen `stage' portability.
389
390 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
391 * configure.in: Use it.
392 Don't check for malloc.h and sys/times.h.
393 * src/system.h: Include them when appropriate.
394 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
395 times and struct tms are available.
396
217598da
AD
3972002-07-30 Akim Demaille <akim@epita.fr>
398
399 In verbose parse error message, don't report `error' as an
400 expected token.
401 * tests/actions.at (Printers and Destructors): Adjust.
402 * tests/calc.at (Calculator $1): Adjust.
403 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
404 error message, do not report the parser accepts the error token in
405 that state.
406
52489d44
AD
4072002-07-30 Akim Demaille <akim@epita.fr>
408
409 Normalize conflict related messages.
410
411 * src/complain.h, src/complain.c (warn, complain): New.
412 * src/conflicts.c (conflicts_print): Use them.
413 (conflict_report_yacc): New, extracted from...
414 (conflicts_print): here.
415 * tests/conflicts.at, tests/existing.at: Adjust.
416
e8832397
AD
4172002-07-30 Akim Demaille <akim@epita.fr>
418
419 Report rules which are never reduced by the parser: those hidden
420 by conflicts.
421
422 * src/LR0.c (save_reductions): Don't make the final state too
423 different: save its reduction (accept) instead of having a state
424 without any action (no shift or goto, no reduce).
425 Note: the final state is now a ``regular'' state, i.e., the
426 parsers now contain `reduce 0' as default reduction.
427 Nevertheless, since they decide to `accept' when yystate =
428 final_state, they still will not reduce rule 0.
429 * src/print.c (print_actions, print_reduction): Adjust.
430 * src/output.c (action_row): Track reduced rules.
431 (token_actions): Report rules never reduced.
432 * tests/conflicts.at, tests/regression.at: Adjust.
433
caf23d24
AD
4342002-07-30 Akim Demaille <akim@epita.fr>
435
436 `stage' was accidently included in a previous patch.
437 Initiate its autoconfiscation.
438
439 * configure.in: Look for malloc.h and sys/times.h.
440 * src/main.c (stage): Adjust.
441 Report only when trace_flag.
442
640748ee
AD
4432002-07-29 Akim Demaille <akim@epita.fr>
444
445 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
446 state_number_t.
447 (errs_t): symbol_t*, not symbol_number_t.
448 (reductions_t): rule_t*, not rule_number_t.
449 (FOR_EACH_SHIFT): New.
450 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
451 * src/print.c, src/print_graph.c: Adjust.
452
88bce5a2
AD
4532002-07-29 Akim Demaille <akim@epita.fr>
454
455 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
456
457 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
458 (endtoken, accept): these.
459 * src/reader.c (reader): Set endtoken's default tag to "$end".
460 Set undeftoken's tag to "$undefined" instead of "$undefined.".
461 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
462 Adjust.
463
1bfb97db
AD
4642002-07-29 Akim Demaille <akim@epita.fr>
465
466 * src/reduce.c (reduce_grammar): When the language is empty,
467 complain about the start symbol, not the axiom.
468 Use its location.
469 * tests/reduce.at (Empty Language): New.
470
fc5734fe
AD
4712002-07-26 Akim Demaille <akim@epita.fr>
472
473 * src/reader.h, src/reader.c (gram_error): ... can't get
474 yycontrol without making too strong assumptions on the parser
475 itself.
476 * src/output.c (prepare_tokens): Use the real 0th value of
477 token_translations instead of `0'.
478 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
479 visible here.
480 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
481 for the time being: %locations ought to provide it to yyerror.
482
3650b4b8
AD
4832002-07-25 Akim Demaille <akim@epita.fr>
484
485 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
486 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
487 * tests/regression.at (Web2c Actions): Adjust.
488
4b3d3a8e
AD
4892002-07-25 Akim Demaille <akim@epita.fr>
490
491 Stop storing rules from 1 to nrules + 1.
492
493 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
494 * src/nullable.c, src/output.c, src/print.c, src/reader.c
495 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
496 Iterate from 0 to nrules.
497 Use rule_number_as_item_number and item_number_as_rule_number.
498 Adjust to `derive' now containing possibly 0.
499 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
500 Handle the `- 1' part in rule numbers from/to item numbers.
501 * src/conflicts.c (log_resolution): Fix the message which reversed
502 shift and reduce.
503 * src/output.c (action_row): Initialize default_rule to -1.
504 (token_actions): Adjust.
505 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
506 expected output.
507 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
508
4a2a22f4
AD
5092002-07-25 Akim Demaille <akim@epita.fr>
510
511 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
512 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
513 (b4_c_knr_arg_decl): New.
514 * data/yacc.c: Use it to define yysymprint, yydestruct, and
515 yyreport_parse_error.
516
b8df3223
AD
5172002-07-25 Akim Demaille <akim@epita.fr>
518
519 * data/yacc.c (yyreport_parse_error): New, extracted from...
520 (yyparse): here.
521 (yydestruct, yysymprint): Move above yyparse.
522 Be K&R compliant.
523
a762e609
AD
5242002-07-25 Akim Demaille <akim@epita.fr>
525
526 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
527 replace...
528 (b4_sint_type, b4_uint_type): these.
529 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
530 * tests/regression.at (Web2c Actions): Adjust.
531
12b0043a
AD
5322002-07-25 Akim Demaille <akim@epita.fr>
533
534 * src/gram.h (TIEM_NUMBER_MAX): New.
535 (item_number_of_rule_number, rule_number_of_item_number): Rename
536 as...
537 (rule_number_as_item_number, item_number_as_rule_number): these.
538 Adjust dependencies.
539 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
540 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
541 (symbol_number_to_vector_number): New.
542 (order): Of vector_number_t* type.
543 (base_t, BASE_MAX, BASE_MIN): New.
544 (froms, tos, width, pos, check): Of base_t type.
545 (action_number_t, ACTION_MIN, ACTION_MAX): New.
546 (actrow): Of action_number_t type.
547 (conflrow): Of unsigned int type.
548 (table_ninf, base_ninf): New.
549 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
550 (muscle_insert_int_table, muscle_insert_base_table)
551 (muscle_insert_rule_number_table): New.
552 (prepare_tokens): Output `toknum' as int_table.
553 (action_row): Returns a rule_number_t.
554 Use ACTION_MIN, not SHRT_MIN.
555 (token_actions): yydefact is rule_number_t*.
556 (table_ninf_remap): New.
557 (pack_table): Use it for `base' and `table'.
558 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
559 replaced with...
560 (YYPACT_NINF, YYTABLE_NINF): these.
561 (yypact, yytable): Compute their types instead of hard-coded
562 `short'.
563 * tests/regression.at (Web2c Actions): Adjust.
564
5dde258a
AD
5652002-07-19 Akim Demaille <akim@epita.fr>
566
567 * src/scan-gram.l (id): Can start with an underscore.
568
a945ec39
AD
5692002-07-16 Akim Demaille <akim@epita.fr>
570
571 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
572 Adjust all former `associativity' dependencies.
573 * src/symtab.c (symbol_new): Default associativity is `undef', not
574 `right'.
575 (symbol_check_alias_consistence): Adjust.
576
fae437e8
AD
5772002-07-09 Akim Demaille <akim@epita.fr>
578
579 * doc/bison.texinfo: Properly set the ``header'' part.
580 Use @dircategory ``GNU programming tools'' as per Texinfo's
581 documentation.
582 Use @copying.
583
1a715ef2
AD
5842002-07-09 Akim Demaille <akim@epita.fr>
585
586 * lib/quotearg.h: Protect against multiple inclusions.
587 * src/location.h (location_t): Add a `file' member.
588 (LOCATION_RESET, LOCATION_PRINT): Adjust.
589 * src/complain.c (warn_at, complain_at, fatal_at): Drop
590 `error_one_per_line' support.
591
a5d50994
AD
5922002-07-09 Akim Demaille <akim@epita.fr>
593
594 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
595 * src/reader.c (lineno): Remove.
596 Adjust all dependencies.
597 (get_merge_function): Take a location and use complain_at.
598 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
599 * tests/regression.at (Invalid inputs, Mixing %token styles):
600 Adjust.
601
b275314e
AD
6022002-07-09 Akim Demaille <akim@epita.fr>
603
604 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
605 recovery rule, and forbid extensions when --yacc.
606 (gram_error): Use complain_at.
607 * src/reader.c (reader): Exit if there were parse errors.
608
865b9df1
AD
6092002-07-09 Akim Demaille <akim@epita.fr>
610
611 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
612 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
613 Reported by R Blake <blakers@mac.com>.
614
c76e14da
AD
6152002-07-09 Akim Demaille <akim@epita.fr>
616
617 * data/yacc.c: Output the copyright notive in the header.
618
7db2ed2d
AD
6192002-07-03 Akim Demaille <akim@epita.fr>
620
621 * src/output.c (froms, tos): Are state_number_t.
622 (save_column): sp, sp1, and sp2 are state_number_t.
623 (prepare): Rename `final' as `final_state_number', `nnts' as
624 `nterms_number', `nrules' as `rules_number', `nstates' as
625 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
626 unused.
627 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
628 * data/lalr1.cc (nsym_): Remove, unused.
629
e68e0410
AD
6302002-07-03 Akim Demaille <akim@epita.fr>
631
632 * src/lalr.h, src/lalr.c (goto_number_t): New.
633 * src/lalr.c (goto_list_t): New.
634 Propagate them.
635 * src/nullable.c (rule_list_t): New.
636 Propagate.
637 * src/types.h: Remove.
638
e1a4f3a4
AD
6392002-07-03 Akim Demaille <akim@epita.fr>
640
641 * src/closure.c (print_fderives): Use rule_rhs_print.
642 * src/derives.c (print_derives): Use rule_rhs_print.
643 (rule_list_t): New, replaces `shorts'.
644 (set_derives): Add comments.
645 * tests/sets.at (Nullable, Firsts): Adjust.
646
536545f3
AD
6472002-07-03 Akim Demaille <akim@epita.fr>
648
649 * src/output.c (prepare_actions): Free `tally' and `width'.
650 (prepare_actions): Allocate and free `order'.
651 * src/symtab.c (symbols_free): Free `symbols'.
652 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
653 * src/output.c (m4_invoke): Move to...
654 * src/scan-skel.l: here.
655 (<<EOF>>): Close yyout, and free its name.
656
8b752b00
AD
6572002-07-03 Akim Demaille <akim@epita.fr>
658
659 Fix some memory leaks, and fix a bug: state 0 was examined twice.
660
661 * src/LR0.c (new_state): Merge into...
662 (state_list_append): this.
663 (new_states): Merge into...
664 (generate_states): here.
665 (set_states): Don't ensure a proper `errs' state member here, do it...
666 * src/conflicts.c (conflicts_solve): here.
667 * src/state.h, src/state.c: Comment changes.
668 (state_t): Rename member `shifts' as `transitions'.
669 Adjust all dependencies.
670 (errs_new): For consistency, also take the values as argument.
671 (errs_dup): Remove.
672 (state_errs_set): New.
673 (state_reductions_set, state_transitions_set): Assert that no
674 previous value was assigned.
675 (state_free): New.
676 (states_free): Use it.
677 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
678 temporary storage: use `errs' and `nerrs' as elsewhere.
679 (set_conflicts): Allocate and free this `errs'.
680
613f5e1a
AD
6812002-07-02 Akim Demaille <akim@epita.fr>
682
683 * lib/libiberty.h: New.
684 * lib: Update the bitset implementation from upstream.
685 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
686 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
687 * src/main.c: Adjust bitset stats calls.
688
26e0cadc
PE
6892002-07-01 Paul Eggert <eggert@twinsun.com>
690
691 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
692 char, so that negative chars don't collide with $.
693
1154cced
AD
6942002-06-30 Akim Demaille <akim@epita.fr>
695
696 Have the GLR tests be `warning' checked, and fix the warnings.
697
698 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
699 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
700 (yyremoveDeletes): `yyi' and `yyj' are size_t.
701 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
702 (yyaddDeferredAction): static.
703 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
704 (yyreportParseError): yyprefix is const.
705 yytokenp is used only when verbose.
706 (yy__GNUC__): Replace with __GNUC__.
707 (yypdumpstack): yyi is size_t.
708 (yypreference): Un-yy local variables and arguments, to avoid
709 clashes with `yyr1'. Anyway, we are not in the user name space.
710 (yytname_size): be an int, as is compared with ints.
711 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
712 Use them.
713 * tests/cxx-gram.at: Use quotation to protect $1.
714 Use AT_COMPILE to enable warnings hunts.
715 Prototype yylex and yyerror.
716 `Use' argc.
717 Include `string.h', not `strings.h'.
718 Produce and prototype stmtMerge only when used.
719 yylex takes a location.
720
97650f4e
AD
7212002-06-30 Akim Demaille <akim@epita.fr>
722
723 We spend a lot of time in quotearg, in particular when --verbose.
724
725 * src/symtab.c (symbol_get): Store a quoted version of the key.
726 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
727 Adjust all callers.
728
d2576365
AD
7292002-06-30 Akim Demaille <akim@epita.fr>
730
731 * src/state.h (reductions_t): Rename member `nreds' as num.
732 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
733 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
734
ccaf65bc
AD
7352002-06-30 Akim Demaille <akim@epita.fr>
736
737 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
738 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
739 (shifts_to): Rename as...
740 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
741 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
742 (TRANSITION_IS_DISABLED, transitions_to): these.
743
87675353
AD
7442002-06-30 Akim Demaille <akim@epita.fr>
745
746 * src/print.c (print_shifts, print_gotos): Merge into...
747 (print_transitions): this.
748 (print_transitions, print_errs, print_reductions): Align the
749 lookaheads columns.
750 (print_core, print_transitions, print_errs, print_state,
751 print_grammar): Output empty lines separator before, not after.
752 (state_default_rule_compute): Rename as...
753 (state_default_rule): this.
754 * tests/conflicts.at (Defaulted Conflicted Reduction),
755 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
756 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
757
ce4ccb4b
AD
7582002-06-30 Akim Demaille <akim@epita.fr>
759
760 Display items as we display rules.
761
762 * src/gram.h, src/gram.c (rule_lhs_print): New.
763 * src/gram.c (grammar_rules_partial_print): Use it.
764 * src/print.c (print_core): Likewise.
765 * tests/conflicts.at (Defaulted Conflicted Reduction),
766 (Unresolved SR Conflicts): Adjust.
767 (Unresolved SR Conflicts): Adjust and rename as...
768 (Resolved SR Conflicts): this, as was meant.
769 * tests/regression.at (Web2c Report): Adjust.
770
bc933ef1
AD
7712002-06-30 Akim Demaille <akim@epita.fr>
772
773 * src/print.c (state_default_rule_compute): New, extracted from...
774 (print_reductions): here.
775 Pessimize, but clarify the code.
776 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
777
53d4308d
AD
7782002-06-30 Akim Demaille <akim@epita.fr>
779
780 * src/output.c (action_row): Let default_rule be always a rule
781 number.
782
574fb2d5
AD
7832002-06-30 Akim Demaille <akim@epita.fr>
784
785 * src/closure.c (print_firsts, print_fderives, closure):
786 Use BITSET_EXECUTE.
787 * src/lalr.c (lookaheads_print): Likewise.
788 * src/state.c (state_rule_lookaheads_print): Likewise.
789 * src/print_graph.c (print_core): Likewise.
790 * src/print.c (print_reductions): Likewise.
791 * src/output.c (action_row): Likewise.
792 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
793
05811fd7
AD
7942002-06-30 Akim Demaille <akim@epita.fr>
795
796 * src/print_graph.c: Use report_flag.
797
0e4d5753
AD
7982002-06-30 Akim Demaille <akim@epita.fr>
799
800 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
801 to...
802 * src/relation.h, src/relation.c (traverse, relation_digraph)
803 (relation_print, relation_transpose): New.
804
24c7d800
AD
8052002-06-30 Akim Demaille <akim@epita.fr>
806
807 * src/state.h, src/state.c (shifts_to): New.
808 * src/lalr.c (build_relations): Use it.
809
9222837b
AD
8102002-06-30 Akim Demaille <akim@epita.fr>
811
812 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
813 (item_number_of_rule_number, rule_number_of_item_number): New.
814 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
815 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
816 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
817 Propagate their use.
818 Much remains to be done, in particular wrt `shorts' from types.h.
819
260008e5
AD
8202002-06-30 Akim Demaille <akim@epita.fr>
821
822 * src/symtab.c (symbol_new): Initialize the `printer' member.
823
8a731ca8
AD
8242002-06-30 Akim Demaille <akim@epita.fr>
825
826 * src/LR0.c (save_reductions): Remove, replaced by...
827 * src/state.h, src/state.c (state_reductions_set): New.
828 (reductions, errs): Rename as...
829 (reductions_t, errs_t): these.
830 Adjust all dependencies.
831
32e1e0a4
AD
8322002-06-30 Akim Demaille <akim@epita.fr>
833
834 * src/LR0.c (state_list_t, state_list_append): New.
835 (first_state, last_state): Now symbol_list_t.
836 (this_state): Remove.
837 (new_itemsets, append_states, save_reductions): Take a state_t as
838 argument.
839 (set_states, generate_states): Adjust.
840 (save_shifts): Remove, replaced by...
841 * src/state.h, src/state.c (state_shifts_set): New.
842 (shifts): Rename as...
843 (shifts_t): this.
844 Adjust all dependencies.
845 * src/state.h (state_t): Remove the `next' member.
846
e5fb6710
AD
8472002-06-30 Akim Demaille <akim@epita.fr>
848
849 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
850 escaped in slot 0.
851
c7ca99d4
AD
8522002-06-30 Akim Demaille <akim@epita.fr>
853
854 Use hash.h for the state hash table.
855
856 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
857 (allocate_storage): Use state_hash_new.
858 (free_storage): Use state_hash_free.
859 (new_state, get_state): Adjust.
860 * src/lalr.h, src/lalr.c (states): Move to...
861 * src/states.h (state_t): Remove the `link' member, no longer
862 used.
863 * src/states.h, src/states.c: here.
864 (state_hash_new, state_hash_free, state_hash_lookup)
865 (state_hash_insert, states_free): New.
866 * src/states.c (state_table, state_compare, state_hash): New.
867 * src/output.c (output_actions): Do not free states now, since we
868 still need to know the final_state number in `prepare', called
869 afterwards. Do it...
870 * src/main.c (main): here: call states_free after `output'.
871
df0e7316
AD
8722002-06-30 Akim Demaille <akim@epita.fr>
873
874 * src/state.h, src/state.c (state_new): New, extracted from...
875 * src/LR0.c (new_state): here.
876 * src/state.h (STATE_ALLOC): Move to...
877 * src/state.c: here.
878 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
879 * src/state.h, src/state.c: here.
880
39f41916
AD
8812002-06-30 Akim Demaille <akim@epita.fr>
882
883 * src/reader.c (gensym): Rename as...
884 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
885 (getsym): Rename as...
886 (symbol_get): this.
887
d57650a5
AD
8882002-06-30 Akim Demaille <akim@epita.fr>
889
890 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
891 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
892 * src/output.c, src/print.c, src/print_graph.c: Propagate.
893 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
894
5a08f1ce
AD
8952002-06-30 Akim Demaille <akim@epita.fr>
896
897 Make the test suite pass with warnings checked.
898
899 * tests/actions.at (Printers and Destructors): Improve.
900 Avoid unsigned vs. signed issues.
901 * tests/calc.at: Don't exercise the scanner here, do it...
902 * tests/input.at (Torturing the Scanner): here.
903
720623af
PH
9042002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
905
88e7e941 906 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
907 reorganize first lines parallel to yacc.c.
908
fb8135fa
AD
9092002-06-28 Akim Demaille <akim@epita.fr>
910
911 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
912 (b4_token_enum, b4_token_defines): New, factored from...
913 * data/lalr1.cc, data/yacc.c, glr.c: here.
914
41442480
AD
9152002-06-28 Akim Demaille <akim@epita.fr>
916
917 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
918 unused variables.
919 * src/output.c (merger_output): static.
920
e0e5bf84
AD
9212002-06-28 Akim Demaille <akim@epita.fr>
922
923 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
924 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
925 pacify GCC.
926 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 927
676385e2
PH
9282002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
929
930 Accumulated changelog for new GLR parsing features.
931
6a254321 932 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
933 conflicts_total_count.
934 * src/conflicts.h: Ditto.
935 * src/output.c (token_actions): Use the new name.
936 (output_conflicts): Change conflp => conflict_list_heads, and
937 confl => conflict_list for better readability.
938 * data/glr.c: Use the new names.
939 * NEWS: Add self to GLR announcement.
e0e5bf84 940
676385e2
PH
941 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
942
943 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
944 Akim Demaille.
945
946 * data/bison.glr: Change name to glr.c
947 * data/glr.c: Renamed from bison.glr.
948 * data/Makefile.am: Add glr.c
e0e5bf84
AD
949
950 * src/getargs.c:
951
676385e2
PH
952 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
953 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 954
676385e2
PH
955 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
956
957 * data/bison.glr: Be sure to restore the
958 current #line when returning to the skeleton contents after having
959 exposed the input file's #line.
960
961 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
962
963 * data/bison.glr: Bring up to date with changes to bison.simple.
964
965 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
966
967 * data/bison.glr: Correct definitions that use b4_prefix.
968 Various reformatting.
969 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
970 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
971 yytokenp argument; now part of stack.
972 (yychar): Define to behave as documented.
973 (yyclearin): Ditto.
e0e5bf84 974
676385e2
PH
975 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
976
977 * src/reader.h: Add declaration for free_merger_functions.
978
979 * src/reader.c (merge_functions): New variable.
980 (get_merge_function): New function.
981 (free_merger_functions): New function.
982 (readgram): Check for %prec that is not followed by a symbol.
983 Handle %dprec and %merge declarations.
984 (packgram): Initialize dprec and merger fields in rules array.
985
986 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
987 conflict_list_cnt, conflict_list_free): New variables.
988 (table_grow): Also grow conflict_table.
e0e5bf84 989 (prepare_rules): Output dprec and merger tables.
676385e2 990 (conflict_row): New function.
e0e5bf84 991 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
992 default reduction in conflicted states for GLR parser so that there
993 are spaces for the conflict lists.
994 (save_row): Also save conflict information.
995 (token_actions): Allocate conflict list.
996 (merger_output): New function.
997 (pack_vector): Pack conflict table, too.
998 (output_conflicts): New function to output yyconflp and yyconfl.
999 (output_check): Allocate conflict_tos.
1000 (output_actions): Output conflict tables, also.
1001 (output_skeleton): Output b4_mergers definition.
1002 (prepare): Output b4_max_rhs_length definition.
1003 Use 'bison.glr' as default skeleton for GLR parsers.
1004
1005 * src/gram.c (glr_parser): New flag.
1006 (grammar_free): Call free_merger_functions.
1007
1008 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1009 all pairs of conflicting reductions, rather than just all tokens
1010 causing conflicts. Needed to size conflict tables.
e0e5bf84 1011 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
1012 interface.
1013 (conflicts_print): Ditto.
1014 (count_total_conflicts): New function.
1015
1016 * src/reader.h (merger_list): New type.
1017 (merge_functions): New variable.
1018
1019 * src/lex.h (tok_dprec, tok_merge): New token types.
1020
1021 * src/gram.h (rule_s): Add dprec and merger fields.
1022 (glr_parser): New flag.
1023
1024 * src/conflicts.h (count_total_conflicts): New function.
1025
1026 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1027
1028 * doc/bison.texinfo (Generalized LR Parsing): New section.
1029 (GLR Parsers): New section.
1030 (Language and Grammar): Mention GLR parsing.
1031 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1032 Correct typo ("tge" -> "the").
1033
1034 * data/bison.glr: New skeleton for GLR parsing.
1035
1036 * tests/cxx-gram.at: New tests for GLR parsing.
1037
1038 * tests/testsuite.at: Include cxx-gram.at.
1039
1040 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 1041
676385e2
PH
1042 * src/parse-gram.y:
1043
1044 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1045
1046 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 1047
b5480d74 10482002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
1049
1050 * src/options.h, src/options.c: Remove.
1051 * src/getargs.c (short_options, long_options): New.
1052
60491a94
AD
10532002-06-27 Akim Demaille <akim@epita.fr>
1054
1055 * data/bison.simple, data/bison.c++: Rename as...
1056 * data/yacc.c, data/lalr1.cc: these.
1057 * doc/bison.texinfo (Environment Variables): Remove.
1058
9be0c25b
AD
10592002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1060
1061 * src/getargs.c (report_argmatch): Initialize strtok().
1062
1ae72863
AD
10632002-06-20 Akim Demaille <akim@epita.fr>
1064
1065 * data/bison.simple (b4_symbol_actions): New, replaces...
1066 (b4_symbol_destructor, b4_symbol_printer): these.
1067 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1068 user token numbers.
1069
87542d29
AD
10702002-06-20 Akim Demaille <akim@epita.fr>
1071
1072 * data/bison.simple (yydestructor): Rename as...
1073 (yydestruct): this.
1074
1a31ed21
AD
10752002-06-20 Akim Demaille <akim@epita.fr>
1076
1077 * src/symtab.h, src/symtab.c (symbol_type_set)
1078 (symbol_destructor_set, symbol_precedence_set): The location is
1079 the last argument.
1080 Adjust all callers.
1081
e776192e
AD
10822002-06-20 Akim Demaille <akim@epita.fr>
1083
1084 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1085 internals.
1086 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1087 Takes a location.
1088 * src/symtab.h, src/symtab.c (symbol_class_set)
1089 (symbol_user_token_number_set): Likewise.
1090 Adjust all callers.
1091 Promote complain_at.
1092 * tests/input.at (Type Clashes): Adjust.
1093
5c1180b3
AD
10942002-06-20 Akim Demaille <akim@epita.fr>
1095
1096 * data/bison.simple (YYLEX): Fix the declaration when
1097 %pure-parser.
1098
e3170060
AD
10992002-06-20 Akim Demaille <akim@epita.fr>
1100
1101 * data/bison.simple (yysymprint): Don't print the token number,
1102 just its name.
1103 * tests/actions.at (Destructors): Rename as...
1104 (Printers and Destructors): this.
1105 Also exercise %printer.
1106
253862fd
AD
11072002-06-20 Akim Demaille <akim@epita.fr>
1108
1109 * data/bison.simple (YYDSYMPRINT): New.
1110 Use it to remove many of the #if YYDEBUG/if (yydebug).
1111
366eea36
AD
11122002-06-20 Akim Demaille <akim@epita.fr>
1113
1114 * src/symtab.h, src/symtab.c (symbol_t): printer and
1115 printer_location are new members.
1116 (symbol_printer_set): New.
1117 * src/parse-gram.y (PERCENT_PRINTER): New token.
1118 Handle its associated rule.
1119 * src/scan-gram.l: Adjust.
1120 (handle_destructor_at, handle_destructor_dollar): Rename as...
1121 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1122 * src/output.c (symbol_printers_output): New.
1123 (output_skeleton): Call it.
1124 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1125 since there are already many grammar files with a user `yyprint'.
1126 Replace the calls to YYPRINT to calls to yysymprint.
1127 * tests/calc.at: Adjust.
1128 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1129 taking advantage of parser very internal details (stack size!).
1130
4f25ebb0
AD
11312002-06-20 Akim Demaille <akim@epita.fr>
1132
1133 * src/scan-gram.l: Complete the scanner with the missing patterns
1134 to pacify Flex.
1135 Use `quote' and `symbol_tag_get' where appropriate.
1136
93b68a0e
AD
11372002-06-19 Akim Demaille <akim@epita.fr>
1138
1139 * tests/actions.at (Destructors): Augment to test locations.
1140 * data/bison.simple (yydestructor): Pass it the current location
1141 if locations are enabled.
1142 Prototype only when __STDC__ or C++.
1143 Change the argument names to move into the yy name space: there is
1144 user code here.
1145
58612f1d
AD
11462002-06-19 Akim Demaille <akim@epita.fr>
1147
74310291
AD
1148 * data/bison.simple (b4_pure_if): New.
1149 Use it instead of #ifdef YYPURE.
1150
11512002-06-19 Akim Demaille <akim@epita.fr>
1152
1153 * data/bison.simple (b4_location_if): New.
58612f1d
AD
1154 Use it instead of #ifdef YYLSP_NEEDED.
1155
f25bfb75
AD
11562002-06-19 Akim Demaille <akim@epita.fr>
1157
1158 Prepare @$ in %destructor, but currently don't bind it in the
1159 skeleton, as %location use is not cleaned up yet.
1160
1161 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1162 (handle_action_at): New.
1163 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1164 a braced_code_t and a location as additional arguments.
1165 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1166 unquote one when outputting `b4_dollar_dollar'.
1167 Adjust callers.
1168 * data/bison.simple (b4_eval): Remove.
1169 (b4_symbol_destructor): Adjust.
1170 * tests/input.at (Invalid @n): Adjust.
1171
c732d2c6
AD
11722002-06-19 Zack Weinberg <zack@codesourcery.com>
1173
1174 * doc/bison.texinfo: Document ability to have multiple
1175 prologue sections.
1176
8c165d89
AD
11772002-06-18 Akim Demaille <akim@epita.fr>
1178
1179 * src/files.c (compute_base_names): When computing the output file
1180 names from the input file name, strip the directory part.
1181
ca98bf57
AD
11822002-06-18 Akim Demaille <akim@epita.fr>
1183
1184 * data/bison.simple.new: Comment changes.
1185 Reported by Andreas Schwab.
1186
0bfb02ff
AD
11872002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1188
1189 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1190 there are no `label `yyoverflowlab' defined but not used' warnings
1191 when yyoverflow is defined.
1192
24c0aad7
AD
11932002-06-18 Akim Demaille <akim@epita.fr>
1194
1195 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1196 new member.
1197 (symbol_destructor_set): Adjust.
1198 * src/output.c (symbol_destructors_output): Output the destructor
1199 locations.
1200 Output the symbol name.
1201 * data/bison.simple (b4_symbol_destructor): Adjust.
1202
5719c109
AD
12032002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1204 and Akim Demaille <akim@epita.fr>
1205
1206 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1207 what's left on the stack when the error recovery hits EOF.
1208 * tests/actions.at (Destructors): Complete to exercise this case.
1209
9280d3ef
AD
12102002-06-17 Akim Demaille <akim@epita.fr>
1211
1212 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1213 arguments is really empty, not only equal to `[]'.
1214 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1215 member.
1216 (symbol_destructor_set): New.
1217 * src/output.c (symbol_destructors_output): New.
1218 * src/reader.h (brace_code_t, current_braced_code): New.
1219 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1220 (handle_dollar): Rename as...
1221 (handle_action_dollar): this.
1222 (handle_destructor_dollar): New.
1223 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1224 (grammar_declaration): Use it.
1225 * data/bison.simple (yystos): Is always defined.
1226 (yydestructor): New.
1227 * tests/actions.at (Destructors): New.
1228 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1229
dafdc66f
AD
12302002-06-17 Akim Demaille <akim@epita.fr>
1231
1232 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1233 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1234 rule_length only when needed.
1235 * src/output.c (actions_output, token_definitions_output): Output
1236 the full M4 block.
1237 * src/symtab.c: Don't access directly to the symbol tag, use
1238 symbol_tag_get.
1239 * src/parse-gram.y: Use symbol_list_free.
1240
56c47203
AD
12412002-06-17 Akim Demaille <akim@epita.fr>
1242
1243 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1244 (symbol_list_prepend, get_type_name): Move to...
1245 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1246 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1247 Adjust all callers.
1248 (symbol_list_free): New.
1249 * src/scan-gram.l (handle_dollar): Takes a location.
1250 * tests/input.at (Invalid $n): Adjust.
1251
1e0bab92
AD
12522002-06-17 Akim Demaille <akim@epita.fr>
1253
1254 * src/reader.h, src/reader.c (symbol_list_new): Export it.
1255 (symbol_list_prepend): New.
1256 * src/parse-gram.y (%union): `list' is a new member.
1257 (symbols.1): New, replaces...
1258 (terms_to_prec.1, nterms_to_type.1): these.
1259 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
1260 Take a location as additional argument.
1261 Adjust all callers.
1262
04e60654
AD
12632002-06-15 Akim Demaille <akim@epita.fr>
1264
1265 * src/parse-gram.y: Move %token in the declaration section so that
1266 we don't depend upon CVS Bison.
1267
10e5b8bd
AD
12682002-06-15 Akim Demaille <akim@epita.fr>
1269
1270 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
1271 * src/print.c (print_core): Use it.
1272
9801d40c
AD
12732002-06-15 Akim Demaille <akim@epita.fr>
1274
1275 * src/conflicts.c (log_resolution): Accept the rule involved in
1276 the sr conflicts instead of the lookahead number that points to
1277 that rule.
1278 (flush_reduce): Accept the current lookahead vector as argument,
1279 instead of the index in LA.
1280 (resolve_sr_conflict): Accept the current number of lookahead
1281 bitset to consider for the STATE, instead of the index in LA.
1282 (set_conflicts): Adjust.
1283 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
1284
c0263492
AD
12852002-06-15 Akim Demaille <akim@epita.fr>
1286
1287 * src/state.h (state_t): Replace the `lookaheadsp' member, a
1288 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
1289 Adjust all dependencies.
1290 * src/lalr.c (initialize_lookaheads): Split into...
1291 (states_lookaheads_count, states_lookaheads_initialize): these.
1292 (lalr): Adjust.
1293
9757c359
AD
12942002-06-15 Akim Demaille <akim@epita.fr>
1295
1296 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
1297 out of...
1298 (grammar_rules_print): here.
1299 * src/reduce.c (reduce_output): Use it.
1300 * tests/reduce.at (Useless Rules, Reduced Automaton)
1301 (Underivable Rules): Adjust.
1302
6b98e4b5
AD
13032002-06-15 Akim Demaille <akim@epita.fr>
1304
1305 Copy BYacc's nice way to report the grammar.
1306
1307 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
1308 New.
1309 Don't print the rules' location, it is confusing and useless.
1310 (rule_print): Use grammar_rhs_print.
1311 * src/print.c (print_grammar): Use grammar_rules_print.
1312
6b98e4b5
AD
13132002-06-15 Akim Demaille <akim@epita.fr>
1314
1315 Complete and rationalize `useless thing' warnings.
1316
1317 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
1318 (symbol_tag_print): New.
1319 Use them everywhere in place of accessing directly the tag member.
1320 * src/gram.h, src/gram.c (rule_print): New.
1321 Use it where a rule used to be printed `by hand'.
1322 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
1323 (reduce_grammar_tables): Report the useless rules.
1324 (reduce_print): Useless things are a warning, not an error.
1325 Report it as such.
1326 * tests/reduce.at (Useless Nonterminals, Useless Rules):
1327 (Reduced Automaton, Underivable Rules): Adjust.
1328 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
1329 * tests/conflicts.at (Unresolved SR Conflicts)
1330 (Solved SR Conflicts): Adjust.
1331
ee000ba4
AD
13322002-06-15 Akim Demaille <akim@epita.fr>
1333
1334 Let symbols have a location.
1335
1336 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
1337 (getsym): Adjust.
1338 Adjust all callers.
1339 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
1340 Use location_t, not int.
1341 * src/symtab.c (symbol_check_defined): Take advantage of the
1342 location.
1343 * tests/regression.at (Invalid inputs): Adjust.
1344
8efe435c
AD
13452002-06-15 Akim Demaille <akim@epita.fr>
1346
1347 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
1348 (input): Don't try to initialize yylloc here, do it in the
1349 scanner.
1350 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
1351 * src/gram.h (rule_t): Change line and action_line into location
1352 and action_location, of location_t type.
1353 Adjust all dependencies.
1354 * src/location.h, src/location.c (empty_location): New.
1355 * src/reader.h, src/reader.c (grammar_start_symbol_set)
1356 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
1357 (grammar_current_rule_symbol_append)
1358 (grammar_current_rule_action_append): Expect a location as argument.
1359 * src/reader.c (grammar_midrule_action): Adjust to attach an
1360 action's location as dummy symbol location.
1361 * src/symtab.h, src/symtab.c (startsymbol_location): New.
1362 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
1363 the line numbers.
1364
1921f1d7
AD
13652002-06-14 Akim Demaille <akim@epita.fr>
1366
1367 Grammar declarations may be found in the grammar section.
1368
1369 * src/parse-gram.y (rules_or_grammar_declaration): New.
1370 (declarations): Each declaration may end with a semicolon, not
1371 just...
1372 (grammar_declaration): `"%union"'.
1373 (grammar): Branch to rules_or_grammar_declaration.
1374
4515534c
AD
13752002-06-14 Akim Demaille <akim@epita.fr>
1376
1377 * src/main.c (main): Invoke scanner_free.
1378
f958596b
AD
13792002-06-14 Akim Demaille <akim@epita.fr>
1380
1381 * src/output.c (m4_invoke): Extracted from...
1382 (output_skeleton): here.
1383 Free tempfile.
1384
2c569025
AD
13852002-06-14 Akim Demaille <akim@epita.fr>
1386
1387 * src/parse-gram.y (directives, directive, gram)
1388 (grammar_directives, precedence_directives, precedence_directive):
1389 Rename as...
1390 (declarations, declaration, grammar, grammar_declaration)
1391 (precedence_declaration, precedence_declarator): these.
1392 (symbol_declaration): New.
1393
592e8d4d
AD
13942002-06-14 Akim Demaille <akim@epita.fr>
1395
1396 * src/files.c (action_obstack): Remove, unused.
1397 (output_obstack): Remove it, and all its dependencies, as it is no
1398 longer needed.
1399 * src/reader.c (epilogue_set): Build the epilogue in the
1400 muscle_obstack.
1401 * src/output.h, src/output.c (muscle_obstack): Move to...
1402 * src/muscle_tab.h, src/muscle_tab.h: here.
1403 (muscle_init): Initialize muscle_obstack.
1404 (muscle_free): New.
1405 * src/main.c (main): Call it.
1406
0c15323d
AD
14072002-06-14 Akim Demaille <akim@epita.fr>
1408
1409 * src/location.h: New, extracted from...
1410 * src/reader.h: here.
1411 * src/Makefile.am (noinst_HEADERS): Merge into
1412 (bison_SOURCES): this.
1413 Add location.h.
1414 * src/parse-gram.y: Use location_t instead of Bison's.
1415 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
1416 Use location_t instead of ints.
1417
e96c9728
AD
14182002-06-14 Akim Demaille <akim@epita.fr>
1419
1420 * data/bison.simple, data/bison.c++: Be sure to restore the
1421 current #line when returning to the skeleton contents after having
1422 exposed the input file's #line.
1423
75d1fe16
AD
14242002-06-12 Akim Demaille <akim@epita.fr>
1425
1426 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
1427 eager.
1428 * tests/actions.at (Exotic Dollars): New.
1429
6c35d22c
AD
14302002-06-12 Akim Demaille <akim@epita.fr>
1431
1432 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
1433 ['"/] too eagerly.
1434 * tests/input.at (Torturing the Scanner): New.
1435
1d6412ad
AD
14362002-06-11 Akim Demaille <akim@epita.fr>
1437
1438 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
1439 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
1440 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
1441 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
1442 * src/reader.c (reader): Use it.
1443
4cdb01db
AD
14442002-06-11 Akim Demaille <akim@epita.fr>
1445
1446 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
1447 Adjust all callers.
1448 (scanner_last_string_free): New.
1449
44995b2e
AD
14502002-06-11 Akim Demaille <akim@epita.fr>
1451
1452 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
1453 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
1454 (last_string, YY_OBS_FREE): New.
1455 Use them when returning an ID.
1456
e9955c83
AD
14572002-06-11 Akim Demaille <akim@epita.fr>
1458
1459 Have Bison grammars parsed by a Bison grammar.
1460
1461 * src/reader.c, src/reader.h (prologue_augment): New.
1462 * src/reader.c (copy_definition): Remove.
1463
1464 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
1465 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
1466 (grammar_current_rule_prec_set, grammar_current_rule_check)
1467 (grammar_current_rule_symbol_append)
1468 (grammar_current_rule_action_append): Export.
1469 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
1470 (symbol_list_action_append): Remove.
1471 Hook the routines from reader.
1472 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
1473 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
1474
1475 * src/reader.c (read_declarations): Remove, unused.
1476
1477 * src/parse-gram.y: Handle the epilogue.
1478 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
1479 (grammar_start_symbol_set): this.
1480 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
1481 * src/reader.c (readgram): Remove, unused.
1482 (reader): Adjust to insert eoftoken and axiom where appropriate.
1483
1484 * src/reader.c (copy_dollar): Replace with...
1485 * src/scan-gram.h (handle_dollar): this.
1486 * src/parse-gram.y: Remove `%thong'.
1487
1488 * src/reader.c (copy_at): Replace with...
1489 * src/scan-gram.h (handle_at): this.
1490
1491 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
1492 New.
1493
1494 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
1495 time being.
1496
1497 * src/reader.h, src/reader.c (grammar_rule_end): New.
1498
1499 * src/parse.y (current_type, current_class): New.
1500 Implement `%nterm', `%token' support.
1501 Merge `%term' into `%token'.
1502 (string_as_id): New.
1503 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
1504 type name.
1505
1506 * src/parse-gram.y: Be sure to handle properly the beginning of
1507 rules.
1508
1509 * src/parse-gram.y: Handle %type.
1510 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
1511
1512 * src/parse-gram.y: More directives support.
1513 * src/options.c: No longer handle source directives.
1514
1515 * src/parse-gram.y: Fix %output.
1516
1517 * src/parse-gram.y: Handle %union.
1518 Use the prologue locations.
1519 * src/reader.c (parse_union_decl): Remove.
1520
1521 * src/reader.h, src/reader.c (epilogue_set): New.
1522 * src/parse-gram.y: Use it.
1523
1524 * data/bison.simple, data/bison.c++: b4_stype is now either not
1525 defined, then default to int, or to the contents of %union,
1526 without `union' itself.
1527 Adjust.
1528 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
1529
1530 * src/output.c (actions_output): Don't output braces, as they are
1531 already handled by the scanner.
1532
1533 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
1534 characters to themselves.
1535
1536 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
1537 that the epilogue has a proper #line.
1538
1539 * src/parse-gram.y: Handle precedence/associativity.
1540
1541 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
1542 a terminal.
1543 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
1544 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
1545 at all to define terminals that cannot be emitted.
1546
1547 * src/scan-gram.l: Escape M4 characters.
1548
1549 * src/scan-gram.l: Working properly with escapes in user
1550 strings/characters.
1551
1552 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
1553 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
1554 grammar.
1555 Use more modest sizes, as for the time being the parser does not
1556 release memory, and therefore the process swallows a huge amount
1557 of memory.
1558
1559 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
1560 stricter %token grammar.
1561
1562 * src/symtab.h (associativity): Add `undef_assoc'.
1563 (symbol_precedence_set): Do nothing when passed an undef_assoc.
1564 * src/symtab.c (symbol_check_alias_consistence): Adjust.
1565
1566 * tests/regression.at (Invalid %directive): Remove, as it is now
1567 meaningless.
1568 (Invalid inputs): Adjust to the new error messages.
1569 (Token definitions): The new grammar doesn't allow too many
1570 eccentricities.
1571
1572 * src/lex.h, src/lex.c: Remove.
1573 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1574 (copy_character, copy_string2, copy_string, copy_identifier)
1575 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1576 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1577 (parse_action): Remove.
1578 * po/POTFILES.in: Adjust.
1579
2e047461
AD
15802002-06-11 Akim Demaille <akim@epita.fr>
1581
1582 * src/reader.c (parse_action): Don't store directly into the
1583 rule's action member: return the action as a string.
1584 Don't require `rule_length' as an argument: compute it.
1585 (grammar_current_rule_symbol_append)
1586 (grammar_current_rule_action_append): New, eved out from
1587 (readgram): here.
1588 Remove `action_flag', `rulelength', unused now.
1589
9af3fbce
AD
15902002-06-11 Akim Demaille <akim@epita.fr>
1591
1592 * src/reader.c (grammar_current_rule_prec_set).
1593 (grammar_current_rule_check): New, eved out from...
1594 (readgram): here.
1595 Remove `xaction', `first_rhs': useless.
1596 * tests/input.at (Type clashes): New.
1597 * tests/existing.at (GNU Cim Grammar): Adjust.
1598
1485e106
AD
15992002-06-11 Akim Demaille <akim@epita.fr>
1600
1601 * src/reader.c (grammar_midrule_action): New, Eved out from
1602 (readgram): here.
1603
da4160c3
AD
16042002-06-11 Akim Demaille <akim@epita.fr>
1605
1606 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1607 New.
1608 (readgram): Use them as replacement of inlined code, crule and
1609 crule1.
1610
f6d0f937
AD
16112002-06-11 Akim Demaille <akim@epita.fr>
1612
1613 * src/reader.c (grammar_end, grammar_symbol_append): New.
1614 (readgram): Use them.
1615 Make the use of `p' as local as possible.
1616
69078d4b
AD
16172002-06-10 Akim Demaille <akim@epita.fr>
1618
1619 GCJ's parser requires the tokens to be defined before the prologue.
1620
1621 * data/bison.simple: Output the token definition before the user's
1622 prologue.
1623 * tests/regression.at (Braces parsing, Duplicate string)
1624 (Mixing %token styles): Check the output from bison.
1625 (Early token definitions): New.
1626
5e424082
AD
16272002-06-10 Akim Demaille <akim@epita.fr>
1628
1629 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1630 assigning twice the same user number to a token, so that we can
1631 use it in...
1632 * src/lex.c (lex): here.
1633 Also use `symbol_class_set' instead of hand written code.
1634 * src/reader.c (parse_assoc_decl): Likewise.
1635
44536b35
AD
16362002-06-10 Akim Demaille <akim@epita.fr>
1637
1638 * src/symtab.c, src/symtab.c (symbol_class_set)
1639 (symbol_user_token_number_set): New.
1640 * src/reader.c (parse_token_decl): Use them.
1641 Use a switch instead of ifs.
1642 Use a single argument.
1643
8b9f2372
AD
16442002-06-10 Akim Demaille <akim@epita.fr>
1645
1646 Remove `%thong' support as it is undocumented, unused, duplicates
1647 `%token's job, and creates useless e-mail traffic with people who
1648 want to know what it is, why it is undocumented, unused, and
1649 duplicates `%token's job.
1650
1651 * src/reader.c (parse_thong_decl): Remove.
1652 * src/options.c (option_table): Remove "thong".
1653 * src/lex.h (tok_thong): Remove.
1654
3ae2b51f
AD
16552002-06-10 Akim Demaille <akim@epita.fr>
1656
1657 * src/symtab.c, src/symtab.c (symbol_type_set)
1658 (symbol_precedence_set): New.
1659 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1660 (value_components_used): Remove, unused.
1661
2f1afb73
AD
16622002-06-09 Akim Demaille <akim@epita.fr>
1663
1664 Move symbols handling code out of the reader.
1665
1666 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1667 (axiom): Move to...
1668 * src/symtab.h, src/symtab.c: here.
1669
1670 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1671 * src/reader.c (startval): Rename as...
1672 * src/symtab.h, src/symtab.c (startsymbol): this.
1673 * src/reader.c: Adjust.
1674
1675 * src/reader.c (symbol_check_defined, symbol_make_alias)
1676 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1677 (token_translations_init)
1678 Move to...
1679 * src/symtab.c: here.
1680 * src/reader.c (packsymbols): Move to...
1681 * src/symtab.h, src/symtab.c (symbols_pack): here.
1682 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1683 argument.
1684
e9bca3ad
AD
16852002-06-03 Akim Demaille <akim@epita.fr>
1686
1687 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1688 then statements.
1689
86eff183
AD
16902002-06-03 Akim Demaille <akim@epita.fr>
1691
1692 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1693 structs with non literals.
1694 * src/scan-skel.l: never-interactive.
1695 * src/conflicts.c (enum conflict_resolution_e): No trailing
1696 comma.
1697 * src/getargs.c (usage): Split long literal strings.
1698 Reported by Hans Aberg.
1699
717be197
AD
17002002-05-28 Akim Demaille <akim@epita.fr>
1701
1702 * data/bison.c++: Use C++ ostreams.
1703 (cdebug_): New member.
1704
670ddffd
AD
17052002-05-28 Akim Demaille <akim@epita.fr>
1706
1707 * src/output.c (output_skeleton): Be sure to allocate enough room
1708 for `/' _and_ for `\0' in full_skeleton.
1709
769b430f
AD
17102002-05-28 Akim Demaille <akim@epita.fr>
1711
1712 * data/bison.c++: Catch up with bison.simple:
1713 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1714 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1715 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1716 and popping traces.
1717
7067cb36
PH
17182002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1719
1720 * src/output.c (output_skeleton): Put an explicit path in front of
1721 the skeleton file name, rather than relying on the -I directory,
1722 to partially alleviate effects of having a skeleton file lying around
1723 in the current directory.
769b430f 1724
4a713ec2
PH
17252002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1726
769b430f 1727 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
1728 obstack_printf should be obstack_fgrow1.
1729
b408954b
AD
17302002-05-26 Akim Demaille <akim@epita.fr>
1731
1732 * src/state.h (state_t): `solved_conflicts' is a new member.
1733 * src/LR0.c (new_state): Set it to 0.
1734 * src/conflicts.h, src/conflicts.c (print_conflicts)
1735 (free_conflicts, solve_conflicts): Rename as...
1736 (conflicts_print, conflicts_free, conflicts_solve): these.
1737 Adjust callers.
1738 * src/conflicts.c (enum conflict_resolution_e)
1739 (solved_conflicts_obstack): New, used by...
1740 (log_resolution): this.
1741 Adjust to attach the conflict resolution to each state.
1742 Complete the description with the precedence/associativity
1743 information.
1744 (resolve_sr_conflict): Adjust.
1745 * src/print.c (print_state): Output its solved_conflicts.
1746 * tests/conflicts.at (Unresolved SR Conflicts)
1747 (Solved SR Conflicts): Exercise --report=all.
1748
a49aecd5
AD
17492002-05-26 Akim Demaille <akim@epita.fr>
1750
1751 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1752 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1753 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1754 (token_number_t, item_number_as_token_number)
1755 (token_number_as_item_number, muscle_insert_token_number_table):
1756 Rename as...
1757 (symbol_number_t, item_number_as_symbol_number)
1758 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1759 these, since it is more appropriate.
1760
5504898e
AD
17612002-05-26 Akim Demaille <akim@epita.fr>
1762
1763 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1764 `Error:' lines.
1765 * data/bison.simple (yystos) [YYDEBUG]: New.
1766 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1767 error recovery.
1768 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1769
ec3bc396
AD
17702002-05-25 Akim Demaille <akim@epita.fr>
1771
1772 * doc/bison.texinfo (Debugging): Split into...
1773 (Tracing): this new section, its former contents, and...
1774 (Understanding): this new section.
1775 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1776 by...
1777 (report_flag): this.
1778 Adjust all dependencies.
1779 (report_args, report_types, report_argmatch): New.
1780 (usage, getargs): Report/support -r, --report.
1781 * src/options.h
1782 (struct option_table_struct): Rename as..,
1783 (struct option_table_s): this.
1784 Rename the `set_flag' member to `flag' to match with getopt_long's
1785 struct.
1786 * src/options.c (option_table): Split verbose into an entry for
1787 %verbose, and another for --verbose.
1788 Support --report/-r, so remove -r from the obsolete --raw.
1789 * src/print.c: Attach full item sets and lookaheads reports to
1790 report_flag instead of trace_flag.
1791 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1792
78df8250
PE
17932002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1794 and Paul Eggert <eggert@twinsun.com>
769b430f 1795
78df8250
PE
1796 * data/bison.simple (yyparse): Correct error handling to conform to
1797 POSIX and yacc. Specifically, after syntax error is discovered,
1798 do not reduce further before shifting the error token.
1799 Clean up the code a bit by removing the labels yyerrdefault,
1800 yyerrhandle, yyerrpop.
1801 * NEWS: Document the above.
1802
c0c9ea05
PH
18032002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1804
1805 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1806 type; it isn't always big enough, since it doesn't necessarily
1807 include non-terminals.
769b430f 1808 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
1809 the latter can be removed.
1810 (yy_token_number_type): Remove, only one use.
1811 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1812 don't use TokenNumberType as element type.
769b430f 1813
c0c9ea05
PH
1814 * tests/regression.at: Modify expected output to agree with change
1815 to yyr1 and yytranslate.
769b430f 1816
6390a83f
FK
18172002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1818
1819 * src/reader.c (parse_action): Use copy_character instead of
1820 obstack_1grow.
1821
db7c8e9a
AD
18222002-05-13 Akim Demaille <akim@epita.fr>
1823
1824 * tests/regression.at (Token definitions): Prototype yylex and
1825 yyerror.
1826
fcc61800
PH
18272002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1828
158c687b 1829 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
1830 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1831 32-bit arithmetic.
1832 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1833
5683e9b2
AD
18342002-05-07 Akim Demaille <akim@epita.fr>
1835
1836 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1837 avoid GCC warnings.
1838
0c2d3f4c
AD
18392002-05-07 Akim Demaille <akim@epita.fr>
1840
1841 Kill GCC warnings.
1842
1843 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1844 over the RHS of each rule.
1845 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1846 * src/state.h (state_t): Member `nitems' is unsigned short.
1847 * src/LR0.c (get_state): Adjust.
1848 * src/reader.c (packgram): Likewise.
1849 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1850 `Type'.
1851 (muscle_insert_int_table): Remove, unused.
1852 (prepare_rules): Remove `max'.
1853
1565b720
AD
18542002-05-06 Akim Demaille <akim@epita.fr>
1855
1856 * src/closure.c (print_firsts): Display of the symbol tags.
1857 (bitmatrix_print): Move to...
1858 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1859 here.
1860 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1861
cfaee611
AD
18622002-05-06 Akim Demaille <akim@epita.fr>
1863
1864 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1865 hash_do_for_each.
1866
458be8e0
AD
18672002-05-06 Akim Demaille <akim@epita.fr>
1868
1869 * src/LR0.c (new_state, get_state): Instead of using the global
1870 `kernel_size' and `kernel_base', have two new arguments:
1871 `core_size' and `core'.
1872 Adjust callers.
1873
a900a624
AD
18742002-05-06 Akim Demaille <akim@epita.fr>
1875
1876 * src/reader.c (packgram): No longer end `ritem' with a 0
1877 sentinel: it is not used.
1878
d4e7d3a1
AD
18792002-05-05 Akim Demaille <akim@epita.fr>
1880
1881 New experimental feature: display the lookaheads in the report and
1882 graph.
1883
1884 * src/print (print_core): When --trace-flag, display the rules
1885 lookaheads.
1886 * src/print_graph.c (print_core): Likewise.
1887 Swap the arguments.
1888 Adjust caller.
1889
39ceb25b
AD
18902002-05-05 Akim Demaille <akim@epita.fr>
1891
1892 * tests/torture.at (Many lookaheads): New test.
1893
5372019f
AD
18942002-05-05 Akim Demaille <akim@epita.fr>
1895
1896 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
1897 (GENERATE_MUSCLE_INSERT_TABLE): this.
1898 (output_int_table, output_unsigned_int_table, output_short_table)
1899 (output_token_number_table, output_item_number_table): Replace with...
1900 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
1901 (muscle_insert_short_table, muscle_insert_token_number_table)
1902 (muscle_insert_item_number_table): these.
1903 Adjust all callers.
1904 (prepare_tokens): Don't free `translations', since...
1905 * src/reader.h, src/reader.c (grammar_free): do it.
1906 Move to...
1907 * src/gram.h, src/gram.c (grammar_free): here.
1908 * data/bison.simple, data/bison.c++: b4_token_number_max is now
1909 b4_translate_max.
1910
5df5f6d5
AD
19112002-05-05 Akim Demaille <akim@epita.fr>
1912
1913 * src/output.c (output_unsigned_int_table): New.
1914 (prepare_rules): `i' is unsigned.
1915 `prhs', `rline', `r2' are unsigned int.
1916 Rename muscle `rhs_number_max' as `rhs_max'.
1917 Output muscles `prhs_max', `rline_max', and `r2_max'.
1918 Free rline and r1.
1919 * data/bison.simple, data/bison.c++: Adjust to use these muscles
1920 to compute types instead of constant types.
1921 * tests/regression.at (Web2c Actions): Adjust.
1922
b87f8b21
AD
19232002-05-04 Akim Demaille <akim@epita.fr>
1924
1925 * src/symtab.h (SALIAS, SUNDEF): Rename as...
1926 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
1927 Adjust dependencies.
1928 * src/output.c (token_definitions_output): Be sure not to output a
1929 `#define 'a'' when fed with `%token 'a' "a"'.
1930 * tests/regression.at (Token definitions): New.
1931
8bb936e4
PE
19322002-05-03 Paul Eggert <eggert@twinsun.com>
1933
1934 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
1935 for K&R C.
1936
19372002-05-03 gettextize <bug-gnu-gettext@gnu.org>
1938
1939 * Makefile.am (SUBDIRS): Remove intl.
1940 (EXTRA_DIST): Add config/config.rpath.
1941
53c71a12
AD
19422002-05-03 Akim Demaille <akim@epita.fr>
1943
1944 * data/bison.simple (m4_if): Don't output empty enums.
1945 And actually, output valid enum definitions :(.
1946
289dd0cf
AD
19472002-05-03 Akim Demaille <akim@epita.fr>
1948
1949 * configure.bat: Remove, completely obsolete.
1950 * Makefile.am (EXTRA_DIST): Adjust.
1951 Don't distribute config.rpath...
1952 * config/Makefile.am (EXTRA_DIST): Do it.
1953
db85e524
AD
19542002-05-03 Akim Demaille <akim@epita.fr>
1955
1956 * configure.in (GETTEXT_VERSION): New.
1957 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
1958
83ccf991
AD
19592002-05-03 Akim Demaille <akim@epita.fr>
1960
1961 * data/bison.simple (b4_token_enum): New.
1962 (b4_token_defines): Use it to output tokens both as #define and
1963 enums.
1964 Suggested by Paul Eggert.
1965 * src/output.c (token_definitions_output): Don't output spurious
1966 white spaces.
1967
1f418995
AD
19682002-05-03 Akim Demaille <akim@epita.fr>
1969
1970 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1971
45119f04
RA
19722002-05-02 Robert Anisko <robert@lrde.epita.fr>
1973
1974 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
1975 Update the stack class, give a try to deque as the default container.
1976
b2d52318
AD
19772002-05-02 Akim Demaille <akim@epita.fr>
1978
1979 * data/bison.simple (yyparse): Do not implement @$ = @1.
1980 (YYLLOC_DEFAULT): Adjust to do it.
1981 * doc/bison.texinfo (Location Default Action): Fix.
1982
3a8b4109
AD
19832002-05-02 Akim Demaille <akim@epita.fr>
1984
1985 * src/reader.c (parse_braces): Merge into...
1986 (parse_action): this.
1987
84614e13
AD
19882002-05-02 Akim Demaille <akim@epita.fr>
1989
1990 * configure.in (ALL_LINGUAS): Remove.
1991 * po/LINGUAS, hr.po: New.
1992
fdbcd8e2
AD
19932002-05-02 Akim Demaille <akim@epita.fr>
1994
1995 Remove the so called hairy (semantic) parsers.
1996
1997 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
1998 * src/gram.h, src/gram.c (semantic_parser): Remove.
1999 (rule_t): Remove the guard and guard_line members.
2000 * src/lex.h (token_t): remove tok_guard.
2001 * src/options.c (option_table): Remove %guard and %semantic_parser
2002 support.
2003 * src/output.c, src/output.h (guards_output): Remove.
2004 (prepare): Adjust.
2005 (token_definitions_output): Don't output the `T'
2006 tokens (???).
2007 (output_skeleton): Don't output the guards.
2008 * src/files.c, src/files.c (attrsfile): Remove.
2009 * src/reader.c (symbol_list): Remove the guard and guard_line
2010 members.
2011 Adjust dependencies.
2012 (parse_guard): Remove.
2013 * data/bison.hairy: Remove.
2014 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2015 BISON_HAIRY.
2016
82b6cb3f
AD
20172002-05-02 Akim Demaille <akim@epita.fr>
2018
2019 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2020 (parse_guard): Rename the formal argument `stack_offset' as
2021 `rule_length', which is more readable.
2022 Adjust callers.
2023 (copy_at, copy_dollar): Instead of outputting the hard coded
2024 values of $$, $n and so forth, output invocation to b4_lhs_value,
2025 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
2026 Note: this patch partially drops `semantic-parser' support: it
2027 always does `rule_length - n', where semantic parsers ought to
2028 always use `-n'.
82b6cb3f
AD
2029 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2030 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2031
6cbfbcc5
AD
20322002-05-02 Akim Demaille <akim@epita.fr>
2033
2034 * configure.in (AC_INIT): Bump to 1.49b.
2035 (AM_INIT_AUTOMAKE): Short invocation.
2036
b8548114
AD
20372002-05-02 Akim Demaille <akim@epita.fr>
2038
2039 Version 1.49a.
2040
c20cd1fa
AD
20412002-05-01 Akim Demaille <akim@epita.fr>
2042
2043 * src/skeleton.h: Remove.
2044
8a9566d4
AD
20452002-05-01 Akim Demaille <akim@epita.fr>
2046
2047 * src/skeleton.h: Fix the #endif.
2048 Reported by Magnus Fromreide.
2049
8c6d399a
PE
20502002-04-26 Paul Eggert <eggert@twinsun.com>
2051
2052 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2053 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 2054 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 2055
2b7ed18a
RA
20562002-04-25 Robert Anisko <robert@lrde.epita.fr>
2057
2058 * src/scan-skel.l: Postprocess quadrigraphs.
2059
2060 * src/reader.c (copy_character): New function, used to output
2061 single characters while replacing `[' and `]' with quadrigraphs, to
2062 avoid troubles with M4 quotes.
2063 (copy_comment): Output characters with copy_character.
2064 (read_additionnal_code): Likewise.
2065 (copy_string2): Likewise.
2066 (copy_definition): Likewise.
2067
2068 * tests/calc.at: Exercise M4 quoting.
2069
34a89c50
AD
20702002-04-25 Akim Demaille <akim@epita.fr>
2071
2072 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2073 between `!' and the command.
2074 Reported by Paul Eggert.
2075
0dd1580a
RA
20762002-04-24 Robert Anisko <robert@lrde.epita.fr>
2077
2078 * tests/calc.at: Exercise prologue splitting.
2079
2080 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2081 `b4_post_prologue' instead of `b4_prologue'.
2082
2083 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2084 muscles.
2085 (output): Free pre_prologue_obstack and post_prologue_obstack.
2086 * src/files.h, src/files.c (attrs_obstack): Remove.
2087 (pre_prologue_obstack, post_prologue_obstack): New.
2088 * src/reader.c (copy_definition): Add a parameter to specify the
2089 obstack to fill, instead of using attrs_obstack unconditionally.
2090 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2091 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2092
83c1796f
PE
20932002-04-23 Paul Eggert <eggert@twinsun.com>
2094
2095 * data/bison.simple: Remove unnecessary commentary and white
2096 space differences from 1_29-branch.
2097 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2098
2099 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2100 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2101 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2102 constructors or destructors.
2103
2104 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2105
1207eeac
AD
21062002-04-23 Akim Demaille <akim@epita.fr>
2107
2108 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2109 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2110 location with columns.
2111 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2112 All reported by Paul Eggert.
2113
78ab8f67
AD
21142002-04-22 Akim Demaille <akim@epita.fr>
2115
2116 * src/reduce.c (dump_grammar): Move to...
2117 * src/gram.h, src/gram.c (grammar_dump): here.
2118 Be sure to separate long item numbers.
2119 Don't read the members of a rule's prec if its nil.
2120
133c20e2
AD
21212002-04-22 Akim Demaille <akim@epita.fr>
2122
2123 * src/output.c (table_size, table_grow): New.
2124 (MAXTABLE): Remove, replace uses with table_size.
2125 (pack_vector): Instead of dying when the table is too big, grow it.
2126
9515e8a7
AD
21272002-04-22 Akim Demaille <akim@epita.fr>
2128
2129 * data/bison.simple (yyr1): Its type is that of a token number.
2130 * data/bison.c++ (r1_): Likewise.
2131 * tests/regression.at (Web2c Actions): Adjust.
2132
23c5a174
AD
21332002-04-22 Akim Demaille <akim@epita.fr>
2134
2135 * src/reader.c (token_translations_init): 256 is now the default
2136 value for the error token, i.e., it will be assigned another
2137 number if the user assigned 256 to one of her tokens.
2138 (reader): Don't force 256 to error.
2139 * doc/bison.texinfo (Symbols): Adjust.
2140 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2141 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2142 etc. instead of 10, 20, 30 (which was used to `jump' over error
2143 (256) and undefined (2)).
2144
5fbb0954
AD
21452002-04-22 Akim Demaille <akim@epita.fr>
2146
2147 Propagate more token_number_t.
2148
2149 * src/gram.h (token_number_as_item_number)
2150 (item_number_as_token_number): New.
2151 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2152 Use it to create output_item_number_table and
2153 output_token_number_table.
2154 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2155 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2156 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2157 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2158
4f940944
AD
21592002-04-22 Akim Demaille <akim@epita.fr>
2160
2161 * src/output.h, src/output.c (get_lines_number): Remove.
2162
3ded9a63
AD
21632002-04-19 Akim Demaille <akim@epita.fr>
2164
2165 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2166 as Lex/Flex'.
2167 (Debugging): More details about enabling the debugging features.
2168 (Table of Symbols): Describe $$, $n, @$, and @n.
2169 Suggested by Tim Josling.
2170
e0c471a9
AD
21712002-04-19 Akim Demaille <akim@epita.fr>
2172
2173 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2174
fecc10cd
AD
21752002-04-10 Akim Demaille <akim@epita.fr>
2176
2177 * src/system.h: Rely on HAVE_LIMITS_H.
2178 Suggested by Paul Eggert.
2179
51dec47b
AD
21802002-04-09 Akim Demaille <akim@epita.fr>
2181
2182 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2183 full stderr, and strip it according to the bison options, instead
2184 of composing the error message from different bits.
2185 This makes it easier to check for several error messages.
2186 Adjust all the invocations.
2187 Add an invocation exercising the error token.
2188 Add an invocation demonstrating a stupid error message.
2189 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2190 Adjust the tests.
2191 Error message are for stderr, not stdout.
2192
007a50a4
AD
21932002-04-09 Akim Demaille <akim@epita.fr>
2194
2195 * src/gram.h, src/gram.c (error_token_number): Remove, use
2196 errtoken->number.
2197 * src/reader.c (reader): Don't specify the user token number (2)
2198 for $undefined, as it uselessly prevents using it.
2199 * src/gram.h (token_number_t): Move to...
2200 * src/symtab.h: here.
2201 (state_t.number): Is a token_number_t.
2202 * src/print.c, src/reader.c: Use undeftoken->number instead of
2203 hard coded 2.
2204 (Even though this 2 is not the same as above: the number of the
2205 undeftoken remains being 2, it is its user token number which
2206 might not be 2).
2207 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2208 `user_token_number_max'.
2209 Output `undef_token_number'.
2210 * data/bison.simple, data/bison.c++: Use them.
2211 Be sure to map invalid yylex return values to
2212 `undef_token_number'. This saves us from gratuitous SEGV.
2213
2214 * tests/conflicts.at (Solved SR Conflicts)
2215 (Unresolved SR Conflicts): Adjust.
2216 * tests/regression.at (Web2c Actions): Adjust.
2217
06446ccf
AD
22182002-04-08 Akim Demaille <akim@epita.fr>
2219
2220 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2221 Adding #line.
2222 Remove the duplicate `typedefs'.
2223 (RhsNumberType): Fix the declaration and various other typos.
2224 Use __ofile__.
2225 * data/bison.simple: Use __ofile__.
2226 * src/scan-skel.l: Handle __ofile__.
2227
62a3e4f0
AD
22282002-04-08 Akim Demaille <akim@epita.fr>
2229
2230 * src/gram.h (item_number_t): New, the type of item numbers in
2231 RITEM. Note that it must be able to code symbol numbers as
2232 positive number, and the negation of rule numbers as negative
2233 numbers.
2234 Adjust all dependencies (pretty many).
2235 * src/reduce.c (rule): Remove this `short *' pointer: use
2236 item_number_t.
2237 * src/system.h (MINSHORT, MAXSHORT): Remove.
2238 Include `limits.h'.
2239 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2240 (shortcpy): Remove.
2241 (MAXTABLE): Move to...
2242 * src/output.c (MAXTABLE): here.
2243 (prepare_rules): Use output_int_table to output rhs.
2244 * data/bison.simple, data/bison.c++: Adjust.
2245 * tests/torture.at (Big triangle): Move the limit from 254 to
2246 500.
2247 * tests/regression.at (Web2c Actions): Ajust.
2248
2249 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2250 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
2251 passes, but produces negative #line number, once fixed, GCC is
2252 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
2253 C), it passes.
2254 * src/state.h (state_h): Code input lines on ints, not shorts.
2255
bb88b0fc
AD
22562002-04-08 Akim Demaille <akim@epita.fr>
2257
2258 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
2259 and then the grammar.
2260
9a636f47
AD
22612002-04-08 Akim Demaille <akim@epita.fr>
2262
2263 * src/system.h: No longer using strndup.
2264
680e8701
AD
22652002-04-07 Akim Demaille <akim@epita.fr>
2266
2267 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
2268 * src/output.c (output_table_data): Return the longest number.
2269 (prepare_tokens): Output `token_number_max').
2270 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
2271 New.
2272 Use them to define yy_token_number_type/TokenNumberType.
2273 Use this type for yytranslate.
2274 * tests/torture.at (Big triangle): Push the limit from 124 to
2275 253.
2276 * tests/regression.at (Web2c Actions): Adjust.
2277
817e9f41
AD
22782002-04-07 Akim Demaille <akim@epita.fr>
2279
2280 * tests/torture.at (Big triangle): New.
2281 (GNU AWK Grammar, GNU Cim Grammar): Move to...
2282 * tests/existing.at: here.
2283
5123689b
AD
22842002-04-07 Akim Demaille <akim@epita.fr>
2285
2286 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
2287 nritems.
2288 Adjust dependencies.
2289
f3849179
AD
22902002-04-07 Akim Demaille <akim@epita.fr>
2291
2292 * src/reader.c: Normalize increments to prefix form.
2293
bd02036a
AD
22942002-04-07 Akim Demaille <akim@epita.fr>
2295
2296 * src/reader.c, symtab.c: Remove debugging code.
2297
db8837cb
AD
22982002-04-07 Akim Demaille <akim@epita.fr>
2299
2300 Rename all the `bucket's as `symbol_t'.
2301
2302 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
2303 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
2304 * src/symtab.c, src/symtab.h (bucket): Rename as...
2305 (symbol_t): this.
2306 (symbol_list_new, bucket_check_defined, bucket_make_alias)
2307 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
2308 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2309 (buckets_new, buckets_free, buckets_do): Rename as...
2310 (symbol_list_new, symbol_check_defined, symbol_make_alias)
2311 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2312 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
2313 (symbols_new, symbols_free, symbols_do): these.
2314
72a23c97
AD
23152002-04-07 Akim Demaille <akim@epita.fr>
2316
2317 Use lib/hash for the symbol table.
2318
2319 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
2320 EOF.
2321 * src/lex.c (lex): Set the `number' member of new terminals.
2322 * src/reader.c (bucket_check_defined, bucket_make_alias)
2323 (bucket_check_alias_consistence, bucket_translation): New.
2324 (reader, grammar_free, readgram, token_translations_init)
2325 (packsymbols): Adjust.
2326 (reader): Number the predefined tokens.
2327 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
2328 for predefined tokens.
2329 * src/symtab.h (bucket): Remove all the hash table related
2330 members.
2331 * src/symtab.c (symtab): Replace by...
2332 (bucket_table): this.
2333 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2334 (buckets_new, buckets_do): New.
2335
280a38c3
AD
23362002-04-07 Akim Demaille <akim@epita.fr>
2337
2338 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
2339 (start_symbol, max_user_token_number, semantic_parser)
2340 (error_token_number): Initialize.
2341 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
2342 Initialize.
2343 (reader): Don't.
2344 (errtoken, eoftoken, undeftoken, axiom): Extern.
2345
03b31c0c
AD
23462002-04-07 Akim Demaille <akim@epita.fr>
2347
2348 * src/gram.h (rule_s): prec and precsym are now pointers
2349 to the bucket giving the priority/associativity.
2350 Member `associativity' removed: useless.
2351 * src/reduce.c, src/conflicts.c: Adjust.
2352
8b3df748
AD
23532002-04-07 Akim Demaille <akim@epita.fr>
2354
2355 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
2356 Properly escape the symbols' TAG when outputting them.
2357
e601aa1d
AD
23582002-04-07 Akim Demaille <akim@epita.fr>
2359
2360 * src/lalr.h (LA): Is a bitsetv, not bitset*.
2361
b0299a2e
AD
23622002-04-07 Akim Demaille <akim@epita.fr>
2363
2364 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
2365 (LArule): this, which is an array to rule_t*.
2366 * src/print.c, src/conflicts.c: Adjust.
2367
d7e1f00c
AD
23682002-04-07 Akim Demaille <akim@epita.fr>
2369
2370 * src/gram.h (rule_t): Rename `number' as `user_number'.
2371 `number' is a new member.
2372 Adjust dependencies.
2373 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
2374
cc9305dd
AD
23752002-04-07 Akim Demaille <akim@epita.fr>
2376
2377 As a result of the previous patch, it is no longer needed
2378 to reorder ritem itself.
2379
2380 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
2381
b0940840
AD
23822002-04-07 Akim Demaille <akim@epita.fr>
2383
2384 Be sure never to walk through RITEMS, but use only data related to
2385 the rules themselves. RITEMS should be banished.
2386
2387 * src/output.c (output_token_translations): Rename as...
2388 (prepare_tokens): this.
2389 In addition to `translate', prepare the muscles `tname' and
2390 `toknum', which were handled by...
2391 (output_rule_data): this.
2392 Remove, and move the remainder of its outputs into...
2393 (prepare_rules): this new routines, which also merges content from
2394 (output_gram): this.
2395 (prepare_rules): Be sure never to walk through RITEMS.
2396 (output_stos): Rename as...
2397 (prepare_stos): this.
2398 (output): Always invoke prepare_states, after all, just don't use it
2399 in the output if you don't need it.
2400
643a5994
AD
24012002-04-07 Akim Demaille <akim@epita.fr>
2402
2403 * src/LR0.c (new_state): Display `nstates' as the name of the
2404 newly created state.
2405 Adjust to initialize first_state and last_state if needed.
2406 Be sure to distinguish the initial from the final state.
2407 (new_states): Create the itemset of the initial state, and use
2408 new_state.
2409 * src/closure.c (closure): Now that the initial state has its
2410 items properly set, there is no need for a special case when
2411 creating `ruleset'.
2412
2413 As a result, now the rule 0, reducing to $axiom, is visible in the
2414 outputs. Adjust the test suite.
2415
2416 * tests/conflicts.at (Solved SR Conflicts)
2417 (Unresolved SR Conflicts): Adjust.
2418 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
2419 * tests/conflicts.at (S/R in initial): New.
2420
b4c4ccc2
AD
24212002-04-07 Akim Demaille <akim@epita.fr>
2422
2423 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
2424 the RHS of the rules.
2425 * src/output.c (output_gram): Likewise.
2426
bba97eb2
AD
24272002-04-07 Akim Demaille <akim@epita.fr>
2428
2429 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
2430 bucket.
2431 Adjust all dependencies.
2432 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
2433 `number' of the buckets too.
2434 * src/gram.h: Include `symtab.h'.
2435 (associativity): Move to...
2436 * src/symtab.h: here.
2437 No longer include `gram.h'.
2438
c3b407f4
AD
24392002-04-07 Akim Demaille <akim@epita.fr>
2440
2441 * src/gram.h, src/gram.c (rules_rhs_length): New.
2442 (ritem_longest_rhs): Use it.
2443 * src/gram.h (rule_t): `number' is a new member.
2444 * src/reader.c (packgram): Set it.
2445 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
2446 the end of `rules', and count them out of `nrules'.
2447 (reduce_output, dump_grammar): Adjust.
2448 * src/print.c (print_grammar): It is no longer needed to check for
2449 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
2450 * tests/reduce.at (Reduced Automaton): New test.
2451
11652ab3
AD
24522002-04-07 Akim Demaille <akim@epita.fr>
2453
2454 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
2455 lacking `+ 1' to nrules, Bison reported as useless a token if it
2456 was used solely to set the precedence of the last rule...
2457
26b23c1a
AD
24582002-04-07 Akim Demaille <akim@epita.fr>
2459
2460 * data/bison.c++, data/bison.simple: Don't output the current file
2461 name in #line, to avoid useless diffs between two identical
2462 outputs under different names.
2463
18bcecb0
AD
24642002-04-07 Akim Demaille <akim@epita.fr>
2465
2466 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
2467 Normalize loops to using `< nrules + 1', not `<= nrules'.
2468
fa770c86
AD
24692002-04-07 Akim Demaille <akim@epita.fr>
2470
2471 * TODO: Update.
2472
d9b739c3
AD
24732002-04-07 Akim Demaille <akim@epita.fr>
2474
2475 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
2476 bucket.value as bucket.number.
2477
99013900
AD
24782002-04-07 Akim Demaille <akim@epita.fr>
2479
2480 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
2481 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2482 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
2483 RHS, instead of being an index in RITEMS.
2484
e966383b
PE
24852002-04-04 Paul Eggert <eggert@twinsun.com>
2486
2487 * doc/bison.texinfo: Update copyright date.
2488 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
2489 (Symbols): Warn about running Bison in one character set,
2490 but compiling and/or running in an incompatible one.
2491 Warn about character code 256, too.
2492
24932002-04-03 Paul Eggert <eggert@twinsun.com>
2494
2495 * src/bison.data (YYSTACK_ALLOC): Depend on whether
2496 YYERROR_VERBOSE is nonzero, not whether it is defined.
2497
2498 Merge changes from bison-1_29-branch.
c307773e 2499
8d6c48b9
PE
25002002-03-20 Paul Eggert <eggert@twinsun.com>
2501
2502 Merge fixes from Debian bison_1.34-1.diff.
2503
2504 * configure.in (AC_PREREQ): 2.53.
2505
e53c6322
AD
25062002-03-20 Akim Demaille <akim@epita.fr>
2507
2508 * src/conflicts.c (log_resolution): Argument `resolution' is const.
2509
9ffbeca7
PE
25102002-03-19 Paul Eggert <eggert@twinsun.com>
2511
21db0b2a
PE
2512 * src/bison.simple (YYCOPY): New macro.
2513 (YYSTACK_RELOCATE): Use it.
2514 Remove Type arg; no longer needed. All callers changed.
2515 (yymemcpy): Remove; no longer needed.
2516
9ffbeca7
PE
2517 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
2518 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
2519
642cb8f8
AD
25202002-03-19 Akim Demaille <akim@epita.fr>
2521
2522 Test and fix the #line outputs.
2523
2524 * tests/atlocal.at (GCC): New.
2525 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
2526 (Prologue synch line, ,%union synch line, Postprologue synch line)
2527 (Action synch line, Epilogue synch line): New tests.
2528 * src/reader.c (parse_union_decl): Define the muscle stype_line.
2529 * data/bison.simple, data/bison.c++: Use it.
2530
3c31a486
AD
25312002-03-19 Akim Demaille <akim@epita.fr>
2532
2533 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
2534 (Solved SR Conflicts, %expect not enough, %expect right)
2535 (%expect too much): Move to...
2536 * tests/conflicts.at: this new file.
2537
0d8bed56
AD
25382002-03-19 Akim Demaille <akim@epita.fr>
2539
2540 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2541 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
2542 that we can move to enums for instance.
2543 * src/output.c (token_definitions_output): Output a list of
2544 `token-name, token-number' instead of the #define.
2545 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
2546
9208d17f
AD
25472002-03-14 Akim Demaille <akim@epita.fr>
2548
2549 Use Gettext 0.11.1.
2550
af27eacb
RA
25512002-03-09 Robert Anisko <robert@lrde.epita.fr>
2552
2553 * data/bison.c++: Make the user able to add members to the generated
2554 parser by subclassing.
2555
9101a310
RA
25562002-03-05 Robert Anisko <robert@lrde.epita.fr>
2557
2558 * src/reader.c (read_additionnal_code): `c' should be an integer, not
2559 a character.
2560 Reported by Nicolas Tisserand and Nicolas Burrus.
2561
fff9bf0b
RA
25622002-03-04 Robert Anisko <robert@lrde.epita.fr>
2563
2564 * src/reader.c: Warn about lacking semi-colons, do not complain.
2565
64dba31e
RA
25662002-03-04 Robert Anisko <robert@lrde.epita.fr>
2567
2568 * data/bison.c++: Remove a debug line.
2569
374f5a14
RA
25702002-03-04 Robert Anisko <robert@lrde.epita.fr>
2571
2572 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2573 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2574 provide a default implementation.
2575
bfcf1f3a
AD
25762002-03-04 Akim Demaille <akim@epita.fr>
2577
2578 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2579 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2580 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2581 * tests/semantic.at (Parsing Guards): Similarly.
2582 * src/reader.at (readgram): Complain if the last rule is not ended
2583 with a semi-colon.
2584
65ccf9fc
AD
25852002-03-04 Akim Demaille <akim@epita.fr>
2586
2587 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2588 * src/closure.c: here.
2589 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2590 RTC.
2591 * src/warshall.h, src/warshall.c: Remove.
2592 * tests/sets.at (Broken Closure): Adjust.
2593
d0039cbc
AD
25942002-03-04 Akim Demaille <akim@epita.fr>
2595
2596 * src/output.c (output_skeleton): tempdir is const.
2597 bytes_read is unused.
2598
345cea78
AD
25992002-03-04 Akim Demaille <akim@epita.fr>
2600
2601 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2602 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2603 Update.
2604 From Michael Hayes.
2605
564801f7
AD
26062002-03-04 Akim Demaille <akim@epita.fr>
2607
2608 * src/closure.c (closure): `r' is unused.
2609
e5352bc7
AD
26102002-03-04 Akim Demaille <akim@epita.fr>
2611
2612 * tests/sets.at (Broken Closure): Add the ending `;'.
2613 * src/reader.at (readgram): Complain if a rule is not ended with a
2614 semi-colon.
2615
914feea9
AD
26162002-03-04 Akim Demaille <akim@epita.fr>
2617
2618 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2619 (count_sr_conflicts): Use bitset_count.
2620 * src/reduce.c (inaccessable_symbols): Ditto.
2621 (bits_size): Remove.
2622 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2623
f0250de6
AD
26242002-03-04 Akim Demaille <akim@epita.fr>
2625
2626 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2627 * src/reduce.c: Remove the `bitset_zero's following the
2628 `bitset_create's, as now it is performed by the latter.
2629
ef017502
AD
26302002-03-04 Akim Demaille <akim@epita.fr>
2631
2632 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2633 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2634 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2635 latest sources from Michael.
2636
76514394
AD
26372002-03-04 Akim Demaille <akim@epita.fr>
2638
2639 * src/output.c (output): Don't free the grammar.
2640 * src/reader.c (grammar_free): New.
2641 * src/main.c (main): Call it and don't free symtab here.
2642
55024580
AD
26432002-03-04 Akim Demaille <akim@epita.fr>
2644
2645 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2646 before returning.
2647 Reported by Benoit Perrot.
2648
f9abaa2c
AD
26492002-03-04 Akim Demaille <akim@epita.fr>
2650
2651 Use bitset operations when possible, not loops over bits.
2652
2653 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2654 bitset_or.
2655 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2656 * src/reduce.c (useless_nonterminals): Formatting changes.
2657 * src/warshall.c (TC): Use bitset_or.
2658
0e721e75
AD
26592002-03-04 Akim Demaille <akim@epita.fr>
2660
2661 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2662 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2663 Ditto.
2664
0fb1ffb1
AD
26652002-03-04 Akim Demaille <akim@epita.fr>
2666
2667 * src/lalr.c (F): Now a bitset*.
2668 Adjust all dependencies.
2669
b86796bf
AD
26702002-03-04 Akim Demaille <akim@epita.fr>
2671
2672 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2673 Adjust all dependencies.
2674
602bbf31
AD
26752002-03-04 Akim Demaille <akim@epita.fr>
2676
2677 * src/L0.c, src/LR0.h (nstates): Be size_t.
2678 Adjust comparisons (signed vs unsigned).
2679 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2680 bitset*.
2681 Adjust all dependencies.
2682
d8a0245c
AD
26832002-03-04 Akim Demaille <akim@epita.fr>
2684
2685 * src/closure.c (firsts): Now, also a bitset.
2686 Adjust all dependencies.
2687 (varsetsize): Remove, now unused.
2688 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2689
34ba9743
AD
26902002-03-04 Akim Demaille <akim@epita.fr>
2691
2692 * src/print.c: Convert to use bitset.h, not hand coded iterations
2693 over ints.
2694
ed86e78c
AD
26952002-03-04 Akim Demaille <akim@epita.fr>
2696
2697 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2698
dfdb1797
AD
26992002-03-04 Akim Demaille <akim@epita.fr>
2700
2701 * src/closure.c (ruleset): Be a bitset.
2702 (rulesetsize): Remove.
2703
7086e707
AD
27042002-03-04 Akim Demaille <akim@epita.fr>
2705
2706 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2707 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2708 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2709 * src/closure.c (fderives): Be an array of bitsets.
2710
98254360
RA
27112002-02-28 Robert Anisko <robert@lrde.epita.fr>
2712
2713 * data/bison.c++: Merge the two generated headers. Insert a copyright
2714 notice in each output file.
2715
a75c057f
AD
27162002-02-28 Akim Demaille <akim@epita.fr>
2717
2718 * data/bison.c++: Copy the prologue of bison.simple to fetch
2719 useful M4 definitions, such as b4_header_guard.
2720
06b00abc
AD
27212002-02-25 Akim Demaille <akim@epita.fr>
2722
2723 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
2724 translator friendly scheme for the bgr
2725 copyright notice.
06b00abc 2726
70e7d534
AD
27272002-02-25 Akim Demaille <akim@epita.fr>
2728
2729 * src/output.c (header_output): Remove, now handled completely via
2730 M4.
2731
abe017f6
AD
27322002-02-25 Akim Demaille <akim@epita.fr>
2733
2734 * m4/m4.m4: New, from CVS Autoconf.
2735 * configure.in: Invoke it.
2736 * src/output.c (output_skeleton): Use its result instead of the
2737 hard coded name.
2738
381fb12e
AD
27392002-02-25 Akim Demaille <akim@epita.fr>
2740
2741 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2742 Fileutils 4.1.5.
2743 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2744 * src/output.c (output_skeleton): Use mkstemp to create a real
2745 temporary file.
2746 Move the filling of `skeleton' and its muscle to...
2747 (prepare): here.
2748 (output): Move the definition of the prologue muscle to...
2749 (prepare): here.
2750 * src/system.h (DEFAULT_TMPDIR): New.
2751
6f38107f
PE
27522002-02-14 Paul Eggert <eggert@twinsun.com>
2753
2754 Remove the support for C++ namespace cleanliness; it was
2755 causing more problems than it was curing, since it didn't work
2756 properly on some nonstandard C++ compilers. This can wait
2757 for a proper C++ parser.
2758
2759 * NEWS: Document this.
2760 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2761 of C++, as it's treated like C now.
2762 * src/bison.simple (YYSTD): Remove.
2763 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2764 Treat C++ just like Standard C instead of trying to support
2765 namespace cleanliness.
2766
80cce3da
AD
27672002-02-14 Akim Demaille <akim@epita.fr>
2768
2769 * tests/regression.at (else): Adjust to Andreas' change.
2770
842e8679
AD
27712002-02-14 Akim Demaille <akim@epita.fr>
2772
2773 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2774
4bda3f10
AD
27752002-02-13 Andreas Schwab <schwab@suse.de>
2776
2777 * src/output.c (output_rule_data): Don't output NULL, it might
2778 not be defined yet.
2779
4162fa07 27802002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 2781
4162fa07
RA
2782 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2783 (Copyright notice): Update.
b418ecd8 2784
bd16a5dc
AD
27852002-02-11 Akim Demaille <akim@epita.fr>
2786
2787 * tests/regression.at (%nonassoc and eof): Don't include
2788 nonportable headers.
2789
8d69a1a3
RA
27902002-02-08 Robert Anisko <robert@lrde.epita.fr>
2791
2792 * data/bison.c++: Correct error recovery. Make the user able to
2793 initialize the starting location.
2794
9b2d0677
AD
27952002-02-07 Akim Demaille <akim@epita.fr>
2796
2797 * tests/input.at: New.
2798
69e2658b
RA
27992002-02-07 Robert Anisko <robert@lrde.epita.fr>
2800
2801 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 2802 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
2803 directives around tables only needed for debugging.
2804
4aacc3a7
RA
28052002-02-07 Robert Anisko <robert@lrde.epita.fr>
2806
2807 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2808 C++ parsers.
2809 (yy::b4_name::parse): Use print_.
2810
762a801e
RA
28112002-02-07 Robert Anisko <robert@lrde.epita.fr>
2812
2813 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2814
4bb2bc3f
RA
28152002-02-07 Robert Anisko <robert@lrde.epita.fr>
2816
2817 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2818 C++ parsers.
2819 (yy::b4_name::parse): Build verbose error messages, and use error_.
2820
6b45a3ca
RA
28212002-02-06 Robert Anisko <robert@lrde.epita.fr>
2822
2823 * data/bison.c++: Fix m4 quoting in comments.
2824
50997c6e
RA
28252002-02-06 Robert Anisko <robert@lrde.epita.fr>
2826
2827 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2828 not expanded by m4.
2829
3f3eed27
AD
28302002-02-05 Akim Demaille <akim@epita.fr>
2831
2832 * data/bison.c++: Adjust to the M4 back end.
2833 More is certainly needed.
2834
be2a1a68
AD
28352002-02-05 Akim Demaille <akim@epita.fr>
2836
2837 Give a try to M4 as a back end.
2838
2839 * lib/readpipe.c: New, from wdiff.
2840 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2841 BISON_HAIRY.
2842 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2843 specific values. Now it is m4 that performs the lookup.
2844 * src/parse-skel.y: Remove.
2845 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2846 * src/output.c (actions_output, guards_output)
2847 (token_definitions_output): No longer keeps track of the output
2848 line number, hence remove the second argument.
2849 (guards_output): Check against the guard member of a rule, not the
2850 action member.
2851 Adjust callers.
2852 (output_skeleton): Don't look for the skeleton location, let m4 do
2853 that.
2854 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2855 file will be used.
2856 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2857 (prepare): Given that for the time being changesyntax is not
2858 usable in M4, rename the muscles using `-' to `_'.
2859 Define `defines_flag', `output_parser_name' and `output_header_name'.
2860 * src/output.h (actions_output, guards_output)
2861 (token_definitions_output): Adjust prototypes.
2862 * src/scan-skel.l: Instead of scanning the skeletons, it now
2863 processes the output of m4: `__oline__' and `#output'.
2864 * data/bison.simple: Adjust to be used by M4(sugar).
2865 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2866 to date.
2867 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2868 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2869 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2870 shamelessly stolen from CVS Autoconf.
2871
beda758b
AD
28722002-02-05 Akim Demaille <akim@epita.fr>
2873
2874 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2875 * configure.in: Check for the declarations of free and malloc.
2876 * src/muscle_tab.c: Adjust.
2877
5ece6d43
AD
28782002-02-05 Akim Demaille <akim@epita.fr>
2879
2880 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
2881 which have no values.
2882
5bb18f9a
AD
28832002-02-05 Akim Demaille <akim@epita.fr>
2884
2885 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
2886 * data/: here.
2887
894dd62e
PE
28882002-01-29 Paul Eggert <eggert@twinsun.com>
2889
2890 * src/bison.simple (YYSIZE_T): Do not define merely because
2891 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
2892 On some platforms, <alloca.h> does not declare YYSTD (size_t).
2893
82841af7
AD
28942002-01-27 Akim Demaille <akim@epita.fr>
2895
2896 Fix `%nonassoc and eof'.
2897
2898 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
2899 which were not properly copied! Replace
2900 memcpy (res->errs, src->errs, src->nerrs);
2901 with
2902 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
2903 !!!
2904 * tests/regression.at (%nonassoc and eof): Adjust to newest
2905 Autotest: `.' is not in the PATH.
2906
318b76e9
AD
29072002-01-27 Akim Demaille <akim@epita.fr>
2908
2909 * tests/sets.at (AT_EXTRACT_SETS): New.
2910 (Nullable): Use it.
2911 (Firsts): New.
2912
30d2f3d5
AD
29132002-01-26 Akim Demaille <akim@epita.fr>
2914
2915 * tests/actions.at, tests/calc.at, tests/headers.at,
2916 * tests/torture.at: Adjust to the newest Autotest which no longer
2917 forces `.' in the PATH.
2918
30f8c395
AD
29192002-01-25 Akim Demaille <akim@epita.fr>
2920
2921 * tests/regression.at (%nonassoc and eof): New.
2922 Suggested by Robert Anisko.
2923
29ae55f1
AD
29242002-01-24 Akim Demaille <akim@epita.fr>
2925
2926 Bison dumps core when trying to complain about broken input files.
2927 Reported by Cris van Pelt.
2928
2929 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
2930 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
2931 into...
2932 (Invalid inputs): Strengthen: exercise parse_percent_token.
2933
2b548aa6
RA
29342002-01-24 Robert Anisko <robert.anisko@epita.fr>
2935
2936 * src/Makefile.am: Add bison.c++.
2937 * src/bison.c++: New skeleton.
2938
bb0146c2
AD
29392002-01-21 Paolo Bonzini <bonzini@gnu.org>
2940
2941 * po/it.po: New.
2942
bec30531
AD
29432002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
2944
2945 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
2946
fc6edc45
MA
29472002-01-20 Marc Autret <marc@gnu.org>
2948
2949 * src/files.c (compute_output_file_names): Fix
2950
5e5d5415
MA
29512002-01-20 Marc Autret <marc@gnu.org>
2952
2953 * tests/output.at: New test.
2954 * src/files.c (compute_base_names): Don't map extensions when
2955 the YACC flag is set, use defaults.
2956 Reported by Evgeny Stambulchik.
2957
44ea3fbd
MA
29582002-01-20 Marc Autret <marc@gnu.org>
2959
bb0146c2 2960 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
2961 compilers as well (i.e. the vendor C compiler).
2962 Suggested by Albert Chin-A-Young.
2963
338963d1
TVH
29642002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
2965
2966 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
2967 canonical definition.
2968 * src/system.h: Use the canonical definition for PARAMS (avoids
2969 a conflict with the macro from lib/hash.h).
2970
c57b2479
AD
29712002-01-11 Akim Demaille <akim@epita.fr>
2972
2973 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 2974 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 2975
b85810ae
AD
29762002-01-09 Akim Demaille <akim@epita.fr>
2977
2978 * src/files.c, src/files.h (output_infix): New.
2979 (tab_extension): Remove.
2980 (compute_base_names): Compute the former, drop the latter.
2981 * src/output.c (prepare): Insert the muscles `output-infix', and
2982 `output-suffix'.
2983 * src/parse-skel.y (string, string.1): New.
2984 (section.header): Use it.
2985 (section.yacc): Remove.
2986 (prefix): Remove too.
2987 * src/scan-skel.l: Adjust.
2988 * src/bison.simple, src/bison.hairy: Adjust.
2989
cae60122
AD
29902002-01-09 Akim Demaille <akim@epita.fr>
2991
2992 * configure.in (WERROR_CFLAGS): Compute it.
2993 * src/Makefile.am (CFLAGS): Pass it.
2994 * tests/atlocal.in (CFLAGS): Idem.
2995 * src/files.c: Fix a few warnings.
2996 (get_extension_index): Remove, unused.
2997
ae404801
AD
29982002-01-08 Akim Demaille <akim@epita.fr>
2999
3000 * src/getargs.c (AS_FILE_NAME): New.
3001 (getargs): Use it to convert DOSish file names.
3002 * src/files.c (base_name): Rename as full_base_name to avoid
3003 clashes with `base_name ()'.
3004 (filename_split): New.
3005 (compute_base_names): N-th rewrite, using filename_split.
3006
22312b71
AD
30072002-01-08 Akim Demaille <akim@epita.fr>
3008
3009 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3010 New, stolen from the Fileutils 4.1.
3011 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3012 * configure.in: Check for the presence of memrchr, and of its
3013 prototype.
3014
a67cef01
TVH
30152002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3016
3017 * lib/hash.h (__P): Added definition for this macro.
3018 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3019 BUILT_SOURCES, to ensure they are generated first.
3020 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3021 %error-verbose to allow bootstrapping with bison 1.30x.
3022
2b25d624
AD
30232002-01-06 Akim Demaille <akim@epita.fr>
3024
3025 * src/reader.c (parse_braces): Don't fetch the next char, the
3026 convention is to fetch on entry.
3027 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3028 'switch' without a following semicolon.
3029 * tests/regression.at (braces parsing): New.
3030
3460813b
AD
30312002-01-06 Akim Demaille <akim@epita.fr>
3032
3033 Bison is dead wrong in its RR conflict reports.
3034
3035 * tests/torture.at (GNU Cim Grammar): New.
3036 * src/conflicts.c (count_rr_conflicts): Fix.
3037
73784c64
AD
30382002-01-06 Akim Demaille <akim@epita.fr>
3039
3040 Creating package.m4 from configure.ac causes too many problems.
3041
3042 * tests/Makefile.am (package.m4): Create it by hand,
3043 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3044
25d81090
AD
30452002-01-06 Akim Demaille <akim@epita.fr>
3046
3047 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3048 skeleton.h.
3049
a9b8959e
PE
30502002-01-04 Paul Eggert <eggert@twinsun.com>
3051
3052 * doc/bison.texinfo (Debugging):
3053 Remove YYSTDERR; it's no longer defined or used.
3054 Also, s/cstdio.h/cstdio/.
3055
25d81090
AD
30562002-01-03 Akim Demaille <akim@epita.fr>
3057
3058 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3059
1109455c
AD
30602002-01-03 Akim Demaille <akim@epita.fr>
3061
3062 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3063 tracing code to --trace, wait for a better --trace option, with
3064 args.
3065
7ea5e977
AD
30662002-01-03 Akim Demaille <akim@epita.fr>
3067
3068 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3069 The ISO C++ standard is extremely clear about it: stderr is
3070 considered a macro, not a regular symbol (see table 94 `Header
3071 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3072 Therefore std:: does not apply to it. It still does with fprintf.
3073 Also, s/cstdio.h/cstdio/.
3074
fab5b110
AD
30752002-01-03 Akim Demaille <akim@epita.fr>
3076
3077 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3078 for non system headers.
3079
aed7fd9b
AD
30802002-01-02 Akim Demaille <akim@epita.fr>
3081
3082 Equip the skeleton chain with location tracking, runtime trace,
3083 pure parser and scanner.
3084
3085 * src/parse-skel.y: Request a pure parser, locations, and prefix
3086 renaming.
3087 (%union): Having several members with the same type does not help
3088 type mismatches, simplify.
3089 (YYPRINT, yyprint): New.
3090 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3091 (skel_error): this.
3092 Handle locations.
3093 * src/scan-skel.l: Adjust to these changes.
3094 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3095 (LOCATION_PRINT, skel_control_t): New.
3096
24fad99e
AD
30972001-12-30 Akim Demaille <akim@epita.fr>
3098
3099 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3100 replace `gb' with BLANKS.
3101 * src/scan-skel.l: Adjust.
3102
a4b36db4
AD
31032001-12-30 Akim Demaille <akim@epita.fr>
3104
3105 * src/system.h: We don't need nor want bcopy.
3106 Throw away MS-DOS crap: we don't need getpid.
3107 * configure.in: We don't need strndup. It was even causing
3108 problems: because Flex includes the headers *before* us,
3109 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3110 not visible.
3111 * lib/xstrndup.c: New.
3112 * src/scan-skel.l: Use it.
3113 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3114 * src/parse-skel.y: Use %directives instead of #defines.
3115
1239777d
AD
31162001-12-30 Akim Demaille <akim@epita.fr>
3117
3118 * src/skeleton.h: New.
3119 * src/output.c (output_parser, output_master_parser): Remove, dead
3120 code.
3121 * src/output.h (get_lines_number, actions_output, guards_output)
3122 (token_definitions_output): Prototype them.
3123 * src/parse-skel.y: Add the license notice.
3124 Include output.h and skeleton.h.
3125 (process_skeleton): Returns void, and takes a single parameter.
3126 * src/scan-skel.l: Add the license notice.
3127 Include skeleton.h.
3128 Don't use %option yylineno: it seems that then Flex imagines
3129 REJECT has been used, and therefore it won't reallocate its
3130 buffers (which makes no other sense to me than a bug). It results
3131 in warnings for `unused: yy_flex_realloc'.
3132
9b3add5b
RA
31332001-12-30 Robert Anisko <robert.anisko@epita.fr>
3134
3135 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3136 (MUSCLE_INSERT_PREFIX): ...to there.
3137 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3138 (MUSCLE_INSERT_PREFIX): Move from here...
3139
3140 * src/bison.hairy: Add a section directive. Put braces around muscle
3141 names. This parser skeleton is still broken, but Bison should not
3142 choke on a bad muscle 'syntax'.
3143 * src/bison.simple: Add a section directive. Put braces around muscle
3144 names.
3145
3146 * src/files.h (strsuffix, stringappend): Add declarations.
3147 (tab_extension): Add declaration.
3148 (short_base_name): Add declaration.
3149
3150 * src/files.c (strsuffix, stringappend): No longer static. These
3151 functions are used in the skeleton parser.
3152 (tab_extension): New.
3153 (compute_base_names): Use the computations done in this function
fab5b110 3154 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
3155 names.
3156 (short_base_name): No longer static.
3157
3158 * src/output.c (output_skeleton): New.
3159 (output): Disable call to output_master_parser, and give a try to
3160 a new skeleton handling system.
3161 (guards_output, actions_output): No longer static.
3162 (token_definitions_output, get_lines_number): No longer static.
3163
3164 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3165
fab5b110 3166 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
3167 parse-skel.y.
3168
3169 * src/parse-skel.y: New file.
3170 * src/scan-skel.l: New file.
3171
b5b61c61
AD
31722001-12-29 Akim Demaille <akim@epita.fr>
3173
3174 %name-prefix is broken.
3175
3176 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3177 Adjust all dependencies.
3178 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3179 %name-prefix.
3180
3181 Renaming yylval but not yylloc is not consistent. Now we do.
3182
3183 * src/bison.simple: Prefix yylloc if used.
3184 * doc/bison.texinfo (Decl Summary): Document that.
3185
8c9a50be
AD
31862001-12-29 Akim Demaille <akim@epita.fr>
3187
3188 * doc/bison.texinfo: Promote `%long-directive' over
3189 `%long_directive'.
3190 Remove all references to fixed-output-files, yacc is enough.
3191
d99361e6
AD
31922001-12-29 Akim Demaille <akim@epita.fr>
3193
3194 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3195 user prologue. These are defaults.
3196 * tests/actions.at (Mid-rule actions): Make sure the user can
3197 define YYDEBUG and YYERROR_VERBOSE.
3198
b9cecb91
AD
31992001-12-29 Akim Demaille <akim@epita.fr>
3200
3201 * src/output.c (header_output): Don't forget to export YYLTYPE and
3202 yylloc.
3203 * tests/headers.at (export YYLTYPE): New, make sure it does.
3204 * tests/regression.at (%union and --defines, Invalid CPP headers):
3205 Move to...
3206 * tests/headers.at: here.
3207
aea13e97
AD
32082001-12-29 Akim Demaille <akim@epita.fr>
3209
3210 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3211
931394cb
AD
32122001-12-29 Akim Demaille <akim@epita.fr>
3213
3214 * tests/actions.at (Mid-rule actions): Output on a single line
3215 instead of several.
3216
704a47c4
AD
32172001-12-29 Akim Demaille <akim@epita.fr>
3218
3219 * doc/bison.texinfo: Formatting changes.
3220
091e20bb
AD
32212001-12-29 Akim Demaille <akim@epita.fr>
3222
3223 Don't store the token defs in a muscle, just be ready to output it
3224 on command. Now possible via `symbols'. Fixes a memory leak.
3225
3226 * src/output.c (token_definitions_output): New.
3227 (output_parser, header_output): Use it.
3228 * src/reader.c (symbols_save): Remove.
3229
cce71710
AD
32302001-12-29 Akim Demaille <akim@epita.fr>
3231
3232 * src/bison.simple: Do not provide a default for YYSTYPE and
3233 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3234 default.
3235
82c035a8
AD
32362001-12-29 Akim Demaille <akim@epita.fr>
3237
3238 Mid-rule actions are simply... ignored!
3239
3240 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3241 the empty-rule associated to the dummy symbol, not to the host
3242 rule.
3243 * tests/actions.at (Mid-rule actions): New.
3244
8419d367
AD
32452001-12-29 Akim Demaille <akim@epita.fr>
3246
3247 Memory leak.
3248
3249 * src/reader.c (reader): Free grammar.
3250
375d5806
AD
32512001-12-29 Akim Demaille <akim@epita.fr>
3252
3253 Memory leak.
3254
3255 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
3256 since it allocates it for each state, although only one is needed.
3257 (allocate_storage): Do it here.
3258
f51cb8ff
AD
32592001-12-29 Akim Demaille <akim@epita.fr>
3260
3261 * src/options.h, src/options.c (create_long_option_table): Rename
3262 as...
3263 (long_option_table_new): this, with a clearer prototype.
3264 (percent_table): Remove, unused,
3265 * src/getargs.c (getargs): Adjust.
3266
29e88316
AD
32672001-12-29 Akim Demaille <akim@epita.fr>
3268
3269 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
3270 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
3271 as states.
3272
b9f71f19
AD
32732001-12-29 Akim Demaille <akim@epita.fr>
3274
3275 * src/lalr.c (build_relations): Rename `states' as `states1'.
3276 Sorry, I don't understand exactly what it is, no better name...
3277
1a2b5d37
AD
32782001-12-29 Akim Demaille <akim@epita.fr>
3279
3280 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
3281 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
3282 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
3283 as rules.
3284
1cca533e
AD
32852001-12-29 Akim Demaille <akim@epita.fr>
3286
3287 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
3288 ago.
3289
c03ae966
AD
32902001-12-29 Akim Demaille <akim@epita.fr>
3291
3292 * src/reader.c, src/reader.h (user_toknums): Remove.
3293 Adjust all users to use symbols[i]->user_token_number.
3294
5a670b1e
AD
32952001-12-29 Akim Demaille <akim@epita.fr>
3296
3297 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
3298 Adjust all users to use symbols[i]->prec or ->assoc.
3299
ad949da9
AD
33002001-12-29 Akim Demaille <akim@epita.fr>
3301
3302 * src/reader.c, src/reader.h (tags): Remove.
3303 Adjust all users to use symbols[i]->tag.
3304
0e78e603
AD
33052001-12-29 Akim Demaille <akim@epita.fr>
3306
3307 * src/gram.h, src/gram.c (symbols): New, similar to state_table
3308 and rule_table.
3309 * src/reader.c (packsymbols): Fill this table.
3310 Drop sprec.
3311 * src/conflicts.c (resolve_sr_conflict): Adjust.
3312 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
3313 single table.
3314 Use symbols[i]->tag instead of tags[i].
3315
213e640e
AD
33162001-12-29 Akim Demaille <akim@epita.fr>
3317
3318 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
3319 In addition, put a comment in there, to replace...
3320 * tests/regression.at (%union and C comments): Remove.
3321
e7b8bef1
AD
33222001-12-29 Akim Demaille <akim@epita.fr>
3323
3324 * tests/regression.at (Web2c Actions): Blindly move the actual
3325 output as expected output. The contents *seem* right to me, but I
3326 can't pretend reading perfectly parser tables... Nonetheless, all
3327 the other tests pass correctly, the table look OK, even though the
3328 presence of `$axiom' is to be noted: AFAICS it is useless (but
3329 harmless).
3330
b68e7744
AD
33312001-12-29 Akim Demaille <akim@epita.fr>
3332
3333 * src/reader.c (readgram): Don't add the rule 0 if there were no
3334 rules read. In other words, add it _after_ having performed
3335 grammar sanity checks.
3336 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
3337
78d5bae9
AD
33382001-12-29 Akim Demaille <akim@epita.fr>
3339
3340 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
3341 visible, and some states have now a different number.
3342
ff442794
AD
33432001-12-29 Akim Demaille <akim@epita.fr>
3344
3345 * src/reader.c (readgram): Bind the initial rule's lineno to that
3346 of the first rule.
3347 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
3348 (Solved SR Conflicts): Adjust rule 0's line number.
3349
610ab194
AD
33502001-12-29 Akim Demaille <akim@epita.fr>
3351
3352 Fix the `GAWK Grammar' failure.
3353
3354 * src/LR0.c (final_state): Initialize to -1 so that we do compute
3355 the reductions of the first state which was mistakenly confused
3356 with the final state because precisely final_state was initialized
3357 to 0.
3358 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
3359 now noticed by Bison.
3360 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
3361 have a reduction on $default.
3362
29d29c8f
AD
33632001-12-29 Akim Demaille <akim@epita.fr>
3364
3365 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
3366 rule line numbers.
3367 * src/closure.c (print_closure): Likewise.
3368 * src/derives.c (print_derives): Likewise.
3369 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
3370 now.
3371
7c6b64d0
AD
33722001-12-29 Akim Demaille <akim@epita.fr>
3373
3374 * src/lalr.c (lookaheads_print): New.
3375 (lalr): Call it when --trace-flag.
3376 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
3377 are dumped.
3378
3d4daee3
AD
33792001-12-29 Akim Demaille <akim@epita.fr>
3380
3381 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
3382 when walking through ritem, even via rule->rhs.
3383 * src/reduce.c (dump_grammar, useful_production, reduce_output)
3384 (useful_production, useless_nonterminals): Likewise.
3385 (reduce_grammar_tables): Likewise, plus update nritems.
3386 * src/nullable.c (set_nullable): Likewise.
3387 * src/lalr.c (build_relations): Likewise.
3388 * tests/sets.at (Nullable): Adjust.
3389 Fortunately, now, the $axiom is no longer nullable.
3390
9e7f6bbd
AD
33912001-12-29 Akim Demaille <akim@epita.fr>
3392
3393 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
3394 the 0-sentinel.
3395 * src/gram.c (ritem_longest_rhs): Likewise.
3396 * src/reduce.c (nonterminals_reduce): Likewise.
3397 * src/print_graph.c (print_graph): Likewise.
3398 * src/output.c (output_rule_data): Likewise.
3399 * src/nullable.c (set_nullable): Likewise.
3400
255ef638
AD
34012001-12-29 Akim Demaille <akim@epita.fr>
3402
3403 * src/output.c: Comment changes.
3404
0d8a7363
AD
34052001-12-27 Paul Eggert <eggert@twinsun.com>
3406
3407 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
3408 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
3409 Sparc, as they were causing more porting problems than the
3410 (minor) performance improvement was worth.
3411
3412 Also, catch up with 1.31's YYSTD.
3413
3db472b9
AD
34142001-12-27 Akim Demaille <akim@epita.fr>
3415
3416 * src/output.c (output_gram): Rely on nritems, not the
3417 0-sentinel. See below.
3418 Use -1 as separator, not 0.
3419 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
3420 Rely on -1 as separator in yyrhs, instead of 0.
3421 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
3422 twice `Now at end of input', therefore there are two lines less to
3423 expect.
3424
b365aa05
AD
34252001-12-27 Akim Demaille <akim@epita.fr>
3426
3427 * tests/regression.at (Unresolved SR Conflicts):
3428 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
3429 below.
3430
30171f79
AD
34312001-12-27 Akim Demaille <akim@epita.fr>
3432
3433 * src/LR0.c (new_state): Recognize the final state by the fact it
3434 is reached by eoftoken.
3435 (insert_start_shifting_state, insert_eof_shifting_state)
3436 (insert_accepting_state, augment_automaton): Remove, since now
3437 these states are automatically computed from the initial state.
3438 (generate_states): Adjust.
3439 * src/print.c: When reporting a rule number to the user, substract
3440 1, so that the axiom rule is rule 0, and the first user rule is 1.
3441 * src/reduce.c: Likewise.
3442 * src/print_graph.c (print_core): For the time being, just as for
3443 the report, depend upon --trace-flags to dump the full set of
3444 items.
3445 * src/reader.c (readgram): Once the grammar read, insert the rule
3446 0: `$axiom: START-SYMBOL $'.
3447 * tests/set.at: Adjust: rule 0 is now displayed, and since the
3448 number of the states has changed (the final state is no longer
3449 necessarily the last), catch up.
3450
75142d45
AD
34512001-12-27 Akim Demaille <akim@epita.fr>
3452
3453 Try to make the use of the eoftoken valid. Given that its value
3454 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
3455 is used instead of > 0 where appropriate, (ii), depend upon nritems
3456 instead of the 0-sentinel.
3457
3458 * src/gram.h, src/gram.c (nritems): New.
3459 Expected to be duplication of nitems, but for the time being...
3460 * src/reader.c (packgram): Assert nritems and nitems are equal.
3461 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
3462 * src/closure.c (print_closure, print_fderives): Likewise.
3463 * src/gram.c (ritem_print): Likewise.
3464 * src/print.c (print_core, print_grammar): Likewise.
3465 * src/print_graph.c: Likewise.
3466
b7c49edf
AD
34672001-12-27 Akim Demaille <akim@epita.fr>
3468
3469 * src/main.c (main): If there are complains after grammar
3470 reductions, then output the report anyway if requested, then die.
3471 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
3472 * src/reader.c (eoftoken): New.
3473 (parse_token_decl): If the token being defined has value `0', it
3474 is the eoftoken.
3475 (packsymbols): No longer hack `tags' to insert `$' by hand.
3476 Be sure to preserve the value of the eoftoken.
3477 (reader): Make sure eoftoken is defined.
3478 Initialize nsyms to 0: now eoftoken is created just like the others.
3479 * src/print.c (print_grammar): Don't special case the eof token.
3480 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
3481 lie anyway, albeit pleasant.
3482 * tests/calc.at: Exercise error messages with eoftoken.
3483 Change the grammar so that empty input is invalid.
3484 Adjust expectations.
3485 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
3486
ec2da99f
AD
34872001-12-27 Akim Demaille <akim@epita.fr>
3488
3489 * configure.in: Check the protos of strchr ans strspn.
3490 Replace strchr if needed.
3491 * src/system.h: Provide the protos of strchr, strspn and memchr if
3492 missing.
3493 * lib/strchr.c: New.
3494 * src/reader.c (symbols_save): Use strchr.
3495
8adfa272
AD
34962001-12-27 Akim Demaille <akim@epita.fr>
3497
3498 * src/print.c, src/print_graph.c (escape): New.
3499 Use it to quote the TAGS outputs.
3500 * src/print_graph.c (print_state): Now errors are in red, and
3501 reductions in green.
3502 Prefer high to wide: output the state number on a line of its own.
3503
80dac38c
AD
35042001-12-27 Akim Demaille <akim@epita.fr>
3505
3506 * src/state.h, src/state.c (reductions_new): New.
3507 * src/LR0.c (set_state_table): Let all the states have a
3508 `reductions', even if reduced to 0.
3509 (save_reductions): Adjust.
3510 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
3511 * src/print.c (print_reductions, print_actions): Adjust.
3512 * src/output.c (action_row): Adjust.
3513
2cec70b9
AD
35142001-12-27 Akim Demaille <akim@epita.fr>
3515
3516 * src/state.h, src/state.c (errs_new, errs_dup): New.
3517 * src/LR0.c (set_state_table): Let all the states have an errs,
3518 even if reduced to 0.
3519 * src/print.c (print_errs, print_reductions): Adjust.
3520 * src/output.c (output_actions, action_row): Adjust.
3521 * src/conflicts.c (resolve_sr_conflict): Adjust.
3522
13ca549a
AD
35232001-12-27 Akim Demaille <akim@epita.fr>
3524
3525 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
3526
5092aba5
AD
35272001-12-27 Akim Demaille <akim@epita.fr>
3528
3529 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
3530 * src/print.c: here.
3531 (lookaheadset, shiftset): New, used as additional storage by
3532 print_reductions.
3533 (print_results): Adjust.
3534 (print_shifts, print_gotos, print_errs): New, extracted from...
3535 (print_actions): here.
3536 * src/print_graph.c (print_actions): Remove dead code.
3537
11e2beca
AD
35382001-12-27 Akim Demaille <akim@epita.fr>
3539
3540 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
3541 `$n' and `@n'.
3542
dac3c910
AD
35432001-12-27 Akim Demaille <akim@epita.fr>
3544
3545 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
3546 (build_relations): Adjust.
3547
d0b0fefa
AD
35482001-12-27 Akim Demaille <akim@epita.fr>
3549
3550 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
3551 duplication.
3552
adc8c848
AD
35532001-12-27 Akim Demaille <akim@epita.fr>
3554
3555 * src/reader.c (packgram): Catch nitems overflows.
3556
14d293ac
AD
35572001-12-27 Akim Demaille <akim@epita.fr>
3558
3559 * src/files.c, src/files.h (guard_obstack): Remove.
3560 * src/output.c (output): Adjust.
3561 * src/reader.c (parse_braces): New, factoring...
3562 (copy_action, copy_guard): these two which are renamed as...
3563 (parse_action, parse_guard): these.
3564 As a voluntary consequence, using braces around guards is now
3565 mandatory.
3566
f499b062
AD
35672001-12-27 Akim Demaille <akim@epita.fr>
3568
3569 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3570 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3571 members.
3572 (symbol_list_new): Adjust.
3573 (copy_action): action_line is the first line, not the last.
3574 (copy_guard): Just as for actions, store the `action' only, not
3575 the switch/case/break flesh.
3576 Don't parse the user action that might follow the guard, let...
3577 (readgram): do it, i.e., now, there can be an action after a
3578 guard.
3579 In other words the guard is just explicitly optional.
3580 (packgram): Adjust.
3581 * src/output.c (guards_output): New.
3582 (output_parser): Call it when needed.
3583 (output): Also free the guard and attrs obstacks.
3584 * src/files.c, src/files.h (obstack_save): Remove.
3585 (output_files): Remove.
3586 As a result, if one needs the former `.act' file, using an
3587 appropriate skeleton which requires actions and guards is now
3588 required.
3589 * src/main.c (main): Adjust.
3590 * tests/semantic.at: New.
3591 * tests/regression.at: Use `input.y' as input file name.
3592 Avoid 8+3 problems by requiring input.c when the test needs the
3593 parser.
3594
d945f5cd
AD
35952001-12-27 Akim Demaille <akim@epita.fr>
3596
3597 * src/reader.c (symbol_list_new): Be sure to initialize all the
3598 fields.
3599
d200e455
AD
36002001-12-27 Akim Demaille <akim@epita.fr>
3601
3602 All the hacks using a final pseudo state are now useless.
3603
3604 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3605 * src/lalr.c (nLA): New.
3606 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3607 instead of lookaheadsp from the pseudo state (nstate + 1).
3608
f9507c28
AD
36092001-12-27 Akim Demaille <akim@epita.fr>
3610
3611 * src/output.c (action_row, token_actions): Use a state_t instead
3612 of a integer, and nlookaheads instead of the following state's
3613 lookaheadsp.
3614
065fbd27
AD
36152001-12-27 Akim Demaille <akim@epita.fr>
3616
3617 * src/conflicts.c (log_resolution, flush_shift)
3618 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3619 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3620 (conflicts_print, print_reductions): Use a state_t instead of an
3621 integer when referring to a state.
3622 As much as possible, depend upon nlookaheads, instead of the
3623 `lookaheadsp' member of the following state (since lookaheads of
3624 successive states are successive, the difference between state n + 1
3625 and n served as the number of lookaheads for state n).
3626 * src/lalr.c (add_lookback_edge): Likewise.
3627 * src/print.c (print_core, print_actions, print_state)
3628 (print_results): Likewise.
3629 * src/print_graph.c (print_core, print_actions, print_state)
3630 (print_graph): Likewise.
3631 * src/conflicts.h: Adjust.
3632
1b177bd7
AD
36332001-12-27 Akim Demaille <akim@epita.fr>
3634
3635 * src/bison.hairy: Formatting/comment changes.
3636 ANSIfy.
3637 Remove `register' indications.
3638 Add plenty of `static'.
3639
7742ddeb
AD
36402001-12-27 Akim Demaille <akim@epita.fr>
3641
3642 * src/output.c (prepare): Drop the muscle `ntbase' which
3643 duplicates ntokens.
3644 * src/bison.simple: Formatting/comment changes.
3645 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3646 is an undocumented synonym.
3647
1fa14068
AD
36482001-12-22 Akim Demaille <akim@epita.fr>
3649
3650 * src/output.c (output_table_data): Change the prototype to use
3651 `int' for array ranges: some invocations do pass an int, not a
3652 short.
3653 Reported by Wayne Green.
3654
b9752825
AD
36552001-12-22 Akim Demaille <akim@epita.fr>
3656
3657 Some actions of web2c.y are improperly triggered.
3658 Reported by Mike Castle.
3659
3660 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3661 * tests/regression.at (Web2c): Rename as...
3662 (Web2c Report): this.
3663 (Web2c Actions): New.
3664
776209d6
AD
36652001-12-22 Akim Demaille <akim@epita.fr>
3666
3667 Reductions in web2c.y are improperly reported.
3668 Reported by Mike Castle.
3669
3670 * src/conflicts.c (print_reductions): Fix.
3671 * tests/regression.at (Web2c): New.
3672
275fc3ad
AD
36732001-12-18 Akim Demaille <akim@epita.fr>
3674
3675 Some host fail on `assert (!"foo")', which expands to
3676 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3677 Reported by Nelson Beebee.
3678
3679 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3680 `#define it_succeeded 0' and `assert (it_succeeded)'.
3681
897668ee
MA
36822001-12-17 Marc Autret <autret_m@epita.fr>
3683
3684 * src/bison.simple: Don't hard code the skeleton line and filename.
3685 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3686 New line counter 'skeleton_line' (skeleton-line muscle).
3687
ab3399e0
PE
36882001-12-17 Paul Eggert <eggert@twinsun.com>
3689
3690 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3691 YYDEBUG must be defined to a nonzero value.
3692
3693 * src/bison.simple (yytname): Do not assume that the user defines
3694 YYDEBUG to a properly parenthesized expression.
3695
3877f72b
AD
36962001-12-17 Akim Demaille <akim@epita.fr>
3697
3698 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3699 nlookaheads is a new member.
3700 Adjust all users.
3701 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3702 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3703 state.
776209d6 3704
331dbc1b
AD
37052001-12-17 Akim Demaille <akim@epita.fr>
3706
3707 * src/files.h, src/files.c (open_files, close_files): Remove.
3708 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3709 let...
3710 * src/reader.c (reader): Do it.
776209d6 3711
be750e4c
AD
37122001-12-17 Akim Demaille <akim@epita.fr>
3713
3714 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 3715
709ae8c6
AD
37162001-12-17 Akim Demaille <akim@epita.fr>
3717
3718 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3719 (flush_reduce): New.
3720 (resolve_sr_conflict): Adjust.
776209d6 3721
f87685c3
AD
37222001-12-17 Akim Demaille <akim@epita.fr>
3723
3724 * src/output.c (output_obstack): Be static and rename as...
3725 (format_obstack): this, to avoid any confusion with files.c's
3726 output_obstack.
3727 * src/reader.h (muscle_obstack): Move to...
3728 * src/output.h: here, since it's defined in output.c.
3729
837491d8
AD
37302001-12-17 Akim Demaille <akim@epita.fr>
3731
3732 * src/output.c (action_row, save_column, default_goto)
3733 (sort_actions, matching_state, pack_vector): Better variable
3734 locality.
3735
796d61fb
AD
37362001-12-17 Akim Demaille <akim@epita.fr>
3737
3738 * src/output.c: Various formatting changes.
776209d6 3739
64d15509
AD
37402001-12-17 Akim Demaille <akim@epita.fr>
3741
3742 * src/files.c (output_files): Free the output_obstack.
3743 * src/main.c (main): Call print and print_graph conditionally.
3744 * src/print.c (print): Work unconditionally.
3745 * src/print_graph.c (print_graph): Work unconditionally.
3746 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3747
fbc8ecb7
MA
37482001-12-16 Marc Autret <autret_m@epita.fr>
3749
3750 * src/output.c (actions_output): Fix. When we use %no-lines,
3751 there is one less line per action.
3752
f0440388
MA
37532001-12-16 Marc Autret <autret_m@epita.fr>
3754
3755 * src/bison.simple: Remove a useless #line directive.
3756 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3757 * src/output.c (get_lines_number): New.
776209d6 3758 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
3759 output muscles.
3760 Fix line numbering.
3761 (actions_output): Computes the number of lines taken by actions.
3762 (output_master_parser): Insert new skeleton which is the name of
3763 the output parser file name.
3764
a79986b8
MA
37652001-12-15 Marc Autret <autret_m@epita.fr>
3766
3767 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3768
4ec8e00f
MA
37692001-12-15 Marc Autret <autret_m@epita.fr>
3770
3771 * src/output.c (output_gram): Keep track of the hairy one.
3772
1a4648ff
AD
37732001-12-15 Akim Demaille <akim@epita.fr>
3774
3775 Make `make distcheck' work.
3776
3777 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3778 system.h which uses libgettext.h.
3779
9c2c67e6
AD
37802001-12-15 Akim Demaille <akim@epita.fr>
3781
3782 * src/nullable.c (set_nullable): Useless rules must be skipped,
3783 otherwise, since we range over their symbols, we might look at a
3784 nonterminal which no longer ``exists'', i.e., it is not counted in
3785 `nvars', hence we overflow our arrays.
3786
93ede233
AD
37872001-12-15 Akim Demaille <akim@epita.fr>
3788
3789 The header can also be produced directly, without any obstack!
3790 Yahoo!
3791
3792 * src/files.c, src/files.h (defines_obstack): Remove.
3793 (compute_header_macro): Global.
3794 (defines_obstack_save): Remove.
3795 * src/reader.c (parse_union_decl): No longer output to
3796 defines_obstack: its content can be found in the `stype' muscle
3797 anyway.
3798 (output_token_translations): Merge into...
3799 (symbols_output): this.
3800 Rename as...
3801 (symbols_save): this.
3802 (reader): Adjust.
3803 * src/output.c (header_output): New.
3804 (output): Call it.
3805
2666f928
AD
38062001-12-15 Akim Demaille <akim@epita.fr>
3807
3808 * src/reader.c (parse_union_decl): Instead of handling two obstack
3809 simultaneously, use one to define the `stype' muscle, and use the
3810 value of the latter to fill defines_obstack.
3811 (copy_comment): Remove.
3812 (copy_comment2): Work for a single obstack.
3813 Rename as...
3814 (copy_comment): this.
3815
428046f8
AD
38162001-12-15 Akim Demaille <akim@epita.fr>
3817
3818 * src/lex.c, src/lex.h (xgetc): No longer static.
3819 * src/reader.c (parse_union_decl): Revamp.
3820
ea52d706
AD
38212001-12-15 Akim Demaille <akim@epita.fr>
3822
3823 Still making progress in separating Bison into (i) input, (ii)
3824 process, (iii) output: now we can directly output the parser file
3825 without using table_obstack at all.
3826
3827 * src/files.c, src/files.h (table_obstack): Bye bye.
3828 (parser_file_name): New.
3829 * src/files.c (compute_output_file_names): Compute it.
3830 * src/output.c (actions_output, output_parser)
3831 (output_master_parser): To a file instead of an obstack.
3832
3f96f4dc
AD
38332001-12-15 Akim Demaille <akim@epita.fr>
3834
3835 Attach actions to rules, instead of pre-outputting them to
3836 actions_obstack.
3837
3838 * src/gram.h (rule_t): action and action_line are new members.
3839 * src/reader.c (symbol_list): Likewise.
3840 (copy_action): Save the actions within the rule.
3841 (packgram): Save them in rule_table.
3842 * src/output.c (actions_output): New.
3843 (output_parser): Use it on `%%actions'.
3844 (output_rule_data): Don't free rule_table.
3845 (output): Do it.
3846 (prepare): Don't save the `action' muscle.
3847 * src/bison.simple: s/%%action/%%actions/.
3848
51576fb3
AD
38492001-12-15 Akim Demaille <akim@epita.fr>
3850
3851 * src/reader.c (copy_action): When --yacc, don't append a `;'
3852 to the user action: let it fail if lacking.
dee049eb 3853 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 3854
2648a72d
AD
38552001-12-14 Akim Demaille <akim@epita.fr>
3856
3857 * src/lex.c (literalchar): Simply return the char you decoded, non
3858 longer mess around with obstacks and int pointers.
3859 Adjust all callers.
3860
92790e5b
AD
38612001-12-14 Akim Demaille <akim@epita.fr>
3862
3863 * src/lex.c (literalchar): Don't escape the special characters,
3864 just decode them, and keep them as char (before, eol was output as
3865 the 2 char string `\n' etc.).
3866 * src/output.c (output_rule_data): Use quotearg to output the
3867 token strings.
3868
927c1557
PE
38692001-12-13 Paul Eggert <eggert@twinsun.com>
3870
3871 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3872 Do not infringe on the global user namespace when using C++.
3873 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3874 All uses of `fprintf' and `stderr' changed.
3875
3876 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3877
ed8e1f68
AD
38782001-12-13 Akim Demaille <akim@epita.fr>
3879
3880 The computation of nullable is broken: it doesn't handle empty
3881 RHS's properly.
3882
3883 * tests/torture.at (GNU AWK Grammar): New.
3884 * tests/sets.at (Nullable): New.
3885 * src/nullable.c (set_nullable): Instead of blindly looping over
3886 `ritems', loop over the rules, and then over their rhs's.
3887
3888 Work around Autotest bugs.
3889
3890 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
3891 frame, because Autotest understand lines starting with a `+' as
3892 traces from the shell. Then, they are not processed properly.
3893 Admittedly an Autotest bug, but we don't have time to wait for
3894 Autotest to catch up.
3895 * tests/regression.at (Broken Closure): Adjust to the new table
3896 frames.
3897 Move to...
3898 * tests/sets.at: here.
3899
cb581495
AD
39002001-12-13 Akim Demaille <akim@epita.fr>
3901
3902 * src/closure.c (closure): Use nrules instead of playing tricks
3903 with BITS_PER_WORD.
3904
2e729273
AD
39052001-12-13 Akim Demaille <akim@epita.fr>
3906
3907 * src/print.c (print_actions): Output the handling of `$' as the
3908 traces do: shifting the token EOF. Before EOF was treated as a
3909 nonterminal.
3910 * tests/regression.at: Adjust some tests.
3911 * src/print_graph.c (print_core): Complete the set of items via
3912 closure. The next-to-final and final states are still unsatisfying,
3913 but that's to be addressed elsewhere.
3914 No longer output the rule numbers, but do output the state number.
3915 A single loop for the shifts + gotos is enough, but picked a
3916 distinct color for each.
3917 (print_graph): Initialize and finalize closure.
3918
107f7dfb
AD
39192001-12-13 Akim Demaille <akim@epita.fr>
3920
3921 * src/reader.c (readgram): Remove dead code, an strip useless
3922 braces.
3923 (get_type): Remove, unused.
3924
9b53a24f
AD
39252001-12-12 Akim Demaille <akim@epita.fr>
3926
3927 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
3928 on that of lib/error.c.
3929
dbfb6dcd
AD
39302001-12-12 Akim Demaille <akim@epita.fr>
3931
3932 Some hosts don't like `/' in includes.
3933
3934 * src/system.h: Include libgettext.h without qualifying the path.
3935 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
3936 $(top_srcdir).
3937
c25fb648
MA
39382001-12-11 Marc Autret <autret_m@epita.fr>
3939
3940 * src/output.c (output_parser): Remove useless muscle.
3941
710ddc4f
MA
39422001-12-11 Marc Autret <autret_m@epita.fr>
3943
3944 * src/bison.simple: Remove #line just before %%epilogue. It
3945 is now handled in ...
3946 * src/reader.c (read_additionnal_code): Add the output of a
3947 #line for the epilogue.
3948
e83d80b8
MA
39492001-12-10 Marc Autret <autret_m@epita.fr>
3950
927c1557 3951 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
3952 replace precedent remove.
3953 * src/bison.simple: Remove #line before %%prologue because
3954 %%input-line is wrong at this time.
3955
971d5158
MA
39562001-12-10 Marc Autret <autret_m@epita.fr>
3957
3958 * src/reader.c (symbols_output): Clean up.
927c1557 3959 * src/output.c (output_gram, output): Clean up.
971d5158 3960
5edafffd
AD
39612001-12-10 Akim Demaille <akim@epita.fr>
3962
3963 * src/lalr.c (initialize_lookaheads): New. Extracted from...
3964 * src/LR0.c (set_state_table): here.
3965 * src/lalr.c (lalr): Call it.
3966
0279f8e9
AD
39672001-12-10 Akim Demaille <akim@epita.fr>
3968
3969 * src/state.h (shifts): Remove the `number' member: shifts are
3970 attached to state, hence no longer need to be labelled with a
3971 state number.
3972
190c4f5f
AD
39732001-12-10 Akim Demaille <akim@epita.fr>
3974
3975 Now that states have a complete set of members, the linked list of
3976 shifts is useless: just fill directly the state's shifts member.
3977
3978 * src/state.h (shifts): Remove the `next' member.
3979 * src/LR0.c (first_state, last_state): Remove.
3980 Adjust the callers.
3981 (augment_automaton): Don't look for the shifts that must be added
3982 a shift on EOF: it is those of the state we looked for! But now,
3983 since shifts are attached, it is no longer needed to looking
3984 merely by its id: its number.
3985
2a73b93d
AD
39862001-12-10 Akim Demaille <akim@epita.fr>
3987
3988 * src/LR0.c (augment_automaton): Better variable locality.
3989 Remove an impossible branch: if there is a state corresponding to
3990 the start symbol being shifted, then there is shift for the start
3991 symbol from the initial state.
3992
74392f6a
AD
39932001-12-10 Akim Demaille <akim@epita.fr>
3994
3995 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
3996 only when appropriate: when insert_start_shifting_state' is not
3997 invoked.
3998 * tests/regression.at (Rule Line Numbers): Adjust.
3999
37c82725
AD
40002001-12-10 Akim Demaille <akim@epita.fr>
4001
4002 * src/LR0.c (augment_automaton): Now that all states have shifts,
4003 merge the two cases addition shifts to the initial state.
4004
6a164e0c
AD
40052001-12-10 Akim Demaille <akim@epita.fr>
4006
4007 * src/lalr.c (set_state_table): Move to...
4008 * src/LR0.c: here.
4009 * src/lalr.c (lalr): Don't call it...
4010 * src/LR0.c (generate_states): do it.
4011 * src/LR0.h (first_state): Remove, only the table is used.
4012
7215de24
AD
40132001-12-10 Akim Demaille <akim@epita.fr>
4014
4015 * src/LR0.h (first_shift, first_reduction): Remove.
4016 * src/lalr.c: Don't use first_shift: find shifts through the
4017 states.
4018
80e25d4d
AD
40192001-12-10 Akim Demaille <akim@epita.fr>
4020
4021 * src/LR0.c: Attach shifts to states as soon as they are
4022 computed.
4023 * src/lalr.c (set_state_table): Instead of assigning shifts to
4024 state, just assert that the mapping was properly done.
4025
0ab3728b
AD
40262001-12-10 Akim Demaille <akim@epita.fr>
4027
4028 * src/LR0.c (insert_start_shift): Rename as...
4029 (insert_start_shifting_state): this.
4030 (insert_eof_shifting_state, insert_accepting_state): New.
4031 (augment_automaton): Adjust.
4032 Better locality of the variables.
4033 When looking if the start_symbol is shifted from the initial
4034 state, using `while (... symbol != start_symbol ...)' sounds
4035 better than `while (... symbol < start_symbol ...)': If fail
4036 to see how the order between symbols could be relevant!
4037
78af9bbc
AD
40382001-12-10 Akim Demaille <akim@epita.fr>
4039
4040 * src/getargs.h: Don't declare `spec_name_prefix' and
4041 `spec_file_prefix', declared by src/files.h.
4042 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4043 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4044 * src/output.c (prepare): Adjust.
4045 * src/reader.c (symbols_output): Likewise.
4046 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4047
bdef2a41
AD
40482001-12-10 Akim Demaille <akim@epita.fr>
4049
4050 * src/muscle_tab.c (muscle_init): NULL is a better default than
4051 `"0"'.
4052
3735969c
AD
40532001-12-10 Akim Demaille <akim@epita.fr>
4054
4055 * src/reader.c (reader): Calling symbols_output once is enough.
4056
49701457
AD
40572001-12-10 Akim Demaille <akim@epita.fr>
4058
4059 Now that states have a complete set of members, the linked list of
4060 reductions is useless: just fill directly the state's reductions
4061 member.
4062
4063 * src/state.h (struct reductions): Remove member `number' and
4064 `next'.
4065 * src/LR0.c (first_reduction, last_reduction): Remove.
4066 (save_reductions): Don't link the new reductions, store them in
4067 this_state.
4068 * src/lalr.c (set_state_table): No need to attach reductions to
4069 states, it's already done.
4070 * src/output.c (output_actions): No longer free the shifts, then
4071 the reductions, then the states: free all the states and their
4072 members.
4073
0edad749
AD
40742001-12-10 Akim Demaille <akim@epita.fr>
4075
4076 * src/options.c (OPTN, DRTV, BOTH): New.
4077 (option_table): Use them.
4078
0edad749
AD
4079 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4080 the job of system.h.
4081 * src/options.c: Don't include stdio.h and xalloc.h for the same
4082 reasons.
4083
5449dd0f
AD
40842001-12-10 Akim Demaille <akim@epita.fr>
4085
4086 * src/output.c (output, prepare): Make sure the values of the
4087 muscles `action' and `prologue' are 0-terminated.
4088
a870c567
AD
40892001-12-10 Akim Demaille <akim@epita.fr>
4090
4091 Clean up GCC warnings.
4092
4093 * src/reader.c (copy_action): `buf' is not used.
4094 (parse_skel_decl): Be static.
4095 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4096 * src/options.h (create_long_option_table): Have a real prototype.
4097 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4098 (hash_delete_at): Return const void *.
4099 Adjust casts to preserve the const.
4100
80df8768
AD
41012001-12-10 Akim Demaille <akim@epita.fr>
4102
4103 * configure.in: Require 2.52g.
4104 M4 is not needed, but AUTOM4TE is.
4105 * m4/m4.m4: Remove.
4106 * tests/Makefile.am: Adjust.
4107
f693ad14
AD
41082001-12-10 Akim Demaille <akim@epita.fr>
4109
4110 One structure for states is enough, even though theoretically
4111 there are LR(0) states and LALR(1) states.
4112
4113 * src/lalr.h (state_t): Remove.
4114 (state_table): Be state_t **, not state_t *.
4115 * src/state.h (core, CORE_ALLOC): Rename as...
4116 (state_t, STATE_ALLOC): this.
4117 Add the LALR(1) members: shifts, reductions, errs.
4118 * src/LR0.c (state_table): Rename as...
4119 (state_hash): this, to avoid name clashes with the global
4120 `state_table'.
4121 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4122 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4123
74ffbcb6
AD
41242001-12-10 Akim Demaille <akim@epita.fr>
4125
4126 Bison dumps core on bash.y.
4127 Reported by Pascal Bart.
4128
4129 * src/warshall.c (bitmatrix_print): New.
4130 (TC): Use it.
4131 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4132 j must be the outer loop.
4133 * tests/regression.at (Broken Closure): New.
4134
07708e19
AD
41352001-12-05 Akim Demaille <akim@epita.fr>
4136
4137 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4138 its argument.
4139