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