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