]> git.saurik.com Git - bison.git/blame - ChangeLog
* src/lalr.h, src/lalr.c (goto_number_t): New.
[bison.git] / ChangeLog
CommitLineData
e68e0410
AD
12002-07-03 Akim Demaille <akim@epita.fr>
2
3 * src/lalr.h, src/lalr.c (goto_number_t): New.
4 * src/lalr.c (goto_list_t): New.
5 Propagate them.
6 * src/nullable.c (rule_list_t): New.
7 Propagate.
8 * src/types.h: Remove.
9
e1a4f3a4
AD
102002-07-03 Akim Demaille <akim@epita.fr>
11
12 * src/closure.c (print_fderives): Use rule_rhs_print.
13 * src/derives.c (print_derives): Use rule_rhs_print.
14 (rule_list_t): New, replaces `shorts'.
15 (set_derives): Add comments.
16 * tests/sets.at (Nullable, Firsts): Adjust.
17
536545f3
AD
182002-07-03 Akim Demaille <akim@epita.fr>
19
20 * src/output.c (prepare_actions): Free `tally' and `width'.
21 (prepare_actions): Allocate and free `order'.
22 * src/symtab.c (symbols_free): Free `symbols'.
23 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
24 * src/output.c (m4_invoke): Move to...
25 * src/scan-skel.l: here.
26 (<<EOF>>): Close yyout, and free its name.
27
8b752b00
AD
282002-07-03 Akim Demaille <akim@epita.fr>
29
30 Fix some memory leaks, and fix a bug: state 0 was examined twice.
31
32 * src/LR0.c (new_state): Merge into...
33 (state_list_append): this.
34 (new_states): Merge into...
35 (generate_states): here.
36 (set_states): Don't ensure a proper `errs' state member here, do it...
37 * src/conflicts.c (conflicts_solve): here.
38 * src/state.h, src/state.c: Comment changes.
39 (state_t): Rename member `shifts' as `transitions'.
40 Adjust all dependencies.
41 (errs_new): For consistency, also take the values as argument.
42 (errs_dup): Remove.
43 (state_errs_set): New.
44 (state_reductions_set, state_transitions_set): Assert that no
45 previous value was assigned.
46 (state_free): New.
47 (states_free): Use it.
48 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
49 temporary storage: use `errs' and `nerrs' as elsewhere.
50 (set_conflicts): Allocate and free this `errs'.
51
613f5e1a
AD
522002-07-02 Akim Demaille <akim@epita.fr>
53
54 * lib/libiberty.h: New.
55 * lib: Update the bitset implementation from upstream.
56 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
57 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
58 * src/main.c: Adjust bitset stats calls.
59
26e0cadc
PE
602002-07-01 Paul Eggert <eggert@twinsun.com>
61
62 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
63 char, so that negative chars don't collide with $.
64
1154cced
AD
652002-06-30 Akim Demaille <akim@epita.fr>
66
67 Have the GLR tests be `warning' checked, and fix the warnings.
68
69 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
70 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
71 (yyremoveDeletes): `yyi' and `yyj' are size_t.
72 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
73 (yyaddDeferredAction): static.
74 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
75 (yyreportParseError): yyprefix is const.
76 yytokenp is used only when verbose.
77 (yy__GNUC__): Replace with __GNUC__.
78 (yypdumpstack): yyi is size_t.
79 (yypreference): Un-yy local variables and arguments, to avoid
80 clashes with `yyr1'. Anyway, we are not in the user name space.
81 (yytname_size): be an int, as is compared with ints.
82 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
83 Use them.
84 * tests/cxx-gram.at: Use quotation to protect $1.
85 Use AT_COMPILE to enable warnings hunts.
86 Prototype yylex and yyerror.
87 `Use' argc.
88 Include `string.h', not `strings.h'.
89 Produce and prototype stmtMerge only when used.
90 yylex takes a location.
91
97650f4e
AD
922002-06-30 Akim Demaille <akim@epita.fr>
93
94 We spend a lot of time in quotearg, in particular when --verbose.
95
96 * src/symtab.c (symbol_get): Store a quoted version of the key.
97 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
98 Adjust all callers.
99
d2576365
AD
1002002-06-30 Akim Demaille <akim@epita.fr>
101
102 * src/state.h (reductions_t): Rename member `nreds' as num.
103 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
104 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
105
ccaf65bc
AD
1062002-06-30 Akim Demaille <akim@epita.fr>
107
108 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
109 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
110 (shifts_to): Rename as...
111 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
112 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
113 (TRANSITION_IS_DISABLED, transitions_to): these.
114
87675353
AD
1152002-06-30 Akim Demaille <akim@epita.fr>
116
117 * src/print.c (print_shifts, print_gotos): Merge into...
118 (print_transitions): this.
119 (print_transitions, print_errs, print_reductions): Align the
120 lookaheads columns.
121 (print_core, print_transitions, print_errs, print_state,
122 print_grammar): Output empty lines separator before, not after.
123 (state_default_rule_compute): Rename as...
124 (state_default_rule): this.
125 * tests/conflicts.at (Defaulted Conflicted Reduction),
126 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
127 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
128
ce4ccb4b
AD
1292002-06-30 Akim Demaille <akim@epita.fr>
130
131 Display items as we display rules.
132
133 * src/gram.h, src/gram.c (rule_lhs_print): New.
134 * src/gram.c (grammar_rules_partial_print): Use it.
135 * src/print.c (print_core): Likewise.
136 * tests/conflicts.at (Defaulted Conflicted Reduction),
137 (Unresolved SR Conflicts): Adjust.
138 (Unresolved SR Conflicts): Adjust and rename as...
139 (Resolved SR Conflicts): this, as was meant.
140 * tests/regression.at (Web2c Report): Adjust.
141
bc933ef1
AD
1422002-06-30 Akim Demaille <akim@epita.fr>
143
144 * src/print.c (state_default_rule_compute): New, extracted from...
145 (print_reductions): here.
146 Pessimize, but clarify the code.
147 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
148
53d4308d
AD
1492002-06-30 Akim Demaille <akim@epita.fr>
150
151 * src/output.c (action_row): Let default_rule be always a rule
152 number.
153
574fb2d5
AD
1542002-06-30 Akim Demaille <akim@epita.fr>
155
156 * src/closure.c (print_firsts, print_fderives, closure):
157 Use BITSET_EXECUTE.
158 * src/lalr.c (lookaheads_print): Likewise.
159 * src/state.c (state_rule_lookaheads_print): Likewise.
160 * src/print_graph.c (print_core): Likewise.
161 * src/print.c (print_reductions): Likewise.
162 * src/output.c (action_row): Likewise.
163 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
164
05811fd7
AD
1652002-06-30 Akim Demaille <akim@epita.fr>
166
167 * src/print_graph.c: Use report_flag.
168
0e4d5753
AD
1692002-06-30 Akim Demaille <akim@epita.fr>
170
171 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
172 to...
173 * src/relation.h, src/relation.c (traverse, relation_digraph)
174 (relation_print, relation_transpose): New.
175
24c7d800
AD
1762002-06-30 Akim Demaille <akim@epita.fr>
177
178 * src/state.h, src/state.c (shifts_to): New.
179 * src/lalr.c (build_relations): Use it.
180
9222837b
AD
1812002-06-30 Akim Demaille <akim@epita.fr>
182
183 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
184 (item_number_of_rule_number, rule_number_of_item_number): New.
185 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
186 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
187 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
188 Propagate their use.
189 Much remains to be done, in particular wrt `shorts' from types.h.
190
260008e5
AD
1912002-06-30 Akim Demaille <akim@epita.fr>
192
193 * src/symtab.c (symbol_new): Initialize the `printer' member.
194
8a731ca8
AD
1952002-06-30 Akim Demaille <akim@epita.fr>
196
197 * src/LR0.c (save_reductions): Remove, replaced by...
198 * src/state.h, src/state.c (state_reductions_set): New.
199 (reductions, errs): Rename as...
200 (reductions_t, errs_t): these.
201 Adjust all dependencies.
202
32e1e0a4
AD
2032002-06-30 Akim Demaille <akim@epita.fr>
204
205 * src/LR0.c (state_list_t, state_list_append): New.
206 (first_state, last_state): Now symbol_list_t.
207 (this_state): Remove.
208 (new_itemsets, append_states, save_reductions): Take a state_t as
209 argument.
210 (set_states, generate_states): Adjust.
211 (save_shifts): Remove, replaced by...
212 * src/state.h, src/state.c (state_shifts_set): New.
213 (shifts): Rename as...
214 (shifts_t): this.
215 Adjust all dependencies.
216 * src/state.h (state_t): Remove the `next' member.
217
e5fb6710
AD
2182002-06-30 Akim Demaille <akim@epita.fr>
219
220 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
221 escaped in slot 0.
222
c7ca99d4
AD
2232002-06-30 Akim Demaille <akim@epita.fr>
224
225 Use hash.h for the state hash table.
226
227 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
228 (allocate_storage): Use state_hash_new.
229 (free_storage): Use state_hash_free.
230 (new_state, get_state): Adjust.
231 * src/lalr.h, src/lalr.c (states): Move to...
232 * src/states.h (state_t): Remove the `link' member, no longer
233 used.
234 * src/states.h, src/states.c: here.
235 (state_hash_new, state_hash_free, state_hash_lookup)
236 (state_hash_insert, states_free): New.
237 * src/states.c (state_table, state_compare, state_hash): New.
238 * src/output.c (output_actions): Do not free states now, since we
239 still need to know the final_state number in `prepare', called
240 afterwards. Do it...
241 * src/main.c (main): here: call states_free after `output'.
242
df0e7316
AD
2432002-06-30 Akim Demaille <akim@epita.fr>
244
245 * src/state.h, src/state.c (state_new): New, extracted from...
246 * src/LR0.c (new_state): here.
247 * src/state.h (STATE_ALLOC): Move to...
248 * src/state.c: here.
249 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
250 * src/state.h, src/state.c: here.
251
39f41916
AD
2522002-06-30 Akim Demaille <akim@epita.fr>
253
254 * src/reader.c (gensym): Rename as...
255 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
256 (getsym): Rename as...
257 (symbol_get): this.
258
d57650a5
AD
2592002-06-30 Akim Demaille <akim@epita.fr>
260
261 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
262 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
263 * src/output.c, src/print.c, src/print_graph.c: Propagate.
264 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
265
5a08f1ce
AD
2662002-06-30 Akim Demaille <akim@epita.fr>
267
268 Make the test suite pass with warnings checked.
269
270 * tests/actions.at (Printers and Destructors): Improve.
271 Avoid unsigned vs. signed issues.
272 * tests/calc.at: Don't exercise the scanner here, do it...
273 * tests/input.at (Torturing the Scanner): here.
274
720623af
PH
2752002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
276
88e7e941 277 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
278 reorganize first lines parallel to yacc.c.
279
fb8135fa
AD
2802002-06-28 Akim Demaille <akim@epita.fr>
281
282 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
283 (b4_token_enum, b4_token_defines): New, factored from...
284 * data/lalr1.cc, data/yacc.c, glr.c: here.
285
41442480
AD
2862002-06-28 Akim Demaille <akim@epita.fr>
287
288 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
289 unused variables.
290 * src/output.c (merger_output): static.
291
e0e5bf84
AD
2922002-06-28 Akim Demaille <akim@epita.fr>
293
294 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
295 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
296 pacify GCC.
297 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 298
676385e2
PH
2992002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
300
301 Accumulated changelog for new GLR parsing features.
302
e0e5bf84 303 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
304 conflicts_total_count.
305 * src/conflicts.h: Ditto.
306 * src/output.c (token_actions): Use the new name.
307 (output_conflicts): Change conflp => conflict_list_heads, and
308 confl => conflict_list for better readability.
309 * data/glr.c: Use the new names.
310 * NEWS: Add self to GLR announcement.
e0e5bf84 311
676385e2
PH
312 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
313
314 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
315 Akim Demaille.
316
317 * data/bison.glr: Change name to glr.c
318 * data/glr.c: Renamed from bison.glr.
319 * data/Makefile.am: Add glr.c
e0e5bf84
AD
320
321 * src/getargs.c:
322
676385e2
PH
323 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
324 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 325
676385e2
PH
326 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
327
328 * data/bison.glr: Be sure to restore the
329 current #line when returning to the skeleton contents after having
330 exposed the input file's #line.
331
332 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
333
334 * data/bison.glr: Bring up to date with changes to bison.simple.
335
336 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
337
338 * data/bison.glr: Correct definitions that use b4_prefix.
339 Various reformatting.
340 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
341 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
342 yytokenp argument; now part of stack.
343 (yychar): Define to behave as documented.
344 (yyclearin): Ditto.
e0e5bf84 345
676385e2
PH
346 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
347
348 * src/reader.h: Add declaration for free_merger_functions.
349
350 * src/reader.c (merge_functions): New variable.
351 (get_merge_function): New function.
352 (free_merger_functions): New function.
353 (readgram): Check for %prec that is not followed by a symbol.
354 Handle %dprec and %merge declarations.
355 (packgram): Initialize dprec and merger fields in rules array.
356
357 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
358 conflict_list_cnt, conflict_list_free): New variables.
359 (table_grow): Also grow conflict_table.
e0e5bf84 360 (prepare_rules): Output dprec and merger tables.
676385e2 361 (conflict_row): New function.
e0e5bf84 362 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
363 default reduction in conflicted states for GLR parser so that there
364 are spaces for the conflict lists.
365 (save_row): Also save conflict information.
366 (token_actions): Allocate conflict list.
367 (merger_output): New function.
368 (pack_vector): Pack conflict table, too.
369 (output_conflicts): New function to output yyconflp and yyconfl.
370 (output_check): Allocate conflict_tos.
371 (output_actions): Output conflict tables, also.
372 (output_skeleton): Output b4_mergers definition.
373 (prepare): Output b4_max_rhs_length definition.
374 Use 'bison.glr' as default skeleton for GLR parsers.
375
376 * src/gram.c (glr_parser): New flag.
377 (grammar_free): Call free_merger_functions.
378
379 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
380 all pairs of conflicting reductions, rather than just all tokens
381 causing conflicts. Needed to size conflict tables.
e0e5bf84 382 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
383 interface.
384 (conflicts_print): Ditto.
385 (count_total_conflicts): New function.
386
387 * src/reader.h (merger_list): New type.
388 (merge_functions): New variable.
389
390 * src/lex.h (tok_dprec, tok_merge): New token types.
391
392 * src/gram.h (rule_s): Add dprec and merger fields.
393 (glr_parser): New flag.
394
395 * src/conflicts.h (count_total_conflicts): New function.
396
397 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
398
399 * doc/bison.texinfo (Generalized LR Parsing): New section.
400 (GLR Parsers): New section.
401 (Language and Grammar): Mention GLR parsing.
402 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
403 Correct typo ("tge" -> "the").
404
405 * data/bison.glr: New skeleton for GLR parsing.
406
407 * tests/cxx-gram.at: New tests for GLR parsing.
408
409 * tests/testsuite.at: Include cxx-gram.at.
410
411 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 412
676385e2
PH
413 * src/parse-gram.y:
414
415 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
416
417 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 418
b5480d74 4192002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
420
421 * src/options.h, src/options.c: Remove.
422 * src/getargs.c (short_options, long_options): New.
423
60491a94
AD
4242002-06-27 Akim Demaille <akim@epita.fr>
425
426 * data/bison.simple, data/bison.c++: Rename as...
427 * data/yacc.c, data/lalr1.cc: these.
428 * doc/bison.texinfo (Environment Variables): Remove.
429
9be0c25b
AD
4302002-06-25 Raja R Harinath <harinath@cs.umn.edu>
431
432 * src/getargs.c (report_argmatch): Initialize strtok().
433
1ae72863
AD
4342002-06-20 Akim Demaille <akim@epita.fr>
435
436 * data/bison.simple (b4_symbol_actions): New, replaces...
437 (b4_symbol_destructor, b4_symbol_printer): these.
438 (yysymprint): Be sure to call YYPRINT only for tokens, and using
439 user token numbers.
440
87542d29
AD
4412002-06-20 Akim Demaille <akim@epita.fr>
442
443 * data/bison.simple (yydestructor): Rename as...
444 (yydestruct): this.
445
1a31ed21
AD
4462002-06-20 Akim Demaille <akim@epita.fr>
447
448 * src/symtab.h, src/symtab.c (symbol_type_set)
449 (symbol_destructor_set, symbol_precedence_set): The location is
450 the last argument.
451 Adjust all callers.
452
e776192e
AD
4532002-06-20 Akim Demaille <akim@epita.fr>
454
455 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
456 internals.
457 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
458 Takes a location.
459 * src/symtab.h, src/symtab.c (symbol_class_set)
460 (symbol_user_token_number_set): Likewise.
461 Adjust all callers.
462 Promote complain_at.
463 * tests/input.at (Type Clashes): Adjust.
464
5c1180b3
AD
4652002-06-20 Akim Demaille <akim@epita.fr>
466
467 * data/bison.simple (YYLEX): Fix the declaration when
468 %pure-parser.
469
e3170060
AD
4702002-06-20 Akim Demaille <akim@epita.fr>
471
472 * data/bison.simple (yysymprint): Don't print the token number,
473 just its name.
474 * tests/actions.at (Destructors): Rename as...
475 (Printers and Destructors): this.
476 Also exercise %printer.
477
253862fd
AD
4782002-06-20 Akim Demaille <akim@epita.fr>
479
480 * data/bison.simple (YYDSYMPRINT): New.
481 Use it to remove many of the #if YYDEBUG/if (yydebug).
482
366eea36
AD
4832002-06-20 Akim Demaille <akim@epita.fr>
484
485 * src/symtab.h, src/symtab.c (symbol_t): printer and
486 printer_location are new members.
487 (symbol_printer_set): New.
488 * src/parse-gram.y (PERCENT_PRINTER): New token.
489 Handle its associated rule.
490 * src/scan-gram.l: Adjust.
491 (handle_destructor_at, handle_destructor_dollar): Rename as...
492 (handle_symbol_code_at, handle_symbol_code_dollar): these.
493 * src/output.c (symbol_printers_output): New.
494 (output_skeleton): Call it.
495 * data/bison.simple (yysymprint): New. Cannot be named yyprint
496 since there are already many grammar files with a user `yyprint'.
497 Replace the calls to YYPRINT to calls to yysymprint.
498 * tests/calc.at: Adjust.
499 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
500 taking advantage of parser very internal details (stack size!).
501
4f25ebb0
AD
5022002-06-20 Akim Demaille <akim@epita.fr>
503
504 * src/scan-gram.l: Complete the scanner with the missing patterns
505 to pacify Flex.
506 Use `quote' and `symbol_tag_get' where appropriate.
507
93b68a0e
AD
5082002-06-19 Akim Demaille <akim@epita.fr>
509
510 * tests/actions.at (Destructors): Augment to test locations.
511 * data/bison.simple (yydestructor): Pass it the current location
512 if locations are enabled.
513 Prototype only when __STDC__ or C++.
514 Change the argument names to move into the yy name space: there is
515 user code here.
516
58612f1d
AD
5172002-06-19 Akim Demaille <akim@epita.fr>
518
74310291
AD
519 * data/bison.simple (b4_pure_if): New.
520 Use it instead of #ifdef YYPURE.
521
5222002-06-19 Akim Demaille <akim@epita.fr>
523
524 * data/bison.simple (b4_location_if): New.
58612f1d
AD
525 Use it instead of #ifdef YYLSP_NEEDED.
526
f25bfb75
AD
5272002-06-19 Akim Demaille <akim@epita.fr>
528
529 Prepare @$ in %destructor, but currently don't bind it in the
530 skeleton, as %location use is not cleaned up yet.
531
532 * src/scan-gram.l (handle_dollar, handle_destructor_at)
533 (handle_action_at): New.
534 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
535 a braced_code_t and a location as additional arguments.
536 (handle_destructor_dollar): Instead of requiring `b4_eval', just
537 unquote one when outputting `b4_dollar_dollar'.
538 Adjust callers.
539 * data/bison.simple (b4_eval): Remove.
540 (b4_symbol_destructor): Adjust.
541 * tests/input.at (Invalid @n): Adjust.
542
c732d2c6
AD
5432002-06-19 Zack Weinberg <zack@codesourcery.com>
544
545 * doc/bison.texinfo: Document ability to have multiple
546 prologue sections.
547
8c165d89
AD
5482002-06-18 Akim Demaille <akim@epita.fr>
549
550 * src/files.c (compute_base_names): When computing the output file
551 names from the input file name, strip the directory part.
552
ca98bf57
AD
5532002-06-18 Akim Demaille <akim@epita.fr>
554
555 * data/bison.simple.new: Comment changes.
556 Reported by Andreas Schwab.
557
0bfb02ff
AD
5582002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
559
560 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
561 there are no `label `yyoverflowlab' defined but not used' warnings
562 when yyoverflow is defined.
563
24c0aad7
AD
5642002-06-18 Akim Demaille <akim@epita.fr>
565
566 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
567 new member.
568 (symbol_destructor_set): Adjust.
569 * src/output.c (symbol_destructors_output): Output the destructor
570 locations.
571 Output the symbol name.
572 * data/bison.simple (b4_symbol_destructor): Adjust.
573
5719c109
AD
5742002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
575 and Akim Demaille <akim@epita.fr>
576
577 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
578 what's left on the stack when the error recovery hits EOF.
579 * tests/actions.at (Destructors): Complete to exercise this case.
580
9280d3ef
AD
5812002-06-17 Akim Demaille <akim@epita.fr>
582
583 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
584 arguments is really empty, not only equal to `[]'.
585 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
586 member.
587 (symbol_destructor_set): New.
588 * src/output.c (symbol_destructors_output): New.
589 * src/reader.h (brace_code_t, current_braced_code): New.
590 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
591 (handle_dollar): Rename as...
592 (handle_action_dollar): this.
593 (handle_destructor_dollar): New.
594 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
595 (grammar_declaration): Use it.
596 * data/bison.simple (yystos): Is always defined.
597 (yydestructor): New.
598 * tests/actions.at (Destructors): New.
599 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
600
dafdc66f
AD
6012002-06-17 Akim Demaille <akim@epita.fr>
602
603 * src/symlist.h, src/symlist.c (symbol_list_length): New.
604 * src/scan-gram.l (handle_dollar, handle_at): Compute the
605 rule_length only when needed.
606 * src/output.c (actions_output, token_definitions_output): Output
607 the full M4 block.
608 * src/symtab.c: Don't access directly to the symbol tag, use
609 symbol_tag_get.
610 * src/parse-gram.y: Use symbol_list_free.
611
56c47203
AD
6122002-06-17 Akim Demaille <akim@epita.fr>
613
614 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
615 (symbol_list_prepend, get_type_name): Move to...
616 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
617 (symbol_list_prepend, symbol_list_n_type_name_get): here.
618 Adjust all callers.
619 (symbol_list_free): New.
620 * src/scan-gram.l (handle_dollar): Takes a location.
621 * tests/input.at (Invalid $n): Adjust.
622
1e0bab92
AD
6232002-06-17 Akim Demaille <akim@epita.fr>
624
625 * src/reader.h, src/reader.c (symbol_list_new): Export it.
626 (symbol_list_prepend): New.
627 * src/parse-gram.y (%union): `list' is a new member.
628 (symbols.1): New, replaces...
629 (terms_to_prec.1, nterms_to_type.1): these.
630 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
631 Take a location as additional argument.
632 Adjust all callers.
633
04e60654
AD
6342002-06-15 Akim Demaille <akim@epita.fr>
635
636 * src/parse-gram.y: Move %token in the declaration section so that
637 we don't depend upon CVS Bison.
638
10e5b8bd
AD
6392002-06-15 Akim Demaille <akim@epita.fr>
640
641 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
642 * src/print.c (print_core): Use it.
643
9801d40c
AD
6442002-06-15 Akim Demaille <akim@epita.fr>
645
646 * src/conflicts.c (log_resolution): Accept the rule involved in
647 the sr conflicts instead of the lookahead number that points to
648 that rule.
649 (flush_reduce): Accept the current lookahead vector as argument,
650 instead of the index in LA.
651 (resolve_sr_conflict): Accept the current number of lookahead
652 bitset to consider for the STATE, instead of the index in LA.
653 (set_conflicts): Adjust.
654 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
655
c0263492
AD
6562002-06-15 Akim Demaille <akim@epita.fr>
657
658 * src/state.h (state_t): Replace the `lookaheadsp' member, a
659 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
660 Adjust all dependencies.
661 * src/lalr.c (initialize_lookaheads): Split into...
662 (states_lookaheads_count, states_lookaheads_initialize): these.
663 (lalr): Adjust.
664
9757c359
AD
6652002-06-15 Akim Demaille <akim@epita.fr>
666
667 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
668 out of...
669 (grammar_rules_print): here.
670 * src/reduce.c (reduce_output): Use it.
671 * tests/reduce.at (Useless Rules, Reduced Automaton)
672 (Underivable Rules): Adjust.
673
6b98e4b5
AD
6742002-06-15 Akim Demaille <akim@epita.fr>
675
676 Copy BYacc's nice way to report the grammar.
677
678 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
679 New.
680 Don't print the rules' location, it is confusing and useless.
681 (rule_print): Use grammar_rhs_print.
682 * src/print.c (print_grammar): Use grammar_rules_print.
683
6b98e4b5
AD
6842002-06-15 Akim Demaille <akim@epita.fr>
685
686 Complete and rationalize `useless thing' warnings.
687
688 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
689 (symbol_tag_print): New.
690 Use them everywhere in place of accessing directly the tag member.
691 * src/gram.h, src/gram.c (rule_print): New.
692 Use it where a rule used to be printed `by hand'.
693 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
694 (reduce_grammar_tables): Report the useless rules.
695 (reduce_print): Useless things are a warning, not an error.
696 Report it as such.
697 * tests/reduce.at (Useless Nonterminals, Useless Rules):
698 (Reduced Automaton, Underivable Rules): Adjust.
699 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
700 * tests/conflicts.at (Unresolved SR Conflicts)
701 (Solved SR Conflicts): Adjust.
702
ee000ba4
AD
7032002-06-15 Akim Demaille <akim@epita.fr>
704
705 Let symbols have a location.
706
707 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
708 (getsym): Adjust.
709 Adjust all callers.
710 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
711 Use location_t, not int.
712 * src/symtab.c (symbol_check_defined): Take advantage of the
713 location.
714 * tests/regression.at (Invalid inputs): Adjust.
715
8efe435c
AD
7162002-06-15 Akim Demaille <akim@epita.fr>
717
718 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
719 (input): Don't try to initialize yylloc here, do it in the
720 scanner.
721 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
722 * src/gram.h (rule_t): Change line and action_line into location
723 and action_location, of location_t type.
724 Adjust all dependencies.
725 * src/location.h, src/location.c (empty_location): New.
726 * src/reader.h, src/reader.c (grammar_start_symbol_set)
727 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
728 (grammar_current_rule_symbol_append)
729 (grammar_current_rule_action_append): Expect a location as argument.
730 * src/reader.c (grammar_midrule_action): Adjust to attach an
731 action's location as dummy symbol location.
732 * src/symtab.h, src/symtab.c (startsymbol_location): New.
733 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
734 the line numbers.
735
1921f1d7
AD
7362002-06-14 Akim Demaille <akim@epita.fr>
737
738 Grammar declarations may be found in the grammar section.
739
740 * src/parse-gram.y (rules_or_grammar_declaration): New.
741 (declarations): Each declaration may end with a semicolon, not
742 just...
743 (grammar_declaration): `"%union"'.
744 (grammar): Branch to rules_or_grammar_declaration.
745
4515534c
AD
7462002-06-14 Akim Demaille <akim@epita.fr>
747
748 * src/main.c (main): Invoke scanner_free.
749
f958596b
AD
7502002-06-14 Akim Demaille <akim@epita.fr>
751
752 * src/output.c (m4_invoke): Extracted from...
753 (output_skeleton): here.
754 Free tempfile.
755
2c569025
AD
7562002-06-14 Akim Demaille <akim@epita.fr>
757
758 * src/parse-gram.y (directives, directive, gram)
759 (grammar_directives, precedence_directives, precedence_directive):
760 Rename as...
761 (declarations, declaration, grammar, grammar_declaration)
762 (precedence_declaration, precedence_declarator): these.
763 (symbol_declaration): New.
764
592e8d4d
AD
7652002-06-14 Akim Demaille <akim@epita.fr>
766
767 * src/files.c (action_obstack): Remove, unused.
768 (output_obstack): Remove it, and all its dependencies, as it is no
769 longer needed.
770 * src/reader.c (epilogue_set): Build the epilogue in the
771 muscle_obstack.
772 * src/output.h, src/output.c (muscle_obstack): Move to...
773 * src/muscle_tab.h, src/muscle_tab.h: here.
774 (muscle_init): Initialize muscle_obstack.
775 (muscle_free): New.
776 * src/main.c (main): Call it.
777
0c15323d
AD
7782002-06-14 Akim Demaille <akim@epita.fr>
779
780 * src/location.h: New, extracted from...
781 * src/reader.h: here.
782 * src/Makefile.am (noinst_HEADERS): Merge into
783 (bison_SOURCES): this.
784 Add location.h.
785 * src/parse-gram.y: Use location_t instead of Bison's.
786 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
787 Use location_t instead of ints.
788
e96c9728
AD
7892002-06-14 Akim Demaille <akim@epita.fr>
790
791 * data/bison.simple, data/bison.c++: Be sure to restore the
792 current #line when returning to the skeleton contents after having
793 exposed the input file's #line.
794
75d1fe16
AD
7952002-06-12 Akim Demaille <akim@epita.fr>
796
797 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
798 eager.
799 * tests/actions.at (Exotic Dollars): New.
800
6c35d22c
AD
8012002-06-12 Akim Demaille <akim@epita.fr>
802
803 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
804 ['"/] too eagerly.
805 * tests/input.at (Torturing the Scanner): New.
806
1d6412ad
AD
8072002-06-11 Akim Demaille <akim@epita.fr>
808
809 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
810 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
811 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
812 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
813 * src/reader.c (reader): Use it.
814
4cdb01db
AD
8152002-06-11 Akim Demaille <akim@epita.fr>
816
817 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
818 Adjust all callers.
819 (scanner_last_string_free): New.
820
44995b2e
AD
8212002-06-11 Akim Demaille <akim@epita.fr>
822
823 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
824 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
825 (last_string, YY_OBS_FREE): New.
826 Use them when returning an ID.
827
e9955c83
AD
8282002-06-11 Akim Demaille <akim@epita.fr>
829
830 Have Bison grammars parsed by a Bison grammar.
831
832 * src/reader.c, src/reader.h (prologue_augment): New.
833 * src/reader.c (copy_definition): Remove.
834
835 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
836 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
837 (grammar_current_rule_prec_set, grammar_current_rule_check)
838 (grammar_current_rule_symbol_append)
839 (grammar_current_rule_action_append): Export.
840 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
841 (symbol_list_action_append): Remove.
842 Hook the routines from reader.
843 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
844 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
845
846 * src/reader.c (read_declarations): Remove, unused.
847
848 * src/parse-gram.y: Handle the epilogue.
849 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
850 (grammar_start_symbol_set): this.
851 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
852 * src/reader.c (readgram): Remove, unused.
853 (reader): Adjust to insert eoftoken and axiom where appropriate.
854
855 * src/reader.c (copy_dollar): Replace with...
856 * src/scan-gram.h (handle_dollar): this.
857 * src/parse-gram.y: Remove `%thong'.
858
859 * src/reader.c (copy_at): Replace with...
860 * src/scan-gram.h (handle_at): this.
861
862 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
863 New.
864
865 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
866 time being.
867
868 * src/reader.h, src/reader.c (grammar_rule_end): New.
869
870 * src/parse.y (current_type, current_class): New.
871 Implement `%nterm', `%token' support.
872 Merge `%term' into `%token'.
873 (string_as_id): New.
874 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
875 type name.
876
877 * src/parse-gram.y: Be sure to handle properly the beginning of
878 rules.
879
880 * src/parse-gram.y: Handle %type.
881 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
882
883 * src/parse-gram.y: More directives support.
884 * src/options.c: No longer handle source directives.
885
886 * src/parse-gram.y: Fix %output.
887
888 * src/parse-gram.y: Handle %union.
889 Use the prologue locations.
890 * src/reader.c (parse_union_decl): Remove.
891
892 * src/reader.h, src/reader.c (epilogue_set): New.
893 * src/parse-gram.y: Use it.
894
895 * data/bison.simple, data/bison.c++: b4_stype is now either not
896 defined, then default to int, or to the contents of %union,
897 without `union' itself.
898 Adjust.
899 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
900
901 * src/output.c (actions_output): Don't output braces, as they are
902 already handled by the scanner.
903
904 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
905 characters to themselves.
906
907 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
908 that the epilogue has a proper #line.
909
910 * src/parse-gram.y: Handle precedence/associativity.
911
912 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
913 a terminal.
914 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
915 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
916 at all to define terminals that cannot be emitted.
917
918 * src/scan-gram.l: Escape M4 characters.
919
920 * src/scan-gram.l: Working properly with escapes in user
921 strings/characters.
922
923 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
924 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
925 grammar.
926 Use more modest sizes, as for the time being the parser does not
927 release memory, and therefore the process swallows a huge amount
928 of memory.
929
930 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
931 stricter %token grammar.
932
933 * src/symtab.h (associativity): Add `undef_assoc'.
934 (symbol_precedence_set): Do nothing when passed an undef_assoc.
935 * src/symtab.c (symbol_check_alias_consistence): Adjust.
936
937 * tests/regression.at (Invalid %directive): Remove, as it is now
938 meaningless.
939 (Invalid inputs): Adjust to the new error messages.
940 (Token definitions): The new grammar doesn't allow too many
941 eccentricities.
942
943 * src/lex.h, src/lex.c: Remove.
944 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
945 (copy_character, copy_string2, copy_string, copy_identifier)
946 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
947 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
948 (parse_action): Remove.
949 * po/POTFILES.in: Adjust.
950
2e047461
AD
9512002-06-11 Akim Demaille <akim@epita.fr>
952
953 * src/reader.c (parse_action): Don't store directly into the
954 rule's action member: return the action as a string.
955 Don't require `rule_length' as an argument: compute it.
956 (grammar_current_rule_symbol_append)
957 (grammar_current_rule_action_append): New, eved out from
958 (readgram): here.
959 Remove `action_flag', `rulelength', unused now.
960
9af3fbce
AD
9612002-06-11 Akim Demaille <akim@epita.fr>
962
963 * src/reader.c (grammar_current_rule_prec_set).
964 (grammar_current_rule_check): New, eved out from...
965 (readgram): here.
966 Remove `xaction', `first_rhs': useless.
967 * tests/input.at (Type clashes): New.
968 * tests/existing.at (GNU Cim Grammar): Adjust.
969
1485e106
AD
9702002-06-11 Akim Demaille <akim@epita.fr>
971
972 * src/reader.c (grammar_midrule_action): New, Eved out from
973 (readgram): here.
974
da4160c3
AD
9752002-06-11 Akim Demaille <akim@epita.fr>
976
977 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
978 New.
979 (readgram): Use them as replacement of inlined code, crule and
980 crule1.
981
f6d0f937
AD
9822002-06-11 Akim Demaille <akim@epita.fr>
983
984 * src/reader.c (grammar_end, grammar_symbol_append): New.
985 (readgram): Use them.
986 Make the use of `p' as local as possible.
987
69078d4b
AD
9882002-06-10 Akim Demaille <akim@epita.fr>
989
990 GCJ's parser requires the tokens to be defined before the prologue.
991
992 * data/bison.simple: Output the token definition before the user's
993 prologue.
994 * tests/regression.at (Braces parsing, Duplicate string)
995 (Mixing %token styles): Check the output from bison.
996 (Early token definitions): New.
997
5e424082
AD
9982002-06-10 Akim Demaille <akim@epita.fr>
999
1000 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1001 assigning twice the same user number to a token, so that we can
1002 use it in...
1003 * src/lex.c (lex): here.
1004 Also use `symbol_class_set' instead of hand written code.
1005 * src/reader.c (parse_assoc_decl): Likewise.
1006
44536b35
AD
10072002-06-10 Akim Demaille <akim@epita.fr>
1008
1009 * src/symtab.c, src/symtab.c (symbol_class_set)
1010 (symbol_user_token_number_set): New.
1011 * src/reader.c (parse_token_decl): Use them.
1012 Use a switch instead of ifs.
1013 Use a single argument.
1014
8b9f2372
AD
10152002-06-10 Akim Demaille <akim@epita.fr>
1016
1017 Remove `%thong' support as it is undocumented, unused, duplicates
1018 `%token's job, and creates useless e-mail traffic with people who
1019 want to know what it is, why it is undocumented, unused, and
1020 duplicates `%token's job.
1021
1022 * src/reader.c (parse_thong_decl): Remove.
1023 * src/options.c (option_table): Remove "thong".
1024 * src/lex.h (tok_thong): Remove.
1025
3ae2b51f
AD
10262002-06-10 Akim Demaille <akim@epita.fr>
1027
1028 * src/symtab.c, src/symtab.c (symbol_type_set)
1029 (symbol_precedence_set): New.
1030 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1031 (value_components_used): Remove, unused.
1032
2f1afb73
AD
10332002-06-09 Akim Demaille <akim@epita.fr>
1034
1035 Move symbols handling code out of the reader.
1036
1037 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1038 (axiom): Move to...
1039 * src/symtab.h, src/symtab.c: here.
1040
1041 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1042 * src/reader.c (startval): Rename as...
1043 * src/symtab.h, src/symtab.c (startsymbol): this.
1044 * src/reader.c: Adjust.
1045
1046 * src/reader.c (symbol_check_defined, symbol_make_alias)
1047 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1048 (token_translations_init)
1049 Move to...
1050 * src/symtab.c: here.
1051 * src/reader.c (packsymbols): Move to...
1052 * src/symtab.h, src/symtab.c (symbols_pack): here.
1053 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1054 argument.
1055
e9bca3ad
AD
10562002-06-03 Akim Demaille <akim@epita.fr>
1057
1058 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1059 then statements.
1060
86eff183
AD
10612002-06-03 Akim Demaille <akim@epita.fr>
1062
1063 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1064 structs with non literals.
1065 * src/scan-skel.l: never-interactive.
1066 * src/conflicts.c (enum conflict_resolution_e): No trailing
1067 comma.
1068 * src/getargs.c (usage): Split long literal strings.
1069 Reported by Hans Aberg.
1070
717be197
AD
10712002-05-28 Akim Demaille <akim@epita.fr>
1072
1073 * data/bison.c++: Use C++ ostreams.
1074 (cdebug_): New member.
1075
670ddffd
AD
10762002-05-28 Akim Demaille <akim@epita.fr>
1077
1078 * src/output.c (output_skeleton): Be sure to allocate enough room
1079 for `/' _and_ for `\0' in full_skeleton.
1080
769b430f
AD
10812002-05-28 Akim Demaille <akim@epita.fr>
1082
1083 * data/bison.c++: Catch up with bison.simple:
1084 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1085 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1086 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1087 and popping traces.
1088
7067cb36
PH
10892002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1090
1091 * src/output.c (output_skeleton): Put an explicit path in front of
1092 the skeleton file name, rather than relying on the -I directory,
1093 to partially alleviate effects of having a skeleton file lying around
1094 in the current directory.
769b430f 1095
4a713ec2
PH
10962002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1097
769b430f 1098 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
1099 obstack_printf should be obstack_fgrow1.
1100
b408954b
AD
11012002-05-26 Akim Demaille <akim@epita.fr>
1102
1103 * src/state.h (state_t): `solved_conflicts' is a new member.
1104 * src/LR0.c (new_state): Set it to 0.
1105 * src/conflicts.h, src/conflicts.c (print_conflicts)
1106 (free_conflicts, solve_conflicts): Rename as...
1107 (conflicts_print, conflicts_free, conflicts_solve): these.
1108 Adjust callers.
1109 * src/conflicts.c (enum conflict_resolution_e)
1110 (solved_conflicts_obstack): New, used by...
1111 (log_resolution): this.
1112 Adjust to attach the conflict resolution to each state.
1113 Complete the description with the precedence/associativity
1114 information.
1115 (resolve_sr_conflict): Adjust.
1116 * src/print.c (print_state): Output its solved_conflicts.
1117 * tests/conflicts.at (Unresolved SR Conflicts)
1118 (Solved SR Conflicts): Exercise --report=all.
1119
a49aecd5
AD
11202002-05-26 Akim Demaille <akim@epita.fr>
1121
1122 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1123 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1124 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1125 (token_number_t, item_number_as_token_number)
1126 (token_number_as_item_number, muscle_insert_token_number_table):
1127 Rename as...
1128 (symbol_number_t, item_number_as_symbol_number)
1129 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1130 these, since it is more appropriate.
1131
5504898e
AD
11322002-05-26 Akim Demaille <akim@epita.fr>
1133
1134 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1135 `Error:' lines.
1136 * data/bison.simple (yystos) [YYDEBUG]: New.
1137 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1138 error recovery.
1139 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1140
ec3bc396
AD
11412002-05-25 Akim Demaille <akim@epita.fr>
1142
1143 * doc/bison.texinfo (Debugging): Split into...
1144 (Tracing): this new section, its former contents, and...
1145 (Understanding): this new section.
1146 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1147 by...
1148 (report_flag): this.
1149 Adjust all dependencies.
1150 (report_args, report_types, report_argmatch): New.
1151 (usage, getargs): Report/support -r, --report.
1152 * src/options.h
1153 (struct option_table_struct): Rename as..,
1154 (struct option_table_s): this.
1155 Rename the `set_flag' member to `flag' to match with getopt_long's
1156 struct.
1157 * src/options.c (option_table): Split verbose into an entry for
1158 %verbose, and another for --verbose.
1159 Support --report/-r, so remove -r from the obsolete --raw.
1160 * src/print.c: Attach full item sets and lookaheads reports to
1161 report_flag instead of trace_flag.
1162 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1163
78df8250
PE
11642002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1165 and Paul Eggert <eggert@twinsun.com>
769b430f 1166
78df8250
PE
1167 * data/bison.simple (yyparse): Correct error handling to conform to
1168 POSIX and yacc. Specifically, after syntax error is discovered,
1169 do not reduce further before shifting the error token.
1170 Clean up the code a bit by removing the labels yyerrdefault,
1171 yyerrhandle, yyerrpop.
1172 * NEWS: Document the above.
1173
c0c9ea05
PH
11742002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1175
1176 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1177 type; it isn't always big enough, since it doesn't necessarily
1178 include non-terminals.
769b430f 1179 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
1180 the latter can be removed.
1181 (yy_token_number_type): Remove, only one use.
1182 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1183 don't use TokenNumberType as element type.
769b430f 1184
c0c9ea05
PH
1185 * tests/regression.at: Modify expected output to agree with change
1186 to yyr1 and yytranslate.
769b430f 1187
6390a83f
FK
11882002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1189
1190 * src/reader.c (parse_action): Use copy_character instead of
1191 obstack_1grow.
1192
db7c8e9a
AD
11932002-05-13 Akim Demaille <akim@epita.fr>
1194
1195 * tests/regression.at (Token definitions): Prototype yylex and
1196 yyerror.
1197
fcc61800
PH
11982002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1199
158c687b 1200 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
1201 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1202 32-bit arithmetic.
1203 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1204
5683e9b2
AD
12052002-05-07 Akim Demaille <akim@epita.fr>
1206
1207 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1208 avoid GCC warnings.
1209
0c2d3f4c
AD
12102002-05-07 Akim Demaille <akim@epita.fr>
1211
1212 Kill GCC warnings.
1213
1214 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1215 over the RHS of each rule.
1216 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1217 * src/state.h (state_t): Member `nitems' is unsigned short.
1218 * src/LR0.c (get_state): Adjust.
1219 * src/reader.c (packgram): Likewise.
1220 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1221 `Type'.
1222 (muscle_insert_int_table): Remove, unused.
1223 (prepare_rules): Remove `max'.
1224
1565b720
AD
12252002-05-06 Akim Demaille <akim@epita.fr>
1226
1227 * src/closure.c (print_firsts): Display of the symbol tags.
1228 (bitmatrix_print): Move to...
1229 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1230 here.
1231 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1232
cfaee611
AD
12332002-05-06 Akim Demaille <akim@epita.fr>
1234
1235 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1236 hash_do_for_each.
1237
458be8e0
AD
12382002-05-06 Akim Demaille <akim@epita.fr>
1239
1240 * src/LR0.c (new_state, get_state): Instead of using the global
1241 `kernel_size' and `kernel_base', have two new arguments:
1242 `core_size' and `core'.
1243 Adjust callers.
1244
a900a624
AD
12452002-05-06 Akim Demaille <akim@epita.fr>
1246
1247 * src/reader.c (packgram): No longer end `ritem' with a 0
1248 sentinel: it is not used.
1249
d4e7d3a1
AD
12502002-05-05 Akim Demaille <akim@epita.fr>
1251
1252 New experimental feature: display the lookaheads in the report and
1253 graph.
1254
1255 * src/print (print_core): When --trace-flag, display the rules
1256 lookaheads.
1257 * src/print_graph.c (print_core): Likewise.
1258 Swap the arguments.
1259 Adjust caller.
1260
39ceb25b
AD
12612002-05-05 Akim Demaille <akim@epita.fr>
1262
1263 * tests/torture.at (Many lookaheads): New test.
1264
5372019f
AD
12652002-05-05 Akim Demaille <akim@epita.fr>
1266
1267 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
1268 (GENERATE_MUSCLE_INSERT_TABLE): this.
1269 (output_int_table, output_unsigned_int_table, output_short_table)
1270 (output_token_number_table, output_item_number_table): Replace with...
1271 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
1272 (muscle_insert_short_table, muscle_insert_token_number_table)
1273 (muscle_insert_item_number_table): these.
1274 Adjust all callers.
1275 (prepare_tokens): Don't free `translations', since...
1276 * src/reader.h, src/reader.c (grammar_free): do it.
1277 Move to...
1278 * src/gram.h, src/gram.c (grammar_free): here.
1279 * data/bison.simple, data/bison.c++: b4_token_number_max is now
1280 b4_translate_max.
1281
5df5f6d5
AD
12822002-05-05 Akim Demaille <akim@epita.fr>
1283
1284 * src/output.c (output_unsigned_int_table): New.
1285 (prepare_rules): `i' is unsigned.
1286 `prhs', `rline', `r2' are unsigned int.
1287 Rename muscle `rhs_number_max' as `rhs_max'.
1288 Output muscles `prhs_max', `rline_max', and `r2_max'.
1289 Free rline and r1.
1290 * data/bison.simple, data/bison.c++: Adjust to use these muscles
1291 to compute types instead of constant types.
1292 * tests/regression.at (Web2c Actions): Adjust.
1293
b87f8b21
AD
12942002-05-04 Akim Demaille <akim@epita.fr>
1295
1296 * src/symtab.h (SALIAS, SUNDEF): Rename as...
1297 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
1298 Adjust dependencies.
1299 * src/output.c (token_definitions_output): Be sure not to output a
1300 `#define 'a'' when fed with `%token 'a' "a"'.
1301 * tests/regression.at (Token definitions): New.
1302
8bb936e4
PE
13032002-05-03 Paul Eggert <eggert@twinsun.com>
1304
1305 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
1306 for K&R C.
1307
13082002-05-03 gettextize <bug-gnu-gettext@gnu.org>
1309
1310 * Makefile.am (SUBDIRS): Remove intl.
1311 (EXTRA_DIST): Add config/config.rpath.
1312
53c71a12
AD
13132002-05-03 Akim Demaille <akim@epita.fr>
1314
1315 * data/bison.simple (m4_if): Don't output empty enums.
1316 And actually, output valid enum definitions :(.
1317
289dd0cf
AD
13182002-05-03 Akim Demaille <akim@epita.fr>
1319
1320 * configure.bat: Remove, completely obsolete.
1321 * Makefile.am (EXTRA_DIST): Adjust.
1322 Don't distribute config.rpath...
1323 * config/Makefile.am (EXTRA_DIST): Do it.
1324
db85e524
AD
13252002-05-03 Akim Demaille <akim@epita.fr>
1326
1327 * configure.in (GETTEXT_VERSION): New.
1328 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
1329
83ccf991
AD
13302002-05-03 Akim Demaille <akim@epita.fr>
1331
1332 * data/bison.simple (b4_token_enum): New.
1333 (b4_token_defines): Use it to output tokens both as #define and
1334 enums.
1335 Suggested by Paul Eggert.
1336 * src/output.c (token_definitions_output): Don't output spurious
1337 white spaces.
1338
1f418995
AD
13392002-05-03 Akim Demaille <akim@epita.fr>
1340
1341 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1342
45119f04
RA
13432002-05-02 Robert Anisko <robert@lrde.epita.fr>
1344
1345 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
1346 Update the stack class, give a try to deque as the default container.
1347
b2d52318
AD
13482002-05-02 Akim Demaille <akim@epita.fr>
1349
1350 * data/bison.simple (yyparse): Do not implement @$ = @1.
1351 (YYLLOC_DEFAULT): Adjust to do it.
1352 * doc/bison.texinfo (Location Default Action): Fix.
1353
3a8b4109
AD
13542002-05-02 Akim Demaille <akim@epita.fr>
1355
1356 * src/reader.c (parse_braces): Merge into...
1357 (parse_action): this.
1358
84614e13
AD
13592002-05-02 Akim Demaille <akim@epita.fr>
1360
1361 * configure.in (ALL_LINGUAS): Remove.
1362 * po/LINGUAS, hr.po: New.
1363
fdbcd8e2
AD
13642002-05-02 Akim Demaille <akim@epita.fr>
1365
1366 Remove the so called hairy (semantic) parsers.
1367
1368 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
1369 * src/gram.h, src/gram.c (semantic_parser): Remove.
1370 (rule_t): Remove the guard and guard_line members.
1371 * src/lex.h (token_t): remove tok_guard.
1372 * src/options.c (option_table): Remove %guard and %semantic_parser
1373 support.
1374 * src/output.c, src/output.h (guards_output): Remove.
1375 (prepare): Adjust.
1376 (token_definitions_output): Don't output the `T'
1377 tokens (???).
1378 (output_skeleton): Don't output the guards.
1379 * src/files.c, src/files.c (attrsfile): Remove.
1380 * src/reader.c (symbol_list): Remove the guard and guard_line
1381 members.
1382 Adjust dependencies.
1383 (parse_guard): Remove.
1384 * data/bison.hairy: Remove.
1385 * doc/bison.texinfo (Environment Variables): Remove occurrences of
1386 BISON_HAIRY.
1387
82b6cb3f
AD
13882002-05-02 Akim Demaille <akim@epita.fr>
1389
1390 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
1391 (parse_guard): Rename the formal argument `stack_offset' as
1392 `rule_length', which is more readable.
1393 Adjust callers.
1394 (copy_at, copy_dollar): Instead of outputting the hard coded
1395 values of $$, $n and so forth, output invocation to b4_lhs_value,
1396 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
1397 Note: this patch partially drops `semantic-parser' support: it
1398 always does `rule_length - n', where semantic parsers ought to
1399 always use `-n'.
82b6cb3f
AD
1400 * data/bison.simple, data/bison.c++ (b4_lhs_value)
1401 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
1402
6cbfbcc5
AD
14032002-05-02 Akim Demaille <akim@epita.fr>
1404
1405 * configure.in (AC_INIT): Bump to 1.49b.
1406 (AM_INIT_AUTOMAKE): Short invocation.
1407
b8548114
AD
14082002-05-02 Akim Demaille <akim@epita.fr>
1409
1410 Version 1.49a.
1411
c20cd1fa
AD
14122002-05-01 Akim Demaille <akim@epita.fr>
1413
1414 * src/skeleton.h: Remove.
1415
8a9566d4
AD
14162002-05-01 Akim Demaille <akim@epita.fr>
1417
1418 * src/skeleton.h: Fix the #endif.
1419 Reported by Magnus Fromreide.
1420
8c6d399a
PE
14212002-04-26 Paul Eggert <eggert@twinsun.com>
1422
1423 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
1424 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 1425 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 1426
2b7ed18a
RA
14272002-04-25 Robert Anisko <robert@lrde.epita.fr>
1428
1429 * src/scan-skel.l: Postprocess quadrigraphs.
1430
1431 * src/reader.c (copy_character): New function, used to output
1432 single characters while replacing `[' and `]' with quadrigraphs, to
1433 avoid troubles with M4 quotes.
1434 (copy_comment): Output characters with copy_character.
1435 (read_additionnal_code): Likewise.
1436 (copy_string2): Likewise.
1437 (copy_definition): Likewise.
1438
1439 * tests/calc.at: Exercise M4 quoting.
1440
34a89c50
AD
14412002-04-25 Akim Demaille <akim@epita.fr>
1442
1443 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
1444 between `!' and the command.
1445 Reported by Paul Eggert.
1446
0dd1580a
RA
14472002-04-24 Robert Anisko <robert@lrde.epita.fr>
1448
1449 * tests/calc.at: Exercise prologue splitting.
1450
1451 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
1452 `b4_post_prologue' instead of `b4_prologue'.
1453
1454 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
1455 muscles.
1456 (output): Free pre_prologue_obstack and post_prologue_obstack.
1457 * src/files.h, src/files.c (attrs_obstack): Remove.
1458 (pre_prologue_obstack, post_prologue_obstack): New.
1459 * src/reader.c (copy_definition): Add a parameter to specify the
1460 obstack to fill, instead of using attrs_obstack unconditionally.
1461 (read_declarations): Pass pre_prologue_obstack to copy_definition if
1462 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
1463
83c1796f
PE
14642002-04-23 Paul Eggert <eggert@twinsun.com>
1465
1466 * data/bison.simple: Remove unnecessary commentary and white
1467 space differences from 1_29-branch.
1468 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
1469
1470 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
1471 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
1472 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
1473 constructors or destructors.
1474
1475 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
1476
1207eeac
AD
14772002-04-23 Akim Demaille <akim@epita.fr>
1478
1479 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
1480 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
1481 location with columns.
1482 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
1483 All reported by Paul Eggert.
1484
78ab8f67
AD
14852002-04-22 Akim Demaille <akim@epita.fr>
1486
1487 * src/reduce.c (dump_grammar): Move to...
1488 * src/gram.h, src/gram.c (grammar_dump): here.
1489 Be sure to separate long item numbers.
1490 Don't read the members of a rule's prec if its nil.
1491
133c20e2
AD
14922002-04-22 Akim Demaille <akim@epita.fr>
1493
1494 * src/output.c (table_size, table_grow): New.
1495 (MAXTABLE): Remove, replace uses with table_size.
1496 (pack_vector): Instead of dying when the table is too big, grow it.
1497
9515e8a7
AD
14982002-04-22 Akim Demaille <akim@epita.fr>
1499
1500 * data/bison.simple (yyr1): Its type is that of a token number.
1501 * data/bison.c++ (r1_): Likewise.
1502 * tests/regression.at (Web2c Actions): Adjust.
1503
23c5a174
AD
15042002-04-22 Akim Demaille <akim@epita.fr>
1505
1506 * src/reader.c (token_translations_init): 256 is now the default
1507 value for the error token, i.e., it will be assigned another
1508 number if the user assigned 256 to one of her tokens.
1509 (reader): Don't force 256 to error.
1510 * doc/bison.texinfo (Symbols): Adjust.
1511 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
1512 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
1513 etc. instead of 10, 20, 30 (which was used to `jump' over error
1514 (256) and undefined (2)).
1515
5fbb0954
AD
15162002-04-22 Akim Demaille <akim@epita.fr>
1517
1518 Propagate more token_number_t.
1519
1520 * src/gram.h (token_number_as_item_number)
1521 (item_number_as_token_number): New.
1522 * src/output.c (GENERATE_OUTPUT_TABLE): New.
1523 Use it to create output_item_number_table and
1524 output_token_number_table.
1525 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1526 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
1527 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
1528 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
1529
4f940944
AD
15302002-04-22 Akim Demaille <akim@epita.fr>
1531
1532 * src/output.h, src/output.c (get_lines_number): Remove.
1533
3ded9a63
AD
15342002-04-19 Akim Demaille <akim@epita.fr>
1535
1536 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
1537 as Lex/Flex'.
1538 (Debugging): More details about enabling the debugging features.
1539 (Table of Symbols): Describe $$, $n, @$, and @n.
1540 Suggested by Tim Josling.
1541
e0c471a9
AD
15422002-04-19 Akim Demaille <akim@epita.fr>
1543
1544 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
1545
fecc10cd
AD
15462002-04-10 Akim Demaille <akim@epita.fr>
1547
1548 * src/system.h: Rely on HAVE_LIMITS_H.
1549 Suggested by Paul Eggert.
1550
51dec47b
AD
15512002-04-09 Akim Demaille <akim@epita.fr>
1552
1553 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
1554 full stderr, and strip it according to the bison options, instead
1555 of composing the error message from different bits.
1556 This makes it easier to check for several error messages.
1557 Adjust all the invocations.
1558 Add an invocation exercising the error token.
1559 Add an invocation demonstrating a stupid error message.
1560 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
1561 Adjust the tests.
1562 Error message are for stderr, not stdout.
1563
007a50a4
AD
15642002-04-09 Akim Demaille <akim@epita.fr>
1565
1566 * src/gram.h, src/gram.c (error_token_number): Remove, use
1567 errtoken->number.
1568 * src/reader.c (reader): Don't specify the user token number (2)
1569 for $undefined, as it uselessly prevents using it.
1570 * src/gram.h (token_number_t): Move to...
1571 * src/symtab.h: here.
1572 (state_t.number): Is a token_number_t.
1573 * src/print.c, src/reader.c: Use undeftoken->number instead of
1574 hard coded 2.
1575 (Even though this 2 is not the same as above: the number of the
1576 undeftoken remains being 2, it is its user token number which
1577 might not be 2).
1578 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
1579 `user_token_number_max'.
1580 Output `undef_token_number'.
1581 * data/bison.simple, data/bison.c++: Use them.
1582 Be sure to map invalid yylex return values to
1583 `undef_token_number'. This saves us from gratuitous SEGV.
1584
1585 * tests/conflicts.at (Solved SR Conflicts)
1586 (Unresolved SR Conflicts): Adjust.
1587 * tests/regression.at (Web2c Actions): Adjust.
1588
06446ccf
AD
15892002-04-08 Akim Demaille <akim@epita.fr>
1590
1591 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
1592 Adding #line.
1593 Remove the duplicate `typedefs'.
1594 (RhsNumberType): Fix the declaration and various other typos.
1595 Use __ofile__.
1596 * data/bison.simple: Use __ofile__.
1597 * src/scan-skel.l: Handle __ofile__.
1598
62a3e4f0
AD
15992002-04-08 Akim Demaille <akim@epita.fr>
1600
1601 * src/gram.h (item_number_t): New, the type of item numbers in
1602 RITEM. Note that it must be able to code symbol numbers as
1603 positive number, and the negation of rule numbers as negative
1604 numbers.
1605 Adjust all dependencies (pretty many).
1606 * src/reduce.c (rule): Remove this `short *' pointer: use
1607 item_number_t.
1608 * src/system.h (MINSHORT, MAXSHORT): Remove.
1609 Include `limits.h'.
1610 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
1611 (shortcpy): Remove.
1612 (MAXTABLE): Move to...
1613 * src/output.c (MAXTABLE): here.
1614 (prepare_rules): Use output_int_table to output rhs.
1615 * data/bison.simple, data/bison.c++: Adjust.
1616 * tests/torture.at (Big triangle): Move the limit from 254 to
1617 500.
1618 * tests/regression.at (Web2c Actions): Ajust.
1619
1620 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
1621 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
1622 passes, but produces negative #line number, once fixed, GCC is
1623 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
1624 C), it passes.
1625 * src/state.h (state_h): Code input lines on ints, not shorts.
1626
bb88b0fc
AD
16272002-04-08 Akim Demaille <akim@epita.fr>
1628
1629 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
1630 and then the grammar.
1631
9a636f47
AD
16322002-04-08 Akim Demaille <akim@epita.fr>
1633
1634 * src/system.h: No longer using strndup.
1635
680e8701
AD
16362002-04-07 Akim Demaille <akim@epita.fr>
1637
1638 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
1639 * src/output.c (output_table_data): Return the longest number.
1640 (prepare_tokens): Output `token_number_max').
1641 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
1642 New.
1643 Use them to define yy_token_number_type/TokenNumberType.
1644 Use this type for yytranslate.
1645 * tests/torture.at (Big triangle): Push the limit from 124 to
1646 253.
1647 * tests/regression.at (Web2c Actions): Adjust.
1648
817e9f41
AD
16492002-04-07 Akim Demaille <akim@epita.fr>
1650
1651 * tests/torture.at (Big triangle): New.
1652 (GNU AWK Grammar, GNU Cim Grammar): Move to...
1653 * tests/existing.at: here.
1654
5123689b
AD
16552002-04-07 Akim Demaille <akim@epita.fr>
1656
1657 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
1658 nritems.
1659 Adjust dependencies.
1660
f3849179
AD
16612002-04-07 Akim Demaille <akim@epita.fr>
1662
1663 * src/reader.c: Normalize increments to prefix form.
1664
bd02036a
AD
16652002-04-07 Akim Demaille <akim@epita.fr>
1666
1667 * src/reader.c, symtab.c: Remove debugging code.
1668
db8837cb
AD
16692002-04-07 Akim Demaille <akim@epita.fr>
1670
1671 Rename all the `bucket's as `symbol_t'.
1672
1673 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
1674 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
1675 * src/symtab.c, src/symtab.h (bucket): Rename as...
1676 (symbol_t): this.
1677 (symbol_list_new, bucket_check_defined, bucket_make_alias)
1678 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
1679 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1680 (buckets_new, buckets_free, buckets_do): Rename as...
1681 (symbol_list_new, symbol_check_defined, symbol_make_alias)
1682 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1683 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
1684 (symbols_new, symbols_free, symbols_do): these.
1685
72a23c97
AD
16862002-04-07 Akim Demaille <akim@epita.fr>
1687
1688 Use lib/hash for the symbol table.
1689
1690 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
1691 EOF.
1692 * src/lex.c (lex): Set the `number' member of new terminals.
1693 * src/reader.c (bucket_check_defined, bucket_make_alias)
1694 (bucket_check_alias_consistence, bucket_translation): New.
1695 (reader, grammar_free, readgram, token_translations_init)
1696 (packsymbols): Adjust.
1697 (reader): Number the predefined tokens.
1698 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
1699 for predefined tokens.
1700 * src/symtab.h (bucket): Remove all the hash table related
1701 members.
1702 * src/symtab.c (symtab): Replace by...
1703 (bucket_table): this.
1704 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1705 (buckets_new, buckets_do): New.
1706
280a38c3
AD
17072002-04-07 Akim Demaille <akim@epita.fr>
1708
1709 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
1710 (start_symbol, max_user_token_number, semantic_parser)
1711 (error_token_number): Initialize.
1712 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
1713 Initialize.
1714 (reader): Don't.
1715 (errtoken, eoftoken, undeftoken, axiom): Extern.
1716
03b31c0c
AD
17172002-04-07 Akim Demaille <akim@epita.fr>
1718
1719 * src/gram.h (rule_s): prec and precsym are now pointers
1720 to the bucket giving the priority/associativity.
1721 Member `associativity' removed: useless.
1722 * src/reduce.c, src/conflicts.c: Adjust.
1723
8b3df748
AD
17242002-04-07 Akim Demaille <akim@epita.fr>
1725
1726 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
1727 Properly escape the symbols' TAG when outputting them.
1728
e601aa1d
AD
17292002-04-07 Akim Demaille <akim@epita.fr>
1730
1731 * src/lalr.h (LA): Is a bitsetv, not bitset*.
1732
b0299a2e
AD
17332002-04-07 Akim Demaille <akim@epita.fr>
1734
1735 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
1736 (LArule): this, which is an array to rule_t*.
1737 * src/print.c, src/conflicts.c: Adjust.
1738
d7e1f00c
AD
17392002-04-07 Akim Demaille <akim@epita.fr>
1740
1741 * src/gram.h (rule_t): Rename `number' as `user_number'.
1742 `number' is a new member.
1743 Adjust dependencies.
1744 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
1745
cc9305dd
AD
17462002-04-07 Akim Demaille <akim@epita.fr>
1747
1748 As a result of the previous patch, it is no longer needed
1749 to reorder ritem itself.
1750
1751 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
1752
b0940840
AD
17532002-04-07 Akim Demaille <akim@epita.fr>
1754
1755 Be sure never to walk through RITEMS, but use only data related to
1756 the rules themselves. RITEMS should be banished.
1757
1758 * src/output.c (output_token_translations): Rename as...
1759 (prepare_tokens): this.
1760 In addition to `translate', prepare the muscles `tname' and
1761 `toknum', which were handled by...
1762 (output_rule_data): this.
1763 Remove, and move the remainder of its outputs into...
1764 (prepare_rules): this new routines, which also merges content from
1765 (output_gram): this.
1766 (prepare_rules): Be sure never to walk through RITEMS.
1767 (output_stos): Rename as...
1768 (prepare_stos): this.
1769 (output): Always invoke prepare_states, after all, just don't use it
1770 in the output if you don't need it.
1771
643a5994
AD
17722002-04-07 Akim Demaille <akim@epita.fr>
1773
1774 * src/LR0.c (new_state): Display `nstates' as the name of the
1775 newly created state.
1776 Adjust to initialize first_state and last_state if needed.
1777 Be sure to distinguish the initial from the final state.
1778 (new_states): Create the itemset of the initial state, and use
1779 new_state.
1780 * src/closure.c (closure): Now that the initial state has its
1781 items properly set, there is no need for a special case when
1782 creating `ruleset'.
1783
1784 As a result, now the rule 0, reducing to $axiom, is visible in the
1785 outputs. Adjust the test suite.
1786
1787 * tests/conflicts.at (Solved SR Conflicts)
1788 (Unresolved SR Conflicts): Adjust.
1789 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
1790 * tests/conflicts.at (S/R in initial): New.
1791
b4c4ccc2
AD
17922002-04-07 Akim Demaille <akim@epita.fr>
1793
1794 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
1795 the RHS of the rules.
1796 * src/output.c (output_gram): Likewise.
1797
bba97eb2
AD
17982002-04-07 Akim Demaille <akim@epita.fr>
1799
1800 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
1801 bucket.
1802 Adjust all dependencies.
1803 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
1804 `number' of the buckets too.
1805 * src/gram.h: Include `symtab.h'.
1806 (associativity): Move to...
1807 * src/symtab.h: here.
1808 No longer include `gram.h'.
1809
c3b407f4
AD
18102002-04-07 Akim Demaille <akim@epita.fr>
1811
1812 * src/gram.h, src/gram.c (rules_rhs_length): New.
1813 (ritem_longest_rhs): Use it.
1814 * src/gram.h (rule_t): `number' is a new member.
1815 * src/reader.c (packgram): Set it.
1816 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
1817 the end of `rules', and count them out of `nrules'.
1818 (reduce_output, dump_grammar): Adjust.
1819 * src/print.c (print_grammar): It is no longer needed to check for
1820 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
1821 * tests/reduce.at (Reduced Automaton): New test.
1822
11652ab3
AD
18232002-04-07 Akim Demaille <akim@epita.fr>
1824
1825 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
1826 lacking `+ 1' to nrules, Bison reported as useless a token if it
1827 was used solely to set the precedence of the last rule...
1828
26b23c1a
AD
18292002-04-07 Akim Demaille <akim@epita.fr>
1830
1831 * data/bison.c++, data/bison.simple: Don't output the current file
1832 name in #line, to avoid useless diffs between two identical
1833 outputs under different names.
1834
18bcecb0
AD
18352002-04-07 Akim Demaille <akim@epita.fr>
1836
1837 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
1838 Normalize loops to using `< nrules + 1', not `<= nrules'.
1839
fa770c86
AD
18402002-04-07 Akim Demaille <akim@epita.fr>
1841
1842 * TODO: Update.
1843
d9b739c3
AD
18442002-04-07 Akim Demaille <akim@epita.fr>
1845
1846 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
1847 bucket.value as bucket.number.
1848
99013900
AD
18492002-04-07 Akim Demaille <akim@epita.fr>
1850
1851 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
1852 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1853 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
1854 RHS, instead of being an index in RITEMS.
1855
e966383b
PE
18562002-04-04 Paul Eggert <eggert@twinsun.com>
1857
1858 * doc/bison.texinfo: Update copyright date.
1859 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
1860 (Symbols): Warn about running Bison in one character set,
1861 but compiling and/or running in an incompatible one.
1862 Warn about character code 256, too.
1863
18642002-04-03 Paul Eggert <eggert@twinsun.com>
1865
1866 * src/bison.data (YYSTACK_ALLOC): Depend on whether
1867 YYERROR_VERBOSE is nonzero, not whether it is defined.
1868
1869 Merge changes from bison-1_29-branch.
c307773e 1870
8d6c48b9
PE
18712002-03-20 Paul Eggert <eggert@twinsun.com>
1872
1873 Merge fixes from Debian bison_1.34-1.diff.
1874
1875 * configure.in (AC_PREREQ): 2.53.
1876
e53c6322
AD
18772002-03-20 Akim Demaille <akim@epita.fr>
1878
1879 * src/conflicts.c (log_resolution): Argument `resolution' is const.
1880
9ffbeca7
PE
18812002-03-19 Paul Eggert <eggert@twinsun.com>
1882
21db0b2a
PE
1883 * src/bison.simple (YYCOPY): New macro.
1884 (YYSTACK_RELOCATE): Use it.
1885 Remove Type arg; no longer needed. All callers changed.
1886 (yymemcpy): Remove; no longer needed.
1887
9ffbeca7
PE
1888 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
1889 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1890
642cb8f8
AD
18912002-03-19 Akim Demaille <akim@epita.fr>
1892
1893 Test and fix the #line outputs.
1894
1895 * tests/atlocal.at (GCC): New.
1896 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
1897 (Prologue synch line, ,%union synch line, Postprologue synch line)
1898 (Action synch line, Epilogue synch line): New tests.
1899 * src/reader.c (parse_union_decl): Define the muscle stype_line.
1900 * data/bison.simple, data/bison.c++: Use it.
1901
3c31a486
AD
19022002-03-19 Akim Demaille <akim@epita.fr>
1903
1904 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
1905 (Solved SR Conflicts, %expect not enough, %expect right)
1906 (%expect too much): Move to...
1907 * tests/conflicts.at: this new file.
1908
0d8bed56
AD
19092002-03-19 Akim Demaille <akim@epita.fr>
1910
1911 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1912 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
1913 that we can move to enums for instance.
1914 * src/output.c (token_definitions_output): Output a list of
1915 `token-name, token-number' instead of the #define.
1916 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
1917
9208d17f
AD
19182002-03-14 Akim Demaille <akim@epita.fr>
1919
1920 Use Gettext 0.11.1.
1921
af27eacb
RA
19222002-03-09 Robert Anisko <robert@lrde.epita.fr>
1923
1924 * data/bison.c++: Make the user able to add members to the generated
1925 parser by subclassing.
1926
9101a310
RA
19272002-03-05 Robert Anisko <robert@lrde.epita.fr>
1928
1929 * src/reader.c (read_additionnal_code): `c' should be an integer, not
1930 a character.
1931 Reported by Nicolas Tisserand and Nicolas Burrus.
1932
fff9bf0b
RA
19332002-03-04 Robert Anisko <robert@lrde.epita.fr>
1934
1935 * src/reader.c: Warn about lacking semi-colons, do not complain.
1936
64dba31e
RA
19372002-03-04 Robert Anisko <robert@lrde.epita.fr>
1938
1939 * data/bison.c++: Remove a debug line.
1940
374f5a14
RA
19412002-03-04 Robert Anisko <robert@lrde.epita.fr>
1942
1943 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
1944 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
1945 provide a default implementation.
1946
bfcf1f3a
AD
19472002-03-04 Akim Demaille <akim@epita.fr>
1948
1949 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
1950 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
1951 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
1952 * tests/semantic.at (Parsing Guards): Similarly.
1953 * src/reader.at (readgram): Complain if the last rule is not ended
1954 with a semi-colon.
1955
65ccf9fc
AD
19562002-03-04 Akim Demaille <akim@epita.fr>
1957
1958 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
1959 * src/closure.c: here.
1960 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
1961 RTC.
1962 * src/warshall.h, src/warshall.c: Remove.
1963 * tests/sets.at (Broken Closure): Adjust.
1964
d0039cbc
AD
19652002-03-04 Akim Demaille <akim@epita.fr>
1966
1967 * src/output.c (output_skeleton): tempdir is const.
1968 bytes_read is unused.
1969
345cea78
AD
19702002-03-04 Akim Demaille <akim@epita.fr>
1971
1972 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
1973 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
1974 Update.
1975 From Michael Hayes.
1976
564801f7
AD
19772002-03-04 Akim Demaille <akim@epita.fr>
1978
1979 * src/closure.c (closure): `r' is unused.
1980
e5352bc7
AD
19812002-03-04 Akim Demaille <akim@epita.fr>
1982
1983 * tests/sets.at (Broken Closure): Add the ending `;'.
1984 * src/reader.at (readgram): Complain if a rule is not ended with a
1985 semi-colon.
1986
914feea9
AD
19872002-03-04 Akim Demaille <akim@epita.fr>
1988
1989 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
1990 (count_sr_conflicts): Use bitset_count.
1991 * src/reduce.c (inaccessable_symbols): Ditto.
1992 (bits_size): Remove.
1993 * src/warshall.h, src/warshall.c: Convert to bitsetv.
1994
f0250de6
AD
19952002-03-04 Akim Demaille <akim@epita.fr>
1996
1997 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
1998 * src/reduce.c: Remove the `bitset_zero's following the
1999 `bitset_create's, as now it is performed by the latter.
2000
ef017502
AD
20012002-03-04 Akim Demaille <akim@epita.fr>
2002
2003 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2004 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2005 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2006 latest sources from Michael.
2007
76514394
AD
20082002-03-04 Akim Demaille <akim@epita.fr>
2009
2010 * src/output.c (output): Don't free the grammar.
2011 * src/reader.c (grammar_free): New.
2012 * src/main.c (main): Call it and don't free symtab here.
2013
55024580
AD
20142002-03-04 Akim Demaille <akim@epita.fr>
2015
2016 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2017 before returning.
2018 Reported by Benoit Perrot.
2019
f9abaa2c
AD
20202002-03-04 Akim Demaille <akim@epita.fr>
2021
2022 Use bitset operations when possible, not loops over bits.
2023
2024 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2025 bitset_or.
2026 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2027 * src/reduce.c (useless_nonterminals): Formatting changes.
2028 * src/warshall.c (TC): Use bitset_or.
2029
0e721e75
AD
20302002-03-04 Akim Demaille <akim@epita.fr>
2031
2032 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2033 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2034 Ditto.
2035
0fb1ffb1
AD
20362002-03-04 Akim Demaille <akim@epita.fr>
2037
2038 * src/lalr.c (F): Now a bitset*.
2039 Adjust all dependencies.
2040
b86796bf
AD
20412002-03-04 Akim Demaille <akim@epita.fr>
2042
2043 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2044 Adjust all dependencies.
2045
602bbf31
AD
20462002-03-04 Akim Demaille <akim@epita.fr>
2047
2048 * src/L0.c, src/LR0.h (nstates): Be size_t.
2049 Adjust comparisons (signed vs unsigned).
2050 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2051 bitset*.
2052 Adjust all dependencies.
2053
d8a0245c
AD
20542002-03-04 Akim Demaille <akim@epita.fr>
2055
2056 * src/closure.c (firsts): Now, also a bitset.
2057 Adjust all dependencies.
2058 (varsetsize): Remove, now unused.
2059 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2060
34ba9743
AD
20612002-03-04 Akim Demaille <akim@epita.fr>
2062
2063 * src/print.c: Convert to use bitset.h, not hand coded iterations
2064 over ints.
2065
ed86e78c
AD
20662002-03-04 Akim Demaille <akim@epita.fr>
2067
2068 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2069
dfdb1797
AD
20702002-03-04 Akim Demaille <akim@epita.fr>
2071
2072 * src/closure.c (ruleset): Be a bitset.
2073 (rulesetsize): Remove.
2074
7086e707
AD
20752002-03-04 Akim Demaille <akim@epita.fr>
2076
2077 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2078 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2079 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2080 * src/closure.c (fderives): Be an array of bitsets.
2081
98254360
RA
20822002-02-28 Robert Anisko <robert@lrde.epita.fr>
2083
2084 * data/bison.c++: Merge the two generated headers. Insert a copyright
2085 notice in each output file.
2086
a75c057f
AD
20872002-02-28 Akim Demaille <akim@epita.fr>
2088
2089 * data/bison.c++: Copy the prologue of bison.simple to fetch
2090 useful M4 definitions, such as b4_header_guard.
2091
06b00abc
AD
20922002-02-25 Akim Demaille <akim@epita.fr>
2093
2094 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
2095 translator friendly scheme for the bgr
2096 copyright notice.
06b00abc 2097
70e7d534
AD
20982002-02-25 Akim Demaille <akim@epita.fr>
2099
2100 * src/output.c (header_output): Remove, now handled completely via
2101 M4.
2102
abe017f6
AD
21032002-02-25 Akim Demaille <akim@epita.fr>
2104
2105 * m4/m4.m4: New, from CVS Autoconf.
2106 * configure.in: Invoke it.
2107 * src/output.c (output_skeleton): Use its result instead of the
2108 hard coded name.
2109
381fb12e
AD
21102002-02-25 Akim Demaille <akim@epita.fr>
2111
2112 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2113 Fileutils 4.1.5.
2114 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2115 * src/output.c (output_skeleton): Use mkstemp to create a real
2116 temporary file.
2117 Move the filling of `skeleton' and its muscle to...
2118 (prepare): here.
2119 (output): Move the definition of the prologue muscle to...
2120 (prepare): here.
2121 * src/system.h (DEFAULT_TMPDIR): New.
2122
6f38107f
PE
21232002-02-14 Paul Eggert <eggert@twinsun.com>
2124
2125 Remove the support for C++ namespace cleanliness; it was
2126 causing more problems than it was curing, since it didn't work
2127 properly on some nonstandard C++ compilers. This can wait
2128 for a proper C++ parser.
2129
2130 * NEWS: Document this.
2131 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2132 of C++, as it's treated like C now.
2133 * src/bison.simple (YYSTD): Remove.
2134 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2135 Treat C++ just like Standard C instead of trying to support
2136 namespace cleanliness.
2137
80cce3da
AD
21382002-02-14 Akim Demaille <akim@epita.fr>
2139
2140 * tests/regression.at (else): Adjust to Andreas' change.
2141
842e8679
AD
21422002-02-14 Akim Demaille <akim@epita.fr>
2143
2144 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2145
4bda3f10
AD
21462002-02-13 Andreas Schwab <schwab@suse.de>
2147
2148 * src/output.c (output_rule_data): Don't output NULL, it might
2149 not be defined yet.
2150
4162fa07 21512002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 2152
4162fa07
RA
2153 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2154 (Copyright notice): Update.
b418ecd8 2155
bd16a5dc
AD
21562002-02-11 Akim Demaille <akim@epita.fr>
2157
2158 * tests/regression.at (%nonassoc and eof): Don't include
2159 nonportable headers.
2160
8d69a1a3
RA
21612002-02-08 Robert Anisko <robert@lrde.epita.fr>
2162
2163 * data/bison.c++: Correct error recovery. Make the user able to
2164 initialize the starting location.
2165
9b2d0677
AD
21662002-02-07 Akim Demaille <akim@epita.fr>
2167
2168 * tests/input.at: New.
2169
69e2658b
RA
21702002-02-07 Robert Anisko <robert@lrde.epita.fr>
2171
2172 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 2173 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
2174 directives around tables only needed for debugging.
2175
4aacc3a7
RA
21762002-02-07 Robert Anisko <robert@lrde.epita.fr>
2177
2178 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2179 C++ parsers.
2180 (yy::b4_name::parse): Use print_.
2181
762a801e
RA
21822002-02-07 Robert Anisko <robert@lrde.epita.fr>
2183
2184 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2185
4bb2bc3f
RA
21862002-02-07 Robert Anisko <robert@lrde.epita.fr>
2187
2188 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2189 C++ parsers.
2190 (yy::b4_name::parse): Build verbose error messages, and use error_.
2191
6b45a3ca
RA
21922002-02-06 Robert Anisko <robert@lrde.epita.fr>
2193
2194 * data/bison.c++: Fix m4 quoting in comments.
2195
50997c6e
RA
21962002-02-06 Robert Anisko <robert@lrde.epita.fr>
2197
2198 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2199 not expanded by m4.
2200
3f3eed27
AD
22012002-02-05 Akim Demaille <akim@epita.fr>
2202
2203 * data/bison.c++: Adjust to the M4 back end.
2204 More is certainly needed.
2205
be2a1a68
AD
22062002-02-05 Akim Demaille <akim@epita.fr>
2207
2208 Give a try to M4 as a back end.
2209
2210 * lib/readpipe.c: New, from wdiff.
2211 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2212 BISON_HAIRY.
2213 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2214 specific values. Now it is m4 that performs the lookup.
2215 * src/parse-skel.y: Remove.
2216 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2217 * src/output.c (actions_output, guards_output)
2218 (token_definitions_output): No longer keeps track of the output
2219 line number, hence remove the second argument.
2220 (guards_output): Check against the guard member of a rule, not the
2221 action member.
2222 Adjust callers.
2223 (output_skeleton): Don't look for the skeleton location, let m4 do
2224 that.
2225 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2226 file will be used.
2227 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2228 (prepare): Given that for the time being changesyntax is not
2229 usable in M4, rename the muscles using `-' to `_'.
2230 Define `defines_flag', `output_parser_name' and `output_header_name'.
2231 * src/output.h (actions_output, guards_output)
2232 (token_definitions_output): Adjust prototypes.
2233 * src/scan-skel.l: Instead of scanning the skeletons, it now
2234 processes the output of m4: `__oline__' and `#output'.
2235 * data/bison.simple: Adjust to be used by M4(sugar).
2236 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2237 to date.
2238 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2239 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2240 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2241 shamelessly stolen from CVS Autoconf.
2242
beda758b
AD
22432002-02-05 Akim Demaille <akim@epita.fr>
2244
2245 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2246 * configure.in: Check for the declarations of free and malloc.
2247 * src/muscle_tab.c: Adjust.
2248
5ece6d43
AD
22492002-02-05 Akim Demaille <akim@epita.fr>
2250
2251 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
2252 which have no values.
2253
5bb18f9a
AD
22542002-02-05 Akim Demaille <akim@epita.fr>
2255
2256 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
2257 * data/: here.
2258
894dd62e
PE
22592002-01-29 Paul Eggert <eggert@twinsun.com>
2260
2261 * src/bison.simple (YYSIZE_T): Do not define merely because
2262 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
2263 On some platforms, <alloca.h> does not declare YYSTD (size_t).
2264
82841af7
AD
22652002-01-27 Akim Demaille <akim@epita.fr>
2266
2267 Fix `%nonassoc and eof'.
2268
2269 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
2270 which were not properly copied! Replace
2271 memcpy (res->errs, src->errs, src->nerrs);
2272 with
2273 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
2274 !!!
2275 * tests/regression.at (%nonassoc and eof): Adjust to newest
2276 Autotest: `.' is not in the PATH.
2277
318b76e9
AD
22782002-01-27 Akim Demaille <akim@epita.fr>
2279
2280 * tests/sets.at (AT_EXTRACT_SETS): New.
2281 (Nullable): Use it.
2282 (Firsts): New.
2283
30d2f3d5
AD
22842002-01-26 Akim Demaille <akim@epita.fr>
2285
2286 * tests/actions.at, tests/calc.at, tests/headers.at,
2287 * tests/torture.at: Adjust to the newest Autotest which no longer
2288 forces `.' in the PATH.
2289
30f8c395
AD
22902002-01-25 Akim Demaille <akim@epita.fr>
2291
2292 * tests/regression.at (%nonassoc and eof): New.
2293 Suggested by Robert Anisko.
2294
29ae55f1
AD
22952002-01-24 Akim Demaille <akim@epita.fr>
2296
2297 Bison dumps core when trying to complain about broken input files.
2298 Reported by Cris van Pelt.
2299
2300 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
2301 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
2302 into...
2303 (Invalid inputs): Strengthen: exercise parse_percent_token.
2304
2b548aa6
RA
23052002-01-24 Robert Anisko <robert.anisko@epita.fr>
2306
2307 * src/Makefile.am: Add bison.c++.
2308 * src/bison.c++: New skeleton.
2309
bb0146c2
AD
23102002-01-21 Paolo Bonzini <bonzini@gnu.org>
2311
2312 * po/it.po: New.
2313
bec30531
AD
23142002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
2315
2316 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
2317
fc6edc45
MA
23182002-01-20 Marc Autret <marc@gnu.org>
2319
2320 * src/files.c (compute_output_file_names): Fix
2321
5e5d5415
MA
23222002-01-20 Marc Autret <marc@gnu.org>
2323
2324 * tests/output.at: New test.
2325 * src/files.c (compute_base_names): Don't map extensions when
2326 the YACC flag is set, use defaults.
2327 Reported by Evgeny Stambulchik.
2328
44ea3fbd
MA
23292002-01-20 Marc Autret <marc@gnu.org>
2330
bb0146c2 2331 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
2332 compilers as well (i.e. the vendor C compiler).
2333 Suggested by Albert Chin-A-Young.
2334
338963d1
TVH
23352002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
2336
2337 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
2338 canonical definition.
2339 * src/system.h: Use the canonical definition for PARAMS (avoids
2340 a conflict with the macro from lib/hash.h).
2341
c57b2479
AD
23422002-01-11 Akim Demaille <akim@epita.fr>
2343
2344 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 2345 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 2346
b85810ae
AD
23472002-01-09 Akim Demaille <akim@epita.fr>
2348
2349 * src/files.c, src/files.h (output_infix): New.
2350 (tab_extension): Remove.
2351 (compute_base_names): Compute the former, drop the latter.
2352 * src/output.c (prepare): Insert the muscles `output-infix', and
2353 `output-suffix'.
2354 * src/parse-skel.y (string, string.1): New.
2355 (section.header): Use it.
2356 (section.yacc): Remove.
2357 (prefix): Remove too.
2358 * src/scan-skel.l: Adjust.
2359 * src/bison.simple, src/bison.hairy: Adjust.
2360
cae60122
AD
23612002-01-09 Akim Demaille <akim@epita.fr>
2362
2363 * configure.in (WERROR_CFLAGS): Compute it.
2364 * src/Makefile.am (CFLAGS): Pass it.
2365 * tests/atlocal.in (CFLAGS): Idem.
2366 * src/files.c: Fix a few warnings.
2367 (get_extension_index): Remove, unused.
2368
ae404801
AD
23692002-01-08 Akim Demaille <akim@epita.fr>
2370
2371 * src/getargs.c (AS_FILE_NAME): New.
2372 (getargs): Use it to convert DOSish file names.
2373 * src/files.c (base_name): Rename as full_base_name to avoid
2374 clashes with `base_name ()'.
2375 (filename_split): New.
2376 (compute_base_names): N-th rewrite, using filename_split.
2377
22312b71
AD
23782002-01-08 Akim Demaille <akim@epita.fr>
2379
2380 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
2381 New, stolen from the Fileutils 4.1.
2382 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
2383 * configure.in: Check for the presence of memrchr, and of its
2384 prototype.
2385
a67cef01
TVH
23862002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
2387
2388 * lib/hash.h (__P): Added definition for this macro.
2389 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
2390 BUILT_SOURCES, to ensure they are generated first.
2391 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
2392 %error-verbose to allow bootstrapping with bison 1.30x.
2393
2b25d624
AD
23942002-01-06 Akim Demaille <akim@epita.fr>
2395
2396 * src/reader.c (parse_braces): Don't fetch the next char, the
2397 convention is to fetch on entry.
2398 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
2399 'switch' without a following semicolon.
2400 * tests/regression.at (braces parsing): New.
2401
3460813b
AD
24022002-01-06 Akim Demaille <akim@epita.fr>
2403
2404 Bison is dead wrong in its RR conflict reports.
2405
2406 * tests/torture.at (GNU Cim Grammar): New.
2407 * src/conflicts.c (count_rr_conflicts): Fix.
2408
73784c64
AD
24092002-01-06 Akim Demaille <akim@epita.fr>
2410
2411 Creating package.m4 from configure.ac causes too many problems.
2412
2413 * tests/Makefile.am (package.m4): Create it by hand,
2414 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
2415
25d81090
AD
24162002-01-06 Akim Demaille <akim@epita.fr>
2417
2418 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
2419 skeleton.h.
2420
a9b8959e
PE
24212002-01-04 Paul Eggert <eggert@twinsun.com>
2422
2423 * doc/bison.texinfo (Debugging):
2424 Remove YYSTDERR; it's no longer defined or used.
2425 Also, s/cstdio.h/cstdio/.
2426
25d81090
AD
24272002-01-03 Akim Demaille <akim@epita.fr>
2428
2429 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
2430
1109455c
AD
24312002-01-03 Akim Demaille <akim@epita.fr>
2432
2433 * src/parse-skel.y (process_skeleton): Don't bind the parser's
2434 tracing code to --trace, wait for a better --trace option, with
2435 args.
2436
7ea5e977
AD
24372002-01-03 Akim Demaille <akim@epita.fr>
2438
2439 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
2440 The ISO C++ standard is extremely clear about it: stderr is
2441 considered a macro, not a regular symbol (see table 94 `Header
2442 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
2443 Therefore std:: does not apply to it. It still does with fprintf.
2444 Also, s/cstdio.h/cstdio/.
2445
fab5b110
AD
24462002-01-03 Akim Demaille <akim@epita.fr>
2447
2448 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
2449 for non system headers.
2450
aed7fd9b
AD
24512002-01-02 Akim Demaille <akim@epita.fr>
2452
2453 Equip the skeleton chain with location tracking, runtime trace,
2454 pure parser and scanner.
2455
2456 * src/parse-skel.y: Request a pure parser, locations, and prefix
2457 renaming.
2458 (%union): Having several members with the same type does not help
2459 type mismatches, simplify.
2460 (YYPRINT, yyprint): New.
2461 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
2462 (skel_error): this.
2463 Handle locations.
2464 * src/scan-skel.l: Adjust to these changes.
2465 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
2466 (LOCATION_PRINT, skel_control_t): New.
2467
24fad99e
AD
24682001-12-30 Akim Demaille <akim@epita.fr>
2469
2470 * src/parse-skel.y: Get rid of the shift/reduce conflict:
2471 replace `gb' with BLANKS.
2472 * src/scan-skel.l: Adjust.
2473
a4b36db4
AD
24742001-12-30 Akim Demaille <akim@epita.fr>
2475
2476 * src/system.h: We don't need nor want bcopy.
2477 Throw away MS-DOS crap: we don't need getpid.
2478 * configure.in: We don't need strndup. It was even causing
2479 problems: because Flex includes the headers *before* us,
2480 _GNU_SOURCE is not defined by config.h, and therefore strndup was
2481 not visible.
2482 * lib/xstrndup.c: New.
2483 * src/scan-skel.l: Use it.
2484 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
2485 * src/parse-skel.y: Use %directives instead of #defines.
2486
1239777d
AD
24872001-12-30 Akim Demaille <akim@epita.fr>
2488
2489 * src/skeleton.h: New.
2490 * src/output.c (output_parser, output_master_parser): Remove, dead
2491 code.
2492 * src/output.h (get_lines_number, actions_output, guards_output)
2493 (token_definitions_output): Prototype them.
2494 * src/parse-skel.y: Add the license notice.
2495 Include output.h and skeleton.h.
2496 (process_skeleton): Returns void, and takes a single parameter.
2497 * src/scan-skel.l: Add the license notice.
2498 Include skeleton.h.
2499 Don't use %option yylineno: it seems that then Flex imagines
2500 REJECT has been used, and therefore it won't reallocate its
2501 buffers (which makes no other sense to me than a bug). It results
2502 in warnings for `unused: yy_flex_realloc'.
2503
9b3add5b
RA
25042001-12-30 Robert Anisko <robert.anisko@epita.fr>
2505
2506 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2507 (MUSCLE_INSERT_PREFIX): ...to there.
2508 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2509 (MUSCLE_INSERT_PREFIX): Move from here...
2510
2511 * src/bison.hairy: Add a section directive. Put braces around muscle
2512 names. This parser skeleton is still broken, but Bison should not
2513 choke on a bad muscle 'syntax'.
2514 * src/bison.simple: Add a section directive. Put braces around muscle
2515 names.
2516
2517 * src/files.h (strsuffix, stringappend): Add declarations.
2518 (tab_extension): Add declaration.
2519 (short_base_name): Add declaration.
2520
2521 * src/files.c (strsuffix, stringappend): No longer static. These
2522 functions are used in the skeleton parser.
2523 (tab_extension): New.
2524 (compute_base_names): Use the computations done in this function
fab5b110 2525 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
2526 names.
2527 (short_base_name): No longer static.
2528
2529 * src/output.c (output_skeleton): New.
2530 (output): Disable call to output_master_parser, and give a try to
2531 a new skeleton handling system.
2532 (guards_output, actions_output): No longer static.
2533 (token_definitions_output, get_lines_number): No longer static.
2534
2535 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
2536
fab5b110 2537 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
2538 parse-skel.y.
2539
2540 * src/parse-skel.y: New file.
2541 * src/scan-skel.l: New file.
2542
b5b61c61
AD
25432001-12-29 Akim Demaille <akim@epita.fr>
2544
2545 %name-prefix is broken.
2546
2547 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
2548 Adjust all dependencies.
2549 * tests/headers.at (export YYLTYPE): Strengthen this test: use
2550 %name-prefix.
2551
2552 Renaming yylval but not yylloc is not consistent. Now we do.
2553
2554 * src/bison.simple: Prefix yylloc if used.
2555 * doc/bison.texinfo (Decl Summary): Document that.
2556
8c9a50be
AD
25572001-12-29 Akim Demaille <akim@epita.fr>
2558
2559 * doc/bison.texinfo: Promote `%long-directive' over
2560 `%long_directive'.
2561 Remove all references to fixed-output-files, yacc is enough.
2562
d99361e6
AD
25632001-12-29 Akim Demaille <akim@epita.fr>
2564
2565 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
2566 user prologue. These are defaults.
2567 * tests/actions.at (Mid-rule actions): Make sure the user can
2568 define YYDEBUG and YYERROR_VERBOSE.
2569
b9cecb91
AD
25702001-12-29 Akim Demaille <akim@epita.fr>
2571
2572 * src/output.c (header_output): Don't forget to export YYLTYPE and
2573 yylloc.
2574 * tests/headers.at (export YYLTYPE): New, make sure it does.
2575 * tests/regression.at (%union and --defines, Invalid CPP headers):
2576 Move to...
2577 * tests/headers.at: here.
2578
aea13e97
AD
25792001-12-29 Akim Demaille <akim@epita.fr>
2580
2581 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
2582
931394cb
AD
25832001-12-29 Akim Demaille <akim@epita.fr>
2584
2585 * tests/actions.at (Mid-rule actions): Output on a single line
2586 instead of several.
2587
704a47c4
AD
25882001-12-29 Akim Demaille <akim@epita.fr>
2589
2590 * doc/bison.texinfo: Formatting changes.
2591
091e20bb
AD
25922001-12-29 Akim Demaille <akim@epita.fr>
2593
2594 Don't store the token defs in a muscle, just be ready to output it
2595 on command. Now possible via `symbols'. Fixes a memory leak.
2596
2597 * src/output.c (token_definitions_output): New.
2598 (output_parser, header_output): Use it.
2599 * src/reader.c (symbols_save): Remove.
2600
cce71710
AD
26012001-12-29 Akim Demaille <akim@epita.fr>
2602
2603 * src/bison.simple: Do not provide a default for YYSTYPE and
2604 YYLTYPE before the user's prologue. Otherwise it's hardly... a
2605 default.
2606
82c035a8
AD
26072001-12-29 Akim Demaille <akim@epita.fr>
2608
2609 Mid-rule actions are simply... ignored!
2610
2611 * src/reader.c (readgram): Be sure to attach mid-rule actions to
2612 the empty-rule associated to the dummy symbol, not to the host
2613 rule.
2614 * tests/actions.at (Mid-rule actions): New.
2615
8419d367
AD
26162001-12-29 Akim Demaille <akim@epita.fr>
2617
2618 Memory leak.
2619
2620 * src/reader.c (reader): Free grammar.
2621
375d5806
AD
26222001-12-29 Akim Demaille <akim@epita.fr>
2623
2624 Memory leak.
2625
2626 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
2627 since it allocates it for each state, although only one is needed.
2628 (allocate_storage): Do it here.
2629
f51cb8ff
AD
26302001-12-29 Akim Demaille <akim@epita.fr>
2631
2632 * src/options.h, src/options.c (create_long_option_table): Rename
2633 as...
2634 (long_option_table_new): this, with a clearer prototype.
2635 (percent_table): Remove, unused,
2636 * src/getargs.c (getargs): Adjust.
2637
29e88316
AD
26382001-12-29 Akim Demaille <akim@epita.fr>
2639
2640 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
2641 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
2642 as states.
2643
b9f71f19
AD
26442001-12-29 Akim Demaille <akim@epita.fr>
2645
2646 * src/lalr.c (build_relations): Rename `states' as `states1'.
2647 Sorry, I don't understand exactly what it is, no better name...
2648
1a2b5d37
AD
26492001-12-29 Akim Demaille <akim@epita.fr>
2650
2651 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
2652 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
2653 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
2654 as rules.
2655
1cca533e
AD
26562001-12-29 Akim Demaille <akim@epita.fr>
2657
2658 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
2659 ago.
2660
c03ae966
AD
26612001-12-29 Akim Demaille <akim@epita.fr>
2662
2663 * src/reader.c, src/reader.h (user_toknums): Remove.
2664 Adjust all users to use symbols[i]->user_token_number.
2665
5a670b1e
AD
26662001-12-29 Akim Demaille <akim@epita.fr>
2667
2668 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
2669 Adjust all users to use symbols[i]->prec or ->assoc.
2670
ad949da9
AD
26712001-12-29 Akim Demaille <akim@epita.fr>
2672
2673 * src/reader.c, src/reader.h (tags): Remove.
2674 Adjust all users to use symbols[i]->tag.
2675
0e78e603
AD
26762001-12-29 Akim Demaille <akim@epita.fr>
2677
2678 * src/gram.h, src/gram.c (symbols): New, similar to state_table
2679 and rule_table.
2680 * src/reader.c (packsymbols): Fill this table.
2681 Drop sprec.
2682 * src/conflicts.c (resolve_sr_conflict): Adjust.
2683 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
2684 single table.
2685 Use symbols[i]->tag instead of tags[i].
2686
213e640e
AD
26872001-12-29 Akim Demaille <akim@epita.fr>
2688
2689 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
2690 In addition, put a comment in there, to replace...
2691 * tests/regression.at (%union and C comments): Remove.
2692
e7b8bef1
AD
26932001-12-29 Akim Demaille <akim@epita.fr>
2694
2695 * tests/regression.at (Web2c Actions): Blindly move the actual
2696 output as expected output. The contents *seem* right to me, but I
2697 can't pretend reading perfectly parser tables... Nonetheless, all
2698 the other tests pass correctly, the table look OK, even though the
2699 presence of `$axiom' is to be noted: AFAICS it is useless (but
2700 harmless).
2701
b68e7744
AD
27022001-12-29 Akim Demaille <akim@epita.fr>
2703
2704 * src/reader.c (readgram): Don't add the rule 0 if there were no
2705 rules read. In other words, add it _after_ having performed
2706 grammar sanity checks.
2707 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
2708
78d5bae9
AD
27092001-12-29 Akim Demaille <akim@epita.fr>
2710
2711 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
2712 visible, and some states have now a different number.
2713
ff442794
AD
27142001-12-29 Akim Demaille <akim@epita.fr>
2715
2716 * src/reader.c (readgram): Bind the initial rule's lineno to that
2717 of the first rule.
2718 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
2719 (Solved SR Conflicts): Adjust rule 0's line number.
2720
610ab194
AD
27212001-12-29 Akim Demaille <akim@epita.fr>
2722
2723 Fix the `GAWK Grammar' failure.
2724
2725 * src/LR0.c (final_state): Initialize to -1 so that we do compute
2726 the reductions of the first state which was mistakenly confused
2727 with the final state because precisely final_state was initialized
2728 to 0.
2729 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
2730 now noticed by Bison.
2731 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
2732 have a reduction on $default.
2733
29d29c8f
AD
27342001-12-29 Akim Demaille <akim@epita.fr>
2735
2736 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
2737 rule line numbers.
2738 * src/closure.c (print_closure): Likewise.
2739 * src/derives.c (print_derives): Likewise.
2740 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
2741 now.
2742
7c6b64d0
AD
27432001-12-29 Akim Demaille <akim@epita.fr>
2744
2745 * src/lalr.c (lookaheads_print): New.
2746 (lalr): Call it when --trace-flag.
2747 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
2748 are dumped.
2749
3d4daee3
AD
27502001-12-29 Akim Demaille <akim@epita.fr>
2751
2752 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
2753 when walking through ritem, even via rule->rhs.
2754 * src/reduce.c (dump_grammar, useful_production, reduce_output)
2755 (useful_production, useless_nonterminals): Likewise.
2756 (reduce_grammar_tables): Likewise, plus update nritems.
2757 * src/nullable.c (set_nullable): Likewise.
2758 * src/lalr.c (build_relations): Likewise.
2759 * tests/sets.at (Nullable): Adjust.
2760 Fortunately, now, the $axiom is no longer nullable.
2761
9e7f6bbd
AD
27622001-12-29 Akim Demaille <akim@epita.fr>
2763
2764 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
2765 the 0-sentinel.
2766 * src/gram.c (ritem_longest_rhs): Likewise.
2767 * src/reduce.c (nonterminals_reduce): Likewise.
2768 * src/print_graph.c (print_graph): Likewise.
2769 * src/output.c (output_rule_data): Likewise.
2770 * src/nullable.c (set_nullable): Likewise.
2771
255ef638
AD
27722001-12-29 Akim Demaille <akim@epita.fr>
2773
2774 * src/output.c: Comment changes.
2775
0d8a7363
AD
27762001-12-27 Paul Eggert <eggert@twinsun.com>
2777
2778 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
2779 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
2780 Sparc, as they were causing more porting problems than the
2781 (minor) performance improvement was worth.
2782
2783 Also, catch up with 1.31's YYSTD.
2784
3db472b9
AD
27852001-12-27 Akim Demaille <akim@epita.fr>
2786
2787 * src/output.c (output_gram): Rely on nritems, not the
2788 0-sentinel. See below.
2789 Use -1 as separator, not 0.
2790 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
2791 Rely on -1 as separator in yyrhs, instead of 0.
2792 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
2793 twice `Now at end of input', therefore there are two lines less to
2794 expect.
2795
b365aa05
AD
27962001-12-27 Akim Demaille <akim@epita.fr>
2797
2798 * tests/regression.at (Unresolved SR Conflicts):
2799 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
2800 below.
2801
30171f79
AD
28022001-12-27 Akim Demaille <akim@epita.fr>
2803
2804 * src/LR0.c (new_state): Recognize the final state by the fact it
2805 is reached by eoftoken.
2806 (insert_start_shifting_state, insert_eof_shifting_state)
2807 (insert_accepting_state, augment_automaton): Remove, since now
2808 these states are automatically computed from the initial state.
2809 (generate_states): Adjust.
2810 * src/print.c: When reporting a rule number to the user, substract
2811 1, so that the axiom rule is rule 0, and the first user rule is 1.
2812 * src/reduce.c: Likewise.
2813 * src/print_graph.c (print_core): For the time being, just as for
2814 the report, depend upon --trace-flags to dump the full set of
2815 items.
2816 * src/reader.c (readgram): Once the grammar read, insert the rule
2817 0: `$axiom: START-SYMBOL $'.
2818 * tests/set.at: Adjust: rule 0 is now displayed, and since the
2819 number of the states has changed (the final state is no longer
2820 necessarily the last), catch up.
2821
75142d45
AD
28222001-12-27 Akim Demaille <akim@epita.fr>
2823
2824 Try to make the use of the eoftoken valid. Given that its value
2825 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
2826 is used instead of > 0 where appropriate, (ii), depend upon nritems
2827 instead of the 0-sentinel.
2828
2829 * src/gram.h, src/gram.c (nritems): New.
2830 Expected to be duplication of nitems, but for the time being...
2831 * src/reader.c (packgram): Assert nritems and nitems are equal.
2832 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
2833 * src/closure.c (print_closure, print_fderives): Likewise.
2834 * src/gram.c (ritem_print): Likewise.
2835 * src/print.c (print_core, print_grammar): Likewise.
2836 * src/print_graph.c: Likewise.
2837
b7c49edf
AD
28382001-12-27 Akim Demaille <akim@epita.fr>
2839
2840 * src/main.c (main): If there are complains after grammar
2841 reductions, then output the report anyway if requested, then die.
2842 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
2843 * src/reader.c (eoftoken): New.
2844 (parse_token_decl): If the token being defined has value `0', it
2845 is the eoftoken.
2846 (packsymbols): No longer hack `tags' to insert `$' by hand.
2847 Be sure to preserve the value of the eoftoken.
2848 (reader): Make sure eoftoken is defined.
2849 Initialize nsyms to 0: now eoftoken is created just like the others.
2850 * src/print.c (print_grammar): Don't special case the eof token.
2851 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
2852 lie anyway, albeit pleasant.
2853 * tests/calc.at: Exercise error messages with eoftoken.
2854 Change the grammar so that empty input is invalid.
2855 Adjust expectations.
2856 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
2857
ec2da99f
AD
28582001-12-27 Akim Demaille <akim@epita.fr>
2859
2860 * configure.in: Check the protos of strchr ans strspn.
2861 Replace strchr if needed.
2862 * src/system.h: Provide the protos of strchr, strspn and memchr if
2863 missing.
2864 * lib/strchr.c: New.
2865 * src/reader.c (symbols_save): Use strchr.
2866
8adfa272
AD
28672001-12-27 Akim Demaille <akim@epita.fr>
2868
2869 * src/print.c, src/print_graph.c (escape): New.
2870 Use it to quote the TAGS outputs.
2871 * src/print_graph.c (print_state): Now errors are in red, and
2872 reductions in green.
2873 Prefer high to wide: output the state number on a line of its own.
2874
80dac38c
AD
28752001-12-27 Akim Demaille <akim@epita.fr>
2876
2877 * src/state.h, src/state.c (reductions_new): New.
2878 * src/LR0.c (set_state_table): Let all the states have a
2879 `reductions', even if reduced to 0.
2880 (save_reductions): Adjust.
2881 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
2882 * src/print.c (print_reductions, print_actions): Adjust.
2883 * src/output.c (action_row): Adjust.
2884
2cec70b9
AD
28852001-12-27 Akim Demaille <akim@epita.fr>
2886
2887 * src/state.h, src/state.c (errs_new, errs_dup): New.
2888 * src/LR0.c (set_state_table): Let all the states have an errs,
2889 even if reduced to 0.
2890 * src/print.c (print_errs, print_reductions): Adjust.
2891 * src/output.c (output_actions, action_row): Adjust.
2892 * src/conflicts.c (resolve_sr_conflict): Adjust.
2893
13ca549a
AD
28942001-12-27 Akim Demaille <akim@epita.fr>
2895
2896 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
2897
5092aba5
AD
28982001-12-27 Akim Demaille <akim@epita.fr>
2899
2900 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
2901 * src/print.c: here.
2902 (lookaheadset, shiftset): New, used as additional storage by
2903 print_reductions.
2904 (print_results): Adjust.
2905 (print_shifts, print_gotos, print_errs): New, extracted from...
2906 (print_actions): here.
2907 * src/print_graph.c (print_actions): Remove dead code.
2908
11e2beca
AD
29092001-12-27 Akim Demaille <akim@epita.fr>
2910
2911 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
2912 `$n' and `@n'.
2913
dac3c910
AD
29142001-12-27 Akim Demaille <akim@epita.fr>
2915
2916 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
2917 (build_relations): Adjust.
2918
d0b0fefa
AD
29192001-12-27 Akim Demaille <akim@epita.fr>
2920
2921 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
2922 duplication.
2923
adc8c848
AD
29242001-12-27 Akim Demaille <akim@epita.fr>
2925
2926 * src/reader.c (packgram): Catch nitems overflows.
2927
14d293ac
AD
29282001-12-27 Akim Demaille <akim@epita.fr>
2929
2930 * src/files.c, src/files.h (guard_obstack): Remove.
2931 * src/output.c (output): Adjust.
2932 * src/reader.c (parse_braces): New, factoring...
2933 (copy_action, copy_guard): these two which are renamed as...
2934 (parse_action, parse_guard): these.
2935 As a voluntary consequence, using braces around guards is now
2936 mandatory.
2937
f499b062
AD
29382001-12-27 Akim Demaille <akim@epita.fr>
2939
2940 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
2941 * src/reader.c (symbol_list): `guard' and `guard_line' are new
2942 members.
2943 (symbol_list_new): Adjust.
2944 (copy_action): action_line is the first line, not the last.
2945 (copy_guard): Just as for actions, store the `action' only, not
2946 the switch/case/break flesh.
2947 Don't parse the user action that might follow the guard, let...
2948 (readgram): do it, i.e., now, there can be an action after a
2949 guard.
2950 In other words the guard is just explicitly optional.
2951 (packgram): Adjust.
2952 * src/output.c (guards_output): New.
2953 (output_parser): Call it when needed.
2954 (output): Also free the guard and attrs obstacks.
2955 * src/files.c, src/files.h (obstack_save): Remove.
2956 (output_files): Remove.
2957 As a result, if one needs the former `.act' file, using an
2958 appropriate skeleton which requires actions and guards is now
2959 required.
2960 * src/main.c (main): Adjust.
2961 * tests/semantic.at: New.
2962 * tests/regression.at: Use `input.y' as input file name.
2963 Avoid 8+3 problems by requiring input.c when the test needs the
2964 parser.
2965
d945f5cd
AD
29662001-12-27 Akim Demaille <akim@epita.fr>
2967
2968 * src/reader.c (symbol_list_new): Be sure to initialize all the
2969 fields.
2970
d200e455
AD
29712001-12-27 Akim Demaille <akim@epita.fr>
2972
2973 All the hacks using a final pseudo state are now useless.
2974
2975 * src/LR0.c (set_state_table): state_table holds exactly nstates.
2976 * src/lalr.c (nLA): New.
2977 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
2978 instead of lookaheadsp from the pseudo state (nstate + 1).
2979
f9507c28
AD
29802001-12-27 Akim Demaille <akim@epita.fr>
2981
2982 * src/output.c (action_row, token_actions): Use a state_t instead
2983 of a integer, and nlookaheads instead of the following state's
2984 lookaheadsp.
2985
065fbd27
AD
29862001-12-27 Akim Demaille <akim@epita.fr>
2987
2988 * src/conflicts.c (log_resolution, flush_shift)
2989 (resolve_sr_conflict, set_conflicts, solve_conflicts)
2990 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
2991 (conflicts_print, print_reductions): Use a state_t instead of an
2992 integer when referring to a state.
2993 As much as possible, depend upon nlookaheads, instead of the
2994 `lookaheadsp' member of the following state (since lookaheads of
2995 successive states are successive, the difference between state n + 1
2996 and n served as the number of lookaheads for state n).
2997 * src/lalr.c (add_lookback_edge): Likewise.
2998 * src/print.c (print_core, print_actions, print_state)
2999 (print_results): Likewise.
3000 * src/print_graph.c (print_core, print_actions, print_state)
3001 (print_graph): Likewise.
3002 * src/conflicts.h: Adjust.
3003
1b177bd7
AD
30042001-12-27 Akim Demaille <akim@epita.fr>
3005
3006 * src/bison.hairy: Formatting/comment changes.
3007 ANSIfy.
3008 Remove `register' indications.
3009 Add plenty of `static'.
3010
7742ddeb
AD
30112001-12-27 Akim Demaille <akim@epita.fr>
3012
3013 * src/output.c (prepare): Drop the muscle `ntbase' which
3014 duplicates ntokens.
3015 * src/bison.simple: Formatting/comment changes.
3016 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3017 is an undocumented synonym.
3018
1fa14068
AD
30192001-12-22 Akim Demaille <akim@epita.fr>
3020
3021 * src/output.c (output_table_data): Change the prototype to use
3022 `int' for array ranges: some invocations do pass an int, not a
3023 short.
3024 Reported by Wayne Green.
3025
b9752825
AD
30262001-12-22 Akim Demaille <akim@epita.fr>
3027
3028 Some actions of web2c.y are improperly triggered.
3029 Reported by Mike Castle.
3030
3031 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3032 * tests/regression.at (Web2c): Rename as...
3033 (Web2c Report): this.
3034 (Web2c Actions): New.
3035
776209d6
AD
30362001-12-22 Akim Demaille <akim@epita.fr>
3037
3038 Reductions in web2c.y are improperly reported.
3039 Reported by Mike Castle.
3040
3041 * src/conflicts.c (print_reductions): Fix.
3042 * tests/regression.at (Web2c): New.
3043
275fc3ad
AD
30442001-12-18 Akim Demaille <akim@epita.fr>
3045
3046 Some host fail on `assert (!"foo")', which expands to
3047 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3048 Reported by Nelson Beebee.
3049
3050 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3051 `#define it_succeeded 0' and `assert (it_succeeded)'.
3052
897668ee
MA
30532001-12-17 Marc Autret <autret_m@epita.fr>
3054
3055 * src/bison.simple: Don't hard code the skeleton line and filename.
3056 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3057 New line counter 'skeleton_line' (skeleton-line muscle).
3058
ab3399e0
PE
30592001-12-17 Paul Eggert <eggert@twinsun.com>
3060
3061 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3062 YYDEBUG must be defined to a nonzero value.
3063
3064 * src/bison.simple (yytname): Do not assume that the user defines
3065 YYDEBUG to a properly parenthesized expression.
3066
3877f72b
AD
30672001-12-17 Akim Demaille <akim@epita.fr>
3068
3069 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3070 nlookaheads is a new member.
3071 Adjust all users.
3072 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3073 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3074 state.
776209d6 3075
331dbc1b
AD
30762001-12-17 Akim Demaille <akim@epita.fr>
3077
3078 * src/files.h, src/files.c (open_files, close_files): Remove.
3079 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3080 let...
3081 * src/reader.c (reader): Do it.
776209d6 3082
be750e4c
AD
30832001-12-17 Akim Demaille <akim@epita.fr>
3084
3085 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 3086
709ae8c6
AD
30872001-12-17 Akim Demaille <akim@epita.fr>
3088
3089 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3090 (flush_reduce): New.
3091 (resolve_sr_conflict): Adjust.
776209d6 3092
f87685c3
AD
30932001-12-17 Akim Demaille <akim@epita.fr>
3094
3095 * src/output.c (output_obstack): Be static and rename as...
3096 (format_obstack): this, to avoid any confusion with files.c's
3097 output_obstack.
3098 * src/reader.h (muscle_obstack): Move to...
3099 * src/output.h: here, since it's defined in output.c.
3100
837491d8
AD
31012001-12-17 Akim Demaille <akim@epita.fr>
3102
3103 * src/output.c (action_row, save_column, default_goto)
3104 (sort_actions, matching_state, pack_vector): Better variable
3105 locality.
3106
796d61fb
AD
31072001-12-17 Akim Demaille <akim@epita.fr>
3108
3109 * src/output.c: Various formatting changes.
776209d6 3110
64d15509
AD
31112001-12-17 Akim Demaille <akim@epita.fr>
3112
3113 * src/files.c (output_files): Free the output_obstack.
3114 * src/main.c (main): Call print and print_graph conditionally.
3115 * src/print.c (print): Work unconditionally.
3116 * src/print_graph.c (print_graph): Work unconditionally.
3117 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3118
fbc8ecb7
MA
31192001-12-16 Marc Autret <autret_m@epita.fr>
3120
3121 * src/output.c (actions_output): Fix. When we use %no-lines,
3122 there is one less line per action.
3123
f0440388
MA
31242001-12-16 Marc Autret <autret_m@epita.fr>
3125
3126 * src/bison.simple: Remove a useless #line directive.
3127 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3128 * src/output.c (get_lines_number): New.
776209d6 3129 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
3130 output muscles.
3131 Fix line numbering.
3132 (actions_output): Computes the number of lines taken by actions.
3133 (output_master_parser): Insert new skeleton which is the name of
3134 the output parser file name.
3135
a79986b8
MA
31362001-12-15 Marc Autret <autret_m@epita.fr>
3137
3138 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3139
4ec8e00f
MA
31402001-12-15 Marc Autret <autret_m@epita.fr>
3141
3142 * src/output.c (output_gram): Keep track of the hairy one.
3143
1a4648ff
AD
31442001-12-15 Akim Demaille <akim@epita.fr>
3145
3146 Make `make distcheck' work.
3147
3148 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3149 system.h which uses libgettext.h.
3150
9c2c67e6
AD
31512001-12-15 Akim Demaille <akim@epita.fr>
3152
3153 * src/nullable.c (set_nullable): Useless rules must be skipped,
3154 otherwise, since we range over their symbols, we might look at a
3155 nonterminal which no longer ``exists'', i.e., it is not counted in
3156 `nvars', hence we overflow our arrays.
3157
93ede233
AD
31582001-12-15 Akim Demaille <akim@epita.fr>
3159
3160 The header can also be produced directly, without any obstack!
3161 Yahoo!
3162
3163 * src/files.c, src/files.h (defines_obstack): Remove.
3164 (compute_header_macro): Global.
3165 (defines_obstack_save): Remove.
3166 * src/reader.c (parse_union_decl): No longer output to
3167 defines_obstack: its content can be found in the `stype' muscle
3168 anyway.
3169 (output_token_translations): Merge into...
3170 (symbols_output): this.
3171 Rename as...
3172 (symbols_save): this.
3173 (reader): Adjust.
3174 * src/output.c (header_output): New.
3175 (output): Call it.
3176
2666f928
AD
31772001-12-15 Akim Demaille <akim@epita.fr>
3178
3179 * src/reader.c (parse_union_decl): Instead of handling two obstack
3180 simultaneously, use one to define the `stype' muscle, and use the
3181 value of the latter to fill defines_obstack.
3182 (copy_comment): Remove.
3183 (copy_comment2): Work for a single obstack.
3184 Rename as...
3185 (copy_comment): this.
3186
428046f8
AD
31872001-12-15 Akim Demaille <akim@epita.fr>
3188
3189 * src/lex.c, src/lex.h (xgetc): No longer static.
3190 * src/reader.c (parse_union_decl): Revamp.
3191
ea52d706
AD
31922001-12-15 Akim Demaille <akim@epita.fr>
3193
3194 Still making progress in separating Bison into (i) input, (ii)
3195 process, (iii) output: now we can directly output the parser file
3196 without using table_obstack at all.
3197
3198 * src/files.c, src/files.h (table_obstack): Bye bye.
3199 (parser_file_name): New.
3200 * src/files.c (compute_output_file_names): Compute it.
3201 * src/output.c (actions_output, output_parser)
3202 (output_master_parser): To a file instead of an obstack.
3203
3f96f4dc
AD
32042001-12-15 Akim Demaille <akim@epita.fr>
3205
3206 Attach actions to rules, instead of pre-outputting them to
3207 actions_obstack.
3208
3209 * src/gram.h (rule_t): action and action_line are new members.
3210 * src/reader.c (symbol_list): Likewise.
3211 (copy_action): Save the actions within the rule.
3212 (packgram): Save them in rule_table.
3213 * src/output.c (actions_output): New.
3214 (output_parser): Use it on `%%actions'.
3215 (output_rule_data): Don't free rule_table.
3216 (output): Do it.
3217 (prepare): Don't save the `action' muscle.
3218 * src/bison.simple: s/%%action/%%actions/.
3219
51576fb3
AD
32202001-12-15 Akim Demaille <akim@epita.fr>
3221
3222 * src/reader.c (copy_action): When --yacc, don't append a `;'
3223 to the user action: let it fail if lacking.
dee049eb 3224 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 3225
2648a72d
AD
32262001-12-14 Akim Demaille <akim@epita.fr>
3227
3228 * src/lex.c (literalchar): Simply return the char you decoded, non
3229 longer mess around with obstacks and int pointers.
3230 Adjust all callers.
3231
92790e5b
AD
32322001-12-14 Akim Demaille <akim@epita.fr>
3233
3234 * src/lex.c (literalchar): Don't escape the special characters,
3235 just decode them, and keep them as char (before, eol was output as
3236 the 2 char string `\n' etc.).
3237 * src/output.c (output_rule_data): Use quotearg to output the
3238 token strings.
3239
927c1557
PE
32402001-12-13 Paul Eggert <eggert@twinsun.com>
3241
3242 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3243 Do not infringe on the global user namespace when using C++.
3244 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3245 All uses of `fprintf' and `stderr' changed.
3246
3247 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3248
ed8e1f68
AD
32492001-12-13 Akim Demaille <akim@epita.fr>
3250
3251 The computation of nullable is broken: it doesn't handle empty
3252 RHS's properly.
3253
3254 * tests/torture.at (GNU AWK Grammar): New.
3255 * tests/sets.at (Nullable): New.
3256 * src/nullable.c (set_nullable): Instead of blindly looping over
3257 `ritems', loop over the rules, and then over their rhs's.
3258
3259 Work around Autotest bugs.
3260
3261 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
3262 frame, because Autotest understand lines starting with a `+' as
3263 traces from the shell. Then, they are not processed properly.
3264 Admittedly an Autotest bug, but we don't have time to wait for
3265 Autotest to catch up.
3266 * tests/regression.at (Broken Closure): Adjust to the new table
3267 frames.
3268 Move to...
3269 * tests/sets.at: here.
3270
cb581495
AD
32712001-12-13 Akim Demaille <akim@epita.fr>
3272
3273 * src/closure.c (closure): Use nrules instead of playing tricks
3274 with BITS_PER_WORD.
3275
2e729273
AD
32762001-12-13 Akim Demaille <akim@epita.fr>
3277
3278 * src/print.c (print_actions): Output the handling of `$' as the
3279 traces do: shifting the token EOF. Before EOF was treated as a
3280 nonterminal.
3281 * tests/regression.at: Adjust some tests.
3282 * src/print_graph.c (print_core): Complete the set of items via
3283 closure. The next-to-final and final states are still unsatisfying,
3284 but that's to be addressed elsewhere.
3285 No longer output the rule numbers, but do output the state number.
3286 A single loop for the shifts + gotos is enough, but picked a
3287 distinct color for each.
3288 (print_graph): Initialize and finalize closure.
3289
107f7dfb
AD
32902001-12-13 Akim Demaille <akim@epita.fr>
3291
3292 * src/reader.c (readgram): Remove dead code, an strip useless
3293 braces.
3294 (get_type): Remove, unused.
3295
9b53a24f
AD
32962001-12-12 Akim Demaille <akim@epita.fr>
3297
3298 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
3299 on that of lib/error.c.
3300
dbfb6dcd
AD
33012001-12-12 Akim Demaille <akim@epita.fr>
3302
3303 Some hosts don't like `/' in includes.
3304
3305 * src/system.h: Include libgettext.h without qualifying the path.
3306 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
3307 $(top_srcdir).
3308
c25fb648
MA
33092001-12-11 Marc Autret <autret_m@epita.fr>
3310
3311 * src/output.c (output_parser): Remove useless muscle.
3312
710ddc4f
MA
33132001-12-11 Marc Autret <autret_m@epita.fr>
3314
3315 * src/bison.simple: Remove #line just before %%epilogue. It
3316 is now handled in ...
3317 * src/reader.c (read_additionnal_code): Add the output of a
3318 #line for the epilogue.
3319
e83d80b8
MA
33202001-12-10 Marc Autret <autret_m@epita.fr>
3321
927c1557 3322 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
3323 replace precedent remove.
3324 * src/bison.simple: Remove #line before %%prologue because
3325 %%input-line is wrong at this time.
3326
971d5158
MA
33272001-12-10 Marc Autret <autret_m@epita.fr>
3328
3329 * src/reader.c (symbols_output): Clean up.
927c1557 3330 * src/output.c (output_gram, output): Clean up.
971d5158 3331
5edafffd
AD
33322001-12-10 Akim Demaille <akim@epita.fr>
3333
3334 * src/lalr.c (initialize_lookaheads): New. Extracted from...
3335 * src/LR0.c (set_state_table): here.
3336 * src/lalr.c (lalr): Call it.
3337
0279f8e9
AD
33382001-12-10 Akim Demaille <akim@epita.fr>
3339
3340 * src/state.h (shifts): Remove the `number' member: shifts are
3341 attached to state, hence no longer need to be labelled with a
3342 state number.
3343
190c4f5f
AD
33442001-12-10 Akim Demaille <akim@epita.fr>
3345
3346 Now that states have a complete set of members, the linked list of
3347 shifts is useless: just fill directly the state's shifts member.
3348
3349 * src/state.h (shifts): Remove the `next' member.
3350 * src/LR0.c (first_state, last_state): Remove.
3351 Adjust the callers.
3352 (augment_automaton): Don't look for the shifts that must be added
3353 a shift on EOF: it is those of the state we looked for! But now,
3354 since shifts are attached, it is no longer needed to looking
3355 merely by its id: its number.
3356
2a73b93d
AD
33572001-12-10 Akim Demaille <akim@epita.fr>
3358
3359 * src/LR0.c (augment_automaton): Better variable locality.
3360 Remove an impossible branch: if there is a state corresponding to
3361 the start symbol being shifted, then there is shift for the start
3362 symbol from the initial state.
3363
74392f6a
AD
33642001-12-10 Akim Demaille <akim@epita.fr>
3365
3366 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
3367 only when appropriate: when insert_start_shifting_state' is not
3368 invoked.
3369 * tests/regression.at (Rule Line Numbers): Adjust.
3370
37c82725
AD
33712001-12-10 Akim Demaille <akim@epita.fr>
3372
3373 * src/LR0.c (augment_automaton): Now that all states have shifts,
3374 merge the two cases addition shifts to the initial state.
3375
6a164e0c
AD
33762001-12-10 Akim Demaille <akim@epita.fr>
3377
3378 * src/lalr.c (set_state_table): Move to...
3379 * src/LR0.c: here.
3380 * src/lalr.c (lalr): Don't call it...
3381 * src/LR0.c (generate_states): do it.
3382 * src/LR0.h (first_state): Remove, only the table is used.
3383
7215de24
AD
33842001-12-10 Akim Demaille <akim@epita.fr>
3385
3386 * src/LR0.h (first_shift, first_reduction): Remove.
3387 * src/lalr.c: Don't use first_shift: find shifts through the
3388 states.
3389
80e25d4d
AD
33902001-12-10 Akim Demaille <akim@epita.fr>
3391
3392 * src/LR0.c: Attach shifts to states as soon as they are
3393 computed.
3394 * src/lalr.c (set_state_table): Instead of assigning shifts to
3395 state, just assert that the mapping was properly done.
3396
0ab3728b
AD
33972001-12-10 Akim Demaille <akim@epita.fr>
3398
3399 * src/LR0.c (insert_start_shift): Rename as...
3400 (insert_start_shifting_state): this.
3401 (insert_eof_shifting_state, insert_accepting_state): New.
3402 (augment_automaton): Adjust.
3403 Better locality of the variables.
3404 When looking if the start_symbol is shifted from the initial
3405 state, using `while (... symbol != start_symbol ...)' sounds
3406 better than `while (... symbol < start_symbol ...)': If fail
3407 to see how the order between symbols could be relevant!
3408
78af9bbc
AD
34092001-12-10 Akim Demaille <akim@epita.fr>
3410
3411 * src/getargs.h: Don't declare `spec_name_prefix' and
3412 `spec_file_prefix', declared by src/files.h.
3413 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
3414 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
3415 * src/output.c (prepare): Adjust.
3416 * src/reader.c (symbols_output): Likewise.
3417 * src/vmsgetargs.c: Vaguely adjust, but who cares?
3418
bdef2a41
AD
34192001-12-10 Akim Demaille <akim@epita.fr>
3420
3421 * src/muscle_tab.c (muscle_init): NULL is a better default than
3422 `"0"'.
3423
3735969c
AD
34242001-12-10 Akim Demaille <akim@epita.fr>
3425
3426 * src/reader.c (reader): Calling symbols_output once is enough.
3427
49701457
AD
34282001-12-10 Akim Demaille <akim@epita.fr>
3429
3430 Now that states have a complete set of members, the linked list of
3431 reductions is useless: just fill directly the state's reductions
3432 member.
3433
3434 * src/state.h (struct reductions): Remove member `number' and
3435 `next'.
3436 * src/LR0.c (first_reduction, last_reduction): Remove.
3437 (save_reductions): Don't link the new reductions, store them in
3438 this_state.
3439 * src/lalr.c (set_state_table): No need to attach reductions to
3440 states, it's already done.
3441 * src/output.c (output_actions): No longer free the shifts, then
3442 the reductions, then the states: free all the states and their
3443 members.
3444
0edad749
AD
34452001-12-10 Akim Demaille <akim@epita.fr>
3446
3447 * src/options.c (OPTN, DRTV, BOTH): New.
3448 (option_table): Use them.
3449
0edad749
AD
3450 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
3451 the job of system.h.
3452 * src/options.c: Don't include stdio.h and xalloc.h for the same
3453 reasons.
3454
5449dd0f
AD
34552001-12-10 Akim Demaille <akim@epita.fr>
3456
3457 * src/output.c (output, prepare): Make sure the values of the
3458 muscles `action' and `prologue' are 0-terminated.
3459
a870c567
AD
34602001-12-10 Akim Demaille <akim@epita.fr>
3461
3462 Clean up GCC warnings.
3463
3464 * src/reader.c (copy_action): `buf' is not used.
3465 (parse_skel_decl): Be static.
3466 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
3467 * src/options.h (create_long_option_table): Have a real prototype.
3468 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
3469 (hash_delete_at): Return const void *.
3470 Adjust casts to preserve the const.
3471
80df8768
AD
34722001-12-10 Akim Demaille <akim@epita.fr>
3473
3474 * configure.in: Require 2.52g.
3475 M4 is not needed, but AUTOM4TE is.
3476 * m4/m4.m4: Remove.
3477 * tests/Makefile.am: Adjust.
3478
f693ad14
AD
34792001-12-10 Akim Demaille <akim@epita.fr>
3480
3481 One structure for states is enough, even though theoretically
3482 there are LR(0) states and LALR(1) states.
3483
3484 * src/lalr.h (state_t): Remove.
3485 (state_table): Be state_t **, not state_t *.
3486 * src/state.h (core, CORE_ALLOC): Rename as...
3487 (state_t, STATE_ALLOC): this.
3488 Add the LALR(1) members: shifts, reductions, errs.
3489 * src/LR0.c (state_table): Rename as...
3490 (state_hash): this, to avoid name clashes with the global
3491 `state_table'.
3492 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
3493 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
3494
74ffbcb6
AD
34952001-12-10 Akim Demaille <akim@epita.fr>
3496
3497 Bison dumps core on bash.y.
3498 Reported by Pascal Bart.
3499
3500 * src/warshall.c (bitmatrix_print): New.
3501 (TC): Use it.
3502 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
3503 j must be the outer loop.
3504 * tests/regression.at (Broken Closure): New.
3505
07708e19
AD
35062001-12-05 Akim Demaille <akim@epita.fr>
3507
3508 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
3509 its argument.
3510