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