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