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