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