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