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