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