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