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