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