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