]> git.saurik.com Git - bison.git/blame - ChangeLog
Add HACKING.
[bison.git] / ChangeLog
CommitLineData
217598da
AD
12002-07-30 Akim Demaille <akim@epita.fr>
2
3 In verbose parse error message, don't report `error' as an
4 expected token.
5 * tests/actions.at (Printers and Destructors): Adjust.
6 * tests/calc.at (Calculator $1): Adjust.
7 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
8 error message, do not report the parser accepts the error token in
9 that state.
10
52489d44
AD
112002-07-30 Akim Demaille <akim@epita.fr>
12
13 Normalize conflict related messages.
14
15 * src/complain.h, src/complain.c (warn, complain): New.
16 * src/conflicts.c (conflicts_print): Use them.
17 (conflict_report_yacc): New, extracted from...
18 (conflicts_print): here.
19 * tests/conflicts.at, tests/existing.at: Adjust.
20
e8832397
AD
212002-07-30 Akim Demaille <akim@epita.fr>
22
23 Report rules which are never reduced by the parser: those hidden
24 by conflicts.
25
26 * src/LR0.c (save_reductions): Don't make the final state too
27 different: save its reduction (accept) instead of having a state
28 without any action (no shift or goto, no reduce).
29 Note: the final state is now a ``regular'' state, i.e., the
30 parsers now contain `reduce 0' as default reduction.
31 Nevertheless, since they decide to `accept' when yystate =
32 final_state, they still will not reduce rule 0.
33 * src/print.c (print_actions, print_reduction): Adjust.
34 * src/output.c (action_row): Track reduced rules.
35 (token_actions): Report rules never reduced.
36 * tests/conflicts.at, tests/regression.at: Adjust.
37
caf23d24
AD
382002-07-30 Akim Demaille <akim@epita.fr>
39
40 `stage' was accidently included in a previous patch.
41 Initiate its autoconfiscation.
42
43 * configure.in: Look for malloc.h and sys/times.h.
44 * src/main.c (stage): Adjust.
45 Report only when trace_flag.
46
640748ee
AD
472002-07-29 Akim Demaille <akim@epita.fr>
48
49 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
50 state_number_t.
51 (errs_t): symbol_t*, not symbol_number_t.
52 (reductions_t): rule_t*, not rule_number_t.
53 (FOR_EACH_SHIFT): New.
54 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
55 * src/print.c, src/print_graph.c: Adjust.
56
88bce5a2
AD
572002-07-29 Akim Demaille <akim@epita.fr>
58
59 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
60
61 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
62 (endtoken, accept): these.
63 * src/reader.c (reader): Set endtoken's default tag to "$end".
64 Set undeftoken's tag to "$undefined" instead of "$undefined.".
65 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
66 Adjust.
67
1bfb97db
AD
682002-07-29 Akim Demaille <akim@epita.fr>
69
70 * src/reduce.c (reduce_grammar): When the language is empty,
71 complain about the start symbol, not the axiom.
72 Use its location.
73 * tests/reduce.at (Empty Language): New.
74
fc5734fe
AD
752002-07-26 Akim Demaille <akim@epita.fr>
76
77 * src/reader.h, src/reader.c (gram_error): ... can't get
78 yycontrol without making too strong assumptions on the parser
79 itself.
80 * src/output.c (prepare_tokens): Use the real 0th value of
81 token_translations instead of `0'.
82 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
83 visible here.
84 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
85 for the time being: %locations ought to provide it to yyerror.
86
3650b4b8
AD
872002-07-25 Akim Demaille <akim@epita.fr>
88
89 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
90 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
91 * tests/regression.at (Web2c Actions): Adjust.
92
4b3d3a8e
AD
932002-07-25 Akim Demaille <akim@epita.fr>
94
95 Stop storing rules from 1 to nrules + 1.
96
97 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
98 * src/nullable.c, src/output.c, src/print.c, src/reader.c
99 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
100 Iterate from 0 to nrules.
101 Use rule_number_as_item_number and item_number_as_rule_number.
102 Adjust to `derive' now containing possibly 0.
103 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
104 Handle the `- 1' part in rule numbers from/to item numbers.
105 * src/conflicts.c (log_resolution): Fix the message which reversed
106 shift and reduce.
107 * src/output.c (action_row): Initialize default_rule to -1.
108 (token_actions): Adjust.
109 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
110 expected output.
111 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
112
4a2a22f4
AD
1132002-07-25 Akim Demaille <akim@epita.fr>
114
115 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
116 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
117 (b4_c_knr_arg_decl): New.
118 * data/yacc.c: Use it to define yysymprint, yydestruct, and
119 yyreport_parse_error.
120
b8df3223
AD
1212002-07-25 Akim Demaille <akim@epita.fr>
122
123 * data/yacc.c (yyreport_parse_error): New, extracted from...
124 (yyparse): here.
125 (yydestruct, yysymprint): Move above yyparse.
126 Be K&R compliant.
127
a762e609
AD
1282002-07-25 Akim Demaille <akim@epita.fr>
129
130 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
131 replace...
132 (b4_sint_type, b4_uint_type): these.
133 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
134 * tests/regression.at (Web2c Actions): Adjust.
135
12b0043a
AD
1362002-07-25 Akim Demaille <akim@epita.fr>
137
138 * src/gram.h (TIEM_NUMBER_MAX): New.
139 (item_number_of_rule_number, rule_number_of_item_number): Rename
140 as...
141 (rule_number_as_item_number, item_number_as_rule_number): these.
142 Adjust dependencies.
143 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
144 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
145 (symbol_number_to_vector_number): New.
146 (order): Of vector_number_t* type.
147 (base_t, BASE_MAX, BASE_MIN): New.
148 (froms, tos, width, pos, check): Of base_t type.
149 (action_number_t, ACTION_MIN, ACTION_MAX): New.
150 (actrow): Of action_number_t type.
151 (conflrow): Of unsigned int type.
152 (table_ninf, base_ninf): New.
153 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
154 (muscle_insert_int_table, muscle_insert_base_table)
155 (muscle_insert_rule_number_table): New.
156 (prepare_tokens): Output `toknum' as int_table.
157 (action_row): Returns a rule_number_t.
158 Use ACTION_MIN, not SHRT_MIN.
159 (token_actions): yydefact is rule_number_t*.
160 (table_ninf_remap): New.
161 (pack_table): Use it for `base' and `table'.
162 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
163 replaced with...
164 (YYPACT_NINF, YYTABLE_NINF): these.
165 (yypact, yytable): Compute their types instead of hard-coded
166 `short'.
167 * tests/regression.at (Web2c Actions): Adjust.
168
5dde258a
AD
1692002-07-19 Akim Demaille <akim@epita.fr>
170
171 * src/scan-gram.l (id): Can start with an underscore.
172
a945ec39
AD
1732002-07-16 Akim Demaille <akim@epita.fr>
174
175 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
176 Adjust all former `associativity' dependencies.
177 * src/symtab.c (symbol_new): Default associativity is `undef', not
178 `right'.
179 (symbol_check_alias_consistence): Adjust.
180
fae437e8
AD
1812002-07-09 Akim Demaille <akim@epita.fr>
182
183 * doc/bison.texinfo: Properly set the ``header'' part.
184 Use @dircategory ``GNU programming tools'' as per Texinfo's
185 documentation.
186 Use @copying.
187
1a715ef2
AD
1882002-07-09 Akim Demaille <akim@epita.fr>
189
190 * lib/quotearg.h: Protect against multiple inclusions.
191 * src/location.h (location_t): Add a `file' member.
192 (LOCATION_RESET, LOCATION_PRINT): Adjust.
193 * src/complain.c (warn_at, complain_at, fatal_at): Drop
194 `error_one_per_line' support.
195
a5d50994
AD
1962002-07-09 Akim Demaille <akim@epita.fr>
197
198 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
199 * src/reader.c (lineno): Remove.
200 Adjust all dependencies.
201 (get_merge_function): Take a location and use complain_at.
202 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
203 * tests/regression.at (Invalid inputs, Mixing %token styles):
204 Adjust.
205
b275314e
AD
2062002-07-09 Akim Demaille <akim@epita.fr>
207
208 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
209 recovery rule, and forbid extensions when --yacc.
210 (gram_error): Use complain_at.
211 * src/reader.c (reader): Exit if there were parse errors.
212
865b9df1
AD
2132002-07-09 Akim Demaille <akim@epita.fr>
214
215 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
216 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
217 Reported by R Blake <blakers@mac.com>.
218
c76e14da
AD
2192002-07-09 Akim Demaille <akim@epita.fr>
220
221 * data/yacc.c: Output the copyright notive in the header.
222
7db2ed2d
AD
2232002-07-03 Akim Demaille <akim@epita.fr>
224
225 * src/output.c (froms, tos): Are state_number_t.
226 (save_column): sp, sp1, and sp2 are state_number_t.
227 (prepare): Rename `final' as `final_state_number', `nnts' as
228 `nterms_number', `nrules' as `rules_number', `nstates' as
229 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
230 unused.
231 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
232 * data/lalr1.cc (nsym_): Remove, unused.
233
e68e0410
AD
2342002-07-03 Akim Demaille <akim@epita.fr>
235
236 * src/lalr.h, src/lalr.c (goto_number_t): New.
237 * src/lalr.c (goto_list_t): New.
238 Propagate them.
239 * src/nullable.c (rule_list_t): New.
240 Propagate.
241 * src/types.h: Remove.
242
e1a4f3a4
AD
2432002-07-03 Akim Demaille <akim@epita.fr>
244
245 * src/closure.c (print_fderives): Use rule_rhs_print.
246 * src/derives.c (print_derives): Use rule_rhs_print.
247 (rule_list_t): New, replaces `shorts'.
248 (set_derives): Add comments.
249 * tests/sets.at (Nullable, Firsts): Adjust.
250
536545f3
AD
2512002-07-03 Akim Demaille <akim@epita.fr>
252
253 * src/output.c (prepare_actions): Free `tally' and `width'.
254 (prepare_actions): Allocate and free `order'.
255 * src/symtab.c (symbols_free): Free `symbols'.
256 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
257 * src/output.c (m4_invoke): Move to...
258 * src/scan-skel.l: here.
259 (<<EOF>>): Close yyout, and free its name.
260
8b752b00
AD
2612002-07-03 Akim Demaille <akim@epita.fr>
262
263 Fix some memory leaks, and fix a bug: state 0 was examined twice.
264
265 * src/LR0.c (new_state): Merge into...
266 (state_list_append): this.
267 (new_states): Merge into...
268 (generate_states): here.
269 (set_states): Don't ensure a proper `errs' state member here, do it...
270 * src/conflicts.c (conflicts_solve): here.
271 * src/state.h, src/state.c: Comment changes.
272 (state_t): Rename member `shifts' as `transitions'.
273 Adjust all dependencies.
274 (errs_new): For consistency, also take the values as argument.
275 (errs_dup): Remove.
276 (state_errs_set): New.
277 (state_reductions_set, state_transitions_set): Assert that no
278 previous value was assigned.
279 (state_free): New.
280 (states_free): Use it.
281 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
282 temporary storage: use `errs' and `nerrs' as elsewhere.
283 (set_conflicts): Allocate and free this `errs'.
284
613f5e1a
AD
2852002-07-02 Akim Demaille <akim@epita.fr>
286
287 * lib/libiberty.h: New.
288 * lib: Update the bitset implementation from upstream.
289 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
290 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
291 * src/main.c: Adjust bitset stats calls.
292
26e0cadc
PE
2932002-07-01 Paul Eggert <eggert@twinsun.com>
294
295 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
296 char, so that negative chars don't collide with $.
297
1154cced
AD
2982002-06-30 Akim Demaille <akim@epita.fr>
299
300 Have the GLR tests be `warning' checked, and fix the warnings.
301
302 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
303 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
304 (yyremoveDeletes): `yyi' and `yyj' are size_t.
305 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
306 (yyaddDeferredAction): static.
307 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
308 (yyreportParseError): yyprefix is const.
309 yytokenp is used only when verbose.
310 (yy__GNUC__): Replace with __GNUC__.
311 (yypdumpstack): yyi is size_t.
312 (yypreference): Un-yy local variables and arguments, to avoid
313 clashes with `yyr1'. Anyway, we are not in the user name space.
314 (yytname_size): be an int, as is compared with ints.
315 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
316 Use them.
317 * tests/cxx-gram.at: Use quotation to protect $1.
318 Use AT_COMPILE to enable warnings hunts.
319 Prototype yylex and yyerror.
320 `Use' argc.
321 Include `string.h', not `strings.h'.
322 Produce and prototype stmtMerge only when used.
323 yylex takes a location.
324
97650f4e
AD
3252002-06-30 Akim Demaille <akim@epita.fr>
326
327 We spend a lot of time in quotearg, in particular when --verbose.
328
329 * src/symtab.c (symbol_get): Store a quoted version of the key.
330 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
331 Adjust all callers.
332
d2576365
AD
3332002-06-30 Akim Demaille <akim@epita.fr>
334
335 * src/state.h (reductions_t): Rename member `nreds' as num.
336 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
337 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
338
ccaf65bc
AD
3392002-06-30 Akim Demaille <akim@epita.fr>
340
341 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
342 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
343 (shifts_to): Rename as...
344 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
345 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
346 (TRANSITION_IS_DISABLED, transitions_to): these.
347
87675353
AD
3482002-06-30 Akim Demaille <akim@epita.fr>
349
350 * src/print.c (print_shifts, print_gotos): Merge into...
351 (print_transitions): this.
352 (print_transitions, print_errs, print_reductions): Align the
353 lookaheads columns.
354 (print_core, print_transitions, print_errs, print_state,
355 print_grammar): Output empty lines separator before, not after.
356 (state_default_rule_compute): Rename as...
357 (state_default_rule): this.
358 * tests/conflicts.at (Defaulted Conflicted Reduction),
359 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
360 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
361
ce4ccb4b
AD
3622002-06-30 Akim Demaille <akim@epita.fr>
363
364 Display items as we display rules.
365
366 * src/gram.h, src/gram.c (rule_lhs_print): New.
367 * src/gram.c (grammar_rules_partial_print): Use it.
368 * src/print.c (print_core): Likewise.
369 * tests/conflicts.at (Defaulted Conflicted Reduction),
370 (Unresolved SR Conflicts): Adjust.
371 (Unresolved SR Conflicts): Adjust and rename as...
372 (Resolved SR Conflicts): this, as was meant.
373 * tests/regression.at (Web2c Report): Adjust.
374
bc933ef1
AD
3752002-06-30 Akim Demaille <akim@epita.fr>
376
377 * src/print.c (state_default_rule_compute): New, extracted from...
378 (print_reductions): here.
379 Pessimize, but clarify the code.
380 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
381
53d4308d
AD
3822002-06-30 Akim Demaille <akim@epita.fr>
383
384 * src/output.c (action_row): Let default_rule be always a rule
385 number.
386
574fb2d5
AD
3872002-06-30 Akim Demaille <akim@epita.fr>
388
389 * src/closure.c (print_firsts, print_fderives, closure):
390 Use BITSET_EXECUTE.
391 * src/lalr.c (lookaheads_print): Likewise.
392 * src/state.c (state_rule_lookaheads_print): Likewise.
393 * src/print_graph.c (print_core): Likewise.
394 * src/print.c (print_reductions): Likewise.
395 * src/output.c (action_row): Likewise.
396 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
397
05811fd7
AD
3982002-06-30 Akim Demaille <akim@epita.fr>
399
400 * src/print_graph.c: Use report_flag.
401
0e4d5753
AD
4022002-06-30 Akim Demaille <akim@epita.fr>
403
404 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
405 to...
406 * src/relation.h, src/relation.c (traverse, relation_digraph)
407 (relation_print, relation_transpose): New.
408
24c7d800
AD
4092002-06-30 Akim Demaille <akim@epita.fr>
410
411 * src/state.h, src/state.c (shifts_to): New.
412 * src/lalr.c (build_relations): Use it.
413
9222837b
AD
4142002-06-30 Akim Demaille <akim@epita.fr>
415
416 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
417 (item_number_of_rule_number, rule_number_of_item_number): New.
418 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
419 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
420 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
421 Propagate their use.
422 Much remains to be done, in particular wrt `shorts' from types.h.
423
260008e5
AD
4242002-06-30 Akim Demaille <akim@epita.fr>
425
426 * src/symtab.c (symbol_new): Initialize the `printer' member.
427
8a731ca8
AD
4282002-06-30 Akim Demaille <akim@epita.fr>
429
430 * src/LR0.c (save_reductions): Remove, replaced by...
431 * src/state.h, src/state.c (state_reductions_set): New.
432 (reductions, errs): Rename as...
433 (reductions_t, errs_t): these.
434 Adjust all dependencies.
435
32e1e0a4
AD
4362002-06-30 Akim Demaille <akim@epita.fr>
437
438 * src/LR0.c (state_list_t, state_list_append): New.
439 (first_state, last_state): Now symbol_list_t.
440 (this_state): Remove.
441 (new_itemsets, append_states, save_reductions): Take a state_t as
442 argument.
443 (set_states, generate_states): Adjust.
444 (save_shifts): Remove, replaced by...
445 * src/state.h, src/state.c (state_shifts_set): New.
446 (shifts): Rename as...
447 (shifts_t): this.
448 Adjust all dependencies.
449 * src/state.h (state_t): Remove the `next' member.
450
e5fb6710
AD
4512002-06-30 Akim Demaille <akim@epita.fr>
452
453 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
454 escaped in slot 0.
455
c7ca99d4
AD
4562002-06-30 Akim Demaille <akim@epita.fr>
457
458 Use hash.h for the state hash table.
459
460 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
461 (allocate_storage): Use state_hash_new.
462 (free_storage): Use state_hash_free.
463 (new_state, get_state): Adjust.
464 * src/lalr.h, src/lalr.c (states): Move to...
465 * src/states.h (state_t): Remove the `link' member, no longer
466 used.
467 * src/states.h, src/states.c: here.
468 (state_hash_new, state_hash_free, state_hash_lookup)
469 (state_hash_insert, states_free): New.
470 * src/states.c (state_table, state_compare, state_hash): New.
471 * src/output.c (output_actions): Do not free states now, since we
472 still need to know the final_state number in `prepare', called
473 afterwards. Do it...
474 * src/main.c (main): here: call states_free after `output'.
475
df0e7316
AD
4762002-06-30 Akim Demaille <akim@epita.fr>
477
478 * src/state.h, src/state.c (state_new): New, extracted from...
479 * src/LR0.c (new_state): here.
480 * src/state.h (STATE_ALLOC): Move to...
481 * src/state.c: here.
482 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
483 * src/state.h, src/state.c: here.
484
39f41916
AD
4852002-06-30 Akim Demaille <akim@epita.fr>
486
487 * src/reader.c (gensym): Rename as...
488 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
489 (getsym): Rename as...
490 (symbol_get): this.
491
d57650a5
AD
4922002-06-30 Akim Demaille <akim@epita.fr>
493
494 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
495 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
496 * src/output.c, src/print.c, src/print_graph.c: Propagate.
497 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
498
5a08f1ce
AD
4992002-06-30 Akim Demaille <akim@epita.fr>
500
501 Make the test suite pass with warnings checked.
502
503 * tests/actions.at (Printers and Destructors): Improve.
504 Avoid unsigned vs. signed issues.
505 * tests/calc.at: Don't exercise the scanner here, do it...
506 * tests/input.at (Torturing the Scanner): here.
507
720623af
PH
5082002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
509
88e7e941 510 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
511 reorganize first lines parallel to yacc.c.
512
fb8135fa
AD
5132002-06-28 Akim Demaille <akim@epita.fr>
514
515 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
516 (b4_token_enum, b4_token_defines): New, factored from...
517 * data/lalr1.cc, data/yacc.c, glr.c: here.
518
41442480
AD
5192002-06-28 Akim Demaille <akim@epita.fr>
520
521 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
522 unused variables.
523 * src/output.c (merger_output): static.
524
e0e5bf84
AD
5252002-06-28 Akim Demaille <akim@epita.fr>
526
527 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
528 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
529 pacify GCC.
530 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 531
676385e2
PH
5322002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
533
534 Accumulated changelog for new GLR parsing features.
535
e0e5bf84 536 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
537 conflicts_total_count.
538 * src/conflicts.h: Ditto.
539 * src/output.c (token_actions): Use the new name.
540 (output_conflicts): Change conflp => conflict_list_heads, and
541 confl => conflict_list for better readability.
542 * data/glr.c: Use the new names.
543 * NEWS: Add self to GLR announcement.
e0e5bf84 544
676385e2
PH
545 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
546
547 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
548 Akim Demaille.
549
550 * data/bison.glr: Change name to glr.c
551 * data/glr.c: Renamed from bison.glr.
552 * data/Makefile.am: Add glr.c
e0e5bf84
AD
553
554 * src/getargs.c:
555
676385e2
PH
556 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
557 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 558
676385e2
PH
559 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
560
561 * data/bison.glr: Be sure to restore the
562 current #line when returning to the skeleton contents after having
563 exposed the input file's #line.
564
565 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
566
567 * data/bison.glr: Bring up to date with changes to bison.simple.
568
569 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
570
571 * data/bison.glr: Correct definitions that use b4_prefix.
572 Various reformatting.
573 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
574 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
575 yytokenp argument; now part of stack.
576 (yychar): Define to behave as documented.
577 (yyclearin): Ditto.
e0e5bf84 578
676385e2
PH
579 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
580
581 * src/reader.h: Add declaration for free_merger_functions.
582
583 * src/reader.c (merge_functions): New variable.
584 (get_merge_function): New function.
585 (free_merger_functions): New function.
586 (readgram): Check for %prec that is not followed by a symbol.
587 Handle %dprec and %merge declarations.
588 (packgram): Initialize dprec and merger fields in rules array.
589
590 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
591 conflict_list_cnt, conflict_list_free): New variables.
592 (table_grow): Also grow conflict_table.
e0e5bf84 593 (prepare_rules): Output dprec and merger tables.
676385e2 594 (conflict_row): New function.
e0e5bf84 595 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
596 default reduction in conflicted states for GLR parser so that there
597 are spaces for the conflict lists.
598 (save_row): Also save conflict information.
599 (token_actions): Allocate conflict list.
600 (merger_output): New function.
601 (pack_vector): Pack conflict table, too.
602 (output_conflicts): New function to output yyconflp and yyconfl.
603 (output_check): Allocate conflict_tos.
604 (output_actions): Output conflict tables, also.
605 (output_skeleton): Output b4_mergers definition.
606 (prepare): Output b4_max_rhs_length definition.
607 Use 'bison.glr' as default skeleton for GLR parsers.
608
609 * src/gram.c (glr_parser): New flag.
610 (grammar_free): Call free_merger_functions.
611
612 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
613 all pairs of conflicting reductions, rather than just all tokens
614 causing conflicts. Needed to size conflict tables.
e0e5bf84 615 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
616 interface.
617 (conflicts_print): Ditto.
618 (count_total_conflicts): New function.
619
620 * src/reader.h (merger_list): New type.
621 (merge_functions): New variable.
622
623 * src/lex.h (tok_dprec, tok_merge): New token types.
624
625 * src/gram.h (rule_s): Add dprec and merger fields.
626 (glr_parser): New flag.
627
628 * src/conflicts.h (count_total_conflicts): New function.
629
630 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
631
632 * doc/bison.texinfo (Generalized LR Parsing): New section.
633 (GLR Parsers): New section.
634 (Language and Grammar): Mention GLR parsing.
635 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
636 Correct typo ("tge" -> "the").
637
638 * data/bison.glr: New skeleton for GLR parsing.
639
640 * tests/cxx-gram.at: New tests for GLR parsing.
641
642 * tests/testsuite.at: Include cxx-gram.at.
643
644 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 645
676385e2
PH
646 * src/parse-gram.y:
647
648 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
649
650 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 651
b5480d74 6522002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
653
654 * src/options.h, src/options.c: Remove.
655 * src/getargs.c (short_options, long_options): New.
656
60491a94
AD
6572002-06-27 Akim Demaille <akim@epita.fr>
658
659 * data/bison.simple, data/bison.c++: Rename as...
660 * data/yacc.c, data/lalr1.cc: these.
661 * doc/bison.texinfo (Environment Variables): Remove.
662
9be0c25b
AD
6632002-06-25 Raja R Harinath <harinath@cs.umn.edu>
664
665 * src/getargs.c (report_argmatch): Initialize strtok().
666
1ae72863
AD
6672002-06-20 Akim Demaille <akim@epita.fr>
668
669 * data/bison.simple (b4_symbol_actions): New, replaces...
670 (b4_symbol_destructor, b4_symbol_printer): these.
671 (yysymprint): Be sure to call YYPRINT only for tokens, and using
672 user token numbers.
673
87542d29
AD
6742002-06-20 Akim Demaille <akim@epita.fr>
675
676 * data/bison.simple (yydestructor): Rename as...
677 (yydestruct): this.
678
1a31ed21
AD
6792002-06-20 Akim Demaille <akim@epita.fr>
680
681 * src/symtab.h, src/symtab.c (symbol_type_set)
682 (symbol_destructor_set, symbol_precedence_set): The location is
683 the last argument.
684 Adjust all callers.
685
e776192e
AD
6862002-06-20 Akim Demaille <akim@epita.fr>
687
688 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
689 internals.
690 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
691 Takes a location.
692 * src/symtab.h, src/symtab.c (symbol_class_set)
693 (symbol_user_token_number_set): Likewise.
694 Adjust all callers.
695 Promote complain_at.
696 * tests/input.at (Type Clashes): Adjust.
697
5c1180b3
AD
6982002-06-20 Akim Demaille <akim@epita.fr>
699
700 * data/bison.simple (YYLEX): Fix the declaration when
701 %pure-parser.
702
e3170060
AD
7032002-06-20 Akim Demaille <akim@epita.fr>
704
705 * data/bison.simple (yysymprint): Don't print the token number,
706 just its name.
707 * tests/actions.at (Destructors): Rename as...
708 (Printers and Destructors): this.
709 Also exercise %printer.
710
253862fd
AD
7112002-06-20 Akim Demaille <akim@epita.fr>
712
713 * data/bison.simple (YYDSYMPRINT): New.
714 Use it to remove many of the #if YYDEBUG/if (yydebug).
715
366eea36
AD
7162002-06-20 Akim Demaille <akim@epita.fr>
717
718 * src/symtab.h, src/symtab.c (symbol_t): printer and
719 printer_location are new members.
720 (symbol_printer_set): New.
721 * src/parse-gram.y (PERCENT_PRINTER): New token.
722 Handle its associated rule.
723 * src/scan-gram.l: Adjust.
724 (handle_destructor_at, handle_destructor_dollar): Rename as...
725 (handle_symbol_code_at, handle_symbol_code_dollar): these.
726 * src/output.c (symbol_printers_output): New.
727 (output_skeleton): Call it.
728 * data/bison.simple (yysymprint): New. Cannot be named yyprint
729 since there are already many grammar files with a user `yyprint'.
730 Replace the calls to YYPRINT to calls to yysymprint.
731 * tests/calc.at: Adjust.
732 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
733 taking advantage of parser very internal details (stack size!).
734
4f25ebb0
AD
7352002-06-20 Akim Demaille <akim@epita.fr>
736
737 * src/scan-gram.l: Complete the scanner with the missing patterns
738 to pacify Flex.
739 Use `quote' and `symbol_tag_get' where appropriate.
740
93b68a0e
AD
7412002-06-19 Akim Demaille <akim@epita.fr>
742
743 * tests/actions.at (Destructors): Augment to test locations.
744 * data/bison.simple (yydestructor): Pass it the current location
745 if locations are enabled.
746 Prototype only when __STDC__ or C++.
747 Change the argument names to move into the yy name space: there is
748 user code here.
749
58612f1d
AD
7502002-06-19 Akim Demaille <akim@epita.fr>
751
74310291
AD
752 * data/bison.simple (b4_pure_if): New.
753 Use it instead of #ifdef YYPURE.
754
7552002-06-19 Akim Demaille <akim@epita.fr>
756
757 * data/bison.simple (b4_location_if): New.
58612f1d
AD
758 Use it instead of #ifdef YYLSP_NEEDED.
759
f25bfb75
AD
7602002-06-19 Akim Demaille <akim@epita.fr>
761
762 Prepare @$ in %destructor, but currently don't bind it in the
763 skeleton, as %location use is not cleaned up yet.
764
765 * src/scan-gram.l (handle_dollar, handle_destructor_at)
766 (handle_action_at): New.
767 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
768 a braced_code_t and a location as additional arguments.
769 (handle_destructor_dollar): Instead of requiring `b4_eval', just
770 unquote one when outputting `b4_dollar_dollar'.
771 Adjust callers.
772 * data/bison.simple (b4_eval): Remove.
773 (b4_symbol_destructor): Adjust.
774 * tests/input.at (Invalid @n): Adjust.
775
c732d2c6
AD
7762002-06-19 Zack Weinberg <zack@codesourcery.com>
777
778 * doc/bison.texinfo: Document ability to have multiple
779 prologue sections.
780
8c165d89
AD
7812002-06-18 Akim Demaille <akim@epita.fr>
782
783 * src/files.c (compute_base_names): When computing the output file
784 names from the input file name, strip the directory part.
785
ca98bf57
AD
7862002-06-18 Akim Demaille <akim@epita.fr>
787
788 * data/bison.simple.new: Comment changes.
789 Reported by Andreas Schwab.
790
0bfb02ff
AD
7912002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
792
793 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
794 there are no `label `yyoverflowlab' defined but not used' warnings
795 when yyoverflow is defined.
796
24c0aad7
AD
7972002-06-18 Akim Demaille <akim@epita.fr>
798
799 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
800 new member.
801 (symbol_destructor_set): Adjust.
802 * src/output.c (symbol_destructors_output): Output the destructor
803 locations.
804 Output the symbol name.
805 * data/bison.simple (b4_symbol_destructor): Adjust.
806
5719c109
AD
8072002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
808 and Akim Demaille <akim@epita.fr>
809
810 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
811 what's left on the stack when the error recovery hits EOF.
812 * tests/actions.at (Destructors): Complete to exercise this case.
813
9280d3ef
AD
8142002-06-17 Akim Demaille <akim@epita.fr>
815
816 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
817 arguments is really empty, not only equal to `[]'.
818 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
819 member.
820 (symbol_destructor_set): New.
821 * src/output.c (symbol_destructors_output): New.
822 * src/reader.h (brace_code_t, current_braced_code): New.
823 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
824 (handle_dollar): Rename as...
825 (handle_action_dollar): this.
826 (handle_destructor_dollar): New.
827 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
828 (grammar_declaration): Use it.
829 * data/bison.simple (yystos): Is always defined.
830 (yydestructor): New.
831 * tests/actions.at (Destructors): New.
832 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
833
dafdc66f
AD
8342002-06-17 Akim Demaille <akim@epita.fr>
835
836 * src/symlist.h, src/symlist.c (symbol_list_length): New.
837 * src/scan-gram.l (handle_dollar, handle_at): Compute the
838 rule_length only when needed.
839 * src/output.c (actions_output, token_definitions_output): Output
840 the full M4 block.
841 * src/symtab.c: Don't access directly to the symbol tag, use
842 symbol_tag_get.
843 * src/parse-gram.y: Use symbol_list_free.
844
56c47203
AD
8452002-06-17 Akim Demaille <akim@epita.fr>
846
847 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
848 (symbol_list_prepend, get_type_name): Move to...
849 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
850 (symbol_list_prepend, symbol_list_n_type_name_get): here.
851 Adjust all callers.
852 (symbol_list_free): New.
853 * src/scan-gram.l (handle_dollar): Takes a location.
854 * tests/input.at (Invalid $n): Adjust.
855
1e0bab92
AD
8562002-06-17 Akim Demaille <akim@epita.fr>
857
858 * src/reader.h, src/reader.c (symbol_list_new): Export it.
859 (symbol_list_prepend): New.
860 * src/parse-gram.y (%union): `list' is a new member.
861 (symbols.1): New, replaces...
862 (terms_to_prec.1, nterms_to_type.1): these.
863 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
864 Take a location as additional argument.
865 Adjust all callers.
866
04e60654
AD
8672002-06-15 Akim Demaille <akim@epita.fr>
868
869 * src/parse-gram.y: Move %token in the declaration section so that
870 we don't depend upon CVS Bison.
871
10e5b8bd
AD
8722002-06-15 Akim Demaille <akim@epita.fr>
873
874 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
875 * src/print.c (print_core): Use it.
876
9801d40c
AD
8772002-06-15 Akim Demaille <akim@epita.fr>
878
879 * src/conflicts.c (log_resolution): Accept the rule involved in
880 the sr conflicts instead of the lookahead number that points to
881 that rule.
882 (flush_reduce): Accept the current lookahead vector as argument,
883 instead of the index in LA.
884 (resolve_sr_conflict): Accept the current number of lookahead
885 bitset to consider for the STATE, instead of the index in LA.
886 (set_conflicts): Adjust.
887 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
888
c0263492
AD
8892002-06-15 Akim Demaille <akim@epita.fr>
890
891 * src/state.h (state_t): Replace the `lookaheadsp' member, a
892 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
893 Adjust all dependencies.
894 * src/lalr.c (initialize_lookaheads): Split into...
895 (states_lookaheads_count, states_lookaheads_initialize): these.
896 (lalr): Adjust.
897
9757c359
AD
8982002-06-15 Akim Demaille <akim@epita.fr>
899
900 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
901 out of...
902 (grammar_rules_print): here.
903 * src/reduce.c (reduce_output): Use it.
904 * tests/reduce.at (Useless Rules, Reduced Automaton)
905 (Underivable Rules): Adjust.
906
6b98e4b5
AD
9072002-06-15 Akim Demaille <akim@epita.fr>
908
909 Copy BYacc's nice way to report the grammar.
910
911 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
912 New.
913 Don't print the rules' location, it is confusing and useless.
914 (rule_print): Use grammar_rhs_print.
915 * src/print.c (print_grammar): Use grammar_rules_print.
916
6b98e4b5
AD
9172002-06-15 Akim Demaille <akim@epita.fr>
918
919 Complete and rationalize `useless thing' warnings.
920
921 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
922 (symbol_tag_print): New.
923 Use them everywhere in place of accessing directly the tag member.
924 * src/gram.h, src/gram.c (rule_print): New.
925 Use it where a rule used to be printed `by hand'.
926 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
927 (reduce_grammar_tables): Report the useless rules.
928 (reduce_print): Useless things are a warning, not an error.
929 Report it as such.
930 * tests/reduce.at (Useless Nonterminals, Useless Rules):
931 (Reduced Automaton, Underivable Rules): Adjust.
932 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
933 * tests/conflicts.at (Unresolved SR Conflicts)
934 (Solved SR Conflicts): Adjust.
935
ee000ba4
AD
9362002-06-15 Akim Demaille <akim@epita.fr>
937
938 Let symbols have a location.
939
940 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
941 (getsym): Adjust.
942 Adjust all callers.
943 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
944 Use location_t, not int.
945 * src/symtab.c (symbol_check_defined): Take advantage of the
946 location.
947 * tests/regression.at (Invalid inputs): Adjust.
948
8efe435c
AD
9492002-06-15 Akim Demaille <akim@epita.fr>
950
951 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
952 (input): Don't try to initialize yylloc here, do it in the
953 scanner.
954 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
955 * src/gram.h (rule_t): Change line and action_line into location
956 and action_location, of location_t type.
957 Adjust all dependencies.
958 * src/location.h, src/location.c (empty_location): New.
959 * src/reader.h, src/reader.c (grammar_start_symbol_set)
960 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
961 (grammar_current_rule_symbol_append)
962 (grammar_current_rule_action_append): Expect a location as argument.
963 * src/reader.c (grammar_midrule_action): Adjust to attach an
964 action's location as dummy symbol location.
965 * src/symtab.h, src/symtab.c (startsymbol_location): New.
966 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
967 the line numbers.
968
1921f1d7
AD
9692002-06-14 Akim Demaille <akim@epita.fr>
970
971 Grammar declarations may be found in the grammar section.
972
973 * src/parse-gram.y (rules_or_grammar_declaration): New.
974 (declarations): Each declaration may end with a semicolon, not
975 just...
976 (grammar_declaration): `"%union"'.
977 (grammar): Branch to rules_or_grammar_declaration.
978
4515534c
AD
9792002-06-14 Akim Demaille <akim@epita.fr>
980
981 * src/main.c (main): Invoke scanner_free.
982
f958596b
AD
9832002-06-14 Akim Demaille <akim@epita.fr>
984
985 * src/output.c (m4_invoke): Extracted from...
986 (output_skeleton): here.
987 Free tempfile.
988
2c569025
AD
9892002-06-14 Akim Demaille <akim@epita.fr>
990
991 * src/parse-gram.y (directives, directive, gram)
992 (grammar_directives, precedence_directives, precedence_directive):
993 Rename as...
994 (declarations, declaration, grammar, grammar_declaration)
995 (precedence_declaration, precedence_declarator): these.
996 (symbol_declaration): New.
997
592e8d4d
AD
9982002-06-14 Akim Demaille <akim@epita.fr>
999
1000 * src/files.c (action_obstack): Remove, unused.
1001 (output_obstack): Remove it, and all its dependencies, as it is no
1002 longer needed.
1003 * src/reader.c (epilogue_set): Build the epilogue in the
1004 muscle_obstack.
1005 * src/output.h, src/output.c (muscle_obstack): Move to...
1006 * src/muscle_tab.h, src/muscle_tab.h: here.
1007 (muscle_init): Initialize muscle_obstack.
1008 (muscle_free): New.
1009 * src/main.c (main): Call it.
1010
0c15323d
AD
10112002-06-14 Akim Demaille <akim@epita.fr>
1012
1013 * src/location.h: New, extracted from...
1014 * src/reader.h: here.
1015 * src/Makefile.am (noinst_HEADERS): Merge into
1016 (bison_SOURCES): this.
1017 Add location.h.
1018 * src/parse-gram.y: Use location_t instead of Bison's.
1019 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
1020 Use location_t instead of ints.
1021
e96c9728
AD
10222002-06-14 Akim Demaille <akim@epita.fr>
1023
1024 * data/bison.simple, data/bison.c++: Be sure to restore the
1025 current #line when returning to the skeleton contents after having
1026 exposed the input file's #line.
1027
75d1fe16
AD
10282002-06-12 Akim Demaille <akim@epita.fr>
1029
1030 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
1031 eager.
1032 * tests/actions.at (Exotic Dollars): New.
1033
6c35d22c
AD
10342002-06-12 Akim Demaille <akim@epita.fr>
1035
1036 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
1037 ['"/] too eagerly.
1038 * tests/input.at (Torturing the Scanner): New.
1039
1d6412ad
AD
10402002-06-11 Akim Demaille <akim@epita.fr>
1041
1042 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
1043 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
1044 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
1045 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
1046 * src/reader.c (reader): Use it.
1047
4cdb01db
AD
10482002-06-11 Akim Demaille <akim@epita.fr>
1049
1050 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
1051 Adjust all callers.
1052 (scanner_last_string_free): New.
1053
44995b2e
AD
10542002-06-11 Akim Demaille <akim@epita.fr>
1055
1056 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
1057 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
1058 (last_string, YY_OBS_FREE): New.
1059 Use them when returning an ID.
1060
e9955c83
AD
10612002-06-11 Akim Demaille <akim@epita.fr>
1062
1063 Have Bison grammars parsed by a Bison grammar.
1064
1065 * src/reader.c, src/reader.h (prologue_augment): New.
1066 * src/reader.c (copy_definition): Remove.
1067
1068 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
1069 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
1070 (grammar_current_rule_prec_set, grammar_current_rule_check)
1071 (grammar_current_rule_symbol_append)
1072 (grammar_current_rule_action_append): Export.
1073 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
1074 (symbol_list_action_append): Remove.
1075 Hook the routines from reader.
1076 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
1077 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
1078
1079 * src/reader.c (read_declarations): Remove, unused.
1080
1081 * src/parse-gram.y: Handle the epilogue.
1082 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
1083 (grammar_start_symbol_set): this.
1084 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
1085 * src/reader.c (readgram): Remove, unused.
1086 (reader): Adjust to insert eoftoken and axiom where appropriate.
1087
1088 * src/reader.c (copy_dollar): Replace with...
1089 * src/scan-gram.h (handle_dollar): this.
1090 * src/parse-gram.y: Remove `%thong'.
1091
1092 * src/reader.c (copy_at): Replace with...
1093 * src/scan-gram.h (handle_at): this.
1094
1095 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
1096 New.
1097
1098 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
1099 time being.
1100
1101 * src/reader.h, src/reader.c (grammar_rule_end): New.
1102
1103 * src/parse.y (current_type, current_class): New.
1104 Implement `%nterm', `%token' support.
1105 Merge `%term' into `%token'.
1106 (string_as_id): New.
1107 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
1108 type name.
1109
1110 * src/parse-gram.y: Be sure to handle properly the beginning of
1111 rules.
1112
1113 * src/parse-gram.y: Handle %type.
1114 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
1115
1116 * src/parse-gram.y: More directives support.
1117 * src/options.c: No longer handle source directives.
1118
1119 * src/parse-gram.y: Fix %output.
1120
1121 * src/parse-gram.y: Handle %union.
1122 Use the prologue locations.
1123 * src/reader.c (parse_union_decl): Remove.
1124
1125 * src/reader.h, src/reader.c (epilogue_set): New.
1126 * src/parse-gram.y: Use it.
1127
1128 * data/bison.simple, data/bison.c++: b4_stype is now either not
1129 defined, then default to int, or to the contents of %union,
1130 without `union' itself.
1131 Adjust.
1132 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
1133
1134 * src/output.c (actions_output): Don't output braces, as they are
1135 already handled by the scanner.
1136
1137 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
1138 characters to themselves.
1139
1140 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
1141 that the epilogue has a proper #line.
1142
1143 * src/parse-gram.y: Handle precedence/associativity.
1144
1145 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
1146 a terminal.
1147 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
1148 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
1149 at all to define terminals that cannot be emitted.
1150
1151 * src/scan-gram.l: Escape M4 characters.
1152
1153 * src/scan-gram.l: Working properly with escapes in user
1154 strings/characters.
1155
1156 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
1157 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
1158 grammar.
1159 Use more modest sizes, as for the time being the parser does not
1160 release memory, and therefore the process swallows a huge amount
1161 of memory.
1162
1163 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
1164 stricter %token grammar.
1165
1166 * src/symtab.h (associativity): Add `undef_assoc'.
1167 (symbol_precedence_set): Do nothing when passed an undef_assoc.
1168 * src/symtab.c (symbol_check_alias_consistence): Adjust.
1169
1170 * tests/regression.at (Invalid %directive): Remove, as it is now
1171 meaningless.
1172 (Invalid inputs): Adjust to the new error messages.
1173 (Token definitions): The new grammar doesn't allow too many
1174 eccentricities.
1175
1176 * src/lex.h, src/lex.c: Remove.
1177 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1178 (copy_character, copy_string2, copy_string, copy_identifier)
1179 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1180 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1181 (parse_action): Remove.
1182 * po/POTFILES.in: Adjust.
1183
2e047461
AD
11842002-06-11 Akim Demaille <akim@epita.fr>
1185
1186 * src/reader.c (parse_action): Don't store directly into the
1187 rule's action member: return the action as a string.
1188 Don't require `rule_length' as an argument: compute it.
1189 (grammar_current_rule_symbol_append)
1190 (grammar_current_rule_action_append): New, eved out from
1191 (readgram): here.
1192 Remove `action_flag', `rulelength', unused now.
1193
9af3fbce
AD
11942002-06-11 Akim Demaille <akim@epita.fr>
1195
1196 * src/reader.c (grammar_current_rule_prec_set).
1197 (grammar_current_rule_check): New, eved out from...
1198 (readgram): here.
1199 Remove `xaction', `first_rhs': useless.
1200 * tests/input.at (Type clashes): New.
1201 * tests/existing.at (GNU Cim Grammar): Adjust.
1202
1485e106
AD
12032002-06-11 Akim Demaille <akim@epita.fr>
1204
1205 * src/reader.c (grammar_midrule_action): New, Eved out from
1206 (readgram): here.
1207
da4160c3
AD
12082002-06-11 Akim Demaille <akim@epita.fr>
1209
1210 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1211 New.
1212 (readgram): Use them as replacement of inlined code, crule and
1213 crule1.
1214
f6d0f937
AD
12152002-06-11 Akim Demaille <akim@epita.fr>
1216
1217 * src/reader.c (grammar_end, grammar_symbol_append): New.
1218 (readgram): Use them.
1219 Make the use of `p' as local as possible.
1220
69078d4b
AD
12212002-06-10 Akim Demaille <akim@epita.fr>
1222
1223 GCJ's parser requires the tokens to be defined before the prologue.
1224
1225 * data/bison.simple: Output the token definition before the user's
1226 prologue.
1227 * tests/regression.at (Braces parsing, Duplicate string)
1228 (Mixing %token styles): Check the output from bison.
1229 (Early token definitions): New.
1230
5e424082
AD
12312002-06-10 Akim Demaille <akim@epita.fr>
1232
1233 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1234 assigning twice the same user number to a token, so that we can
1235 use it in...
1236 * src/lex.c (lex): here.
1237 Also use `symbol_class_set' instead of hand written code.
1238 * src/reader.c (parse_assoc_decl): Likewise.
1239
44536b35
AD
12402002-06-10 Akim Demaille <akim@epita.fr>
1241
1242 * src/symtab.c, src/symtab.c (symbol_class_set)
1243 (symbol_user_token_number_set): New.
1244 * src/reader.c (parse_token_decl): Use them.
1245 Use a switch instead of ifs.
1246 Use a single argument.
1247
8b9f2372
AD
12482002-06-10 Akim Demaille <akim@epita.fr>
1249
1250 Remove `%thong' support as it is undocumented, unused, duplicates
1251 `%token's job, and creates useless e-mail traffic with people who
1252 want to know what it is, why it is undocumented, unused, and
1253 duplicates `%token's job.
1254
1255 * src/reader.c (parse_thong_decl): Remove.
1256 * src/options.c (option_table): Remove "thong".
1257 * src/lex.h (tok_thong): Remove.
1258
3ae2b51f
AD
12592002-06-10 Akim Demaille <akim@epita.fr>
1260
1261 * src/symtab.c, src/symtab.c (symbol_type_set)
1262 (symbol_precedence_set): New.
1263 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1264 (value_components_used): Remove, unused.
1265
2f1afb73
AD
12662002-06-09 Akim Demaille <akim@epita.fr>
1267
1268 Move symbols handling code out of the reader.
1269
1270 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1271 (axiom): Move to...
1272 * src/symtab.h, src/symtab.c: here.
1273
1274 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1275 * src/reader.c (startval): Rename as...
1276 * src/symtab.h, src/symtab.c (startsymbol): this.
1277 * src/reader.c: Adjust.
1278
1279 * src/reader.c (symbol_check_defined, symbol_make_alias)
1280 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1281 (token_translations_init)
1282 Move to...
1283 * src/symtab.c: here.
1284 * src/reader.c (packsymbols): Move to...
1285 * src/symtab.h, src/symtab.c (symbols_pack): here.
1286 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1287 argument.
1288
e9bca3ad
AD
12892002-06-03 Akim Demaille <akim@epita.fr>
1290
1291 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1292 then statements.
1293
86eff183
AD
12942002-06-03 Akim Demaille <akim@epita.fr>
1295
1296 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1297 structs with non literals.
1298 * src/scan-skel.l: never-interactive.
1299 * src/conflicts.c (enum conflict_resolution_e): No trailing
1300 comma.
1301 * src/getargs.c (usage): Split long literal strings.
1302 Reported by Hans Aberg.
1303
717be197
AD
13042002-05-28 Akim Demaille <akim@epita.fr>
1305
1306 * data/bison.c++: Use C++ ostreams.
1307 (cdebug_): New member.
1308
670ddffd
AD
13092002-05-28 Akim Demaille <akim@epita.fr>
1310
1311 * src/output.c (output_skeleton): Be sure to allocate enough room
1312 for `/' _and_ for `\0' in full_skeleton.
1313
769b430f
AD
13142002-05-28 Akim Demaille <akim@epita.fr>
1315
1316 * data/bison.c++: Catch up with bison.simple:
1317 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1318 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1319 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1320 and popping traces.
1321
7067cb36
PH
13222002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1323
1324 * src/output.c (output_skeleton): Put an explicit path in front of
1325 the skeleton file name, rather than relying on the -I directory,
1326 to partially alleviate effects of having a skeleton file lying around
1327 in the current directory.
769b430f 1328
4a713ec2
PH
13292002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1330
769b430f 1331 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
1332 obstack_printf should be obstack_fgrow1.
1333
b408954b
AD
13342002-05-26 Akim Demaille <akim@epita.fr>
1335
1336 * src/state.h (state_t): `solved_conflicts' is a new member.
1337 * src/LR0.c (new_state): Set it to 0.
1338 * src/conflicts.h, src/conflicts.c (print_conflicts)
1339 (free_conflicts, solve_conflicts): Rename as...
1340 (conflicts_print, conflicts_free, conflicts_solve): these.
1341 Adjust callers.
1342 * src/conflicts.c (enum conflict_resolution_e)
1343 (solved_conflicts_obstack): New, used by...
1344 (log_resolution): this.
1345 Adjust to attach the conflict resolution to each state.
1346 Complete the description with the precedence/associativity
1347 information.
1348 (resolve_sr_conflict): Adjust.
1349 * src/print.c (print_state): Output its solved_conflicts.
1350 * tests/conflicts.at (Unresolved SR Conflicts)
1351 (Solved SR Conflicts): Exercise --report=all.
1352
a49aecd5
AD
13532002-05-26 Akim Demaille <akim@epita.fr>
1354
1355 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1356 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1357 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1358 (token_number_t, item_number_as_token_number)
1359 (token_number_as_item_number, muscle_insert_token_number_table):
1360 Rename as...
1361 (symbol_number_t, item_number_as_symbol_number)
1362 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1363 these, since it is more appropriate.
1364
5504898e
AD
13652002-05-26 Akim Demaille <akim@epita.fr>
1366
1367 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1368 `Error:' lines.
1369 * data/bison.simple (yystos) [YYDEBUG]: New.
1370 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1371 error recovery.
1372 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1373
ec3bc396
AD
13742002-05-25 Akim Demaille <akim@epita.fr>
1375
1376 * doc/bison.texinfo (Debugging): Split into...
1377 (Tracing): this new section, its former contents, and...
1378 (Understanding): this new section.
1379 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1380 by...
1381 (report_flag): this.
1382 Adjust all dependencies.
1383 (report_args, report_types, report_argmatch): New.
1384 (usage, getargs): Report/support -r, --report.
1385 * src/options.h
1386 (struct option_table_struct): Rename as..,
1387 (struct option_table_s): this.
1388 Rename the `set_flag' member to `flag' to match with getopt_long's
1389 struct.
1390 * src/options.c (option_table): Split verbose into an entry for
1391 %verbose, and another for --verbose.
1392 Support --report/-r, so remove -r from the obsolete --raw.
1393 * src/print.c: Attach full item sets and lookaheads reports to
1394 report_flag instead of trace_flag.
1395 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1396
78df8250
PE
13972002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1398 and Paul Eggert <eggert@twinsun.com>
769b430f 1399
78df8250
PE
1400 * data/bison.simple (yyparse): Correct error handling to conform to
1401 POSIX and yacc. Specifically, after syntax error is discovered,
1402 do not reduce further before shifting the error token.
1403 Clean up the code a bit by removing the labels yyerrdefault,
1404 yyerrhandle, yyerrpop.
1405 * NEWS: Document the above.
1406
c0c9ea05
PH
14072002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1408
1409 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1410 type; it isn't always big enough, since it doesn't necessarily
1411 include non-terminals.
769b430f 1412 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
1413 the latter can be removed.
1414 (yy_token_number_type): Remove, only one use.
1415 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1416 don't use TokenNumberType as element type.
769b430f 1417
c0c9ea05
PH
1418 * tests/regression.at: Modify expected output to agree with change
1419 to yyr1 and yytranslate.
769b430f 1420
6390a83f
FK
14212002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1422
1423 * src/reader.c (parse_action): Use copy_character instead of
1424 obstack_1grow.
1425
db7c8e9a
AD
14262002-05-13 Akim Demaille <akim@epita.fr>
1427
1428 * tests/regression.at (Token definitions): Prototype yylex and
1429 yyerror.
1430
fcc61800
PH
14312002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1432
158c687b 1433 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
1434 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1435 32-bit arithmetic.
1436 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1437
5683e9b2
AD
14382002-05-07 Akim Demaille <akim@epita.fr>
1439
1440 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1441 avoid GCC warnings.
1442
0c2d3f4c
AD
14432002-05-07 Akim Demaille <akim@epita.fr>
1444
1445 Kill GCC warnings.
1446
1447 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1448 over the RHS of each rule.
1449 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1450 * src/state.h (state_t): Member `nitems' is unsigned short.
1451 * src/LR0.c (get_state): Adjust.
1452 * src/reader.c (packgram): Likewise.
1453 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1454 `Type'.
1455 (muscle_insert_int_table): Remove, unused.
1456 (prepare_rules): Remove `max'.
1457
1565b720
AD
14582002-05-06 Akim Demaille <akim@epita.fr>
1459
1460 * src/closure.c (print_firsts): Display of the symbol tags.
1461 (bitmatrix_print): Move to...
1462 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1463 here.
1464 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1465
cfaee611
AD
14662002-05-06 Akim Demaille <akim@epita.fr>
1467
1468 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1469 hash_do_for_each.
1470
458be8e0
AD
14712002-05-06 Akim Demaille <akim@epita.fr>
1472
1473 * src/LR0.c (new_state, get_state): Instead of using the global
1474 `kernel_size' and `kernel_base', have two new arguments:
1475 `core_size' and `core'.
1476 Adjust callers.
1477
a900a624
AD
14782002-05-06 Akim Demaille <akim@epita.fr>
1479
1480 * src/reader.c (packgram): No longer end `ritem' with a 0
1481 sentinel: it is not used.
1482
d4e7d3a1
AD
14832002-05-05 Akim Demaille <akim@epita.fr>
1484
1485 New experimental feature: display the lookaheads in the report and
1486 graph.
1487
1488 * src/print (print_core): When --trace-flag, display the rules
1489 lookaheads.
1490 * src/print_graph.c (print_core): Likewise.
1491 Swap the arguments.
1492 Adjust caller.
1493
39ceb25b
AD
14942002-05-05 Akim Demaille <akim@epita.fr>
1495
1496 * tests/torture.at (Many lookaheads): New test.
1497
5372019f
AD
14982002-05-05 Akim Demaille <akim@epita.fr>
1499
1500 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
1501 (GENERATE_MUSCLE_INSERT_TABLE): this.
1502 (output_int_table, output_unsigned_int_table, output_short_table)
1503 (output_token_number_table, output_item_number_table): Replace with...
1504 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
1505 (muscle_insert_short_table, muscle_insert_token_number_table)
1506 (muscle_insert_item_number_table): these.
1507 Adjust all callers.
1508 (prepare_tokens): Don't free `translations', since...
1509 * src/reader.h, src/reader.c (grammar_free): do it.
1510 Move to...
1511 * src/gram.h, src/gram.c (grammar_free): here.
1512 * data/bison.simple, data/bison.c++: b4_token_number_max is now
1513 b4_translate_max.
1514
5df5f6d5
AD
15152002-05-05 Akim Demaille <akim@epita.fr>
1516
1517 * src/output.c (output_unsigned_int_table): New.
1518 (prepare_rules): `i' is unsigned.
1519 `prhs', `rline', `r2' are unsigned int.
1520 Rename muscle `rhs_number_max' as `rhs_max'.
1521 Output muscles `prhs_max', `rline_max', and `r2_max'.
1522 Free rline and r1.
1523 * data/bison.simple, data/bison.c++: Adjust to use these muscles
1524 to compute types instead of constant types.
1525 * tests/regression.at (Web2c Actions): Adjust.
1526
b87f8b21
AD
15272002-05-04 Akim Demaille <akim@epita.fr>
1528
1529 * src/symtab.h (SALIAS, SUNDEF): Rename as...
1530 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
1531 Adjust dependencies.
1532 * src/output.c (token_definitions_output): Be sure not to output a
1533 `#define 'a'' when fed with `%token 'a' "a"'.
1534 * tests/regression.at (Token definitions): New.
1535
8bb936e4
PE
15362002-05-03 Paul Eggert <eggert@twinsun.com>
1537
1538 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
1539 for K&R C.
1540
15412002-05-03 gettextize <bug-gnu-gettext@gnu.org>
1542
1543 * Makefile.am (SUBDIRS): Remove intl.
1544 (EXTRA_DIST): Add config/config.rpath.
1545
53c71a12
AD
15462002-05-03 Akim Demaille <akim@epita.fr>
1547
1548 * data/bison.simple (m4_if): Don't output empty enums.
1549 And actually, output valid enum definitions :(.
1550
289dd0cf
AD
15512002-05-03 Akim Demaille <akim@epita.fr>
1552
1553 * configure.bat: Remove, completely obsolete.
1554 * Makefile.am (EXTRA_DIST): Adjust.
1555 Don't distribute config.rpath...
1556 * config/Makefile.am (EXTRA_DIST): Do it.
1557
db85e524
AD
15582002-05-03 Akim Demaille <akim@epita.fr>
1559
1560 * configure.in (GETTEXT_VERSION): New.
1561 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
1562
83ccf991
AD
15632002-05-03 Akim Demaille <akim@epita.fr>
1564
1565 * data/bison.simple (b4_token_enum): New.
1566 (b4_token_defines): Use it to output tokens both as #define and
1567 enums.
1568 Suggested by Paul Eggert.
1569 * src/output.c (token_definitions_output): Don't output spurious
1570 white spaces.
1571
1f418995
AD
15722002-05-03 Akim Demaille <akim@epita.fr>
1573
1574 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1575
45119f04
RA
15762002-05-02 Robert Anisko <robert@lrde.epita.fr>
1577
1578 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
1579 Update the stack class, give a try to deque as the default container.
1580
b2d52318
AD
15812002-05-02 Akim Demaille <akim@epita.fr>
1582
1583 * data/bison.simple (yyparse): Do not implement @$ = @1.
1584 (YYLLOC_DEFAULT): Adjust to do it.
1585 * doc/bison.texinfo (Location Default Action): Fix.
1586
3a8b4109
AD
15872002-05-02 Akim Demaille <akim@epita.fr>
1588
1589 * src/reader.c (parse_braces): Merge into...
1590 (parse_action): this.
1591
84614e13
AD
15922002-05-02 Akim Demaille <akim@epita.fr>
1593
1594 * configure.in (ALL_LINGUAS): Remove.
1595 * po/LINGUAS, hr.po: New.
1596
fdbcd8e2
AD
15972002-05-02 Akim Demaille <akim@epita.fr>
1598
1599 Remove the so called hairy (semantic) parsers.
1600
1601 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
1602 * src/gram.h, src/gram.c (semantic_parser): Remove.
1603 (rule_t): Remove the guard and guard_line members.
1604 * src/lex.h (token_t): remove tok_guard.
1605 * src/options.c (option_table): Remove %guard and %semantic_parser
1606 support.
1607 * src/output.c, src/output.h (guards_output): Remove.
1608 (prepare): Adjust.
1609 (token_definitions_output): Don't output the `T'
1610 tokens (???).
1611 (output_skeleton): Don't output the guards.
1612 * src/files.c, src/files.c (attrsfile): Remove.
1613 * src/reader.c (symbol_list): Remove the guard and guard_line
1614 members.
1615 Adjust dependencies.
1616 (parse_guard): Remove.
1617 * data/bison.hairy: Remove.
1618 * doc/bison.texinfo (Environment Variables): Remove occurrences of
1619 BISON_HAIRY.
1620
82b6cb3f
AD
16212002-05-02 Akim Demaille <akim@epita.fr>
1622
1623 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
1624 (parse_guard): Rename the formal argument `stack_offset' as
1625 `rule_length', which is more readable.
1626 Adjust callers.
1627 (copy_at, copy_dollar): Instead of outputting the hard coded
1628 values of $$, $n and so forth, output invocation to b4_lhs_value,
1629 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
1630 Note: this patch partially drops `semantic-parser' support: it
1631 always does `rule_length - n', where semantic parsers ought to
1632 always use `-n'.
82b6cb3f
AD
1633 * data/bison.simple, data/bison.c++ (b4_lhs_value)
1634 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
1635
6cbfbcc5
AD
16362002-05-02 Akim Demaille <akim@epita.fr>
1637
1638 * configure.in (AC_INIT): Bump to 1.49b.
1639 (AM_INIT_AUTOMAKE): Short invocation.
1640
b8548114
AD
16412002-05-02 Akim Demaille <akim@epita.fr>
1642
1643 Version 1.49a.
1644
c20cd1fa
AD
16452002-05-01 Akim Demaille <akim@epita.fr>
1646
1647 * src/skeleton.h: Remove.
1648
8a9566d4
AD
16492002-05-01 Akim Demaille <akim@epita.fr>
1650
1651 * src/skeleton.h: Fix the #endif.
1652 Reported by Magnus Fromreide.
1653
8c6d399a
PE
16542002-04-26 Paul Eggert <eggert@twinsun.com>
1655
1656 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
1657 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 1658 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 1659
2b7ed18a
RA
16602002-04-25 Robert Anisko <robert@lrde.epita.fr>
1661
1662 * src/scan-skel.l: Postprocess quadrigraphs.
1663
1664 * src/reader.c (copy_character): New function, used to output
1665 single characters while replacing `[' and `]' with quadrigraphs, to
1666 avoid troubles with M4 quotes.
1667 (copy_comment): Output characters with copy_character.
1668 (read_additionnal_code): Likewise.
1669 (copy_string2): Likewise.
1670 (copy_definition): Likewise.
1671
1672 * tests/calc.at: Exercise M4 quoting.
1673
34a89c50
AD
16742002-04-25 Akim Demaille <akim@epita.fr>
1675
1676 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
1677 between `!' and the command.
1678 Reported by Paul Eggert.
1679
0dd1580a
RA
16802002-04-24 Robert Anisko <robert@lrde.epita.fr>
1681
1682 * tests/calc.at: Exercise prologue splitting.
1683
1684 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
1685 `b4_post_prologue' instead of `b4_prologue'.
1686
1687 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
1688 muscles.
1689 (output): Free pre_prologue_obstack and post_prologue_obstack.
1690 * src/files.h, src/files.c (attrs_obstack): Remove.
1691 (pre_prologue_obstack, post_prologue_obstack): New.
1692 * src/reader.c (copy_definition): Add a parameter to specify the
1693 obstack to fill, instead of using attrs_obstack unconditionally.
1694 (read_declarations): Pass pre_prologue_obstack to copy_definition if
1695 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
1696
83c1796f
PE
16972002-04-23 Paul Eggert <eggert@twinsun.com>
1698
1699 * data/bison.simple: Remove unnecessary commentary and white
1700 space differences from 1_29-branch.
1701 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
1702
1703 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
1704 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
1705 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
1706 constructors or destructors.
1707
1708 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
1709
1207eeac
AD
17102002-04-23 Akim Demaille <akim@epita.fr>
1711
1712 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
1713 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
1714 location with columns.
1715 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
1716 All reported by Paul Eggert.
1717
78ab8f67
AD
17182002-04-22 Akim Demaille <akim@epita.fr>
1719
1720 * src/reduce.c (dump_grammar): Move to...
1721 * src/gram.h, src/gram.c (grammar_dump): here.
1722 Be sure to separate long item numbers.
1723 Don't read the members of a rule's prec if its nil.
1724
133c20e2
AD
17252002-04-22 Akim Demaille <akim@epita.fr>
1726
1727 * src/output.c (table_size, table_grow): New.
1728 (MAXTABLE): Remove, replace uses with table_size.
1729 (pack_vector): Instead of dying when the table is too big, grow it.
1730
9515e8a7
AD
17312002-04-22 Akim Demaille <akim@epita.fr>
1732
1733 * data/bison.simple (yyr1): Its type is that of a token number.
1734 * data/bison.c++ (r1_): Likewise.
1735 * tests/regression.at (Web2c Actions): Adjust.
1736
23c5a174
AD
17372002-04-22 Akim Demaille <akim@epita.fr>
1738
1739 * src/reader.c (token_translations_init): 256 is now the default
1740 value for the error token, i.e., it will be assigned another
1741 number if the user assigned 256 to one of her tokens.
1742 (reader): Don't force 256 to error.
1743 * doc/bison.texinfo (Symbols): Adjust.
1744 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
1745 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
1746 etc. instead of 10, 20, 30 (which was used to `jump' over error
1747 (256) and undefined (2)).
1748
5fbb0954
AD
17492002-04-22 Akim Demaille <akim@epita.fr>
1750
1751 Propagate more token_number_t.
1752
1753 * src/gram.h (token_number_as_item_number)
1754 (item_number_as_token_number): New.
1755 * src/output.c (GENERATE_OUTPUT_TABLE): New.
1756 Use it to create output_item_number_table and
1757 output_token_number_table.
1758 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1759 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
1760 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
1761 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
1762
4f940944
AD
17632002-04-22 Akim Demaille <akim@epita.fr>
1764
1765 * src/output.h, src/output.c (get_lines_number): Remove.
1766
3ded9a63
AD
17672002-04-19 Akim Demaille <akim@epita.fr>
1768
1769 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
1770 as Lex/Flex'.
1771 (Debugging): More details about enabling the debugging features.
1772 (Table of Symbols): Describe $$, $n, @$, and @n.
1773 Suggested by Tim Josling.
1774
e0c471a9
AD
17752002-04-19 Akim Demaille <akim@epita.fr>
1776
1777 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
1778
fecc10cd
AD
17792002-04-10 Akim Demaille <akim@epita.fr>
1780
1781 * src/system.h: Rely on HAVE_LIMITS_H.
1782 Suggested by Paul Eggert.
1783
51dec47b
AD
17842002-04-09 Akim Demaille <akim@epita.fr>
1785
1786 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
1787 full stderr, and strip it according to the bison options, instead
1788 of composing the error message from different bits.
1789 This makes it easier to check for several error messages.
1790 Adjust all the invocations.
1791 Add an invocation exercising the error token.
1792 Add an invocation demonstrating a stupid error message.
1793 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
1794 Adjust the tests.
1795 Error message are for stderr, not stdout.
1796
007a50a4
AD
17972002-04-09 Akim Demaille <akim@epita.fr>
1798
1799 * src/gram.h, src/gram.c (error_token_number): Remove, use
1800 errtoken->number.
1801 * src/reader.c (reader): Don't specify the user token number (2)
1802 for $undefined, as it uselessly prevents using it.
1803 * src/gram.h (token_number_t): Move to...
1804 * src/symtab.h: here.
1805 (state_t.number): Is a token_number_t.
1806 * src/print.c, src/reader.c: Use undeftoken->number instead of
1807 hard coded 2.
1808 (Even though this 2 is not the same as above: the number of the
1809 undeftoken remains being 2, it is its user token number which
1810 might not be 2).
1811 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
1812 `user_token_number_max'.
1813 Output `undef_token_number'.
1814 * data/bison.simple, data/bison.c++: Use them.
1815 Be sure to map invalid yylex return values to
1816 `undef_token_number'. This saves us from gratuitous SEGV.
1817
1818 * tests/conflicts.at (Solved SR Conflicts)
1819 (Unresolved SR Conflicts): Adjust.
1820 * tests/regression.at (Web2c Actions): Adjust.
1821
06446ccf
AD
18222002-04-08 Akim Demaille <akim@epita.fr>
1823
1824 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
1825 Adding #line.
1826 Remove the duplicate `typedefs'.
1827 (RhsNumberType): Fix the declaration and various other typos.
1828 Use __ofile__.
1829 * data/bison.simple: Use __ofile__.
1830 * src/scan-skel.l: Handle __ofile__.
1831
62a3e4f0
AD
18322002-04-08 Akim Demaille <akim@epita.fr>
1833
1834 * src/gram.h (item_number_t): New, the type of item numbers in
1835 RITEM. Note that it must be able to code symbol numbers as
1836 positive number, and the negation of rule numbers as negative
1837 numbers.
1838 Adjust all dependencies (pretty many).
1839 * src/reduce.c (rule): Remove this `short *' pointer: use
1840 item_number_t.
1841 * src/system.h (MINSHORT, MAXSHORT): Remove.
1842 Include `limits.h'.
1843 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
1844 (shortcpy): Remove.
1845 (MAXTABLE): Move to...
1846 * src/output.c (MAXTABLE): here.
1847 (prepare_rules): Use output_int_table to output rhs.
1848 * data/bison.simple, data/bison.c++: Adjust.
1849 * tests/torture.at (Big triangle): Move the limit from 254 to
1850 500.
1851 * tests/regression.at (Web2c Actions): Ajust.
1852
1853 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
1854 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
1855 passes, but produces negative #line number, once fixed, GCC is
1856 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
1857 C), it passes.
1858 * src/state.h (state_h): Code input lines on ints, not shorts.
1859
bb88b0fc
AD
18602002-04-08 Akim Demaille <akim@epita.fr>
1861
1862 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
1863 and then the grammar.
1864
9a636f47
AD
18652002-04-08 Akim Demaille <akim@epita.fr>
1866
1867 * src/system.h: No longer using strndup.
1868
680e8701
AD
18692002-04-07 Akim Demaille <akim@epita.fr>
1870
1871 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
1872 * src/output.c (output_table_data): Return the longest number.
1873 (prepare_tokens): Output `token_number_max').
1874 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
1875 New.
1876 Use them to define yy_token_number_type/TokenNumberType.
1877 Use this type for yytranslate.
1878 * tests/torture.at (Big triangle): Push the limit from 124 to
1879 253.
1880 * tests/regression.at (Web2c Actions): Adjust.
1881
817e9f41
AD
18822002-04-07 Akim Demaille <akim@epita.fr>
1883
1884 * tests/torture.at (Big triangle): New.
1885 (GNU AWK Grammar, GNU Cim Grammar): Move to...
1886 * tests/existing.at: here.
1887
5123689b
AD
18882002-04-07 Akim Demaille <akim@epita.fr>
1889
1890 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
1891 nritems.
1892 Adjust dependencies.
1893
f3849179
AD
18942002-04-07 Akim Demaille <akim@epita.fr>
1895
1896 * src/reader.c: Normalize increments to prefix form.
1897
bd02036a
AD
18982002-04-07 Akim Demaille <akim@epita.fr>
1899
1900 * src/reader.c, symtab.c: Remove debugging code.
1901
db8837cb
AD
19022002-04-07 Akim Demaille <akim@epita.fr>
1903
1904 Rename all the `bucket's as `symbol_t'.
1905
1906 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
1907 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
1908 * src/symtab.c, src/symtab.h (bucket): Rename as...
1909 (symbol_t): this.
1910 (symbol_list_new, bucket_check_defined, bucket_make_alias)
1911 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
1912 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1913 (buckets_new, buckets_free, buckets_do): Rename as...
1914 (symbol_list_new, symbol_check_defined, symbol_make_alias)
1915 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1916 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
1917 (symbols_new, symbols_free, symbols_do): these.
1918
72a23c97
AD
19192002-04-07 Akim Demaille <akim@epita.fr>
1920
1921 Use lib/hash for the symbol table.
1922
1923 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
1924 EOF.
1925 * src/lex.c (lex): Set the `number' member of new terminals.
1926 * src/reader.c (bucket_check_defined, bucket_make_alias)
1927 (bucket_check_alias_consistence, bucket_translation): New.
1928 (reader, grammar_free, readgram, token_translations_init)
1929 (packsymbols): Adjust.
1930 (reader): Number the predefined tokens.
1931 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
1932 for predefined tokens.
1933 * src/symtab.h (bucket): Remove all the hash table related
1934 members.
1935 * src/symtab.c (symtab): Replace by...
1936 (bucket_table): this.
1937 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1938 (buckets_new, buckets_do): New.
1939
280a38c3
AD
19402002-04-07 Akim Demaille <akim@epita.fr>
1941
1942 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
1943 (start_symbol, max_user_token_number, semantic_parser)
1944 (error_token_number): Initialize.
1945 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
1946 Initialize.
1947 (reader): Don't.
1948 (errtoken, eoftoken, undeftoken, axiom): Extern.
1949
03b31c0c
AD
19502002-04-07 Akim Demaille <akim@epita.fr>
1951
1952 * src/gram.h (rule_s): prec and precsym are now pointers
1953 to the bucket giving the priority/associativity.
1954 Member `associativity' removed: useless.
1955 * src/reduce.c, src/conflicts.c: Adjust.
1956
8b3df748
AD
19572002-04-07 Akim Demaille <akim@epita.fr>
1958
1959 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
1960 Properly escape the symbols' TAG when outputting them.
1961
e601aa1d
AD
19622002-04-07 Akim Demaille <akim@epita.fr>
1963
1964 * src/lalr.h (LA): Is a bitsetv, not bitset*.
1965
b0299a2e
AD
19662002-04-07 Akim Demaille <akim@epita.fr>
1967
1968 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
1969 (LArule): this, which is an array to rule_t*.
1970 * src/print.c, src/conflicts.c: Adjust.
1971
d7e1f00c
AD
19722002-04-07 Akim Demaille <akim@epita.fr>
1973
1974 * src/gram.h (rule_t): Rename `number' as `user_number'.
1975 `number' is a new member.
1976 Adjust dependencies.
1977 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
1978
cc9305dd
AD
19792002-04-07 Akim Demaille <akim@epita.fr>
1980
1981 As a result of the previous patch, it is no longer needed
1982 to reorder ritem itself.
1983
1984 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
1985
b0940840
AD
19862002-04-07 Akim Demaille <akim@epita.fr>
1987
1988 Be sure never to walk through RITEMS, but use only data related to
1989 the rules themselves. RITEMS should be banished.
1990
1991 * src/output.c (output_token_translations): Rename as...
1992 (prepare_tokens): this.
1993 In addition to `translate', prepare the muscles `tname' and
1994 `toknum', which were handled by...
1995 (output_rule_data): this.
1996 Remove, and move the remainder of its outputs into...
1997 (prepare_rules): this new routines, which also merges content from
1998 (output_gram): this.
1999 (prepare_rules): Be sure never to walk through RITEMS.
2000 (output_stos): Rename as...
2001 (prepare_stos): this.
2002 (output): Always invoke prepare_states, after all, just don't use it
2003 in the output if you don't need it.
2004
643a5994
AD
20052002-04-07 Akim Demaille <akim@epita.fr>
2006
2007 * src/LR0.c (new_state): Display `nstates' as the name of the
2008 newly created state.
2009 Adjust to initialize first_state and last_state if needed.
2010 Be sure to distinguish the initial from the final state.
2011 (new_states): Create the itemset of the initial state, and use
2012 new_state.
2013 * src/closure.c (closure): Now that the initial state has its
2014 items properly set, there is no need for a special case when
2015 creating `ruleset'.
2016
2017 As a result, now the rule 0, reducing to $axiom, is visible in the
2018 outputs. Adjust the test suite.
2019
2020 * tests/conflicts.at (Solved SR Conflicts)
2021 (Unresolved SR Conflicts): Adjust.
2022 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
2023 * tests/conflicts.at (S/R in initial): New.
2024
b4c4ccc2
AD
20252002-04-07 Akim Demaille <akim@epita.fr>
2026
2027 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
2028 the RHS of the rules.
2029 * src/output.c (output_gram): Likewise.
2030
bba97eb2
AD
20312002-04-07 Akim Demaille <akim@epita.fr>
2032
2033 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
2034 bucket.
2035 Adjust all dependencies.
2036 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
2037 `number' of the buckets too.
2038 * src/gram.h: Include `symtab.h'.
2039 (associativity): Move to...
2040 * src/symtab.h: here.
2041 No longer include `gram.h'.
2042
c3b407f4
AD
20432002-04-07 Akim Demaille <akim@epita.fr>
2044
2045 * src/gram.h, src/gram.c (rules_rhs_length): New.
2046 (ritem_longest_rhs): Use it.
2047 * src/gram.h (rule_t): `number' is a new member.
2048 * src/reader.c (packgram): Set it.
2049 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
2050 the end of `rules', and count them out of `nrules'.
2051 (reduce_output, dump_grammar): Adjust.
2052 * src/print.c (print_grammar): It is no longer needed to check for
2053 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
2054 * tests/reduce.at (Reduced Automaton): New test.
2055
11652ab3
AD
20562002-04-07 Akim Demaille <akim@epita.fr>
2057
2058 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
2059 lacking `+ 1' to nrules, Bison reported as useless a token if it
2060 was used solely to set the precedence of the last rule...
2061
26b23c1a
AD
20622002-04-07 Akim Demaille <akim@epita.fr>
2063
2064 * data/bison.c++, data/bison.simple: Don't output the current file
2065 name in #line, to avoid useless diffs between two identical
2066 outputs under different names.
2067
18bcecb0
AD
20682002-04-07 Akim Demaille <akim@epita.fr>
2069
2070 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
2071 Normalize loops to using `< nrules + 1', not `<= nrules'.
2072
fa770c86
AD
20732002-04-07 Akim Demaille <akim@epita.fr>
2074
2075 * TODO: Update.
2076
d9b739c3
AD
20772002-04-07 Akim Demaille <akim@epita.fr>
2078
2079 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
2080 bucket.value as bucket.number.
2081
99013900
AD
20822002-04-07 Akim Demaille <akim@epita.fr>
2083
2084 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
2085 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2086 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
2087 RHS, instead of being an index in RITEMS.
2088
e966383b
PE
20892002-04-04 Paul Eggert <eggert@twinsun.com>
2090
2091 * doc/bison.texinfo: Update copyright date.
2092 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
2093 (Symbols): Warn about running Bison in one character set,
2094 but compiling and/or running in an incompatible one.
2095 Warn about character code 256, too.
2096
20972002-04-03 Paul Eggert <eggert@twinsun.com>
2098
2099 * src/bison.data (YYSTACK_ALLOC): Depend on whether
2100 YYERROR_VERBOSE is nonzero, not whether it is defined.
2101
2102 Merge changes from bison-1_29-branch.
c307773e 2103
8d6c48b9
PE
21042002-03-20 Paul Eggert <eggert@twinsun.com>
2105
2106 Merge fixes from Debian bison_1.34-1.diff.
2107
2108 * configure.in (AC_PREREQ): 2.53.
2109
e53c6322
AD
21102002-03-20 Akim Demaille <akim@epita.fr>
2111
2112 * src/conflicts.c (log_resolution): Argument `resolution' is const.
2113
9ffbeca7
PE
21142002-03-19 Paul Eggert <eggert@twinsun.com>
2115
21db0b2a
PE
2116 * src/bison.simple (YYCOPY): New macro.
2117 (YYSTACK_RELOCATE): Use it.
2118 Remove Type arg; no longer needed. All callers changed.
2119 (yymemcpy): Remove; no longer needed.
2120
9ffbeca7
PE
2121 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
2122 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
2123
642cb8f8
AD
21242002-03-19 Akim Demaille <akim@epita.fr>
2125
2126 Test and fix the #line outputs.
2127
2128 * tests/atlocal.at (GCC): New.
2129 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
2130 (Prologue synch line, ,%union synch line, Postprologue synch line)
2131 (Action synch line, Epilogue synch line): New tests.
2132 * src/reader.c (parse_union_decl): Define the muscle stype_line.
2133 * data/bison.simple, data/bison.c++: Use it.
2134
3c31a486
AD
21352002-03-19 Akim Demaille <akim@epita.fr>
2136
2137 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
2138 (Solved SR Conflicts, %expect not enough, %expect right)
2139 (%expect too much): Move to...
2140 * tests/conflicts.at: this new file.
2141
0d8bed56
AD
21422002-03-19 Akim Demaille <akim@epita.fr>
2143
2144 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2145 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
2146 that we can move to enums for instance.
2147 * src/output.c (token_definitions_output): Output a list of
2148 `token-name, token-number' instead of the #define.
2149 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
2150
9208d17f
AD
21512002-03-14 Akim Demaille <akim@epita.fr>
2152
2153 Use Gettext 0.11.1.
2154
af27eacb
RA
21552002-03-09 Robert Anisko <robert@lrde.epita.fr>
2156
2157 * data/bison.c++: Make the user able to add members to the generated
2158 parser by subclassing.
2159
9101a310
RA
21602002-03-05 Robert Anisko <robert@lrde.epita.fr>
2161
2162 * src/reader.c (read_additionnal_code): `c' should be an integer, not
2163 a character.
2164 Reported by Nicolas Tisserand and Nicolas Burrus.
2165
fff9bf0b
RA
21662002-03-04 Robert Anisko <robert@lrde.epita.fr>
2167
2168 * src/reader.c: Warn about lacking semi-colons, do not complain.
2169
64dba31e
RA
21702002-03-04 Robert Anisko <robert@lrde.epita.fr>
2171
2172 * data/bison.c++: Remove a debug line.
2173
374f5a14
RA
21742002-03-04 Robert Anisko <robert@lrde.epita.fr>
2175
2176 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2177 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2178 provide a default implementation.
2179
bfcf1f3a
AD
21802002-03-04 Akim Demaille <akim@epita.fr>
2181
2182 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2183 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2184 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2185 * tests/semantic.at (Parsing Guards): Similarly.
2186 * src/reader.at (readgram): Complain if the last rule is not ended
2187 with a semi-colon.
2188
65ccf9fc
AD
21892002-03-04 Akim Demaille <akim@epita.fr>
2190
2191 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2192 * src/closure.c: here.
2193 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2194 RTC.
2195 * src/warshall.h, src/warshall.c: Remove.
2196 * tests/sets.at (Broken Closure): Adjust.
2197
d0039cbc
AD
21982002-03-04 Akim Demaille <akim@epita.fr>
2199
2200 * src/output.c (output_skeleton): tempdir is const.
2201 bytes_read is unused.
2202
345cea78
AD
22032002-03-04 Akim Demaille <akim@epita.fr>
2204
2205 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2206 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2207 Update.
2208 From Michael Hayes.
2209
564801f7
AD
22102002-03-04 Akim Demaille <akim@epita.fr>
2211
2212 * src/closure.c (closure): `r' is unused.
2213
e5352bc7
AD
22142002-03-04 Akim Demaille <akim@epita.fr>
2215
2216 * tests/sets.at (Broken Closure): Add the ending `;'.
2217 * src/reader.at (readgram): Complain if a rule is not ended with a
2218 semi-colon.
2219
914feea9
AD
22202002-03-04 Akim Demaille <akim@epita.fr>
2221
2222 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2223 (count_sr_conflicts): Use bitset_count.
2224 * src/reduce.c (inaccessable_symbols): Ditto.
2225 (bits_size): Remove.
2226 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2227
f0250de6
AD
22282002-03-04 Akim Demaille <akim@epita.fr>
2229
2230 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2231 * src/reduce.c: Remove the `bitset_zero's following the
2232 `bitset_create's, as now it is performed by the latter.
2233
ef017502
AD
22342002-03-04 Akim Demaille <akim@epita.fr>
2235
2236 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2237 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2238 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2239 latest sources from Michael.
2240
76514394
AD
22412002-03-04 Akim Demaille <akim@epita.fr>
2242
2243 * src/output.c (output): Don't free the grammar.
2244 * src/reader.c (grammar_free): New.
2245 * src/main.c (main): Call it and don't free symtab here.
2246
55024580
AD
22472002-03-04 Akim Demaille <akim@epita.fr>
2248
2249 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2250 before returning.
2251 Reported by Benoit Perrot.
2252
f9abaa2c
AD
22532002-03-04 Akim Demaille <akim@epita.fr>
2254
2255 Use bitset operations when possible, not loops over bits.
2256
2257 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2258 bitset_or.
2259 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2260 * src/reduce.c (useless_nonterminals): Formatting changes.
2261 * src/warshall.c (TC): Use bitset_or.
2262
0e721e75
AD
22632002-03-04 Akim Demaille <akim@epita.fr>
2264
2265 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2266 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2267 Ditto.
2268
0fb1ffb1
AD
22692002-03-04 Akim Demaille <akim@epita.fr>
2270
2271 * src/lalr.c (F): Now a bitset*.
2272 Adjust all dependencies.
2273
b86796bf
AD
22742002-03-04 Akim Demaille <akim@epita.fr>
2275
2276 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2277 Adjust all dependencies.
2278
602bbf31
AD
22792002-03-04 Akim Demaille <akim@epita.fr>
2280
2281 * src/L0.c, src/LR0.h (nstates): Be size_t.
2282 Adjust comparisons (signed vs unsigned).
2283 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2284 bitset*.
2285 Adjust all dependencies.
2286
d8a0245c
AD
22872002-03-04 Akim Demaille <akim@epita.fr>
2288
2289 * src/closure.c (firsts): Now, also a bitset.
2290 Adjust all dependencies.
2291 (varsetsize): Remove, now unused.
2292 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2293
34ba9743
AD
22942002-03-04 Akim Demaille <akim@epita.fr>
2295
2296 * src/print.c: Convert to use bitset.h, not hand coded iterations
2297 over ints.
2298
ed86e78c
AD
22992002-03-04 Akim Demaille <akim@epita.fr>
2300
2301 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2302
dfdb1797
AD
23032002-03-04 Akim Demaille <akim@epita.fr>
2304
2305 * src/closure.c (ruleset): Be a bitset.
2306 (rulesetsize): Remove.
2307
7086e707
AD
23082002-03-04 Akim Demaille <akim@epita.fr>
2309
2310 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2311 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2312 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2313 * src/closure.c (fderives): Be an array of bitsets.
2314
98254360
RA
23152002-02-28 Robert Anisko <robert@lrde.epita.fr>
2316
2317 * data/bison.c++: Merge the two generated headers. Insert a copyright
2318 notice in each output file.
2319
a75c057f
AD
23202002-02-28 Akim Demaille <akim@epita.fr>
2321
2322 * data/bison.c++: Copy the prologue of bison.simple to fetch
2323 useful M4 definitions, such as b4_header_guard.
2324
06b00abc
AD
23252002-02-25 Akim Demaille <akim@epita.fr>
2326
2327 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
2328 translator friendly scheme for the bgr
2329 copyright notice.
06b00abc 2330
70e7d534
AD
23312002-02-25 Akim Demaille <akim@epita.fr>
2332
2333 * src/output.c (header_output): Remove, now handled completely via
2334 M4.
2335
abe017f6
AD
23362002-02-25 Akim Demaille <akim@epita.fr>
2337
2338 * m4/m4.m4: New, from CVS Autoconf.
2339 * configure.in: Invoke it.
2340 * src/output.c (output_skeleton): Use its result instead of the
2341 hard coded name.
2342
381fb12e
AD
23432002-02-25 Akim Demaille <akim@epita.fr>
2344
2345 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2346 Fileutils 4.1.5.
2347 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2348 * src/output.c (output_skeleton): Use mkstemp to create a real
2349 temporary file.
2350 Move the filling of `skeleton' and its muscle to...
2351 (prepare): here.
2352 (output): Move the definition of the prologue muscle to...
2353 (prepare): here.
2354 * src/system.h (DEFAULT_TMPDIR): New.
2355
6f38107f
PE
23562002-02-14 Paul Eggert <eggert@twinsun.com>
2357
2358 Remove the support for C++ namespace cleanliness; it was
2359 causing more problems than it was curing, since it didn't work
2360 properly on some nonstandard C++ compilers. This can wait
2361 for a proper C++ parser.
2362
2363 * NEWS: Document this.
2364 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2365 of C++, as it's treated like C now.
2366 * src/bison.simple (YYSTD): Remove.
2367 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2368 Treat C++ just like Standard C instead of trying to support
2369 namespace cleanliness.
2370
80cce3da
AD
23712002-02-14 Akim Demaille <akim@epita.fr>
2372
2373 * tests/regression.at (else): Adjust to Andreas' change.
2374
842e8679
AD
23752002-02-14 Akim Demaille <akim@epita.fr>
2376
2377 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2378
4bda3f10
AD
23792002-02-13 Andreas Schwab <schwab@suse.de>
2380
2381 * src/output.c (output_rule_data): Don't output NULL, it might
2382 not be defined yet.
2383
4162fa07 23842002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 2385
4162fa07
RA
2386 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2387 (Copyright notice): Update.
b418ecd8 2388
bd16a5dc
AD
23892002-02-11 Akim Demaille <akim@epita.fr>
2390
2391 * tests/regression.at (%nonassoc and eof): Don't include
2392 nonportable headers.
2393
8d69a1a3
RA
23942002-02-08 Robert Anisko <robert@lrde.epita.fr>
2395
2396 * data/bison.c++: Correct error recovery. Make the user able to
2397 initialize the starting location.
2398
9b2d0677
AD
23992002-02-07 Akim Demaille <akim@epita.fr>
2400
2401 * tests/input.at: New.
2402
69e2658b
RA
24032002-02-07 Robert Anisko <robert@lrde.epita.fr>
2404
2405 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 2406 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
2407 directives around tables only needed for debugging.
2408
4aacc3a7
RA
24092002-02-07 Robert Anisko <robert@lrde.epita.fr>
2410
2411 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2412 C++ parsers.
2413 (yy::b4_name::parse): Use print_.
2414
762a801e
RA
24152002-02-07 Robert Anisko <robert@lrde.epita.fr>
2416
2417 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2418
4bb2bc3f
RA
24192002-02-07 Robert Anisko <robert@lrde.epita.fr>
2420
2421 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2422 C++ parsers.
2423 (yy::b4_name::parse): Build verbose error messages, and use error_.
2424
6b45a3ca
RA
24252002-02-06 Robert Anisko <robert@lrde.epita.fr>
2426
2427 * data/bison.c++: Fix m4 quoting in comments.
2428
50997c6e
RA
24292002-02-06 Robert Anisko <robert@lrde.epita.fr>
2430
2431 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2432 not expanded by m4.
2433
3f3eed27
AD
24342002-02-05 Akim Demaille <akim@epita.fr>
2435
2436 * data/bison.c++: Adjust to the M4 back end.
2437 More is certainly needed.
2438
be2a1a68
AD
24392002-02-05 Akim Demaille <akim@epita.fr>
2440
2441 Give a try to M4 as a back end.
2442
2443 * lib/readpipe.c: New, from wdiff.
2444 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2445 BISON_HAIRY.
2446 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2447 specific values. Now it is m4 that performs the lookup.
2448 * src/parse-skel.y: Remove.
2449 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2450 * src/output.c (actions_output, guards_output)
2451 (token_definitions_output): No longer keeps track of the output
2452 line number, hence remove the second argument.
2453 (guards_output): Check against the guard member of a rule, not the
2454 action member.
2455 Adjust callers.
2456 (output_skeleton): Don't look for the skeleton location, let m4 do
2457 that.
2458 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2459 file will be used.
2460 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2461 (prepare): Given that for the time being changesyntax is not
2462 usable in M4, rename the muscles using `-' to `_'.
2463 Define `defines_flag', `output_parser_name' and `output_header_name'.
2464 * src/output.h (actions_output, guards_output)
2465 (token_definitions_output): Adjust prototypes.
2466 * src/scan-skel.l: Instead of scanning the skeletons, it now
2467 processes the output of m4: `__oline__' and `#output'.
2468 * data/bison.simple: Adjust to be used by M4(sugar).
2469 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2470 to date.
2471 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2472 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2473 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2474 shamelessly stolen from CVS Autoconf.
2475
beda758b
AD
24762002-02-05 Akim Demaille <akim@epita.fr>
2477
2478 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2479 * configure.in: Check for the declarations of free and malloc.
2480 * src/muscle_tab.c: Adjust.
2481
5ece6d43
AD
24822002-02-05 Akim Demaille <akim@epita.fr>
2483
2484 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
2485 which have no values.
2486
5bb18f9a
AD
24872002-02-05 Akim Demaille <akim@epita.fr>
2488
2489 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
2490 * data/: here.
2491
894dd62e
PE
24922002-01-29 Paul Eggert <eggert@twinsun.com>
2493
2494 * src/bison.simple (YYSIZE_T): Do not define merely because
2495 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
2496 On some platforms, <alloca.h> does not declare YYSTD (size_t).
2497
82841af7
AD
24982002-01-27 Akim Demaille <akim@epita.fr>
2499
2500 Fix `%nonassoc and eof'.
2501
2502 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
2503 which were not properly copied! Replace
2504 memcpy (res->errs, src->errs, src->nerrs);
2505 with
2506 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
2507 !!!
2508 * tests/regression.at (%nonassoc and eof): Adjust to newest
2509 Autotest: `.' is not in the PATH.
2510
318b76e9
AD
25112002-01-27 Akim Demaille <akim@epita.fr>
2512
2513 * tests/sets.at (AT_EXTRACT_SETS): New.
2514 (Nullable): Use it.
2515 (Firsts): New.
2516
30d2f3d5
AD
25172002-01-26 Akim Demaille <akim@epita.fr>
2518
2519 * tests/actions.at, tests/calc.at, tests/headers.at,
2520 * tests/torture.at: Adjust to the newest Autotest which no longer
2521 forces `.' in the PATH.
2522
30f8c395
AD
25232002-01-25 Akim Demaille <akim@epita.fr>
2524
2525 * tests/regression.at (%nonassoc and eof): New.
2526 Suggested by Robert Anisko.
2527
29ae55f1
AD
25282002-01-24 Akim Demaille <akim@epita.fr>
2529
2530 Bison dumps core when trying to complain about broken input files.
2531 Reported by Cris van Pelt.
2532
2533 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
2534 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
2535 into...
2536 (Invalid inputs): Strengthen: exercise parse_percent_token.
2537
2b548aa6
RA
25382002-01-24 Robert Anisko <robert.anisko@epita.fr>
2539
2540 * src/Makefile.am: Add bison.c++.
2541 * src/bison.c++: New skeleton.
2542
bb0146c2
AD
25432002-01-21 Paolo Bonzini <bonzini@gnu.org>
2544
2545 * po/it.po: New.
2546
bec30531
AD
25472002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
2548
2549 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
2550
fc6edc45
MA
25512002-01-20 Marc Autret <marc@gnu.org>
2552
2553 * src/files.c (compute_output_file_names): Fix
2554
5e5d5415
MA
25552002-01-20 Marc Autret <marc@gnu.org>
2556
2557 * tests/output.at: New test.
2558 * src/files.c (compute_base_names): Don't map extensions when
2559 the YACC flag is set, use defaults.
2560 Reported by Evgeny Stambulchik.
2561
44ea3fbd
MA
25622002-01-20 Marc Autret <marc@gnu.org>
2563
bb0146c2 2564 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
2565 compilers as well (i.e. the vendor C compiler).
2566 Suggested by Albert Chin-A-Young.
2567
338963d1
TVH
25682002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
2569
2570 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
2571 canonical definition.
2572 * src/system.h: Use the canonical definition for PARAMS (avoids
2573 a conflict with the macro from lib/hash.h).
2574
c57b2479
AD
25752002-01-11 Akim Demaille <akim@epita.fr>
2576
2577 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 2578 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 2579
b85810ae
AD
25802002-01-09 Akim Demaille <akim@epita.fr>
2581
2582 * src/files.c, src/files.h (output_infix): New.
2583 (tab_extension): Remove.
2584 (compute_base_names): Compute the former, drop the latter.
2585 * src/output.c (prepare): Insert the muscles `output-infix', and
2586 `output-suffix'.
2587 * src/parse-skel.y (string, string.1): New.
2588 (section.header): Use it.
2589 (section.yacc): Remove.
2590 (prefix): Remove too.
2591 * src/scan-skel.l: Adjust.
2592 * src/bison.simple, src/bison.hairy: Adjust.
2593
cae60122
AD
25942002-01-09 Akim Demaille <akim@epita.fr>
2595
2596 * configure.in (WERROR_CFLAGS): Compute it.
2597 * src/Makefile.am (CFLAGS): Pass it.
2598 * tests/atlocal.in (CFLAGS): Idem.
2599 * src/files.c: Fix a few warnings.
2600 (get_extension_index): Remove, unused.
2601
ae404801
AD
26022002-01-08 Akim Demaille <akim@epita.fr>
2603
2604 * src/getargs.c (AS_FILE_NAME): New.
2605 (getargs): Use it to convert DOSish file names.
2606 * src/files.c (base_name): Rename as full_base_name to avoid
2607 clashes with `base_name ()'.
2608 (filename_split): New.
2609 (compute_base_names): N-th rewrite, using filename_split.
2610
22312b71
AD
26112002-01-08 Akim Demaille <akim@epita.fr>
2612
2613 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
2614 New, stolen from the Fileutils 4.1.
2615 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
2616 * configure.in: Check for the presence of memrchr, and of its
2617 prototype.
2618
a67cef01
TVH
26192002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
2620
2621 * lib/hash.h (__P): Added definition for this macro.
2622 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
2623 BUILT_SOURCES, to ensure they are generated first.
2624 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
2625 %error-verbose to allow bootstrapping with bison 1.30x.
2626
2b25d624
AD
26272002-01-06 Akim Demaille <akim@epita.fr>
2628
2629 * src/reader.c (parse_braces): Don't fetch the next char, the
2630 convention is to fetch on entry.
2631 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
2632 'switch' without a following semicolon.
2633 * tests/regression.at (braces parsing): New.
2634
3460813b
AD
26352002-01-06 Akim Demaille <akim@epita.fr>
2636
2637 Bison is dead wrong in its RR conflict reports.
2638
2639 * tests/torture.at (GNU Cim Grammar): New.
2640 * src/conflicts.c (count_rr_conflicts): Fix.
2641
73784c64
AD
26422002-01-06 Akim Demaille <akim@epita.fr>
2643
2644 Creating package.m4 from configure.ac causes too many problems.
2645
2646 * tests/Makefile.am (package.m4): Create it by hand,
2647 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
2648
25d81090
AD
26492002-01-06 Akim Demaille <akim@epita.fr>
2650
2651 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
2652 skeleton.h.
2653
a9b8959e
PE
26542002-01-04 Paul Eggert <eggert@twinsun.com>
2655
2656 * doc/bison.texinfo (Debugging):
2657 Remove YYSTDERR; it's no longer defined or used.
2658 Also, s/cstdio.h/cstdio/.
2659
25d81090
AD
26602002-01-03 Akim Demaille <akim@epita.fr>
2661
2662 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
2663
1109455c
AD
26642002-01-03 Akim Demaille <akim@epita.fr>
2665
2666 * src/parse-skel.y (process_skeleton): Don't bind the parser's
2667 tracing code to --trace, wait for a better --trace option, with
2668 args.
2669
7ea5e977
AD
26702002-01-03 Akim Demaille <akim@epita.fr>
2671
2672 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
2673 The ISO C++ standard is extremely clear about it: stderr is
2674 considered a macro, not a regular symbol (see table 94 `Header
2675 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
2676 Therefore std:: does not apply to it. It still does with fprintf.
2677 Also, s/cstdio.h/cstdio/.
2678
fab5b110
AD
26792002-01-03 Akim Demaille <akim@epita.fr>
2680
2681 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
2682 for non system headers.
2683
aed7fd9b
AD
26842002-01-02 Akim Demaille <akim@epita.fr>
2685
2686 Equip the skeleton chain with location tracking, runtime trace,
2687 pure parser and scanner.
2688
2689 * src/parse-skel.y: Request a pure parser, locations, and prefix
2690 renaming.
2691 (%union): Having several members with the same type does not help
2692 type mismatches, simplify.
2693 (YYPRINT, yyprint): New.
2694 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
2695 (skel_error): this.
2696 Handle locations.
2697 * src/scan-skel.l: Adjust to these changes.
2698 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
2699 (LOCATION_PRINT, skel_control_t): New.
2700
24fad99e
AD
27012001-12-30 Akim Demaille <akim@epita.fr>
2702
2703 * src/parse-skel.y: Get rid of the shift/reduce conflict:
2704 replace `gb' with BLANKS.
2705 * src/scan-skel.l: Adjust.
2706
a4b36db4
AD
27072001-12-30 Akim Demaille <akim@epita.fr>
2708
2709 * src/system.h: We don't need nor want bcopy.
2710 Throw away MS-DOS crap: we don't need getpid.
2711 * configure.in: We don't need strndup. It was even causing
2712 problems: because Flex includes the headers *before* us,
2713 _GNU_SOURCE is not defined by config.h, and therefore strndup was
2714 not visible.
2715 * lib/xstrndup.c: New.
2716 * src/scan-skel.l: Use it.
2717 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
2718 * src/parse-skel.y: Use %directives instead of #defines.
2719
1239777d
AD
27202001-12-30 Akim Demaille <akim@epita.fr>
2721
2722 * src/skeleton.h: New.
2723 * src/output.c (output_parser, output_master_parser): Remove, dead
2724 code.
2725 * src/output.h (get_lines_number, actions_output, guards_output)
2726 (token_definitions_output): Prototype them.
2727 * src/parse-skel.y: Add the license notice.
2728 Include output.h and skeleton.h.
2729 (process_skeleton): Returns void, and takes a single parameter.
2730 * src/scan-skel.l: Add the license notice.
2731 Include skeleton.h.
2732 Don't use %option yylineno: it seems that then Flex imagines
2733 REJECT has been used, and therefore it won't reallocate its
2734 buffers (which makes no other sense to me than a bug). It results
2735 in warnings for `unused: yy_flex_realloc'.
2736
9b3add5b
RA
27372001-12-30 Robert Anisko <robert.anisko@epita.fr>
2738
2739 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2740 (MUSCLE_INSERT_PREFIX): ...to there.
2741 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2742 (MUSCLE_INSERT_PREFIX): Move from here...
2743
2744 * src/bison.hairy: Add a section directive. Put braces around muscle
2745 names. This parser skeleton is still broken, but Bison should not
2746 choke on a bad muscle 'syntax'.
2747 * src/bison.simple: Add a section directive. Put braces around muscle
2748 names.
2749
2750 * src/files.h (strsuffix, stringappend): Add declarations.
2751 (tab_extension): Add declaration.
2752 (short_base_name): Add declaration.
2753
2754 * src/files.c (strsuffix, stringappend): No longer static. These
2755 functions are used in the skeleton parser.
2756 (tab_extension): New.
2757 (compute_base_names): Use the computations done in this function
fab5b110 2758 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
2759 names.
2760 (short_base_name): No longer static.
2761
2762 * src/output.c (output_skeleton): New.
2763 (output): Disable call to output_master_parser, and give a try to
2764 a new skeleton handling system.
2765 (guards_output, actions_output): No longer static.
2766 (token_definitions_output, get_lines_number): No longer static.
2767
2768 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
2769
fab5b110 2770 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
2771 parse-skel.y.
2772
2773 * src/parse-skel.y: New file.
2774 * src/scan-skel.l: New file.
2775
b5b61c61
AD
27762001-12-29 Akim Demaille <akim@epita.fr>
2777
2778 %name-prefix is broken.
2779
2780 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
2781 Adjust all dependencies.
2782 * tests/headers.at (export YYLTYPE): Strengthen this test: use
2783 %name-prefix.
2784
2785 Renaming yylval but not yylloc is not consistent. Now we do.
2786
2787 * src/bison.simple: Prefix yylloc if used.
2788 * doc/bison.texinfo (Decl Summary): Document that.
2789
8c9a50be
AD
27902001-12-29 Akim Demaille <akim@epita.fr>
2791
2792 * doc/bison.texinfo: Promote `%long-directive' over
2793 `%long_directive'.
2794 Remove all references to fixed-output-files, yacc is enough.
2795
d99361e6
AD
27962001-12-29 Akim Demaille <akim@epita.fr>
2797
2798 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
2799 user prologue. These are defaults.
2800 * tests/actions.at (Mid-rule actions): Make sure the user can
2801 define YYDEBUG and YYERROR_VERBOSE.
2802
b9cecb91
AD
28032001-12-29 Akim Demaille <akim@epita.fr>
2804
2805 * src/output.c (header_output): Don't forget to export YYLTYPE and
2806 yylloc.
2807 * tests/headers.at (export YYLTYPE): New, make sure it does.
2808 * tests/regression.at (%union and --defines, Invalid CPP headers):
2809 Move to...
2810 * tests/headers.at: here.
2811
aea13e97
AD
28122001-12-29 Akim Demaille <akim@epita.fr>
2813
2814 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
2815
931394cb
AD
28162001-12-29 Akim Demaille <akim@epita.fr>
2817
2818 * tests/actions.at (Mid-rule actions): Output on a single line
2819 instead of several.
2820
704a47c4
AD
28212001-12-29 Akim Demaille <akim@epita.fr>
2822
2823 * doc/bison.texinfo: Formatting changes.
2824
091e20bb
AD
28252001-12-29 Akim Demaille <akim@epita.fr>
2826
2827 Don't store the token defs in a muscle, just be ready to output it
2828 on command. Now possible via `symbols'. Fixes a memory leak.
2829
2830 * src/output.c (token_definitions_output): New.
2831 (output_parser, header_output): Use it.
2832 * src/reader.c (symbols_save): Remove.
2833
cce71710
AD
28342001-12-29 Akim Demaille <akim@epita.fr>
2835
2836 * src/bison.simple: Do not provide a default for YYSTYPE and
2837 YYLTYPE before the user's prologue. Otherwise it's hardly... a
2838 default.
2839
82c035a8
AD
28402001-12-29 Akim Demaille <akim@epita.fr>
2841
2842 Mid-rule actions are simply... ignored!
2843
2844 * src/reader.c (readgram): Be sure to attach mid-rule actions to
2845 the empty-rule associated to the dummy symbol, not to the host
2846 rule.
2847 * tests/actions.at (Mid-rule actions): New.
2848
8419d367
AD
28492001-12-29 Akim Demaille <akim@epita.fr>
2850
2851 Memory leak.
2852
2853 * src/reader.c (reader): Free grammar.
2854
375d5806
AD
28552001-12-29 Akim Demaille <akim@epita.fr>
2856
2857 Memory leak.
2858
2859 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
2860 since it allocates it for each state, although only one is needed.
2861 (allocate_storage): Do it here.
2862
f51cb8ff
AD
28632001-12-29 Akim Demaille <akim@epita.fr>
2864
2865 * src/options.h, src/options.c (create_long_option_table): Rename
2866 as...
2867 (long_option_table_new): this, with a clearer prototype.
2868 (percent_table): Remove, unused,
2869 * src/getargs.c (getargs): Adjust.
2870
29e88316
AD
28712001-12-29 Akim Demaille <akim@epita.fr>
2872
2873 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
2874 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
2875 as states.
2876
b9f71f19
AD
28772001-12-29 Akim Demaille <akim@epita.fr>
2878
2879 * src/lalr.c (build_relations): Rename `states' as `states1'.
2880 Sorry, I don't understand exactly what it is, no better name...
2881
1a2b5d37
AD
28822001-12-29 Akim Demaille <akim@epita.fr>
2883
2884 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
2885 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
2886 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
2887 as rules.
2888
1cca533e
AD
28892001-12-29 Akim Demaille <akim@epita.fr>
2890
2891 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
2892 ago.
2893
c03ae966
AD
28942001-12-29 Akim Demaille <akim@epita.fr>
2895
2896 * src/reader.c, src/reader.h (user_toknums): Remove.
2897 Adjust all users to use symbols[i]->user_token_number.
2898
5a670b1e
AD
28992001-12-29 Akim Demaille <akim@epita.fr>
2900
2901 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
2902 Adjust all users to use symbols[i]->prec or ->assoc.
2903
ad949da9
AD
29042001-12-29 Akim Demaille <akim@epita.fr>
2905
2906 * src/reader.c, src/reader.h (tags): Remove.
2907 Adjust all users to use symbols[i]->tag.
2908
0e78e603
AD
29092001-12-29 Akim Demaille <akim@epita.fr>
2910
2911 * src/gram.h, src/gram.c (symbols): New, similar to state_table
2912 and rule_table.
2913 * src/reader.c (packsymbols): Fill this table.
2914 Drop sprec.
2915 * src/conflicts.c (resolve_sr_conflict): Adjust.
2916 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
2917 single table.
2918 Use symbols[i]->tag instead of tags[i].
2919
213e640e
AD
29202001-12-29 Akim Demaille <akim@epita.fr>
2921
2922 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
2923 In addition, put a comment in there, to replace...
2924 * tests/regression.at (%union and C comments): Remove.
2925
e7b8bef1
AD
29262001-12-29 Akim Demaille <akim@epita.fr>
2927
2928 * tests/regression.at (Web2c Actions): Blindly move the actual
2929 output as expected output. The contents *seem* right to me, but I
2930 can't pretend reading perfectly parser tables... Nonetheless, all
2931 the other tests pass correctly, the table look OK, even though the
2932 presence of `$axiom' is to be noted: AFAICS it is useless (but
2933 harmless).
2934
b68e7744
AD
29352001-12-29 Akim Demaille <akim@epita.fr>
2936
2937 * src/reader.c (readgram): Don't add the rule 0 if there were no
2938 rules read. In other words, add it _after_ having performed
2939 grammar sanity checks.
2940 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
2941
78d5bae9
AD
29422001-12-29 Akim Demaille <akim@epita.fr>
2943
2944 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
2945 visible, and some states have now a different number.
2946
ff442794
AD
29472001-12-29 Akim Demaille <akim@epita.fr>
2948
2949 * src/reader.c (readgram): Bind the initial rule's lineno to that
2950 of the first rule.
2951 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
2952 (Solved SR Conflicts): Adjust rule 0's line number.
2953
610ab194
AD
29542001-12-29 Akim Demaille <akim@epita.fr>
2955
2956 Fix the `GAWK Grammar' failure.
2957
2958 * src/LR0.c (final_state): Initialize to -1 so that we do compute
2959 the reductions of the first state which was mistakenly confused
2960 with the final state because precisely final_state was initialized
2961 to 0.
2962 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
2963 now noticed by Bison.
2964 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
2965 have a reduction on $default.
2966
29d29c8f
AD
29672001-12-29 Akim Demaille <akim@epita.fr>
2968
2969 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
2970 rule line numbers.
2971 * src/closure.c (print_closure): Likewise.
2972 * src/derives.c (print_derives): Likewise.
2973 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
2974 now.
2975
7c6b64d0
AD
29762001-12-29 Akim Demaille <akim@epita.fr>
2977
2978 * src/lalr.c (lookaheads_print): New.
2979 (lalr): Call it when --trace-flag.
2980 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
2981 are dumped.
2982
3d4daee3
AD
29832001-12-29 Akim Demaille <akim@epita.fr>
2984
2985 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
2986 when walking through ritem, even via rule->rhs.
2987 * src/reduce.c (dump_grammar, useful_production, reduce_output)
2988 (useful_production, useless_nonterminals): Likewise.
2989 (reduce_grammar_tables): Likewise, plus update nritems.
2990 * src/nullable.c (set_nullable): Likewise.
2991 * src/lalr.c (build_relations): Likewise.
2992 * tests/sets.at (Nullable): Adjust.
2993 Fortunately, now, the $axiom is no longer nullable.
2994
9e7f6bbd
AD
29952001-12-29 Akim Demaille <akim@epita.fr>
2996
2997 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
2998 the 0-sentinel.
2999 * src/gram.c (ritem_longest_rhs): Likewise.
3000 * src/reduce.c (nonterminals_reduce): Likewise.
3001 * src/print_graph.c (print_graph): Likewise.
3002 * src/output.c (output_rule_data): Likewise.
3003 * src/nullable.c (set_nullable): Likewise.
3004
255ef638
AD
30052001-12-29 Akim Demaille <akim@epita.fr>
3006
3007 * src/output.c: Comment changes.
3008
0d8a7363
AD
30092001-12-27 Paul Eggert <eggert@twinsun.com>
3010
3011 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
3012 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
3013 Sparc, as they were causing more porting problems than the
3014 (minor) performance improvement was worth.
3015
3016 Also, catch up with 1.31's YYSTD.
3017
3db472b9
AD
30182001-12-27 Akim Demaille <akim@epita.fr>
3019
3020 * src/output.c (output_gram): Rely on nritems, not the
3021 0-sentinel. See below.
3022 Use -1 as separator, not 0.
3023 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
3024 Rely on -1 as separator in yyrhs, instead of 0.
3025 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
3026 twice `Now at end of input', therefore there are two lines less to
3027 expect.
3028
b365aa05
AD
30292001-12-27 Akim Demaille <akim@epita.fr>
3030
3031 * tests/regression.at (Unresolved SR Conflicts):
3032 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
3033 below.
3034
30171f79
AD
30352001-12-27 Akim Demaille <akim@epita.fr>
3036
3037 * src/LR0.c (new_state): Recognize the final state by the fact it
3038 is reached by eoftoken.
3039 (insert_start_shifting_state, insert_eof_shifting_state)
3040 (insert_accepting_state, augment_automaton): Remove, since now
3041 these states are automatically computed from the initial state.
3042 (generate_states): Adjust.
3043 * src/print.c: When reporting a rule number to the user, substract
3044 1, so that the axiom rule is rule 0, and the first user rule is 1.
3045 * src/reduce.c: Likewise.
3046 * src/print_graph.c (print_core): For the time being, just as for
3047 the report, depend upon --trace-flags to dump the full set of
3048 items.
3049 * src/reader.c (readgram): Once the grammar read, insert the rule
3050 0: `$axiom: START-SYMBOL $'.
3051 * tests/set.at: Adjust: rule 0 is now displayed, and since the
3052 number of the states has changed (the final state is no longer
3053 necessarily the last), catch up.
3054
75142d45
AD
30552001-12-27 Akim Demaille <akim@epita.fr>
3056
3057 Try to make the use of the eoftoken valid. Given that its value
3058 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
3059 is used instead of > 0 where appropriate, (ii), depend upon nritems
3060 instead of the 0-sentinel.
3061
3062 * src/gram.h, src/gram.c (nritems): New.
3063 Expected to be duplication of nitems, but for the time being...
3064 * src/reader.c (packgram): Assert nritems and nitems are equal.
3065 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
3066 * src/closure.c (print_closure, print_fderives): Likewise.
3067 * src/gram.c (ritem_print): Likewise.
3068 * src/print.c (print_core, print_grammar): Likewise.
3069 * src/print_graph.c: Likewise.
3070
b7c49edf
AD
30712001-12-27 Akim Demaille <akim@epita.fr>
3072
3073 * src/main.c (main): If there are complains after grammar
3074 reductions, then output the report anyway if requested, then die.
3075 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
3076 * src/reader.c (eoftoken): New.
3077 (parse_token_decl): If the token being defined has value `0', it
3078 is the eoftoken.
3079 (packsymbols): No longer hack `tags' to insert `$' by hand.
3080 Be sure to preserve the value of the eoftoken.
3081 (reader): Make sure eoftoken is defined.
3082 Initialize nsyms to 0: now eoftoken is created just like the others.
3083 * src/print.c (print_grammar): Don't special case the eof token.
3084 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
3085 lie anyway, albeit pleasant.
3086 * tests/calc.at: Exercise error messages with eoftoken.
3087 Change the grammar so that empty input is invalid.
3088 Adjust expectations.
3089 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
3090
ec2da99f
AD
30912001-12-27 Akim Demaille <akim@epita.fr>
3092
3093 * configure.in: Check the protos of strchr ans strspn.
3094 Replace strchr if needed.
3095 * src/system.h: Provide the protos of strchr, strspn and memchr if
3096 missing.
3097 * lib/strchr.c: New.
3098 * src/reader.c (symbols_save): Use strchr.
3099
8adfa272
AD
31002001-12-27 Akim Demaille <akim@epita.fr>
3101
3102 * src/print.c, src/print_graph.c (escape): New.
3103 Use it to quote the TAGS outputs.
3104 * src/print_graph.c (print_state): Now errors are in red, and
3105 reductions in green.
3106 Prefer high to wide: output the state number on a line of its own.
3107
80dac38c
AD
31082001-12-27 Akim Demaille <akim@epita.fr>
3109
3110 * src/state.h, src/state.c (reductions_new): New.
3111 * src/LR0.c (set_state_table): Let all the states have a
3112 `reductions', even if reduced to 0.
3113 (save_reductions): Adjust.
3114 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
3115 * src/print.c (print_reductions, print_actions): Adjust.
3116 * src/output.c (action_row): Adjust.
3117
2cec70b9
AD
31182001-12-27 Akim Demaille <akim@epita.fr>
3119
3120 * src/state.h, src/state.c (errs_new, errs_dup): New.
3121 * src/LR0.c (set_state_table): Let all the states have an errs,
3122 even if reduced to 0.
3123 * src/print.c (print_errs, print_reductions): Adjust.
3124 * src/output.c (output_actions, action_row): Adjust.
3125 * src/conflicts.c (resolve_sr_conflict): Adjust.
3126
13ca549a
AD
31272001-12-27 Akim Demaille <akim@epita.fr>
3128
3129 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
3130
5092aba5
AD
31312001-12-27 Akim Demaille <akim@epita.fr>
3132
3133 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
3134 * src/print.c: here.
3135 (lookaheadset, shiftset): New, used as additional storage by
3136 print_reductions.
3137 (print_results): Adjust.
3138 (print_shifts, print_gotos, print_errs): New, extracted from...
3139 (print_actions): here.
3140 * src/print_graph.c (print_actions): Remove dead code.
3141
11e2beca
AD
31422001-12-27 Akim Demaille <akim@epita.fr>
3143
3144 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
3145 `$n' and `@n'.
3146
dac3c910
AD
31472001-12-27 Akim Demaille <akim@epita.fr>
3148
3149 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
3150 (build_relations): Adjust.
3151
d0b0fefa
AD
31522001-12-27 Akim Demaille <akim@epita.fr>
3153
3154 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
3155 duplication.
3156
adc8c848
AD
31572001-12-27 Akim Demaille <akim@epita.fr>
3158
3159 * src/reader.c (packgram): Catch nitems overflows.
3160
14d293ac
AD
31612001-12-27 Akim Demaille <akim@epita.fr>
3162
3163 * src/files.c, src/files.h (guard_obstack): Remove.
3164 * src/output.c (output): Adjust.
3165 * src/reader.c (parse_braces): New, factoring...
3166 (copy_action, copy_guard): these two which are renamed as...
3167 (parse_action, parse_guard): these.
3168 As a voluntary consequence, using braces around guards is now
3169 mandatory.
3170
f499b062
AD
31712001-12-27 Akim Demaille <akim@epita.fr>
3172
3173 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3174 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3175 members.
3176 (symbol_list_new): Adjust.
3177 (copy_action): action_line is the first line, not the last.
3178 (copy_guard): Just as for actions, store the `action' only, not
3179 the switch/case/break flesh.
3180 Don't parse the user action that might follow the guard, let...
3181 (readgram): do it, i.e., now, there can be an action after a
3182 guard.
3183 In other words the guard is just explicitly optional.
3184 (packgram): Adjust.
3185 * src/output.c (guards_output): New.
3186 (output_parser): Call it when needed.
3187 (output): Also free the guard and attrs obstacks.
3188 * src/files.c, src/files.h (obstack_save): Remove.
3189 (output_files): Remove.
3190 As a result, if one needs the former `.act' file, using an
3191 appropriate skeleton which requires actions and guards is now
3192 required.
3193 * src/main.c (main): Adjust.
3194 * tests/semantic.at: New.
3195 * tests/regression.at: Use `input.y' as input file name.
3196 Avoid 8+3 problems by requiring input.c when the test needs the
3197 parser.
3198
d945f5cd
AD
31992001-12-27 Akim Demaille <akim@epita.fr>
3200
3201 * src/reader.c (symbol_list_new): Be sure to initialize all the
3202 fields.
3203
d200e455
AD
32042001-12-27 Akim Demaille <akim@epita.fr>
3205
3206 All the hacks using a final pseudo state are now useless.
3207
3208 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3209 * src/lalr.c (nLA): New.
3210 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3211 instead of lookaheadsp from the pseudo state (nstate + 1).
3212
f9507c28
AD
32132001-12-27 Akim Demaille <akim@epita.fr>
3214
3215 * src/output.c (action_row, token_actions): Use a state_t instead
3216 of a integer, and nlookaheads instead of the following state's
3217 lookaheadsp.
3218
065fbd27
AD
32192001-12-27 Akim Demaille <akim@epita.fr>
3220
3221 * src/conflicts.c (log_resolution, flush_shift)
3222 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3223 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3224 (conflicts_print, print_reductions): Use a state_t instead of an
3225 integer when referring to a state.
3226 As much as possible, depend upon nlookaheads, instead of the
3227 `lookaheadsp' member of the following state (since lookaheads of
3228 successive states are successive, the difference between state n + 1
3229 and n served as the number of lookaheads for state n).
3230 * src/lalr.c (add_lookback_edge): Likewise.
3231 * src/print.c (print_core, print_actions, print_state)
3232 (print_results): Likewise.
3233 * src/print_graph.c (print_core, print_actions, print_state)
3234 (print_graph): Likewise.
3235 * src/conflicts.h: Adjust.
3236
1b177bd7
AD
32372001-12-27 Akim Demaille <akim@epita.fr>
3238
3239 * src/bison.hairy: Formatting/comment changes.
3240 ANSIfy.
3241 Remove `register' indications.
3242 Add plenty of `static'.
3243
7742ddeb
AD
32442001-12-27 Akim Demaille <akim@epita.fr>
3245
3246 * src/output.c (prepare): Drop the muscle `ntbase' which
3247 duplicates ntokens.
3248 * src/bison.simple: Formatting/comment changes.
3249 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3250 is an undocumented synonym.
3251
1fa14068
AD
32522001-12-22 Akim Demaille <akim@epita.fr>
3253
3254 * src/output.c (output_table_data): Change the prototype to use
3255 `int' for array ranges: some invocations do pass an int, not a
3256 short.
3257 Reported by Wayne Green.
3258
b9752825
AD
32592001-12-22 Akim Demaille <akim@epita.fr>
3260
3261 Some actions of web2c.y are improperly triggered.
3262 Reported by Mike Castle.
3263
3264 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3265 * tests/regression.at (Web2c): Rename as...
3266 (Web2c Report): this.
3267 (Web2c Actions): New.
3268
776209d6
AD
32692001-12-22 Akim Demaille <akim@epita.fr>
3270
3271 Reductions in web2c.y are improperly reported.
3272 Reported by Mike Castle.
3273
3274 * src/conflicts.c (print_reductions): Fix.
3275 * tests/regression.at (Web2c): New.
3276
275fc3ad
AD
32772001-12-18 Akim Demaille <akim@epita.fr>
3278
3279 Some host fail on `assert (!"foo")', which expands to
3280 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3281 Reported by Nelson Beebee.
3282
3283 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3284 `#define it_succeeded 0' and `assert (it_succeeded)'.
3285
897668ee
MA
32862001-12-17 Marc Autret <autret_m@epita.fr>
3287
3288 * src/bison.simple: Don't hard code the skeleton line and filename.
3289 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3290 New line counter 'skeleton_line' (skeleton-line muscle).
3291
ab3399e0
PE
32922001-12-17 Paul Eggert <eggert@twinsun.com>
3293
3294 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3295 YYDEBUG must be defined to a nonzero value.
3296
3297 * src/bison.simple (yytname): Do not assume that the user defines
3298 YYDEBUG to a properly parenthesized expression.
3299
3877f72b
AD
33002001-12-17 Akim Demaille <akim@epita.fr>
3301
3302 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3303 nlookaheads is a new member.
3304 Adjust all users.
3305 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3306 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3307 state.
776209d6 3308
331dbc1b
AD
33092001-12-17 Akim Demaille <akim@epita.fr>
3310
3311 * src/files.h, src/files.c (open_files, close_files): Remove.
3312 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3313 let...
3314 * src/reader.c (reader): Do it.
776209d6 3315
be750e4c
AD
33162001-12-17 Akim Demaille <akim@epita.fr>
3317
3318 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 3319
709ae8c6
AD
33202001-12-17 Akim Demaille <akim@epita.fr>
3321
3322 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3323 (flush_reduce): New.
3324 (resolve_sr_conflict): Adjust.
776209d6 3325
f87685c3
AD
33262001-12-17 Akim Demaille <akim@epita.fr>
3327
3328 * src/output.c (output_obstack): Be static and rename as...
3329 (format_obstack): this, to avoid any confusion with files.c's
3330 output_obstack.
3331 * src/reader.h (muscle_obstack): Move to...
3332 * src/output.h: here, since it's defined in output.c.
3333
837491d8
AD
33342001-12-17 Akim Demaille <akim@epita.fr>
3335
3336 * src/output.c (action_row, save_column, default_goto)
3337 (sort_actions, matching_state, pack_vector): Better variable
3338 locality.
3339
796d61fb
AD
33402001-12-17 Akim Demaille <akim@epita.fr>
3341
3342 * src/output.c: Various formatting changes.
776209d6 3343
64d15509
AD
33442001-12-17 Akim Demaille <akim@epita.fr>
3345
3346 * src/files.c (output_files): Free the output_obstack.
3347 * src/main.c (main): Call print and print_graph conditionally.
3348 * src/print.c (print): Work unconditionally.
3349 * src/print_graph.c (print_graph): Work unconditionally.
3350 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3351
fbc8ecb7
MA
33522001-12-16 Marc Autret <autret_m@epita.fr>
3353
3354 * src/output.c (actions_output): Fix. When we use %no-lines,
3355 there is one less line per action.
3356
f0440388
MA
33572001-12-16 Marc Autret <autret_m@epita.fr>
3358
3359 * src/bison.simple: Remove a useless #line directive.
3360 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3361 * src/output.c (get_lines_number): New.
776209d6 3362 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
3363 output muscles.
3364 Fix line numbering.
3365 (actions_output): Computes the number of lines taken by actions.
3366 (output_master_parser): Insert new skeleton which is the name of
3367 the output parser file name.
3368
a79986b8
MA
33692001-12-15 Marc Autret <autret_m@epita.fr>
3370
3371 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3372
4ec8e00f
MA
33732001-12-15 Marc Autret <autret_m@epita.fr>
3374
3375 * src/output.c (output_gram): Keep track of the hairy one.
3376
1a4648ff
AD
33772001-12-15 Akim Demaille <akim@epita.fr>
3378
3379 Make `make distcheck' work.
3380
3381 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3382 system.h which uses libgettext.h.
3383
9c2c67e6
AD
33842001-12-15 Akim Demaille <akim@epita.fr>
3385
3386 * src/nullable.c (set_nullable): Useless rules must be skipped,
3387 otherwise, since we range over their symbols, we might look at a
3388 nonterminal which no longer ``exists'', i.e., it is not counted in
3389 `nvars', hence we overflow our arrays.
3390
93ede233
AD
33912001-12-15 Akim Demaille <akim@epita.fr>
3392
3393 The header can also be produced directly, without any obstack!
3394 Yahoo!
3395
3396 * src/files.c, src/files.h (defines_obstack): Remove.
3397 (compute_header_macro): Global.
3398 (defines_obstack_save): Remove.
3399 * src/reader.c (parse_union_decl): No longer output to
3400 defines_obstack: its content can be found in the `stype' muscle
3401 anyway.
3402 (output_token_translations): Merge into...
3403 (symbols_output): this.
3404 Rename as...
3405 (symbols_save): this.
3406 (reader): Adjust.
3407 * src/output.c (header_output): New.
3408 (output): Call it.
3409
2666f928
AD
34102001-12-15 Akim Demaille <akim@epita.fr>
3411
3412 * src/reader.c (parse_union_decl): Instead of handling two obstack
3413 simultaneously, use one to define the `stype' muscle, and use the
3414 value of the latter to fill defines_obstack.
3415 (copy_comment): Remove.
3416 (copy_comment2): Work for a single obstack.
3417 Rename as...
3418 (copy_comment): this.
3419
428046f8
AD
34202001-12-15 Akim Demaille <akim@epita.fr>
3421
3422 * src/lex.c, src/lex.h (xgetc): No longer static.
3423 * src/reader.c (parse_union_decl): Revamp.
3424
ea52d706
AD
34252001-12-15 Akim Demaille <akim@epita.fr>
3426
3427 Still making progress in separating Bison into (i) input, (ii)
3428 process, (iii) output: now we can directly output the parser file
3429 without using table_obstack at all.
3430
3431 * src/files.c, src/files.h (table_obstack): Bye bye.
3432 (parser_file_name): New.
3433 * src/files.c (compute_output_file_names): Compute it.
3434 * src/output.c (actions_output, output_parser)
3435 (output_master_parser): To a file instead of an obstack.
3436
3f96f4dc
AD
34372001-12-15 Akim Demaille <akim@epita.fr>
3438
3439 Attach actions to rules, instead of pre-outputting them to
3440 actions_obstack.
3441
3442 * src/gram.h (rule_t): action and action_line are new members.
3443 * src/reader.c (symbol_list): Likewise.
3444 (copy_action): Save the actions within the rule.
3445 (packgram): Save them in rule_table.
3446 * src/output.c (actions_output): New.
3447 (output_parser): Use it on `%%actions'.
3448 (output_rule_data): Don't free rule_table.
3449 (output): Do it.
3450 (prepare): Don't save the `action' muscle.
3451 * src/bison.simple: s/%%action/%%actions/.
3452
51576fb3
AD
34532001-12-15 Akim Demaille <akim@epita.fr>
3454
3455 * src/reader.c (copy_action): When --yacc, don't append a `;'
3456 to the user action: let it fail if lacking.
dee049eb 3457 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 3458
2648a72d
AD
34592001-12-14 Akim Demaille <akim@epita.fr>
3460
3461 * src/lex.c (literalchar): Simply return the char you decoded, non
3462 longer mess around with obstacks and int pointers.
3463 Adjust all callers.
3464
92790e5b
AD
34652001-12-14 Akim Demaille <akim@epita.fr>
3466
3467 * src/lex.c (literalchar): Don't escape the special characters,
3468 just decode them, and keep them as char (before, eol was output as
3469 the 2 char string `\n' etc.).
3470 * src/output.c (output_rule_data): Use quotearg to output the
3471 token strings.
3472
927c1557
PE
34732001-12-13 Paul Eggert <eggert@twinsun.com>
3474
3475 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3476 Do not infringe on the global user namespace when using C++.
3477 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3478 All uses of `fprintf' and `stderr' changed.
3479
3480 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3481
ed8e1f68
AD
34822001-12-13 Akim Demaille <akim@epita.fr>
3483
3484 The computation of nullable is broken: it doesn't handle empty
3485 RHS's properly.
3486
3487 * tests/torture.at (GNU AWK Grammar): New.
3488 * tests/sets.at (Nullable): New.
3489 * src/nullable.c (set_nullable): Instead of blindly looping over
3490 `ritems', loop over the rules, and then over their rhs's.
3491
3492 Work around Autotest bugs.
3493
3494 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
3495 frame, because Autotest understand lines starting with a `+' as
3496 traces from the shell. Then, they are not processed properly.
3497 Admittedly an Autotest bug, but we don't have time to wait for
3498 Autotest to catch up.
3499 * tests/regression.at (Broken Closure): Adjust to the new table
3500 frames.
3501 Move to...
3502 * tests/sets.at: here.
3503
cb581495
AD
35042001-12-13 Akim Demaille <akim@epita.fr>
3505
3506 * src/closure.c (closure): Use nrules instead of playing tricks
3507 with BITS_PER_WORD.
3508
2e729273
AD
35092001-12-13 Akim Demaille <akim@epita.fr>
3510
3511 * src/print.c (print_actions): Output the handling of `$' as the
3512 traces do: shifting the token EOF. Before EOF was treated as a
3513 nonterminal.
3514 * tests/regression.at: Adjust some tests.
3515 * src/print_graph.c (print_core): Complete the set of items via
3516 closure. The next-to-final and final states are still unsatisfying,
3517 but that's to be addressed elsewhere.
3518 No longer output the rule numbers, but do output the state number.
3519 A single loop for the shifts + gotos is enough, but picked a
3520 distinct color for each.
3521 (print_graph): Initialize and finalize closure.
3522
107f7dfb
AD
35232001-12-13 Akim Demaille <akim@epita.fr>
3524
3525 * src/reader.c (readgram): Remove dead code, an strip useless
3526 braces.
3527 (get_type): Remove, unused.
3528
9b53a24f
AD
35292001-12-12 Akim Demaille <akim@epita.fr>
3530
3531 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
3532 on that of lib/error.c.
3533
dbfb6dcd
AD
35342001-12-12 Akim Demaille <akim@epita.fr>
3535
3536 Some hosts don't like `/' in includes.
3537
3538 * src/system.h: Include libgettext.h without qualifying the path.
3539 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
3540 $(top_srcdir).
3541
c25fb648
MA
35422001-12-11 Marc Autret <autret_m@epita.fr>
3543
3544 * src/output.c (output_parser): Remove useless muscle.
3545
710ddc4f
MA
35462001-12-11 Marc Autret <autret_m@epita.fr>
3547
3548 * src/bison.simple: Remove #line just before %%epilogue. It
3549 is now handled in ...
3550 * src/reader.c (read_additionnal_code): Add the output of a
3551 #line for the epilogue.
3552
e83d80b8
MA
35532001-12-10 Marc Autret <autret_m@epita.fr>
3554
927c1557 3555 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
3556 replace precedent remove.
3557 * src/bison.simple: Remove #line before %%prologue because
3558 %%input-line is wrong at this time.
3559
971d5158
MA
35602001-12-10 Marc Autret <autret_m@epita.fr>
3561
3562 * src/reader.c (symbols_output): Clean up.
927c1557 3563 * src/output.c (output_gram, output): Clean up.
971d5158 3564
5edafffd
AD
35652001-12-10 Akim Demaille <akim@epita.fr>
3566
3567 * src/lalr.c (initialize_lookaheads): New. Extracted from...
3568 * src/LR0.c (set_state_table): here.
3569 * src/lalr.c (lalr): Call it.
3570
0279f8e9
AD
35712001-12-10 Akim Demaille <akim@epita.fr>
3572
3573 * src/state.h (shifts): Remove the `number' member: shifts are
3574 attached to state, hence no longer need to be labelled with a
3575 state number.
3576
190c4f5f
AD
35772001-12-10 Akim Demaille <akim@epita.fr>
3578
3579 Now that states have a complete set of members, the linked list of
3580 shifts is useless: just fill directly the state's shifts member.
3581
3582 * src/state.h (shifts): Remove the `next' member.
3583 * src/LR0.c (first_state, last_state): Remove.
3584 Adjust the callers.
3585 (augment_automaton): Don't look for the shifts that must be added
3586 a shift on EOF: it is those of the state we looked for! But now,
3587 since shifts are attached, it is no longer needed to looking
3588 merely by its id: its number.
3589
2a73b93d
AD
35902001-12-10 Akim Demaille <akim@epita.fr>
3591
3592 * src/LR0.c (augment_automaton): Better variable locality.
3593 Remove an impossible branch: if there is a state corresponding to
3594 the start symbol being shifted, then there is shift for the start
3595 symbol from the initial state.
3596
74392f6a
AD
35972001-12-10 Akim Demaille <akim@epita.fr>
3598
3599 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
3600 only when appropriate: when insert_start_shifting_state' is not
3601 invoked.
3602 * tests/regression.at (Rule Line Numbers): Adjust.
3603
37c82725
AD
36042001-12-10 Akim Demaille <akim@epita.fr>
3605
3606 * src/LR0.c (augment_automaton): Now that all states have shifts,
3607 merge the two cases addition shifts to the initial state.
3608
6a164e0c
AD
36092001-12-10 Akim Demaille <akim@epita.fr>
3610
3611 * src/lalr.c (set_state_table): Move to...
3612 * src/LR0.c: here.
3613 * src/lalr.c (lalr): Don't call it...
3614 * src/LR0.c (generate_states): do it.
3615 * src/LR0.h (first_state): Remove, only the table is used.
3616
7215de24
AD
36172001-12-10 Akim Demaille <akim@epita.fr>
3618
3619 * src/LR0.h (first_shift, first_reduction): Remove.
3620 * src/lalr.c: Don't use first_shift: find shifts through the
3621 states.
3622
80e25d4d
AD
36232001-12-10 Akim Demaille <akim@epita.fr>
3624
3625 * src/LR0.c: Attach shifts to states as soon as they are
3626 computed.
3627 * src/lalr.c (set_state_table): Instead of assigning shifts to
3628 state, just assert that the mapping was properly done.
3629
0ab3728b
AD
36302001-12-10 Akim Demaille <akim@epita.fr>
3631
3632 * src/LR0.c (insert_start_shift): Rename as...
3633 (insert_start_shifting_state): this.
3634 (insert_eof_shifting_state, insert_accepting_state): New.
3635 (augment_automaton): Adjust.
3636 Better locality of the variables.
3637 When looking if the start_symbol is shifted from the initial
3638 state, using `while (... symbol != start_symbol ...)' sounds
3639 better than `while (... symbol < start_symbol ...)': If fail
3640 to see how the order between symbols could be relevant!
3641
78af9bbc
AD
36422001-12-10 Akim Demaille <akim@epita.fr>
3643
3644 * src/getargs.h: Don't declare `spec_name_prefix' and
3645 `spec_file_prefix', declared by src/files.h.
3646 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
3647 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
3648 * src/output.c (prepare): Adjust.
3649 * src/reader.c (symbols_output): Likewise.
3650 * src/vmsgetargs.c: Vaguely adjust, but who cares?
3651
bdef2a41
AD
36522001-12-10 Akim Demaille <akim@epita.fr>
3653
3654 * src/muscle_tab.c (muscle_init): NULL is a better default than
3655 `"0"'.
3656
3735969c
AD
36572001-12-10 Akim Demaille <akim@epita.fr>
3658
3659 * src/reader.c (reader): Calling symbols_output once is enough.
3660
49701457
AD
36612001-12-10 Akim Demaille <akim@epita.fr>
3662
3663 Now that states have a complete set of members, the linked list of
3664 reductions is useless: just fill directly the state's reductions
3665 member.
3666
3667 * src/state.h (struct reductions): Remove member `number' and
3668 `next'.
3669 * src/LR0.c (first_reduction, last_reduction): Remove.
3670 (save_reductions): Don't link the new reductions, store them in
3671 this_state.
3672 * src/lalr.c (set_state_table): No need to attach reductions to
3673 states, it's already done.
3674 * src/output.c (output_actions): No longer free the shifts, then
3675 the reductions, then the states: free all the states and their
3676 members.
3677
0edad749
AD
36782001-12-10 Akim Demaille <akim@epita.fr>
3679
3680 * src/options.c (OPTN, DRTV, BOTH): New.
3681 (option_table): Use them.
3682
0edad749
AD
3683 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
3684 the job of system.h.
3685 * src/options.c: Don't include stdio.h and xalloc.h for the same
3686 reasons.
3687
5449dd0f
AD
36882001-12-10 Akim Demaille <akim@epita.fr>
3689
3690 * src/output.c (output, prepare): Make sure the values of the
3691 muscles `action' and `prologue' are 0-terminated.
3692
a870c567
AD
36932001-12-10 Akim Demaille <akim@epita.fr>
3694
3695 Clean up GCC warnings.
3696
3697 * src/reader.c (copy_action): `buf' is not used.
3698 (parse_skel_decl): Be static.
3699 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
3700 * src/options.h (create_long_option_table): Have a real prototype.
3701 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
3702 (hash_delete_at): Return const void *.
3703 Adjust casts to preserve the const.
3704
80df8768
AD
37052001-12-10 Akim Demaille <akim@epita.fr>
3706
3707 * configure.in: Require 2.52g.
3708 M4 is not needed, but AUTOM4TE is.
3709 * m4/m4.m4: Remove.
3710 * tests/Makefile.am: Adjust.
3711
f693ad14
AD
37122001-12-10 Akim Demaille <akim@epita.fr>
3713
3714 One structure for states is enough, even though theoretically
3715 there are LR(0) states and LALR(1) states.
3716
3717 * src/lalr.h (state_t): Remove.
3718 (state_table): Be state_t **, not state_t *.
3719 * src/state.h (core, CORE_ALLOC): Rename as...
3720 (state_t, STATE_ALLOC): this.
3721 Add the LALR(1) members: shifts, reductions, errs.
3722 * src/LR0.c (state_table): Rename as...
3723 (state_hash): this, to avoid name clashes with the global
3724 `state_table'.
3725 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
3726 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
3727
74ffbcb6
AD
37282001-12-10 Akim Demaille <akim@epita.fr>
3729
3730 Bison dumps core on bash.y.
3731 Reported by Pascal Bart.
3732
3733 * src/warshall.c (bitmatrix_print): New.
3734 (TC): Use it.
3735 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
3736 j must be the outer loop.
3737 * tests/regression.at (Broken Closure): New.
3738
07708e19
AD
37392001-12-05 Akim Demaille <akim@epita.fr>
3740
3741 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
3742 its argument.
3743