]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
* src/output.c (action_row): Let default_rule be always a rule
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-06-30 Akim Demaille <akim@epita.fr>
2
3 * src/output.c (action_row): Let default_rule be always a rule
4 number.
5
6
72002-06-30 Akim Demaille <akim@epita.fr>
8
9 * src/closure.c (print_firsts, print_fderives, closure):
10 Use BITSET_EXECUTE.
11 * src/lalr.c (lookaheads_print): Likewise.
12 * src/state.c (state_rule_lookaheads_print): Likewise.
13 * src/print_graph.c (print_core): Likewise.
14 * src/print.c (print_reductions): Likewise.
15 * src/output.c (action_row): Likewise.
16 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
17
18
192002-06-30 Akim Demaille <akim@epita.fr>
20
21 * src/print_graph.c: Use report_flag.
22
23
242002-06-30 Akim Demaille <akim@epita.fr>
25
26 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
27 to...
28 * src/relation.h, src/relation.c (traverse, relation_digraph)
29 (relation_print, relation_transpose): New.
30
31
322002-06-30 Akim Demaille <akim@epita.fr>
33
34 * src/state.h, src/state.c (shifts_to): New.
35 * src/lalr.c (build_relations): Use it.
36
37
382002-06-30 Akim Demaille <akim@epita.fr>
39
40 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
41 (item_number_of_rule_number, rule_number_of_item_number): New.
42 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
43 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
44 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
45 Propagate their use.
46 Much remains to be done, in particular wrt `shorts' from types.h.
47
48
492002-06-30 Akim Demaille <akim@epita.fr>
50
51 * src/symtab.c (symbol_new): Initialize the `printer' member.
52
53
542002-06-30 Akim Demaille <akim@epita.fr>
55
56 * src/LR0.c (save_reductions): Remove, replaced by...
57 * src/state.h, src/state.c (state_reductions_set): New.
58 (reductions, errs): Rename as...
59 (reductions_t, errs_t): these.
60 Adjust all dependencies.
61
62
632002-06-30 Akim Demaille <akim@epita.fr>
64
65 * src/LR0.c (state_list_t, state_list_append): New.
66 (first_state, last_state): Now symbol_list_t.
67 (this_state): Remove.
68 (new_itemsets, append_states, save_reductions): Take a state_t as
69 argument.
70 (set_states, generate_states): Adjust.
71 (save_shifts): Remove, replaced by...
72 * src/state.h, src/state.c (state_shifts_set): New.
73 (shifts): Rename as...
74 (shifts_t): this.
75 Adjust all dependencies.
76 * src/state.h (state_t): Remove the `next' member.
77
78
792002-06-30 Akim Demaille <akim@epita.fr>
80
81 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
82 escaped in slot 0.
83
84
852002-06-30 Akim Demaille <akim@epita.fr>
86
87 Use hash.h for the state hash table.
88
89 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
90 (allocate_storage): Use state_hash_new.
91 (free_storage): Use state_hash_free.
92 (new_state, get_state): Adjust.
93 * src/lalr.h, src/lalr.c (states): Move to...
94 * src/states.h (state_t): Remove the `link' member, no longer
95 used.
96 * src/states.h, src/states.c: here.
97 (state_hash_new, state_hash_free, state_hash_lookup)
98 (state_hash_insert, states_free): New.
99 * src/states.c (state_table, state_compare, state_hash): New.
100 * src/output.c (output_actions): Do not free states now, since we
101 still need to know the final_state number in `prepare', called
102 afterwards. Do it...
103 * src/main.c (main): here: call states_free after `output'.
104
105
1062002-06-30 Akim Demaille <akim@epita.fr>
107
108 Use hash.h for the state hash table.
109
110 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
111 (allocate_storage): Use state_hash_new.
112 (free_storage): Use state_hash_free.
113 (new_state, get_state): Adjust.
114 * src/lalr.h, src/lalr.c (states): Move to...
115 * src/states.h (state_t): Remove the `link' member, no longer
116 used.
117 * src/states.h, src/states.c: here.
118 (state_hash_new, state_hash_free, state_hash_lookup)
119 (state_hash_insert, states_free): New.
120 * src/states.c (state_table, state_compare, state_hash): New.
121 * src/output.c (output_actions): Do not free states now, since we
122 still need to know the final_state number in `prepare', called
123 afterwards. Do it...
124 * src/main.c (main): here: call states_free after `output'.
125
126
1272002-06-30 Akim Demaille <akim@epita.fr>
128
129 * src/state.h, src/state.c (state_new): New, extracted from...
130 * src/LR0.c (new_state): here.
131 * src/state.h (STATE_ALLOC): Move to...
132 * src/state.c: here.
133 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
134 * src/state.h, src/state.c: here.
135
136
1372002-06-30 Akim Demaille <akim@epita.fr>
138
139 * src/reader.c (gensym): Rename as...
140 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
141 (getsym): Rename as...
142 (symbol_get): this.
143
144
1452002-06-30 Akim Demaille <akim@epita.fr>
146
147 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
148 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
149 * src/output.c, src/print.c, src/print_graph.c: Propagate.
150 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
151
1522002-06-30 Akim Demaille <akim@epita.fr>
153
154 Make the test suite pass with warnings checked.
155
156 * tests/actions.at (Printers and Destructors): Improve.
157 Avoid unsigned vs. signed issues.
158 * tests/calc.at: Don't exercise the scanner here, do it...
159 * tests/input.at (Torturing the Scanner): here.
160
161
1622002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
163
164 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
165 reorganize first lines parallel to yacc.c.
166
1672002-06-28 Akim Demaille <akim@epita.fr>
168
169 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
170 (b4_token_enum, b4_token_defines): New, factored from...
171 * data/lalr1.cc, data/yacc.c, glr.c: here.
172
1732002-06-28 Akim Demaille <akim@epita.fr>
174
175 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
176 unused variables.
177 * src/output.c (merger_output): static.
178
1792002-06-28 Akim Demaille <akim@epita.fr>
180
181 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
182 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
183 pacify GCC.
184 * src/output.c (save_row): Initialize all the variables to pacify GCC.
185
1862002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
187
188 Accumulated changelog for new GLR parsing features.
189
190 * src/conflicts.c (count_total_conflicts): Change name to
191 conflicts_total_count.
192 * src/conflicts.h: Ditto.
193 * src/output.c (token_actions): Use the new name.
194 (output_conflicts): Change conflp => conflict_list_heads, and
195 confl => conflict_list for better readability.
196 * data/glr.c: Use the new names.
197 * NEWS: Add self to GLR announcement.
198
199 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
200
201 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
202 Akim Demaille.
203
204 * data/bison.glr: Change name to glr.c
205 * data/glr.c: Renamed from bison.glr.
206 * data/Makefile.am: Add glr.c
207
208 * src/getargs.c:
209
210 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
211 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
212
213 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
214
215 * data/bison.glr: Be sure to restore the
216 current #line when returning to the skeleton contents after having
217 exposed the input file's #line.
218
219 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
220
221 * data/bison.glr: Bring up to date with changes to bison.simple.
222
223 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
224
225 * data/bison.glr: Correct definitions that use b4_prefix.
226 Various reformatting.
227 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
228 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
229 yytokenp argument; now part of stack.
230 (yychar): Define to behave as documented.
231 (yyclearin): Ditto.
232
233 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
234
235 * src/reader.h: Add declaration for free_merger_functions.
236
237 * src/reader.c (merge_functions): New variable.
238 (get_merge_function): New function.
239 (free_merger_functions): New function.
240 (readgram): Check for %prec that is not followed by a symbol.
241 Handle %dprec and %merge declarations.
242 (packgram): Initialize dprec and merger fields in rules array.
243
244 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
245 conflict_list_cnt, conflict_list_free): New variables.
246 (table_grow): Also grow conflict_table.
247 (prepare_rules): Output dprec and merger tables.
248 (conflict_row): New function.
249 (action_row): Output conflict lists for GLR parser. Don't use
250 default reduction in conflicted states for GLR parser so that there
251 are spaces for the conflict lists.
252 (save_row): Also save conflict information.
253 (token_actions): Allocate conflict list.
254 (merger_output): New function.
255 (pack_vector): Pack conflict table, too.
256 (output_conflicts): New function to output yyconflp and yyconfl.
257 (output_check): Allocate conflict_tos.
258 (output_actions): Output conflict tables, also.
259 (output_skeleton): Output b4_mergers definition.
260 (prepare): Output b4_max_rhs_length definition.
261 Use 'bison.glr' as default skeleton for GLR parsers.
262
263 * src/gram.c (glr_parser): New flag.
264 (grammar_free): Call free_merger_functions.
265
266 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
267 all pairs of conflicting reductions, rather than just all tokens
268 causing conflicts. Needed to size conflict tables.
269 (conflicts_output): Modify call to count_rr_conflicts for new
270 interface.
271 (conflicts_print): Ditto.
272 (count_total_conflicts): New function.
273
274 * src/reader.h (merger_list): New type.
275 (merge_functions): New variable.
276
277 * src/lex.h (tok_dprec, tok_merge): New token types.
278
279 * src/gram.h (rule_s): Add dprec and merger fields.
280 (glr_parser): New flag.
281
282 * src/conflicts.h (count_total_conflicts): New function.
283
284 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
285
286 * doc/bison.texinfo (Generalized LR Parsing): New section.
287 (GLR Parsers): New section.
288 (Language and Grammar): Mention GLR parsing.
289 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
290 Correct typo ("tge" -> "the").
291
292 * data/bison.glr: New skeleton for GLR parsing.
293
294 * tests/cxx-gram.at: New tests for GLR parsing.
295
296 * tests/testsuite.at: Include cxx-gram.at.
297
298 * tests/Makefile.am: Add cxx-gram.at.
299
300 * src/parse-gram.y:
301
302 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
303
304 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
305
3062002-06-27 Akim Demaille <akim@epita.fr>
307
308 * src/options.h, src/options.c: Remove.
309 * src/getargs.c (short_options, long_options): New.
310
3112002-06-27 Akim Demaille <akim@epita.fr>
312
313 * data/bison.simple, data/bison.c++: Rename as...
314 * data/yacc.c, data/lalr1.cc: these.
315 * doc/bison.texinfo (Environment Variables): Remove.
316
3172002-06-25 Raja R Harinath <harinath@cs.umn.edu>
318
319 * src/getargs.c (report_argmatch): Initialize strtok().
320
3212002-06-20 Akim Demaille <akim@epita.fr>
322
323 * data/bison.simple (b4_symbol_actions): New, replaces...
324 (b4_symbol_destructor, b4_symbol_printer): these.
325 (yysymprint): Be sure to call YYPRINT only for tokens, and using
326 user token numbers.
327
3282002-06-20 Akim Demaille <akim@epita.fr>
329
330 * data/bison.simple (yydestructor): Rename as...
331 (yydestruct): this.
332
3332002-06-20 Akim Demaille <akim@epita.fr>
334
335 * src/symtab.h, src/symtab.c (symbol_type_set)
336 (symbol_destructor_set, symbol_precedence_set): The location is
337 the last argument.
338 Adjust all callers.
339
3402002-06-20 Akim Demaille <akim@epita.fr>
341
342 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
343 internals.
344 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
345 Takes a location.
346 * src/symtab.h, src/symtab.c (symbol_class_set)
347 (symbol_user_token_number_set): Likewise.
348 Adjust all callers.
349 Promote complain_at.
350 * tests/input.at (Type Clashes): Adjust.
351
3522002-06-20 Akim Demaille <akim@epita.fr>
353
354 * data/bison.simple (YYLEX): Fix the declaration when
355 %pure-parser.
356
3572002-06-20 Akim Demaille <akim@epita.fr>
358
359 * data/bison.simple (yysymprint): Don't print the token number,
360 just its name.
361 * tests/actions.at (Destructors): Rename as...
362 (Printers and Destructors): this.
363 Also exercise %printer.
364
3652002-06-20 Akim Demaille <akim@epita.fr>
366
367 * data/bison.simple (YYDSYMPRINT): New.
368 Use it to remove many of the #if YYDEBUG/if (yydebug).
369
3702002-06-20 Akim Demaille <akim@epita.fr>
371
372 * src/symtab.h, src/symtab.c (symbol_t): printer and
373 printer_location are new members.
374 (symbol_printer_set): New.
375 * src/parse-gram.y (PERCENT_PRINTER): New token.
376 Handle its associated rule.
377 * src/scan-gram.l: Adjust.
378 (handle_destructor_at, handle_destructor_dollar): Rename as...
379 (handle_symbol_code_at, handle_symbol_code_dollar): these.
380 * src/output.c (symbol_printers_output): New.
381 (output_skeleton): Call it.
382 * data/bison.simple (yysymprint): New. Cannot be named yyprint
383 since there are already many grammar files with a user `yyprint'.
384 Replace the calls to YYPRINT to calls to yysymprint.
385 * tests/calc.at: Adjust.
386 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
387 taking advantage of parser very internal details (stack size!).
388
3892002-06-20 Akim Demaille <akim@epita.fr>
390
391 * src/scan-gram.l: Complete the scanner with the missing patterns
392 to pacify Flex.
393 Use `quote' and `symbol_tag_get' where appropriate.
394
3952002-06-19 Akim Demaille <akim@epita.fr>
396
397 * tests/actions.at (Destructors): Augment to test locations.
398 * data/bison.simple (yydestructor): Pass it the current location
399 if locations are enabled.
400 Prototype only when __STDC__ or C++.
401 Change the argument names to move into the yy name space: there is
402 user code here.
403
4042002-06-19 Akim Demaille <akim@epita.fr>
405
406 * data/bison.simple (b4_pure_if): New.
407 Use it instead of #ifdef YYPURE.
408
4092002-06-19 Akim Demaille <akim@epita.fr>
410
411 * data/bison.simple (b4_location_if): New.
412 Use it instead of #ifdef YYLSP_NEEDED.
413
4142002-06-19 Akim Demaille <akim@epita.fr>
415
416 Prepare @$ in %destructor, but currently don't bind it in the
417 skeleton, as %location use is not cleaned up yet.
418
419 * src/scan-gram.l (handle_dollar, handle_destructor_at)
420 (handle_action_at): New.
421 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
422 a braced_code_t and a location as additional arguments.
423 (handle_destructor_dollar): Instead of requiring `b4_eval', just
424 unquote one when outputting `b4_dollar_dollar'.
425 Adjust callers.
426 * data/bison.simple (b4_eval): Remove.
427 (b4_symbol_destructor): Adjust.
428 * tests/input.at (Invalid @n): Adjust.
429
4302002-06-19 Zack Weinberg <zack@codesourcery.com>
431
432 * doc/bison.texinfo: Document ability to have multiple
433 prologue sections.
434
4352002-06-18 Akim Demaille <akim@epita.fr>
436
437 * src/files.c (compute_base_names): When computing the output file
438 names from the input file name, strip the directory part.
439
4402002-06-18 Akim Demaille <akim@epita.fr>
441
442 * data/bison.simple.new: Comment changes.
443 Reported by Andreas Schwab.
444
4452002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
446
447 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
448 there are no `label `yyoverflowlab' defined but not used' warnings
449 when yyoverflow is defined.
450
4512002-06-18 Akim Demaille <akim@epita.fr>
452
453 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
454 new member.
455 (symbol_destructor_set): Adjust.
456 * src/output.c (symbol_destructors_output): Output the destructor
457 locations.
458 Output the symbol name.
459 * data/bison.simple (b4_symbol_destructor): Adjust.
460
4612002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
462 and Akim Demaille <akim@epita.fr>
463
464 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
465 what's left on the stack when the error recovery hits EOF.
466 * tests/actions.at (Destructors): Complete to exercise this case.
467
4682002-06-17 Akim Demaille <akim@epita.fr>
469
470 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
471 arguments is really empty, not only equal to `[]'.
472 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
473 member.
474 (symbol_destructor_set): New.
475 * src/output.c (symbol_destructors_output): New.
476 * src/reader.h (brace_code_t, current_braced_code): New.
477 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
478 (handle_dollar): Rename as...
479 (handle_action_dollar): this.
480 (handle_destructor_dollar): New.
481 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
482 (grammar_declaration): Use it.
483 * data/bison.simple (yystos): Is always defined.
484 (yydestructor): New.
485 * tests/actions.at (Destructors): New.
486 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
487
4882002-06-17 Akim Demaille <akim@epita.fr>
489
490 * src/symlist.h, src/symlist.c (symbol_list_length): New.
491 * src/scan-gram.l (handle_dollar, handle_at): Compute the
492 rule_length only when needed.
493 * src/output.c (actions_output, token_definitions_output): Output
494 the full M4 block.
495 * src/symtab.c: Don't access directly to the symbol tag, use
496 symbol_tag_get.
497 * src/parse-gram.y: Use symbol_list_free.
498
4992002-06-17 Akim Demaille <akim@epita.fr>
500
501 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
502 (symbol_list_prepend, get_type_name): Move to...
503 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
504 (symbol_list_prepend, symbol_list_n_type_name_get): here.
505 Adjust all callers.
506 (symbol_list_free): New.
507 * src/scan-gram.l (handle_dollar): Takes a location.
508 * tests/input.at (Invalid $n): Adjust.
509
5102002-06-17 Akim Demaille <akim@epita.fr>
511
512 * src/reader.h, src/reader.c (symbol_list_new): Export it.
513 (symbol_list_prepend): New.
514 * src/parse-gram.y (%union): `list' is a new member.
515 (symbols.1): New, replaces...
516 (terms_to_prec.1, nterms_to_type.1): these.
517 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
518 Take a location as additional argument.
519 Adjust all callers.
520
5212002-06-15 Akim Demaille <akim@epita.fr>
522
523 * src/parse-gram.y: Move %token in the declaration section so that
524 we don't depend upon CVS Bison.
525
5262002-06-15 Akim Demaille <akim@epita.fr>
527
528 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
529 * src/print.c (print_core): Use it.
530
5312002-06-15 Akim Demaille <akim@epita.fr>
532
533 * src/conflicts.c (log_resolution): Accept the rule involved in
534 the sr conflicts instead of the lookahead number that points to
535 that rule.
536 (flush_reduce): Accept the current lookahead vector as argument,
537 instead of the index in LA.
538 (resolve_sr_conflict): Accept the current number of lookahead
539 bitset to consider for the STATE, instead of the index in LA.
540 (set_conflicts): Adjust.
541 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
542
5432002-06-15 Akim Demaille <akim@epita.fr>
544
545 * src/state.h (state_t): Replace the `lookaheadsp' member, a
546 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
547 Adjust all dependencies.
548 * src/lalr.c (initialize_lookaheads): Split into...
549 (states_lookaheads_count, states_lookaheads_initialize): these.
550 (lalr): Adjust.
551
5522002-06-15 Akim Demaille <akim@epita.fr>
553
554 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
555 out of...
556 (grammar_rules_print): here.
557 * src/reduce.c (reduce_output): Use it.
558 * tests/reduce.at (Useless Rules, Reduced Automaton)
559 (Underivable Rules): Adjust.
560
5612002-06-15 Akim Demaille <akim@epita.fr>
562
563 Copy BYacc's nice way to report the grammar.
564
565 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
566 New.
567 Don't print the rules' location, it is confusing and useless.
568 (rule_print): Use grammar_rhs_print.
569 * src/print.c (print_grammar): Use grammar_rules_print.
570
5712002-06-15 Akim Demaille <akim@epita.fr>
572
573 Complete and rationalize `useless thing' warnings.
574
575 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
576 (symbol_tag_print): New.
577 Use them everywhere in place of accessing directly the tag member.
578 * src/gram.h, src/gram.c (rule_print): New.
579 Use it where a rule used to be printed `by hand'.
580 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
581 (reduce_grammar_tables): Report the useless rules.
582 (reduce_print): Useless things are a warning, not an error.
583 Report it as such.
584 * tests/reduce.at (Useless Nonterminals, Useless Rules):
585 (Reduced Automaton, Underivable Rules): Adjust.
586 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
587 * tests/conflicts.at (Unresolved SR Conflicts)
588 (Solved SR Conflicts): Adjust.
589
5902002-06-15 Akim Demaille <akim@epita.fr>
591
592 Let symbols have a location.
593
594 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
595 (getsym): Adjust.
596 Adjust all callers.
597 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
598 Use location_t, not int.
599 * src/symtab.c (symbol_check_defined): Take advantage of the
600 location.
601 * tests/regression.at (Invalid inputs): Adjust.
602
6032002-06-15 Akim Demaille <akim@epita.fr>
604
605 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
606 (input): Don't try to initialize yylloc here, do it in the
607 scanner.
608 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
609 * src/gram.h (rule_t): Change line and action_line into location
610 and action_location, of location_t type.
611 Adjust all dependencies.
612 * src/location.h, src/location.c (empty_location): New.
613 * src/reader.h, src/reader.c (grammar_start_symbol_set)
614 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
615 (grammar_current_rule_symbol_append)
616 (grammar_current_rule_action_append): Expect a location as argument.
617 * src/reader.c (grammar_midrule_action): Adjust to attach an
618 action's location as dummy symbol location.
619 * src/symtab.h, src/symtab.c (startsymbol_location): New.
620 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
621 the line numbers.
622
6232002-06-14 Akim Demaille <akim@epita.fr>
624
625 Grammar declarations may be found in the grammar section.
626
627 * src/parse-gram.y (rules_or_grammar_declaration): New.
628 (declarations): Each declaration may end with a semicolon, not
629 just...
630 (grammar_declaration): `"%union"'.
631 (grammar): Branch to rules_or_grammar_declaration.
632
6332002-06-14 Akim Demaille <akim@epita.fr>
634
635 * src/main.c (main): Invoke scanner_free.
636
6372002-06-14 Akim Demaille <akim@epita.fr>
638
639 * src/output.c (m4_invoke): Extracted from...
640 (output_skeleton): here.
641 Free tempfile.
642
6432002-06-14 Akim Demaille <akim@epita.fr>
644
645 * src/parse-gram.y (directives, directive, gram)
646 (grammar_directives, precedence_directives, precedence_directive):
647 Rename as...
648 (declarations, declaration, grammar, grammar_declaration)
649 (precedence_declaration, precedence_declarator): these.
650 (symbol_declaration): New.
651
6522002-06-14 Akim Demaille <akim@epita.fr>
653
654 * src/files.c (action_obstack): Remove, unused.
655 (output_obstack): Remove it, and all its dependencies, as it is no
656 longer needed.
657 * src/reader.c (epilogue_set): Build the epilogue in the
658 muscle_obstack.
659 * src/output.h, src/output.c (muscle_obstack): Move to...
660 * src/muscle_tab.h, src/muscle_tab.h: here.
661 (muscle_init): Initialize muscle_obstack.
662 (muscle_free): New.
663 * src/main.c (main): Call it.
664
6652002-06-14 Akim Demaille <akim@epita.fr>
666
667 * src/location.h: New, extracted from...
668 * src/reader.h: here.
669 * src/Makefile.am (noinst_HEADERS): Merge into
670 (bison_SOURCES): this.
671 Add location.h.
672 * src/parse-gram.y: Use location_t instead of Bison's.
673 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
674 Use location_t instead of ints.
675
6762002-06-14 Akim Demaille <akim@epita.fr>
677
678 * data/bison.simple, data/bison.c++: Be sure to restore the
679 current #line when returning to the skeleton contents after having
680 exposed the input file's #line.
681
6822002-06-12 Akim Demaille <akim@epita.fr>
683
684 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
685 eager.
686 * tests/actions.at (Exotic Dollars): New.
687
6882002-06-12 Akim Demaille <akim@epita.fr>
689
690 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
691 ['"/] too eagerly.
692 * tests/input.at (Torturing the Scanner): New.
693
6942002-06-11 Akim Demaille <akim@epita.fr>
695
696 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
697 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
698 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
699 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
700 * src/reader.c (reader): Use it.
701
7022002-06-11 Akim Demaille <akim@epita.fr>
703
704 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
705 Adjust all callers.
706 (scanner_last_string_free): New.
707
7082002-06-11 Akim Demaille <akim@epita.fr>
709
710 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
711 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
712 (last_string, YY_OBS_FREE): New.
713 Use them when returning an ID.
714
7152002-06-11 Akim Demaille <akim@epita.fr>
716
717 Have Bison grammars parsed by a Bison grammar.
718
719 * src/reader.c, src/reader.h (prologue_augment): New.
720 * src/reader.c (copy_definition): Remove.
721
722 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
723 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
724 (grammar_current_rule_prec_set, grammar_current_rule_check)
725 (grammar_current_rule_symbol_append)
726 (grammar_current_rule_action_append): Export.
727 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
728 (symbol_list_action_append): Remove.
729 Hook the routines from reader.
730 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
731 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
732
733 * src/reader.c (read_declarations): Remove, unused.
734
735 * src/parse-gram.y: Handle the epilogue.
736 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
737 (grammar_start_symbol_set): this.
738 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
739 * src/reader.c (readgram): Remove, unused.
740 (reader): Adjust to insert eoftoken and axiom where appropriate.
741
742 * src/reader.c (copy_dollar): Replace with...
743 * src/scan-gram.h (handle_dollar): this.
744 * src/parse-gram.y: Remove `%thong'.
745
746 * src/reader.c (copy_at): Replace with...
747 * src/scan-gram.h (handle_at): this.
748
749 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
750 New.
751
752 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
753 time being.
754
755 * src/reader.h, src/reader.c (grammar_rule_end): New.
756
757 * src/parse.y (current_type, current_class): New.
758 Implement `%nterm', `%token' support.
759 Merge `%term' into `%token'.
760 (string_as_id): New.
761 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
762 type name.
763
764 * src/parse-gram.y: Be sure to handle properly the beginning of
765 rules.
766
767 * src/parse-gram.y: Handle %type.
768 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
769
770 * src/parse-gram.y: More directives support.
771 * src/options.c: No longer handle source directives.
772
773 * src/parse-gram.y: Fix %output.
774
775 * src/parse-gram.y: Handle %union.
776 Use the prologue locations.
777 * src/reader.c (parse_union_decl): Remove.
778
779 * src/reader.h, src/reader.c (epilogue_set): New.
780 * src/parse-gram.y: Use it.
781
782 * data/bison.simple, data/bison.c++: b4_stype is now either not
783 defined, then default to int, or to the contents of %union,
784 without `union' itself.
785 Adjust.
786 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
787
788 * src/output.c (actions_output): Don't output braces, as they are
789 already handled by the scanner.
790
791 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
792 characters to themselves.
793
794 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
795 that the epilogue has a proper #line.
796
797 * src/parse-gram.y: Handle precedence/associativity.
798
799 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
800 a terminal.
801 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
802 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
803 at all to define terminals that cannot be emitted.
804
805 * src/scan-gram.l: Escape M4 characters.
806
807 * src/scan-gram.l: Working properly with escapes in user
808 strings/characters.
809
810 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
811 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
812 grammar.
813 Use more modest sizes, as for the time being the parser does not
814 release memory, and therefore the process swallows a huge amount
815 of memory.
816
817 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
818 stricter %token grammar.
819
820 * src/symtab.h (associativity): Add `undef_assoc'.
821 (symbol_precedence_set): Do nothing when passed an undef_assoc.
822 * src/symtab.c (symbol_check_alias_consistence): Adjust.
823
824 * tests/regression.at (Invalid %directive): Remove, as it is now
825 meaningless.
826 (Invalid inputs): Adjust to the new error messages.
827 (Token definitions): The new grammar doesn't allow too many
828 eccentricities.
829
830 * src/lex.h, src/lex.c: Remove.
831 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
832 (copy_character, copy_string2, copy_string, copy_identifier)
833 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
834 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
835 (parse_action): Remove.
836 * po/POTFILES.in: Adjust.
837
8382002-06-11 Akim Demaille <akim@epita.fr>
839
840 * src/reader.c (parse_action): Don't store directly into the
841 rule's action member: return the action as a string.
842 Don't require `rule_length' as an argument: compute it.
843 (grammar_current_rule_symbol_append)
844 (grammar_current_rule_action_append): New, eved out from
845 (readgram): here.
846 Remove `action_flag', `rulelength', unused now.
847
8482002-06-11 Akim Demaille <akim@epita.fr>
849
850 * src/reader.c (grammar_current_rule_prec_set).
851 (grammar_current_rule_check): New, eved out from...
852 (readgram): here.
853 Remove `xaction', `first_rhs': useless.
854 * tests/input.at (Type clashes): New.
855 * tests/existing.at (GNU Cim Grammar): Adjust.
856
8572002-06-11 Akim Demaille <akim@epita.fr>
858
859 * src/reader.c (grammar_midrule_action): New, Eved out from
860 (readgram): here.
861
8622002-06-11 Akim Demaille <akim@epita.fr>
863
864 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
865 New.
866 (readgram): Use them as replacement of inlined code, crule and
867 crule1.
868
8692002-06-11 Akim Demaille <akim@epita.fr>
870
871 * src/reader.c (grammar_end, grammar_symbol_append): New.
872 (readgram): Use them.
873 Make the use of `p' as local as possible.
874
8752002-06-10 Akim Demaille <akim@epita.fr>
876
877 GCJ's parser requires the tokens to be defined before the prologue.
878
879 * data/bison.simple: Output the token definition before the user's
880 prologue.
881 * tests/regression.at (Braces parsing, Duplicate string)
882 (Mixing %token styles): Check the output from bison.
883 (Early token definitions): New.
884
8852002-06-10 Akim Demaille <akim@epita.fr>
886
887 * src/symtab.c (symbol_user_token_number_set): Don't complain when
888 assigning twice the same user number to a token, so that we can
889 use it in...
890 * src/lex.c (lex): here.
891 Also use `symbol_class_set' instead of hand written code.
892 * src/reader.c (parse_assoc_decl): Likewise.
893
8942002-06-10 Akim Demaille <akim@epita.fr>
895
896 * src/symtab.c, src/symtab.c (symbol_class_set)
897 (symbol_user_token_number_set): New.
898 * src/reader.c (parse_token_decl): Use them.
899 Use a switch instead of ifs.
900 Use a single argument.
901
9022002-06-10 Akim Demaille <akim@epita.fr>
903
904 Remove `%thong' support as it is undocumented, unused, duplicates
905 `%token's job, and creates useless e-mail traffic with people who
906 want to know what it is, why it is undocumented, unused, and
907 duplicates `%token's job.
908
909 * src/reader.c (parse_thong_decl): Remove.
910 * src/options.c (option_table): Remove "thong".
911 * src/lex.h (tok_thong): Remove.
912
9132002-06-10 Akim Demaille <akim@epita.fr>
914
915 * src/symtab.c, src/symtab.c (symbol_type_set)
916 (symbol_precedence_set): New.
917 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
918 (value_components_used): Remove, unused.
919
9202002-06-09 Akim Demaille <akim@epita.fr>
921
922 Move symbols handling code out of the reader.
923
924 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
925 (axiom): Move to...
926 * src/symtab.h, src/symtab.c: here.
927
928 * src/gram.c (start_symbol): Remove: use startsymbol->number.
929 * src/reader.c (startval): Rename as...
930 * src/symtab.h, src/symtab.c (startsymbol): this.
931 * src/reader.c: Adjust.
932
933 * src/reader.c (symbol_check_defined, symbol_make_alias)
934 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
935 (token_translations_init)
936 Move to...
937 * src/symtab.c: here.
938 * src/reader.c (packsymbols): Move to...
939 * src/symtab.h, src/symtab.c (symbols_pack): here.
940 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
941 argument.
942
9432002-06-03 Akim Demaille <akim@epita.fr>
944
945 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
946 then statements.
947
9482002-06-03 Akim Demaille <akim@epita.fr>
949
950 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
951 structs with non literals.
952 * src/scan-skel.l: never-interactive.
953 * src/conflicts.c (enum conflict_resolution_e): No trailing
954 comma.
955 * src/getargs.c (usage): Split long literal strings.
956 Reported by Hans Aberg.
957
9582002-05-28 Akim Demaille <akim@epita.fr>
959
960 * data/bison.c++: Use C++ ostreams.
961 (cdebug_): New member.
962
9632002-05-28 Akim Demaille <akim@epita.fr>
964
965 * src/output.c (output_skeleton): Be sure to allocate enough room
966 for `/' _and_ for `\0' in full_skeleton.
967
9682002-05-28 Akim Demaille <akim@epita.fr>
969
970 * data/bison.c++: Catch up with bison.simple:
971 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
972 and Paul Eggert <eggert@twinsun.com>: `error' handing.
973 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
974 and popping traces.
975
9762002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
977
978 * src/output.c (output_skeleton): Put an explicit path in front of
979 the skeleton file name, rather than relying on the -I directory,
980 to partially alleviate effects of having a skeleton file lying around
981 in the current directory.
982
9832002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
984
985 * src/conflicts.c (log_resolution): Correct typo:
986 obstack_printf should be obstack_fgrow1.
987
9882002-05-26 Akim Demaille <akim@epita.fr>
989
990 * src/state.h (state_t): `solved_conflicts' is a new member.
991 * src/LR0.c (new_state): Set it to 0.
992 * src/conflicts.h, src/conflicts.c (print_conflicts)
993 (free_conflicts, solve_conflicts): Rename as...
994 (conflicts_print, conflicts_free, conflicts_solve): these.
995 Adjust callers.
996 * src/conflicts.c (enum conflict_resolution_e)
997 (solved_conflicts_obstack): New, used by...
998 (log_resolution): this.
999 Adjust to attach the conflict resolution to each state.
1000 Complete the description with the precedence/associativity
1001 information.
1002 (resolve_sr_conflict): Adjust.
1003 * src/print.c (print_state): Output its solved_conflicts.
1004 * tests/conflicts.at (Unresolved SR Conflicts)
1005 (Solved SR Conflicts): Exercise --report=all.
1006
10072002-05-26 Akim Demaille <akim@epita.fr>
1008
1009 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1010 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1011 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1012 (token_number_t, item_number_as_token_number)
1013 (token_number_as_item_number, muscle_insert_token_number_table):
1014 Rename as...
1015 (symbol_number_t, item_number_as_symbol_number)
1016 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1017 these, since it is more appropriate.
1018
10192002-05-26 Akim Demaille <akim@epita.fr>
1020
1021 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1022 `Error:' lines.
1023 * data/bison.simple (yystos) [YYDEBUG]: New.
1024 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1025 error recovery.
1026 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1027
10282002-05-25 Akim Demaille <akim@epita.fr>
1029
1030 * doc/bison.texinfo (Debugging): Split into...
1031 (Tracing): this new section, its former contents, and...
1032 (Understanding): this new section.
1033 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1034 by...
1035 (report_flag): this.
1036 Adjust all dependencies.
1037 (report_args, report_types, report_argmatch): New.
1038 (usage, getargs): Report/support -r, --report.
1039 * src/options.h
1040 (struct option_table_struct): Rename as..,
1041 (struct option_table_s): this.
1042 Rename the `set_flag' member to `flag' to match with getopt_long's
1043 struct.
1044 * src/options.c (option_table): Split verbose into an entry for
1045 %verbose, and another for --verbose.
1046 Support --report/-r, so remove -r from the obsolete --raw.
1047 * src/print.c: Attach full item sets and lookaheads reports to
1048 report_flag instead of trace_flag.
1049 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1050
10512002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1052 and Paul Eggert <eggert@twinsun.com>
1053
1054 * data/bison.simple (yyparse): Correct error handling to conform to
1055 POSIX and yacc. Specifically, after syntax error is discovered,
1056 do not reduce further before shifting the error token.
1057 Clean up the code a bit by removing the labels yyerrdefault,
1058 yyerrhandle, yyerrpop.
1059 * NEWS: Document the above.
1060
10612002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1062
1063 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1064 type; it isn't always big enough, since it doesn't necessarily
1065 include non-terminals.
1066 (yytranslate): Expand definition of yy_token_number_type, so that
1067 the latter can be removed.
1068 (yy_token_number_type): Remove, only one use.
1069 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1070 don't use TokenNumberType as element type.
1071
1072 * tests/regression.at: Modify expected output to agree with change
1073 to yyr1 and yytranslate.
1074
10752002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1076
1077 * src/reader.c (parse_action): Use copy_character instead of
1078 obstack_1grow.
1079
10802002-05-13 Akim Demaille <akim@epita.fr>
1081
1082 * tests/regression.at (Token definitions): Prototype yylex and
1083 yyerror.
1084
10852002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1086
1087 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
1088 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1089 32-bit arithmetic.
1090 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1091
10922002-05-07 Akim Demaille <akim@epita.fr>
1093
1094 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1095 avoid GCC warnings.
1096
10972002-05-07 Akim Demaille <akim@epita.fr>
1098
1099 Kill GCC warnings.
1100
1101 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1102 over the RHS of each rule.
1103 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1104 * src/state.h (state_t): Member `nitems' is unsigned short.
1105 * src/LR0.c (get_state): Adjust.
1106 * src/reader.c (packgram): Likewise.
1107 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1108 `Type'.
1109 (muscle_insert_int_table): Remove, unused.
1110 (prepare_rules): Remove `max'.
1111
11122002-05-06 Akim Demaille <akim@epita.fr>
1113
1114 * src/closure.c (print_firsts): Display of the symbol tags.
1115 (bitmatrix_print): Move to...
1116 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1117 here.
1118 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1119
11202002-05-06 Akim Demaille <akim@epita.fr>
1121
1122 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1123 hash_do_for_each.
1124
11252002-05-06 Akim Demaille <akim@epita.fr>
1126
1127 * src/LR0.c (new_state, get_state): Instead of using the global
1128 `kernel_size' and `kernel_base', have two new arguments:
1129 `core_size' and `core'.
1130 Adjust callers.
1131
11322002-05-06 Akim Demaille <akim@epita.fr>
1133
1134 * src/reader.c (packgram): No longer end `ritem' with a 0
1135 sentinel: it is not used.
1136
11372002-05-05 Akim Demaille <akim@epita.fr>
1138
1139 New experimental feature: display the lookaheads in the report and
1140 graph.
1141
1142 * src/print (print_core): When --trace-flag, display the rules
1143 lookaheads.
1144 * src/print_graph.c (print_core): Likewise.
1145 Swap the arguments.
1146 Adjust caller.
1147
11482002-05-05 Akim Demaille <akim@epita.fr>
1149
1150 * tests/torture.at (Many lookaheads): New test.
1151
11522002-05-05 Akim Demaille <akim@epita.fr>
1153
1154 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
1155 (GENERATE_MUSCLE_INSERT_TABLE): this.
1156 (output_int_table, output_unsigned_int_table, output_short_table)
1157 (output_token_number_table, output_item_number_table): Replace with...
1158 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
1159 (muscle_insert_short_table, muscle_insert_token_number_table)
1160 (muscle_insert_item_number_table): these.
1161 Adjust all callers.
1162 (prepare_tokens): Don't free `translations', since...
1163 * src/reader.h, src/reader.c (grammar_free): do it.
1164 Move to...
1165 * src/gram.h, src/gram.c (grammar_free): here.
1166 * data/bison.simple, data/bison.c++: b4_token_number_max is now
1167 b4_translate_max.
1168
11692002-05-05 Akim Demaille <akim@epita.fr>
1170
1171 * src/output.c (output_unsigned_int_table): New.
1172 (prepare_rules): `i' is unsigned.
1173 `prhs', `rline', `r2' are unsigned int.
1174 Rename muscle `rhs_number_max' as `rhs_max'.
1175 Output muscles `prhs_max', `rline_max', and `r2_max'.
1176 Free rline and r1.
1177 * data/bison.simple, data/bison.c++: Adjust to use these muscles
1178 to compute types instead of constant types.
1179 * tests/regression.at (Web2c Actions): Adjust.
1180
11812002-05-04 Akim Demaille <akim@epita.fr>
1182
1183 * src/symtab.h (SALIAS, SUNDEF): Rename as...
1184 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
1185 Adjust dependencies.
1186 * src/output.c (token_definitions_output): Be sure not to output a
1187 `#define 'a'' when fed with `%token 'a' "a"'.
1188 * tests/regression.at (Token definitions): New.
1189
11902002-05-03 Paul Eggert <eggert@twinsun.com>
1191
1192 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
1193 for K&R C.
1194
11952002-05-03 gettextize <bug-gnu-gettext@gnu.org>
1196
1197 * Makefile.am (SUBDIRS): Remove intl.
1198 (EXTRA_DIST): Add config/config.rpath.
1199
12002002-05-03 Akim Demaille <akim@epita.fr>
1201
1202 * data/bison.simple (m4_if): Don't output empty enums.
1203 And actually, output valid enum definitions :(.
1204
12052002-05-03 Akim Demaille <akim@epita.fr>
1206
1207 * configure.bat: Remove, completely obsolete.
1208 * Makefile.am (EXTRA_DIST): Adjust.
1209 Don't distribute config.rpath...
1210 * config/Makefile.am (EXTRA_DIST): Do it.
1211
12122002-05-03 Akim Demaille <akim@epita.fr>
1213
1214 * configure.in (GETTEXT_VERSION): New.
1215 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
1216
12172002-05-03 Akim Demaille <akim@epita.fr>
1218
1219 * data/bison.simple (b4_token_enum): New.
1220 (b4_token_defines): Use it to output tokens both as #define and
1221 enums.
1222 Suggested by Paul Eggert.
1223 * src/output.c (token_definitions_output): Don't output spurious
1224 white spaces.
1225
12262002-05-03 Akim Demaille <akim@epita.fr>
1227
1228 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1229
12302002-05-02 Robert Anisko <robert@lrde.epita.fr>
1231
1232 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
1233 Update the stack class, give a try to deque as the default container.
1234
12352002-05-02 Akim Demaille <akim@epita.fr>
1236
1237 * data/bison.simple (yyparse): Do not implement @$ = @1.
1238 (YYLLOC_DEFAULT): Adjust to do it.
1239 * doc/bison.texinfo (Location Default Action): Fix.
1240
12412002-05-02 Akim Demaille <akim@epita.fr>
1242
1243 * src/reader.c (parse_braces): Merge into...
1244 (parse_action): this.
1245
12462002-05-02 Akim Demaille <akim@epita.fr>
1247
1248 * configure.in (ALL_LINGUAS): Remove.
1249 * po/LINGUAS, hr.po: New.
1250
12512002-05-02 Akim Demaille <akim@epita.fr>
1252
1253 Remove the so called hairy (semantic) parsers.
1254
1255 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
1256 * src/gram.h, src/gram.c (semantic_parser): Remove.
1257 (rule_t): Remove the guard and guard_line members.
1258 * src/lex.h (token_t): remove tok_guard.
1259 * src/options.c (option_table): Remove %guard and %semantic_parser
1260 support.
1261 * src/output.c, src/output.h (guards_output): Remove.
1262 (prepare): Adjust.
1263 (token_definitions_output): Don't output the `T'
1264 tokens (???).
1265 (output_skeleton): Don't output the guards.
1266 * src/files.c, src/files.c (attrsfile): Remove.
1267 * src/reader.c (symbol_list): Remove the guard and guard_line
1268 members.
1269 Adjust dependencies.
1270 (parse_guard): Remove.
1271 * data/bison.hairy: Remove.
1272 * doc/bison.texinfo (Environment Variables): Remove occurrences of
1273 BISON_HAIRY.
1274
12752002-05-02 Akim Demaille <akim@epita.fr>
1276
1277 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
1278 (parse_guard): Rename the formal argument `stack_offset' as
1279 `rule_length', which is more readable.
1280 Adjust callers.
1281 (copy_at, copy_dollar): Instead of outputting the hard coded
1282 values of $$, $n and so forth, output invocation to b4_lhs_value,
1283 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
1284 Note: this patch partially drops `semantic-parser' support: it
1285 always does `rule_length - n', where semantic parsers ought to
1286 always use `-n'.
1287 * data/bison.simple, data/bison.c++ (b4_lhs_value)
1288 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
1289
12902002-05-02 Akim Demaille <akim@epita.fr>
1291
1292 * configure.in (AC_INIT): Bump to 1.49b.
1293 (AM_INIT_AUTOMAKE): Short invocation.
1294
12952002-05-02 Akim Demaille <akim@epita.fr>
1296
1297 Version 1.49a.
1298
12992002-05-01 Akim Demaille <akim@epita.fr>
1300
1301 * src/skeleton.h: Remove.
1302
13032002-05-01 Akim Demaille <akim@epita.fr>
1304
1305 * src/skeleton.h: Fix the #endif.
1306 Reported by Magnus Fromreide.
1307
13082002-04-26 Paul Eggert <eggert@twinsun.com>
1309
1310 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
1311 Define if we define YYSTYPE and YYLTYPE, respectively.
1312 (YYCOPY): Fix [] quoting problem in the non-GCC case.
1313
13142002-04-25 Robert Anisko <robert@lrde.epita.fr>
1315
1316 * src/scan-skel.l: Postprocess quadrigraphs.
1317
1318 * src/reader.c (copy_character): New function, used to output
1319 single characters while replacing `[' and `]' with quadrigraphs, to
1320 avoid troubles with M4 quotes.
1321 (copy_comment): Output characters with copy_character.
1322 (read_additionnal_code): Likewise.
1323 (copy_string2): Likewise.
1324 (copy_definition): Likewise.
1325
1326 * tests/calc.at: Exercise M4 quoting.
1327
13282002-04-25 Akim Demaille <akim@epita.fr>
1329
1330 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
1331 between `!' and the command.
1332 Reported by Paul Eggert.
1333
13342002-04-24 Robert Anisko <robert@lrde.epita.fr>
1335
1336 * tests/calc.at: Exercise prologue splitting.
1337
1338 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
1339 `b4_post_prologue' instead of `b4_prologue'.
1340
1341 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
1342 muscles.
1343 (output): Free pre_prologue_obstack and post_prologue_obstack.
1344 * src/files.h, src/files.c (attrs_obstack): Remove.
1345 (pre_prologue_obstack, post_prologue_obstack): New.
1346 * src/reader.c (copy_definition): Add a parameter to specify the
1347 obstack to fill, instead of using attrs_obstack unconditionally.
1348 (read_declarations): Pass pre_prologue_obstack to copy_definition if
1349 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
1350
13512002-04-23 Paul Eggert <eggert@twinsun.com>
1352
1353 * data/bison.simple: Remove unnecessary commentary and white
1354 space differences from 1_29-branch.
1355 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
1356
1357 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
1358 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
1359 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
1360 constructors or destructors.
1361
1362 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
1363
13642002-04-23 Akim Demaille <akim@epita.fr>
1365
1366 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
1367 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
1368 location with columns.
1369 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
1370 All reported by Paul Eggert.
1371
13722002-04-22 Akim Demaille <akim@epita.fr>
1373
1374 * src/reduce.c (dump_grammar): Move to...
1375 * src/gram.h, src/gram.c (grammar_dump): here.
1376 Be sure to separate long item numbers.
1377 Don't read the members of a rule's prec if its nil.
1378
13792002-04-22 Akim Demaille <akim@epita.fr>
1380
1381 * src/output.c (table_size, table_grow): New.
1382 (MAXTABLE): Remove, replace uses with table_size.
1383 (pack_vector): Instead of dying when the table is too big, grow it.
1384
13852002-04-22 Akim Demaille <akim@epita.fr>
1386
1387 * data/bison.simple (yyr1): Its type is that of a token number.
1388 * data/bison.c++ (r1_): Likewise.
1389 * tests/regression.at (Web2c Actions): Adjust.
1390
13912002-04-22 Akim Demaille <akim@epita.fr>
1392
1393 * src/reader.c (token_translations_init): 256 is now the default
1394 value for the error token, i.e., it will be assigned another
1395 number if the user assigned 256 to one of her tokens.
1396 (reader): Don't force 256 to error.
1397 * doc/bison.texinfo (Symbols): Adjust.
1398 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
1399 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
1400 etc. instead of 10, 20, 30 (which was used to `jump' over error
1401 (256) and undefined (2)).
1402
14032002-04-22 Akim Demaille <akim@epita.fr>
1404
1405 Propagate more token_number_t.
1406
1407 * src/gram.h (token_number_as_item_number)
1408 (item_number_as_token_number): New.
1409 * src/output.c (GENERATE_OUTPUT_TABLE): New.
1410 Use it to create output_item_number_table and
1411 output_token_number_table.
1412 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1413 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
1414 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
1415 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
1416
14172002-04-22 Akim Demaille <akim@epita.fr>
1418
1419 * src/output.h, src/output.c (get_lines_number): Remove.
1420
14212002-04-19 Akim Demaille <akim@epita.fr>
1422
1423 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
1424 as Lex/Flex'.
1425 (Debugging): More details about enabling the debugging features.
1426 (Table of Symbols): Describe $$, $n, @$, and @n.
1427 Suggested by Tim Josling.
1428
14292002-04-19 Akim Demaille <akim@epita.fr>
1430
1431 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
1432
14332002-04-10 Akim Demaille <akim@epita.fr>
1434
1435 * src/system.h: Rely on HAVE_LIMITS_H.
1436 Suggested by Paul Eggert.
1437
14382002-04-09 Akim Demaille <akim@epita.fr>
1439
1440 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
1441 full stderr, and strip it according to the bison options, instead
1442 of composing the error message from different bits.
1443 This makes it easier to check for several error messages.
1444 Adjust all the invocations.
1445 Add an invocation exercising the error token.
1446 Add an invocation demonstrating a stupid error message.
1447 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
1448 Adjust the tests.
1449 Error message are for stderr, not stdout.
1450
14512002-04-09 Akim Demaille <akim@epita.fr>
1452
1453 * src/gram.h, src/gram.c (error_token_number): Remove, use
1454 errtoken->number.
1455 * src/reader.c (reader): Don't specify the user token number (2)
1456 for $undefined, as it uselessly prevents using it.
1457 * src/gram.h (token_number_t): Move to...
1458 * src/symtab.h: here.
1459 (state_t.number): Is a token_number_t.
1460 * src/print.c, src/reader.c: Use undeftoken->number instead of
1461 hard coded 2.
1462 (Even though this 2 is not the same as above: the number of the
1463 undeftoken remains being 2, it is its user token number which
1464 might not be 2).
1465 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
1466 `user_token_number_max'.
1467 Output `undef_token_number'.
1468 * data/bison.simple, data/bison.c++: Use them.
1469 Be sure to map invalid yylex return values to
1470 `undef_token_number'. This saves us from gratuitous SEGV.
1471
1472 * tests/conflicts.at (Solved SR Conflicts)
1473 (Unresolved SR Conflicts): Adjust.
1474 * tests/regression.at (Web2c Actions): Adjust.
1475
14762002-04-08 Akim Demaille <akim@epita.fr>
1477
1478 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
1479 Adding #line.
1480 Remove the duplicate `typedefs'.
1481 (RhsNumberType): Fix the declaration and various other typos.
1482 Use __ofile__.
1483 * data/bison.simple: Use __ofile__.
1484 * src/scan-skel.l: Handle __ofile__.
1485
14862002-04-08 Akim Demaille <akim@epita.fr>
1487
1488 * src/gram.h (item_number_t): New, the type of item numbers in
1489 RITEM. Note that it must be able to code symbol numbers as
1490 positive number, and the negation of rule numbers as negative
1491 numbers.
1492 Adjust all dependencies (pretty many).
1493 * src/reduce.c (rule): Remove this `short *' pointer: use
1494 item_number_t.
1495 * src/system.h (MINSHORT, MAXSHORT): Remove.
1496 Include `limits.h'.
1497 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
1498 (shortcpy): Remove.
1499 (MAXTABLE): Move to...
1500 * src/output.c (MAXTABLE): here.
1501 (prepare_rules): Use output_int_table to output rhs.
1502 * data/bison.simple, data/bison.c++: Adjust.
1503 * tests/torture.at (Big triangle): Move the limit from 254 to
1504 500.
1505 * tests/regression.at (Web2c Actions): Ajust.
1506
1507 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
1508 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
1509 passes, but produces negative #line number, once fixed, GCC is
1510 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
1511 C), it passes.
1512 * src/state.h (state_h): Code input lines on ints, not shorts.
1513
15142002-04-08 Akim Demaille <akim@epita.fr>
1515
1516 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
1517 and then the grammar.
1518
15192002-04-08 Akim Demaille <akim@epita.fr>
1520
1521 * src/system.h: No longer using strndup.
1522
15232002-04-07 Akim Demaille <akim@epita.fr>
1524
1525 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
1526 * src/output.c (output_table_data): Return the longest number.
1527 (prepare_tokens): Output `token_number_max').
1528 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
1529 New.
1530 Use them to define yy_token_number_type/TokenNumberType.
1531 Use this type for yytranslate.
1532 * tests/torture.at (Big triangle): Push the limit from 124 to
1533 253.
1534 * tests/regression.at (Web2c Actions): Adjust.
1535
15362002-04-07 Akim Demaille <akim@epita.fr>
1537
1538 * tests/torture.at (Big triangle): New.
1539 (GNU AWK Grammar, GNU Cim Grammar): Move to...
1540 * tests/existing.at: here.
1541
15422002-04-07 Akim Demaille <akim@epita.fr>
1543
1544 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
1545 nritems.
1546 Adjust dependencies.
1547
15482002-04-07 Akim Demaille <akim@epita.fr>
1549
1550 * src/reader.c: Normalize increments to prefix form.
1551
15522002-04-07 Akim Demaille <akim@epita.fr>
1553
1554 * src/reader.c, symtab.c: Remove debugging code.
1555
15562002-04-07 Akim Demaille <akim@epita.fr>
1557
1558 Rename all the `bucket's as `symbol_t'.
1559
1560 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
1561 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
1562 * src/symtab.c, src/symtab.h (bucket): Rename as...
1563 (symbol_t): this.
1564 (symbol_list_new, bucket_check_defined, bucket_make_alias)
1565 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
1566 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1567 (buckets_new, buckets_free, buckets_do): Rename as...
1568 (symbol_list_new, symbol_check_defined, symbol_make_alias)
1569 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1570 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
1571 (symbols_new, symbols_free, symbols_do): these.
1572
15732002-04-07 Akim Demaille <akim@epita.fr>
1574
1575 Use lib/hash for the symbol table.
1576
1577 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
1578 EOF.
1579 * src/lex.c (lex): Set the `number' member of new terminals.
1580 * src/reader.c (bucket_check_defined, bucket_make_alias)
1581 (bucket_check_alias_consistence, bucket_translation): New.
1582 (reader, grammar_free, readgram, token_translations_init)
1583 (packsymbols): Adjust.
1584 (reader): Number the predefined tokens.
1585 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
1586 for predefined tokens.
1587 * src/symtab.h (bucket): Remove all the hash table related
1588 members.
1589 * src/symtab.c (symtab): Replace by...
1590 (bucket_table): this.
1591 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1592 (buckets_new, buckets_do): New.
1593
15942002-04-07 Akim Demaille <akim@epita.fr>
1595
1596 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
1597 (start_symbol, max_user_token_number, semantic_parser)
1598 (error_token_number): Initialize.
1599 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
1600 Initialize.
1601 (reader): Don't.
1602 (errtoken, eoftoken, undeftoken, axiom): Extern.
1603
16042002-04-07 Akim Demaille <akim@epita.fr>
1605
1606 * src/gram.h (rule_s): prec and precsym are now pointers
1607 to the bucket giving the priority/associativity.
1608 Member `associativity' removed: useless.
1609 * src/reduce.c, src/conflicts.c: Adjust.
1610
16112002-04-07 Akim Demaille <akim@epita.fr>
1612
1613 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
1614 Properly escape the symbols' TAG when outputting them.
1615
16162002-04-07 Akim Demaille <akim@epita.fr>
1617
1618 * src/lalr.h (LA): Is a bitsetv, not bitset*.
1619
16202002-04-07 Akim Demaille <akim@epita.fr>
1621
1622 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
1623 (LArule): this, which is an array to rule_t*.
1624 * src/print.c, src/conflicts.c: Adjust.
1625
16262002-04-07 Akim Demaille <akim@epita.fr>
1627
1628 * src/gram.h (rule_t): Rename `number' as `user_number'.
1629 `number' is a new member.
1630 Adjust dependencies.
1631 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
1632
16332002-04-07 Akim Demaille <akim@epita.fr>
1634
1635 As a result of the previous patch, it is no longer needed
1636 to reorder ritem itself.
1637
1638 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
1639
16402002-04-07 Akim Demaille <akim@epita.fr>
1641
1642 Be sure never to walk through RITEMS, but use only data related to
1643 the rules themselves. RITEMS should be banished.
1644
1645 * src/output.c (output_token_translations): Rename as...
1646 (prepare_tokens): this.
1647 In addition to `translate', prepare the muscles `tname' and
1648 `toknum', which were handled by...
1649 (output_rule_data): this.
1650 Remove, and move the remainder of its outputs into...
1651 (prepare_rules): this new routines, which also merges content from
1652 (output_gram): this.
1653 (prepare_rules): Be sure never to walk through RITEMS.
1654 (output_stos): Rename as...
1655 (prepare_stos): this.
1656 (output): Always invoke prepare_states, after all, just don't use it
1657 in the output if you don't need it.
1658
16592002-04-07 Akim Demaille <akim@epita.fr>
1660
1661 * src/LR0.c (new_state): Display `nstates' as the name of the
1662 newly created state.
1663 Adjust to initialize first_state and last_state if needed.
1664 Be sure to distinguish the initial from the final state.
1665 (new_states): Create the itemset of the initial state, and use
1666 new_state.
1667 * src/closure.c (closure): Now that the initial state has its
1668 items properly set, there is no need for a special case when
1669 creating `ruleset'.
1670
1671 As a result, now the rule 0, reducing to $axiom, is visible in the
1672 outputs. Adjust the test suite.
1673
1674 * tests/conflicts.at (Solved SR Conflicts)
1675 (Unresolved SR Conflicts): Adjust.
1676 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
1677 * tests/conflicts.at (S/R in initial): New.
1678
16792002-04-07 Akim Demaille <akim@epita.fr>
1680
1681 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
1682 the RHS of the rules.
1683 * src/output.c (output_gram): Likewise.
1684
16852002-04-07 Akim Demaille <akim@epita.fr>
1686
1687 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
1688 bucket.
1689 Adjust all dependencies.
1690 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
1691 `number' of the buckets too.
1692 * src/gram.h: Include `symtab.h'.
1693 (associativity): Move to...
1694 * src/symtab.h: here.
1695 No longer include `gram.h'.
1696
16972002-04-07 Akim Demaille <akim@epita.fr>
1698
1699 * src/gram.h, src/gram.c (rules_rhs_length): New.
1700 (ritem_longest_rhs): Use it.
1701 * src/gram.h (rule_t): `number' is a new member.
1702 * src/reader.c (packgram): Set it.
1703 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
1704 the end of `rules', and count them out of `nrules'.
1705 (reduce_output, dump_grammar): Adjust.
1706 * src/print.c (print_grammar): It is no longer needed to check for
1707 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
1708 * tests/reduce.at (Reduced Automaton): New test.
1709
17102002-04-07 Akim Demaille <akim@epita.fr>
1711
1712 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
1713 lacking `+ 1' to nrules, Bison reported as useless a token if it
1714 was used solely to set the precedence of the last rule...
1715
17162002-04-07 Akim Demaille <akim@epita.fr>
1717
1718 * data/bison.c++, data/bison.simple: Don't output the current file
1719 name in #line, to avoid useless diffs between two identical
1720 outputs under different names.
1721
17222002-04-07 Akim Demaille <akim@epita.fr>
1723
1724 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
1725 Normalize loops to using `< nrules + 1', not `<= nrules'.
1726
17272002-04-07 Akim Demaille <akim@epita.fr>
1728
1729 * TODO: Update.
1730
17312002-04-07 Akim Demaille <akim@epita.fr>
1732
1733 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
1734 bucket.value as bucket.number.
1735
17362002-04-07 Akim Demaille <akim@epita.fr>
1737
1738 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
1739 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1740 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
1741 RHS, instead of being an index in RITEMS.
1742
17432002-04-04 Paul Eggert <eggert@twinsun.com>
1744
1745 * doc/bison.texinfo: Update copyright date.
1746 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
1747 (Symbols): Warn about running Bison in one character set,
1748 but compiling and/or running in an incompatible one.
1749 Warn about character code 256, too.
1750
17512002-04-03 Paul Eggert <eggert@twinsun.com>
1752
1753 * src/bison.data (YYSTACK_ALLOC): Depend on whether
1754 YYERROR_VERBOSE is nonzero, not whether it is defined.
1755
1756 Merge changes from bison-1_29-branch.
1757
17582002-03-20 Paul Eggert <eggert@twinsun.com>
1759
1760 Merge fixes from Debian bison_1.34-1.diff.
1761
1762 * configure.in (AC_PREREQ): 2.53.
1763
17642002-03-20 Akim Demaille <akim@epita.fr>
1765
1766 * src/conflicts.c (log_resolution): Argument `resolution' is const.
1767
17682002-03-19 Paul Eggert <eggert@twinsun.com>
1769
1770 * src/bison.simple (YYCOPY): New macro.
1771 (YYSTACK_RELOCATE): Use it.
1772 Remove Type arg; no longer needed. All callers changed.
1773 (yymemcpy): Remove; no longer needed.
1774
1775 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
1776 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1777
17782002-03-19 Akim Demaille <akim@epita.fr>
1779
1780 Test and fix the #line outputs.
1781
1782 * tests/atlocal.at (GCC): New.
1783 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
1784 (Prologue synch line, ,%union synch line, Postprologue synch line)
1785 (Action synch line, Epilogue synch line): New tests.
1786 * src/reader.c (parse_union_decl): Define the muscle stype_line.
1787 * data/bison.simple, data/bison.c++: Use it.
1788
17892002-03-19 Akim Demaille <akim@epita.fr>
1790
1791 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
1792 (Solved SR Conflicts, %expect not enough, %expect right)
1793 (%expect too much): Move to...
1794 * tests/conflicts.at: this new file.
1795
17962002-03-19 Akim Demaille <akim@epita.fr>
1797
1798 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1799 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
1800 that we can move to enums for instance.
1801 * src/output.c (token_definitions_output): Output a list of
1802 `token-name, token-number' instead of the #define.
1803 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
1804
18052002-03-14 Akim Demaille <akim@epita.fr>
1806
1807 Use Gettext 0.11.1.
1808
18092002-03-09 Robert Anisko <robert@lrde.epita.fr>
1810
1811 * data/bison.c++: Make the user able to add members to the generated
1812 parser by subclassing.
1813
18142002-03-05 Robert Anisko <robert@lrde.epita.fr>
1815
1816 * src/reader.c (read_additionnal_code): `c' should be an integer, not
1817 a character.
1818 Reported by Nicolas Tisserand and Nicolas Burrus.
1819
18202002-03-04 Robert Anisko <robert@lrde.epita.fr>
1821
1822 * src/reader.c: Warn about lacking semi-colons, do not complain.
1823
18242002-03-04 Robert Anisko <robert@lrde.epita.fr>
1825
1826 * data/bison.c++: Remove a debug line.
1827
18282002-03-04 Robert Anisko <robert@lrde.epita.fr>
1829
1830 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
1831 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
1832 provide a default implementation.
1833
18342002-03-04 Akim Demaille <akim@epita.fr>
1835
1836 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
1837 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
1838 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
1839 * tests/semantic.at (Parsing Guards): Similarly.
1840 * src/reader.at (readgram): Complain if the last rule is not ended
1841 with a semi-colon.
1842
18432002-03-04 Akim Demaille <akim@epita.fr>
1844
1845 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
1846 * src/closure.c: here.
1847 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
1848 RTC.
1849 * src/warshall.h, src/warshall.c: Remove.
1850 * tests/sets.at (Broken Closure): Adjust.
1851
18522002-03-04 Akim Demaille <akim@epita.fr>
1853
1854 * src/output.c (output_skeleton): tempdir is const.
1855 bytes_read is unused.
1856
18572002-03-04 Akim Demaille <akim@epita.fr>
1858
1859 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
1860 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
1861 Update.
1862 From Michael Hayes.
1863
18642002-03-04 Akim Demaille <akim@epita.fr>
1865
1866 * src/closure.c (closure): `r' is unused.
1867
18682002-03-04 Akim Demaille <akim@epita.fr>
1869
1870 * tests/sets.at (Broken Closure): Add the ending `;'.
1871 * src/reader.at (readgram): Complain if a rule is not ended with a
1872 semi-colon.
1873
18742002-03-04 Akim Demaille <akim@epita.fr>
1875
1876 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
1877 (count_sr_conflicts): Use bitset_count.
1878 * src/reduce.c (inaccessable_symbols): Ditto.
1879 (bits_size): Remove.
1880 * src/warshall.h, src/warshall.c: Convert to bitsetv.
1881
18822002-03-04 Akim Demaille <akim@epita.fr>
1883
1884 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
1885 * src/reduce.c: Remove the `bitset_zero's following the
1886 `bitset_create's, as now it is performed by the latter.
1887
18882002-03-04 Akim Demaille <akim@epita.fr>
1889
1890 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
1891 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
1892 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
1893 latest sources from Michael.
1894
18952002-03-04 Akim Demaille <akim@epita.fr>
1896
1897 * src/output.c (output): Don't free the grammar.
1898 * src/reader.c (grammar_free): New.
1899 * src/main.c (main): Call it and don't free symtab here.
1900
19012002-03-04 Akim Demaille <akim@epita.fr>
1902
1903 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
1904 before returning.
1905 Reported by Benoit Perrot.
1906
19072002-03-04 Akim Demaille <akim@epita.fr>
1908
1909 Use bitset operations when possible, not loops over bits.
1910
1911 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
1912 bitset_or.
1913 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
1914 * src/reduce.c (useless_nonterminals): Formatting changes.
1915 * src/warshall.c (TC): Use bitset_or.
1916
19172002-03-04 Akim Demaille <akim@epita.fr>
1918
1919 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
1920 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
1921 Ditto.
1922
19232002-03-04 Akim Demaille <akim@epita.fr>
1924
1925 * src/lalr.c (F): Now a bitset*.
1926 Adjust all dependencies.
1927
19282002-03-04 Akim Demaille <akim@epita.fr>
1929
1930 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
1931 Adjust all dependencies.
1932
19332002-03-04 Akim Demaille <akim@epita.fr>
1934
1935 * src/L0.c, src/LR0.h (nstates): Be size_t.
1936 Adjust comparisons (signed vs unsigned).
1937 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
1938 bitset*.
1939 Adjust all dependencies.
1940
19412002-03-04 Akim Demaille <akim@epita.fr>
1942
1943 * src/closure.c (firsts): Now, also a bitset.
1944 Adjust all dependencies.
1945 (varsetsize): Remove, now unused.
1946 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
1947
19482002-03-04 Akim Demaille <akim@epita.fr>
1949
1950 * src/print.c: Convert to use bitset.h, not hand coded iterations
1951 over ints.
1952
19532002-03-04 Akim Demaille <akim@epita.fr>
1954
1955 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
1956
19572002-03-04 Akim Demaille <akim@epita.fr>
1958
1959 * src/closure.c (ruleset): Be a bitset.
1960 (rulesetsize): Remove.
1961
19622002-03-04 Akim Demaille <akim@epita.fr>
1963
1964 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
1965 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
1966 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
1967 * src/closure.c (fderives): Be an array of bitsets.
1968
19692002-02-28 Robert Anisko <robert@lrde.epita.fr>
1970
1971 * data/bison.c++: Merge the two generated headers. Insert a copyright
1972 notice in each output file.
1973
19742002-02-28 Akim Demaille <akim@epita.fr>
1975
1976 * data/bison.c++: Copy the prologue of bison.simple to fetch
1977 useful M4 definitions, such as b4_header_guard.
1978
19792002-02-25 Akim Demaille <akim@epita.fr>
1980
1981 * src/getargs.c (version): Give the name of the authors, and use a
1982 translator friendly scheme for the bgr
1983 copyright notice.
1984
19852002-02-25 Akim Demaille <akim@epita.fr>
1986
1987 * src/output.c (header_output): Remove, now handled completely via
1988 M4.
1989
19902002-02-25 Akim Demaille <akim@epita.fr>
1991
1992 * m4/m4.m4: New, from CVS Autoconf.
1993 * configure.in: Invoke it.
1994 * src/output.c (output_skeleton): Use its result instead of the
1995 hard coded name.
1996
19972002-02-25 Akim Demaille <akim@epita.fr>
1998
1999 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2000 Fileutils 4.1.5.
2001 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2002 * src/output.c (output_skeleton): Use mkstemp to create a real
2003 temporary file.
2004 Move the filling of `skeleton' and its muscle to...
2005 (prepare): here.
2006 (output): Move the definition of the prologue muscle to...
2007 (prepare): here.
2008 * src/system.h (DEFAULT_TMPDIR): New.
2009
20102002-02-14 Paul Eggert <eggert@twinsun.com>
2011
2012 Remove the support for C++ namespace cleanliness; it was
2013 causing more problems than it was curing, since it didn't work
2014 properly on some nonstandard C++ compilers. This can wait
2015 for a proper C++ parser.
2016
2017 * NEWS: Document this.
2018 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2019 of C++, as it's treated like C now.
2020 * src/bison.simple (YYSTD): Remove.
2021 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2022 Treat C++ just like Standard C instead of trying to support
2023 namespace cleanliness.
2024
20252002-02-14 Akim Demaille <akim@epita.fr>
2026
2027 * tests/regression.at (else): Adjust to Andreas' change.
2028
20292002-02-14 Akim Demaille <akim@epita.fr>
2030
2031 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2032
20332002-02-13 Andreas Schwab <schwab@suse.de>
2034
2035 * src/output.c (output_rule_data): Don't output NULL, it might
2036 not be defined yet.
2037
20382002-02-11 Robert Anisko <robert@lrde.epita.fr>
2039
2040 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2041 (Copyright notice): Update.
2042
20432002-02-11 Akim Demaille <akim@epita.fr>
2044
2045 * tests/regression.at (%nonassoc and eof): Don't include
2046 nonportable headers.
2047
20482002-02-08 Robert Anisko <robert@lrde.epita.fr>
2049
2050 * data/bison.c++: Correct error recovery. Make the user able to
2051 initialize the starting location.
2052
20532002-02-07 Akim Demaille <akim@epita.fr>
2054
2055 * tests/input.at: New.
2056
20572002-02-07 Robert Anisko <robert@lrde.epita.fr>
2058
2059 * data/bison.c++: Replace some direct m4 expansions by constants. Be
2060 more consistent when naming methods and variables. Put preprocessor
2061 directives around tables only needed for debugging.
2062
20632002-02-07 Robert Anisko <robert@lrde.epita.fr>
2064
2065 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2066 C++ parsers.
2067 (yy::b4_name::parse): Use print_.
2068
20692002-02-07 Robert Anisko <robert@lrde.epita.fr>
2070
2071 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2072
20732002-02-07 Robert Anisko <robert@lrde.epita.fr>
2074
2075 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2076 C++ parsers.
2077 (yy::b4_name::parse): Build verbose error messages, and use error_.
2078
20792002-02-06 Robert Anisko <robert@lrde.epita.fr>
2080
2081 * data/bison.c++: Fix m4 quoting in comments.
2082
20832002-02-06 Robert Anisko <robert@lrde.epita.fr>
2084
2085 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2086 not expanded by m4.
2087
20882002-02-05 Akim Demaille <akim@epita.fr>
2089
2090 * data/bison.c++: Adjust to the M4 back end.
2091 More is certainly needed.
2092
20932002-02-05 Akim Demaille <akim@epita.fr>
2094
2095 Give a try to M4 as a back end.
2096
2097 * lib/readpipe.c: New, from wdiff.
2098 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2099 BISON_HAIRY.
2100 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2101 specific values. Now it is m4 that performs the lookup.
2102 * src/parse-skel.y: Remove.
2103 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2104 * src/output.c (actions_output, guards_output)
2105 (token_definitions_output): No longer keeps track of the output
2106 line number, hence remove the second argument.
2107 (guards_output): Check against the guard member of a rule, not the
2108 action member.
2109 Adjust callers.
2110 (output_skeleton): Don't look for the skeleton location, let m4 do
2111 that.
2112 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2113 file will be used.
2114 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2115 (prepare): Given that for the time being changesyntax is not
2116 usable in M4, rename the muscles using `-' to `_'.
2117 Define `defines_flag', `output_parser_name' and `output_header_name'.
2118 * src/output.h (actions_output, guards_output)
2119 (token_definitions_output): Adjust prototypes.
2120 * src/scan-skel.l: Instead of scanning the skeletons, it now
2121 processes the output of m4: `__oline__' and `#output'.
2122 * data/bison.simple: Adjust to be used by M4(sugar).
2123 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2124 to date.
2125 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2126 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2127 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2128 shamelessly stolen from CVS Autoconf.
2129
21302002-02-05 Akim Demaille <akim@epita.fr>
2131
2132 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2133 * configure.in: Check for the declarations of free and malloc.
2134 * src/muscle_tab.c: Adjust.
2135
21362002-02-05 Akim Demaille <akim@epita.fr>
2137
2138 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
2139 which have no values.
2140
21412002-02-05 Akim Demaille <akim@epita.fr>
2142
2143 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
2144 * data/: here.
2145
21462002-01-29 Paul Eggert <eggert@twinsun.com>
2147
2148 * src/bison.simple (YYSIZE_T): Do not define merely because
2149 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
2150 On some platforms, <alloca.h> does not declare YYSTD (size_t).
2151
21522002-01-27 Akim Demaille <akim@epita.fr>
2153
2154 Fix `%nonassoc and eof'.
2155
2156 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
2157 which were not properly copied! Replace
2158 memcpy (res->errs, src->errs, src->nerrs);
2159 with
2160 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
2161 !!!
2162 * tests/regression.at (%nonassoc and eof): Adjust to newest
2163 Autotest: `.' is not in the PATH.
2164
21652002-01-27 Akim Demaille <akim@epita.fr>
2166
2167 * tests/sets.at (AT_EXTRACT_SETS): New.
2168 (Nullable): Use it.
2169 (Firsts): New.
2170
21712002-01-26 Akim Demaille <akim@epita.fr>
2172
2173 * tests/actions.at, tests/calc.at, tests/headers.at,
2174 * tests/torture.at: Adjust to the newest Autotest which no longer
2175 forces `.' in the PATH.
2176
21772002-01-25 Akim Demaille <akim@epita.fr>
2178
2179 * tests/regression.at (%nonassoc and eof): New.
2180 Suggested by Robert Anisko.
2181
21822002-01-24 Akim Demaille <akim@epita.fr>
2183
2184 Bison dumps core when trying to complain about broken input files.
2185 Reported by Cris van Pelt.
2186
2187 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
2188 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
2189 into...
2190 (Invalid inputs): Strengthen: exercise parse_percent_token.
2191
21922002-01-24 Robert Anisko <robert.anisko@epita.fr>
2193
2194 * src/Makefile.am: Add bison.c++.
2195 * src/bison.c++: New skeleton.
2196
21972002-01-21 Paolo Bonzini <bonzini@gnu.org>
2198
2199 * po/it.po: New.
2200
22012002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
2202
2203 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
2204
22052002-01-20 Marc Autret <marc@gnu.org>
2206
2207 * src/files.c (compute_output_file_names): Fix
2208
22092002-01-20 Marc Autret <marc@gnu.org>
2210
2211 * tests/output.at: New test.
2212 * src/files.c (compute_base_names): Don't map extensions when
2213 the YACC flag is set, use defaults.
2214 Reported by Evgeny Stambulchik.
2215
22162002-01-20 Marc Autret <marc@gnu.org>
2217
2218 * src/system.h: Need to define __attribute__ away for non-GCC
2219 compilers as well (i.e. the vendor C compiler).
2220 Suggested by Albert Chin-A-Young.
2221
22222002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
2223
2224 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
2225 canonical definition.
2226 * src/system.h: Use the canonical definition for PARAMS (avoids
2227 a conflict with the macro from lib/hash.h).
2228
22292002-01-11 Akim Demaille <akim@epita.fr>
2230
2231 * configure.in: Use AC_FUNC_STRNLEN.
2232 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
2233
22342002-01-09 Akim Demaille <akim@epita.fr>
2235
2236 * src/files.c, src/files.h (output_infix): New.
2237 (tab_extension): Remove.
2238 (compute_base_names): Compute the former, drop the latter.
2239 * src/output.c (prepare): Insert the muscles `output-infix', and
2240 `output-suffix'.
2241 * src/parse-skel.y (string, string.1): New.
2242 (section.header): Use it.
2243 (section.yacc): Remove.
2244 (prefix): Remove too.
2245 * src/scan-skel.l: Adjust.
2246 * src/bison.simple, src/bison.hairy: Adjust.
2247
22482002-01-09 Akim Demaille <akim@epita.fr>
2249
2250 * configure.in (WERROR_CFLAGS): Compute it.
2251 * src/Makefile.am (CFLAGS): Pass it.
2252 * tests/atlocal.in (CFLAGS): Idem.
2253 * src/files.c: Fix a few warnings.
2254 (get_extension_index): Remove, unused.
2255
22562002-01-08 Akim Demaille <akim@epita.fr>
2257
2258 * src/getargs.c (AS_FILE_NAME): New.
2259 (getargs): Use it to convert DOSish file names.
2260 * src/files.c (base_name): Rename as full_base_name to avoid
2261 clashes with `base_name ()'.
2262 (filename_split): New.
2263 (compute_base_names): N-th rewrite, using filename_split.
2264
22652002-01-08 Akim Demaille <akim@epita.fr>
2266
2267 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
2268 New, stolen from the Fileutils 4.1.
2269 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
2270 * configure.in: Check for the presence of memrchr, and of its
2271 prototype.
2272
22732002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
2274
2275 * lib/hash.h (__P): Added definition for this macro.
2276 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
2277 BUILT_SOURCES, to ensure they are generated first.
2278 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
2279 %error-verbose to allow bootstrapping with bison 1.30x.
2280
22812002-01-06 Akim Demaille <akim@epita.fr>
2282
2283 * src/reader.c (parse_braces): Don't fetch the next char, the
2284 convention is to fetch on entry.
2285 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
2286 'switch' without a following semicolon.
2287 * tests/regression.at (braces parsing): New.
2288
22892002-01-06 Akim Demaille <akim@epita.fr>
2290
2291 Bison is dead wrong in its RR conflict reports.
2292
2293 * tests/torture.at (GNU Cim Grammar): New.
2294 * src/conflicts.c (count_rr_conflicts): Fix.
2295
22962002-01-06 Akim Demaille <akim@epita.fr>
2297
2298 Creating package.m4 from configure.ac causes too many problems.
2299
2300 * tests/Makefile.am (package.m4): Create it by hand,
2301 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
2302
23032002-01-06 Akim Demaille <akim@epita.fr>
2304
2305 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
2306 skeleton.h.
2307
23082002-01-04 Paul Eggert <eggert@twinsun.com>
2309
2310 * doc/bison.texinfo (Debugging):
2311 Remove YYSTDERR; it's no longer defined or used.
2312 Also, s/cstdio.h/cstdio/.
2313
23142002-01-03 Akim Demaille <akim@epita.fr>
2315
2316 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
2317
23182002-01-03 Akim Demaille <akim@epita.fr>
2319
2320 * src/parse-skel.y (process_skeleton): Don't bind the parser's
2321 tracing code to --trace, wait for a better --trace option, with
2322 args.
2323
23242002-01-03 Akim Demaille <akim@epita.fr>
2325
2326 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
2327 The ISO C++ standard is extremely clear about it: stderr is
2328 considered a macro, not a regular symbol (see table 94 `Header
2329 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
2330 Therefore std:: does not apply to it. It still does with fprintf.
2331 Also, s/cstdio.h/cstdio/.
2332
23332002-01-03 Akim Demaille <akim@epita.fr>
2334
2335 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
2336 for non system headers.
2337
23382002-01-02 Akim Demaille <akim@epita.fr>
2339
2340 Equip the skeleton chain with location tracking, runtime trace,
2341 pure parser and scanner.
2342
2343 * src/parse-skel.y: Request a pure parser, locations, and prefix
2344 renaming.
2345 (%union): Having several members with the same type does not help
2346 type mismatches, simplify.
2347 (YYPRINT, yyprint): New.
2348 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
2349 (skel_error): this.
2350 Handle locations.
2351 * src/scan-skel.l: Adjust to these changes.
2352 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
2353 (LOCATION_PRINT, skel_control_t): New.
2354
23552001-12-30 Akim Demaille <akim@epita.fr>
2356
2357 * src/parse-skel.y: Get rid of the shift/reduce conflict:
2358 replace `gb' with BLANKS.
2359 * src/scan-skel.l: Adjust.
2360
23612001-12-30 Akim Demaille <akim@epita.fr>
2362
2363 * src/system.h: We don't need nor want bcopy.
2364 Throw away MS-DOS crap: we don't need getpid.
2365 * configure.in: We don't need strndup. It was even causing
2366 problems: because Flex includes the headers *before* us,
2367 _GNU_SOURCE is not defined by config.h, and therefore strndup was
2368 not visible.
2369 * lib/xstrndup.c: New.
2370 * src/scan-skel.l: Use it.
2371 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
2372 * src/parse-skel.y: Use %directives instead of #defines.
2373
23742001-12-30 Akim Demaille <akim@epita.fr>
2375
2376 * src/skeleton.h: New.
2377 * src/output.c (output_parser, output_master_parser): Remove, dead
2378 code.
2379 * src/output.h (get_lines_number, actions_output, guards_output)
2380 (token_definitions_output): Prototype them.
2381 * src/parse-skel.y: Add the license notice.
2382 Include output.h and skeleton.h.
2383 (process_skeleton): Returns void, and takes a single parameter.
2384 * src/scan-skel.l: Add the license notice.
2385 Include skeleton.h.
2386 Don't use %option yylineno: it seems that then Flex imagines
2387 REJECT has been used, and therefore it won't reallocate its
2388 buffers (which makes no other sense to me than a bug). It results
2389 in warnings for `unused: yy_flex_realloc'.
2390
23912001-12-30 Robert Anisko <robert.anisko@epita.fr>
2392
2393 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2394 (MUSCLE_INSERT_PREFIX): ...to there.
2395 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2396 (MUSCLE_INSERT_PREFIX): Move from here...
2397
2398 * src/bison.hairy: Add a section directive. Put braces around muscle
2399 names. This parser skeleton is still broken, but Bison should not
2400 choke on a bad muscle 'syntax'.
2401 * src/bison.simple: Add a section directive. Put braces around muscle
2402 names.
2403
2404 * src/files.h (strsuffix, stringappend): Add declarations.
2405 (tab_extension): Add declaration.
2406 (short_base_name): Add declaration.
2407
2408 * src/files.c (strsuffix, stringappend): No longer static. These
2409 functions are used in the skeleton parser.
2410 (tab_extension): New.
2411 (compute_base_names): Use the computations done in this function
2412 to guess if the generated parsers should have '.tab' in their
2413 names.
2414 (short_base_name): No longer static.
2415
2416 * src/output.c (output_skeleton): New.
2417 (output): Disable call to output_master_parser, and give a try to
2418 a new skeleton handling system.
2419 (guards_output, actions_output): No longer static.
2420 (token_definitions_output, get_lines_number): No longer static.
2421
2422 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
2423
2424 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
2425 parse-skel.y.
2426
2427 * src/parse-skel.y: New file.
2428 * src/scan-skel.l: New file.
2429
24302001-12-29 Akim Demaille <akim@epita.fr>
2431
2432 %name-prefix is broken.
2433
2434 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
2435 Adjust all dependencies.
2436 * tests/headers.at (export YYLTYPE): Strengthen this test: use
2437 %name-prefix.
2438
2439 Renaming yylval but not yylloc is not consistent. Now we do.
2440
2441 * src/bison.simple: Prefix yylloc if used.
2442 * doc/bison.texinfo (Decl Summary): Document that.
2443
24442001-12-29 Akim Demaille <akim@epita.fr>
2445
2446 * doc/bison.texinfo: Promote `%long-directive' over
2447 `%long_directive'.
2448 Remove all references to fixed-output-files, yacc is enough.
2449
24502001-12-29 Akim Demaille <akim@epita.fr>
2451
2452 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
2453 user prologue. These are defaults.
2454 * tests/actions.at (Mid-rule actions): Make sure the user can
2455 define YYDEBUG and YYERROR_VERBOSE.
2456
24572001-12-29 Akim Demaille <akim@epita.fr>
2458
2459 * src/output.c (header_output): Don't forget to export YYLTYPE and
2460 yylloc.
2461 * tests/headers.at (export YYLTYPE): New, make sure it does.
2462 * tests/regression.at (%union and --defines, Invalid CPP headers):
2463 Move to...
2464 * tests/headers.at: here.
2465
24662001-12-29 Akim Demaille <akim@epita.fr>
2467
2468 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
2469
24702001-12-29 Akim Demaille <akim@epita.fr>
2471
2472 * tests/actions.at (Mid-rule actions): Output on a single line
2473 instead of several.
2474
24752001-12-29 Akim Demaille <akim@epita.fr>
2476
2477 * doc/bison.texinfo: Formatting changes.
2478
24792001-12-29 Akim Demaille <akim@epita.fr>
2480
2481 Don't store the token defs in a muscle, just be ready to output it
2482 on command. Now possible via `symbols'. Fixes a memory leak.
2483
2484 * src/output.c (token_definitions_output): New.
2485 (output_parser, header_output): Use it.
2486 * src/reader.c (symbols_save): Remove.
2487
24882001-12-29 Akim Demaille <akim@epita.fr>
2489
2490 * src/bison.simple: Do not provide a default for YYSTYPE and
2491 YYLTYPE before the user's prologue. Otherwise it's hardly... a
2492 default.
2493
24942001-12-29 Akim Demaille <akim@epita.fr>
2495
2496 Mid-rule actions are simply... ignored!
2497
2498 * src/reader.c (readgram): Be sure to attach mid-rule actions to
2499 the empty-rule associated to the dummy symbol, not to the host
2500 rule.
2501 * tests/actions.at (Mid-rule actions): New.
2502
25032001-12-29 Akim Demaille <akim@epita.fr>
2504
2505 Memory leak.
2506
2507 * src/reader.c (reader): Free grammar.
2508
25092001-12-29 Akim Demaille <akim@epita.fr>
2510
2511 Memory leak.
2512
2513 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
2514 since it allocates it for each state, although only one is needed.
2515 (allocate_storage): Do it here.
2516
25172001-12-29 Akim Demaille <akim@epita.fr>
2518
2519 * src/options.h, src/options.c (create_long_option_table): Rename
2520 as...
2521 (long_option_table_new): this, with a clearer prototype.
2522 (percent_table): Remove, unused,
2523 * src/getargs.c (getargs): Adjust.
2524
25252001-12-29 Akim Demaille <akim@epita.fr>
2526
2527 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
2528 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
2529 as states.
2530
25312001-12-29 Akim Demaille <akim@epita.fr>
2532
2533 * src/lalr.c (build_relations): Rename `states' as `states1'.
2534 Sorry, I don't understand exactly what it is, no better name...
2535
25362001-12-29 Akim Demaille <akim@epita.fr>
2537
2538 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
2539 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
2540 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
2541 as rules.
2542
25432001-12-29 Akim Demaille <akim@epita.fr>
2544
2545 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
2546 ago.
2547
25482001-12-29 Akim Demaille <akim@epita.fr>
2549
2550 * src/reader.c, src/reader.h (user_toknums): Remove.
2551 Adjust all users to use symbols[i]->user_token_number.
2552
25532001-12-29 Akim Demaille <akim@epita.fr>
2554
2555 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
2556 Adjust all users to use symbols[i]->prec or ->assoc.
2557
25582001-12-29 Akim Demaille <akim@epita.fr>
2559
2560 * src/reader.c, src/reader.h (tags): Remove.
2561 Adjust all users to use symbols[i]->tag.
2562
25632001-12-29 Akim Demaille <akim@epita.fr>
2564
2565 * src/gram.h, src/gram.c (symbols): New, similar to state_table
2566 and rule_table.
2567 * src/reader.c (packsymbols): Fill this table.
2568 Drop sprec.
2569 * src/conflicts.c (resolve_sr_conflict): Adjust.
2570 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
2571 single table.
2572 Use symbols[i]->tag instead of tags[i].
2573
25742001-12-29 Akim Demaille <akim@epita.fr>
2575
2576 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
2577 In addition, put a comment in there, to replace...
2578 * tests/regression.at (%union and C comments): Remove.
2579
25802001-12-29 Akim Demaille <akim@epita.fr>
2581
2582 * tests/regression.at (Web2c Actions): Blindly move the actual
2583 output as expected output. The contents *seem* right to me, but I
2584 can't pretend reading perfectly parser tables... Nonetheless, all
2585 the other tests pass correctly, the table look OK, even though the
2586 presence of `$axiom' is to be noted: AFAICS it is useless (but
2587 harmless).
2588
25892001-12-29 Akim Demaille <akim@epita.fr>
2590
2591 * src/reader.c (readgram): Don't add the rule 0 if there were no
2592 rules read. In other words, add it _after_ having performed
2593 grammar sanity checks.
2594 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
2595
25962001-12-29 Akim Demaille <akim@epita.fr>
2597
2598 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
2599 visible, and some states have now a different number.
2600
26012001-12-29 Akim Demaille <akim@epita.fr>
2602
2603 * src/reader.c (readgram): Bind the initial rule's lineno to that
2604 of the first rule.
2605 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
2606 (Solved SR Conflicts): Adjust rule 0's line number.
2607
26082001-12-29 Akim Demaille <akim@epita.fr>
2609
2610 Fix the `GAWK Grammar' failure.
2611
2612 * src/LR0.c (final_state): Initialize to -1 so that we do compute
2613 the reductions of the first state which was mistakenly confused
2614 with the final state because precisely final_state was initialized
2615 to 0.
2616 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
2617 now noticed by Bison.
2618 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
2619 have a reduction on $default.
2620
26212001-12-29 Akim Demaille <akim@epita.fr>
2622
2623 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
2624 rule line numbers.
2625 * src/closure.c (print_closure): Likewise.
2626 * src/derives.c (print_derives): Likewise.
2627 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
2628 now.
2629
26302001-12-29 Akim Demaille <akim@epita.fr>
2631
2632 * src/lalr.c (lookaheads_print): New.
2633 (lalr): Call it when --trace-flag.
2634 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
2635 are dumped.
2636
26372001-12-29 Akim Demaille <akim@epita.fr>
2638
2639 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
2640 when walking through ritem, even via rule->rhs.
2641 * src/reduce.c (dump_grammar, useful_production, reduce_output)
2642 (useful_production, useless_nonterminals): Likewise.
2643 (reduce_grammar_tables): Likewise, plus update nritems.
2644 * src/nullable.c (set_nullable): Likewise.
2645 * src/lalr.c (build_relations): Likewise.
2646 * tests/sets.at (Nullable): Adjust.
2647 Fortunately, now, the $axiom is no longer nullable.
2648
26492001-12-29 Akim Demaille <akim@epita.fr>
2650
2651 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
2652 the 0-sentinel.
2653 * src/gram.c (ritem_longest_rhs): Likewise.
2654 * src/reduce.c (nonterminals_reduce): Likewise.
2655 * src/print_graph.c (print_graph): Likewise.
2656 * src/output.c (output_rule_data): Likewise.
2657 * src/nullable.c (set_nullable): Likewise.
2658
26592001-12-29 Akim Demaille <akim@epita.fr>
2660
2661 * src/output.c: Comment changes.
2662
26632001-12-27 Paul Eggert <eggert@twinsun.com>
2664
2665 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
2666 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
2667 Sparc, as they were causing more porting problems than the
2668 (minor) performance improvement was worth.
2669
2670 Also, catch up with 1.31's YYSTD.
2671
26722001-12-27 Akim Demaille <akim@epita.fr>
2673
2674 * src/output.c (output_gram): Rely on nritems, not the
2675 0-sentinel. See below.
2676 Use -1 as separator, not 0.
2677 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
2678 Rely on -1 as separator in yyrhs, instead of 0.
2679 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
2680 twice `Now at end of input', therefore there are two lines less to
2681 expect.
2682
26832001-12-27 Akim Demaille <akim@epita.fr>
2684
2685 * tests/regression.at (Unresolved SR Conflicts):
2686 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
2687 below.
2688
26892001-12-27 Akim Demaille <akim@epita.fr>
2690
2691 * src/LR0.c (new_state): Recognize the final state by the fact it
2692 is reached by eoftoken.
2693 (insert_start_shifting_state, insert_eof_shifting_state)
2694 (insert_accepting_state, augment_automaton): Remove, since now
2695 these states are automatically computed from the initial state.
2696 (generate_states): Adjust.
2697 * src/print.c: When reporting a rule number to the user, substract
2698 1, so that the axiom rule is rule 0, and the first user rule is 1.
2699 * src/reduce.c: Likewise.
2700 * src/print_graph.c (print_core): For the time being, just as for
2701 the report, depend upon --trace-flags to dump the full set of
2702 items.
2703 * src/reader.c (readgram): Once the grammar read, insert the rule
2704 0: `$axiom: START-SYMBOL $'.
2705 * tests/set.at: Adjust: rule 0 is now displayed, and since the
2706 number of the states has changed (the final state is no longer
2707 necessarily the last), catch up.
2708
27092001-12-27 Akim Demaille <akim@epita.fr>
2710
2711 Try to make the use of the eoftoken valid. Given that its value
2712 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
2713 is used instead of > 0 where appropriate, (ii), depend upon nritems
2714 instead of the 0-sentinel.
2715
2716 * src/gram.h, src/gram.c (nritems): New.
2717 Expected to be duplication of nitems, but for the time being...
2718 * src/reader.c (packgram): Assert nritems and nitems are equal.
2719 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
2720 * src/closure.c (print_closure, print_fderives): Likewise.
2721 * src/gram.c (ritem_print): Likewise.
2722 * src/print.c (print_core, print_grammar): Likewise.
2723 * src/print_graph.c: Likewise.
2724
27252001-12-27 Akim Demaille <akim@epita.fr>
2726
2727 * src/main.c (main): If there are complains after grammar
2728 reductions, then output the report anyway if requested, then die.
2729 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
2730 * src/reader.c (eoftoken): New.
2731 (parse_token_decl): If the token being defined has value `0', it
2732 is the eoftoken.
2733 (packsymbols): No longer hack `tags' to insert `$' by hand.
2734 Be sure to preserve the value of the eoftoken.
2735 (reader): Make sure eoftoken is defined.
2736 Initialize nsyms to 0: now eoftoken is created just like the others.
2737 * src/print.c (print_grammar): Don't special case the eof token.
2738 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
2739 lie anyway, albeit pleasant.
2740 * tests/calc.at: Exercise error messages with eoftoken.
2741 Change the grammar so that empty input is invalid.
2742 Adjust expectations.
2743 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
2744
27452001-12-27 Akim Demaille <akim@epita.fr>
2746
2747 * configure.in: Check the protos of strchr ans strspn.
2748 Replace strchr if needed.
2749 * src/system.h: Provide the protos of strchr, strspn and memchr if
2750 missing.
2751 * lib/strchr.c: New.
2752 * src/reader.c (symbols_save): Use strchr.
2753
27542001-12-27 Akim Demaille <akim@epita.fr>
2755
2756 * src/print.c, src/print_graph.c (escape): New.
2757 Use it to quote the TAGS outputs.
2758 * src/print_graph.c (print_state): Now errors are in red, and
2759 reductions in green.
2760 Prefer high to wide: output the state number on a line of its own.
2761
27622001-12-27 Akim Demaille <akim@epita.fr>
2763
2764 * src/state.h, src/state.c (reductions_new): New.
2765 * src/LR0.c (set_state_table): Let all the states have a
2766 `reductions', even if reduced to 0.
2767 (save_reductions): Adjust.
2768 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
2769 * src/print.c (print_reductions, print_actions): Adjust.
2770 * src/output.c (action_row): Adjust.
2771
27722001-12-27 Akim Demaille <akim@epita.fr>
2773
2774 * src/state.h, src/state.c (errs_new, errs_dup): New.
2775 * src/LR0.c (set_state_table): Let all the states have an errs,
2776 even if reduced to 0.
2777 * src/print.c (print_errs, print_reductions): Adjust.
2778 * src/output.c (output_actions, action_row): Adjust.
2779 * src/conflicts.c (resolve_sr_conflict): Adjust.
2780
27812001-12-27 Akim Demaille <akim@epita.fr>
2782
2783 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
2784
27852001-12-27 Akim Demaille <akim@epita.fr>
2786
2787 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
2788 * src/print.c: here.
2789 (lookaheadset, shiftset): New, used as additional storage by
2790 print_reductions.
2791 (print_results): Adjust.
2792 (print_shifts, print_gotos, print_errs): New, extracted from...
2793 (print_actions): here.
2794 * src/print_graph.c (print_actions): Remove dead code.
2795
27962001-12-27 Akim Demaille <akim@epita.fr>
2797
2798 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
2799 `$n' and `@n'.
2800
28012001-12-27 Akim Demaille <akim@epita.fr>
2802
2803 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
2804 (build_relations): Adjust.
2805
28062001-12-27 Akim Demaille <akim@epita.fr>
2807
2808 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
2809 duplication.
2810
28112001-12-27 Akim Demaille <akim@epita.fr>
2812
2813 * src/reader.c (packgram): Catch nitems overflows.
2814
28152001-12-27 Akim Demaille <akim@epita.fr>
2816
2817 * src/files.c, src/files.h (guard_obstack): Remove.
2818 * src/output.c (output): Adjust.
2819 * src/reader.c (parse_braces): New, factoring...
2820 (copy_action, copy_guard): these two which are renamed as...
2821 (parse_action, parse_guard): these.
2822 As a voluntary consequence, using braces around guards is now
2823 mandatory.
2824
28252001-12-27 Akim Demaille <akim@epita.fr>
2826
2827 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
2828 * src/reader.c (symbol_list): `guard' and `guard_line' are new
2829 members.
2830 (symbol_list_new): Adjust.
2831 (copy_action): action_line is the first line, not the last.
2832 (copy_guard): Just as for actions, store the `action' only, not
2833 the switch/case/break flesh.
2834 Don't parse the user action that might follow the guard, let...
2835 (readgram): do it, i.e., now, there can be an action after a
2836 guard.
2837 In other words the guard is just explicitly optional.
2838 (packgram): Adjust.
2839 * src/output.c (guards_output): New.
2840 (output_parser): Call it when needed.
2841 (output): Also free the guard and attrs obstacks.
2842 * src/files.c, src/files.h (obstack_save): Remove.
2843 (output_files): Remove.
2844 As a result, if one needs the former `.act' file, using an
2845 appropriate skeleton which requires actions and guards is now
2846 required.
2847 * src/main.c (main): Adjust.
2848 * tests/semantic.at: New.
2849 * tests/regression.at: Use `input.y' as input file name.
2850 Avoid 8+3 problems by requiring input.c when the test needs the
2851 parser.
2852
28532001-12-27 Akim Demaille <akim@epita.fr>
2854
2855 * src/reader.c (symbol_list_new): Be sure to initialize all the
2856 fields.
2857
28582001-12-27 Akim Demaille <akim@epita.fr>
2859
2860 All the hacks using a final pseudo state are now useless.
2861
2862 * src/LR0.c (set_state_table): state_table holds exactly nstates.
2863 * src/lalr.c (nLA): New.
2864 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
2865 instead of lookaheadsp from the pseudo state (nstate + 1).
2866
28672001-12-27 Akim Demaille <akim@epita.fr>
2868
2869 * src/output.c (action_row, token_actions): Use a state_t instead
2870 of a integer, and nlookaheads instead of the following state's
2871 lookaheadsp.
2872
28732001-12-27 Akim Demaille <akim@epita.fr>
2874
2875 * src/conflicts.c (log_resolution, flush_shift)
2876 (resolve_sr_conflict, set_conflicts, solve_conflicts)
2877 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
2878 (conflicts_print, print_reductions): Use a state_t instead of an
2879 integer when referring to a state.
2880 As much as possible, depend upon nlookaheads, instead of the
2881 `lookaheadsp' member of the following state (since lookaheads of
2882 successive states are successive, the difference between state n + 1
2883 and n served as the number of lookaheads for state n).
2884 * src/lalr.c (add_lookback_edge): Likewise.
2885 * src/print.c (print_core, print_actions, print_state)
2886 (print_results): Likewise.
2887 * src/print_graph.c (print_core, print_actions, print_state)
2888 (print_graph): Likewise.
2889 * src/conflicts.h: Adjust.
2890
28912001-12-27 Akim Demaille <akim@epita.fr>
2892
2893 * src/bison.hairy: Formatting/comment changes.
2894 ANSIfy.
2895 Remove `register' indications.
2896 Add plenty of `static'.
2897
28982001-12-27 Akim Demaille <akim@epita.fr>
2899
2900 * src/output.c (prepare): Drop the muscle `ntbase' which
2901 duplicates ntokens.
2902 * src/bison.simple: Formatting/comment changes.
2903 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
2904 is an undocumented synonym.
2905
29062001-12-22 Akim Demaille <akim@epita.fr>
2907
2908 * src/output.c (output_table_data): Change the prototype to use
2909 `int' for array ranges: some invocations do pass an int, not a
2910 short.
2911 Reported by Wayne Green.
2912
29132001-12-22 Akim Demaille <akim@epita.fr>
2914
2915 Some actions of web2c.y are improperly triggered.
2916 Reported by Mike Castle.
2917
2918 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
2919 * tests/regression.at (Web2c): Rename as...
2920 (Web2c Report): this.
2921 (Web2c Actions): New.
2922
29232001-12-22 Akim Demaille <akim@epita.fr>
2924
2925 Reductions in web2c.y are improperly reported.
2926 Reported by Mike Castle.
2927
2928 * src/conflicts.c (print_reductions): Fix.
2929 * tests/regression.at (Web2c): New.
2930
29312001-12-18 Akim Demaille <akim@epita.fr>
2932
2933 Some host fail on `assert (!"foo")', which expands to
2934 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
2935 Reported by Nelson Beebee.
2936
2937 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
2938 `#define it_succeeded 0' and `assert (it_succeeded)'.
2939
29402001-12-17 Marc Autret <autret_m@epita.fr>
2941
2942 * src/bison.simple: Don't hard code the skeleton line and filename.
2943 * src/output.c (output_parser): Rename 'line' as 'output_line'.
2944 New line counter 'skeleton_line' (skeleton-line muscle).
2945
29462001-12-17 Paul Eggert <eggert@twinsun.com>
2947
2948 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
2949 YYDEBUG must be defined to a nonzero value.
2950
2951 * src/bison.simple (yytname): Do not assume that the user defines
2952 YYDEBUG to a properly parenthesized expression.
2953
29542001-12-17 Akim Demaille <akim@epita.fr>
2955
2956 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
2957 nlookaheads is a new member.
2958 Adjust all users.
2959 * src/lalr.h (nlookaheads): Remove this orphan declaration.
2960 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
2961 state.
2962
29632001-12-17 Akim Demaille <akim@epita.fr>
2964
2965 * src/files.h, src/files.c (open_files, close_files): Remove.
2966 * src/main.c (main): Don't open/close files, nor invoke lex_free,
2967 let...
2968 * src/reader.c (reader): Do it.
2969
29702001-12-17 Akim Demaille <akim@epita.fr>
2971
2972 * src/conflicts.c (print_reductions): Formatting changes.
2973
29742001-12-17 Akim Demaille <akim@epita.fr>
2975
2976 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
2977 (flush_reduce): New.
2978 (resolve_sr_conflict): Adjust.
2979
29802001-12-17 Akim Demaille <akim@epita.fr>
2981
2982 * src/output.c (output_obstack): Be static and rename as...
2983 (format_obstack): this, to avoid any confusion with files.c's
2984 output_obstack.
2985 * src/reader.h (muscle_obstack): Move to...
2986 * src/output.h: here, since it's defined in output.c.
2987
29882001-12-17 Akim Demaille <akim@epita.fr>
2989
2990 * src/output.c (action_row, save_column, default_goto)
2991 (sort_actions, matching_state, pack_vector): Better variable
2992 locality.
2993
29942001-12-17 Akim Demaille <akim@epita.fr>
2995
2996 * src/output.c: Various formatting changes.
2997
29982001-12-17 Akim Demaille <akim@epita.fr>
2999
3000 * src/files.c (output_files): Free the output_obstack.
3001 * src/main.c (main): Call print and print_graph conditionally.
3002 * src/print.c (print): Work unconditionally.
3003 * src/print_graph.c (print_graph): Work unconditionally.
3004 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3005
30062001-12-16 Marc Autret <autret_m@epita.fr>
3007
3008 * src/output.c (actions_output): Fix. When we use %no-lines,
3009 there is one less line per action.
3010
30112001-12-16 Marc Autret <autret_m@epita.fr>
3012
3013 * src/bison.simple: Remove a useless #line directive.
3014 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3015 * src/output.c (get_lines_number): New.
3016 (output_parser): Adjust, now takes care about the lines of a
3017 output muscles.
3018 Fix line numbering.
3019 (actions_output): Computes the number of lines taken by actions.
3020 (output_master_parser): Insert new skeleton which is the name of
3021 the output parser file name.
3022
30232001-12-15 Marc Autret <autret_m@epita.fr>
3024
3025 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3026
30272001-12-15 Marc Autret <autret_m@epita.fr>
3028
3029 * src/output.c (output_gram): Keep track of the hairy one.
3030
30312001-12-15 Akim Demaille <akim@epita.fr>
3032
3033 Make `make distcheck' work.
3034
3035 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3036 system.h which uses libgettext.h.
3037
30382001-12-15 Akim Demaille <akim@epita.fr>
3039
3040 * src/nullable.c (set_nullable): Useless rules must be skipped,
3041 otherwise, since we range over their symbols, we might look at a
3042 nonterminal which no longer ``exists'', i.e., it is not counted in
3043 `nvars', hence we overflow our arrays.
3044
30452001-12-15 Akim Demaille <akim@epita.fr>
3046
3047 The header can also be produced directly, without any obstack!
3048 Yahoo!
3049
3050 * src/files.c, src/files.h (defines_obstack): Remove.
3051 (compute_header_macro): Global.
3052 (defines_obstack_save): Remove.
3053 * src/reader.c (parse_union_decl): No longer output to
3054 defines_obstack: its content can be found in the `stype' muscle
3055 anyway.
3056 (output_token_translations): Merge into...
3057 (symbols_output): this.
3058 Rename as...
3059 (symbols_save): this.
3060 (reader): Adjust.
3061 * src/output.c (header_output): New.
3062 (output): Call it.
3063
30642001-12-15 Akim Demaille <akim@epita.fr>
3065
3066 * src/reader.c (parse_union_decl): Instead of handling two obstack
3067 simultaneously, use one to define the `stype' muscle, and use the
3068 value of the latter to fill defines_obstack.
3069 (copy_comment): Remove.
3070 (copy_comment2): Work for a single obstack.
3071 Rename as...
3072 (copy_comment): this.
3073
30742001-12-15 Akim Demaille <akim@epita.fr>
3075
3076 * src/lex.c, src/lex.h (xgetc): No longer static.
3077 * src/reader.c (parse_union_decl): Revamp.
3078
30792001-12-15 Akim Demaille <akim@epita.fr>
3080
3081 Still making progress in separating Bison into (i) input, (ii)
3082 process, (iii) output: now we can directly output the parser file
3083 without using table_obstack at all.
3084
3085 * src/files.c, src/files.h (table_obstack): Bye bye.
3086 (parser_file_name): New.
3087 * src/files.c (compute_output_file_names): Compute it.
3088 * src/output.c (actions_output, output_parser)
3089 (output_master_parser): To a file instead of an obstack.
3090
30912001-12-15 Akim Demaille <akim@epita.fr>
3092
3093 Attach actions to rules, instead of pre-outputting them to
3094 actions_obstack.
3095
3096 * src/gram.h (rule_t): action and action_line are new members.
3097 * src/reader.c (symbol_list): Likewise.
3098 (copy_action): Save the actions within the rule.
3099 (packgram): Save them in rule_table.
3100 * src/output.c (actions_output): New.
3101 (output_parser): Use it on `%%actions'.
3102 (output_rule_data): Don't free rule_table.
3103 (output): Do it.
3104 (prepare): Don't save the `action' muscle.
3105 * src/bison.simple: s/%%action/%%actions/.
3106
31072001-12-15 Akim Demaille <akim@epita.fr>
3108
3109 * src/reader.c (copy_action): When --yacc, don't append a `;'
3110 to the user action: let it fail if lacking.
3111 Suggested by Arnold Robbins and Tom Tromey.
3112
31132001-12-14 Akim Demaille <akim@epita.fr>
3114
3115 * src/lex.c (literalchar): Simply return the char you decoded, non
3116 longer mess around with obstacks and int pointers.
3117 Adjust all callers.
3118
31192001-12-14 Akim Demaille <akim@epita.fr>
3120
3121 * src/lex.c (literalchar): Don't escape the special characters,
3122 just decode them, and keep them as char (before, eol was output as
3123 the 2 char string `\n' etc.).
3124 * src/output.c (output_rule_data): Use quotearg to output the
3125 token strings.
3126
31272001-12-13 Paul Eggert <eggert@twinsun.com>
3128
3129 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3130 Do not infringe on the global user namespace when using C++.
3131 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3132 All uses of `fprintf' and `stderr' changed.
3133
3134 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3135
31362001-12-13 Akim Demaille <akim@epita.fr>
3137
3138 The computation of nullable is broken: it doesn't handle empty
3139 RHS's properly.
3140
3141 * tests/torture.at (GNU AWK Grammar): New.
3142 * tests/sets.at (Nullable): New.
3143 * src/nullable.c (set_nullable): Instead of blindly looping over
3144 `ritems', loop over the rules, and then over their rhs's.
3145
3146 Work around Autotest bugs.
3147
3148 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
3149 frame, because Autotest understand lines starting with a `+' as
3150 traces from the shell. Then, they are not processed properly.
3151 Admittedly an Autotest bug, but we don't have time to wait for
3152 Autotest to catch up.
3153 * tests/regression.at (Broken Closure): Adjust to the new table
3154 frames.
3155 Move to...
3156 * tests/sets.at: here.
3157
31582001-12-13 Akim Demaille <akim@epita.fr>
3159
3160 * src/closure.c (closure): Use nrules instead of playing tricks
3161 with BITS_PER_WORD.
3162
31632001-12-13 Akim Demaille <akim@epita.fr>
3164
3165 * src/print.c (print_actions): Output the handling of `$' as the
3166 traces do: shifting the token EOF. Before EOF was treated as a
3167 nonterminal.
3168 * tests/regression.at: Adjust some tests.
3169 * src/print_graph.c (print_core): Complete the set of items via
3170 closure. The next-to-final and final states are still unsatisfying,
3171 but that's to be addressed elsewhere.
3172 No longer output the rule numbers, but do output the state number.
3173 A single loop for the shifts + gotos is enough, but picked a
3174 distinct color for each.
3175 (print_graph): Initialize and finalize closure.
3176
31772001-12-13 Akim Demaille <akim@epita.fr>
3178
3179 * src/reader.c (readgram): Remove dead code, an strip useless
3180 braces.
3181 (get_type): Remove, unused.
3182
31832001-12-12 Akim Demaille <akim@epita.fr>
3184
3185 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
3186 on that of lib/error.c.
3187
31882001-12-12 Akim Demaille <akim@epita.fr>
3189
3190 Some hosts don't like `/' in includes.
3191
3192 * src/system.h: Include libgettext.h without qualifying the path.
3193 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
3194 $(top_srcdir).
3195
31962001-12-11 Marc Autret <autret_m@epita.fr>
3197
3198 * src/output.c (output_parser): Remove useless muscle.
3199
32002001-12-11 Marc Autret <autret_m@epita.fr>
3201
3202 * src/bison.simple: Remove #line just before %%epilogue. It
3203 is now handled in ...
3204 * src/reader.c (read_additionnal_code): Add the output of a
3205 #line for the epilogue.
3206
32072001-12-10 Marc Autret <autret_m@epita.fr>
3208
3209 * src/reader.c (copy_definition): Re-use CPP-outed code which
3210 replace precedent remove.
3211 * src/bison.simple: Remove #line before %%prologue because
3212 %%input-line is wrong at this time.
3213
32142001-12-10 Marc Autret <autret_m@epita.fr>
3215
3216 * src/reader.c (symbols_output): Clean up.
3217 * src/output.c (output_gram, output): Clean up.
3218
32192001-12-10 Akim Demaille <akim@epita.fr>
3220
3221 * src/lalr.c (initialize_lookaheads): New. Extracted from...
3222 * src/LR0.c (set_state_table): here.
3223 * src/lalr.c (lalr): Call it.
3224
32252001-12-10 Akim Demaille <akim@epita.fr>
3226
3227 * src/state.h (shifts): Remove the `number' member: shifts are
3228 attached to state, hence no longer need to be labelled with a
3229 state number.
3230
32312001-12-10 Akim Demaille <akim@epita.fr>
3232
3233 Now that states have a complete set of members, the linked list of
3234 shifts is useless: just fill directly the state's shifts member.
3235
3236 * src/state.h (shifts): Remove the `next' member.
3237 * src/LR0.c (first_state, last_state): Remove.
3238 Adjust the callers.
3239 (augment_automaton): Don't look for the shifts that must be added
3240 a shift on EOF: it is those of the state we looked for! But now,
3241 since shifts are attached, it is no longer needed to looking
3242 merely by its id: its number.
3243
32442001-12-10 Akim Demaille <akim@epita.fr>
3245
3246 * src/LR0.c (augment_automaton): Better variable locality.
3247 Remove an impossible branch: if there is a state corresponding to
3248 the start symbol being shifted, then there is shift for the start
3249 symbol from the initial state.
3250
32512001-12-10 Akim Demaille <akim@epita.fr>
3252
3253 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
3254 only when appropriate: when insert_start_shifting_state' is not
3255 invoked.
3256 * tests/regression.at (Rule Line Numbers): Adjust.
3257
32582001-12-10 Akim Demaille <akim@epita.fr>
3259
3260 * src/LR0.c (augment_automaton): Now that all states have shifts,
3261 merge the two cases addition shifts to the initial state.
3262
32632001-12-10 Akim Demaille <akim@epita.fr>
3264
3265 * src/lalr.c (set_state_table): Move to...
3266 * src/LR0.c: here.
3267 * src/lalr.c (lalr): Don't call it...
3268 * src/LR0.c (generate_states): do it.
3269 * src/LR0.h (first_state): Remove, only the table is used.
3270
32712001-12-10 Akim Demaille <akim@epita.fr>
3272
3273 * src/LR0.h (first_shift, first_reduction): Remove.
3274 * src/lalr.c: Don't use first_shift: find shifts through the
3275 states.
3276
32772001-12-10 Akim Demaille <akim@epita.fr>
3278
3279 * src/LR0.c: Attach shifts to states as soon as they are
3280 computed.
3281 * src/lalr.c (set_state_table): Instead of assigning shifts to
3282 state, just assert that the mapping was properly done.
3283
32842001-12-10 Akim Demaille <akim@epita.fr>
3285
3286 * src/LR0.c (insert_start_shift): Rename as...
3287 (insert_start_shifting_state): this.
3288 (insert_eof_shifting_state, insert_accepting_state): New.
3289 (augment_automaton): Adjust.
3290 Better locality of the variables.
3291 When looking if the start_symbol is shifted from the initial
3292 state, using `while (... symbol != start_symbol ...)' sounds
3293 better than `while (... symbol < start_symbol ...)': If fail
3294 to see how the order between symbols could be relevant!
3295
32962001-12-10 Akim Demaille <akim@epita.fr>
3297
3298 * src/getargs.h: Don't declare `spec_name_prefix' and
3299 `spec_file_prefix', declared by src/files.h.
3300 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
3301 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
3302 * src/output.c (prepare): Adjust.
3303 * src/reader.c (symbols_output): Likewise.
3304 * src/vmsgetargs.c: Vaguely adjust, but who cares?
3305
33062001-12-10 Akim Demaille <akim@epita.fr>
3307
3308 * src/muscle_tab.c (muscle_init): NULL is a better default than
3309 `"0"'.
3310
33112001-12-10 Akim Demaille <akim@epita.fr>
3312
3313 * src/reader.c (reader): Calling symbols_output once is enough.
3314
33152001-12-10 Akim Demaille <akim@epita.fr>
3316
3317 Now that states have a complete set of members, the linked list of
3318 reductions is useless: just fill directly the state's reductions
3319 member.
3320
3321 * src/state.h (struct reductions): Remove member `number' and
3322 `next'.
3323 * src/LR0.c (first_reduction, last_reduction): Remove.
3324 (save_reductions): Don't link the new reductions, store them in
3325 this_state.
3326 * src/lalr.c (set_state_table): No need to attach reductions to
3327 states, it's already done.
3328 * src/output.c (output_actions): No longer free the shifts, then
3329 the reductions, then the states: free all the states and their
3330 members.
3331
33322001-12-10 Akim Demaille <akim@epita.fr>
3333
3334 * src/options.c (OPTN, DRTV, BOTH): New.
3335 (option_table): Use them.
3336
3337 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
3338 the job of system.h.
3339 * src/options.c: Don't include stdio.h and xalloc.h for the same
3340 reasons.
3341
33422001-12-10 Akim Demaille <akim@epita.fr>
3343
3344 * src/output.c (output, prepare): Make sure the values of the
3345 muscles `action' and `prologue' are 0-terminated.
3346
33472001-12-10 Akim Demaille <akim@epita.fr>
3348
3349 Clean up GCC warnings.
3350
3351 * src/reader.c (copy_action): `buf' is not used.
3352 (parse_skel_decl): Be static.
3353 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
3354 * src/options.h (create_long_option_table): Have a real prototype.
3355 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
3356 (hash_delete_at): Return const void *.
3357 Adjust casts to preserve the const.
3358
33592001-12-10 Akim Demaille <akim@epita.fr>
3360
3361 * configure.in: Require 2.52g.
3362 M4 is not needed, but AUTOM4TE is.
3363 * m4/m4.m4: Remove.
3364 * tests/Makefile.am: Adjust.
3365
33662001-12-10 Akim Demaille <akim@epita.fr>
3367
3368 One structure for states is enough, even though theoretically
3369 there are LR(0) states and LALR(1) states.
3370
3371 * src/lalr.h (state_t): Remove.
3372 (state_table): Be state_t **, not state_t *.
3373 * src/state.h (core, CORE_ALLOC): Rename as...
3374 (state_t, STATE_ALLOC): this.
3375 Add the LALR(1) members: shifts, reductions, errs.
3376 * src/LR0.c (state_table): Rename as...
3377 (state_hash): this, to avoid name clashes with the global
3378 `state_table'.
3379 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
3380 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
3381
33822001-12-10 Akim Demaille <akim@epita.fr>
3383
3384 Bison dumps core on bash.y.
3385 Reported by Pascal Bart.
3386
3387 * src/warshall.c (bitmatrix_print): New.
3388 (TC): Use it.
3389 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
3390 j must be the outer loop.
3391 * tests/regression.at (Broken Closure): New.
3392
33932001-12-05 Akim Demaille <akim@epita.fr>
3394
3395 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
3396 its argument.
3397