]> git.saurik.com Git - bison.git/blame - ChangeLog
* src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
[bison.git] / ChangeLog
CommitLineData
a945ec39
AD
12002-07-16 Akim Demaille <akim@epita.fr>
2
3 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
4 Adjust all former `associativity' dependencies.
5 * src/symtab.c (symbol_new): Default associativity is `undef', not
6 `right'.
7 (symbol_check_alias_consistence): Adjust.
8
fae437e8
AD
92002-07-09 Akim Demaille <akim@epita.fr>
10
11 * doc/bison.texinfo: Properly set the ``header'' part.
12 Use @dircategory ``GNU programming tools'' as per Texinfo's
13 documentation.
14 Use @copying.
15
1a715ef2
AD
162002-07-09 Akim Demaille <akim@epita.fr>
17
18 * lib/quotearg.h: Protect against multiple inclusions.
19 * src/location.h (location_t): Add a `file' member.
20 (LOCATION_RESET, LOCATION_PRINT): Adjust.
21 * src/complain.c (warn_at, complain_at, fatal_at): Drop
22 `error_one_per_line' support.
23
a5d50994
AD
242002-07-09 Akim Demaille <akim@epita.fr>
25
26 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
27 * src/reader.c (lineno): Remove.
28 Adjust all dependencies.
29 (get_merge_function): Take a location and use complain_at.
30 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
31 * tests/regression.at (Invalid inputs, Mixing %token styles):
32 Adjust.
33
b275314e
AD
342002-07-09 Akim Demaille <akim@epita.fr>
35
36 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
37 recovery rule, and forbid extensions when --yacc.
38 (gram_error): Use complain_at.
39 * src/reader.c (reader): Exit if there were parse errors.
40
865b9df1
AD
412002-07-09 Akim Demaille <akim@epita.fr>
42
43 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
44 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
45 Reported by R Blake <blakers@mac.com>.
46
c76e14da
AD
472002-07-09 Akim Demaille <akim@epita.fr>
48
49 * data/yacc.c: Output the copyright notive in the header.
50
7db2ed2d
AD
512002-07-03 Akim Demaille <akim@epita.fr>
52
53 * src/output.c (froms, tos): Are state_number_t.
54 (save_column): sp, sp1, and sp2 are state_number_t.
55 (prepare): Rename `final' as `final_state_number', `nnts' as
56 `nterms_number', `nrules' as `rules_number', `nstates' as
57 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
58 unused.
59 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
60 * data/lalr1.cc (nsym_): Remove, unused.
61
e68e0410
AD
622002-07-03 Akim Demaille <akim@epita.fr>
63
64 * src/lalr.h, src/lalr.c (goto_number_t): New.
65 * src/lalr.c (goto_list_t): New.
66 Propagate them.
67 * src/nullable.c (rule_list_t): New.
68 Propagate.
69 * src/types.h: Remove.
70
e1a4f3a4
AD
712002-07-03 Akim Demaille <akim@epita.fr>
72
73 * src/closure.c (print_fderives): Use rule_rhs_print.
74 * src/derives.c (print_derives): Use rule_rhs_print.
75 (rule_list_t): New, replaces `shorts'.
76 (set_derives): Add comments.
77 * tests/sets.at (Nullable, Firsts): Adjust.
78
536545f3
AD
792002-07-03 Akim Demaille <akim@epita.fr>
80
81 * src/output.c (prepare_actions): Free `tally' and `width'.
82 (prepare_actions): Allocate and free `order'.
83 * src/symtab.c (symbols_free): Free `symbols'.
84 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
85 * src/output.c (m4_invoke): Move to...
86 * src/scan-skel.l: here.
87 (<<EOF>>): Close yyout, and free its name.
88
8b752b00
AD
892002-07-03 Akim Demaille <akim@epita.fr>
90
91 Fix some memory leaks, and fix a bug: state 0 was examined twice.
92
93 * src/LR0.c (new_state): Merge into...
94 (state_list_append): this.
95 (new_states): Merge into...
96 (generate_states): here.
97 (set_states): Don't ensure a proper `errs' state member here, do it...
98 * src/conflicts.c (conflicts_solve): here.
99 * src/state.h, src/state.c: Comment changes.
100 (state_t): Rename member `shifts' as `transitions'.
101 Adjust all dependencies.
102 (errs_new): For consistency, also take the values as argument.
103 (errs_dup): Remove.
104 (state_errs_set): New.
105 (state_reductions_set, state_transitions_set): Assert that no
106 previous value was assigned.
107 (state_free): New.
108 (states_free): Use it.
109 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
110 temporary storage: use `errs' and `nerrs' as elsewhere.
111 (set_conflicts): Allocate and free this `errs'.
112
613f5e1a
AD
1132002-07-02 Akim Demaille <akim@epita.fr>
114
115 * lib/libiberty.h: New.
116 * lib: Update the bitset implementation from upstream.
117 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
118 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
119 * src/main.c: Adjust bitset stats calls.
120
26e0cadc
PE
1212002-07-01 Paul Eggert <eggert@twinsun.com>
122
123 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
124 char, so that negative chars don't collide with $.
125
1154cced
AD
1262002-06-30 Akim Demaille <akim@epita.fr>
127
128 Have the GLR tests be `warning' checked, and fix the warnings.
129
130 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
131 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
132 (yyremoveDeletes): `yyi' and `yyj' are size_t.
133 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
134 (yyaddDeferredAction): static.
135 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
136 (yyreportParseError): yyprefix is const.
137 yytokenp is used only when verbose.
138 (yy__GNUC__): Replace with __GNUC__.
139 (yypdumpstack): yyi is size_t.
140 (yypreference): Un-yy local variables and arguments, to avoid
141 clashes with `yyr1'. Anyway, we are not in the user name space.
142 (yytname_size): be an int, as is compared with ints.
143 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
144 Use them.
145 * tests/cxx-gram.at: Use quotation to protect $1.
146 Use AT_COMPILE to enable warnings hunts.
147 Prototype yylex and yyerror.
148 `Use' argc.
149 Include `string.h', not `strings.h'.
150 Produce and prototype stmtMerge only when used.
151 yylex takes a location.
152
97650f4e
AD
1532002-06-30 Akim Demaille <akim@epita.fr>
154
155 We spend a lot of time in quotearg, in particular when --verbose.
156
157 * src/symtab.c (symbol_get): Store a quoted version of the key.
158 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
159 Adjust all callers.
160
d2576365
AD
1612002-06-30 Akim Demaille <akim@epita.fr>
162
163 * src/state.h (reductions_t): Rename member `nreds' as num.
164 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
165 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
166
ccaf65bc
AD
1672002-06-30 Akim Demaille <akim@epita.fr>
168
169 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
170 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
171 (shifts_to): Rename as...
172 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
173 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
174 (TRANSITION_IS_DISABLED, transitions_to): these.
175
87675353
AD
1762002-06-30 Akim Demaille <akim@epita.fr>
177
178 * src/print.c (print_shifts, print_gotos): Merge into...
179 (print_transitions): this.
180 (print_transitions, print_errs, print_reductions): Align the
181 lookaheads columns.
182 (print_core, print_transitions, print_errs, print_state,
183 print_grammar): Output empty lines separator before, not after.
184 (state_default_rule_compute): Rename as...
185 (state_default_rule): this.
186 * tests/conflicts.at (Defaulted Conflicted Reduction),
187 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
188 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
189
ce4ccb4b
AD
1902002-06-30 Akim Demaille <akim@epita.fr>
191
192 Display items as we display rules.
193
194 * src/gram.h, src/gram.c (rule_lhs_print): New.
195 * src/gram.c (grammar_rules_partial_print): Use it.
196 * src/print.c (print_core): Likewise.
197 * tests/conflicts.at (Defaulted Conflicted Reduction),
198 (Unresolved SR Conflicts): Adjust.
199 (Unresolved SR Conflicts): Adjust and rename as...
200 (Resolved SR Conflicts): this, as was meant.
201 * tests/regression.at (Web2c Report): Adjust.
202
bc933ef1
AD
2032002-06-30 Akim Demaille <akim@epita.fr>
204
205 * src/print.c (state_default_rule_compute): New, extracted from...
206 (print_reductions): here.
207 Pessimize, but clarify the code.
208 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
209
53d4308d
AD
2102002-06-30 Akim Demaille <akim@epita.fr>
211
212 * src/output.c (action_row): Let default_rule be always a rule
213 number.
214
574fb2d5
AD
2152002-06-30 Akim Demaille <akim@epita.fr>
216
217 * src/closure.c (print_firsts, print_fderives, closure):
218 Use BITSET_EXECUTE.
219 * src/lalr.c (lookaheads_print): Likewise.
220 * src/state.c (state_rule_lookaheads_print): Likewise.
221 * src/print_graph.c (print_core): Likewise.
222 * src/print.c (print_reductions): Likewise.
223 * src/output.c (action_row): Likewise.
224 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
225
05811fd7
AD
2262002-06-30 Akim Demaille <akim@epita.fr>
227
228 * src/print_graph.c: Use report_flag.
229
0e4d5753
AD
2302002-06-30 Akim Demaille <akim@epita.fr>
231
232 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
233 to...
234 * src/relation.h, src/relation.c (traverse, relation_digraph)
235 (relation_print, relation_transpose): New.
236
24c7d800
AD
2372002-06-30 Akim Demaille <akim@epita.fr>
238
239 * src/state.h, src/state.c (shifts_to): New.
240 * src/lalr.c (build_relations): Use it.
241
9222837b
AD
2422002-06-30 Akim Demaille <akim@epita.fr>
243
244 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
245 (item_number_of_rule_number, rule_number_of_item_number): New.
246 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
247 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
248 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
249 Propagate their use.
250 Much remains to be done, in particular wrt `shorts' from types.h.
251
260008e5
AD
2522002-06-30 Akim Demaille <akim@epita.fr>
253
254 * src/symtab.c (symbol_new): Initialize the `printer' member.
255
8a731ca8
AD
2562002-06-30 Akim Demaille <akim@epita.fr>
257
258 * src/LR0.c (save_reductions): Remove, replaced by...
259 * src/state.h, src/state.c (state_reductions_set): New.
260 (reductions, errs): Rename as...
261 (reductions_t, errs_t): these.
262 Adjust all dependencies.
263
32e1e0a4
AD
2642002-06-30 Akim Demaille <akim@epita.fr>
265
266 * src/LR0.c (state_list_t, state_list_append): New.
267 (first_state, last_state): Now symbol_list_t.
268 (this_state): Remove.
269 (new_itemsets, append_states, save_reductions): Take a state_t as
270 argument.
271 (set_states, generate_states): Adjust.
272 (save_shifts): Remove, replaced by...
273 * src/state.h, src/state.c (state_shifts_set): New.
274 (shifts): Rename as...
275 (shifts_t): this.
276 Adjust all dependencies.
277 * src/state.h (state_t): Remove the `next' member.
278
e5fb6710
AD
2792002-06-30 Akim Demaille <akim@epita.fr>
280
281 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
282 escaped in slot 0.
283
c7ca99d4
AD
2842002-06-30 Akim Demaille <akim@epita.fr>
285
286 Use hash.h for the state hash table.
287
288 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
289 (allocate_storage): Use state_hash_new.
290 (free_storage): Use state_hash_free.
291 (new_state, get_state): Adjust.
292 * src/lalr.h, src/lalr.c (states): Move to...
293 * src/states.h (state_t): Remove the `link' member, no longer
294 used.
295 * src/states.h, src/states.c: here.
296 (state_hash_new, state_hash_free, state_hash_lookup)
297 (state_hash_insert, states_free): New.
298 * src/states.c (state_table, state_compare, state_hash): New.
299 * src/output.c (output_actions): Do not free states now, since we
300 still need to know the final_state number in `prepare', called
301 afterwards. Do it...
302 * src/main.c (main): here: call states_free after `output'.
303
df0e7316
AD
3042002-06-30 Akim Demaille <akim@epita.fr>
305
306 * src/state.h, src/state.c (state_new): New, extracted from...
307 * src/LR0.c (new_state): here.
308 * src/state.h (STATE_ALLOC): Move to...
309 * src/state.c: here.
310 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
311 * src/state.h, src/state.c: here.
312
39f41916
AD
3132002-06-30 Akim Demaille <akim@epita.fr>
314
315 * src/reader.c (gensym): Rename as...
316 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
317 (getsym): Rename as...
318 (symbol_get): this.
319
d57650a5
AD
3202002-06-30 Akim Demaille <akim@epita.fr>
321
322 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
323 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
324 * src/output.c, src/print.c, src/print_graph.c: Propagate.
325 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
326
5a08f1ce
AD
3272002-06-30 Akim Demaille <akim@epita.fr>
328
329 Make the test suite pass with warnings checked.
330
331 * tests/actions.at (Printers and Destructors): Improve.
332 Avoid unsigned vs. signed issues.
333 * tests/calc.at: Don't exercise the scanner here, do it...
334 * tests/input.at (Torturing the Scanner): here.
335
720623af
PH
3362002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
337
88e7e941 338 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
339 reorganize first lines parallel to yacc.c.
340
fb8135fa
AD
3412002-06-28 Akim Demaille <akim@epita.fr>
342
343 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
344 (b4_token_enum, b4_token_defines): New, factored from...
345 * data/lalr1.cc, data/yacc.c, glr.c: here.
346
41442480
AD
3472002-06-28 Akim Demaille <akim@epita.fr>
348
349 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
350 unused variables.
351 * src/output.c (merger_output): static.
352
e0e5bf84
AD
3532002-06-28 Akim Demaille <akim@epita.fr>
354
355 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
356 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
357 pacify GCC.
358 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 359
676385e2
PH
3602002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
361
362 Accumulated changelog for new GLR parsing features.
363
e0e5bf84 364 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
365 conflicts_total_count.
366 * src/conflicts.h: Ditto.
367 * src/output.c (token_actions): Use the new name.
368 (output_conflicts): Change conflp => conflict_list_heads, and
369 confl => conflict_list for better readability.
370 * data/glr.c: Use the new names.
371 * NEWS: Add self to GLR announcement.
e0e5bf84 372
676385e2
PH
373 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
374
375 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
376 Akim Demaille.
377
378 * data/bison.glr: Change name to glr.c
379 * data/glr.c: Renamed from bison.glr.
380 * data/Makefile.am: Add glr.c
e0e5bf84
AD
381
382 * src/getargs.c:
383
676385e2
PH
384 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
385 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 386
676385e2
PH
387 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
388
389 * data/bison.glr: Be sure to restore the
390 current #line when returning to the skeleton contents after having
391 exposed the input file's #line.
392
393 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
394
395 * data/bison.glr: Bring up to date with changes to bison.simple.
396
397 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
398
399 * data/bison.glr: Correct definitions that use b4_prefix.
400 Various reformatting.
401 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
402 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
403 yytokenp argument; now part of stack.
404 (yychar): Define to behave as documented.
405 (yyclearin): Ditto.
e0e5bf84 406
676385e2
PH
407 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
408
409 * src/reader.h: Add declaration for free_merger_functions.
410
411 * src/reader.c (merge_functions): New variable.
412 (get_merge_function): New function.
413 (free_merger_functions): New function.
414 (readgram): Check for %prec that is not followed by a symbol.
415 Handle %dprec and %merge declarations.
416 (packgram): Initialize dprec and merger fields in rules array.
417
418 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
419 conflict_list_cnt, conflict_list_free): New variables.
420 (table_grow): Also grow conflict_table.
e0e5bf84 421 (prepare_rules): Output dprec and merger tables.
676385e2 422 (conflict_row): New function.
e0e5bf84 423 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
424 default reduction in conflicted states for GLR parser so that there
425 are spaces for the conflict lists.
426 (save_row): Also save conflict information.
427 (token_actions): Allocate conflict list.
428 (merger_output): New function.
429 (pack_vector): Pack conflict table, too.
430 (output_conflicts): New function to output yyconflp and yyconfl.
431 (output_check): Allocate conflict_tos.
432 (output_actions): Output conflict tables, also.
433 (output_skeleton): Output b4_mergers definition.
434 (prepare): Output b4_max_rhs_length definition.
435 Use 'bison.glr' as default skeleton for GLR parsers.
436
437 * src/gram.c (glr_parser): New flag.
438 (grammar_free): Call free_merger_functions.
439
440 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
441 all pairs of conflicting reductions, rather than just all tokens
442 causing conflicts. Needed to size conflict tables.
e0e5bf84 443 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
444 interface.
445 (conflicts_print): Ditto.
446 (count_total_conflicts): New function.
447
448 * src/reader.h (merger_list): New type.
449 (merge_functions): New variable.
450
451 * src/lex.h (tok_dprec, tok_merge): New token types.
452
453 * src/gram.h (rule_s): Add dprec and merger fields.
454 (glr_parser): New flag.
455
456 * src/conflicts.h (count_total_conflicts): New function.
457
458 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
459
460 * doc/bison.texinfo (Generalized LR Parsing): New section.
461 (GLR Parsers): New section.
462 (Language and Grammar): Mention GLR parsing.
463 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
464 Correct typo ("tge" -> "the").
465
466 * data/bison.glr: New skeleton for GLR parsing.
467
468 * tests/cxx-gram.at: New tests for GLR parsing.
469
470 * tests/testsuite.at: Include cxx-gram.at.
471
472 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 473
676385e2
PH
474 * src/parse-gram.y:
475
476 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
477
478 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 479
b5480d74 4802002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
481
482 * src/options.h, src/options.c: Remove.
483 * src/getargs.c (short_options, long_options): New.
484
60491a94
AD
4852002-06-27 Akim Demaille <akim@epita.fr>
486
487 * data/bison.simple, data/bison.c++: Rename as...
488 * data/yacc.c, data/lalr1.cc: these.
489 * doc/bison.texinfo (Environment Variables): Remove.
490
9be0c25b
AD
4912002-06-25 Raja R Harinath <harinath@cs.umn.edu>
492
493 * src/getargs.c (report_argmatch): Initialize strtok().
494
1ae72863
AD
4952002-06-20 Akim Demaille <akim@epita.fr>
496
497 * data/bison.simple (b4_symbol_actions): New, replaces...
498 (b4_symbol_destructor, b4_symbol_printer): these.
499 (yysymprint): Be sure to call YYPRINT only for tokens, and using
500 user token numbers.
501
87542d29
AD
5022002-06-20 Akim Demaille <akim@epita.fr>
503
504 * data/bison.simple (yydestructor): Rename as...
505 (yydestruct): this.
506
1a31ed21
AD
5072002-06-20 Akim Demaille <akim@epita.fr>
508
509 * src/symtab.h, src/symtab.c (symbol_type_set)
510 (symbol_destructor_set, symbol_precedence_set): The location is
511 the last argument.
512 Adjust all callers.
513
e776192e
AD
5142002-06-20 Akim Demaille <akim@epita.fr>
515
516 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
517 internals.
518 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
519 Takes a location.
520 * src/symtab.h, src/symtab.c (symbol_class_set)
521 (symbol_user_token_number_set): Likewise.
522 Adjust all callers.
523 Promote complain_at.
524 * tests/input.at (Type Clashes): Adjust.
525
5c1180b3
AD
5262002-06-20 Akim Demaille <akim@epita.fr>
527
528 * data/bison.simple (YYLEX): Fix the declaration when
529 %pure-parser.
530
e3170060
AD
5312002-06-20 Akim Demaille <akim@epita.fr>
532
533 * data/bison.simple (yysymprint): Don't print the token number,
534 just its name.
535 * tests/actions.at (Destructors): Rename as...
536 (Printers and Destructors): this.
537 Also exercise %printer.
538
253862fd
AD
5392002-06-20 Akim Demaille <akim@epita.fr>
540
541 * data/bison.simple (YYDSYMPRINT): New.
542 Use it to remove many of the #if YYDEBUG/if (yydebug).
543
366eea36
AD
5442002-06-20 Akim Demaille <akim@epita.fr>
545
546 * src/symtab.h, src/symtab.c (symbol_t): printer and
547 printer_location are new members.
548 (symbol_printer_set): New.
549 * src/parse-gram.y (PERCENT_PRINTER): New token.
550 Handle its associated rule.
551 * src/scan-gram.l: Adjust.
552 (handle_destructor_at, handle_destructor_dollar): Rename as...
553 (handle_symbol_code_at, handle_symbol_code_dollar): these.
554 * src/output.c (symbol_printers_output): New.
555 (output_skeleton): Call it.
556 * data/bison.simple (yysymprint): New. Cannot be named yyprint
557 since there are already many grammar files with a user `yyprint'.
558 Replace the calls to YYPRINT to calls to yysymprint.
559 * tests/calc.at: Adjust.
560 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
561 taking advantage of parser very internal details (stack size!).
562
4f25ebb0
AD
5632002-06-20 Akim Demaille <akim@epita.fr>
564
565 * src/scan-gram.l: Complete the scanner with the missing patterns
566 to pacify Flex.
567 Use `quote' and `symbol_tag_get' where appropriate.
568
93b68a0e
AD
5692002-06-19 Akim Demaille <akim@epita.fr>
570
571 * tests/actions.at (Destructors): Augment to test locations.
572 * data/bison.simple (yydestructor): Pass it the current location
573 if locations are enabled.
574 Prototype only when __STDC__ or C++.
575 Change the argument names to move into the yy name space: there is
576 user code here.
577
58612f1d
AD
5782002-06-19 Akim Demaille <akim@epita.fr>
579
74310291
AD
580 * data/bison.simple (b4_pure_if): New.
581 Use it instead of #ifdef YYPURE.
582
5832002-06-19 Akim Demaille <akim@epita.fr>
584
585 * data/bison.simple (b4_location_if): New.
58612f1d
AD
586 Use it instead of #ifdef YYLSP_NEEDED.
587
f25bfb75
AD
5882002-06-19 Akim Demaille <akim@epita.fr>
589
590 Prepare @$ in %destructor, but currently don't bind it in the
591 skeleton, as %location use is not cleaned up yet.
592
593 * src/scan-gram.l (handle_dollar, handle_destructor_at)
594 (handle_action_at): New.
595 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
596 a braced_code_t and a location as additional arguments.
597 (handle_destructor_dollar): Instead of requiring `b4_eval', just
598 unquote one when outputting `b4_dollar_dollar'.
599 Adjust callers.
600 * data/bison.simple (b4_eval): Remove.
601 (b4_symbol_destructor): Adjust.
602 * tests/input.at (Invalid @n): Adjust.
603
c732d2c6
AD
6042002-06-19 Zack Weinberg <zack@codesourcery.com>
605
606 * doc/bison.texinfo: Document ability to have multiple
607 prologue sections.
608
8c165d89
AD
6092002-06-18 Akim Demaille <akim@epita.fr>
610
611 * src/files.c (compute_base_names): When computing the output file
612 names from the input file name, strip the directory part.
613
ca98bf57
AD
6142002-06-18 Akim Demaille <akim@epita.fr>
615
616 * data/bison.simple.new: Comment changes.
617 Reported by Andreas Schwab.
618
0bfb02ff
AD
6192002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
620
621 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
622 there are no `label `yyoverflowlab' defined but not used' warnings
623 when yyoverflow is defined.
624
24c0aad7
AD
6252002-06-18 Akim Demaille <akim@epita.fr>
626
627 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
628 new member.
629 (symbol_destructor_set): Adjust.
630 * src/output.c (symbol_destructors_output): Output the destructor
631 locations.
632 Output the symbol name.
633 * data/bison.simple (b4_symbol_destructor): Adjust.
634
5719c109
AD
6352002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
636 and Akim Demaille <akim@epita.fr>
637
638 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
639 what's left on the stack when the error recovery hits EOF.
640 * tests/actions.at (Destructors): Complete to exercise this case.
641
9280d3ef
AD
6422002-06-17 Akim Demaille <akim@epita.fr>
643
644 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
645 arguments is really empty, not only equal to `[]'.
646 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
647 member.
648 (symbol_destructor_set): New.
649 * src/output.c (symbol_destructors_output): New.
650 * src/reader.h (brace_code_t, current_braced_code): New.
651 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
652 (handle_dollar): Rename as...
653 (handle_action_dollar): this.
654 (handle_destructor_dollar): New.
655 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
656 (grammar_declaration): Use it.
657 * data/bison.simple (yystos): Is always defined.
658 (yydestructor): New.
659 * tests/actions.at (Destructors): New.
660 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
661
dafdc66f
AD
6622002-06-17 Akim Demaille <akim@epita.fr>
663
664 * src/symlist.h, src/symlist.c (symbol_list_length): New.
665 * src/scan-gram.l (handle_dollar, handle_at): Compute the
666 rule_length only when needed.
667 * src/output.c (actions_output, token_definitions_output): Output
668 the full M4 block.
669 * src/symtab.c: Don't access directly to the symbol tag, use
670 symbol_tag_get.
671 * src/parse-gram.y: Use symbol_list_free.
672
56c47203
AD
6732002-06-17 Akim Demaille <akim@epita.fr>
674
675 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
676 (symbol_list_prepend, get_type_name): Move to...
677 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
678 (symbol_list_prepend, symbol_list_n_type_name_get): here.
679 Adjust all callers.
680 (symbol_list_free): New.
681 * src/scan-gram.l (handle_dollar): Takes a location.
682 * tests/input.at (Invalid $n): Adjust.
683
1e0bab92
AD
6842002-06-17 Akim Demaille <akim@epita.fr>
685
686 * src/reader.h, src/reader.c (symbol_list_new): Export it.
687 (symbol_list_prepend): New.
688 * src/parse-gram.y (%union): `list' is a new member.
689 (symbols.1): New, replaces...
690 (terms_to_prec.1, nterms_to_type.1): these.
691 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
692 Take a location as additional argument.
693 Adjust all callers.
694
04e60654
AD
6952002-06-15 Akim Demaille <akim@epita.fr>
696
697 * src/parse-gram.y: Move %token in the declaration section so that
698 we don't depend upon CVS Bison.
699
10e5b8bd
AD
7002002-06-15 Akim Demaille <akim@epita.fr>
701
702 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
703 * src/print.c (print_core): Use it.
704
9801d40c
AD
7052002-06-15 Akim Demaille <akim@epita.fr>
706
707 * src/conflicts.c (log_resolution): Accept the rule involved in
708 the sr conflicts instead of the lookahead number that points to
709 that rule.
710 (flush_reduce): Accept the current lookahead vector as argument,
711 instead of the index in LA.
712 (resolve_sr_conflict): Accept the current number of lookahead
713 bitset to consider for the STATE, instead of the index in LA.
714 (set_conflicts): Adjust.
715 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
716
c0263492
AD
7172002-06-15 Akim Demaille <akim@epita.fr>
718
719 * src/state.h (state_t): Replace the `lookaheadsp' member, a
720 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
721 Adjust all dependencies.
722 * src/lalr.c (initialize_lookaheads): Split into...
723 (states_lookaheads_count, states_lookaheads_initialize): these.
724 (lalr): Adjust.
725
9757c359
AD
7262002-06-15 Akim Demaille <akim@epita.fr>
727
728 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
729 out of...
730 (grammar_rules_print): here.
731 * src/reduce.c (reduce_output): Use it.
732 * tests/reduce.at (Useless Rules, Reduced Automaton)
733 (Underivable Rules): Adjust.
734
6b98e4b5
AD
7352002-06-15 Akim Demaille <akim@epita.fr>
736
737 Copy BYacc's nice way to report the grammar.
738
739 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
740 New.
741 Don't print the rules' location, it is confusing and useless.
742 (rule_print): Use grammar_rhs_print.
743 * src/print.c (print_grammar): Use grammar_rules_print.
744
6b98e4b5
AD
7452002-06-15 Akim Demaille <akim@epita.fr>
746
747 Complete and rationalize `useless thing' warnings.
748
749 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
750 (symbol_tag_print): New.
751 Use them everywhere in place of accessing directly the tag member.
752 * src/gram.h, src/gram.c (rule_print): New.
753 Use it where a rule used to be printed `by hand'.
754 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
755 (reduce_grammar_tables): Report the useless rules.
756 (reduce_print): Useless things are a warning, not an error.
757 Report it as such.
758 * tests/reduce.at (Useless Nonterminals, Useless Rules):
759 (Reduced Automaton, Underivable Rules): Adjust.
760 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
761 * tests/conflicts.at (Unresolved SR Conflicts)
762 (Solved SR Conflicts): Adjust.
763
ee000ba4
AD
7642002-06-15 Akim Demaille <akim@epita.fr>
765
766 Let symbols have a location.
767
768 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
769 (getsym): Adjust.
770 Adjust all callers.
771 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
772 Use location_t, not int.
773 * src/symtab.c (symbol_check_defined): Take advantage of the
774 location.
775 * tests/regression.at (Invalid inputs): Adjust.
776
8efe435c
AD
7772002-06-15 Akim Demaille <akim@epita.fr>
778
779 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
780 (input): Don't try to initialize yylloc here, do it in the
781 scanner.
782 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
783 * src/gram.h (rule_t): Change line and action_line into location
784 and action_location, of location_t type.
785 Adjust all dependencies.
786 * src/location.h, src/location.c (empty_location): New.
787 * src/reader.h, src/reader.c (grammar_start_symbol_set)
788 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
789 (grammar_current_rule_symbol_append)
790 (grammar_current_rule_action_append): Expect a location as argument.
791 * src/reader.c (grammar_midrule_action): Adjust to attach an
792 action's location as dummy symbol location.
793 * src/symtab.h, src/symtab.c (startsymbol_location): New.
794 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
795 the line numbers.
796
1921f1d7
AD
7972002-06-14 Akim Demaille <akim@epita.fr>
798
799 Grammar declarations may be found in the grammar section.
800
801 * src/parse-gram.y (rules_or_grammar_declaration): New.
802 (declarations): Each declaration may end with a semicolon, not
803 just...
804 (grammar_declaration): `"%union"'.
805 (grammar): Branch to rules_or_grammar_declaration.
806
4515534c
AD
8072002-06-14 Akim Demaille <akim@epita.fr>
808
809 * src/main.c (main): Invoke scanner_free.
810
f958596b
AD
8112002-06-14 Akim Demaille <akim@epita.fr>
812
813 * src/output.c (m4_invoke): Extracted from...
814 (output_skeleton): here.
815 Free tempfile.
816
2c569025
AD
8172002-06-14 Akim Demaille <akim@epita.fr>
818
819 * src/parse-gram.y (directives, directive, gram)
820 (grammar_directives, precedence_directives, precedence_directive):
821 Rename as...
822 (declarations, declaration, grammar, grammar_declaration)
823 (precedence_declaration, precedence_declarator): these.
824 (symbol_declaration): New.
825
592e8d4d
AD
8262002-06-14 Akim Demaille <akim@epita.fr>
827
828 * src/files.c (action_obstack): Remove, unused.
829 (output_obstack): Remove it, and all its dependencies, as it is no
830 longer needed.
831 * src/reader.c (epilogue_set): Build the epilogue in the
832 muscle_obstack.
833 * src/output.h, src/output.c (muscle_obstack): Move to...
834 * src/muscle_tab.h, src/muscle_tab.h: here.
835 (muscle_init): Initialize muscle_obstack.
836 (muscle_free): New.
837 * src/main.c (main): Call it.
838
0c15323d
AD
8392002-06-14 Akim Demaille <akim@epita.fr>
840
841 * src/location.h: New, extracted from...
842 * src/reader.h: here.
843 * src/Makefile.am (noinst_HEADERS): Merge into
844 (bison_SOURCES): this.
845 Add location.h.
846 * src/parse-gram.y: Use location_t instead of Bison's.
847 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
848 Use location_t instead of ints.
849
e96c9728
AD
8502002-06-14 Akim Demaille <akim@epita.fr>
851
852 * data/bison.simple, data/bison.c++: Be sure to restore the
853 current #line when returning to the skeleton contents after having
854 exposed the input file's #line.
855
75d1fe16
AD
8562002-06-12 Akim Demaille <akim@epita.fr>
857
858 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
859 eager.
860 * tests/actions.at (Exotic Dollars): New.
861
6c35d22c
AD
8622002-06-12 Akim Demaille <akim@epita.fr>
863
864 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
865 ['"/] too eagerly.
866 * tests/input.at (Torturing the Scanner): New.
867
1d6412ad
AD
8682002-06-11 Akim Demaille <akim@epita.fr>
869
870 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
871 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
872 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
873 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
874 * src/reader.c (reader): Use it.
875
4cdb01db
AD
8762002-06-11 Akim Demaille <akim@epita.fr>
877
878 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
879 Adjust all callers.
880 (scanner_last_string_free): New.
881
44995b2e
AD
8822002-06-11 Akim Demaille <akim@epita.fr>
883
884 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
885 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
886 (last_string, YY_OBS_FREE): New.
887 Use them when returning an ID.
888
e9955c83
AD
8892002-06-11 Akim Demaille <akim@epita.fr>
890
891 Have Bison grammars parsed by a Bison grammar.
892
893 * src/reader.c, src/reader.h (prologue_augment): New.
894 * src/reader.c (copy_definition): Remove.
895
896 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
897 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
898 (grammar_current_rule_prec_set, grammar_current_rule_check)
899 (grammar_current_rule_symbol_append)
900 (grammar_current_rule_action_append): Export.
901 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
902 (symbol_list_action_append): Remove.
903 Hook the routines from reader.
904 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
905 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
906
907 * src/reader.c (read_declarations): Remove, unused.
908
909 * src/parse-gram.y: Handle the epilogue.
910 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
911 (grammar_start_symbol_set): this.
912 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
913 * src/reader.c (readgram): Remove, unused.
914 (reader): Adjust to insert eoftoken and axiom where appropriate.
915
916 * src/reader.c (copy_dollar): Replace with...
917 * src/scan-gram.h (handle_dollar): this.
918 * src/parse-gram.y: Remove `%thong'.
919
920 * src/reader.c (copy_at): Replace with...
921 * src/scan-gram.h (handle_at): this.
922
923 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
924 New.
925
926 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
927 time being.
928
929 * src/reader.h, src/reader.c (grammar_rule_end): New.
930
931 * src/parse.y (current_type, current_class): New.
932 Implement `%nterm', `%token' support.
933 Merge `%term' into `%token'.
934 (string_as_id): New.
935 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
936 type name.
937
938 * src/parse-gram.y: Be sure to handle properly the beginning of
939 rules.
940
941 * src/parse-gram.y: Handle %type.
942 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
943
944 * src/parse-gram.y: More directives support.
945 * src/options.c: No longer handle source directives.
946
947 * src/parse-gram.y: Fix %output.
948
949 * src/parse-gram.y: Handle %union.
950 Use the prologue locations.
951 * src/reader.c (parse_union_decl): Remove.
952
953 * src/reader.h, src/reader.c (epilogue_set): New.
954 * src/parse-gram.y: Use it.
955
956 * data/bison.simple, data/bison.c++: b4_stype is now either not
957 defined, then default to int, or to the contents of %union,
958 without `union' itself.
959 Adjust.
960 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
961
962 * src/output.c (actions_output): Don't output braces, as they are
963 already handled by the scanner.
964
965 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
966 characters to themselves.
967
968 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
969 that the epilogue has a proper #line.
970
971 * src/parse-gram.y: Handle precedence/associativity.
972
973 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
974 a terminal.
975 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
976 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
977 at all to define terminals that cannot be emitted.
978
979 * src/scan-gram.l: Escape M4 characters.
980
981 * src/scan-gram.l: Working properly with escapes in user
982 strings/characters.
983
984 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
985 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
986 grammar.
987 Use more modest sizes, as for the time being the parser does not
988 release memory, and therefore the process swallows a huge amount
989 of memory.
990
991 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
992 stricter %token grammar.
993
994 * src/symtab.h (associativity): Add `undef_assoc'.
995 (symbol_precedence_set): Do nothing when passed an undef_assoc.
996 * src/symtab.c (symbol_check_alias_consistence): Adjust.
997
998 * tests/regression.at (Invalid %directive): Remove, as it is now
999 meaningless.
1000 (Invalid inputs): Adjust to the new error messages.
1001 (Token definitions): The new grammar doesn't allow too many
1002 eccentricities.
1003
1004 * src/lex.h, src/lex.c: Remove.
1005 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
1006 (copy_character, copy_string2, copy_string, copy_identifier)
1007 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
1008 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
1009 (parse_action): Remove.
1010 * po/POTFILES.in: Adjust.
1011
2e047461
AD
10122002-06-11 Akim Demaille <akim@epita.fr>
1013
1014 * src/reader.c (parse_action): Don't store directly into the
1015 rule's action member: return the action as a string.
1016 Don't require `rule_length' as an argument: compute it.
1017 (grammar_current_rule_symbol_append)
1018 (grammar_current_rule_action_append): New, eved out from
1019 (readgram): here.
1020 Remove `action_flag', `rulelength', unused now.
1021
9af3fbce
AD
10222002-06-11 Akim Demaille <akim@epita.fr>
1023
1024 * src/reader.c (grammar_current_rule_prec_set).
1025 (grammar_current_rule_check): New, eved out from...
1026 (readgram): here.
1027 Remove `xaction', `first_rhs': useless.
1028 * tests/input.at (Type clashes): New.
1029 * tests/existing.at (GNU Cim Grammar): Adjust.
1030
1485e106
AD
10312002-06-11 Akim Demaille <akim@epita.fr>
1032
1033 * src/reader.c (grammar_midrule_action): New, Eved out from
1034 (readgram): here.
1035
da4160c3
AD
10362002-06-11 Akim Demaille <akim@epita.fr>
1037
1038 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
1039 New.
1040 (readgram): Use them as replacement of inlined code, crule and
1041 crule1.
1042
f6d0f937
AD
10432002-06-11 Akim Demaille <akim@epita.fr>
1044
1045 * src/reader.c (grammar_end, grammar_symbol_append): New.
1046 (readgram): Use them.
1047 Make the use of `p' as local as possible.
1048
69078d4b
AD
10492002-06-10 Akim Demaille <akim@epita.fr>
1050
1051 GCJ's parser requires the tokens to be defined before the prologue.
1052
1053 * data/bison.simple: Output the token definition before the user's
1054 prologue.
1055 * tests/regression.at (Braces parsing, Duplicate string)
1056 (Mixing %token styles): Check the output from bison.
1057 (Early token definitions): New.
1058
5e424082
AD
10592002-06-10 Akim Demaille <akim@epita.fr>
1060
1061 * src/symtab.c (symbol_user_token_number_set): Don't complain when
1062 assigning twice the same user number to a token, so that we can
1063 use it in...
1064 * src/lex.c (lex): here.
1065 Also use `symbol_class_set' instead of hand written code.
1066 * src/reader.c (parse_assoc_decl): Likewise.
1067
44536b35
AD
10682002-06-10 Akim Demaille <akim@epita.fr>
1069
1070 * src/symtab.c, src/symtab.c (symbol_class_set)
1071 (symbol_user_token_number_set): New.
1072 * src/reader.c (parse_token_decl): Use them.
1073 Use a switch instead of ifs.
1074 Use a single argument.
1075
8b9f2372
AD
10762002-06-10 Akim Demaille <akim@epita.fr>
1077
1078 Remove `%thong' support as it is undocumented, unused, duplicates
1079 `%token's job, and creates useless e-mail traffic with people who
1080 want to know what it is, why it is undocumented, unused, and
1081 duplicates `%token's job.
1082
1083 * src/reader.c (parse_thong_decl): Remove.
1084 * src/options.c (option_table): Remove "thong".
1085 * src/lex.h (tok_thong): Remove.
1086
3ae2b51f
AD
10872002-06-10 Akim Demaille <akim@epita.fr>
1088
1089 * src/symtab.c, src/symtab.c (symbol_type_set)
1090 (symbol_precedence_set): New.
1091 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
1092 (value_components_used): Remove, unused.
1093
2f1afb73
AD
10942002-06-09 Akim Demaille <akim@epita.fr>
1095
1096 Move symbols handling code out of the reader.
1097
1098 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
1099 (axiom): Move to...
1100 * src/symtab.h, src/symtab.c: here.
1101
1102 * src/gram.c (start_symbol): Remove: use startsymbol->number.
1103 * src/reader.c (startval): Rename as...
1104 * src/symtab.h, src/symtab.c (startsymbol): this.
1105 * src/reader.c: Adjust.
1106
1107 * src/reader.c (symbol_check_defined, symbol_make_alias)
1108 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1109 (token_translations_init)
1110 Move to...
1111 * src/symtab.c: here.
1112 * src/reader.c (packsymbols): Move to...
1113 * src/symtab.h, src/symtab.c (symbols_pack): here.
1114 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
1115 argument.
1116
e9bca3ad
AD
11172002-06-03 Akim Demaille <akim@epita.fr>
1118
1119 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
1120 then statements.
1121
86eff183
AD
11222002-06-03 Akim Demaille <akim@epita.fr>
1123
1124 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
1125 structs with non literals.
1126 * src/scan-skel.l: never-interactive.
1127 * src/conflicts.c (enum conflict_resolution_e): No trailing
1128 comma.
1129 * src/getargs.c (usage): Split long literal strings.
1130 Reported by Hans Aberg.
1131
717be197
AD
11322002-05-28 Akim Demaille <akim@epita.fr>
1133
1134 * data/bison.c++: Use C++ ostreams.
1135 (cdebug_): New member.
1136
670ddffd
AD
11372002-05-28 Akim Demaille <akim@epita.fr>
1138
1139 * src/output.c (output_skeleton): Be sure to allocate enough room
1140 for `/' _and_ for `\0' in full_skeleton.
1141
769b430f
AD
11422002-05-28 Akim Demaille <akim@epita.fr>
1143
1144 * data/bison.c++: Catch up with bison.simple:
1145 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1146 and Paul Eggert <eggert@twinsun.com>: `error' handing.
1147 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
1148 and popping traces.
1149
7067cb36
PH
11502002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1151
1152 * src/output.c (output_skeleton): Put an explicit path in front of
1153 the skeleton file name, rather than relying on the -I directory,
1154 to partially alleviate effects of having a skeleton file lying around
1155 in the current directory.
769b430f 1156
4a713ec2
PH
11572002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1158
769b430f 1159 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
1160 obstack_printf should be obstack_fgrow1.
1161
b408954b
AD
11622002-05-26 Akim Demaille <akim@epita.fr>
1163
1164 * src/state.h (state_t): `solved_conflicts' is a new member.
1165 * src/LR0.c (new_state): Set it to 0.
1166 * src/conflicts.h, src/conflicts.c (print_conflicts)
1167 (free_conflicts, solve_conflicts): Rename as...
1168 (conflicts_print, conflicts_free, conflicts_solve): these.
1169 Adjust callers.
1170 * src/conflicts.c (enum conflict_resolution_e)
1171 (solved_conflicts_obstack): New, used by...
1172 (log_resolution): this.
1173 Adjust to attach the conflict resolution to each state.
1174 Complete the description with the precedence/associativity
1175 information.
1176 (resolve_sr_conflict): Adjust.
1177 * src/print.c (print_state): Output its solved_conflicts.
1178 * tests/conflicts.at (Unresolved SR Conflicts)
1179 (Solved SR Conflicts): Exercise --report=all.
1180
a49aecd5
AD
11812002-05-26 Akim Demaille <akim@epita.fr>
1182
1183 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1184 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1185 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
1186 (token_number_t, item_number_as_token_number)
1187 (token_number_as_item_number, muscle_insert_token_number_table):
1188 Rename as...
1189 (symbol_number_t, item_number_as_symbol_number)
1190 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
1191 these, since it is more appropriate.
1192
5504898e
AD
11932002-05-26 Akim Demaille <akim@epita.fr>
1194
1195 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
1196 `Error:' lines.
1197 * data/bison.simple (yystos) [YYDEBUG]: New.
1198 (yyparse) [YYDEBUG]: Display the symbols which are popped during
1199 error recovery.
1200 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
1201
ec3bc396
AD
12022002-05-25 Akim Demaille <akim@epita.fr>
1203
1204 * doc/bison.texinfo (Debugging): Split into...
1205 (Tracing): this new section, its former contents, and...
1206 (Understanding): this new section.
1207 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
1208 by...
1209 (report_flag): this.
1210 Adjust all dependencies.
1211 (report_args, report_types, report_argmatch): New.
1212 (usage, getargs): Report/support -r, --report.
1213 * src/options.h
1214 (struct option_table_struct): Rename as..,
1215 (struct option_table_s): this.
1216 Rename the `set_flag' member to `flag' to match with getopt_long's
1217 struct.
1218 * src/options.c (option_table): Split verbose into an entry for
1219 %verbose, and another for --verbose.
1220 Support --report/-r, so remove -r from the obsolete --raw.
1221 * src/print.c: Attach full item sets and lookaheads reports to
1222 report_flag instead of trace_flag.
1223 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
1224
78df8250
PE
12252002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1226 and Paul Eggert <eggert@twinsun.com>
769b430f 1227
78df8250
PE
1228 * data/bison.simple (yyparse): Correct error handling to conform to
1229 POSIX and yacc. Specifically, after syntax error is discovered,
1230 do not reduce further before shifting the error token.
1231 Clean up the code a bit by removing the labels yyerrdefault,
1232 yyerrhandle, yyerrpop.
1233 * NEWS: Document the above.
1234
c0c9ea05
PH
12352002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1236
1237 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
1238 type; it isn't always big enough, since it doesn't necessarily
1239 include non-terminals.
769b430f 1240 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
1241 the latter can be removed.
1242 (yy_token_number_type): Remove, only one use.
1243 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
1244 don't use TokenNumberType as element type.
769b430f 1245
c0c9ea05
PH
1246 * tests/regression.at: Modify expected output to agree with change
1247 to yyr1 and yytranslate.
769b430f 1248
6390a83f
FK
12492002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
1250
1251 * src/reader.c (parse_action): Use copy_character instead of
1252 obstack_1grow.
1253
db7c8e9a
AD
12542002-05-13 Akim Demaille <akim@epita.fr>
1255
1256 * tests/regression.at (Token definitions): Prototype yylex and
1257 yyerror.
1258
fcc61800
PH
12592002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1260
158c687b 1261 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
1262 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
1263 32-bit arithmetic.
1264 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
1265
5683e9b2
AD
12662002-05-07 Akim Demaille <akim@epita.fr>
1267
1268 * tests/synclines.at: Be sure to prototype yylex and yyerror to
1269 avoid GCC warnings.
1270
0c2d3f4c
AD
12712002-05-07 Akim Demaille <akim@epita.fr>
1272
1273 Kill GCC warnings.
1274
1275 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
1276 over the RHS of each rule.
1277 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
1278 * src/state.h (state_t): Member `nitems' is unsigned short.
1279 * src/LR0.c (get_state): Adjust.
1280 * src/reader.c (packgram): Likewise.
1281 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
1282 `Type'.
1283 (muscle_insert_int_table): Remove, unused.
1284 (prepare_rules): Remove `max'.
1285
1565b720
AD
12862002-05-06 Akim Demaille <akim@epita.fr>
1287
1288 * src/closure.c (print_firsts): Display of the symbol tags.
1289 (bitmatrix_print): Move to...
1290 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
1291 here.
1292 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
1293
cfaee611
AD
12942002-05-06 Akim Demaille <akim@epita.fr>
1295
1296 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
1297 hash_do_for_each.
1298
458be8e0
AD
12992002-05-06 Akim Demaille <akim@epita.fr>
1300
1301 * src/LR0.c (new_state, get_state): Instead of using the global
1302 `kernel_size' and `kernel_base', have two new arguments:
1303 `core_size' and `core'.
1304 Adjust callers.
1305
a900a624
AD
13062002-05-06 Akim Demaille <akim@epita.fr>
1307
1308 * src/reader.c (packgram): No longer end `ritem' with a 0
1309 sentinel: it is not used.
1310
d4e7d3a1
AD
13112002-05-05 Akim Demaille <akim@epita.fr>
1312
1313 New experimental feature: display the lookaheads in the report and
1314 graph.
1315
1316 * src/print (print_core): When --trace-flag, display the rules
1317 lookaheads.
1318 * src/print_graph.c (print_core): Likewise.
1319 Swap the arguments.
1320 Adjust caller.
1321
39ceb25b
AD
13222002-05-05 Akim Demaille <akim@epita.fr>
1323
1324 * tests/torture.at (Many lookaheads): New test.
1325
5372019f
AD
13262002-05-05 Akim Demaille <akim@epita.fr>
1327
1328 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
1329 (GENERATE_MUSCLE_INSERT_TABLE): this.
1330 (output_int_table, output_unsigned_int_table, output_short_table)
1331 (output_token_number_table, output_item_number_table): Replace with...
1332 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
1333 (muscle_insert_short_table, muscle_insert_token_number_table)
1334 (muscle_insert_item_number_table): these.
1335 Adjust all callers.
1336 (prepare_tokens): Don't free `translations', since...
1337 * src/reader.h, src/reader.c (grammar_free): do it.
1338 Move to...
1339 * src/gram.h, src/gram.c (grammar_free): here.
1340 * data/bison.simple, data/bison.c++: b4_token_number_max is now
1341 b4_translate_max.
1342
5df5f6d5
AD
13432002-05-05 Akim Demaille <akim@epita.fr>
1344
1345 * src/output.c (output_unsigned_int_table): New.
1346 (prepare_rules): `i' is unsigned.
1347 `prhs', `rline', `r2' are unsigned int.
1348 Rename muscle `rhs_number_max' as `rhs_max'.
1349 Output muscles `prhs_max', `rline_max', and `r2_max'.
1350 Free rline and r1.
1351 * data/bison.simple, data/bison.c++: Adjust to use these muscles
1352 to compute types instead of constant types.
1353 * tests/regression.at (Web2c Actions): Adjust.
1354
b87f8b21
AD
13552002-05-04 Akim Demaille <akim@epita.fr>
1356
1357 * src/symtab.h (SALIAS, SUNDEF): Rename as...
1358 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
1359 Adjust dependencies.
1360 * src/output.c (token_definitions_output): Be sure not to output a
1361 `#define 'a'' when fed with `%token 'a' "a"'.
1362 * tests/regression.at (Token definitions): New.
1363
8bb936e4
PE
13642002-05-03 Paul Eggert <eggert@twinsun.com>
1365
1366 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
1367 for K&R C.
1368
13692002-05-03 gettextize <bug-gnu-gettext@gnu.org>
1370
1371 * Makefile.am (SUBDIRS): Remove intl.
1372 (EXTRA_DIST): Add config/config.rpath.
1373
53c71a12
AD
13742002-05-03 Akim Demaille <akim@epita.fr>
1375
1376 * data/bison.simple (m4_if): Don't output empty enums.
1377 And actually, output valid enum definitions :(.
1378
289dd0cf
AD
13792002-05-03 Akim Demaille <akim@epita.fr>
1380
1381 * configure.bat: Remove, completely obsolete.
1382 * Makefile.am (EXTRA_DIST): Adjust.
1383 Don't distribute config.rpath...
1384 * config/Makefile.am (EXTRA_DIST): Do it.
1385
db85e524
AD
13862002-05-03 Akim Demaille <akim@epita.fr>
1387
1388 * configure.in (GETTEXT_VERSION): New.
1389 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
1390
83ccf991
AD
13912002-05-03 Akim Demaille <akim@epita.fr>
1392
1393 * data/bison.simple (b4_token_enum): New.
1394 (b4_token_defines): Use it to output tokens both as #define and
1395 enums.
1396 Suggested by Paul Eggert.
1397 * src/output.c (token_definitions_output): Don't output spurious
1398 white spaces.
1399
1f418995
AD
14002002-05-03 Akim Demaille <akim@epita.fr>
1401
1402 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1403
45119f04
RA
14042002-05-02 Robert Anisko <robert@lrde.epita.fr>
1405
1406 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
1407 Update the stack class, give a try to deque as the default container.
1408
b2d52318
AD
14092002-05-02 Akim Demaille <akim@epita.fr>
1410
1411 * data/bison.simple (yyparse): Do not implement @$ = @1.
1412 (YYLLOC_DEFAULT): Adjust to do it.
1413 * doc/bison.texinfo (Location Default Action): Fix.
1414
3a8b4109
AD
14152002-05-02 Akim Demaille <akim@epita.fr>
1416
1417 * src/reader.c (parse_braces): Merge into...
1418 (parse_action): this.
1419
84614e13
AD
14202002-05-02 Akim Demaille <akim@epita.fr>
1421
1422 * configure.in (ALL_LINGUAS): Remove.
1423 * po/LINGUAS, hr.po: New.
1424
fdbcd8e2
AD
14252002-05-02 Akim Demaille <akim@epita.fr>
1426
1427 Remove the so called hairy (semantic) parsers.
1428
1429 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
1430 * src/gram.h, src/gram.c (semantic_parser): Remove.
1431 (rule_t): Remove the guard and guard_line members.
1432 * src/lex.h (token_t): remove tok_guard.
1433 * src/options.c (option_table): Remove %guard and %semantic_parser
1434 support.
1435 * src/output.c, src/output.h (guards_output): Remove.
1436 (prepare): Adjust.
1437 (token_definitions_output): Don't output the `T'
1438 tokens (???).
1439 (output_skeleton): Don't output the guards.
1440 * src/files.c, src/files.c (attrsfile): Remove.
1441 * src/reader.c (symbol_list): Remove the guard and guard_line
1442 members.
1443 Adjust dependencies.
1444 (parse_guard): Remove.
1445 * data/bison.hairy: Remove.
1446 * doc/bison.texinfo (Environment Variables): Remove occurrences of
1447 BISON_HAIRY.
1448
82b6cb3f
AD
14492002-05-02 Akim Demaille <akim@epita.fr>
1450
1451 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
1452 (parse_guard): Rename the formal argument `stack_offset' as
1453 `rule_length', which is more readable.
1454 Adjust callers.
1455 (copy_at, copy_dollar): Instead of outputting the hard coded
1456 values of $$, $n and so forth, output invocation to b4_lhs_value,
1457 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
1458 Note: this patch partially drops `semantic-parser' support: it
1459 always does `rule_length - n', where semantic parsers ought to
1460 always use `-n'.
82b6cb3f
AD
1461 * data/bison.simple, data/bison.c++ (b4_lhs_value)
1462 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
1463
6cbfbcc5
AD
14642002-05-02 Akim Demaille <akim@epita.fr>
1465
1466 * configure.in (AC_INIT): Bump to 1.49b.
1467 (AM_INIT_AUTOMAKE): Short invocation.
1468
b8548114
AD
14692002-05-02 Akim Demaille <akim@epita.fr>
1470
1471 Version 1.49a.
1472
c20cd1fa
AD
14732002-05-01 Akim Demaille <akim@epita.fr>
1474
1475 * src/skeleton.h: Remove.
1476
8a9566d4
AD
14772002-05-01 Akim Demaille <akim@epita.fr>
1478
1479 * src/skeleton.h: Fix the #endif.
1480 Reported by Magnus Fromreide.
1481
8c6d399a
PE
14822002-04-26 Paul Eggert <eggert@twinsun.com>
1483
1484 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
1485 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 1486 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 1487
2b7ed18a
RA
14882002-04-25 Robert Anisko <robert@lrde.epita.fr>
1489
1490 * src/scan-skel.l: Postprocess quadrigraphs.
1491
1492 * src/reader.c (copy_character): New function, used to output
1493 single characters while replacing `[' and `]' with quadrigraphs, to
1494 avoid troubles with M4 quotes.
1495 (copy_comment): Output characters with copy_character.
1496 (read_additionnal_code): Likewise.
1497 (copy_string2): Likewise.
1498 (copy_definition): Likewise.
1499
1500 * tests/calc.at: Exercise M4 quoting.
1501
34a89c50
AD
15022002-04-25 Akim Demaille <akim@epita.fr>
1503
1504 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
1505 between `!' and the command.
1506 Reported by Paul Eggert.
1507
0dd1580a
RA
15082002-04-24 Robert Anisko <robert@lrde.epita.fr>
1509
1510 * tests/calc.at: Exercise prologue splitting.
1511
1512 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
1513 `b4_post_prologue' instead of `b4_prologue'.
1514
1515 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
1516 muscles.
1517 (output): Free pre_prologue_obstack and post_prologue_obstack.
1518 * src/files.h, src/files.c (attrs_obstack): Remove.
1519 (pre_prologue_obstack, post_prologue_obstack): New.
1520 * src/reader.c (copy_definition): Add a parameter to specify the
1521 obstack to fill, instead of using attrs_obstack unconditionally.
1522 (read_declarations): Pass pre_prologue_obstack to copy_definition if
1523 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
1524
83c1796f
PE
15252002-04-23 Paul Eggert <eggert@twinsun.com>
1526
1527 * data/bison.simple: Remove unnecessary commentary and white
1528 space differences from 1_29-branch.
1529 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
1530
1531 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
1532 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
1533 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
1534 constructors or destructors.
1535
1536 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
1537
1207eeac
AD
15382002-04-23 Akim Demaille <akim@epita.fr>
1539
1540 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
1541 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
1542 location with columns.
1543 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
1544 All reported by Paul Eggert.
1545
78ab8f67
AD
15462002-04-22 Akim Demaille <akim@epita.fr>
1547
1548 * src/reduce.c (dump_grammar): Move to...
1549 * src/gram.h, src/gram.c (grammar_dump): here.
1550 Be sure to separate long item numbers.
1551 Don't read the members of a rule's prec if its nil.
1552
133c20e2
AD
15532002-04-22 Akim Demaille <akim@epita.fr>
1554
1555 * src/output.c (table_size, table_grow): New.
1556 (MAXTABLE): Remove, replace uses with table_size.
1557 (pack_vector): Instead of dying when the table is too big, grow it.
1558
9515e8a7
AD
15592002-04-22 Akim Demaille <akim@epita.fr>
1560
1561 * data/bison.simple (yyr1): Its type is that of a token number.
1562 * data/bison.c++ (r1_): Likewise.
1563 * tests/regression.at (Web2c Actions): Adjust.
1564
23c5a174
AD
15652002-04-22 Akim Demaille <akim@epita.fr>
1566
1567 * src/reader.c (token_translations_init): 256 is now the default
1568 value for the error token, i.e., it will be assigned another
1569 number if the user assigned 256 to one of her tokens.
1570 (reader): Don't force 256 to error.
1571 * doc/bison.texinfo (Symbols): Adjust.
1572 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
1573 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
1574 etc. instead of 10, 20, 30 (which was used to `jump' over error
1575 (256) and undefined (2)).
1576
5fbb0954
AD
15772002-04-22 Akim Demaille <akim@epita.fr>
1578
1579 Propagate more token_number_t.
1580
1581 * src/gram.h (token_number_as_item_number)
1582 (item_number_as_token_number): New.
1583 * src/output.c (GENERATE_OUTPUT_TABLE): New.
1584 Use it to create output_item_number_table and
1585 output_token_number_table.
1586 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
1587 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
1588 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
1589 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
1590
4f940944
AD
15912002-04-22 Akim Demaille <akim@epita.fr>
1592
1593 * src/output.h, src/output.c (get_lines_number): Remove.
1594
3ded9a63
AD
15952002-04-19 Akim Demaille <akim@epita.fr>
1596
1597 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
1598 as Lex/Flex'.
1599 (Debugging): More details about enabling the debugging features.
1600 (Table of Symbols): Describe $$, $n, @$, and @n.
1601 Suggested by Tim Josling.
1602
e0c471a9
AD
16032002-04-19 Akim Demaille <akim@epita.fr>
1604
1605 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
1606
fecc10cd
AD
16072002-04-10 Akim Demaille <akim@epita.fr>
1608
1609 * src/system.h: Rely on HAVE_LIMITS_H.
1610 Suggested by Paul Eggert.
1611
51dec47b
AD
16122002-04-09 Akim Demaille <akim@epita.fr>
1613
1614 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
1615 full stderr, and strip it according to the bison options, instead
1616 of composing the error message from different bits.
1617 This makes it easier to check for several error messages.
1618 Adjust all the invocations.
1619 Add an invocation exercising the error token.
1620 Add an invocation demonstrating a stupid error message.
1621 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
1622 Adjust the tests.
1623 Error message are for stderr, not stdout.
1624
007a50a4
AD
16252002-04-09 Akim Demaille <akim@epita.fr>
1626
1627 * src/gram.h, src/gram.c (error_token_number): Remove, use
1628 errtoken->number.
1629 * src/reader.c (reader): Don't specify the user token number (2)
1630 for $undefined, as it uselessly prevents using it.
1631 * src/gram.h (token_number_t): Move to...
1632 * src/symtab.h: here.
1633 (state_t.number): Is a token_number_t.
1634 * src/print.c, src/reader.c: Use undeftoken->number instead of
1635 hard coded 2.
1636 (Even though this 2 is not the same as above: the number of the
1637 undeftoken remains being 2, it is its user token number which
1638 might not be 2).
1639 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
1640 `user_token_number_max'.
1641 Output `undef_token_number'.
1642 * data/bison.simple, data/bison.c++: Use them.
1643 Be sure to map invalid yylex return values to
1644 `undef_token_number'. This saves us from gratuitous SEGV.
1645
1646 * tests/conflicts.at (Solved SR Conflicts)
1647 (Unresolved SR Conflicts): Adjust.
1648 * tests/regression.at (Web2c Actions): Adjust.
1649
06446ccf
AD
16502002-04-08 Akim Demaille <akim@epita.fr>
1651
1652 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
1653 Adding #line.
1654 Remove the duplicate `typedefs'.
1655 (RhsNumberType): Fix the declaration and various other typos.
1656 Use __ofile__.
1657 * data/bison.simple: Use __ofile__.
1658 * src/scan-skel.l: Handle __ofile__.
1659
62a3e4f0
AD
16602002-04-08 Akim Demaille <akim@epita.fr>
1661
1662 * src/gram.h (item_number_t): New, the type of item numbers in
1663 RITEM. Note that it must be able to code symbol numbers as
1664 positive number, and the negation of rule numbers as negative
1665 numbers.
1666 Adjust all dependencies (pretty many).
1667 * src/reduce.c (rule): Remove this `short *' pointer: use
1668 item_number_t.
1669 * src/system.h (MINSHORT, MAXSHORT): Remove.
1670 Include `limits.h'.
1671 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
1672 (shortcpy): Remove.
1673 (MAXTABLE): Move to...
1674 * src/output.c (MAXTABLE): here.
1675 (prepare_rules): Use output_int_table to output rhs.
1676 * data/bison.simple, data/bison.c++: Adjust.
1677 * tests/torture.at (Big triangle): Move the limit from 254 to
1678 500.
1679 * tests/regression.at (Web2c Actions): Ajust.
1680
1681 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
1682 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
1683 passes, but produces negative #line number, once fixed, GCC is
1684 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
1685 C), it passes.
1686 * src/state.h (state_h): Code input lines on ints, not shorts.
1687
bb88b0fc
AD
16882002-04-08 Akim Demaille <akim@epita.fr>
1689
1690 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
1691 and then the grammar.
1692
9a636f47
AD
16932002-04-08 Akim Demaille <akim@epita.fr>
1694
1695 * src/system.h: No longer using strndup.
1696
680e8701
AD
16972002-04-07 Akim Demaille <akim@epita.fr>
1698
1699 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
1700 * src/output.c (output_table_data): Return the longest number.
1701 (prepare_tokens): Output `token_number_max').
1702 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
1703 New.
1704 Use them to define yy_token_number_type/TokenNumberType.
1705 Use this type for yytranslate.
1706 * tests/torture.at (Big triangle): Push the limit from 124 to
1707 253.
1708 * tests/regression.at (Web2c Actions): Adjust.
1709
817e9f41
AD
17102002-04-07 Akim Demaille <akim@epita.fr>
1711
1712 * tests/torture.at (Big triangle): New.
1713 (GNU AWK Grammar, GNU Cim Grammar): Move to...
1714 * tests/existing.at: here.
1715
5123689b
AD
17162002-04-07 Akim Demaille <akim@epita.fr>
1717
1718 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
1719 nritems.
1720 Adjust dependencies.
1721
f3849179
AD
17222002-04-07 Akim Demaille <akim@epita.fr>
1723
1724 * src/reader.c: Normalize increments to prefix form.
1725
bd02036a
AD
17262002-04-07 Akim Demaille <akim@epita.fr>
1727
1728 * src/reader.c, symtab.c: Remove debugging code.
1729
db8837cb
AD
17302002-04-07 Akim Demaille <akim@epita.fr>
1731
1732 Rename all the `bucket's as `symbol_t'.
1733
1734 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
1735 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
1736 * src/symtab.c, src/symtab.h (bucket): Rename as...
1737 (symbol_t): this.
1738 (symbol_list_new, bucket_check_defined, bucket_make_alias)
1739 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
1740 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1741 (buckets_new, buckets_free, buckets_do): Rename as...
1742 (symbol_list_new, symbol_check_defined, symbol_make_alias)
1743 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
1744 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
1745 (symbols_new, symbols_free, symbols_do): these.
1746
72a23c97
AD
17472002-04-07 Akim Demaille <akim@epita.fr>
1748
1749 Use lib/hash for the symbol table.
1750
1751 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
1752 EOF.
1753 * src/lex.c (lex): Set the `number' member of new terminals.
1754 * src/reader.c (bucket_check_defined, bucket_make_alias)
1755 (bucket_check_alias_consistence, bucket_translation): New.
1756 (reader, grammar_free, readgram, token_translations_init)
1757 (packsymbols): Adjust.
1758 (reader): Number the predefined tokens.
1759 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
1760 for predefined tokens.
1761 * src/symtab.h (bucket): Remove all the hash table related
1762 members.
1763 * src/symtab.c (symtab): Replace by...
1764 (bucket_table): this.
1765 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
1766 (buckets_new, buckets_do): New.
1767
280a38c3
AD
17682002-04-07 Akim Demaille <akim@epita.fr>
1769
1770 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
1771 (start_symbol, max_user_token_number, semantic_parser)
1772 (error_token_number): Initialize.
1773 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
1774 Initialize.
1775 (reader): Don't.
1776 (errtoken, eoftoken, undeftoken, axiom): Extern.
1777
03b31c0c
AD
17782002-04-07 Akim Demaille <akim@epita.fr>
1779
1780 * src/gram.h (rule_s): prec and precsym are now pointers
1781 to the bucket giving the priority/associativity.
1782 Member `associativity' removed: useless.
1783 * src/reduce.c, src/conflicts.c: Adjust.
1784
8b3df748
AD
17852002-04-07 Akim Demaille <akim@epita.fr>
1786
1787 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
1788 Properly escape the symbols' TAG when outputting them.
1789
e601aa1d
AD
17902002-04-07 Akim Demaille <akim@epita.fr>
1791
1792 * src/lalr.h (LA): Is a bitsetv, not bitset*.
1793
b0299a2e
AD
17942002-04-07 Akim Demaille <akim@epita.fr>
1795
1796 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
1797 (LArule): this, which is an array to rule_t*.
1798 * src/print.c, src/conflicts.c: Adjust.
1799
d7e1f00c
AD
18002002-04-07 Akim Demaille <akim@epita.fr>
1801
1802 * src/gram.h (rule_t): Rename `number' as `user_number'.
1803 `number' is a new member.
1804 Adjust dependencies.
1805 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
1806
cc9305dd
AD
18072002-04-07 Akim Demaille <akim@epita.fr>
1808
1809 As a result of the previous patch, it is no longer needed
1810 to reorder ritem itself.
1811
1812 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
1813
b0940840
AD
18142002-04-07 Akim Demaille <akim@epita.fr>
1815
1816 Be sure never to walk through RITEMS, but use only data related to
1817 the rules themselves. RITEMS should be banished.
1818
1819 * src/output.c (output_token_translations): Rename as...
1820 (prepare_tokens): this.
1821 In addition to `translate', prepare the muscles `tname' and
1822 `toknum', which were handled by...
1823 (output_rule_data): this.
1824 Remove, and move the remainder of its outputs into...
1825 (prepare_rules): this new routines, which also merges content from
1826 (output_gram): this.
1827 (prepare_rules): Be sure never to walk through RITEMS.
1828 (output_stos): Rename as...
1829 (prepare_stos): this.
1830 (output): Always invoke prepare_states, after all, just don't use it
1831 in the output if you don't need it.
1832
643a5994
AD
18332002-04-07 Akim Demaille <akim@epita.fr>
1834
1835 * src/LR0.c (new_state): Display `nstates' as the name of the
1836 newly created state.
1837 Adjust to initialize first_state and last_state if needed.
1838 Be sure to distinguish the initial from the final state.
1839 (new_states): Create the itemset of the initial state, and use
1840 new_state.
1841 * src/closure.c (closure): Now that the initial state has its
1842 items properly set, there is no need for a special case when
1843 creating `ruleset'.
1844
1845 As a result, now the rule 0, reducing to $axiom, is visible in the
1846 outputs. Adjust the test suite.
1847
1848 * tests/conflicts.at (Solved SR Conflicts)
1849 (Unresolved SR Conflicts): Adjust.
1850 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
1851 * tests/conflicts.at (S/R in initial): New.
1852
b4c4ccc2
AD
18532002-04-07 Akim Demaille <akim@epita.fr>
1854
1855 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
1856 the RHS of the rules.
1857 * src/output.c (output_gram): Likewise.
1858
bba97eb2
AD
18592002-04-07 Akim Demaille <akim@epita.fr>
1860
1861 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
1862 bucket.
1863 Adjust all dependencies.
1864 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
1865 `number' of the buckets too.
1866 * src/gram.h: Include `symtab.h'.
1867 (associativity): Move to...
1868 * src/symtab.h: here.
1869 No longer include `gram.h'.
1870
c3b407f4
AD
18712002-04-07 Akim Demaille <akim@epita.fr>
1872
1873 * src/gram.h, src/gram.c (rules_rhs_length): New.
1874 (ritem_longest_rhs): Use it.
1875 * src/gram.h (rule_t): `number' is a new member.
1876 * src/reader.c (packgram): Set it.
1877 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
1878 the end of `rules', and count them out of `nrules'.
1879 (reduce_output, dump_grammar): Adjust.
1880 * src/print.c (print_grammar): It is no longer needed to check for
1881 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
1882 * tests/reduce.at (Reduced Automaton): New test.
1883
11652ab3
AD
18842002-04-07 Akim Demaille <akim@epita.fr>
1885
1886 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
1887 lacking `+ 1' to nrules, Bison reported as useless a token if it
1888 was used solely to set the precedence of the last rule...
1889
26b23c1a
AD
18902002-04-07 Akim Demaille <akim@epita.fr>
1891
1892 * data/bison.c++, data/bison.simple: Don't output the current file
1893 name in #line, to avoid useless diffs between two identical
1894 outputs under different names.
1895
18bcecb0
AD
18962002-04-07 Akim Demaille <akim@epita.fr>
1897
1898 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
1899 Normalize loops to using `< nrules + 1', not `<= nrules'.
1900
fa770c86
AD
19012002-04-07 Akim Demaille <akim@epita.fr>
1902
1903 * TODO: Update.
1904
d9b739c3
AD
19052002-04-07 Akim Demaille <akim@epita.fr>
1906
1907 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
1908 bucket.value as bucket.number.
1909
99013900
AD
19102002-04-07 Akim Demaille <akim@epita.fr>
1911
1912 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
1913 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
1914 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
1915 RHS, instead of being an index in RITEMS.
1916
e966383b
PE
19172002-04-04 Paul Eggert <eggert@twinsun.com>
1918
1919 * doc/bison.texinfo: Update copyright date.
1920 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
1921 (Symbols): Warn about running Bison in one character set,
1922 but compiling and/or running in an incompatible one.
1923 Warn about character code 256, too.
1924
19252002-04-03 Paul Eggert <eggert@twinsun.com>
1926
1927 * src/bison.data (YYSTACK_ALLOC): Depend on whether
1928 YYERROR_VERBOSE is nonzero, not whether it is defined.
1929
1930 Merge changes from bison-1_29-branch.
c307773e 1931
8d6c48b9
PE
19322002-03-20 Paul Eggert <eggert@twinsun.com>
1933
1934 Merge fixes from Debian bison_1.34-1.diff.
1935
1936 * configure.in (AC_PREREQ): 2.53.
1937
e53c6322
AD
19382002-03-20 Akim Demaille <akim@epita.fr>
1939
1940 * src/conflicts.c (log_resolution): Argument `resolution' is const.
1941
9ffbeca7
PE
19422002-03-19 Paul Eggert <eggert@twinsun.com>
1943
21db0b2a
PE
1944 * src/bison.simple (YYCOPY): New macro.
1945 (YYSTACK_RELOCATE): Use it.
1946 Remove Type arg; no longer needed. All callers changed.
1947 (yymemcpy): Remove; no longer needed.
1948
9ffbeca7
PE
1949 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
1950 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1951
642cb8f8
AD
19522002-03-19 Akim Demaille <akim@epita.fr>
1953
1954 Test and fix the #line outputs.
1955
1956 * tests/atlocal.at (GCC): New.
1957 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
1958 (Prologue synch line, ,%union synch line, Postprologue synch line)
1959 (Action synch line, Epilogue synch line): New tests.
1960 * src/reader.c (parse_union_decl): Define the muscle stype_line.
1961 * data/bison.simple, data/bison.c++: Use it.
1962
3c31a486
AD
19632002-03-19 Akim Demaille <akim@epita.fr>
1964
1965 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
1966 (Solved SR Conflicts, %expect not enough, %expect right)
1967 (%expect too much): Move to...
1968 * tests/conflicts.at: this new file.
1969
0d8bed56
AD
19702002-03-19 Akim Demaille <akim@epita.fr>
1971
1972 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
1973 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
1974 that we can move to enums for instance.
1975 * src/output.c (token_definitions_output): Output a list of
1976 `token-name, token-number' instead of the #define.
1977 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
1978
9208d17f
AD
19792002-03-14 Akim Demaille <akim@epita.fr>
1980
1981 Use Gettext 0.11.1.
1982
af27eacb
RA
19832002-03-09 Robert Anisko <robert@lrde.epita.fr>
1984
1985 * data/bison.c++: Make the user able to add members to the generated
1986 parser by subclassing.
1987
9101a310
RA
19882002-03-05 Robert Anisko <robert@lrde.epita.fr>
1989
1990 * src/reader.c (read_additionnal_code): `c' should be an integer, not
1991 a character.
1992 Reported by Nicolas Tisserand and Nicolas Burrus.
1993
fff9bf0b
RA
19942002-03-04 Robert Anisko <robert@lrde.epita.fr>
1995
1996 * src/reader.c: Warn about lacking semi-colons, do not complain.
1997
64dba31e
RA
19982002-03-04 Robert Anisko <robert@lrde.epita.fr>
1999
2000 * data/bison.c++: Remove a debug line.
2001
374f5a14
RA
20022002-03-04 Robert Anisko <robert@lrde.epita.fr>
2003
2004 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
2005 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
2006 provide a default implementation.
2007
bfcf1f3a
AD
20082002-03-04 Akim Demaille <akim@epita.fr>
2009
2010 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
2011 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
2012 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
2013 * tests/semantic.at (Parsing Guards): Similarly.
2014 * src/reader.at (readgram): Complain if the last rule is not ended
2015 with a semi-colon.
2016
65ccf9fc
AD
20172002-03-04 Akim Demaille <akim@epita.fr>
2018
2019 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
2020 * src/closure.c: here.
2021 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
2022 RTC.
2023 * src/warshall.h, src/warshall.c: Remove.
2024 * tests/sets.at (Broken Closure): Adjust.
2025
d0039cbc
AD
20262002-03-04 Akim Demaille <akim@epita.fr>
2027
2028 * src/output.c (output_skeleton): tempdir is const.
2029 bytes_read is unused.
2030
345cea78
AD
20312002-03-04 Akim Demaille <akim@epita.fr>
2032
2033 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2034 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
2035 Update.
2036 From Michael Hayes.
2037
564801f7
AD
20382002-03-04 Akim Demaille <akim@epita.fr>
2039
2040 * src/closure.c (closure): `r' is unused.
2041
e5352bc7
AD
20422002-03-04 Akim Demaille <akim@epita.fr>
2043
2044 * tests/sets.at (Broken Closure): Add the ending `;'.
2045 * src/reader.at (readgram): Complain if a rule is not ended with a
2046 semi-colon.
2047
914feea9
AD
20482002-03-04 Akim Demaille <akim@epita.fr>
2049
2050 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
2051 (count_sr_conflicts): Use bitset_count.
2052 * src/reduce.c (inaccessable_symbols): Ditto.
2053 (bits_size): Remove.
2054 * src/warshall.h, src/warshall.c: Convert to bitsetv.
2055
f0250de6
AD
20562002-03-04 Akim Demaille <akim@epita.fr>
2057
2058 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
2059 * src/reduce.c: Remove the `bitset_zero's following the
2060 `bitset_create's, as now it is performed by the latter.
2061
ef017502
AD
20622002-03-04 Akim Demaille <akim@epita.fr>
2063
2064 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
2065 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
2066 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
2067 latest sources from Michael.
2068
76514394
AD
20692002-03-04 Akim Demaille <akim@epita.fr>
2070
2071 * src/output.c (output): Don't free the grammar.
2072 * src/reader.c (grammar_free): New.
2073 * src/main.c (main): Call it and don't free symtab here.
2074
55024580
AD
20752002-03-04 Akim Demaille <akim@epita.fr>
2076
2077 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
2078 before returning.
2079 Reported by Benoit Perrot.
2080
f9abaa2c
AD
20812002-03-04 Akim Demaille <akim@epita.fr>
2082
2083 Use bitset operations when possible, not loops over bits.
2084
2085 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
2086 bitset_or.
2087 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
2088 * src/reduce.c (useless_nonterminals): Formatting changes.
2089 * src/warshall.c (TC): Use bitset_or.
2090
0e721e75
AD
20912002-03-04 Akim Demaille <akim@epita.fr>
2092
2093 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
2094 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
2095 Ditto.
2096
0fb1ffb1
AD
20972002-03-04 Akim Demaille <akim@epita.fr>
2098
2099 * src/lalr.c (F): Now a bitset*.
2100 Adjust all dependencies.
2101
b86796bf
AD
21022002-03-04 Akim Demaille <akim@epita.fr>
2103
2104 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
2105 Adjust all dependencies.
2106
602bbf31
AD
21072002-03-04 Akim Demaille <akim@epita.fr>
2108
2109 * src/L0.c, src/LR0.h (nstates): Be size_t.
2110 Adjust comparisons (signed vs unsigned).
2111 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
2112 bitset*.
2113 Adjust all dependencies.
2114
d8a0245c
AD
21152002-03-04 Akim Demaille <akim@epita.fr>
2116
2117 * src/closure.c (firsts): Now, also a bitset.
2118 Adjust all dependencies.
2119 (varsetsize): Remove, now unused.
2120 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
2121
34ba9743
AD
21222002-03-04 Akim Demaille <akim@epita.fr>
2123
2124 * src/print.c: Convert to use bitset.h, not hand coded iterations
2125 over ints.
2126
ed86e78c
AD
21272002-03-04 Akim Demaille <akim@epita.fr>
2128
2129 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
2130
dfdb1797
AD
21312002-03-04 Akim Demaille <akim@epita.fr>
2132
2133 * src/closure.c (ruleset): Be a bitset.
2134 (rulesetsize): Remove.
2135
7086e707
AD
21362002-03-04 Akim Demaille <akim@epita.fr>
2137
2138 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
2139 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
2140 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
2141 * src/closure.c (fderives): Be an array of bitsets.
2142
98254360
RA
21432002-02-28 Robert Anisko <robert@lrde.epita.fr>
2144
2145 * data/bison.c++: Merge the two generated headers. Insert a copyright
2146 notice in each output file.
2147
a75c057f
AD
21482002-02-28 Akim Demaille <akim@epita.fr>
2149
2150 * data/bison.c++: Copy the prologue of bison.simple to fetch
2151 useful M4 definitions, such as b4_header_guard.
2152
06b00abc
AD
21532002-02-25 Akim Demaille <akim@epita.fr>
2154
2155 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
2156 translator friendly scheme for the bgr
2157 copyright notice.
06b00abc 2158
70e7d534
AD
21592002-02-25 Akim Demaille <akim@epita.fr>
2160
2161 * src/output.c (header_output): Remove, now handled completely via
2162 M4.
2163
abe017f6
AD
21642002-02-25 Akim Demaille <akim@epita.fr>
2165
2166 * m4/m4.m4: New, from CVS Autoconf.
2167 * configure.in: Invoke it.
2168 * src/output.c (output_skeleton): Use its result instead of the
2169 hard coded name.
2170
381fb12e
AD
21712002-02-25 Akim Demaille <akim@epita.fr>
2172
2173 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
2174 Fileutils 4.1.5.
2175 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
2176 * src/output.c (output_skeleton): Use mkstemp to create a real
2177 temporary file.
2178 Move the filling of `skeleton' and its muscle to...
2179 (prepare): here.
2180 (output): Move the definition of the prologue muscle to...
2181 (prepare): here.
2182 * src/system.h (DEFAULT_TMPDIR): New.
2183
6f38107f
PE
21842002-02-14 Paul Eggert <eggert@twinsun.com>
2185
2186 Remove the support for C++ namespace cleanliness; it was
2187 causing more problems than it was curing, since it didn't work
2188 properly on some nonstandard C++ compilers. This can wait
2189 for a proper C++ parser.
2190
2191 * NEWS: Document this.
2192 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
2193 of C++, as it's treated like C now.
2194 * src/bison.simple (YYSTD): Remove.
2195 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
2196 Treat C++ just like Standard C instead of trying to support
2197 namespace cleanliness.
2198
80cce3da
AD
21992002-02-14 Akim Demaille <akim@epita.fr>
2200
2201 * tests/regression.at (else): Adjust to Andreas' change.
2202
842e8679
AD
22032002-02-14 Akim Demaille <akim@epita.fr>
2204
2205 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
2206
4bda3f10
AD
22072002-02-13 Andreas Schwab <schwab@suse.de>
2208
2209 * src/output.c (output_rule_data): Don't output NULL, it might
2210 not be defined yet.
2211
4162fa07 22122002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 2213
4162fa07
RA
2214 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
2215 (Copyright notice): Update.
b418ecd8 2216
bd16a5dc
AD
22172002-02-11 Akim Demaille <akim@epita.fr>
2218
2219 * tests/regression.at (%nonassoc and eof): Don't include
2220 nonportable headers.
2221
8d69a1a3
RA
22222002-02-08 Robert Anisko <robert@lrde.epita.fr>
2223
2224 * data/bison.c++: Correct error recovery. Make the user able to
2225 initialize the starting location.
2226
9b2d0677
AD
22272002-02-07 Akim Demaille <akim@epita.fr>
2228
2229 * tests/input.at: New.
2230
69e2658b
RA
22312002-02-07 Robert Anisko <robert@lrde.epita.fr>
2232
2233 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 2234 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
2235 directives around tables only needed for debugging.
2236
4aacc3a7
RA
22372002-02-07 Robert Anisko <robert@lrde.epita.fr>
2238
2239 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
2240 C++ parsers.
2241 (yy::b4_name::parse): Use print_.
2242
762a801e
RA
22432002-02-07 Robert Anisko <robert@lrde.epita.fr>
2244
2245 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
2246
4bb2bc3f
RA
22472002-02-07 Robert Anisko <robert@lrde.epita.fr>
2248
2249 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
2250 C++ parsers.
2251 (yy::b4_name::parse): Build verbose error messages, and use error_.
2252
6b45a3ca
RA
22532002-02-06 Robert Anisko <robert@lrde.epita.fr>
2254
2255 * data/bison.c++: Fix m4 quoting in comments.
2256
50997c6e
RA
22572002-02-06 Robert Anisko <robert@lrde.epita.fr>
2258
2259 * data/bison.c++: Adjust the parser code. Fix some muscles that were
2260 not expanded by m4.
2261
3f3eed27
AD
22622002-02-05 Akim Demaille <akim@epita.fr>
2263
2264 * data/bison.c++: Adjust to the M4 back end.
2265 More is certainly needed.
2266
be2a1a68
AD
22672002-02-05 Akim Demaille <akim@epita.fr>
2268
2269 Give a try to M4 as a back end.
2270
2271 * lib/readpipe.c: New, from wdiff.
2272 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
2273 BISON_HAIRY.
2274 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
2275 specific values. Now it is m4 that performs the lookup.
2276 * src/parse-skel.y: Remove.
2277 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
2278 * src/output.c (actions_output, guards_output)
2279 (token_definitions_output): No longer keeps track of the output
2280 line number, hence remove the second argument.
2281 (guards_output): Check against the guard member of a rule, not the
2282 action member.
2283 Adjust callers.
2284 (output_skeleton): Don't look for the skeleton location, let m4 do
2285 that.
2286 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
2287 file will be used.
2288 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
2289 (prepare): Given that for the time being changesyntax is not
2290 usable in M4, rename the muscles using `-' to `_'.
2291 Define `defines_flag', `output_parser_name' and `output_header_name'.
2292 * src/output.h (actions_output, guards_output)
2293 (token_definitions_output): Adjust prototypes.
2294 * src/scan-skel.l: Instead of scanning the skeletons, it now
2295 processes the output of m4: `__oline__' and `#output'.
2296 * data/bison.simple: Adjust to be used by M4(sugar).
2297 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
2298 to date.
2299 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
2300 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
2301 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
2302 shamelessly stolen from CVS Autoconf.
2303
beda758b
AD
23042002-02-05 Akim Demaille <akim@epita.fr>
2305
2306 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
2307 * configure.in: Check for the declarations of free and malloc.
2308 * src/muscle_tab.c: Adjust.
2309
5ece6d43
AD
23102002-02-05 Akim Demaille <akim@epita.fr>
2311
2312 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
2313 which have no values.
2314
5bb18f9a
AD
23152002-02-05 Akim Demaille <akim@epita.fr>
2316
2317 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
2318 * data/: here.
2319
894dd62e
PE
23202002-01-29 Paul Eggert <eggert@twinsun.com>
2321
2322 * src/bison.simple (YYSIZE_T): Do not define merely because
2323 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
2324 On some platforms, <alloca.h> does not declare YYSTD (size_t).
2325
82841af7
AD
23262002-01-27 Akim Demaille <akim@epita.fr>
2327
2328 Fix `%nonassoc and eof'.
2329
2330 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
2331 which were not properly copied! Replace
2332 memcpy (res->errs, src->errs, src->nerrs);
2333 with
2334 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
2335 !!!
2336 * tests/regression.at (%nonassoc and eof): Adjust to newest
2337 Autotest: `.' is not in the PATH.
2338
318b76e9
AD
23392002-01-27 Akim Demaille <akim@epita.fr>
2340
2341 * tests/sets.at (AT_EXTRACT_SETS): New.
2342 (Nullable): Use it.
2343 (Firsts): New.
2344
30d2f3d5
AD
23452002-01-26 Akim Demaille <akim@epita.fr>
2346
2347 * tests/actions.at, tests/calc.at, tests/headers.at,
2348 * tests/torture.at: Adjust to the newest Autotest which no longer
2349 forces `.' in the PATH.
2350
30f8c395
AD
23512002-01-25 Akim Demaille <akim@epita.fr>
2352
2353 * tests/regression.at (%nonassoc and eof): New.
2354 Suggested by Robert Anisko.
2355
29ae55f1
AD
23562002-01-24 Akim Demaille <akim@epita.fr>
2357
2358 Bison dumps core when trying to complain about broken input files.
2359 Reported by Cris van Pelt.
2360
2361 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
2362 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
2363 into...
2364 (Invalid inputs): Strengthen: exercise parse_percent_token.
2365
2b548aa6
RA
23662002-01-24 Robert Anisko <robert.anisko@epita.fr>
2367
2368 * src/Makefile.am: Add bison.c++.
2369 * src/bison.c++: New skeleton.
2370
bb0146c2
AD
23712002-01-21 Paolo Bonzini <bonzini@gnu.org>
2372
2373 * po/it.po: New.
2374
bec30531
AD
23752002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
2376
2377 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
2378
fc6edc45
MA
23792002-01-20 Marc Autret <marc@gnu.org>
2380
2381 * src/files.c (compute_output_file_names): Fix
2382
5e5d5415
MA
23832002-01-20 Marc Autret <marc@gnu.org>
2384
2385 * tests/output.at: New test.
2386 * src/files.c (compute_base_names): Don't map extensions when
2387 the YACC flag is set, use defaults.
2388 Reported by Evgeny Stambulchik.
2389
44ea3fbd
MA
23902002-01-20 Marc Autret <marc@gnu.org>
2391
bb0146c2 2392 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
2393 compilers as well (i.e. the vendor C compiler).
2394 Suggested by Albert Chin-A-Young.
2395
338963d1
TVH
23962002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
2397
2398 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
2399 canonical definition.
2400 * src/system.h: Use the canonical definition for PARAMS (avoids
2401 a conflict with the macro from lib/hash.h).
2402
c57b2479
AD
24032002-01-11 Akim Demaille <akim@epita.fr>
2404
2405 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 2406 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 2407
b85810ae
AD
24082002-01-09 Akim Demaille <akim@epita.fr>
2409
2410 * src/files.c, src/files.h (output_infix): New.
2411 (tab_extension): Remove.
2412 (compute_base_names): Compute the former, drop the latter.
2413 * src/output.c (prepare): Insert the muscles `output-infix', and
2414 `output-suffix'.
2415 * src/parse-skel.y (string, string.1): New.
2416 (section.header): Use it.
2417 (section.yacc): Remove.
2418 (prefix): Remove too.
2419 * src/scan-skel.l: Adjust.
2420 * src/bison.simple, src/bison.hairy: Adjust.
2421
cae60122
AD
24222002-01-09 Akim Demaille <akim@epita.fr>
2423
2424 * configure.in (WERROR_CFLAGS): Compute it.
2425 * src/Makefile.am (CFLAGS): Pass it.
2426 * tests/atlocal.in (CFLAGS): Idem.
2427 * src/files.c: Fix a few warnings.
2428 (get_extension_index): Remove, unused.
2429
ae404801
AD
24302002-01-08 Akim Demaille <akim@epita.fr>
2431
2432 * src/getargs.c (AS_FILE_NAME): New.
2433 (getargs): Use it to convert DOSish file names.
2434 * src/files.c (base_name): Rename as full_base_name to avoid
2435 clashes with `base_name ()'.
2436 (filename_split): New.
2437 (compute_base_names): N-th rewrite, using filename_split.
2438
22312b71
AD
24392002-01-08 Akim Demaille <akim@epita.fr>
2440
2441 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
2442 New, stolen from the Fileutils 4.1.
2443 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
2444 * configure.in: Check for the presence of memrchr, and of its
2445 prototype.
2446
a67cef01
TVH
24472002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
2448
2449 * lib/hash.h (__P): Added definition for this macro.
2450 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
2451 BUILT_SOURCES, to ensure they are generated first.
2452 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
2453 %error-verbose to allow bootstrapping with bison 1.30x.
2454
2b25d624
AD
24552002-01-06 Akim Demaille <akim@epita.fr>
2456
2457 * src/reader.c (parse_braces): Don't fetch the next char, the
2458 convention is to fetch on entry.
2459 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
2460 'switch' without a following semicolon.
2461 * tests/regression.at (braces parsing): New.
2462
3460813b
AD
24632002-01-06 Akim Demaille <akim@epita.fr>
2464
2465 Bison is dead wrong in its RR conflict reports.
2466
2467 * tests/torture.at (GNU Cim Grammar): New.
2468 * src/conflicts.c (count_rr_conflicts): Fix.
2469
73784c64
AD
24702002-01-06 Akim Demaille <akim@epita.fr>
2471
2472 Creating package.m4 from configure.ac causes too many problems.
2473
2474 * tests/Makefile.am (package.m4): Create it by hand,
2475 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
2476
25d81090
AD
24772002-01-06 Akim Demaille <akim@epita.fr>
2478
2479 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
2480 skeleton.h.
2481
a9b8959e
PE
24822002-01-04 Paul Eggert <eggert@twinsun.com>
2483
2484 * doc/bison.texinfo (Debugging):
2485 Remove YYSTDERR; it's no longer defined or used.
2486 Also, s/cstdio.h/cstdio/.
2487
25d81090
AD
24882002-01-03 Akim Demaille <akim@epita.fr>
2489
2490 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
2491
1109455c
AD
24922002-01-03 Akim Demaille <akim@epita.fr>
2493
2494 * src/parse-skel.y (process_skeleton): Don't bind the parser's
2495 tracing code to --trace, wait for a better --trace option, with
2496 args.
2497
7ea5e977
AD
24982002-01-03 Akim Demaille <akim@epita.fr>
2499
2500 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
2501 The ISO C++ standard is extremely clear about it: stderr is
2502 considered a macro, not a regular symbol (see table 94 `Header
2503 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
2504 Therefore std:: does not apply to it. It still does with fprintf.
2505 Also, s/cstdio.h/cstdio/.
2506
fab5b110
AD
25072002-01-03 Akim Demaille <akim@epita.fr>
2508
2509 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
2510 for non system headers.
2511
aed7fd9b
AD
25122002-01-02 Akim Demaille <akim@epita.fr>
2513
2514 Equip the skeleton chain with location tracking, runtime trace,
2515 pure parser and scanner.
2516
2517 * src/parse-skel.y: Request a pure parser, locations, and prefix
2518 renaming.
2519 (%union): Having several members with the same type does not help
2520 type mismatches, simplify.
2521 (YYPRINT, yyprint): New.
2522 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
2523 (skel_error): this.
2524 Handle locations.
2525 * src/scan-skel.l: Adjust to these changes.
2526 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
2527 (LOCATION_PRINT, skel_control_t): New.
2528
24fad99e
AD
25292001-12-30 Akim Demaille <akim@epita.fr>
2530
2531 * src/parse-skel.y: Get rid of the shift/reduce conflict:
2532 replace `gb' with BLANKS.
2533 * src/scan-skel.l: Adjust.
2534
a4b36db4
AD
25352001-12-30 Akim Demaille <akim@epita.fr>
2536
2537 * src/system.h: We don't need nor want bcopy.
2538 Throw away MS-DOS crap: we don't need getpid.
2539 * configure.in: We don't need strndup. It was even causing
2540 problems: because Flex includes the headers *before* us,
2541 _GNU_SOURCE is not defined by config.h, and therefore strndup was
2542 not visible.
2543 * lib/xstrndup.c: New.
2544 * src/scan-skel.l: Use it.
2545 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
2546 * src/parse-skel.y: Use %directives instead of #defines.
2547
1239777d
AD
25482001-12-30 Akim Demaille <akim@epita.fr>
2549
2550 * src/skeleton.h: New.
2551 * src/output.c (output_parser, output_master_parser): Remove, dead
2552 code.
2553 * src/output.h (get_lines_number, actions_output, guards_output)
2554 (token_definitions_output): Prototype them.
2555 * src/parse-skel.y: Add the license notice.
2556 Include output.h and skeleton.h.
2557 (process_skeleton): Returns void, and takes a single parameter.
2558 * src/scan-skel.l: Add the license notice.
2559 Include skeleton.h.
2560 Don't use %option yylineno: it seems that then Flex imagines
2561 REJECT has been used, and therefore it won't reallocate its
2562 buffers (which makes no other sense to me than a bug). It results
2563 in warnings for `unused: yy_flex_realloc'.
2564
9b3add5b
RA
25652001-12-30 Robert Anisko <robert.anisko@epita.fr>
2566
2567 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2568 (MUSCLE_INSERT_PREFIX): ...to there.
2569 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
2570 (MUSCLE_INSERT_PREFIX): Move from here...
2571
2572 * src/bison.hairy: Add a section directive. Put braces around muscle
2573 names. This parser skeleton is still broken, but Bison should not
2574 choke on a bad muscle 'syntax'.
2575 * src/bison.simple: Add a section directive. Put braces around muscle
2576 names.
2577
2578 * src/files.h (strsuffix, stringappend): Add declarations.
2579 (tab_extension): Add declaration.
2580 (short_base_name): Add declaration.
2581
2582 * src/files.c (strsuffix, stringappend): No longer static. These
2583 functions are used in the skeleton parser.
2584 (tab_extension): New.
2585 (compute_base_names): Use the computations done in this function
fab5b110 2586 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
2587 names.
2588 (short_base_name): No longer static.
2589
2590 * src/output.c (output_skeleton): New.
2591 (output): Disable call to output_master_parser, and give a try to
2592 a new skeleton handling system.
2593 (guards_output, actions_output): No longer static.
2594 (token_definitions_output, get_lines_number): No longer static.
2595
2596 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
2597
fab5b110 2598 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
2599 parse-skel.y.
2600
2601 * src/parse-skel.y: New file.
2602 * src/scan-skel.l: New file.
2603
b5b61c61
AD
26042001-12-29 Akim Demaille <akim@epita.fr>
2605
2606 %name-prefix is broken.
2607
2608 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
2609 Adjust all dependencies.
2610 * tests/headers.at (export YYLTYPE): Strengthen this test: use
2611 %name-prefix.
2612
2613 Renaming yylval but not yylloc is not consistent. Now we do.
2614
2615 * src/bison.simple: Prefix yylloc if used.
2616 * doc/bison.texinfo (Decl Summary): Document that.
2617
8c9a50be
AD
26182001-12-29 Akim Demaille <akim@epita.fr>
2619
2620 * doc/bison.texinfo: Promote `%long-directive' over
2621 `%long_directive'.
2622 Remove all references to fixed-output-files, yacc is enough.
2623
d99361e6
AD
26242001-12-29 Akim Demaille <akim@epita.fr>
2625
2626 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
2627 user prologue. These are defaults.
2628 * tests/actions.at (Mid-rule actions): Make sure the user can
2629 define YYDEBUG and YYERROR_VERBOSE.
2630
b9cecb91
AD
26312001-12-29 Akim Demaille <akim@epita.fr>
2632
2633 * src/output.c (header_output): Don't forget to export YYLTYPE and
2634 yylloc.
2635 * tests/headers.at (export YYLTYPE): New, make sure it does.
2636 * tests/regression.at (%union and --defines, Invalid CPP headers):
2637 Move to...
2638 * tests/headers.at: here.
2639
aea13e97
AD
26402001-12-29 Akim Demaille <akim@epita.fr>
2641
2642 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
2643
931394cb
AD
26442001-12-29 Akim Demaille <akim@epita.fr>
2645
2646 * tests/actions.at (Mid-rule actions): Output on a single line
2647 instead of several.
2648
704a47c4
AD
26492001-12-29 Akim Demaille <akim@epita.fr>
2650
2651 * doc/bison.texinfo: Formatting changes.
2652
091e20bb
AD
26532001-12-29 Akim Demaille <akim@epita.fr>
2654
2655 Don't store the token defs in a muscle, just be ready to output it
2656 on command. Now possible via `symbols'. Fixes a memory leak.
2657
2658 * src/output.c (token_definitions_output): New.
2659 (output_parser, header_output): Use it.
2660 * src/reader.c (symbols_save): Remove.
2661
cce71710
AD
26622001-12-29 Akim Demaille <akim@epita.fr>
2663
2664 * src/bison.simple: Do not provide a default for YYSTYPE and
2665 YYLTYPE before the user's prologue. Otherwise it's hardly... a
2666 default.
2667
82c035a8
AD
26682001-12-29 Akim Demaille <akim@epita.fr>
2669
2670 Mid-rule actions are simply... ignored!
2671
2672 * src/reader.c (readgram): Be sure to attach mid-rule actions to
2673 the empty-rule associated to the dummy symbol, not to the host
2674 rule.
2675 * tests/actions.at (Mid-rule actions): New.
2676
8419d367
AD
26772001-12-29 Akim Demaille <akim@epita.fr>
2678
2679 Memory leak.
2680
2681 * src/reader.c (reader): Free grammar.
2682
375d5806
AD
26832001-12-29 Akim Demaille <akim@epita.fr>
2684
2685 Memory leak.
2686
2687 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
2688 since it allocates it for each state, although only one is needed.
2689 (allocate_storage): Do it here.
2690
f51cb8ff
AD
26912001-12-29 Akim Demaille <akim@epita.fr>
2692
2693 * src/options.h, src/options.c (create_long_option_table): Rename
2694 as...
2695 (long_option_table_new): this, with a clearer prototype.
2696 (percent_table): Remove, unused,
2697 * src/getargs.c (getargs): Adjust.
2698
29e88316
AD
26992001-12-29 Akim Demaille <akim@epita.fr>
2700
2701 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
2702 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
2703 as states.
2704
b9f71f19
AD
27052001-12-29 Akim Demaille <akim@epita.fr>
2706
2707 * src/lalr.c (build_relations): Rename `states' as `states1'.
2708 Sorry, I don't understand exactly what it is, no better name...
2709
1a2b5d37
AD
27102001-12-29 Akim Demaille <akim@epita.fr>
2711
2712 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
2713 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
2714 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
2715 as rules.
2716
1cca533e
AD
27172001-12-29 Akim Demaille <akim@epita.fr>
2718
2719 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
2720 ago.
2721
c03ae966
AD
27222001-12-29 Akim Demaille <akim@epita.fr>
2723
2724 * src/reader.c, src/reader.h (user_toknums): Remove.
2725 Adjust all users to use symbols[i]->user_token_number.
2726
5a670b1e
AD
27272001-12-29 Akim Demaille <akim@epita.fr>
2728
2729 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
2730 Adjust all users to use symbols[i]->prec or ->assoc.
2731
ad949da9
AD
27322001-12-29 Akim Demaille <akim@epita.fr>
2733
2734 * src/reader.c, src/reader.h (tags): Remove.
2735 Adjust all users to use symbols[i]->tag.
2736
0e78e603
AD
27372001-12-29 Akim Demaille <akim@epita.fr>
2738
2739 * src/gram.h, src/gram.c (symbols): New, similar to state_table
2740 and rule_table.
2741 * src/reader.c (packsymbols): Fill this table.
2742 Drop sprec.
2743 * src/conflicts.c (resolve_sr_conflict): Adjust.
2744 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
2745 single table.
2746 Use symbols[i]->tag instead of tags[i].
2747
213e640e
AD
27482001-12-29 Akim Demaille <akim@epita.fr>
2749
2750 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
2751 In addition, put a comment in there, to replace...
2752 * tests/regression.at (%union and C comments): Remove.
2753
e7b8bef1
AD
27542001-12-29 Akim Demaille <akim@epita.fr>
2755
2756 * tests/regression.at (Web2c Actions): Blindly move the actual
2757 output as expected output. The contents *seem* right to me, but I
2758 can't pretend reading perfectly parser tables... Nonetheless, all
2759 the other tests pass correctly, the table look OK, even though the
2760 presence of `$axiom' is to be noted: AFAICS it is useless (but
2761 harmless).
2762
b68e7744
AD
27632001-12-29 Akim Demaille <akim@epita.fr>
2764
2765 * src/reader.c (readgram): Don't add the rule 0 if there were no
2766 rules read. In other words, add it _after_ having performed
2767 grammar sanity checks.
2768 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
2769
78d5bae9
AD
27702001-12-29 Akim Demaille <akim@epita.fr>
2771
2772 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
2773 visible, and some states have now a different number.
2774
ff442794
AD
27752001-12-29 Akim Demaille <akim@epita.fr>
2776
2777 * src/reader.c (readgram): Bind the initial rule's lineno to that
2778 of the first rule.
2779 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
2780 (Solved SR Conflicts): Adjust rule 0's line number.
2781
610ab194
AD
27822001-12-29 Akim Demaille <akim@epita.fr>
2783
2784 Fix the `GAWK Grammar' failure.
2785
2786 * src/LR0.c (final_state): Initialize to -1 so that we do compute
2787 the reductions of the first state which was mistakenly confused
2788 with the final state because precisely final_state was initialized
2789 to 0.
2790 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
2791 now noticed by Bison.
2792 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
2793 have a reduction on $default.
2794
29d29c8f
AD
27952001-12-29 Akim Demaille <akim@epita.fr>
2796
2797 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
2798 rule line numbers.
2799 * src/closure.c (print_closure): Likewise.
2800 * src/derives.c (print_derives): Likewise.
2801 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
2802 now.
2803
7c6b64d0
AD
28042001-12-29 Akim Demaille <akim@epita.fr>
2805
2806 * src/lalr.c (lookaheads_print): New.
2807 (lalr): Call it when --trace-flag.
2808 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
2809 are dumped.
2810
3d4daee3
AD
28112001-12-29 Akim Demaille <akim@epita.fr>
2812
2813 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
2814 when walking through ritem, even via rule->rhs.
2815 * src/reduce.c (dump_grammar, useful_production, reduce_output)
2816 (useful_production, useless_nonterminals): Likewise.
2817 (reduce_grammar_tables): Likewise, plus update nritems.
2818 * src/nullable.c (set_nullable): Likewise.
2819 * src/lalr.c (build_relations): Likewise.
2820 * tests/sets.at (Nullable): Adjust.
2821 Fortunately, now, the $axiom is no longer nullable.
2822
9e7f6bbd
AD
28232001-12-29 Akim Demaille <akim@epita.fr>
2824
2825 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
2826 the 0-sentinel.
2827 * src/gram.c (ritem_longest_rhs): Likewise.
2828 * src/reduce.c (nonterminals_reduce): Likewise.
2829 * src/print_graph.c (print_graph): Likewise.
2830 * src/output.c (output_rule_data): Likewise.
2831 * src/nullable.c (set_nullable): Likewise.
2832
255ef638
AD
28332001-12-29 Akim Demaille <akim@epita.fr>
2834
2835 * src/output.c: Comment changes.
2836
0d8a7363
AD
28372001-12-27 Paul Eggert <eggert@twinsun.com>
2838
2839 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
2840 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
2841 Sparc, as they were causing more porting problems than the
2842 (minor) performance improvement was worth.
2843
2844 Also, catch up with 1.31's YYSTD.
2845
3db472b9
AD
28462001-12-27 Akim Demaille <akim@epita.fr>
2847
2848 * src/output.c (output_gram): Rely on nritems, not the
2849 0-sentinel. See below.
2850 Use -1 as separator, not 0.
2851 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
2852 Rely on -1 as separator in yyrhs, instead of 0.
2853 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
2854 twice `Now at end of input', therefore there are two lines less to
2855 expect.
2856
b365aa05
AD
28572001-12-27 Akim Demaille <akim@epita.fr>
2858
2859 * tests/regression.at (Unresolved SR Conflicts):
2860 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
2861 below.
2862
30171f79
AD
28632001-12-27 Akim Demaille <akim@epita.fr>
2864
2865 * src/LR0.c (new_state): Recognize the final state by the fact it
2866 is reached by eoftoken.
2867 (insert_start_shifting_state, insert_eof_shifting_state)
2868 (insert_accepting_state, augment_automaton): Remove, since now
2869 these states are automatically computed from the initial state.
2870 (generate_states): Adjust.
2871 * src/print.c: When reporting a rule number to the user, substract
2872 1, so that the axiom rule is rule 0, and the first user rule is 1.
2873 * src/reduce.c: Likewise.
2874 * src/print_graph.c (print_core): For the time being, just as for
2875 the report, depend upon --trace-flags to dump the full set of
2876 items.
2877 * src/reader.c (readgram): Once the grammar read, insert the rule
2878 0: `$axiom: START-SYMBOL $'.
2879 * tests/set.at: Adjust: rule 0 is now displayed, and since the
2880 number of the states has changed (the final state is no longer
2881 necessarily the last), catch up.
2882
75142d45
AD
28832001-12-27 Akim Demaille <akim@epita.fr>
2884
2885 Try to make the use of the eoftoken valid. Given that its value
2886 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
2887 is used instead of > 0 where appropriate, (ii), depend upon nritems
2888 instead of the 0-sentinel.
2889
2890 * src/gram.h, src/gram.c (nritems): New.
2891 Expected to be duplication of nitems, but for the time being...
2892 * src/reader.c (packgram): Assert nritems and nitems are equal.
2893 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
2894 * src/closure.c (print_closure, print_fderives): Likewise.
2895 * src/gram.c (ritem_print): Likewise.
2896 * src/print.c (print_core, print_grammar): Likewise.
2897 * src/print_graph.c: Likewise.
2898
b7c49edf
AD
28992001-12-27 Akim Demaille <akim@epita.fr>
2900
2901 * src/main.c (main): If there are complains after grammar
2902 reductions, then output the report anyway if requested, then die.
2903 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
2904 * src/reader.c (eoftoken): New.
2905 (parse_token_decl): If the token being defined has value `0', it
2906 is the eoftoken.
2907 (packsymbols): No longer hack `tags' to insert `$' by hand.
2908 Be sure to preserve the value of the eoftoken.
2909 (reader): Make sure eoftoken is defined.
2910 Initialize nsyms to 0: now eoftoken is created just like the others.
2911 * src/print.c (print_grammar): Don't special case the eof token.
2912 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
2913 lie anyway, albeit pleasant.
2914 * tests/calc.at: Exercise error messages with eoftoken.
2915 Change the grammar so that empty input is invalid.
2916 Adjust expectations.
2917 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
2918
ec2da99f
AD
29192001-12-27 Akim Demaille <akim@epita.fr>
2920
2921 * configure.in: Check the protos of strchr ans strspn.
2922 Replace strchr if needed.
2923 * src/system.h: Provide the protos of strchr, strspn and memchr if
2924 missing.
2925 * lib/strchr.c: New.
2926 * src/reader.c (symbols_save): Use strchr.
2927
8adfa272
AD
29282001-12-27 Akim Demaille <akim@epita.fr>
2929
2930 * src/print.c, src/print_graph.c (escape): New.
2931 Use it to quote the TAGS outputs.
2932 * src/print_graph.c (print_state): Now errors are in red, and
2933 reductions in green.
2934 Prefer high to wide: output the state number on a line of its own.
2935
80dac38c
AD
29362001-12-27 Akim Demaille <akim@epita.fr>
2937
2938 * src/state.h, src/state.c (reductions_new): New.
2939 * src/LR0.c (set_state_table): Let all the states have a
2940 `reductions', even if reduced to 0.
2941 (save_reductions): Adjust.
2942 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
2943 * src/print.c (print_reductions, print_actions): Adjust.
2944 * src/output.c (action_row): Adjust.
2945
2cec70b9
AD
29462001-12-27 Akim Demaille <akim@epita.fr>
2947
2948 * src/state.h, src/state.c (errs_new, errs_dup): New.
2949 * src/LR0.c (set_state_table): Let all the states have an errs,
2950 even if reduced to 0.
2951 * src/print.c (print_errs, print_reductions): Adjust.
2952 * src/output.c (output_actions, action_row): Adjust.
2953 * src/conflicts.c (resolve_sr_conflict): Adjust.
2954
13ca549a
AD
29552001-12-27 Akim Demaille <akim@epita.fr>
2956
2957 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
2958
5092aba5
AD
29592001-12-27 Akim Demaille <akim@epita.fr>
2960
2961 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
2962 * src/print.c: here.
2963 (lookaheadset, shiftset): New, used as additional storage by
2964 print_reductions.
2965 (print_results): Adjust.
2966 (print_shifts, print_gotos, print_errs): New, extracted from...
2967 (print_actions): here.
2968 * src/print_graph.c (print_actions): Remove dead code.
2969
11e2beca
AD
29702001-12-27 Akim Demaille <akim@epita.fr>
2971
2972 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
2973 `$n' and `@n'.
2974
dac3c910
AD
29752001-12-27 Akim Demaille <akim@epita.fr>
2976
2977 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
2978 (build_relations): Adjust.
2979
d0b0fefa
AD
29802001-12-27 Akim Demaille <akim@epita.fr>
2981
2982 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
2983 duplication.
2984
adc8c848
AD
29852001-12-27 Akim Demaille <akim@epita.fr>
2986
2987 * src/reader.c (packgram): Catch nitems overflows.
2988
14d293ac
AD
29892001-12-27 Akim Demaille <akim@epita.fr>
2990
2991 * src/files.c, src/files.h (guard_obstack): Remove.
2992 * src/output.c (output): Adjust.
2993 * src/reader.c (parse_braces): New, factoring...
2994 (copy_action, copy_guard): these two which are renamed as...
2995 (parse_action, parse_guard): these.
2996 As a voluntary consequence, using braces around guards is now
2997 mandatory.
2998
f499b062
AD
29992001-12-27 Akim Demaille <akim@epita.fr>
3000
3001 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
3002 * src/reader.c (symbol_list): `guard' and `guard_line' are new
3003 members.
3004 (symbol_list_new): Adjust.
3005 (copy_action): action_line is the first line, not the last.
3006 (copy_guard): Just as for actions, store the `action' only, not
3007 the switch/case/break flesh.
3008 Don't parse the user action that might follow the guard, let...
3009 (readgram): do it, i.e., now, there can be an action after a
3010 guard.
3011 In other words the guard is just explicitly optional.
3012 (packgram): Adjust.
3013 * src/output.c (guards_output): New.
3014 (output_parser): Call it when needed.
3015 (output): Also free the guard and attrs obstacks.
3016 * src/files.c, src/files.h (obstack_save): Remove.
3017 (output_files): Remove.
3018 As a result, if one needs the former `.act' file, using an
3019 appropriate skeleton which requires actions and guards is now
3020 required.
3021 * src/main.c (main): Adjust.
3022 * tests/semantic.at: New.
3023 * tests/regression.at: Use `input.y' as input file name.
3024 Avoid 8+3 problems by requiring input.c when the test needs the
3025 parser.
3026
d945f5cd
AD
30272001-12-27 Akim Demaille <akim@epita.fr>
3028
3029 * src/reader.c (symbol_list_new): Be sure to initialize all the
3030 fields.
3031
d200e455
AD
30322001-12-27 Akim Demaille <akim@epita.fr>
3033
3034 All the hacks using a final pseudo state are now useless.
3035
3036 * src/LR0.c (set_state_table): state_table holds exactly nstates.
3037 * src/lalr.c (nLA): New.
3038 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
3039 instead of lookaheadsp from the pseudo state (nstate + 1).
3040
f9507c28
AD
30412001-12-27 Akim Demaille <akim@epita.fr>
3042
3043 * src/output.c (action_row, token_actions): Use a state_t instead
3044 of a integer, and nlookaheads instead of the following state's
3045 lookaheadsp.
3046
065fbd27
AD
30472001-12-27 Akim Demaille <akim@epita.fr>
3048
3049 * src/conflicts.c (log_resolution, flush_shift)
3050 (resolve_sr_conflict, set_conflicts, solve_conflicts)
3051 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
3052 (conflicts_print, print_reductions): Use a state_t instead of an
3053 integer when referring to a state.
3054 As much as possible, depend upon nlookaheads, instead of the
3055 `lookaheadsp' member of the following state (since lookaheads of
3056 successive states are successive, the difference between state n + 1
3057 and n served as the number of lookaheads for state n).
3058 * src/lalr.c (add_lookback_edge): Likewise.
3059 * src/print.c (print_core, print_actions, print_state)
3060 (print_results): Likewise.
3061 * src/print_graph.c (print_core, print_actions, print_state)
3062 (print_graph): Likewise.
3063 * src/conflicts.h: Adjust.
3064
1b177bd7
AD
30652001-12-27 Akim Demaille <akim@epita.fr>
3066
3067 * src/bison.hairy: Formatting/comment changes.
3068 ANSIfy.
3069 Remove `register' indications.
3070 Add plenty of `static'.
3071
7742ddeb
AD
30722001-12-27 Akim Demaille <akim@epita.fr>
3073
3074 * src/output.c (prepare): Drop the muscle `ntbase' which
3075 duplicates ntokens.
3076 * src/bison.simple: Formatting/comment changes.
3077 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
3078 is an undocumented synonym.
3079
1fa14068
AD
30802001-12-22 Akim Demaille <akim@epita.fr>
3081
3082 * src/output.c (output_table_data): Change the prototype to use
3083 `int' for array ranges: some invocations do pass an int, not a
3084 short.
3085 Reported by Wayne Green.
3086
b9752825
AD
30872001-12-22 Akim Demaille <akim@epita.fr>
3088
3089 Some actions of web2c.y are improperly triggered.
3090 Reported by Mike Castle.
3091
3092 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
3093 * tests/regression.at (Web2c): Rename as...
3094 (Web2c Report): this.
3095 (Web2c Actions): New.
3096
776209d6
AD
30972001-12-22 Akim Demaille <akim@epita.fr>
3098
3099 Reductions in web2c.y are improperly reported.
3100 Reported by Mike Castle.
3101
3102 * src/conflicts.c (print_reductions): Fix.
3103 * tests/regression.at (Web2c): New.
3104
275fc3ad
AD
31052001-12-18 Akim Demaille <akim@epita.fr>
3106
3107 Some host fail on `assert (!"foo")', which expands to
3108 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
3109 Reported by Nelson Beebee.
3110
3111 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
3112 `#define it_succeeded 0' and `assert (it_succeeded)'.
3113
897668ee
MA
31142001-12-17 Marc Autret <autret_m@epita.fr>
3115
3116 * src/bison.simple: Don't hard code the skeleton line and filename.
3117 * src/output.c (output_parser): Rename 'line' as 'output_line'.
3118 New line counter 'skeleton_line' (skeleton-line muscle).
3119
ab3399e0
PE
31202001-12-17 Paul Eggert <eggert@twinsun.com>
3121
3122 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
3123 YYDEBUG must be defined to a nonzero value.
3124
3125 * src/bison.simple (yytname): Do not assume that the user defines
3126 YYDEBUG to a properly parenthesized expression.
3127
3877f72b
AD
31282001-12-17 Akim Demaille <akim@epita.fr>
3129
3130 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
3131 nlookaheads is a new member.
3132 Adjust all users.
3133 * src/lalr.h (nlookaheads): Remove this orphan declaration.
3134 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
3135 state.
776209d6 3136
331dbc1b
AD
31372001-12-17 Akim Demaille <akim@epita.fr>
3138
3139 * src/files.h, src/files.c (open_files, close_files): Remove.
3140 * src/main.c (main): Don't open/close files, nor invoke lex_free,
3141 let...
3142 * src/reader.c (reader): Do it.
776209d6 3143
be750e4c
AD
31442001-12-17 Akim Demaille <akim@epita.fr>
3145
3146 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 3147
709ae8c6
AD
31482001-12-17 Akim Demaille <akim@epita.fr>
3149
3150 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
3151 (flush_reduce): New.
3152 (resolve_sr_conflict): Adjust.
776209d6 3153
f87685c3
AD
31542001-12-17 Akim Demaille <akim@epita.fr>
3155
3156 * src/output.c (output_obstack): Be static and rename as...
3157 (format_obstack): this, to avoid any confusion with files.c's
3158 output_obstack.
3159 * src/reader.h (muscle_obstack): Move to...
3160 * src/output.h: here, since it's defined in output.c.
3161
837491d8
AD
31622001-12-17 Akim Demaille <akim@epita.fr>
3163
3164 * src/output.c (action_row, save_column, default_goto)
3165 (sort_actions, matching_state, pack_vector): Better variable
3166 locality.
3167
796d61fb
AD
31682001-12-17 Akim Demaille <akim@epita.fr>
3169
3170 * src/output.c: Various formatting changes.
776209d6 3171
64d15509
AD
31722001-12-17 Akim Demaille <akim@epita.fr>
3173
3174 * src/files.c (output_files): Free the output_obstack.
3175 * src/main.c (main): Call print and print_graph conditionally.
3176 * src/print.c (print): Work unconditionally.
3177 * src/print_graph.c (print_graph): Work unconditionally.
3178 * src/conflicts.c (log_resolution): Output only if verbose_flag.
3179
fbc8ecb7
MA
31802001-12-16 Marc Autret <autret_m@epita.fr>
3181
3182 * src/output.c (actions_output): Fix. When we use %no-lines,
3183 there is one less line per action.
3184
f0440388
MA
31852001-12-16 Marc Autret <autret_m@epita.fr>
3186
3187 * src/bison.simple: Remove a useless #line directive.
3188 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
3189 * src/output.c (get_lines_number): New.
776209d6 3190 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
3191 output muscles.
3192 Fix line numbering.
3193 (actions_output): Computes the number of lines taken by actions.
3194 (output_master_parser): Insert new skeleton which is the name of
3195 the output parser file name.
3196
a79986b8
MA
31972001-12-15 Marc Autret <autret_m@epita.fr>
3198
3199 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
3200
4ec8e00f
MA
32012001-12-15 Marc Autret <autret_m@epita.fr>
3202
3203 * src/output.c (output_gram): Keep track of the hairy one.
3204
1a4648ff
AD
32052001-12-15 Akim Demaille <akim@epita.fr>
3206
3207 Make `make distcheck' work.
3208
3209 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
3210 system.h which uses libgettext.h.
3211
9c2c67e6
AD
32122001-12-15 Akim Demaille <akim@epita.fr>
3213
3214 * src/nullable.c (set_nullable): Useless rules must be skipped,
3215 otherwise, since we range over their symbols, we might look at a
3216 nonterminal which no longer ``exists'', i.e., it is not counted in
3217 `nvars', hence we overflow our arrays.
3218
93ede233
AD
32192001-12-15 Akim Demaille <akim@epita.fr>
3220
3221 The header can also be produced directly, without any obstack!
3222 Yahoo!
3223
3224 * src/files.c, src/files.h (defines_obstack): Remove.
3225 (compute_header_macro): Global.
3226 (defines_obstack_save): Remove.
3227 * src/reader.c (parse_union_decl): No longer output to
3228 defines_obstack: its content can be found in the `stype' muscle
3229 anyway.
3230 (output_token_translations): Merge into...
3231 (symbols_output): this.
3232 Rename as...
3233 (symbols_save): this.
3234 (reader): Adjust.
3235 * src/output.c (header_output): New.
3236 (output): Call it.
3237
2666f928
AD
32382001-12-15 Akim Demaille <akim@epita.fr>
3239
3240 * src/reader.c (parse_union_decl): Instead of handling two obstack
3241 simultaneously, use one to define the `stype' muscle, and use the
3242 value of the latter to fill defines_obstack.
3243 (copy_comment): Remove.
3244 (copy_comment2): Work for a single obstack.
3245 Rename as...
3246 (copy_comment): this.
3247
428046f8
AD
32482001-12-15 Akim Demaille <akim@epita.fr>
3249
3250 * src/lex.c, src/lex.h (xgetc): No longer static.
3251 * src/reader.c (parse_union_decl): Revamp.
3252
ea52d706
AD
32532001-12-15 Akim Demaille <akim@epita.fr>
3254
3255 Still making progress in separating Bison into (i) input, (ii)
3256 process, (iii) output: now we can directly output the parser file
3257 without using table_obstack at all.
3258
3259 * src/files.c, src/files.h (table_obstack): Bye bye.
3260 (parser_file_name): New.
3261 * src/files.c (compute_output_file_names): Compute it.
3262 * src/output.c (actions_output, output_parser)
3263 (output_master_parser): To a file instead of an obstack.
3264
3f96f4dc
AD
32652001-12-15 Akim Demaille <akim@epita.fr>
3266
3267 Attach actions to rules, instead of pre-outputting them to
3268 actions_obstack.
3269
3270 * src/gram.h (rule_t): action and action_line are new members.
3271 * src/reader.c (symbol_list): Likewise.
3272 (copy_action): Save the actions within the rule.
3273 (packgram): Save them in rule_table.
3274 * src/output.c (actions_output): New.
3275 (output_parser): Use it on `%%actions'.
3276 (output_rule_data): Don't free rule_table.
3277 (output): Do it.
3278 (prepare): Don't save the `action' muscle.
3279 * src/bison.simple: s/%%action/%%actions/.
3280
51576fb3
AD
32812001-12-15 Akim Demaille <akim@epita.fr>
3282
3283 * src/reader.c (copy_action): When --yacc, don't append a `;'
3284 to the user action: let it fail if lacking.
dee049eb 3285 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 3286
2648a72d
AD
32872001-12-14 Akim Demaille <akim@epita.fr>
3288
3289 * src/lex.c (literalchar): Simply return the char you decoded, non
3290 longer mess around with obstacks and int pointers.
3291 Adjust all callers.
3292
92790e5b
AD
32932001-12-14 Akim Demaille <akim@epita.fr>
3294
3295 * src/lex.c (literalchar): Don't escape the special characters,
3296 just decode them, and keep them as char (before, eol was output as
3297 the 2 char string `\n' etc.).
3298 * src/output.c (output_rule_data): Use quotearg to output the
3299 token strings.
3300
927c1557
PE
33012001-12-13 Paul Eggert <eggert@twinsun.com>
3302
3303 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
3304 Do not infringe on the global user namespace when using C++.
3305 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
3306 All uses of `fprintf' and `stderr' changed.
3307
3308 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
3309
ed8e1f68
AD
33102001-12-13 Akim Demaille <akim@epita.fr>
3311
3312 The computation of nullable is broken: it doesn't handle empty
3313 RHS's properly.
3314
3315 * tests/torture.at (GNU AWK Grammar): New.
3316 * tests/sets.at (Nullable): New.
3317 * src/nullable.c (set_nullable): Instead of blindly looping over
3318 `ritems', loop over the rules, and then over their rhs's.
3319
3320 Work around Autotest bugs.
3321
3322 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
3323 frame, because Autotest understand lines starting with a `+' as
3324 traces from the shell. Then, they are not processed properly.
3325 Admittedly an Autotest bug, but we don't have time to wait for
3326 Autotest to catch up.
3327 * tests/regression.at (Broken Closure): Adjust to the new table
3328 frames.
3329 Move to...
3330 * tests/sets.at: here.
3331
cb581495
AD
33322001-12-13 Akim Demaille <akim@epita.fr>
3333
3334 * src/closure.c (closure): Use nrules instead of playing tricks
3335 with BITS_PER_WORD.
3336
2e729273
AD
33372001-12-13 Akim Demaille <akim@epita.fr>
3338
3339 * src/print.c (print_actions): Output the handling of `$' as the
3340 traces do: shifting the token EOF. Before EOF was treated as a
3341 nonterminal.
3342 * tests/regression.at: Adjust some tests.
3343 * src/print_graph.c (print_core): Complete the set of items via
3344 closure. The next-to-final and final states are still unsatisfying,
3345 but that's to be addressed elsewhere.
3346 No longer output the rule numbers, but do output the state number.
3347 A single loop for the shifts + gotos is enough, but picked a
3348 distinct color for each.
3349 (print_graph): Initialize and finalize closure.
3350
107f7dfb
AD
33512001-12-13 Akim Demaille <akim@epita.fr>
3352
3353 * src/reader.c (readgram): Remove dead code, an strip useless
3354 braces.
3355 (get_type): Remove, unused.
3356
9b53a24f
AD
33572001-12-12 Akim Demaille <akim@epita.fr>
3358
3359 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
3360 on that of lib/error.c.
3361
dbfb6dcd
AD
33622001-12-12 Akim Demaille <akim@epita.fr>
3363
3364 Some hosts don't like `/' in includes.
3365
3366 * src/system.h: Include libgettext.h without qualifying the path.
3367 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
3368 $(top_srcdir).
3369
c25fb648
MA
33702001-12-11 Marc Autret <autret_m@epita.fr>
3371
3372 * src/output.c (output_parser): Remove useless muscle.
3373
710ddc4f
MA
33742001-12-11 Marc Autret <autret_m@epita.fr>
3375
3376 * src/bison.simple: Remove #line just before %%epilogue. It
3377 is now handled in ...
3378 * src/reader.c (read_additionnal_code): Add the output of a
3379 #line for the epilogue.
3380
e83d80b8
MA
33812001-12-10 Marc Autret <autret_m@epita.fr>
3382
927c1557 3383 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
3384 replace precedent remove.
3385 * src/bison.simple: Remove #line before %%prologue because
3386 %%input-line is wrong at this time.
3387
971d5158
MA
33882001-12-10 Marc Autret <autret_m@epita.fr>
3389
3390 * src/reader.c (symbols_output): Clean up.
927c1557 3391 * src/output.c (output_gram, output): Clean up.
971d5158 3392
5edafffd
AD
33932001-12-10 Akim Demaille <akim@epita.fr>
3394
3395 * src/lalr.c (initialize_lookaheads): New. Extracted from...
3396 * src/LR0.c (set_state_table): here.
3397 * src/lalr.c (lalr): Call it.
3398
0279f8e9
AD
33992001-12-10 Akim Demaille <akim@epita.fr>
3400
3401 * src/state.h (shifts): Remove the `number' member: shifts are
3402 attached to state, hence no longer need to be labelled with a
3403 state number.
3404
190c4f5f
AD
34052001-12-10 Akim Demaille <akim@epita.fr>
3406
3407 Now that states have a complete set of members, the linked list of
3408 shifts is useless: just fill directly the state's shifts member.
3409
3410 * src/state.h (shifts): Remove the `next' member.
3411 * src/LR0.c (first_state, last_state): Remove.
3412 Adjust the callers.
3413 (augment_automaton): Don't look for the shifts that must be added
3414 a shift on EOF: it is those of the state we looked for! But now,
3415 since shifts are attached, it is no longer needed to looking
3416 merely by its id: its number.
3417
2a73b93d
AD
34182001-12-10 Akim Demaille <akim@epita.fr>
3419
3420 * src/LR0.c (augment_automaton): Better variable locality.
3421 Remove an impossible branch: if there is a state corresponding to
3422 the start symbol being shifted, then there is shift for the start
3423 symbol from the initial state.
3424
74392f6a
AD
34252001-12-10 Akim Demaille <akim@epita.fr>
3426
3427 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
3428 only when appropriate: when insert_start_shifting_state' is not
3429 invoked.
3430 * tests/regression.at (Rule Line Numbers): Adjust.
3431
37c82725
AD
34322001-12-10 Akim Demaille <akim@epita.fr>
3433
3434 * src/LR0.c (augment_automaton): Now that all states have shifts,
3435 merge the two cases addition shifts to the initial state.
3436
6a164e0c
AD
34372001-12-10 Akim Demaille <akim@epita.fr>
3438
3439 * src/lalr.c (set_state_table): Move to...
3440 * src/LR0.c: here.
3441 * src/lalr.c (lalr): Don't call it...
3442 * src/LR0.c (generate_states): do it.
3443 * src/LR0.h (first_state): Remove, only the table is used.
3444
7215de24
AD
34452001-12-10 Akim Demaille <akim@epita.fr>
3446
3447 * src/LR0.h (first_shift, first_reduction): Remove.
3448 * src/lalr.c: Don't use first_shift: find shifts through the
3449 states.
3450
80e25d4d
AD
34512001-12-10 Akim Demaille <akim@epita.fr>
3452
3453 * src/LR0.c: Attach shifts to states as soon as they are
3454 computed.
3455 * src/lalr.c (set_state_table): Instead of assigning shifts to
3456 state, just assert that the mapping was properly done.
3457
0ab3728b
AD
34582001-12-10 Akim Demaille <akim@epita.fr>
3459
3460 * src/LR0.c (insert_start_shift): Rename as...
3461 (insert_start_shifting_state): this.
3462 (insert_eof_shifting_state, insert_accepting_state): New.
3463 (augment_automaton): Adjust.
3464 Better locality of the variables.
3465 When looking if the start_symbol is shifted from the initial
3466 state, using `while (... symbol != start_symbol ...)' sounds
3467 better than `while (... symbol < start_symbol ...)': If fail
3468 to see how the order between symbols could be relevant!
3469
78af9bbc
AD
34702001-12-10 Akim Demaille <akim@epita.fr>
3471
3472 * src/getargs.h: Don't declare `spec_name_prefix' and
3473 `spec_file_prefix', declared by src/files.h.
3474 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
3475 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
3476 * src/output.c (prepare): Adjust.
3477 * src/reader.c (symbols_output): Likewise.
3478 * src/vmsgetargs.c: Vaguely adjust, but who cares?
3479
bdef2a41
AD
34802001-12-10 Akim Demaille <akim@epita.fr>
3481
3482 * src/muscle_tab.c (muscle_init): NULL is a better default than
3483 `"0"'.
3484
3735969c
AD
34852001-12-10 Akim Demaille <akim@epita.fr>
3486
3487 * src/reader.c (reader): Calling symbols_output once is enough.
3488
49701457
AD
34892001-12-10 Akim Demaille <akim@epita.fr>
3490
3491 Now that states have a complete set of members, the linked list of
3492 reductions is useless: just fill directly the state's reductions
3493 member.
3494
3495 * src/state.h (struct reductions): Remove member `number' and
3496 `next'.
3497 * src/LR0.c (first_reduction, last_reduction): Remove.
3498 (save_reductions): Don't link the new reductions, store them in
3499 this_state.
3500 * src/lalr.c (set_state_table): No need to attach reductions to
3501 states, it's already done.
3502 * src/output.c (output_actions): No longer free the shifts, then
3503 the reductions, then the states: free all the states and their
3504 members.
3505
0edad749
AD
35062001-12-10 Akim Demaille <akim@epita.fr>
3507
3508 * src/options.c (OPTN, DRTV, BOTH): New.
3509 (option_table): Use them.
3510
0edad749
AD
3511 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
3512 the job of system.h.
3513 * src/options.c: Don't include stdio.h and xalloc.h for the same
3514 reasons.
3515
5449dd0f
AD
35162001-12-10 Akim Demaille <akim@epita.fr>
3517
3518 * src/output.c (output, prepare): Make sure the values of the
3519 muscles `action' and `prologue' are 0-terminated.
3520
a870c567
AD
35212001-12-10 Akim Demaille <akim@epita.fr>
3522
3523 Clean up GCC warnings.
3524
3525 * src/reader.c (copy_action): `buf' is not used.
3526 (parse_skel_decl): Be static.
3527 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
3528 * src/options.h (create_long_option_table): Have a real prototype.
3529 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
3530 (hash_delete_at): Return const void *.
3531 Adjust casts to preserve the const.
3532
80df8768
AD
35332001-12-10 Akim Demaille <akim@epita.fr>
3534
3535 * configure.in: Require 2.52g.
3536 M4 is not needed, but AUTOM4TE is.
3537 * m4/m4.m4: Remove.
3538 * tests/Makefile.am: Adjust.
3539
f693ad14
AD
35402001-12-10 Akim Demaille <akim@epita.fr>
3541
3542 One structure for states is enough, even though theoretically
3543 there are LR(0) states and LALR(1) states.
3544
3545 * src/lalr.h (state_t): Remove.
3546 (state_table): Be state_t **, not state_t *.
3547 * src/state.h (core, CORE_ALLOC): Rename as...
3548 (state_t, STATE_ALLOC): this.
3549 Add the LALR(1) members: shifts, reductions, errs.
3550 * src/LR0.c (state_table): Rename as...
3551 (state_hash): this, to avoid name clashes with the global
3552 `state_table'.
3553 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
3554 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
3555
74ffbcb6
AD
35562001-12-10 Akim Demaille <akim@epita.fr>
3557
3558 Bison dumps core on bash.y.
3559 Reported by Pascal Bart.
3560
3561 * src/warshall.c (bitmatrix_print): New.
3562 (TC): Use it.
3563 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
3564 j must be the outer loop.
3565 * tests/regression.at (Broken Closure): New.
3566
07708e19
AD
35672001-12-05 Akim Demaille <akim@epita.fr>
3568
3569 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
3570 its argument.
3571