]> git.saurik.com Git - bison.git/blame - ChangeLog
Initial revision.
[bison.git] / ChangeLog
CommitLineData
d0f3fe23
PE
12002-12-12 Paul Eggert <eggert@twinsun.com>
2
3 Remove unportable casts and storage allocation tricks.
4 While we're at it, remove almost all casts, since they
5 usually aren't needed and are a sign of trouble.
6
7 * configure.ac (AC_CHECK_TYPES): Check for uintptr_t.
8
9 * src/derives.c (derives_compute): Do not subtract NTOKENS from
10 the pointer DSET returned by malloc; this isn't portable.
11 Instead, always use DSET[i - NTOKENS] rather than DSET[i].
12 Similarly for DERIVES.
13 * src/lalr.c (set_goto_map): Likewise, for GOTO_MAP and TEMP_MAP.
14 * src/nullable.c (nullable_compute): Likewise, for RSETS and NULLABLE.
15 * src/reduce.c (reduce_grammar_tables): Likewise, for nontermmap
16
17 * src/derives.c (derives_compute): Do not bother invoking
18 int_of_rule_number, since rule numbers are integers.
19
20 * src/files.c (concat2, tr, compute_base_name): Use xmalloc (N)
21 rather than XMALLOC (char, N).
22
23 * src/files.c (filename_split): Rewrite to avoid cast.
24
25 * src/gram.h (symbol_number_as_item_number,
26 item_number_as_symbol_number, rule_number_as_item_number,
27 item_number_as_rule_number):
28 Now inline functions rather than macros, to avoid casts.
29 * src/state.h (state_number_as_int): Likewise.
30 * src/tables.c (state_number_to_vector_number,
31 symbol_number_to_vector_number): Likewise.
32
33 * src/gram.h (int_of_rule_number): Remove; no longer used.
34
35 * src/lalr.c (add_lookback_edge): Use malloc rather than calloc,
36 since the resulting storage is always stored into.
37
38 * src/main.c (alloca) [C_ALLOCA]: Add decl here, the only place
39 where it's needed.
40
41 * src/muscle_tab.c (muscle_m4_output):
42 Now inline. Return bool, not int.
43 * src/state.c (state_compare): Likewise.
44 * src/symtab.c (symbol_check_defined,
45 symbol_check_alias_consistency, symbol_pack, symbol_translation,
46 hash_compare_symbol, hash_symbol):
47 Likewise.
48 * src/uniqstr.c (uniqstr_print): Likewise.
49 * src/muscle_tab.c (muscle_m4_output_processor):
50 New function, to avoid casts.
51 * src/state.c (state_comparator, stage_hasher): Likewise.
52 * src/symtab.c (symbol_check_defined_processor,
53 symbol_check_alias_consistency_processor, symbol_pack_processor,
54 symbol_translation_processor, hash_symbol_comparator,
55 hash_symbol_hasher): Likewise.
56 * src/uniqstr.c (uniqstr_print_processor): Likewise.
57 * src/muscle_tab.c (muscles_m4_output):
58 Use new functions instead of casting old functions unportably.
59 * src/state.c (state_hash_new): Likewise.
60 * src/symtab.c (symbols_new, symbols_do, symbols_check_defined,
61 symbols_token_translations_init):
62 Likewise.
63 * src/uniqstr.c (uniqstrs_new, hash_initialize, uniqstrs_do): Likewise.
64
65 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): Use long local
66 var instead of casting to long, to avoid casts.
67 (prepare_states): Use MALLOC rather than alloca, so that we don't
68 have to worry about alloca.
69 * src/state.c (state_hash_lookup): Likewise.
70
71 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>"'"): Use unsigned char
72 local var instead of casting to unsigned char, to avoid casts.
73
74 * src/state.c (TRANSITIONS_ALLOC, ERRS_ALLOC, REDUCTIONS_ALLOC,
75 STATE_ALLOC): Remove.
76 (transitions_new, errs_new, reductions_new, state_new): Use malloc
77 rather than calloc, and use offsetof to avoid allocating slightly
78 too much storage.
79 (state_new): Initialize all members.
80
81 * src/state.c (state_hash): Use unsigned accumulator, not signed.
82
83 * src/symtab.c (symbol_free): Remove; unused.
84 (symbol_get): Remove cast in lhs of assignment.
85 (symbols_do): Now static. Accept generic arguments, not
86 hashing-related ones.
87
88 * src/symtab.h: (NUMBER_UNDEFINED): Remove unnecessary cast.
89 (symbol_processor): Remove.
90 (symbols_do): Remove decl; now static.
91
92 * src/system.h (alloca): Remove; decl no longer needed.
93 (<stddef.h>): Include, for offsetof.
94 (<inttypes.>, <stdint.h>): Include if available.
95 (uintptr_t): New type, if system lacks it.
96 (CALLOC, MALLOC, REALLOC): New macros.
97 All uses of XCALLOC, XMALLOC, and XREALLOC changed to use these
98 new macros.
99
100 * src/tables.c (table_size): Now int, to pacify GCC.
101 (table_grow, table_ninf_remap): Use signed table size.
102 (save_row): Don't bother initializing locals when not needed.
103 (default_goto, goto_actions, pack_vector): Remove unnecessary casts.
104 * src/uniqstr.c (hash_compare_uniqstr): Likewise.
105
106 * src/vcg.h: Correct misspellings.
107
108 * src/vcg_defaults.h (G_CMAX): Now INT_MAX.
109
110
111 * src/getargs.c (getargs): Don't assume EOF == -1.
112
26b4a969
PE
1132002-12-09 Paul Eggert <eggert@twinsun.com>
114
115 Change identifier spellings to avoid collisions with names
116 that are reserved by POSIX.
117
118 Don't use names ending in _t, since POSIX reserves them.
119 For consistency, remove _e and _s endings -- they're weren't
120 needed to remove ambiguity. All uses changed.
121 * src/uniqstr.h (uniqstr): Renamed from uniqstr_t, which in
122 turn was just renamed from struniq_t.
123 * src/uniqstr.c (uniqstr_processor): Renamed from struniq_processor,
124 which in turn was just renamed from struniq_processor_t.
125 (hash_compare_uniqstr): Renamed from hash_compare_struniq, which
126 in turn was renamed from hash_compare_struniq_t.
127 * src/LR0.c (struct state_list): Renamed from struct state_list_s.
128 (state_list): Renamed from state_list_t.
129 * src/assoc.h (assoc): Renamed from assoc_t.
130 * src/conflicts.c (enum conflict_resolution): Renamed from
131 enum conflict_resolution_e.
132 * src/derives.c (struct rule_list): Renamed from struct rule_list_s.
133 (rule_list): Renamed from rule_list_t.
134 * src/getargs.h (enum trace): Renamed from enum trace_e.
135 (enum report): Renamed from enum report_e.
136 * src/gram.h (item_number): Renamed from item_number_t.
137 (rule_number): Renamed from rule_number_t.
138 (struct rule_s): Remove the "rule_s" part; not used.
139 (rule): Renamed from rule_t.
140 (rule_filter): Renamed from rule_filter_t.
141 * src/lalr.c (struct goto_list): Renamed from struct goto_list_s.
142 (goto_list): Renamed from goto_list_t.
143 * src/lalr.h (goto_number): Renamed from goto_number_t.
144 * src/location.h (location): Renamed from location_t.
145 * src/muscle_tab.c (muscle_entry): Renamed from muscle_entry_t,
146 and moved here from:
147 * src/muscle_tab.h (muscle_entry_t): here.
148 * src/nullable.c (struct rule_list): Renamed from struct rule_list_s.
149 (rule_list): Renamed from rule_list_t.
150 * src/print_graph.c (static_graph): Renamed from graph.
151 * src/reader.h (braced_code): Renamed from braced_code_t.
152 Remove brace_code_e tag.
153 * src/relation.h (relation_node): Renamed from relation_node_t.
154 (relation_nodes): Renamed from relation_nodes_t.
155 (relation): Renamed from relation_t.
156 * src/state.h (state_number): Renamed from state_number_t.
157 (struct state): Renamed from struct state_s.
158 (state): Renamed from state_t.
159 (transitions): Renamed from transitions_t. Unused (and
160 misspelled) transtion_s tag removed.
161 (errs): Renamed from errs_t. Unused errs_s tag removed.
162 (reductions): Renamed from reductions_t. Unused tag
163 reductions_s removed.
164 * src/symlist.h (symbol_list): Renamed from symbol_list_t.
165 (struct symbol_list): Renamed from struct symbol_list_s.
166 * src/symtab.h (symbol_number): Renamed from symbol_number_t.
167 (struct symbol): Renamed from struct symbol_s.
168 (symbol): Renamed from symbol_t.
169 * src/tables.c (vector_number): Renamed from vector_number_t.
170 (action_number): Renamed from action_t.
171 * src/tables.h (base_number): Renamed from base_t.
172 * src/vcg.h (enum color): Renamed from enum color_e.
173 (enum textmode): Renamed from enum textmode_e.
174 (enum shape): Renamed from enum shape_e.
175 (struct colorentry): Renamed from struct colorentry_s.
176 (struct classname): Renamed from struct classname_s.
177 (struct infoname): Renamed from struct infoname_s.
178 (enum layoutalgorithm): Renamed from enum layoutalgorithm_e.
179 (enum decision): Renamed from enum decision_e.
180 (enum orientation): Renamed from enum orientation_e.
181 (enum alignment): Renamed from enum alignment_e.
182 (enum arrow_mode): Renamed from enum arrow_mode_e.
183 (enum crossing_type): Renamed from enum crossing_type_e.
184 (enum view): Renamed from enum view_e.
185 (struct node): Renamed from struct node_s.
186 (node): Renamed from node_t.
187 (enum linestyle): Renamed from enum linestyle_e.
188 (enum arrowstyle): Renamed from enum arrowstyle_e.
189 (struct edge): Renamed from struct edge.
190 (edge): Renamed from edge_t.
191 (struct graph): Renamed from struct graph_s.
192 (graph): Renamed from graph_t.
193 * tests/calc.at (_AT_DATA_CALC_Y, Simple LALR Calculator):
194 Rename value_t -> value.
195 * tests/input.at (Torturing the Scanner): Rename value_t -> value,
196 value_t_as_yystype -> value_as_yystype.
197
198 Don't include <errno.h> in the mainstream code, since it
199 reserves E[A-Z0-9]* and we want to use symbols like 'EQUALS'.
200 * lib/get-errno.c, lib/get-errno.h: New files.
201 * lib/Makefile.am (libbison_a_SOURCES): Add get-errno.h,
202 get-errno.c.
203 * src/files.c (xfopen, xfclose): Use get_errno instead of errno.
204 * src/output.c (output_skeleton): Likewise.
205 * src/scan-gram.l (<INITIAL>{int}): Use set_errno and get_errno
206 instead of errno.
207 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>\\x[0-9abcdefABCDEF]+):
208 Likewise.
209 (handle_action_dollar, handle_action_at): Likewise.
210 * src/system.h: Do not include <errno.h>.
211 (TAB_EXT): Renamed from EXT_TAB.
212 (OUTPUT_EXT): Renamed from EXT_OUTPUT.
213
214 Avoid str[a-z]*, since <string.h> reserves that name space.
215 Change all instances of "struniq" in names to "uniqstr", and
216 likewise for "STRUNIQ" and "UNIQSTR".
217 * src/uniqstr.c: Renamed from src/struniq.c.
218 * src/uniqstr.h: Renamed from src/struniq.h.
219 * src/Makefile.am (bison_SOURCES): Adjust to these renamings.
220 * src/files.c (strsuffix): Remove; unused.
221 (concat2): Renamed from stringappend. Now static.
222 * src/files.h (strsuffix, stringappend): Remove; unused.
223 * src/parse-gram.y (<chars>): Renamed from <string>.
224 (<uniqstr>): Renamed from <struniq>.
225 * src/scan-gram.l (obstack_for_string): Renamed from string_obstack.
226 * src/vcg.h (struct node_s.expand): Renamed from struct node_s.stretch.
227 (struct graph_s.expand): Renamed from struct graph_s.stretch.
228 * src/vcg_defaults.h (G_EXPAND): Renamed from G_STRETCH.
229 (G_LONG_STRAIGHT_PHASE): Renamed from G_STRAIGHT_PHASE.
230 (N_EXPAND): Renamed from N_STRETCH.
231
232 Avoid *_MAX and *_MIN, since <limits.h> reserves that name space.
233 * data/yacc.c (YYSTACK_GAP_MAXIMUM): Renamed from YYSTACK_GAP_MAX.
234 * src/gram.h (ITEM_NUMBER_MAX, ITEM_NUMBER_MIN, RULE_NUMBER_MAX):
235 Remove; unused.
236 * src/lalr.h (GOTO_NUMBER_MAXIMUM): Renamed from GOTO_NUMBER_MAX.
237 * src/state.h (STATE_NUMBER_MAXIMUM): Renamed from STATE_NUMBER_MAX.
238 * src/symtab.h (SYMBOL_NUMBER_MAXIMUM): Renamed from SYMBOL_NUMBER_MAX.
239 * src/tables.c (VECTOR_NUMBER_MAX, VECTOR_NUMBER_MIN): Remove; unused.
240 (BASE_MAXIMUM): Renamed from BASE_MAX.
241 (BASE_MINIMUM): Renamed from BASE_MIN.
242 (ACTION_MAX): Remove; unused.
243 (ACTION_NUMBER_MINIMUM): Renamed from ACTION_MIN.
244 Unnecessary casts removed from above defines.
245
246
247 Fix misspelling in names.
248 * src/vcg.h (enum_alignment_e): Renamed from enum_alignement_e.
249 * src/vcg_defaults.h (G_NODE_ALIGNMENT): Renamed from
250 G_NODE_ALIGNEMENT.
251
252
253 * lib/timevar.c (timevar_report): Renamed from time_report,
254 for consistency with other names.
255 * lib/timevar.h (timevar_report): New decl.
256 * src/system.h (time_report): Remove; decl is now in lib/timevar.h.
257
258
259 Sort include-file uses.
260
261 Reorder all include files under src to be in the order "system.h".
262 then the ../lib include files in angle brackets (alphabetized),
263 then the . include files in double-quotes (alphabetized). Fix
264 dependency breakages encountered in this process, as follows:
265 * src/closure.h, src/derives.h, src/state.h: Include "gram.h".
266 * src/complain.c: Don't include stdlib.h, string.h _LIBC stuff.
267 * src/state.h: Include "symtab.h".
268
996b1c7e
PE
2692002-12-08 Paul Eggert <eggert@twinsun.com>
270
271 * data/glr.c, data/lalr1.cc, data/yacc.c: Do not use __file__,
272 since this causes problems when __file__ contains character
273 sequences like "@" that are treated specially by src/scan-skel.l.
274 Instead, just use the file's basename. This fixes the bug
275 reported by Martin Mokrejs in
26b4a969 276 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001945.html>.
996b1c7e 277
e19c4e5d
PE
2782002-12-06 Paul Eggert <eggert@twinsun.com>
279
280 Add support for rules that do not have trailing semicolons, as
281 POSIX requires. Improve the quality of locations in Bison
282 diagnostics.
26b4a969 283
e19c4e5d
PE
284 * src/location.c: Include <quotearg.h>.
285 (empty_location): Now const.
286 (location_print): New function. Follow the recommendation of the
287 GNU Coding Standards for locations that span file boundaries.
288 * src/location.h: Do not include <quotearg.h>; no longer needed.
289 (boundary): New type.
290 (location_t): Use it. This allows locations to span file boundaries.
291 All member uses changed: file -> start.file or end.file (as needed),
292 first_line -> start.line, first_column -> start.column,
293 last_line -> end.line, last_column -> end.column.
294 (equal_boundaries): New function.
295 (LOCATION_RESET, LOCATION_STEP): Remove.
296 (LOCATION_PRINT): Remove. All callers changed to use location_print.
297 (empty_location): Now const.
298 (location_print): New decl.
299 * src/parse-gram.y (lloc_default): New function, which handles
300 empty locations more accurately.
301 (YYLLOC_DEFAULT): Use it.
302 (%token COLON): Remove.
303 (%token ID_COLON): New token.
26b4a969 304 (rules): Use it.
e19c4e5d
PE
305 (declarations, rules): Remove trailing semicolon.
306 (declaration, rules_or_grammar_declaration):
307 Allow empty (";") declaration.
308 (symbol_def): Remove empty actions; no longer needed.
309 (rules_or_grammar_declaration): Remove trailing semicolon.
310 (semi_colon.opt): Remove.
311 * src/reader.h: Include location.h.
312 (scanner_cursor): New decl.
313 * src/reduce.c (nonterminals_reduce): Use warn_at rather than
314 rolling our own.
315 * src/scan-gram.l (YY_USER_INIT): Initialize scanner_cursor instead
316 of *loc.
317 (STEP): Remove. No longer needed, now that adjust_location does
318 the work. All uses removed.
319 (scanner_cursor): New var.
320 (adjust_location): Renamed from extend_location. It now sets
321 *loc and adjusts the scanner cursor. All uses changed.
322 Don't bother testing for CR.
323 (handle_syncline): Remove location arg; now updates scanner cursor.
324 All callers changed.
325 (unexpected_end_of_file): Now accepts start boundary of token or
326 comment, not location. All callers changed. Update scanner cursor,
327 not the location.
328 (SC_AFTER_IDENTIFIER): New state.
329 (context_state): Renamed from c_context. All uses changed.
330 (id_loc, code_start, token_start): New local vars.
331 (<INITIAL,SC_AFTER_IDENTIFIER>): New initial context. Move all
332 processing of Yacc white space and equivalents here.
333 (<INITIAL>{id}): Save id_loc. Begin state SC_AFTER_IDENTIFIER
334 instead of returning ID immediately, since we need to search for
335 a subsequent colon.
336 (<INITIAL>"'", "\""): Save token_start.
337 (<INITIAL>"%{", "{", "%%"): Save code_start.
338 (<SC_AFTER_IDENTIFIER>): New state, looking for a colon.
339 (<SC_YACC_COMMENT>, <SC_COMMENT>, <SC_LINE_COMMENT>):
340 BEGIN context_state at end, not INITIAL.
341 (<SC_ESCAPED_STRING>"\"", <SC_ESCAPED_CHARACTER>"'",
342 <SC_BRACED_CODE>"}", <SC_PROLOGUE>"%}", <SC_EPILOGUE><<EOF>>):
343 Return correct token start.
344 (<SC_BRACED_CODE,SC_PROLOGUE,SC_EPILOGUE>): Save start boundary when
345 the start of a character, string or multiline comment is found.
346 * tests/conflicts.at (S/R in initial, Defaulted Conflicted
347 Reduction): Adjust reported locations to match the more-precise
348 results now expected.
349 * tests/input.at (Invalid $n, Invalid @n, Type Clashes): Likewise.
350 * tests/reduce.at (Useless Rules, Reduced Automaton,
351 Underivable Rules): Likewise.
352 * tests/regression.at (Invalid inputs): No longer `expecting ";"
353 or "|"' now that so many other tokens are allowed by the new grammar.
354
355 * src/complain.h (current_file): Remove duplicate decl;
356 current_file is now owned by files.h.
357 * src/complain.c, src/scan-gram.l: Include files.h.
358
3592002-12-06 Paul Eggert <eggert@twinsun.com>
26b4a969 360
e19c4e5d
PE
361 * data/glr.c (yy_reduce_print): Don't assume that yyrline[yyrule]
362 promotes to int; it might be unsigned int.
363 * data/yacc.c (yy_reduce_print): Likewise.
364
365 * doc/bison.texinfo (Table of Symbols): YYERROR_VERBOSE should
366 be #defined in the prologue, not in the Bison declarations.
367 This fixes Debian Bug 102878, reported by Shaul Karl.
26b4a969 368
b64755e3
PE
3692002-12-02 Paul Eggert <eggert@twinsun.com>
370
371 * configure.ac (AC_REPLACE_FUNCS): Add strtoul.
372 * lib/strtoul.c: New file, from gnulib.
373 This fixes a porting bug reported by Peter Klein in
374 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001944.html>.
375
6e746484
PE
3762002-11-30 Paul Eggert <eggert@twinsun.com>
377
b64755e3
PE
378 * src/scan-gram.l (no_cr_read, extend_location): Move to epilogue,
379 and put only a forward declaration in the prologue. This is for
380 consistency with the other scanner helper functions.
381
6ba55592
PE
382 Type clashes now generate warnings, not errors, since it
383 appears that POSIX may allow some grammars with type clashes.
384 * src/reader.c (grammar_current_rule_check): Warn about
385 type clashes instead of complaining.
386 * tests/input.at (Type Clashes): Expect warnings, not complaints.
387
6e746484
PE
388 Add Yacc library, since POSIX requires it.
389 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
390 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
391 * lib/main.c, lib/yyerror.c: New files.
392
393 gram_error can be static; it need not be extern.
394 * src/reader.h (gram_error): Remove decl.
395 * src/parse-gram.y (gram_error): Now static. Add static decl.
396 (print_token_value): Omit parameter names from forward decl,
397 for consistency.
398
88510f9c
PE
3992002-11-29 Paul Eggert <eggert@twinsun.com>
400
6e746484
PE
401 * doc/bison.texinfo: Emphasize that yylex and yyerror must
402 be declared before being used. E.g., one should typically
403 declare them in the prologue. Use GNU coding style in examples.
404 Put "const" consistently after the type it modifies. Mention
405 that C99 supports "inline". Mention that yyerror traditionally
406 returns "int".
407
88510f9c
PE
408 %parse-param and %lex-param now take just one argument, the
409 declaration; the argument name is deduced from the declaration.
410
411 * doc/bison.texinfo (Parser Function, Pure Calling, Error
412 Reporting, Table of Symbols): Document this.
413 * src/parse-gram.y (add_param): New function.
414 (COMMA): Remove.
415 (declaration): Implement new rule for %parse-param and %lex-param.
416 * src/scan-gram.l: "," now elicits a warning, rather than being
417 a token; this is more compatible with byacc.
418 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
419
bb92250c
PE
4202002-11-27 Paul Eggert <eggert@twinsun.com>
421
422 Rename identifiers to avoid real and potential collisions.
423
424 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
425 to avoid collision with lex macro described by Bruce Lilly in
426 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
427 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
428 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
429 * src/parse-gram.y (print_token_value): Renamed from yyprint.
430 All uses changed.
431 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
432 The name "yycontrol" violates the name space rules, and this stuff
433 wasn't being used anyway.
434 (input): Remove action; this stuff wasn't being used.
435 (gram_error): Rename local variable yylloc -> loc.
436 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
437 (YY_DECL): Don't use "yy" at start of local variables.
438 All uses changed, e.g., yylloc -> loc.
439 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
440 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
441 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
442 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
443
444 * src/parse-gram.y (gram_error): loc is now const *.
445 * src/reader.h (gram_error): Likewise.
446
3af4feb2
PE
4472002-11-24 Paul Eggert <eggert@twinsun.com>
448
449 Version 1.75c.
450
451 * tests/actions.at (Actions after errors): Use an output format
452 more similar to that of the Printers and Destructors test.
453 Test the position of the ';' token too.
454 (Printers and Destructors): Likewise.
455 (Printers and Destructors: %glr-parser): Remove for now, to avoid
456 unnecessarily alarming people when the test fails.
457
458 * data/yacc.c (yyerrlab1): Move this label down, so that the
459 parser does not discard the lookahead token if the user code
460 invokes YYERROR. This change is required for POSIX conformance.
461
462 * lib/error.c: Sync with gnulib.
463
4642002-11-22 Paul Eggert <eggert@twinsun.com>
465
466 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
467 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
468 * lib/xmalloc.c: Likewise.
26b4a969 469
58004308
PE
4702002-11-20 Paul Eggert <eggert@twinsun.com>
471
472 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
473
4742002-11-20 Paul Eggert <eggert@twinsun.com>
26b4a969 475
58004308
PE
476 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
477 should use `if (! x) abort ();' rather than `assert (x);', and
478 anyway it's one less thing to worry about configuring.
479
480 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
481 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
482 and replace all instances of assert with abort.
483 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
484 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
485
486 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
487 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
488 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
489 hash_find_entry, hash_rehash, hash_insert): Likewise.
490 * src/conflicts.c (resolve_sr_conflict): Likewise.
491 * src/lalr.c (set_goto_map, map_goto): Likewise.
492 * src/nullable.c (nullable_compute): Likewise.
493 * src/output.c (prepare_rules, token_definitions_output): Likewise.
494 * src/reader.c (packgram, reader): Likewise.
495 * src/state.c (state_new, state_free, state_transitions_set,
496 state_reduction_find): Likewise.
497 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
498 symbol_pack): Likewise.
499 * src/tables.c (conflict_row, pack_vector): Likewise.
500 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
501 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
502 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
503 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
504
505 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
506 (ARGMATCH_CONSTRAINT): New macro.
507 (ARGMATCH_ASSERT): Use it.
508
509 * src/system.h (verify): New macro.
510 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
511 rather than assert.
512 * src/tables.c (tables_generate): Likewise.
513
514 * src/struniq.c (struniq_assert): Now returns void, and aborts
515 if the assertion is false.
516 (struniq_assert_p): Remove.
517 * src/struniq.h: Likewise.
518
76ae8198
PE
5192002-11-18 Paul Eggert <eggert@twinsun.com>
520
521 * data/glr.c (yygetLRActions): Replace `yyindex' with
522 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
523 This fixes the regression with Sun ONE Studio 7 cc that I reported in
524 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001892.html>.
525
d3c4e709
AD
5262002-11-18 Akim Demaille <akim@epita.fr>
527
528 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
529 space.
530 From Tim Van Holder.
531
8d8a7238
PE
5322002-11-17 Paul Eggert <eggert@twinsun.com>
533
534 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
535 to "SyntaxError" for consistency with my 2002-11-15 change.
536
537 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
538 not define to {}, since this breaks the common use of `YYDPRINTF
539 ((...));' if a single statement is desired (e.g. before `else').
540 Work around GCC warnings by surrounding corresponding calls with
541 {} if needed.
542 (yyhasResolvedValue): Remove unused function.
543 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
544 loop body.
545 (yyreportSyntaxError): Renamed from yyreportParseError.
546 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
547 All uses changed.
548 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
549 extern when possible. Remove unused initializations.
550
b0937b22
AD
5512002-11-16 Akim Demaille <akim@epita.fr>
552
553 Augment the similarity between GLR and LALR traces.
554
555 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
556 (YY_REDUCE_PRINT): New.
557 (yyparse): Use them.
558 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
559 YYDPRINT here.
560 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
561 state reached after the reduction/recovery, since...
562 (yyparse, yyprocessOneStack): Report the state we are entering in.
563
c5e3e510
AD
5642002-11-16 Akim Demaille <akim@epita.fr>
565
566 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
567 Add support for --trace=skeleton.
568 * src/scan-skel.l: %option debug.
569 Scan strings of non-@ or \n instead of character by character.
570 (scan_skel): Handle trace_skeleton.
571 (QPUTS): New.
572 (@output_parser_name@, @output_header_name@): ``Restore'' their
573 support (used to be M4 macros).
574 * data/yacc.c: Quote larger chunks, a la glr.c.
575 * data/lalr1.cc: Likewise.
576 The header guards are no longer available, so use some other
577 string than `YYLSP_NEEDED'.
578
4c6cc1db
AD
5792002-11-16 Akim Demaille <akim@epita.fr>
580
581 Make the ``Printers and Destructors'' test more verbose, taking
582 `yacc.c''s behavior as (possibly wrong) reference.
583
584 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
585 instead of fprint on stdout.
586 Set and report the last_line of the symbols.
587 Consistently display values and locations.
588
6d9e8019
PE
5892002-11-16 Paul Eggert <eggert@twinsun.com>
590
591 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
592
6e649e65
PE
5932002-11-15 Paul Eggert <eggert@twinsun.com>
594
b25d88f6
PE
595 * tests/actions.at (Actions after errors): New test case.
596
6e649e65
PE
597 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
598 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
599 tests/action.at, tests/calc.at, tests/conflicts.at,
600 tests/cxx-type.at, tests/regression.at:
601 "parse error" -> "syntax error" for POSIX compatibility.
602 "parsing stack overflow..." -> "parser stack overflow" so
603 that code matches Bison documentation.
604
0f39aab9
AD
6052002-11-15 Akim Demaille <akim@epita.fr>
606
607 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
608 take two BRACED_CODE, not two string_content.
609 Free the scanner's obstack when we are done.
610 (code_content): New.
611 * tests/calc.at: Adjust.
612 * doc/bison.texinfo: Adjust.
613 Also, make sure to include the `,' for these declarations.
614
761c1926
AD
6152002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
616
617 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
618 definition; avoids potential autoreconf problems.
619
b0f98b10
AD
6202002-11-15 Akim Demaille <akim@epita.fr>
621
622 Always check the value returned by yyparse.
623
624 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
625 returned by yyparse.
626 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
627 Adjust calls.
628 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
629 returned by yyparse.
630
970785f1
PH
6312002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
632
633 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
634 on input.at test.
635
8fcc7db1
PE
6362002-11-14 Paul Eggert <eggert@twinsun.com>
637
7ec1b48e
PE
638 * src/output.c (output_skeleton): Call xfopen instead of
639 duplicating xfopen's body.
640
cfff7583
PE
641 Fix bugs reported by Nelson H. F. Beebe in
642 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
643
8fcc7db1
PE
644 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
645 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
646 Group compiler. Instead, use "$CC -E bar.c". Include the .h
647 file twice in the grammar, as an extra check.
648
649 * tests/input.at (Torturing the Scanner): Surround the
650 backslash-newline tests with "#if 0", to make it less likely that
651 we'll run into compiler bugs. Bring back solitary \ inside
652 comment, but add a closing comment to work around HP C bug. Don't
653 test backslash-newline in C character constant. This should fix
654 the input.at bug reported by Nelson H. F. Beebe in
655 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
656
4e8d992c
AD
6572002-11-14 Akim Demaille <akim@epita.fr>
658
659 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
660 status of the compiler.
f32b346d 661 Calling `exit 1' is no longer needed.
4e8d992c
AD
662 Reported by Nelson H. F. Beebe.
663
9501dc6e
AD
6642002-11-14 Akim Demaille <akim@epita.fr>
665
666 * tests/atlocal.in (CPPFLAGS): We have config.h.
667 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
668 New.
669 * tests/actions.at, tests/calc.at, tests/conflicts.at,
670 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
671 * tests/regression.at, tests/torture.at: Use them for all the
672 grammars that are to be compiled.
673 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
674 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
675 * doc/bison.texinfo (GLR Parsers): Document `inline'.
676
18b519c0
AD
6772002-11-14 Akim Demaille <akim@epita.fr>
678
679 * doc/bison.texinfo: Various formatting changes (alignments in
680 samples, additional @group/@end group, GCS in samples.
681 Use @deffn instead of simple @table to define the directives,
682 macros, variables etc.
683
9a86cdb9
PE
6842002-11-13 Paul Eggert <eggert@twinsun.com>
685
daa33def
PE
686 Fix some bugs reported by Albert Chin-A-Young in
687 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
18b519c0 688
daa33def 689 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
8fcc7db1 690 -o c"; the HP C compiler chatters during compilation.
daa33def
PE
691 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
692 * tests/headers.at (export YYLTYPE): Likewise.
693
694 * tests/input.at (Torturing the Scanner): Remove lines containing
8fcc7db1 695 solitary backslashes, as they tickle a bug in the HP C compiler.
daa33def 696
9a86cdb9
PE
697 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
698 comments, since they're not portable. Use GNU coding style.
699
9c1e26bd
AD
7002002-11-13 Akim Demaille <akim@epita.fr>
701
702 * data/yacc.c: Leave bigger chunks of quoted text.
703 (YYDSYMPRINTF): New.
704 Use it to report symbol activities.
705 * data/glr.c (YYDSYMPRINTF): New.
706 Use it.
707
87f721cc
PE
7082002-11-12 Paul Eggert <eggert@twinsun.com>
709
710 Version 1.75b.
711
712 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
713 (yyglrReduce): Return yyok, not 0.
714 This should avoid the enumerated-type warnings reported
715 by Nelson H.F. Beebe in
716 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
717
718 * lib/bbitset.h (BITSET_INLINE): Remove.
719 * lib/bitset.h [! BITSET_INLINE]: Remove.
720 (bitset_set, bitset_reset, bitset_test): Rename local vars
721 to avoid shadowing warnings by GCC.
722
723 * data/glr.c (inline): Remove #define. It's the user's
724 responsibility to #define it away, just like 'const'.
725 This fixes one of the bugs reported by Nelson H.F. Beebe in
726 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
18b519c0 727
87f721cc
PE
728 * Makefile.maint (po-check): Scan .l and .y files instead of the
729 .c and the .h files that they generate. This fixes the bug
730 reported by Tim Van Holder in:
731 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
732 Look for N_ as well as for _. Try to avoid matching #define for
733 N_ and _.
734 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
735 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
736 * src/scan-gram.l: Revamp regular expressions so that " and '
737 do not confuse xgettext.
738
739 * src/struniq.h (struniq_new): Do not declare the return type
740 to be 'const'; this violates the C standard.
741 * src/struniq.c (struniq_new): Likewise.
742
be14ade5
AD
7432002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
744
745 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
746 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
747 linker.
748
05291fbc
AD
7492002-11-12 Akim Demaille <akim@epita.fr>
750
751 * Makefile.maint: Sync with Autoconf:
752 (local_updates): New.
753
1f5fd52e
AD
7542002-11-12 Akim Demaille <akim@epita.fr>
755
756 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
757
283f1e64
AD
7582002-11-12 Akim Demaille <akim@epita.fr>
759
760 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
761 locations.
762
886b69d1
AD
7632002-11-12 Akim Demaille <akim@epita.fr>
764
765 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
766 not yyvalue.
767
3df37415
AD
7682002-11-12 Akim Demaille <akim@epita.fr>
769
770 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
771 Use it to test the GLR parser.
772
7bd6c77e
AD
7732002-11-12 Akim Demaille <akim@epita.fr>
774
775 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
776 defines it.
777 * data/glr.c (yystos): New.
778 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
779 (YYDSYMPRINT): New.
780 (yyval): Don't define it, it is handled via M4.
781 (yyrecoverParseError): Free verbosely the discarded symbols.
782 * data/yacc.c (yysymprint): Remove, rather...
783 (b4_yysymprint_generate): invoke.
784 * data/c.m4 (b4_yysymprint_generate): New.
785 Accept pointers as arguments, as opposed to the version from
786 yacc.c.
787 (b4_yydestruct_generate): Likewise.
788 * tests/cations.at (Printers and Destructors): Use Bison directives
789 instead of CPP macros.
790 Don't rely on internal details.
791
b0400cc6
AD
7922002-11-12 Akim Demaille <akim@epita.fr>
793
794 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
795 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
796 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
797 it against YYEMPTY and so forth), work on yytoken (i.e., set
798 it to YYEMPTY etc.).
799 (yydestruct): Replace with a b4_yydestruct_generate invocation.
800 (b4_symbol_actions): Remove.
801 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
802 for 0, end-of-input.
803
72f889cc
AD
8042002-11-12 Akim Demaille <akim@epita.fr>
805
806 * doc/bison.texinfo (Destructor Decl): New.
807
b1ae9233
AD
8082002-11-12 Akim Demaille <akim@epita.fr>
809
810 * src/tables.c (tables_generate): Use free for pointers that
811 cannot be NULL, not XFREE.
812 (pack_vector): Use assert, not fatal, for bound violations.
813 * src/state.c (state_new): Likewise.
814 * src/reader.c (reader): Likewise.
815 * src/lalr.c (set_goto_map): Likewise.
72f889cc 816 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
b1ae9233
AD
817 the file name.
818
7ec2d4cd
AD
8192002-11-12 Akim Demaille <akim@epita.fr>
820
821 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
822 Restore.
823 * src/scan-gram.l (last_string): Is global to the file, not to
824 yylex.
825 * src/parse-gram.y (input): Don't append the epilogue here,
826 (epilogue.opt): do it here, and free the scanner's obstack.
827 * src/reader.c (epilogue_set): Rename as...
828 (epilogue_augment): this.
829 * data/c.m4 (b4_epilogue): Defaults to empty.
830
573a6cd3
AD
8312002-11-12 Akim Demaille <akim@epita.fr>
832
833 * src/getargs.c (long_options): Remove duplicates.
834 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
835 Remove.
836 * doc/bison.rnh: Remove.
837 * doc/bison.texinfo (VMS Invocation): Remove.
838
95612cfa
AD
8392002-11-12 Akim Demaille <akim@epita.fr>
840
841 * src/struniq.h, src/struniq.c (struniq_t): Is const.
842 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
843
844 Use struniq for symbols.
845
846 * src/symtab.h (symbol_t): The tag member is a struniq.
847 (symbol_type_set): Adjust.
848 * src/symtab.c (symbol_new): Takes a struniq.
849 (symbol_free): Don't free the tag member.
850 (hash_compare_symbol_t, hash_symbol_t): Rename as...
851 (hash_compare_symbol, hash_symbol): these.
852 Use the fact that tags as struniqs.
853 (symbol_get): Use struniq_new.
854 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
855 Returns a strniq.
856 * src/reader.h (merger_list, grammar_currentmerge_set): The name
857 and type members are struniqs.
858 * src/reader.c (get_merge_function)
859 (grammar_current_rule_merge_set): Adjust.
860 (TYPE, current_type): Are struniq.
861
862 Use struniq for file names.
863
864 * src/files.h, src/files.c (infile): Split into...
865 (grammar_file, current_file): these.
866 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
867 * src/reduce.c (reduce_print): Likewise.
868 * src/getargs.c (getargs): Likewise.
869 * src/complain.h, src/complain.c: Likewise.
870 * src/main.c (main): Call struniqs_new early enough to use it for
871 file names.
872 Don't free the input file name.
873
3e6656f9
AD
8742002-11-12 Akim Demaille <akim@epita.fr>
875
876 * src/symtab.c (symbol_free): Remove dead deactivated code:
877 type_name are properly removed.
878 Don't use XFREE to free items that cannot be NULL.
879 * src/struniq.h, src/struniq.c: New.
880 * src/main.c (main): Initialize/free struniqs.
881 * src/parse-gram.y (%union): Add astruniq member.
882 (yyprint): Adjust.
883 * src/scan-gram.l (<{tag}>): Return a struniq.
884 Free the obstack bit that used to store it.
885 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
886
7672019c
PE
8872002-11-11 Paul Eggert <eggert@twinsun.com>
888
889 Revamp to fix many (but not all) of the C- and M4-related quoting
890 problems. Among other things, this fixes the Bison bug reported
891 by Jan Hubicka when processing the Bash grammar; see:
892 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
893
894 Use new @ escapes consistently. Represent brackets with @{ and @}
895 rather than @<:@ and @:>@, since this works a bit better with dumb
896 editors like vi. Represent @ with @@, since @ is now consistently
897 an escape. Use @oline@ and @ofile@ rather than __oline__ and
898 __ofile__, to avoid unexpected expansions. Similarly, use @output
899 rather than #output.
900
901 * data/c.m4 (b4_copyright): Omit file name from comment, since
902 the file name could contain "*/".
903 (b4_synclines_flag): Don't quote the 2nd argument; it should already
904 be quoted. All uses changed.
905
906 * data/glr.c: Use new @ escapes consistently.
907 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
908 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
909 Remove, since they couldn't handle arbitrary characters in file
910 names.
911 * data/lalr1.cc: Likewise.
912 * data/yacc.c: Likewise.
913
914 * src/files.c (output_infix): Remove; all uses removed.
915 * src/files.h: Likewise.
916
917 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
918 mishandled funny characters in file names, and anyway it isn't
919 needed any more.
920 * data/yacc.c: Likewise.
921 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
922
923 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
924 * data/yacc.c: Likewise.
925
926 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
927 strings now.
928 (muscle_init): Quote filename as a C string.
929 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
930 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
931 * src/output.c (escaped_file_name_output): New function.
932 (prepare_symbols): Quote tokens for M4.
933 (prepare): Don't insert output_infix, output_prefix,
934 output_parser_name, output_header_name; this is now down by scan-skel.
935 Insert skeleton as a C string.
936
937 * src/output.c (user_actions_output, symbol_destructors_output,
938 symbol_printers_output): Quote filenames for C and M4.
939 * src/reader.c (prologue_augment, epilogue_set): Likewise.
940
941 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
942 escapes other than \\ and \'; this simplifies the code.
943 (<SC_STRING>): Likewise, for \\ and \".
944 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
945 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
946 Use new escapes @{ and @} for [ and ].
947
948 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
949 them with auto vars.
950 Switch to new escape scheme, where @ is the escape character uniformly.
951 Abort if a stray escape character is found. Avoid unbounded input
952 buffer when parsing non-escaped text.
953
954 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
955 __oline__, #output, $@, and @{ do not have unintended meanings.
956
acea4f3b
PE
9572002-11-09 Paul Eggert <eggert@twinsun.com>
958
959 Fix the test failure due to GCC warnings described in
960 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
961 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
962 evaluate to 0 if it's impossible for NINF to be in the respective
963 table.
964 (yygetLRActions, yyrecoverParseError): Use them.
965
966 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
967 counted in the token inserted at end of file. Now takes
968 location_t *, not location_t, so that the location can be
969 adjusted. All uses changed.
970
971 * tests/regression.at (Invalid inputs): Adjust wording in
972 diagnostic to match the new behavior.
973
974 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
975 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
976 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
977 abort ();'. This reduces the runtime of the "Many lookaheads"
978 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
979 GCC 3.2.
980
20ef1ad5
PE
9812002-11-07 Paul Eggert <eggert@twinsun.com>
982
983 * src/parse-gram.y (CHARACTER): Remove unused token.
984 All uses removed.
985
986 * src/scan-gram.l: Remove stack option. We no longer use the
987 stack, since the stack was never deeper than 1; instead, use the
988 new auto var c_context to record the stacked value.
989
990 Remove nounput option. At an unexpected end of file, we now unput
991 the minimal input necessary to end cleanly; this simplifies the
992 code.
993
994 Avoid unbounded token sizes where this is easy.
995
996 (unexpected_end_of_file): New function.
997 Use it to systematize the error message on unexpected EOF.
998 (last-string): Now auto, not static.
999 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
1000 (scanner_last_string_free): Remove; not used.
1001 (percent_percent_count): Move decl to just before use.
1002 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
1003 not the (never otherwised-used) CHARACTER.
1004
93724f13
AD
10052002-11-07 Akim Demaille <akim@epita.fr>
1006
1007 Let yyerror always receive the msg as last argument, so that
1008 yyerror can be variadic.
1009
1010 * data/yacc.c (b4_yyerror_args): New.
1011 Use it when calling yyerror.
1012 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
1013 Use it when calling yyerror.
1014 * doc/bison.texinfo (Error Reporting): Adjust.
1015 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
1016 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
1017
6e40b4eb
AD
10182002-11-06 Akim Demaille <akim@epita.fr>
1019
1020 #line should have quoted strings.
1021 Ideally, this should be done by m4_quotearg.
1022
1023 * src/scan-skel.l: Include quotearg.h.
1024 Quote __ofile__.
1025 * src/output.c (symbol_printers_output)
1026 (symbol_destructors_output): Quote the file name.
1027
2dfbfc12
AD
10282002-11-06 Akim Demaille <akim@epita.fr>
1029
1030 * tests/regression.at (Invalid inputs): Adjust to the recent
1031 messages.
1032
437c2d80
AD
10332002-11-06 Akim Demaille <akim@epita.fr>
1034
1035 Restore --no-lines.
1036 Reported by Jim Kent.
1037
1038 * data/c.m4 (b4_syncline): New.
1039 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
1040 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
1041 * src/output.c (user_actions_output): Likewise.
1042 (prepare): Define 'b4_synclines_flag'.
2dfbfc12 1043 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
437c2d80 1044
900c5db5
AD
10452002-11-06 Akim Demaille <akim@epita.fr>
1046
1047 * src/main.c (main): Free `infile'.
1048 * src/scan-gram.l (handle_syncline): New.
1049 Recognize `#line'.
1050 * src/output.c (user_actions_output, symbol_destructors_output)
1051 (symbol_printers_output): Use the location's file name, not
1052 infile.
1053 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1054
e183b123 10552002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
51b4a04c 1056
e183b123 1057 * src/tables.c (matching_state): Don't allow states to match if
51b4a04c 1058 either has GLR conflict entries.
e183b123 1059
193eb6b7
PE
10602002-11-05 Paul Eggert <eggert@twinsun.com>
1061
e183b123
PE
1062 * src/scan-gram.l: Use more accurate diagnostics, e.g.
1063 "integer out of range" rather than "invalid value".
1064 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
1065 accordingly.
1066
193eb6b7
PE
1067 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
1068 Also, remove one static variable in the scanner.
1069
1070 * src/scan-gram.l (braces_level): Now auto, not static.
1071 Initialize to zero if the compiler is being picky.
1072 (INITIAL): Clear braces_level instead of incrementing it.
1073 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
1074 as POSIX 1003.1-2001 requires.
1075 * src/system.h (IF_LINT): New macro, taken from coreutils.
1076 * configure.ac: Define "lint" if --enable-gcc-warnings.
1077
29c01725
AD
10782002-11-05 Akim Demaille <akim@epita.fr>
1079
1080 * src/scan-gram.l: When it starts with `%', complain about the
1081 whole directive, not just that `invalid character: %'.
1082
8aeac3ca
AD
10832002-11-04 Akim Demaille <akim@epita.fr>
1084
1085 * Makefile.maint: Update from Autoconf.
1086 (update, cvs-update, po-update, do-po-update): New.
1087
793a58bb
AD
10882002-11-04 Akim Demaille <akim@epita.fr>
1089
1090 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
1091 and yyerror.
1092 Have yyerror `use' its arguments.
1093 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
1094 returns true when location & yacc & pure & parse-param.
1095 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
1096
c4d720cd
AD
10972002-11-04 Akim Demaille <akim@epita.fr>
1098
1099 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
1100 clashes.
1101 * src/scan-gram.l: Use [\'] instead of ['] to pacify
1102 font-lock-mode.
1103 Use complain_at.
1104 Use quote, not quote_n since LOCATION_PRINT no longer uses the
1105 slot 0.
1106
613a0dc5
PE
11072002-11-03 Paul Eggert <eggert@twinsun.com>
1108
1109 * src/reader.c (get_merge_function, grammar_current_rule_check):
1110 Use consistent diagnostics for reporting type name clashes.
1111 Quote the types with <>, for consistency with Yacc.
1112 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
1113
2a8d363a
AD
11142002-11-03 Akim Demaille <akim@epita.fr>
1115
1116 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
1117 New.
1118 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
1119 (b4_parse_param): Remove.
1120 Use b4_identification.
1121 Propagate b4_pure_args where needed to pass them to yyerror.
1122 * data/glr.m4 (b4_parse_param): Remove.
1123 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
1124 (b4_lpure_formals): New.
1125 Use b4_identification.
1126 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
1127 b4_user_formals and b4_user_args.
1128 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
1129 (yyreportAmbiguity): When using a pure parser, also need
1130 the location, and the parse-params.
1131 Adjust callers.
1132 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
1133 When using a pure parser, also need the parse-params.
1134 Adjust callers.
1135 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
1136 (%pure-parser + %parse-param) LALR and GLR parsers.
1137 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
1138 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
1139 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
1140 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
1141 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
1142 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
1143 * doc/bison.texinfo: Untabify the whole file.
1144 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
1145 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
1146 (Error Reporting): Adjust to these new directives.
1147 Document %error-verbose, deprecate YYERROR_VERBOSE.
1148
9e32add8
AD
11492002-11-03 Akim Demaille <akim@epita.fr>
1150
1151 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
1152 AT_CHECK_CALC_GLR invocations to use % directives, instead of
1153 command line options.
1154 * tests/cxx-type.at: Formatting changes.
1155
b02d90a5
PE
11562002-11-03 Paul Eggert <eggert@twinsun.com>
1157
1158 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
1159 to count columns correctly, and to check for invalid inputs.
9e32add8 1160
b02d90a5
PE
1161 Use mbsnwidth to count columns correctly. Account for tabs, too.
1162 Include mbswidth.h.
1163 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
1164 (extend_location): New function.
1165 (YY_LINES): Remove.
1166
1167 Handle CRLF in C code rather than in Lex code.
1168 (YY_INPUT): New macro.
1169 (no_cr_read): New function.
1170
1171 Scan UCNs, even though we don't fully handle them yet.
1172 (convert_ucn_to_byte): New function.
1173
1174 Handle backslash-newline correctly in C code.
1175 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
1176 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
1177 all uses changed.
1178 (tag, splice): New EREs. Do not allow NUL or newline in tags.
1179 Use {splice} wherever C allows backslash-newline.
1180 YY_STEP after space, newline, vertical-tab.
1181 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
9e32add8 1182
b02d90a5
PE
1183 (letter, id): Don't assume ASCII; e.g., spell out a-z.
1184
1185 ({int}, handle_action_dollar, handle_action_at): Check for integer
1186 overflow.
9e32add8 1187
b02d90a5
PE
1188 (YY_STEP): Omit trailing semicolon, so that it's more like C.
1189
1190 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
1191 as well as \000. Check for UCHAR_MAX, not 255.
1192 Allow \x with an arbitrary positive number of digits, as in C.
1193 Check for overflow here.
1194 Allow \? and UCNs, for compatibility with C.
1195
1196 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
1197 with quote slot used by complain_at.
1198
1199 * tests/input.at: Add tests for backslash-newline, m4 quotes
1200 in symbols, long literals, and funny escapes in strings.
1201
1202 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
1203 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
1204 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
1205 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
1206 * m4/mbswidth.m4: New file, from GNU coreutils.
1207
1208 * doc/bison.texinfo (Grammar Outline): Document // comments.
1209 (Symbols): Document that trigraphs have no special meaning in Bison,
1210 nor is backslash-newline allowed.
1211 (Actions): Document that trigraphs have no special meaning.
1212
1213 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
1214 no longer used.
1215
12162002-11-02 Paul Eggert <eggert@twinsun.com>
1217
1218 * src/reader.c: Don't include quote.h; not needed.
1219 (get_merge_function): Reword warning to be consistent with
1220 type clash diagnostic in grammar_current_rule_check.
1221
1222 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
1223 bug in trigraph handling.
1224
1225 * src/output.c (prepare_symbols): When printing token names,
1226 escape "[" as "@<:@" and likewise for "]".
1227
1228 * src/system.h (errno): Remove declaration, as we are now
1229 assuming C89 or better, and C89 guarantees errno.
1230
762b212b
PE
12312002-10-30 Paul Eggert <eggert@twinsun.com>
1232
1233 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
1234 Check for close failures.
1235 * src/files.h (xfclose): Return void, not int, since it always
1236 returned zero.
1237 * src/files.c (xfclose): Likewise. Report I/O error if ferror
1238 indicates one.
1239 * src/output.c (output_skeleton): Use xfclose rather than fclose
1240 and ferror. xfclose now checks ferror.
1241
1242 * data/glr.c (YYLEFTMOST_STATE): Remove.
1243 (yyreportTree): Use a stack-based leftmost state. This avoids
1244 our continuing battles with bogus warnings about initializers.
1245
56100c60
AD
12462002-10-30 Akim Demaille <akim@epita.fr>
1247
1248 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
1249 #if.
1250
51b4a04c
PH
12512002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1252
1253 * tests/glr-regr1.at: New test for reported regressions.
1254 * tests/testsuite.at: Add glr-regr1.at test.
1255 * tests/Makefile.am: Add glr-regr1.at test.
e183b123 1256
bf1ebda2
PE
12572002-10-24 Paul Eggert <eggert@twinsun.com>
1258
5c16c6b1
PE
1259 Version 1.75a.
1260
bf1ebda2
PE
1261 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
1262 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
1263 we use malloc. Don't assume 'A' through 'Z' are contiguous.
1264 Don't assume strdup exists; POSIX says its an XSI extension.
1265 Check for buffer overflow on input.
1266
b526ee61
AD
12672002-10-24 Akim Demaille <akim@epita.fr>
1268
1269 * src/output.c (output_skeleton): Don't disable M4sugar comments
1270 too soon: it results in comments being expanded.
1271 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
1272 first output.
1273
f1886bb2
AD
12742002-10-24 Akim Demaille <akim@epita.fr>
1275
1276 * data/yacc.c (m4_int_type): New.
1277 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
1278 char' as only yacc.c wants K&R portability.
1279 * data/glr.c (yysigned_char): Remove.
1280 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
1281 Reported by Quoc Peyrot.
1282
c5576256
PE
12832002-10-23 Paul Eggert <eggert@twinsun.com>
1284
1285 * src/main.c (main): With --trace=time, report times even if a
1286 non-fatal error occurs. Formerly, the times were reported in some
1287 such cases but not in others.
1288 * src/reader.c (reader): Just return if a complaint has been issued,
1289 instead of exiting, so that 'main' can report times.
1290
27b0ffea
AD
12912002-10-22 Akim Demaille <akim@epita.fr>
1292
1293 * src/system.h: Include sys/types.
1294 Reported by Bert Deknuydt.
1295
223a7883
PE
12962002-10-23 Paul Eggert <eggert@twinsun.com>
1297
1298 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
1299 Suggested by Art Haas.
1300
13012002-10-22 Paul Eggert <eggert@twinsun.com>
1302
1303 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
1304 decl; not needed any more.
1305 * src/main.c (main): Use return to exit, undoing yesterday's change.
1306 The last OS that we could find where this wouldn't work is
1307 SunOS 3.5, and that's too old to worry about now.
1308
1309 * data/glr.c (struct yyltype): Define members even when not
1310 doing locations. This is more consistent with yacc.c, and it
1311 works around the following bug reports:
1312 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
1313 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
1314 and I hope it also fixes this bug report:
1315 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
27b0ffea 1316
223a7883
PE
1317 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
1318 @acronym consistently. Standardize on "Yacc" instead of "YACC",
1319 "Algol" instead of "ALGOL". Give a bit more history about BNF.
1320
8b76775a
AD
13212002-10-22 Akim Demaille <akim@epita.fr>
1322
1323 * data/README: New.
1324
6db10d14
PE
13252002-10-21 Paul Eggert <eggert@twinsun.com>
1326
1327 Be consistent about 'bool'; the old code used an enum in one
1328 module and an int in another, and this violates the C standard.
1329 * m4/stdbool.m4: New file, from coreutils 4.5.3.
1330 * configure.ac (AC_HEADER_STDBOOL): Add.
1331 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
1332 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
1333 * src/symtab.c (hash_compare_symbol_t): Likewise.
1334 * src/system.h (bool, false, true): Use a definition consistent
1335 with ../lib/hash.c. All uses changed.
1336
1337 * src/complain.c (warning_issued): Renamed from warn_message_count,
1338 so that we needn't worry about integer overflow (!).
1339 Now of type bool. All uses changed.
1340 (complaint_issued): Renamed from complain_message_count; likewise.
1341
1342 * src/main.c (main): Use exit to exit with failure.
27b0ffea 1343
6db10d14
PE
1344 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
1345 rather than 1 and 0.
1346 * src/main.c (main): Likewise.
1347 * src/getargs.c (getargs): Likewise.
1348 * src/reader.c (reader): Likewise.
1349
1350 * src/getarg.c (getargs): Remove duplicate code for
1351 "Try `bison --help'".
1352
1353 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
1354 What was that "2" for?
1355
1356 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
1357 * src/getargs.c (usage): Likewise.
1358
1359 * src/getargs.c (getargs): When there are too few operands, report
1360 the last one. When there are too many, report the first extra
1361 one. This is how diffutils does it.
1362
92a060fd
PE
13632002-10-20 Paul Eggert <eggert@twinsun.com>
1364
1365 Remove K&R vestiges.
1366 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
1367 * src/complain.c (VA_START): Remove. Assume prototypes.
1368 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
1369 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
1370 fatal): Assume prototypes.
1371 * src/complain.h: Assume prototypes.
1372 * src/system.h (PARAMS): Remove.
1373 Include <limits.h> unconditionally, since it's guaranteeed even
1374 for a freestanding C89 compiler.
1375 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
1376 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 1377
e7cb57c0
AD
13782002-10-20 Akim Demaille <akim@epita.fr>
1379
1380 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1381 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1382 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1383 (yyresolveStates, yyresolveAction, yyresolveStack)
1384 (yyprocessOneStack): Use them.
1385 (yy_reduce_print): New.
1386 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1387
0245f82d
AD
13882002-10-20 Akim Demaille <akim@epita.fr>
1389
1390 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1391 arguments and output `void'.
1392 (b4_c_function): Rename as...
1393 (b4_c_function_def): this.
1394 (b4_c_function_decl, b4_c_ansi_function_def)
1395 (b4_c_ansi_function_decl): New.
1396 Change the interpretation of the arguments: before `int, foo', now
1397 `int foo, foo'.
1398 * data/yacc.c (yyparse): Prototype and define thanks to these.
1399 Adjust b4_c_function_def uses.
1400 * data/glr.c (yyparse): Likewise, but ANSI only.
1401
39912f52
AD
14022002-10-20 Akim Demaille <akim@epita.fr>
1403
1404 * src/output.c (prepare): Move the definition of `tokens_number',
1405 `nterms_number', `undef_token_number', `user_token_number_max'
1406 to...
1407 (prepare_tokens): Here.
1408 (prepare_tokens): Rename as...
1409 (prepare_symbols): this.
1410 (prepare): Move the definition of `rules_number' to...
1411 (prepare_rules): here.
1412 (prepare): Move the definition of `last', `final_state_number',
1413 `states_number' to...
1414 (prepare_states): here.
1415 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1416
20c1e2ad
AD
14172002-10-20 Akim Demaille <akim@epita.fr>
1418
1419 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1420
21964f43
AD
14212002-10-20 Akim Demaille <akim@epita.fr>
1422
1423 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1424 * data/c.m4: here.
1425
66d30cd4
AD
14262002-10-20 Akim Demaille <akim@epita.fr>
1427
1428 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1429 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1430 `pair'.
1431 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1432 `name' to...
1433 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1434 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1435 These.
1436
95f2c9fe
PE
14372002-10-19 Paul Eggert <eggert@twinsun.com>
1438
1439 Do not create a temporary file, as that involves security and
1440 cleanup headaches. Instead, use a pair of pipes.
1441 Derived from a suggestion by Florian Krohm.
1442 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1443 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1444 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1445 (BISON_PREREQ_SUBPIPE): Add.
1446 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1447 Add subpipe.h, subpipe.c.
1448 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1449 * po/POTFILES.in: Add lib/subpipe.c.
1450 * src/output.c: Include "subpipe.h".
1451 (m4_invoke): Remove decl.
1452 (scan_skel): New decl.
1453 (output_skeleton): Use pipe rather than temporary file for m4 input.
1454 Check that m4sugar.m4 is readable, to avoid deadlock.
1455 Check for pipe I/O error.
1456 * src/scan-skel.l (readpipe): Remove decl.
1457 (scan_skel): New function, to be used in place of m4_invoke.
1458 Read from stream rather than file.
66d30cd4 1459
95f2c9fe
PE
1460 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1461 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1462 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1463 this generates a more-accurate value anyway.
1464
1465 * lib/timevar.c (timervar_accumulate): Rename locals to
1466 avoid confusion with similarly-named more-global.
1467 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1468
1469 * src/output.c (prepare): Use xstrdup to convert char const *
1470 to char *, to avoid GCC warning.
1471
c19988b7
AD
14722002-10-19 Akim Demaille <akim@epita.fr>
1473
1474 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1475 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1476 Use them to have `calc.y' ready for %pure-parser.
1477 * data/yacc.c (YYLEX): Pass a yylex return type to
1478 b4_c_function_call.
1479
ae7453f2
AD
14802002-10-19 Akim Demaille <akim@epita.fr>
1481
1482 Prototype support of %lex-param and %parse-param.
1483
1484 * src/parse-gram.y: Add the definition of the %lex-param and
1485 %parse-param tokens, plus their rules.
1486 Drop the `_' version of %glr-parser.
1487 Add the "," token.
1488 * src/scan-gram.l (INITIAL): Scan them.
1489 * src/muscle_tab.c: Comment changes.
1490 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1491 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1492 (muscle_entry_s): The `value' member is no longer const.
1493 Adjust all dependencies.
1494 * src/muscle_tab.c (muscle_init): Adjust: use
1495 MUSCLE_INSERT_STRING.
1496 Initialize the obstack earlier.
1497 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1498 (muscle_pair_list_grow): New.
1499 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1500 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1501 * tests/calc.at: Use %locations, not --locations.
1502 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1503
0e575721
AD
15042002-10-19 Akim Demaille <akim@epita.fr>
1505
1506 * src/getargs.c (usage): Take status as argument and exit
1507 accordingly.
1508 Report the traditional `Try ... --help' message when status != 0.
1509 (usage, version): Don't take a FILE * as arg, it is pointless.
1510 (getargs): When there is an incorrect number of arguments, make it
1511 an error, and report it GNUlically thanks to `usage ()'.
1512
724ce7f5
PE
15132002-10-18 Paul Eggert <eggert@twinsun.com>
1514
3a781eb2
PE
1515 * data/glr.c (yyreportParseError): Don't assume that sprintf
1516 yields the length of the printed string, as this is not true
1517 on SunOS 4.1.4. Reported by Peter Klein.
1518
724ce7f5
PE
1519 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1520 * tests/conflicts.at (%nonassoc and eof): Likewise.
1521 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1522
473d0a75
AD
15232002-10-17 Akim Demaille <akim@epita.fr>
1524
1525 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1526 * src/getargs.c (trace_types, trace_args): Adjust.
1527 * src/reader.c (grammar_current_rule_prec_set)
1528 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1529 Standardize error messages.
1530 And s/@prec/%prec/!
1531 (reader): Use trace_flag to enable scanner/parser debugging,
1532 instead of an adhoc scheme.
1533 * src/scan-gram.l: Remove trailing debugging code.
1534
e76d2469
PE
15352002-10-16 Paul Eggert <eggert@twinsun.com>
1536
93e2236a
PE
1537 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1538 MUSCLE_TAB_H.
1539
e76d2469
PE
1540 * NEWS: Officially drop support for building Bison with K&R C,
1541 since it didn't work anyway and it's not worth worrying about.
1542 * Makefile.maint (wget_files): Remove ansi2knr.c.
1543 (ansi2knr.c-url_prefix): Remove.
1544 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1545 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1546 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1547
5bd1c419
PE
15482002-10-15 Paul Eggert <eggert@twinsun.com>
1549
1550 Stop using the "enum_" trick for K&R-style function definitions;
1551 it confused me, and I was the author! Instead, assume that people
1552 who want to use K&R C compilers (when using these modules in GCC,
1553 perhaps?) will run ansi2knr.
1554
1555 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1556 All uses of "enum_" changed to "enum ".
1557 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1558 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 1559
5bd1c419
PE
1560 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1561 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1562 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1563 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1564 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1565 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1566 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1567 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1568 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1569 Use function prototypes; this removes the need for declaring
1570 static functions simply to provide their prototypes.
1571 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1572 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1573 bitset_count_, bitset_create, bitset_dump, bitset_first,
1574 bitset_free, bitset_init, bitset_last, bitset_next,
1575 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1576 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1577 bitset_print, bitset_release_memory, bitset_toggle_,
1578 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1579 debug_bitset): Likewise.
1580 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1581 * lib/bitset_stats.c (bitset_log_histogram_print,
1582 bitset_percent_histogram_print, bitset_stats_and,
1583 bitset_stats_and_cmp, bitset_stats_and_or,
1584 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1585 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1586 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1587 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1588 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1589 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1590 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1591 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1592 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1593 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1594 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1595 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1596 bitset_stats_zero): Likewise.
1597 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1598 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1599 bitsetv_dump, debug_bitsetv): Likewise.
1600 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1601 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1602 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1603 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1604 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1605 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1606 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1607 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1608 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1609 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1610 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1611 Likewise.
1612 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1613 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1614 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1615 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1616 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1617 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1618 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1619 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1620 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1621 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1622 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 1623
ae26e1f0
AD
16242002-10-14 Akim Demaille <akim@epita.fr>
1625
1626 Version 1.75.
1627
d43baf71
AD
16282002-10-14 Akim Demaille <akim@epita.fr>
1629
1630 * tests/Makefile.am (maintainer-check-posix): New.
1631
7ebc83e3
AD
16322002-10-14 Akim Demaille <akim@epita.fr>
1633
1634 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1635 member.
1636
05846dae
AD
16372002-10-14 Akim Demaille <akim@epita.fr>
1638
1639 * src/tables.c (table_ninf_remap): base -> tab.
1640 Reported by Matt Rosing.
1641
1318e37d
PE
16422002-10-14 Paul Eggert <eggert@twinsun.com>
1643
447fbb17
PE
1644 * tests/action.at, tests/calc.at, tests/conflicts.at,
1645 tests/cxx-type.at, tests/headers.at, tests/input.at,
1646 tests/regression.at, tests/synclines.at, tests/torture.at:
1647 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1648 so that the tests still work even if POSIXLY_CORRECT is set.
1649 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 1650
1318e37d
PE
1651 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1652 for portability to K&R hosts. Fix typo: signed char is guaranteed
1653 only to 127, not to 128.
1654 * data/glr.c (yysigned_char): New type.
1655 * data/yacc.c (yysigned_char): Likewise.
1656 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1657
cc0f0794
PE
16582002-10-13 Paul Eggert <eggert@twinsun.com>
1659
5038f418
PE
1660 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1661 true due to limited range of data type" warning from GCC.
1662
cc0f0794
PE
1663 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1664 by wrapping enum yytokentype's definition inside #ifndef
1665 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1666
6fed0802
AD
16672002-10-13 Akim Demaille <akim@epita.fr>
1668
1669 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1670 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1671
32f0598d
AD
16722002-10-13 Akim Demaille <akim@epita.fr>
1673
1674 * Makefile.maint: Update from Autoconf 2.54.
1675 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1676
7ea9a33f
AD
16772002-10-13 Akim Demaille <akim@epita.fr>
1678
1679 * src/print.c (print_state): Separate the list of solved conflicts
1680 from the other items.
1681 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1682
ea99527d
AD
16832002-10-13 Akim Demaille <akim@epita.fr>
1684
1685 Let nondeterministic skeletons be usable with deterministic
1686 tables.
1687
1688 With the patch, GAWK compiled by GCC without -O2 passes its test
1689 suite using a GLR parser driven by LALR tables. It fails with -O2
1690 because `struct stat' gives two different answers on my machine:
1691 88 (definition of an auto var) and later 96 (memset on this var).
1692 Hence the stack is badly corrumpted. The headers inclusion is to
1693 blame: if I move the awk.h inclusion before GLR's system header
1694 inclusion, the two struct stat have the same size.
1695
1696 * src/tables.c (pack_table): Always create conflict_table.
1697 (token_actions): Always create conflict_list.
1698 * data/glr.c (YYFLAG): Remove, unused.
1699
f377f69f
AD
17002002-10-13 Akim Demaille <akim@epita.fr>
1701
1702 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1703 (O0FLAGS): New.
1704 (VALGRIND, GXX): New.
1705 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1706 * tests/bison.in: Run $PREBISON a pre-command.
1707 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1708 (maintainer-check-g++): New.
1709 * Makefile.am (maintainer-check): New.
1710
2a1fe6ed
AD
17112002-10-13 Akim Demaille <akim@epita.fr>
1712
1713 * data/glr.c: Formatting changes.
1714 Tweak some trace messages to match yacc.c's.
1715
f50adbbd
AD
17162002-10-13 Akim Demaille <akim@epita.fr>
1717
1718 GLR parsers sometimes raise parse errors instead of performing the
1719 default reduction.
1720 Reported by Charles-Henry de Boysson.
1721
1722 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1723 check the length of the traces when %glr.
1724 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1725 GLR's traces.
1726 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1727 Test GLR parsers.
1728 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1729 (yyltype): Remove the yy prefix from the member names.
1730 (yytable): Complete its comment.
1731 (yygetLRActions): Map error action number from YYTABLE from
1732 YYTABLE_NINF to 0.
1733 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1734 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1735 not satisfying as we could compare an YYACTION computed from
1736 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1737 only value for error actions.
1738 (yyreportParseError): In verbose parse error messages, don't issue
1739 `error' in the list of expected tokens.
1740 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1741 next action to perform to match glr.c's decoding.
1742 (yytable): Complete its comment.
1743
bcbad5b9
PE
17442002-10-13 Paul Eggert <eggert@twinsun.com>
1745
1746 Fix problem reported by Henrik Grubbstroem in
1747 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1748 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1749 because the Bison parser reads the second action before reducing
1750 the first one.
1751 * src/scan-gram.l (rule_length): New static var.
1752 Use it to keep track of the rule length in the scanner, since
1753 we can't expect the parser to be in lock-step sync with the scanner.
1754 (handle_action_dollar, handle_action_at): Use this var.
1755 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 1756
14904b89
PE
17572002-10-12 Paul Eggert <eggert@twinsun.com>
1758
1fe611e5
PE
1759 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1760 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1761 Include <sys/time.h> when checking for clock_t and struct tms.
1762 Use same include order as source.
1763 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1764 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
05846dae 1765
1fe611e5
PE
1766 * lib/timevar.c: Update copyright date and clarify comments.
1767 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 1768
1fe611e5
PE
1769 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1770 GCC version as of today, then merge Bison's changes.
1771 Change "GCC" to "Bison" in copyright notice. timevar.def's
1772 author is Akim, so change that too.
1773
98194095
PE
1774 * src/reader.c (grammar_current_rule_check):
1775 Don't worry about the default action if $$ is untyped.
1776 Prevents bogus warnings reported by Jim Gifford in
1777 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1778
14904b89
PE
1779 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1780 * data/glr.c, data/lalr1.cc, data/yacc.c:
1781 Output token definitions before the first part of user declarations.
1782 Fixes compatibility problem reported by Jim Gifford for kbd in
1783 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1784
ff6dca18
PE
17852002-10-11 Paul Eggert <eggert@twinsun.com>
1786
1787 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1788 (yyparse): here. This undoes some of the 2002-07-25 change.
1789 Compatibility problem reported by Ralf S. Engelschall with
1790 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1791
eb714592
AD
17922002-10-11 Akim Demaille <akim@epita.fr>
1793
1794 * tests/regression.at Characters Escapes): New.
1795 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1796 characters.
1797 Reported by Jan Nieuwenhuizen.
1798
b7195100
AD
17992002-10-11 Akim Demaille <akim@epita.fr>
1800
1801 * po/id.po: New.
1802
f28a0f2d
PE
18032002-10-10 Paul Eggert <eggert@twinsun.com>
1804
1805 Portability fixes for bitsets; this also avoids several GCC
1806 warnings.
1807
1808 * lib/abitset.c: Include <stddef.h>, for offsetof.
1809 * lib/lbitset.c: Likewise.
1810
1811 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1812 properly for vectors of objects. Do not assume that adding a
1813 header size to a multiple of a word size yields a value that is
1814 properly aligned for the whole union.
1815 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1816
1817 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1818 unique names for structures.
1819 * lib/ebitset.c (ebitset_bytes): Likewise.
1820 * lib/lbitset.c (lbitset_bytes): Likewise.
1821
1822 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1823 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1824 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1825 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1826 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1827 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1828 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1829 to improve the type-checking that GCC can do.
1830 * lib/bitset.c (bitset_op4_cmp): Likewise.
1831 * lib/bitset_stats.c (bitset_stats_count,
1832 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1833 bitset_stats_copy, bitset_stats_disjoint_p,
1834 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1835 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1836 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1837 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1838 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1839 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1840 bitset_stats_or_and_cmp): Likewise.
1841 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1842 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1843 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1844 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1845
1846 * lib/abitset.h: Include bitset.h, not bbitset.h.
1847 * lib/ebitset.h: Likewise.
1848 * lib/lbitset.h: Likewise.
1849
1850 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1851 All instances of parameters of type enum bitset_opts are now of
1852 type enum_bitset_opts, to conform to the C Standard, and similarly
1853 for enum_bitset_type.
1854 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1855 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1856
1857 Do not use "struct bitset_struct" to mean different things in
1858 different modules. Not only is this confusing, it violates
1859 the C Standard, which requires that structure types in different
1860 modules must be compatible if one is to be passed to the other.
1861 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1862 All instances of "struct bitset_struct *" replaced with "bitset".
1863 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1864 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1865 struct lbitset_struct, struct bitset_stats_struct): New types.
1866 All uses of struct bitset_struct changed to union bitset_union,
1867 etc.
1868 * lib/abitset.c (struct abitset_struct, abitset,
1869 struct bitset_struct): Remove.
1870 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1871 struct bitset_struct): Remove.
1872 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1873 bitset_struct): Remove.
1874 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1875 Likewise.
1876
1877 Do not call a function of type T using a call that assumes the
1878 function is of a different type U. Standard C requires that a
1879 function must be called with a type that is compatible with its
1880 definition.
1881 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1882 New decls.
1883 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
1884 New functions.
1885 * lib/ebitset.c (PFV): Remove.
1886 * lib/lbitset.c (PFV): Likewise.
1887 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
1888 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
1889 decls.
1890 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
1891 (ebitset_vtable): Use them.
1892 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
1893 lbitset_xor): New functions.
1894 (lbitset_vtable): Use them.
1895
1896 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
1897 Declare.
1898
1899 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
1900 GCC warning.
1901 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
1902 Use offsetof, for simplicity.
1903
6fbe4984
PE
19042002-10-06 Paul Eggert <eggert@twinsun.com>
1905
1906 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
1907 the same width as int. This reapplies a hunk of the 2002-08-12 patch
1908 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
1909 which was inadvertently undone by the 2002-09-30 patch.
1910 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
1911 the same width as int.
1912
420f93c8
PE
19132002-10-04 Paul Eggert <eggert@twinsun.com>
1914
1915 Version 1.50.
1916
1917 * configure.ac (AC_INIT), NEWS: Increment version number.
1918
1919 * doc/bison.texinfo: Minor spelling, grammar, and white space
1920 fixes.
1921 (Symbols): Mention that any negative value returned from yylex
1922 signifies end-of-input. Warn about negative chars. Mention
1923 the portable Standard C character set.
1924
1925 The GNU coding standard says CFLAGS and YFLAGS are reserved
1926 for the installer to set.
1927 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
1928 * src/Makefile.am (AM_CFLAGS): Likewise.
1929 (AM_YFLAGS): Renamed from YFLAGS.
1930
1931 Fix some MAX and MIN problems.
1932 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
1933 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
1934 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
1935 * src/reader.c (reader): Use it.
1936
1937 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
1938 POSIX 1003.1-2001 has removed fgrep.
1939
19402002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
1941
1942 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
1943 interpreted as signed.
1944 * lib/ebitset.c (ebitset_list): Fix bug.
1945
ff68026d
PE
19462002-10-01 Paul Eggert <eggert@twinsun.com>
1947
1948 More fixes for 64-bit hosts and large bitsets.
1949
1950 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
1951 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
1952 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
1953 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
1954 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
1955 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
1956 bitset_count_): Likewise.
1957 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
1958 bitset_first, bitset_last): Likewise.
1959 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
1960 bitset_stats_list_reverse, bitset_stats_size,
1961 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
1962 Likewise.
1963 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
1964 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1965 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1966 bitsetv_reflexive_transitive_closure): Likewise.
1967 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
1968 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
1969 Likewise.
1970 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
1971 Likewise.
420f93c8 1972
ff68026d
PE
1973 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
1974 Use size_t, not unsigned int, to count bytes.
1975 * lib/abitset.h (abitset_bytes): Likewise.
1976 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
1977 Likewise.
1978 * lib/bitset.h (bitset_bytes): Likewise.
1979 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
1980 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
1981 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1982 * lib/ebitset.c (ebitset_bytes): Likewise.
1983 * lib/ebitset.h (ebitset_bytes): Likewise.
1984 * lib/lbitset.c (lbitset_bytes): Likewise.
1985 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 1986
ff68026d
PE
1987 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
1988 abitset_subset_p, abitset_disjoint_p, abitset_and,
1989 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
1990 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
1991 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
1992 abitset_or_and, abitset_or_and_cmp):
1993 Use bitset_windex instead of unsigned int.
1994 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
1995 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
1996 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
1997 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
1998 Likewise.
1999 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 2000
ff68026d
PE
2001 * lib/bitset.c (bitset_print):
2002 Use proper printf formats for widths of integer types.
2003 * lib/bitset_stats.c (bitset_percent_histogram_print,
2004 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
2005 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2006 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2007 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 2008
ff68026d
PE
2009 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
2010 BITSET_SIZE_MAX): New macros.
2011 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
2012 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
2013 to BITSET_WINDEX_MAX.
2014
2015 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
2016 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
2017 since we now return the bitset_bindex type (not int).
2018
2019 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
2020 when computing sizes.
2021 * lib/ebitset.c (ebitset_elts_grow): Likewise.
2022
2023 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
2024 and avoid cast to unsigned.
2025
6aa452a6
AD
20262002-09-30 Akim Demaille <akim@epita.fr>
2027
2028 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
2029 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
2030 Updates from Michael Hayes.
2031
927f7817
AD
20322002-09-30 Art Haas <ahaas@neosoft.com>
2033
2034 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
2035 invocations.
2036 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
2037 defined.
2038
9738f41e
AD
20392002-09-27 Akim Demaille <akim@epita.fr>
2040
2041 Version 1.49c.
2042
a5c75d7f
AD
20432002-09-27 Akim Demaille <akim@epita.fr>
2044
2045 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
2046 (Because of AC_LIBSOURCE).
2047
8280e179
AD
20482002-09-27 Akim Demaille <akim@epita.fr>
2049
2050 Playing with Autoscan.
2051
2052 * configure.ac: Remove the old LIBOBJ tweaks.
2053 (AC_REPLACE_FUNCS): Add strrchr and strtol.
2054 * lib/strrchr.c: New.
2055 * lib/strtol.c: New, from the Coreutils 4.5.1.
2056
ae64af35
AD
20572002-09-27 Akim Demaille <akim@epita.fr>
2058
2059 Playing with Autoscan.
2060
2061 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
2062 * lib/Makefile.am (libbison_a_SOURCES): No longer include
2063 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
2064 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
2065 Coreutils 4.5.1.
2066
d1a1114f
AD
20672002-09-24 Akim Demaille <akim@epita.fr>
2068
2069 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
2070 (Frequently Asked Questions, Parser Stack Overflow): New.
2071
b906441c
AD
20722002-09-13 Akim Demaille <akim@epita.fr>
2073
2074 Playing with autoscan.
2075
2076 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
2077 * src/files.c (skeleton_find): Remove, unused.
2078 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
2079 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
2080
bd701811
AD
20812002-09-13 Akim Demaille <akim@epita.fr>
2082
2083 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
2084 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
2085
e0a13e7b
AD
20862002-09-13 Akim Demaille <akim@epita.fr>
2087
2088 * configure.ac: Require 2.54.
2089 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
2090 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
2091 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
2092 Remove, provided by Autoconf macros.
2093
c97011bf
AD
20942002-09-12 Akim Demaille <akim@epita.fr>
2095
2096 * m4/prereq.m4: Update, from Coreutils 4.5.1.
2097
d862b1be
AD
20982002-09-12 Akim Demaille <akim@epita.fr>
2099
2100 * m4/prereq.m4: Update, from Fileutils 4.1.5.
2101 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
2102 Reported by Martin Mokrejs.
2103
3d38c03a
AD
21042002-09-10 Akim Demaille <akim@epita.fr>
2105
2106 * src/parse-gram.y: Associate a human readable string to each
2107 token type.
2108 * tests/regression.at (Invalid inputs): Adjust.
2109
b6347355
AD
21102002-09-10 Gary V. Vaughan <gary@gnu.org>
2111
2112 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
2113 with an Autoconf-2.5x style configure.ac.
2114
09ba4ab2
PE
21152002-09-06 Paul Eggert <eggert@twinsun.com>
2116
2117 * doc/bison.texinfo (Conditions): Make explicit that the GPL
2118 exception applies only to yacc.c. This is a modification of a
2119 patch originally suggested by Akim Demaille.
2120
21846f69
AD
21212002-09-06 Akim Demaille <akim@epita.fr>
2122
09ba4ab2
PE
2123 * data/c.m4 (b4_copyright): Move the GPL exception comment from
2124 here to...
2125 * data/yacc.c: here.
2126
21846f69
AD
2127 * data/lalr1.cc (struct yyltype): Don't define it, since we use
2128 LocationType.
2129 (b4_ltype): Default to yy::Location from location.hh.
2130
c0ad8bf3
AD
21312002-09-04 Jim Meyering <jim@meyering.net>
2132
2133 * data/yacc.c: Guard the declaration of yytoknum also with
2134 `#ifdef YYPRINT', so it is declared only when used.
2135
3a93251e
AD
21362002-09-04 Akim Demaille <akim@epita.fr>
2137
2138 * configure.in: Rename as...
2139 * configure.ac: this.
2140 Bump to 1.49c.
2141
427c0dda
AD
21422002-09-04 Akim Demaille <akim@epita.fr>
2143
2144 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
2145 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
2146 translate maintainer only messages.
2147
6a254321
PE
21482002-08-12 Paul Eggert <eggert@twinsun.com>
2149
645e30d1
PE
2150 Version 1.49b.
2151
6a254321
PE
2152 * Makefile.am (SUBDIRS): Remove intl.
2153 (DISTCLEANFILES): Remove.
2154 * NEWS: Mention that GNU M4 is now required. Clarify what is
2155 meant by "larger grammars". Mention the pt_BR translation.
2156 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
2157 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
2158 Bump version from 0.11.2 to 0.11.5.
2159 (BISON_PREREQ_STAGE): Remove.
2160 (AM_GNU_GETTEXT): Use external gettext.
2161 (AC_OUTPUT): Remove intl/Makefile.
2162
2163 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
2164
2165 * data/glr.c: Include string.h, for strlen.
2166 (yyreportParseError): Use size_t for yysize.
2167 (yy_yypstack): No longer nested inside yypstates, as nested
2168 functions are not portable. Do not assume size_t is the
2169 same width as int.
2170 (yypstates): Do not assume that ptrdiff_t is the same width
2171 as int, and similarly for yyposn and YYINDEX.
2172
2173 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
2174
2175 * lib/Makefile.am (INCLUDES): Do not include from the intl
2176 directory, which has been removed.
2177 * src/Makefile.am (INCLUDES): Likewise.
2178
2179 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
2180 (bitsets_sources, additional_bitsets_sources, timevars_sources):
2181 New vars.
2182
2183 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
2184 * tests/Makefile.am (EXTRA_DIST): Likewise.
2185
2186 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
2187 Do not assume that bitset_windex is the same width as unsigned.
2188
2189 * lib/abitset.c (abitset_unused_clear): Do not assume that
2190 bitset_word is the same width as int.
2191 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
2192 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
2193 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
2194 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
2195 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
2196
2197 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
2198 portability to one's complement hosts!).
2199 * lib/ebitset.c (ebitset_op1): Likewise.
2200 * lib/lbitset.c (lbitset_op1): Likewise.
2201
2202 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
2203 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
2204 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
2205 Sync with fileutils.
2206 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
2207 lib/gettext.h: Sync with diffutils.
2208
2209 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
2210 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
2211
2212 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
2213 PROTOTYPES to check for prototypes, and "defined __STDC__" to
2214 check for void *.
2215
2216 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
2217 size_t; the old version tried to do this but casted improperly.
2218 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
2219 (bitset_test): Now returns int, not unsigned long.
2220
2221 * lib/bitset_stats.c: Include "gettext.h".
2222 (_): New macro.
2223 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
2224 name locals "index", as it generates unnecessary warnings on some
2225 hosts that have an "index" function.
2226
2227 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
2228 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
2229 they need translation.
2230 * src/LR0.c (state_list_append, new_itemsets, get_state,
2231 append_states, generate_states): Likewise.
2232 * src/assoc.c (assoc_to_string): Likewise.
2233 * src/closure.c (print_closure, set_firsts, closure): Likewise.
2234 * src/gram.c (grammar_dump): Likewise.
2235 * src/injections.c (injections_compute): Likewise.
2236 * src/lalr.c (lookaheads_print): Likewise.
2237 * src/relation.c (relation_transpose): Likewise.
2238 * src/scan-gram.l: Likewise.
2239 * src/tables.c (table_grow, pack_vector): Likewise.
2240
2241 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
2242 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
2243 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
2244 * m4/mbstate_t.m4: Sync with fileutils.
2245 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
2246
2247 * po/LINGUAS: Add pt_BR.
2248 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
2249 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
2250 lib/timevar.c.
2251 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
2252 manual recommends.
2253 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
2254
2255 * src/complain.c (strerror_r): Remove decl; not needed.
2256 (strerror): Use same pattern as ../lib/error.c.
2257
2258 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
2259
2260 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
2261
2262 * src/main.c (main): Cast result of bindtextdomain and textdomain
2263 to void, to avoid a GCC warning when --disable-nls is in effect.
2264
2265 * src/scan-gram.l: Use strings rather than escapes when possible,
2266 to minimize the number of warnings from xgettext.
2267 (handle_action_dollar, handle_action_at): Don't use isdigit,
2268 as it mishandles negative chars and it may not work as expected
2269 outside the C locale.
2270
2271 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
2272 this is a GCC extension and is not portable to other compilers.
2273
2274 * src/system.h (alloca): Use same pattern as ../lib/error.c.
2275 Do not include <ctype.h>; no longer needed.
2276 Do not include <malloc.h>; no longer needed (and generates
2277 warnings on OpenBSD 3.0).
2278
2279 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
2280 it's not portable.
2281
2282 * tests/regression.at: Do not use 'cc -c input.c -o input';
2283 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
2284
2285 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
2286 exit status as failure, not just exit status 1. Sun C exits
2287 with status 2 sometimes.
2288
2289 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
2290 Use it for the two large tests.
2291
c8f002c7
AD
22922002-08-02 Akim Demaille <akim@epita.fr>
2293
2294 * src/conflicts.c (conflicts_output): Don't output rules never
2295 reduced here, since anyway that computation doesn't work.
2296 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
2297 (rule_useless_p, rule_never_reduced_p): New.
2298 (grammar_rules_partial_print): Use a filter instead of a range.
2299 Display the title only if needed.
2300 (grammar_rules_print): Adjust.
2301 (grammar_rules_never_reduced_report): New.
2302 * src/tables.c (action_row): Move the computation of rules never
2303 reduced to...
2304 (token_actions): here.
2305 * src/main.c (main): Make the parser before making the report, so
2306 that rules never reduced are computed.
2307 Call grammar_rules_never_reduced_report.
2308 * src/print.c (print_results): Report rules never reduced.
2309 * tests/conflicts.at, tests/reduce.at: Adjust.
2310
cd08e51e
AD
23112002-08-01 Akim Demaille <akim@epita.fr>
2312
2313 Instead of attaching lookaheads and duplicating the rules being
2314 reduced by a state, attach the lookaheads to the reductions.
2315
2316 * src/state.h (state_t): Remove the `lookaheads',
2317 `lookaheads_rule' member.
2318 (reductions_t): Add a `lookaheads' member.
2319 Use a regular array for the `rules'.
2320 * src/state.c (reductions_new): Initialize the lookaheads member
2321 to 0.
2322 (state_rule_lookaheads_print): Adjust.
2323 * src/state.h, src/state.c (state_reductions_find): New.
2324 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
2325 (count_rr_conflicts): Adjust.
2326 * src/lalr.c (LArule): Remove.
2327 (add_lookback_edge): Adjust.
2328 (state_lookaheads_count): New.
2329 (states_lookaheads_initialize): Merge into...
2330 (initialize_LA): this.
2331 (lalr_free): Adjust.
2332 * src/main.c (main): Don't free nullable and derives too early: it
2333 is used by --verbose.
2334 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
2335
bb0027a9
AD
23362002-08-01 Akim Demaille <akim@epita.fr>
2337
2338 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
2339 `rule_number_t**'.
2340 (set_derives, free_derives): Rename as...
2341 (derives_compute, derives_free): this.
2342 Adjust all dependencies.
2343 * src/nullable.c (set_nullable, free_nullable): Rename as...
2344 (nullable_compute, nullable_free): these.
2345 (rule_list_t): Store rule_t *, not rule_number_t.
2346 * src/state.c (state_rule_lookaheads_print): Directly compare rule
2347 pointers, instead of their numbers.
2348 * src/main.c (main): Call nullable_free, and derives_free earlier,
2349 as they were lo longer used.
2350
3325ddc4
AD
23512002-08-01 Akim Demaille <akim@epita.fr>
2352
2353 * lib/timevar.c (get_time): Include children time.
2354 * src/lalr.h (LA, LArule): Don't export them: used with the
2355 state_t.
2356 * src/lalr.c (LA, LArule): Static.
2357 * src/lalr.h, src/lalr.c (lalr_free): New.
2358 * src/main.c (main): Call it.
2359 * src/tables.c (pack_vector): Check whether loc is >= to the
2360 table_size, not >.
2361 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
2362 (tables_generate): do it, since that's also it which allocates
2363 them.
2364 Don't free LA and LArule, main does.
2365
c6f1a33c
AD
23662002-07-31 Akim Demaille <akim@epita.fr>
2367
2368 Separate parser tables computation and output.
2369
2370 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
2371 (conflict_list, conflict_list_cnt, table, check, table_ninf)
2372 (yydefgoto, yydefact, high): Move to...
2373 * src/tables.h, src/tables.c: here.
2374 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2375 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2376 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
2377 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
2378 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2379 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2380 (action_row, save_row, token_actions, save_column, default_goto)
2381 (goto_actions, sort_actions, matching_state, pack_vector)
2382 (table_ninf_remap, pack_table, prepare_actions): Move to...
2383 * src/tables.c: here.
2384 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2385 * src/output.c (token_actions, output_base, output_conflicts)
2386 (output_check): Merge into...
2387 (prepare_actions): this.
2388 (actions_output): Rename as...
2389 (user_actions_output): this.
2390 * src/main.c (main): Call tables_generate and tables_free.
2391
1509d42f
AD
23922002-07-31 Akim Demaille <akim@epita.fr>
2393
2394 Steal GCC's --time-report support.
2395
2396 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2397 stolen/adjusted from GCC.
2398 * m4/stage.m4: Remove time related checks.
2399 * m4/timevar.m4: New.
2400 * configure.in: Adjust.
2401 * src/system.h: Adjust to using timevar.h.
2402 * src/getargs.h, src/getargs.c: Support trace_time for
2403 --trace=time.
2404 * src/main.c (stage): Remove.
2405 (main): Replace `stage' invocations with timevar calls.
2406 * src/output.c: Insert pertinent timevar calls.
2407
273a74fa
AD
24082002-07-31 Akim Demaille <akim@epita.fr>
2409
2410 Let --trace have arguments.
2411
2412 * src/getargs.h (enum trace_e): New.
2413 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2414 (long_options, short_options): --trace/-T takes an optional
2415 argument.
2416 Change all the uses of trace_flag to reflect the new flags.
2417 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2418
2419 Strengthen `stage' portability.
2420
2421 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2422 * configure.in: Use it.
2423 Don't check for malloc.h and sys/times.h.
2424 * src/system.h: Include them when appropriate.
2425 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2426 times and struct tms are available.
2427
217598da
AD
24282002-07-30 Akim Demaille <akim@epita.fr>
2429
2430 In verbose parse error message, don't report `error' as an
2431 expected token.
2432 * tests/actions.at (Printers and Destructors): Adjust.
2433 * tests/calc.at (Calculator $1): Adjust.
2434 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2435 error message, do not report the parser accepts the error token in
2436 that state.
2437
52489d44
AD
24382002-07-30 Akim Demaille <akim@epita.fr>
2439
2440 Normalize conflict related messages.
2441
2442 * src/complain.h, src/complain.c (warn, complain): New.
2443 * src/conflicts.c (conflicts_print): Use them.
2444 (conflict_report_yacc): New, extracted from...
2445 (conflicts_print): here.
2446 * tests/conflicts.at, tests/existing.at: Adjust.
2447
e8832397
AD
24482002-07-30 Akim Demaille <akim@epita.fr>
2449
2450 Report rules which are never reduced by the parser: those hidden
2451 by conflicts.
2452
2453 * src/LR0.c (save_reductions): Don't make the final state too
2454 different: save its reduction (accept) instead of having a state
2455 without any action (no shift or goto, no reduce).
2456 Note: the final state is now a ``regular'' state, i.e., the
2457 parsers now contain `reduce 0' as default reduction.
2458 Nevertheless, since they decide to `accept' when yystate =
2459 final_state, they still will not reduce rule 0.
2460 * src/print.c (print_actions, print_reduction): Adjust.
2461 * src/output.c (action_row): Track reduced rules.
2462 (token_actions): Report rules never reduced.
2463 * tests/conflicts.at, tests/regression.at: Adjust.
2464
caf23d24
AD
24652002-07-30 Akim Demaille <akim@epita.fr>
2466
2467 `stage' was accidently included in a previous patch.
2468 Initiate its autoconfiscation.
2469
2470 * configure.in: Look for malloc.h and sys/times.h.
2471 * src/main.c (stage): Adjust.
2472 Report only when trace_flag.
2473
640748ee
AD
24742002-07-29 Akim Demaille <akim@epita.fr>
2475
2476 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2477 state_number_t.
2478 (errs_t): symbol_t*, not symbol_number_t.
2479 (reductions_t): rule_t*, not rule_number_t.
2480 (FOR_EACH_SHIFT): New.
2481 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2482 * src/print.c, src/print_graph.c: Adjust.
2483
88bce5a2
AD
24842002-07-29 Akim Demaille <akim@epita.fr>
2485
2486 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2487
2488 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2489 (endtoken, accept): these.
2490 * src/reader.c (reader): Set endtoken's default tag to "$end".
2491 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2492 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2493 Adjust.
2494
1bfb97db
AD
24952002-07-29 Akim Demaille <akim@epita.fr>
2496
2497 * src/reduce.c (reduce_grammar): When the language is empty,
2498 complain about the start symbol, not the axiom.
2499 Use its location.
2500 * tests/reduce.at (Empty Language): New.
2501
fc5734fe
AD
25022002-07-26 Akim Demaille <akim@epita.fr>
2503
2504 * src/reader.h, src/reader.c (gram_error): ... can't get
2505 yycontrol without making too strong assumptions on the parser
2506 itself.
2507 * src/output.c (prepare_tokens): Use the real 0th value of
2508 token_translations instead of `0'.
2509 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2510 visible here.
2511 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2512 for the time being: %locations ought to provide it to yyerror.
2513
3650b4b8
AD
25142002-07-25 Akim Demaille <akim@epita.fr>
2515
2516 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2517 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2518 * tests/regression.at (Web2c Actions): Adjust.
2519
4b3d3a8e
AD
25202002-07-25 Akim Demaille <akim@epita.fr>
2521
2522 Stop storing rules from 1 to nrules + 1.
2523
2524 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2525 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2526 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2527 Iterate from 0 to nrules.
2528 Use rule_number_as_item_number and item_number_as_rule_number.
2529 Adjust to `derive' now containing possibly 0.
2530 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2531 Handle the `- 1' part in rule numbers from/to item numbers.
2532 * src/conflicts.c (log_resolution): Fix the message which reversed
2533 shift and reduce.
2534 * src/output.c (action_row): Initialize default_rule to -1.
2535 (token_actions): Adjust.
2536 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2537 expected output.
2538 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2539
4a2a22f4
AD
25402002-07-25 Akim Demaille <akim@epita.fr>
2541
2542 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2543 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2544 (b4_c_knr_arg_decl): New.
2545 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2546 yyreport_parse_error.
2547
b8df3223
AD
25482002-07-25 Akim Demaille <akim@epita.fr>
2549
2550 * data/yacc.c (yyreport_parse_error): New, extracted from...
2551 (yyparse): here.
2552 (yydestruct, yysymprint): Move above yyparse.
2553 Be K&R compliant.
2554
a762e609
AD
25552002-07-25 Akim Demaille <akim@epita.fr>
2556
2557 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2558 replace...
2559 (b4_sint_type, b4_uint_type): these.
2560 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2561 * tests/regression.at (Web2c Actions): Adjust.
2562
12b0043a
AD
25632002-07-25 Akim Demaille <akim@epita.fr>
2564
2565 * src/gram.h (TIEM_NUMBER_MAX): New.
2566 (item_number_of_rule_number, rule_number_of_item_number): Rename
2567 as...
2568 (rule_number_as_item_number, item_number_as_rule_number): these.
2569 Adjust dependencies.
2570 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2571 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2572 (symbol_number_to_vector_number): New.
2573 (order): Of vector_number_t* type.
2574 (base_t, BASE_MAX, BASE_MIN): New.
2575 (froms, tos, width, pos, check): Of base_t type.
2576 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2577 (actrow): Of action_number_t type.
2578 (conflrow): Of unsigned int type.
2579 (table_ninf, base_ninf): New.
2580 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2581 (muscle_insert_int_table, muscle_insert_base_table)
2582 (muscle_insert_rule_number_table): New.
2583 (prepare_tokens): Output `toknum' as int_table.
2584 (action_row): Returns a rule_number_t.
2585 Use ACTION_MIN, not SHRT_MIN.
2586 (token_actions): yydefact is rule_number_t*.
2587 (table_ninf_remap): New.
2588 (pack_table): Use it for `base' and `table'.
2589 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2590 replaced with...
2591 (YYPACT_NINF, YYTABLE_NINF): these.
2592 (yypact, yytable): Compute their types instead of hard-coded
2593 `short'.
2594 * tests/regression.at (Web2c Actions): Adjust.
2595
5dde258a
AD
25962002-07-19 Akim Demaille <akim@epita.fr>
2597
2598 * src/scan-gram.l (id): Can start with an underscore.
2599
a945ec39
AD
26002002-07-16 Akim Demaille <akim@epita.fr>
2601
2602 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2603 Adjust all former `associativity' dependencies.
2604 * src/symtab.c (symbol_new): Default associativity is `undef', not
2605 `right'.
2606 (symbol_check_alias_consistence): Adjust.
2607
fae437e8
AD
26082002-07-09 Akim Demaille <akim@epita.fr>
2609
2610 * doc/bison.texinfo: Properly set the ``header'' part.
2611 Use @dircategory ``GNU programming tools'' as per Texinfo's
2612 documentation.
2613 Use @copying.
2614
1a715ef2
AD
26152002-07-09 Akim Demaille <akim@epita.fr>
2616
2617 * lib/quotearg.h: Protect against multiple inclusions.
2618 * src/location.h (location_t): Add a `file' member.
2619 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2620 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2621 `error_one_per_line' support.
2622
a5d50994
AD
26232002-07-09 Akim Demaille <akim@epita.fr>
2624
2625 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2626 * src/reader.c (lineno): Remove.
2627 Adjust all dependencies.
2628 (get_merge_function): Take a location and use complain_at.
2629 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2630 * tests/regression.at (Invalid inputs, Mixing %token styles):
2631 Adjust.
2632
b275314e
AD
26332002-07-09 Akim Demaille <akim@epita.fr>
2634
2635 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2636 recovery rule, and forbid extensions when --yacc.
2637 (gram_error): Use complain_at.
2638 * src/reader.c (reader): Exit if there were parse errors.
2639
865b9df1
AD
26402002-07-09 Akim Demaille <akim@epita.fr>
2641
2642 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2643 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2644 Reported by R Blake <blakers@mac.com>.
2645
c76e14da
AD
26462002-07-09 Akim Demaille <akim@epita.fr>
2647
2648 * data/yacc.c: Output the copyright notive in the header.
2649
7db2ed2d
AD
26502002-07-03 Akim Demaille <akim@epita.fr>
2651
2652 * src/output.c (froms, tos): Are state_number_t.
2653 (save_column): sp, sp1, and sp2 are state_number_t.
2654 (prepare): Rename `final' as `final_state_number', `nnts' as
2655 `nterms_number', `nrules' as `rules_number', `nstates' as
2656 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2657 unused.
2658 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2659 * data/lalr1.cc (nsym_): Remove, unused.
2660
e68e0410
AD
26612002-07-03 Akim Demaille <akim@epita.fr>
2662
2663 * src/lalr.h, src/lalr.c (goto_number_t): New.
2664 * src/lalr.c (goto_list_t): New.
2665 Propagate them.
2666 * src/nullable.c (rule_list_t): New.
2667 Propagate.
2668 * src/types.h: Remove.
2669
e1a4f3a4
AD
26702002-07-03 Akim Demaille <akim@epita.fr>
2671
2672 * src/closure.c (print_fderives): Use rule_rhs_print.
2673 * src/derives.c (print_derives): Use rule_rhs_print.
2674 (rule_list_t): New, replaces `shorts'.
2675 (set_derives): Add comments.
2676 * tests/sets.at (Nullable, Firsts): Adjust.
2677
536545f3
AD
26782002-07-03 Akim Demaille <akim@epita.fr>
2679
2680 * src/output.c (prepare_actions): Free `tally' and `width'.
2681 (prepare_actions): Allocate and free `order'.
2682 * src/symtab.c (symbols_free): Free `symbols'.
2683 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2684 * src/output.c (m4_invoke): Move to...
2685 * src/scan-skel.l: here.
2686 (<<EOF>>): Close yyout, and free its name.
2687
8b752b00
AD
26882002-07-03 Akim Demaille <akim@epita.fr>
2689
2690 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2691
2692 * src/LR0.c (new_state): Merge into...
2693 (state_list_append): this.
2694 (new_states): Merge into...
2695 (generate_states): here.
2696 (set_states): Don't ensure a proper `errs' state member here, do it...
2697 * src/conflicts.c (conflicts_solve): here.
2698 * src/state.h, src/state.c: Comment changes.
2699 (state_t): Rename member `shifts' as `transitions'.
2700 Adjust all dependencies.
2701 (errs_new): For consistency, also take the values as argument.
2702 (errs_dup): Remove.
2703 (state_errs_set): New.
2704 (state_reductions_set, state_transitions_set): Assert that no
2705 previous value was assigned.
2706 (state_free): New.
2707 (states_free): Use it.
2708 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2709 temporary storage: use `errs' and `nerrs' as elsewhere.
2710 (set_conflicts): Allocate and free this `errs'.
2711
613f5e1a
AD
27122002-07-02 Akim Demaille <akim@epita.fr>
2713
2714 * lib/libiberty.h: New.
2715 * lib: Update the bitset implementation from upstream.
2716 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2717 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2718 * src/main.c: Adjust bitset stats calls.
2719
26e0cadc
PE
27202002-07-01 Paul Eggert <eggert@twinsun.com>
2721
2722 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2723 char, so that negative chars don't collide with $.
2724
1154cced
AD
27252002-06-30 Akim Demaille <akim@epita.fr>
2726
2727 Have the GLR tests be `warning' checked, and fix the warnings.
2728
2729 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2730 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2731 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2732 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2733 (yyaddDeferredAction): static.
2734 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2735 (yyreportParseError): yyprefix is const.
2736 yytokenp is used only when verbose.
2737 (yy__GNUC__): Replace with __GNUC__.
2738 (yypdumpstack): yyi is size_t.
2739 (yypreference): Un-yy local variables and arguments, to avoid
2740 clashes with `yyr1'. Anyway, we are not in the user name space.
2741 (yytname_size): be an int, as is compared with ints.
2742 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2743 Use them.
2744 * tests/cxx-gram.at: Use quotation to protect $1.
2745 Use AT_COMPILE to enable warnings hunts.
2746 Prototype yylex and yyerror.
2747 `Use' argc.
2748 Include `string.h', not `strings.h'.
2749 Produce and prototype stmtMerge only when used.
2750 yylex takes a location.
2751
97650f4e
AD
27522002-06-30 Akim Demaille <akim@epita.fr>
2753
2754 We spend a lot of time in quotearg, in particular when --verbose.
2755
2756 * src/symtab.c (symbol_get): Store a quoted version of the key.
2757 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2758 Adjust all callers.
2759
d2576365
AD
27602002-06-30 Akim Demaille <akim@epita.fr>
2761
2762 * src/state.h (reductions_t): Rename member `nreds' as num.
2763 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2764 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2765
ccaf65bc
AD
27662002-06-30 Akim Demaille <akim@epita.fr>
2767
2768 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2769 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2770 (shifts_to): Rename as...
2771 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2772 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2773 (TRANSITION_IS_DISABLED, transitions_to): these.
2774
87675353
AD
27752002-06-30 Akim Demaille <akim@epita.fr>
2776
2777 * src/print.c (print_shifts, print_gotos): Merge into...
2778 (print_transitions): this.
2779 (print_transitions, print_errs, print_reductions): Align the
2780 lookaheads columns.
2781 (print_core, print_transitions, print_errs, print_state,
2782 print_grammar): Output empty lines separator before, not after.
2783 (state_default_rule_compute): Rename as...
2784 (state_default_rule): this.
2785 * tests/conflicts.at (Defaulted Conflicted Reduction),
2786 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2787 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2788
ce4ccb4b
AD
27892002-06-30 Akim Demaille <akim@epita.fr>
2790
2791 Display items as we display rules.
2792
2793 * src/gram.h, src/gram.c (rule_lhs_print): New.
2794 * src/gram.c (grammar_rules_partial_print): Use it.
2795 * src/print.c (print_core): Likewise.
2796 * tests/conflicts.at (Defaulted Conflicted Reduction),
2797 (Unresolved SR Conflicts): Adjust.
2798 (Unresolved SR Conflicts): Adjust and rename as...
2799 (Resolved SR Conflicts): this, as was meant.
2800 * tests/regression.at (Web2c Report): Adjust.
2801
bc933ef1
AD
28022002-06-30 Akim Demaille <akim@epita.fr>
2803
2804 * src/print.c (state_default_rule_compute): New, extracted from...
2805 (print_reductions): here.
2806 Pessimize, but clarify the code.
2807 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2808
53d4308d
AD
28092002-06-30 Akim Demaille <akim@epita.fr>
2810
2811 * src/output.c (action_row): Let default_rule be always a rule
2812 number.
2813
574fb2d5
AD
28142002-06-30 Akim Demaille <akim@epita.fr>
2815
2816 * src/closure.c (print_firsts, print_fderives, closure):
2817 Use BITSET_EXECUTE.
2818 * src/lalr.c (lookaheads_print): Likewise.
2819 * src/state.c (state_rule_lookaheads_print): Likewise.
2820 * src/print_graph.c (print_core): Likewise.
2821 * src/print.c (print_reductions): Likewise.
2822 * src/output.c (action_row): Likewise.
2823 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2824
05811fd7
AD
28252002-06-30 Akim Demaille <akim@epita.fr>
2826
2827 * src/print_graph.c: Use report_flag.
2828
0e4d5753
AD
28292002-06-30 Akim Demaille <akim@epita.fr>
2830
2831 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2832 to...
2833 * src/relation.h, src/relation.c (traverse, relation_digraph)
2834 (relation_print, relation_transpose): New.
2835
24c7d800
AD
28362002-06-30 Akim Demaille <akim@epita.fr>
2837
2838 * src/state.h, src/state.c (shifts_to): New.
2839 * src/lalr.c (build_relations): Use it.
2840
9222837b
AD
28412002-06-30 Akim Demaille <akim@epita.fr>
2842
2843 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2844 (item_number_of_rule_number, rule_number_of_item_number): New.
2845 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2846 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2847 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2848 Propagate their use.
2849 Much remains to be done, in particular wrt `shorts' from types.h.
2850
260008e5
AD
28512002-06-30 Akim Demaille <akim@epita.fr>
2852
2853 * src/symtab.c (symbol_new): Initialize the `printer' member.
2854
8a731ca8
AD
28552002-06-30 Akim Demaille <akim@epita.fr>
2856
2857 * src/LR0.c (save_reductions): Remove, replaced by...
2858 * src/state.h, src/state.c (state_reductions_set): New.
2859 (reductions, errs): Rename as...
2860 (reductions_t, errs_t): these.
2861 Adjust all dependencies.
2862
32e1e0a4
AD
28632002-06-30 Akim Demaille <akim@epita.fr>
2864
2865 * src/LR0.c (state_list_t, state_list_append): New.
2866 (first_state, last_state): Now symbol_list_t.
2867 (this_state): Remove.
2868 (new_itemsets, append_states, save_reductions): Take a state_t as
2869 argument.
2870 (set_states, generate_states): Adjust.
2871 (save_shifts): Remove, replaced by...
2872 * src/state.h, src/state.c (state_shifts_set): New.
2873 (shifts): Rename as...
2874 (shifts_t): this.
2875 Adjust all dependencies.
2876 * src/state.h (state_t): Remove the `next' member.
2877
e5fb6710
AD
28782002-06-30 Akim Demaille <akim@epita.fr>
2879
2880 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2881 escaped in slot 0.
2882
c7ca99d4
AD
28832002-06-30 Akim Demaille <akim@epita.fr>
2884
2885 Use hash.h for the state hash table.
2886
2887 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
2888 (allocate_storage): Use state_hash_new.
2889 (free_storage): Use state_hash_free.
2890 (new_state, get_state): Adjust.
2891 * src/lalr.h, src/lalr.c (states): Move to...
2892 * src/states.h (state_t): Remove the `link' member, no longer
2893 used.
2894 * src/states.h, src/states.c: here.
2895 (state_hash_new, state_hash_free, state_hash_lookup)
2896 (state_hash_insert, states_free): New.
2897 * src/states.c (state_table, state_compare, state_hash): New.
2898 * src/output.c (output_actions): Do not free states now, since we
2899 still need to know the final_state number in `prepare', called
2900 afterwards. Do it...
2901 * src/main.c (main): here: call states_free after `output'.
2902
df0e7316
AD
29032002-06-30 Akim Demaille <akim@epita.fr>
2904
2905 * src/state.h, src/state.c (state_new): New, extracted from...
2906 * src/LR0.c (new_state): here.
2907 * src/state.h (STATE_ALLOC): Move to...
2908 * src/state.c: here.
2909 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
2910 * src/state.h, src/state.c: here.
2911
39f41916
AD
29122002-06-30 Akim Demaille <akim@epita.fr>
2913
2914 * src/reader.c (gensym): Rename as...
2915 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
2916 (getsym): Rename as...
2917 (symbol_get): this.
2918
d57650a5
AD
29192002-06-30 Akim Demaille <akim@epita.fr>
2920
2921 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
2922 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
2923 * src/output.c, src/print.c, src/print_graph.c: Propagate.
2924 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
2925
5a08f1ce
AD
29262002-06-30 Akim Demaille <akim@epita.fr>
2927
2928 Make the test suite pass with warnings checked.
2929
2930 * tests/actions.at (Printers and Destructors): Improve.
2931 Avoid unsigned vs. signed issues.
2932 * tests/calc.at: Don't exercise the scanner here, do it...
2933 * tests/input.at (Torturing the Scanner): here.
2934
720623af
PH
29352002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2936
88e7e941 2937 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
2938 reorganize first lines parallel to yacc.c.
2939
fb8135fa
AD
29402002-06-28 Akim Demaille <akim@epita.fr>
2941
2942 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
2943 (b4_token_enum, b4_token_defines): New, factored from...
2944 * data/lalr1.cc, data/yacc.c, glr.c: here.
2945
41442480
AD
29462002-06-28 Akim Demaille <akim@epita.fr>
2947
2948 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
2949 unused variables.
2950 * src/output.c (merger_output): static.
2951
e0e5bf84
AD
29522002-06-28 Akim Demaille <akim@epita.fr>
2953
2954 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
2955 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
2956 pacify GCC.
2957 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 2958
676385e2
PH
29592002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2960
2961 Accumulated changelog for new GLR parsing features.
2962
6a254321 2963 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
2964 conflicts_total_count.
2965 * src/conflicts.h: Ditto.
2966 * src/output.c (token_actions): Use the new name.
2967 (output_conflicts): Change conflp => conflict_list_heads, and
2968 confl => conflict_list for better readability.
2969 * data/glr.c: Use the new names.
2970 * NEWS: Add self to GLR announcement.
e0e5bf84 2971
676385e2
PH
2972 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
2973
2974 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
2975 Akim Demaille.
2976
2977 * data/bison.glr: Change name to glr.c
2978 * data/glr.c: Renamed from bison.glr.
2979 * data/Makefile.am: Add glr.c
e0e5bf84
AD
2980
2981 * src/getargs.c:
2982
676385e2
PH
2983 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
2984 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 2985
676385e2
PH
2986 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2987
2988 * data/bison.glr: Be sure to restore the
2989 current #line when returning to the skeleton contents after having
2990 exposed the input file's #line.
2991
2992 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2993
2994 * data/bison.glr: Bring up to date with changes to bison.simple.
2995
2996 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2997
2998 * data/bison.glr: Correct definitions that use b4_prefix.
2999 Various reformatting.
3000 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
3001 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
3002 yytokenp argument; now part of stack.
3003 (yychar): Define to behave as documented.
3004 (yyclearin): Ditto.
e0e5bf84 3005
676385e2
PH
3006 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3007
3008 * src/reader.h: Add declaration for free_merger_functions.
3009
3010 * src/reader.c (merge_functions): New variable.
3011 (get_merge_function): New function.
3012 (free_merger_functions): New function.
3013 (readgram): Check for %prec that is not followed by a symbol.
3014 Handle %dprec and %merge declarations.
3015 (packgram): Initialize dprec and merger fields in rules array.
3016
3017 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
3018 conflict_list_cnt, conflict_list_free): New variables.
3019 (table_grow): Also grow conflict_table.
e0e5bf84 3020 (prepare_rules): Output dprec and merger tables.
676385e2 3021 (conflict_row): New function.
e0e5bf84 3022 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
3023 default reduction in conflicted states for GLR parser so that there
3024 are spaces for the conflict lists.
3025 (save_row): Also save conflict information.
3026 (token_actions): Allocate conflict list.
3027 (merger_output): New function.
3028 (pack_vector): Pack conflict table, too.
3029 (output_conflicts): New function to output yyconflp and yyconfl.
3030 (output_check): Allocate conflict_tos.
3031 (output_actions): Output conflict tables, also.
3032 (output_skeleton): Output b4_mergers definition.
3033 (prepare): Output b4_max_rhs_length definition.
3034 Use 'bison.glr' as default skeleton for GLR parsers.
3035
3036 * src/gram.c (glr_parser): New flag.
3037 (grammar_free): Call free_merger_functions.
3038
3039 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
3040 all pairs of conflicting reductions, rather than just all tokens
3041 causing conflicts. Needed to size conflict tables.
e0e5bf84 3042 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
3043 interface.
3044 (conflicts_print): Ditto.
3045 (count_total_conflicts): New function.
3046
3047 * src/reader.h (merger_list): New type.
3048 (merge_functions): New variable.
3049
3050 * src/lex.h (tok_dprec, tok_merge): New token types.
3051
3052 * src/gram.h (rule_s): Add dprec and merger fields.
3053 (glr_parser): New flag.
3054
3055 * src/conflicts.h (count_total_conflicts): New function.
3056
3057 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
3058
3059 * doc/bison.texinfo (Generalized LR Parsing): New section.
3060 (GLR Parsers): New section.
3061 (Language and Grammar): Mention GLR parsing.
3062 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
3063 Correct typo ("tge" -> "the").
3064
3065 * data/bison.glr: New skeleton for GLR parsing.
3066
3067 * tests/cxx-gram.at: New tests for GLR parsing.
3068
3069 * tests/testsuite.at: Include cxx-gram.at.
3070
3071 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 3072
676385e2
PH
3073 * src/parse-gram.y:
3074
3075 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
3076
3077 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 3078
b5480d74 30792002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
3080
3081 * src/options.h, src/options.c: Remove.
3082 * src/getargs.c (short_options, long_options): New.
3083
60491a94
AD
30842002-06-27 Akim Demaille <akim@epita.fr>
3085
3086 * data/bison.simple, data/bison.c++: Rename as...
3087 * data/yacc.c, data/lalr1.cc: these.
3088 * doc/bison.texinfo (Environment Variables): Remove.
3089
9be0c25b
AD
30902002-06-25 Raja R Harinath <harinath@cs.umn.edu>
3091
3092 * src/getargs.c (report_argmatch): Initialize strtok().
3093
1ae72863
AD
30942002-06-20 Akim Demaille <akim@epita.fr>
3095
3096 * data/bison.simple (b4_symbol_actions): New, replaces...
3097 (b4_symbol_destructor, b4_symbol_printer): these.
3098 (yysymprint): Be sure to call YYPRINT only for tokens, and using
3099 user token numbers.
3100
87542d29
AD
31012002-06-20 Akim Demaille <akim@epita.fr>
3102
3103 * data/bison.simple (yydestructor): Rename as...
3104 (yydestruct): this.
3105
1a31ed21
AD
31062002-06-20 Akim Demaille <akim@epita.fr>
3107
3108 * src/symtab.h, src/symtab.c (symbol_type_set)
3109 (symbol_destructor_set, symbol_precedence_set): The location is
3110 the last argument.
3111 Adjust all callers.
3112
e776192e
AD
31132002-06-20 Akim Demaille <akim@epita.fr>
3114
3115 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
3116 internals.
3117 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
3118 Takes a location.
3119 * src/symtab.h, src/symtab.c (symbol_class_set)
3120 (symbol_user_token_number_set): Likewise.
3121 Adjust all callers.
3122 Promote complain_at.
3123 * tests/input.at (Type Clashes): Adjust.
3124
5c1180b3
AD
31252002-06-20 Akim Demaille <akim@epita.fr>
3126
3127 * data/bison.simple (YYLEX): Fix the declaration when
3128 %pure-parser.
3129
e3170060
AD
31302002-06-20 Akim Demaille <akim@epita.fr>
3131
3132 * data/bison.simple (yysymprint): Don't print the token number,
3133 just its name.
3134 * tests/actions.at (Destructors): Rename as...
3135 (Printers and Destructors): this.
3136 Also exercise %printer.
3137
253862fd
AD
31382002-06-20 Akim Demaille <akim@epita.fr>
3139
3140 * data/bison.simple (YYDSYMPRINT): New.
3141 Use it to remove many of the #if YYDEBUG/if (yydebug).
3142
366eea36
AD
31432002-06-20 Akim Demaille <akim@epita.fr>
3144
3145 * src/symtab.h, src/symtab.c (symbol_t): printer and
3146 printer_location are new members.
3147 (symbol_printer_set): New.
3148 * src/parse-gram.y (PERCENT_PRINTER): New token.
3149 Handle its associated rule.
3150 * src/scan-gram.l: Adjust.
3151 (handle_destructor_at, handle_destructor_dollar): Rename as...
3152 (handle_symbol_code_at, handle_symbol_code_dollar): these.
3153 * src/output.c (symbol_printers_output): New.
3154 (output_skeleton): Call it.
3155 * data/bison.simple (yysymprint): New. Cannot be named yyprint
3156 since there are already many grammar files with a user `yyprint'.
3157 Replace the calls to YYPRINT to calls to yysymprint.
3158 * tests/calc.at: Adjust.
3159 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
3160 taking advantage of parser very internal details (stack size!).
3161
4f25ebb0
AD
31622002-06-20 Akim Demaille <akim@epita.fr>
3163
3164 * src/scan-gram.l: Complete the scanner with the missing patterns
3165 to pacify Flex.
3166 Use `quote' and `symbol_tag_get' where appropriate.
3167
93b68a0e
AD
31682002-06-19 Akim Demaille <akim@epita.fr>
3169
3170 * tests/actions.at (Destructors): Augment to test locations.
3171 * data/bison.simple (yydestructor): Pass it the current location
3172 if locations are enabled.
3173 Prototype only when __STDC__ or C++.
3174 Change the argument names to move into the yy name space: there is
3175 user code here.
3176
58612f1d
AD
31772002-06-19 Akim Demaille <akim@epita.fr>
3178
74310291
AD
3179 * data/bison.simple (b4_pure_if): New.
3180 Use it instead of #ifdef YYPURE.
3181
31822002-06-19 Akim Demaille <akim@epita.fr>
3183
3184 * data/bison.simple (b4_location_if): New.
58612f1d
AD
3185 Use it instead of #ifdef YYLSP_NEEDED.
3186
f25bfb75
AD
31872002-06-19 Akim Demaille <akim@epita.fr>
3188
3189 Prepare @$ in %destructor, but currently don't bind it in the
3190 skeleton, as %location use is not cleaned up yet.
3191
3192 * src/scan-gram.l (handle_dollar, handle_destructor_at)
3193 (handle_action_at): New.
3194 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
3195 a braced_code_t and a location as additional arguments.
3196 (handle_destructor_dollar): Instead of requiring `b4_eval', just
3197 unquote one when outputting `b4_dollar_dollar'.
3198 Adjust callers.
3199 * data/bison.simple (b4_eval): Remove.
3200 (b4_symbol_destructor): Adjust.
3201 * tests/input.at (Invalid @n): Adjust.
3202
c732d2c6
AD
32032002-06-19 Zack Weinberg <zack@codesourcery.com>
3204
3205 * doc/bison.texinfo: Document ability to have multiple
3206 prologue sections.
3207
8c165d89
AD
32082002-06-18 Akim Demaille <akim@epita.fr>
3209
3210 * src/files.c (compute_base_names): When computing the output file
3211 names from the input file name, strip the directory part.
3212
ca98bf57
AD
32132002-06-18 Akim Demaille <akim@epita.fr>
3214
3215 * data/bison.simple.new: Comment changes.
3216 Reported by Andreas Schwab.
3217
0bfb02ff
AD
32182002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
3219
3220 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
3221 there are no `label `yyoverflowlab' defined but not used' warnings
3222 when yyoverflow is defined.
3223
24c0aad7
AD
32242002-06-18 Akim Demaille <akim@epita.fr>
3225
3226 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
3227 new member.
3228 (symbol_destructor_set): Adjust.
3229 * src/output.c (symbol_destructors_output): Output the destructor
3230 locations.
3231 Output the symbol name.
3232 * data/bison.simple (b4_symbol_destructor): Adjust.
3233
5719c109
AD
32342002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
3235 and Akim Demaille <akim@epita.fr>
3236
3237 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
3238 what's left on the stack when the error recovery hits EOF.
3239 * tests/actions.at (Destructors): Complete to exercise this case.
3240
9280d3ef
AD
32412002-06-17 Akim Demaille <akim@epita.fr>
3242
3243 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
3244 arguments is really empty, not only equal to `[]'.
3245 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
3246 member.
3247 (symbol_destructor_set): New.
3248 * src/output.c (symbol_destructors_output): New.
3249 * src/reader.h (brace_code_t, current_braced_code): New.
3250 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
3251 (handle_dollar): Rename as...
3252 (handle_action_dollar): this.
3253 (handle_destructor_dollar): New.
3254 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
3255 (grammar_declaration): Use it.
3256 * data/bison.simple (yystos): Is always defined.
3257 (yydestructor): New.
3258 * tests/actions.at (Destructors): New.
3259 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
3260
dafdc66f
AD
32612002-06-17 Akim Demaille <akim@epita.fr>
3262
3263 * src/symlist.h, src/symlist.c (symbol_list_length): New.
3264 * src/scan-gram.l (handle_dollar, handle_at): Compute the
3265 rule_length only when needed.
3266 * src/output.c (actions_output, token_definitions_output): Output
3267 the full M4 block.
3268 * src/symtab.c: Don't access directly to the symbol tag, use
3269 symbol_tag_get.
3270 * src/parse-gram.y: Use symbol_list_free.
3271
56c47203
AD
32722002-06-17 Akim Demaille <akim@epita.fr>
3273
3274 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
3275 (symbol_list_prepend, get_type_name): Move to...
3276 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
3277 (symbol_list_prepend, symbol_list_n_type_name_get): here.
3278 Adjust all callers.
3279 (symbol_list_free): New.
3280 * src/scan-gram.l (handle_dollar): Takes a location.
3281 * tests/input.at (Invalid $n): Adjust.
3282
1e0bab92
AD
32832002-06-17 Akim Demaille <akim@epita.fr>
3284
3285 * src/reader.h, src/reader.c (symbol_list_new): Export it.
3286 (symbol_list_prepend): New.
3287 * src/parse-gram.y (%union): `list' is a new member.
3288 (symbols.1): New, replaces...
3289 (terms_to_prec.1, nterms_to_type.1): these.
3290 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
3291 Take a location as additional argument.
3292 Adjust all callers.
3293
04e60654
AD
32942002-06-15 Akim Demaille <akim@epita.fr>
3295
3296 * src/parse-gram.y: Move %token in the declaration section so that
3297 we don't depend upon CVS Bison.
3298
10e5b8bd
AD
32992002-06-15 Akim Demaille <akim@epita.fr>
3300
3301 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
3302 * src/print.c (print_core): Use it.
3303
9801d40c
AD
33042002-06-15 Akim Demaille <akim@epita.fr>
3305
3306 * src/conflicts.c (log_resolution): Accept the rule involved in
3307 the sr conflicts instead of the lookahead number that points to
3308 that rule.
3309 (flush_reduce): Accept the current lookahead vector as argument,
3310 instead of the index in LA.
3311 (resolve_sr_conflict): Accept the current number of lookahead
3312 bitset to consider for the STATE, instead of the index in LA.
3313 (set_conflicts): Adjust.
3314 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
3315
c0263492
AD
33162002-06-15 Akim Demaille <akim@epita.fr>
3317
3318 * src/state.h (state_t): Replace the `lookaheadsp' member, a
3319 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
3320 Adjust all dependencies.
3321 * src/lalr.c (initialize_lookaheads): Split into...
3322 (states_lookaheads_count, states_lookaheads_initialize): these.
3323 (lalr): Adjust.
3324
9757c359
AD
33252002-06-15 Akim Demaille <akim@epita.fr>
3326
3327 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
3328 out of...
3329 (grammar_rules_print): here.
3330 * src/reduce.c (reduce_output): Use it.
3331 * tests/reduce.at (Useless Rules, Reduced Automaton)
3332 (Underivable Rules): Adjust.
3333
6b98e4b5
AD
33342002-06-15 Akim Demaille <akim@epita.fr>
3335
3336 Copy BYacc's nice way to report the grammar.
3337
3338 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
3339 New.
3340 Don't print the rules' location, it is confusing and useless.
3341 (rule_print): Use grammar_rhs_print.
3342 * src/print.c (print_grammar): Use grammar_rules_print.
3343
6b98e4b5
AD
33442002-06-15 Akim Demaille <akim@epita.fr>
3345
3346 Complete and rationalize `useless thing' warnings.
3347
3348 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
3349 (symbol_tag_print): New.
3350 Use them everywhere in place of accessing directly the tag member.
3351 * src/gram.h, src/gram.c (rule_print): New.
3352 Use it where a rule used to be printed `by hand'.
3353 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
3354 (reduce_grammar_tables): Report the useless rules.
3355 (reduce_print): Useless things are a warning, not an error.
3356 Report it as such.
3357 * tests/reduce.at (Useless Nonterminals, Useless Rules):
3358 (Reduced Automaton, Underivable Rules): Adjust.
3359 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
3360 * tests/conflicts.at (Unresolved SR Conflicts)
3361 (Solved SR Conflicts): Adjust.
3362
ee000ba4
AD
33632002-06-15 Akim Demaille <akim@epita.fr>
3364
3365 Let symbols have a location.
3366
3367 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
3368 (getsym): Adjust.
3369 Adjust all callers.
3370 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
3371 Use location_t, not int.
3372 * src/symtab.c (symbol_check_defined): Take advantage of the
3373 location.
3374 * tests/regression.at (Invalid inputs): Adjust.
3375
8efe435c
AD
33762002-06-15 Akim Demaille <akim@epita.fr>
3377
3378 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3379 (input): Don't try to initialize yylloc here, do it in the
3380 scanner.
3381 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3382 * src/gram.h (rule_t): Change line and action_line into location
3383 and action_location, of location_t type.
3384 Adjust all dependencies.
3385 * src/location.h, src/location.c (empty_location): New.
3386 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3387 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3388 (grammar_current_rule_symbol_append)
3389 (grammar_current_rule_action_append): Expect a location as argument.
3390 * src/reader.c (grammar_midrule_action): Adjust to attach an
3391 action's location as dummy symbol location.
3392 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3393 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3394 the line numbers.
3395
1921f1d7
AD
33962002-06-14 Akim Demaille <akim@epita.fr>
3397
3398 Grammar declarations may be found in the grammar section.
3399
3400 * src/parse-gram.y (rules_or_grammar_declaration): New.
3401 (declarations): Each declaration may end with a semicolon, not
3402 just...
3403 (grammar_declaration): `"%union"'.
3404 (grammar): Branch to rules_or_grammar_declaration.
3405
4515534c
AD
34062002-06-14 Akim Demaille <akim@epita.fr>
3407
3408 * src/main.c (main): Invoke scanner_free.
3409
f958596b
AD
34102002-06-14 Akim Demaille <akim@epita.fr>
3411
3412 * src/output.c (m4_invoke): Extracted from...
3413 (output_skeleton): here.
3414 Free tempfile.
3415
2c569025
AD
34162002-06-14 Akim Demaille <akim@epita.fr>
3417
3418 * src/parse-gram.y (directives, directive, gram)
3419 (grammar_directives, precedence_directives, precedence_directive):
3420 Rename as...
3421 (declarations, declaration, grammar, grammar_declaration)
3422 (precedence_declaration, precedence_declarator): these.
3423 (symbol_declaration): New.
3424
592e8d4d
AD
34252002-06-14 Akim Demaille <akim@epita.fr>
3426
3427 * src/files.c (action_obstack): Remove, unused.
3428 (output_obstack): Remove it, and all its dependencies, as it is no
3429 longer needed.
3430 * src/reader.c (epilogue_set): Build the epilogue in the
3431 muscle_obstack.
3432 * src/output.h, src/output.c (muscle_obstack): Move to...
3433 * src/muscle_tab.h, src/muscle_tab.h: here.
3434 (muscle_init): Initialize muscle_obstack.
3435 (muscle_free): New.
3436 * src/main.c (main): Call it.
3437
0c15323d
AD
34382002-06-14 Akim Demaille <akim@epita.fr>
3439
3440 * src/location.h: New, extracted from...
3441 * src/reader.h: here.
3442 * src/Makefile.am (noinst_HEADERS): Merge into
3443 (bison_SOURCES): this.
3444 Add location.h.
3445 * src/parse-gram.y: Use location_t instead of Bison's.
3446 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3447 Use location_t instead of ints.
3448
e96c9728
AD
34492002-06-14 Akim Demaille <akim@epita.fr>
3450
3451 * data/bison.simple, data/bison.c++: Be sure to restore the
3452 current #line when returning to the skeleton contents after having
3453 exposed the input file's #line.
3454
75d1fe16
AD
34552002-06-12 Akim Demaille <akim@epita.fr>
3456
3457 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3458 eager.
3459 * tests/actions.at (Exotic Dollars): New.
3460
6c35d22c
AD
34612002-06-12 Akim Demaille <akim@epita.fr>
3462
3463 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3464 ['"/] too eagerly.
3465 * tests/input.at (Torturing the Scanner): New.
3466
1d6412ad
AD
34672002-06-11 Akim Demaille <akim@epita.fr>
3468
3469 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3470 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3471 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3472 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3473 * src/reader.c (reader): Use it.
3474
4cdb01db
AD
34752002-06-11 Akim Demaille <akim@epita.fr>
3476
3477 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3478 Adjust all callers.
3479 (scanner_last_string_free): New.
3480
44995b2e
AD
34812002-06-11 Akim Demaille <akim@epita.fr>
3482
3483 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3484 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3485 (last_string, YY_OBS_FREE): New.
3486 Use them when returning an ID.
3487
e9955c83
AD
34882002-06-11 Akim Demaille <akim@epita.fr>
3489
3490 Have Bison grammars parsed by a Bison grammar.
3491
3492 * src/reader.c, src/reader.h (prologue_augment): New.
3493 * src/reader.c (copy_definition): Remove.
3494
3495 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3496 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3497 (grammar_current_rule_prec_set, grammar_current_rule_check)
3498 (grammar_current_rule_symbol_append)
3499 (grammar_current_rule_action_append): Export.
3500 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3501 (symbol_list_action_append): Remove.
3502 Hook the routines from reader.
3503 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3504 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3505
3506 * src/reader.c (read_declarations): Remove, unused.
3507
3508 * src/parse-gram.y: Handle the epilogue.
3509 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3510 (grammar_start_symbol_set): this.
3511 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3512 * src/reader.c (readgram): Remove, unused.
3513 (reader): Adjust to insert eoftoken and axiom where appropriate.
3514
3515 * src/reader.c (copy_dollar): Replace with...
3516 * src/scan-gram.h (handle_dollar): this.
3517 * src/parse-gram.y: Remove `%thong'.
3518
3519 * src/reader.c (copy_at): Replace with...
3520 * src/scan-gram.h (handle_at): this.
3521
3522 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3523 New.
3524
3525 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3526 time being.
3527
3528 * src/reader.h, src/reader.c (grammar_rule_end): New.
3529
3530 * src/parse.y (current_type, current_class): New.
3531 Implement `%nterm', `%token' support.
3532 Merge `%term' into `%token'.
3533 (string_as_id): New.
3534 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3535 type name.
3536
3537 * src/parse-gram.y: Be sure to handle properly the beginning of
3538 rules.
3539
3540 * src/parse-gram.y: Handle %type.
3541 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3542
3543 * src/parse-gram.y: More directives support.
3544 * src/options.c: No longer handle source directives.
3545
3546 * src/parse-gram.y: Fix %output.
3547
3548 * src/parse-gram.y: Handle %union.
3549 Use the prologue locations.
3550 * src/reader.c (parse_union_decl): Remove.
3551
3552 * src/reader.h, src/reader.c (epilogue_set): New.
3553 * src/parse-gram.y: Use it.
3554
3555 * data/bison.simple, data/bison.c++: b4_stype is now either not
3556 defined, then default to int, or to the contents of %union,
3557 without `union' itself.
3558 Adjust.
3559 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3560
3561 * src/output.c (actions_output): Don't output braces, as they are
3562 already handled by the scanner.
3563
3564 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3565 characters to themselves.
3566
3567 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3568 that the epilogue has a proper #line.
3569
3570 * src/parse-gram.y: Handle precedence/associativity.
3571
3572 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3573 a terminal.
3574 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3575 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3576 at all to define terminals that cannot be emitted.
3577
3578 * src/scan-gram.l: Escape M4 characters.
3579
3580 * src/scan-gram.l: Working properly with escapes in user
3581 strings/characters.
3582
3583 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3584 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3585 grammar.
3586 Use more modest sizes, as for the time being the parser does not
3587 release memory, and therefore the process swallows a huge amount
3588 of memory.
3589
3590 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3591 stricter %token grammar.
3592
3593 * src/symtab.h (associativity): Add `undef_assoc'.
3594 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3595 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3596
3597 * tests/regression.at (Invalid %directive): Remove, as it is now
3598 meaningless.
3599 (Invalid inputs): Adjust to the new error messages.
3600 (Token definitions): The new grammar doesn't allow too many
3601 eccentricities.
3602
3603 * src/lex.h, src/lex.c: Remove.
3604 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3605 (copy_character, copy_string2, copy_string, copy_identifier)
3606 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3607 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3608 (parse_action): Remove.
3609 * po/POTFILES.in: Adjust.
3610
2e047461
AD
36112002-06-11 Akim Demaille <akim@epita.fr>
3612
3613 * src/reader.c (parse_action): Don't store directly into the
3614 rule's action member: return the action as a string.
3615 Don't require `rule_length' as an argument: compute it.
3616 (grammar_current_rule_symbol_append)
3617 (grammar_current_rule_action_append): New, eved out from
3618 (readgram): here.
3619 Remove `action_flag', `rulelength', unused now.
3620
9af3fbce
AD
36212002-06-11 Akim Demaille <akim@epita.fr>
3622
3623 * src/reader.c (grammar_current_rule_prec_set).
3624 (grammar_current_rule_check): New, eved out from...
3625 (readgram): here.
3626 Remove `xaction', `first_rhs': useless.
3627 * tests/input.at (Type clashes): New.
3628 * tests/existing.at (GNU Cim Grammar): Adjust.
3629
1485e106
AD
36302002-06-11 Akim Demaille <akim@epita.fr>
3631
3632 * src/reader.c (grammar_midrule_action): New, Eved out from
3633 (readgram): here.
3634
da4160c3
AD
36352002-06-11 Akim Demaille <akim@epita.fr>
3636
3637 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3638 New.
3639 (readgram): Use them as replacement of inlined code, crule and
3640 crule1.
3641
f6d0f937
AD
36422002-06-11 Akim Demaille <akim@epita.fr>
3643
3644 * src/reader.c (grammar_end, grammar_symbol_append): New.
3645 (readgram): Use them.
3646 Make the use of `p' as local as possible.
3647
69078d4b
AD
36482002-06-10 Akim Demaille <akim@epita.fr>
3649
3650 GCJ's parser requires the tokens to be defined before the prologue.
3651
3652 * data/bison.simple: Output the token definition before the user's
3653 prologue.
3654 * tests/regression.at (Braces parsing, Duplicate string)
3655 (Mixing %token styles): Check the output from bison.
3656 (Early token definitions): New.
3657
5e424082
AD
36582002-06-10 Akim Demaille <akim@epita.fr>
3659
3660 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3661 assigning twice the same user number to a token, so that we can
3662 use it in...
3663 * src/lex.c (lex): here.
3664 Also use `symbol_class_set' instead of hand written code.
3665 * src/reader.c (parse_assoc_decl): Likewise.
3666
44536b35
AD
36672002-06-10 Akim Demaille <akim@epita.fr>
3668
3669 * src/symtab.c, src/symtab.c (symbol_class_set)
3670 (symbol_user_token_number_set): New.
3671 * src/reader.c (parse_token_decl): Use them.
3672 Use a switch instead of ifs.
3673 Use a single argument.
3674
8b9f2372
AD
36752002-06-10 Akim Demaille <akim@epita.fr>
3676
3677 Remove `%thong' support as it is undocumented, unused, duplicates
3678 `%token's job, and creates useless e-mail traffic with people who
3679 want to know what it is, why it is undocumented, unused, and
3680 duplicates `%token's job.
3681
3682 * src/reader.c (parse_thong_decl): Remove.
3683 * src/options.c (option_table): Remove "thong".
3684 * src/lex.h (tok_thong): Remove.
3685
3ae2b51f
AD
36862002-06-10 Akim Demaille <akim@epita.fr>
3687
3688 * src/symtab.c, src/symtab.c (symbol_type_set)
3689 (symbol_precedence_set): New.
3690 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3691 (value_components_used): Remove, unused.
3692
2f1afb73
AD
36932002-06-09 Akim Demaille <akim@epita.fr>
3694
3695 Move symbols handling code out of the reader.
3696
3697 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3698 (axiom): Move to...
3699 * src/symtab.h, src/symtab.c: here.
3700
3701 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3702 * src/reader.c (startval): Rename as...
3703 * src/symtab.h, src/symtab.c (startsymbol): this.
3704 * src/reader.c: Adjust.
3705
3706 * src/reader.c (symbol_check_defined, symbol_make_alias)
3707 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3708 (token_translations_init)
3709 Move to...
3710 * src/symtab.c: here.
3711 * src/reader.c (packsymbols): Move to...
3712 * src/symtab.h, src/symtab.c (symbols_pack): here.
3713 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3714 argument.
3715
e9bca3ad
AD
37162002-06-03 Akim Demaille <akim@epita.fr>
3717
3718 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3719 then statements.
3720
86eff183
AD
37212002-06-03 Akim Demaille <akim@epita.fr>
3722
3723 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3724 structs with non literals.
3725 * src/scan-skel.l: never-interactive.
3726 * src/conflicts.c (enum conflict_resolution_e): No trailing
3727 comma.
3728 * src/getargs.c (usage): Split long literal strings.
3729 Reported by Hans Aberg.
3730
717be197
AD
37312002-05-28 Akim Demaille <akim@epita.fr>
3732
3733 * data/bison.c++: Use C++ ostreams.
3734 (cdebug_): New member.
3735
670ddffd
AD
37362002-05-28 Akim Demaille <akim@epita.fr>
3737
3738 * src/output.c (output_skeleton): Be sure to allocate enough room
3739 for `/' _and_ for `\0' in full_skeleton.
3740
769b430f
AD
37412002-05-28 Akim Demaille <akim@epita.fr>
3742
3743 * data/bison.c++: Catch up with bison.simple:
3744 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3745 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3746 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3747 and popping traces.
3748
7067cb36
PH
37492002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3750
3751 * src/output.c (output_skeleton): Put an explicit path in front of
3752 the skeleton file name, rather than relying on the -I directory,
3753 to partially alleviate effects of having a skeleton file lying around
3754 in the current directory.
769b430f 3755
4a713ec2
PH
37562002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3757
769b430f 3758 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
3759 obstack_printf should be obstack_fgrow1.
3760
b408954b
AD
37612002-05-26 Akim Demaille <akim@epita.fr>
3762
3763 * src/state.h (state_t): `solved_conflicts' is a new member.
3764 * src/LR0.c (new_state): Set it to 0.
3765 * src/conflicts.h, src/conflicts.c (print_conflicts)
3766 (free_conflicts, solve_conflicts): Rename as...
3767 (conflicts_print, conflicts_free, conflicts_solve): these.
3768 Adjust callers.
3769 * src/conflicts.c (enum conflict_resolution_e)
3770 (solved_conflicts_obstack): New, used by...
3771 (log_resolution): this.
3772 Adjust to attach the conflict resolution to each state.
3773 Complete the description with the precedence/associativity
3774 information.
3775 (resolve_sr_conflict): Adjust.
3776 * src/print.c (print_state): Output its solved_conflicts.
3777 * tests/conflicts.at (Unresolved SR Conflicts)
3778 (Solved SR Conflicts): Exercise --report=all.
3779
a49aecd5
AD
37802002-05-26 Akim Demaille <akim@epita.fr>
3781
3782 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3783 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3784 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3785 (token_number_t, item_number_as_token_number)
3786 (token_number_as_item_number, muscle_insert_token_number_table):
3787 Rename as...
3788 (symbol_number_t, item_number_as_symbol_number)
3789 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3790 these, since it is more appropriate.
3791
5504898e
AD
37922002-05-26 Akim Demaille <akim@epita.fr>
3793
3794 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3795 `Error:' lines.
3796 * data/bison.simple (yystos) [YYDEBUG]: New.
3797 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3798 error recovery.
3799 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3800
ec3bc396
AD
38012002-05-25 Akim Demaille <akim@epita.fr>
3802
3803 * doc/bison.texinfo (Debugging): Split into...
3804 (Tracing): this new section, its former contents, and...
3805 (Understanding): this new section.
3806 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3807 by...
3808 (report_flag): this.
3809 Adjust all dependencies.
3810 (report_args, report_types, report_argmatch): New.
3811 (usage, getargs): Report/support -r, --report.
3812 * src/options.h
3813 (struct option_table_struct): Rename as..,
3814 (struct option_table_s): this.
3815 Rename the `set_flag' member to `flag' to match with getopt_long's
3816 struct.
3817 * src/options.c (option_table): Split verbose into an entry for
3818 %verbose, and another for --verbose.
3819 Support --report/-r, so remove -r from the obsolete --raw.
3820 * src/print.c: Attach full item sets and lookaheads reports to
3821 report_flag instead of trace_flag.
3822 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3823
78df8250
PE
38242002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3825 and Paul Eggert <eggert@twinsun.com>
769b430f 3826
78df8250
PE
3827 * data/bison.simple (yyparse): Correct error handling to conform to
3828 POSIX and yacc. Specifically, after syntax error is discovered,
3829 do not reduce further before shifting the error token.
3830 Clean up the code a bit by removing the labels yyerrdefault,
3831 yyerrhandle, yyerrpop.
3832 * NEWS: Document the above.
3833
c0c9ea05
PH
38342002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3835
3836 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3837 type; it isn't always big enough, since it doesn't necessarily
3838 include non-terminals.
769b430f 3839 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
3840 the latter can be removed.
3841 (yy_token_number_type): Remove, only one use.
3842 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3843 don't use TokenNumberType as element type.
769b430f 3844
c0c9ea05
PH
3845 * tests/regression.at: Modify expected output to agree with change
3846 to yyr1 and yytranslate.
769b430f 3847
6390a83f
FK
38482002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3849
3850 * src/reader.c (parse_action): Use copy_character instead of
3851 obstack_1grow.
3852
db7c8e9a
AD
38532002-05-13 Akim Demaille <akim@epita.fr>
3854
3855 * tests/regression.at (Token definitions): Prototype yylex and
3856 yyerror.
3857
fcc61800
PH
38582002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3859
158c687b 3860 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
3861 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3862 32-bit arithmetic.
3863 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3864
5683e9b2
AD
38652002-05-07 Akim Demaille <akim@epita.fr>
3866
3867 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3868 avoid GCC warnings.
3869
0c2d3f4c
AD
38702002-05-07 Akim Demaille <akim@epita.fr>
3871
3872 Kill GCC warnings.
3873
3874 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3875 over the RHS of each rule.
3876 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3877 * src/state.h (state_t): Member `nitems' is unsigned short.
3878 * src/LR0.c (get_state): Adjust.
3879 * src/reader.c (packgram): Likewise.
3880 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3881 `Type'.
3882 (muscle_insert_int_table): Remove, unused.
3883 (prepare_rules): Remove `max'.
3884
1565b720
AD
38852002-05-06 Akim Demaille <akim@epita.fr>
3886
3887 * src/closure.c (print_firsts): Display of the symbol tags.
3888 (bitmatrix_print): Move to...
3889 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
3890 here.
3891 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
3892
cfaee611
AD
38932002-05-06 Akim Demaille <akim@epita.fr>
3894
3895 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
3896 hash_do_for_each.
3897
458be8e0
AD
38982002-05-06 Akim Demaille <akim@epita.fr>
3899
3900 * src/LR0.c (new_state, get_state): Instead of using the global
3901 `kernel_size' and `kernel_base', have two new arguments:
3902 `core_size' and `core'.
3903 Adjust callers.
3904
a900a624
AD
39052002-05-06 Akim Demaille <akim@epita.fr>
3906
3907 * src/reader.c (packgram): No longer end `ritem' with a 0
3908 sentinel: it is not used.
3909
d4e7d3a1
AD
39102002-05-05 Akim Demaille <akim@epita.fr>
3911
3912 New experimental feature: display the lookaheads in the report and
3913 graph.
3914
3915 * src/print (print_core): When --trace-flag, display the rules
3916 lookaheads.
3917 * src/print_graph.c (print_core): Likewise.
3918 Swap the arguments.
3919 Adjust caller.
3920
39ceb25b
AD
39212002-05-05 Akim Demaille <akim@epita.fr>
3922
3923 * tests/torture.at (Many lookaheads): New test.
3924
5372019f
AD
39252002-05-05 Akim Demaille <akim@epita.fr>
3926
3927 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
3928 (GENERATE_MUSCLE_INSERT_TABLE): this.
3929 (output_int_table, output_unsigned_int_table, output_short_table)
3930 (output_token_number_table, output_item_number_table): Replace with...
3931 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
3932 (muscle_insert_short_table, muscle_insert_token_number_table)
3933 (muscle_insert_item_number_table): these.
3934 Adjust all callers.
3935 (prepare_tokens): Don't free `translations', since...
3936 * src/reader.h, src/reader.c (grammar_free): do it.
3937 Move to...
3938 * src/gram.h, src/gram.c (grammar_free): here.
3939 * data/bison.simple, data/bison.c++: b4_token_number_max is now
3940 b4_translate_max.
3941
5df5f6d5
AD
39422002-05-05 Akim Demaille <akim@epita.fr>
3943
3944 * src/output.c (output_unsigned_int_table): New.
3945 (prepare_rules): `i' is unsigned.
3946 `prhs', `rline', `r2' are unsigned int.
3947 Rename muscle `rhs_number_max' as `rhs_max'.
3948 Output muscles `prhs_max', `rline_max', and `r2_max'.
3949 Free rline and r1.
3950 * data/bison.simple, data/bison.c++: Adjust to use these muscles
3951 to compute types instead of constant types.
3952 * tests/regression.at (Web2c Actions): Adjust.
3953
b87f8b21
AD
39542002-05-04 Akim Demaille <akim@epita.fr>
3955
3956 * src/symtab.h (SALIAS, SUNDEF): Rename as...
3957 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
3958 Adjust dependencies.
3959 * src/output.c (token_definitions_output): Be sure not to output a
3960 `#define 'a'' when fed with `%token 'a' "a"'.
3961 * tests/regression.at (Token definitions): New.
3962
8bb936e4
PE
39632002-05-03 Paul Eggert <eggert@twinsun.com>
3964
3965 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
3966 for K&R C.
3967
39682002-05-03 gettextize <bug-gnu-gettext@gnu.org>
3969
3970 * Makefile.am (SUBDIRS): Remove intl.
3971 (EXTRA_DIST): Add config/config.rpath.
3972
53c71a12
AD
39732002-05-03 Akim Demaille <akim@epita.fr>
3974
3975 * data/bison.simple (m4_if): Don't output empty enums.
3976 And actually, output valid enum definitions :(.
3977
289dd0cf
AD
39782002-05-03 Akim Demaille <akim@epita.fr>
3979
3980 * configure.bat: Remove, completely obsolete.
3981 * Makefile.am (EXTRA_DIST): Adjust.
3982 Don't distribute config.rpath...
3983 * config/Makefile.am (EXTRA_DIST): Do it.
3984
db85e524
AD
39852002-05-03 Akim Demaille <akim@epita.fr>
3986
3987 * configure.in (GETTEXT_VERSION): New.
3988 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
3989
83ccf991
AD
39902002-05-03 Akim Demaille <akim@epita.fr>
3991
3992 * data/bison.simple (b4_token_enum): New.
3993 (b4_token_defines): Use it to output tokens both as #define and
3994 enums.
3995 Suggested by Paul Eggert.
3996 * src/output.c (token_definitions_output): Don't output spurious
3997 white spaces.
3998
1f418995
AD
39992002-05-03 Akim Demaille <akim@epita.fr>
4000
4001 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4002
45119f04
RA
40032002-05-02 Robert Anisko <robert@lrde.epita.fr>
4004
4005 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
4006 Update the stack class, give a try to deque as the default container.
4007
b2d52318
AD
40082002-05-02 Akim Demaille <akim@epita.fr>
4009
4010 * data/bison.simple (yyparse): Do not implement @$ = @1.
4011 (YYLLOC_DEFAULT): Adjust to do it.
4012 * doc/bison.texinfo (Location Default Action): Fix.
4013
3a8b4109
AD
40142002-05-02 Akim Demaille <akim@epita.fr>
4015
4016 * src/reader.c (parse_braces): Merge into...
4017 (parse_action): this.
4018
84614e13
AD
40192002-05-02 Akim Demaille <akim@epita.fr>
4020
4021 * configure.in (ALL_LINGUAS): Remove.
4022 * po/LINGUAS, hr.po: New.
4023
fdbcd8e2
AD
40242002-05-02 Akim Demaille <akim@epita.fr>
4025
4026 Remove the so called hairy (semantic) parsers.
4027
4028 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
4029 * src/gram.h, src/gram.c (semantic_parser): Remove.
4030 (rule_t): Remove the guard and guard_line members.
4031 * src/lex.h (token_t): remove tok_guard.
4032 * src/options.c (option_table): Remove %guard and %semantic_parser
4033 support.
4034 * src/output.c, src/output.h (guards_output): Remove.
4035 (prepare): Adjust.
4036 (token_definitions_output): Don't output the `T'
4037 tokens (???).
4038 (output_skeleton): Don't output the guards.
4039 * src/files.c, src/files.c (attrsfile): Remove.
4040 * src/reader.c (symbol_list): Remove the guard and guard_line
4041 members.
4042 Adjust dependencies.
4043 (parse_guard): Remove.
4044 * data/bison.hairy: Remove.
4045 * doc/bison.texinfo (Environment Variables): Remove occurrences of
4046 BISON_HAIRY.
4047
82b6cb3f
AD
40482002-05-02 Akim Demaille <akim@epita.fr>
4049
4050 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
4051 (parse_guard): Rename the formal argument `stack_offset' as
4052 `rule_length', which is more readable.
4053 Adjust callers.
4054 (copy_at, copy_dollar): Instead of outputting the hard coded
4055 values of $$, $n and so forth, output invocation to b4_lhs_value,
4056 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
4057 Note: this patch partially drops `semantic-parser' support: it
4058 always does `rule_length - n', where semantic parsers ought to
4059 always use `-n'.
82b6cb3f
AD
4060 * data/bison.simple, data/bison.c++ (b4_lhs_value)
4061 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
4062
6cbfbcc5
AD
40632002-05-02 Akim Demaille <akim@epita.fr>
4064
4065 * configure.in (AC_INIT): Bump to 1.49b.
4066 (AM_INIT_AUTOMAKE): Short invocation.
4067
b8548114
AD
40682002-05-02 Akim Demaille <akim@epita.fr>
4069
4070 Version 1.49a.
4071
c20cd1fa
AD
40722002-05-01 Akim Demaille <akim@epita.fr>
4073
4074 * src/skeleton.h: Remove.
4075
8a9566d4
AD
40762002-05-01 Akim Demaille <akim@epita.fr>
4077
4078 * src/skeleton.h: Fix the #endif.
4079 Reported by Magnus Fromreide.
4080
8c6d399a
PE
40812002-04-26 Paul Eggert <eggert@twinsun.com>
4082
4083 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
4084 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 4085 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 4086
2b7ed18a
RA
40872002-04-25 Robert Anisko <robert@lrde.epita.fr>
4088
4089 * src/scan-skel.l: Postprocess quadrigraphs.
4090
4091 * src/reader.c (copy_character): New function, used to output
4092 single characters while replacing `[' and `]' with quadrigraphs, to
4093 avoid troubles with M4 quotes.
4094 (copy_comment): Output characters with copy_character.
4095 (read_additionnal_code): Likewise.
4096 (copy_string2): Likewise.
4097 (copy_definition): Likewise.
4098
4099 * tests/calc.at: Exercise M4 quoting.
4100
34a89c50
AD
41012002-04-25 Akim Demaille <akim@epita.fr>
4102
4103 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
4104 between `!' and the command.
4105 Reported by Paul Eggert.
4106
0dd1580a
RA
41072002-04-24 Robert Anisko <robert@lrde.epita.fr>
4108
4109 * tests/calc.at: Exercise prologue splitting.
4110
4111 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
4112 `b4_post_prologue' instead of `b4_prologue'.
4113
4114 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
4115 muscles.
4116 (output): Free pre_prologue_obstack and post_prologue_obstack.
4117 * src/files.h, src/files.c (attrs_obstack): Remove.
4118 (pre_prologue_obstack, post_prologue_obstack): New.
4119 * src/reader.c (copy_definition): Add a parameter to specify the
4120 obstack to fill, instead of using attrs_obstack unconditionally.
4121 (read_declarations): Pass pre_prologue_obstack to copy_definition if
4122 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
4123
83c1796f
PE
41242002-04-23 Paul Eggert <eggert@twinsun.com>
4125
4126 * data/bison.simple: Remove unnecessary commentary and white
4127 space differences from 1_29-branch.
4128 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
4129
4130 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
4131 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
4132 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
4133 constructors or destructors.
4134
4135 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
4136
1207eeac
AD
41372002-04-23 Akim Demaille <akim@epita.fr>
4138
4139 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
4140 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
4141 location with columns.
4142 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
4143 All reported by Paul Eggert.
4144
78ab8f67
AD
41452002-04-22 Akim Demaille <akim@epita.fr>
4146
4147 * src/reduce.c (dump_grammar): Move to...
4148 * src/gram.h, src/gram.c (grammar_dump): here.
4149 Be sure to separate long item numbers.
4150 Don't read the members of a rule's prec if its nil.
4151
133c20e2
AD
41522002-04-22 Akim Demaille <akim@epita.fr>
4153
4154 * src/output.c (table_size, table_grow): New.
4155 (MAXTABLE): Remove, replace uses with table_size.
4156 (pack_vector): Instead of dying when the table is too big, grow it.
4157
9515e8a7
AD
41582002-04-22 Akim Demaille <akim@epita.fr>
4159
4160 * data/bison.simple (yyr1): Its type is that of a token number.
4161 * data/bison.c++ (r1_): Likewise.
4162 * tests/regression.at (Web2c Actions): Adjust.
4163
23c5a174
AD
41642002-04-22 Akim Demaille <akim@epita.fr>
4165
4166 * src/reader.c (token_translations_init): 256 is now the default
4167 value for the error token, i.e., it will be assigned another
4168 number if the user assigned 256 to one of her tokens.
4169 (reader): Don't force 256 to error.
4170 * doc/bison.texinfo (Symbols): Adjust.
4171 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
4172 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
4173 etc. instead of 10, 20, 30 (which was used to `jump' over error
4174 (256) and undefined (2)).
4175
5fbb0954
AD
41762002-04-22 Akim Demaille <akim@epita.fr>
4177
4178 Propagate more token_number_t.
4179
4180 * src/gram.h (token_number_as_item_number)
4181 (item_number_as_token_number): New.
4182 * src/output.c (GENERATE_OUTPUT_TABLE): New.
4183 Use it to create output_item_number_table and
4184 output_token_number_table.
4185 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4186 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
4187 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
4188 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
4189
4f940944
AD
41902002-04-22 Akim Demaille <akim@epita.fr>
4191
4192 * src/output.h, src/output.c (get_lines_number): Remove.
4193
3ded9a63
AD
41942002-04-19 Akim Demaille <akim@epita.fr>
4195
4196 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
4197 as Lex/Flex'.
4198 (Debugging): More details about enabling the debugging features.
4199 (Table of Symbols): Describe $$, $n, @$, and @n.
4200 Suggested by Tim Josling.
4201
e0c471a9
AD
42022002-04-19 Akim Demaille <akim@epita.fr>
4203
4204 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
4205
fecc10cd
AD
42062002-04-10 Akim Demaille <akim@epita.fr>
4207
4208 * src/system.h: Rely on HAVE_LIMITS_H.
4209 Suggested by Paul Eggert.
4210
51dec47b
AD
42112002-04-09 Akim Demaille <akim@epita.fr>
4212
4213 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
4214 full stderr, and strip it according to the bison options, instead
4215 of composing the error message from different bits.
4216 This makes it easier to check for several error messages.
4217 Adjust all the invocations.
4218 Add an invocation exercising the error token.
4219 Add an invocation demonstrating a stupid error message.
4220 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
4221 Adjust the tests.
4222 Error message are for stderr, not stdout.
4223
007a50a4
AD
42242002-04-09 Akim Demaille <akim@epita.fr>
4225
4226 * src/gram.h, src/gram.c (error_token_number): Remove, use
4227 errtoken->number.
4228 * src/reader.c (reader): Don't specify the user token number (2)
4229 for $undefined, as it uselessly prevents using it.
4230 * src/gram.h (token_number_t): Move to...
4231 * src/symtab.h: here.
4232 (state_t.number): Is a token_number_t.
4233 * src/print.c, src/reader.c: Use undeftoken->number instead of
4234 hard coded 2.
4235 (Even though this 2 is not the same as above: the number of the
4236 undeftoken remains being 2, it is its user token number which
4237 might not be 2).
4238 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
4239 `user_token_number_max'.
4240 Output `undef_token_number'.
4241 * data/bison.simple, data/bison.c++: Use them.
4242 Be sure to map invalid yylex return values to
4243 `undef_token_number'. This saves us from gratuitous SEGV.
4244
4245 * tests/conflicts.at (Solved SR Conflicts)
4246 (Unresolved SR Conflicts): Adjust.
4247 * tests/regression.at (Web2c Actions): Adjust.
4248
06446ccf
AD
42492002-04-08 Akim Demaille <akim@epita.fr>
4250
4251 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
4252 Adding #line.
4253 Remove the duplicate `typedefs'.
4254 (RhsNumberType): Fix the declaration and various other typos.
4255 Use __ofile__.
4256 * data/bison.simple: Use __ofile__.
4257 * src/scan-skel.l: Handle __ofile__.
4258
62a3e4f0
AD
42592002-04-08 Akim Demaille <akim@epita.fr>
4260
4261 * src/gram.h (item_number_t): New, the type of item numbers in
4262 RITEM. Note that it must be able to code symbol numbers as
4263 positive number, and the negation of rule numbers as negative
4264 numbers.
4265 Adjust all dependencies (pretty many).
4266 * src/reduce.c (rule): Remove this `short *' pointer: use
4267 item_number_t.
4268 * src/system.h (MINSHORT, MAXSHORT): Remove.
4269 Include `limits.h'.
4270 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
4271 (shortcpy): Remove.
4272 (MAXTABLE): Move to...
4273 * src/output.c (MAXTABLE): here.
4274 (prepare_rules): Use output_int_table to output rhs.
4275 * data/bison.simple, data/bison.c++: Adjust.
4276 * tests/torture.at (Big triangle): Move the limit from 254 to
4277 500.
4278 * tests/regression.at (Web2c Actions): Ajust.
4279
4280 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
4281 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
4282 passes, but produces negative #line number, once fixed, GCC is
4283 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
4284 C), it passes.
4285 * src/state.h (state_h): Code input lines on ints, not shorts.
4286
bb88b0fc
AD
42872002-04-08 Akim Demaille <akim@epita.fr>
4288
4289 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
4290 and then the grammar.
4291
9a636f47
AD
42922002-04-08 Akim Demaille <akim@epita.fr>
4293
4294 * src/system.h: No longer using strndup.
4295
680e8701
AD
42962002-04-07 Akim Demaille <akim@epita.fr>
4297
4298 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
4299 * src/output.c (output_table_data): Return the longest number.
4300 (prepare_tokens): Output `token_number_max').
4301 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
4302 New.
4303 Use them to define yy_token_number_type/TokenNumberType.
4304 Use this type for yytranslate.
4305 * tests/torture.at (Big triangle): Push the limit from 124 to
4306 253.
4307 * tests/regression.at (Web2c Actions): Adjust.
4308
817e9f41
AD
43092002-04-07 Akim Demaille <akim@epita.fr>
4310
4311 * tests/torture.at (Big triangle): New.
4312 (GNU AWK Grammar, GNU Cim Grammar): Move to...
4313 * tests/existing.at: here.
4314
5123689b
AD
43152002-04-07 Akim Demaille <akim@epita.fr>
4316
4317 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
4318 nritems.
4319 Adjust dependencies.
4320
f3849179
AD
43212002-04-07 Akim Demaille <akim@epita.fr>
4322
4323 * src/reader.c: Normalize increments to prefix form.
4324
bd02036a
AD
43252002-04-07 Akim Demaille <akim@epita.fr>
4326
4327 * src/reader.c, symtab.c: Remove debugging code.
4328
db8837cb
AD
43292002-04-07 Akim Demaille <akim@epita.fr>
4330
4331 Rename all the `bucket's as `symbol_t'.
4332
4333 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
4334 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
4335 * src/symtab.c, src/symtab.h (bucket): Rename as...
4336 (symbol_t): this.
4337 (symbol_list_new, bucket_check_defined, bucket_make_alias)
4338 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
4339 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4340 (buckets_new, buckets_free, buckets_do): Rename as...
4341 (symbol_list_new, symbol_check_defined, symbol_make_alias)
4342 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4343 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
4344 (symbols_new, symbols_free, symbols_do): these.
4345
72a23c97
AD
43462002-04-07 Akim Demaille <akim@epita.fr>
4347
4348 Use lib/hash for the symbol table.
4349
4350 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
4351 EOF.
4352 * src/lex.c (lex): Set the `number' member of new terminals.
4353 * src/reader.c (bucket_check_defined, bucket_make_alias)
4354 (bucket_check_alias_consistence, bucket_translation): New.
4355 (reader, grammar_free, readgram, token_translations_init)
4356 (packsymbols): Adjust.
4357 (reader): Number the predefined tokens.
4358 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
4359 for predefined tokens.
4360 * src/symtab.h (bucket): Remove all the hash table related
4361 members.
4362 * src/symtab.c (symtab): Replace by...
4363 (bucket_table): this.
4364 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4365 (buckets_new, buckets_do): New.
4366
280a38c3
AD
43672002-04-07 Akim Demaille <akim@epita.fr>
4368
4369 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
4370 (start_symbol, max_user_token_number, semantic_parser)
4371 (error_token_number): Initialize.
4372 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
4373 Initialize.
4374 (reader): Don't.
4375 (errtoken, eoftoken, undeftoken, axiom): Extern.
4376
03b31c0c
AD
43772002-04-07 Akim Demaille <akim@epita.fr>
4378
4379 * src/gram.h (rule_s): prec and precsym are now pointers
4380 to the bucket giving the priority/associativity.
4381 Member `associativity' removed: useless.
4382 * src/reduce.c, src/conflicts.c: Adjust.
4383
8b3df748
AD
43842002-04-07 Akim Demaille <akim@epita.fr>
4385
4386 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4387 Properly escape the symbols' TAG when outputting them.
4388
e601aa1d
AD
43892002-04-07 Akim Demaille <akim@epita.fr>
4390
4391 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4392
b0299a2e
AD
43932002-04-07 Akim Demaille <akim@epita.fr>
4394
4395 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4396 (LArule): this, which is an array to rule_t*.
4397 * src/print.c, src/conflicts.c: Adjust.
4398
d7e1f00c
AD
43992002-04-07 Akim Demaille <akim@epita.fr>
4400
4401 * src/gram.h (rule_t): Rename `number' as `user_number'.
4402 `number' is a new member.
4403 Adjust dependencies.
4404 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4405
cc9305dd
AD
44062002-04-07 Akim Demaille <akim@epita.fr>
4407
4408 As a result of the previous patch, it is no longer needed
4409 to reorder ritem itself.
4410
4411 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4412
b0940840
AD
44132002-04-07 Akim Demaille <akim@epita.fr>
4414
4415 Be sure never to walk through RITEMS, but use only data related to
4416 the rules themselves. RITEMS should be banished.
4417
4418 * src/output.c (output_token_translations): Rename as...
4419 (prepare_tokens): this.
4420 In addition to `translate', prepare the muscles `tname' and
4421 `toknum', which were handled by...
4422 (output_rule_data): this.
4423 Remove, and move the remainder of its outputs into...
4424 (prepare_rules): this new routines, which also merges content from
4425 (output_gram): this.
4426 (prepare_rules): Be sure never to walk through RITEMS.
4427 (output_stos): Rename as...
4428 (prepare_stos): this.
4429 (output): Always invoke prepare_states, after all, just don't use it
4430 in the output if you don't need it.
4431
643a5994
AD
44322002-04-07 Akim Demaille <akim@epita.fr>
4433
4434 * src/LR0.c (new_state): Display `nstates' as the name of the
4435 newly created state.
4436 Adjust to initialize first_state and last_state if needed.
4437 Be sure to distinguish the initial from the final state.
4438 (new_states): Create the itemset of the initial state, and use
4439 new_state.
4440 * src/closure.c (closure): Now that the initial state has its
4441 items properly set, there is no need for a special case when
4442 creating `ruleset'.
4443
4444 As a result, now the rule 0, reducing to $axiom, is visible in the
4445 outputs. Adjust the test suite.
4446
4447 * tests/conflicts.at (Solved SR Conflicts)
4448 (Unresolved SR Conflicts): Adjust.
4449 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4450 * tests/conflicts.at (S/R in initial): New.
4451
b4c4ccc2
AD
44522002-04-07 Akim Demaille <akim@epita.fr>
4453
4454 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4455 the RHS of the rules.
4456 * src/output.c (output_gram): Likewise.
4457
bba97eb2
AD
44582002-04-07 Akim Demaille <akim@epita.fr>
4459
4460 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4461 bucket.
4462 Adjust all dependencies.
4463 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4464 `number' of the buckets too.
4465 * src/gram.h: Include `symtab.h'.
4466 (associativity): Move to...
4467 * src/symtab.h: here.
4468 No longer include `gram.h'.
4469
c3b407f4
AD
44702002-04-07 Akim Demaille <akim@epita.fr>
4471
4472 * src/gram.h, src/gram.c (rules_rhs_length): New.
4473 (ritem_longest_rhs): Use it.
4474 * src/gram.h (rule_t): `number' is a new member.
4475 * src/reader.c (packgram): Set it.
4476 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4477 the end of `rules', and count them out of `nrules'.
4478 (reduce_output, dump_grammar): Adjust.
4479 * src/print.c (print_grammar): It is no longer needed to check for
4480 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4481 * tests/reduce.at (Reduced Automaton): New test.
4482
11652ab3
AD
44832002-04-07 Akim Demaille <akim@epita.fr>
4484
4485 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4486 lacking `+ 1' to nrules, Bison reported as useless a token if it
4487 was used solely to set the precedence of the last rule...
4488
26b23c1a
AD
44892002-04-07 Akim Demaille <akim@epita.fr>
4490
4491 * data/bison.c++, data/bison.simple: Don't output the current file
4492 name in #line, to avoid useless diffs between two identical
4493 outputs under different names.
4494
18bcecb0
AD
44952002-04-07 Akim Demaille <akim@epita.fr>
4496
4497 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4498 Normalize loops to using `< nrules + 1', not `<= nrules'.
4499
fa770c86
AD
45002002-04-07 Akim Demaille <akim@epita.fr>
4501
4502 * TODO: Update.
4503
d9b739c3
AD
45042002-04-07 Akim Demaille <akim@epita.fr>
4505
4506 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4507 bucket.value as bucket.number.
4508
99013900
AD
45092002-04-07 Akim Demaille <akim@epita.fr>
4510
4511 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4512 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4513 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4514 RHS, instead of being an index in RITEMS.
4515
e966383b
PE
45162002-04-04 Paul Eggert <eggert@twinsun.com>
4517
4518 * doc/bison.texinfo: Update copyright date.
4519 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4520 (Symbols): Warn about running Bison in one character set,
4521 but compiling and/or running in an incompatible one.
4522 Warn about character code 256, too.
4523
45242002-04-03 Paul Eggert <eggert@twinsun.com>
4525
4526 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4527 YYERROR_VERBOSE is nonzero, not whether it is defined.
4528
4529 Merge changes from bison-1_29-branch.
c307773e 4530
8d6c48b9
PE
45312002-03-20 Paul Eggert <eggert@twinsun.com>
4532
4533 Merge fixes from Debian bison_1.34-1.diff.
4534
4535 * configure.in (AC_PREREQ): 2.53.
4536
e53c6322
AD
45372002-03-20 Akim Demaille <akim@epita.fr>
4538
4539 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4540
9ffbeca7
PE
45412002-03-19 Paul Eggert <eggert@twinsun.com>
4542
21db0b2a
PE
4543 * src/bison.simple (YYCOPY): New macro.
4544 (YYSTACK_RELOCATE): Use it.
4545 Remove Type arg; no longer needed. All callers changed.
4546 (yymemcpy): Remove; no longer needed.
4547
9ffbeca7
PE
4548 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4549 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4550
642cb8f8
AD
45512002-03-19 Akim Demaille <akim@epita.fr>
4552
4553 Test and fix the #line outputs.
4554
4555 * tests/atlocal.at (GCC): New.
4556 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4557 (Prologue synch line, ,%union synch line, Postprologue synch line)
4558 (Action synch line, Epilogue synch line): New tests.
4559 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4560 * data/bison.simple, data/bison.c++: Use it.
4561
3c31a486
AD
45622002-03-19 Akim Demaille <akim@epita.fr>
4563
4564 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4565 (Solved SR Conflicts, %expect not enough, %expect right)
4566 (%expect too much): Move to...
4567 * tests/conflicts.at: this new file.
4568
0d8bed56
AD
45692002-03-19 Akim Demaille <akim@epita.fr>
4570
4571 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4572 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4573 that we can move to enums for instance.
4574 * src/output.c (token_definitions_output): Output a list of
4575 `token-name, token-number' instead of the #define.
4576 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4577
9208d17f
AD
45782002-03-14 Akim Demaille <akim@epita.fr>
4579
4580 Use Gettext 0.11.1.
4581
af27eacb
RA
45822002-03-09 Robert Anisko <robert@lrde.epita.fr>
4583
4584 * data/bison.c++: Make the user able to add members to the generated
4585 parser by subclassing.
4586
9101a310
RA
45872002-03-05 Robert Anisko <robert@lrde.epita.fr>
4588
4589 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4590 a character.
4591 Reported by Nicolas Tisserand and Nicolas Burrus.
4592
fff9bf0b
RA
45932002-03-04 Robert Anisko <robert@lrde.epita.fr>
4594
4595 * src/reader.c: Warn about lacking semi-colons, do not complain.
4596
64dba31e
RA
45972002-03-04 Robert Anisko <robert@lrde.epita.fr>
4598
4599 * data/bison.c++: Remove a debug line.
4600
374f5a14
RA
46012002-03-04 Robert Anisko <robert@lrde.epita.fr>
4602
4603 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4604 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4605 provide a default implementation.
4606
bfcf1f3a
AD
46072002-03-04 Akim Demaille <akim@epita.fr>
4608
4609 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4610 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4611 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4612 * tests/semantic.at (Parsing Guards): Similarly.
4613 * src/reader.at (readgram): Complain if the last rule is not ended
4614 with a semi-colon.
4615
65ccf9fc
AD
46162002-03-04 Akim Demaille <akim@epita.fr>
4617
4618 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4619 * src/closure.c: here.
4620 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4621 RTC.
4622 * src/warshall.h, src/warshall.c: Remove.
4623 * tests/sets.at (Broken Closure): Adjust.
4624
d0039cbc
AD
46252002-03-04 Akim Demaille <akim@epita.fr>
4626
4627 * src/output.c (output_skeleton): tempdir is const.
4628 bytes_read is unused.
4629
345cea78
AD
46302002-03-04 Akim Demaille <akim@epita.fr>
4631
4632 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4633 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4634 Update.
4635 From Michael Hayes.
4636
564801f7
AD
46372002-03-04 Akim Demaille <akim@epita.fr>
4638
4639 * src/closure.c (closure): `r' is unused.
4640
e5352bc7
AD
46412002-03-04 Akim Demaille <akim@epita.fr>
4642
4643 * tests/sets.at (Broken Closure): Add the ending `;'.
4644 * src/reader.at (readgram): Complain if a rule is not ended with a
4645 semi-colon.
4646
914feea9
AD
46472002-03-04 Akim Demaille <akim@epita.fr>
4648
4649 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4650 (count_sr_conflicts): Use bitset_count.
4651 * src/reduce.c (inaccessable_symbols): Ditto.
4652 (bits_size): Remove.
4653 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4654
f0250de6
AD
46552002-03-04 Akim Demaille <akim@epita.fr>
4656
4657 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4658 * src/reduce.c: Remove the `bitset_zero's following the
4659 `bitset_create's, as now it is performed by the latter.
4660
ef017502
AD
46612002-03-04 Akim Demaille <akim@epita.fr>
4662
4663 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4664 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4665 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4666 latest sources from Michael.
4667
76514394
AD
46682002-03-04 Akim Demaille <akim@epita.fr>
4669
4670 * src/output.c (output): Don't free the grammar.
4671 * src/reader.c (grammar_free): New.
4672 * src/main.c (main): Call it and don't free symtab here.
4673
55024580
AD
46742002-03-04 Akim Demaille <akim@epita.fr>
4675
4676 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4677 before returning.
4678 Reported by Benoit Perrot.
4679
f9abaa2c
AD
46802002-03-04 Akim Demaille <akim@epita.fr>
4681
4682 Use bitset operations when possible, not loops over bits.
4683
4684 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4685 bitset_or.
4686 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4687 * src/reduce.c (useless_nonterminals): Formatting changes.
4688 * src/warshall.c (TC): Use bitset_or.
4689
0e721e75
AD
46902002-03-04 Akim Demaille <akim@epita.fr>
4691
4692 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4693 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4694 Ditto.
4695
0fb1ffb1
AD
46962002-03-04 Akim Demaille <akim@epita.fr>
4697
4698 * src/lalr.c (F): Now a bitset*.
4699 Adjust all dependencies.
4700
b86796bf
AD
47012002-03-04 Akim Demaille <akim@epita.fr>
4702
4703 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4704 Adjust all dependencies.
4705
602bbf31
AD
47062002-03-04 Akim Demaille <akim@epita.fr>
4707
4708 * src/L0.c, src/LR0.h (nstates): Be size_t.
4709 Adjust comparisons (signed vs unsigned).
4710 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4711 bitset*.
4712 Adjust all dependencies.
4713
d8a0245c
AD
47142002-03-04 Akim Demaille <akim@epita.fr>
4715
4716 * src/closure.c (firsts): Now, also a bitset.
4717 Adjust all dependencies.
4718 (varsetsize): Remove, now unused.
4719 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4720
34ba9743
AD
47212002-03-04 Akim Demaille <akim@epita.fr>
4722
4723 * src/print.c: Convert to use bitset.h, not hand coded iterations
4724 over ints.
4725
ed86e78c
AD
47262002-03-04 Akim Demaille <akim@epita.fr>
4727
4728 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4729
dfdb1797
AD
47302002-03-04 Akim Demaille <akim@epita.fr>
4731
4732 * src/closure.c (ruleset): Be a bitset.
4733 (rulesetsize): Remove.
4734
7086e707
AD
47352002-03-04 Akim Demaille <akim@epita.fr>
4736
4737 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4738 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4739 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4740 * src/closure.c (fderives): Be an array of bitsets.
4741
98254360
RA
47422002-02-28 Robert Anisko <robert@lrde.epita.fr>
4743
4744 * data/bison.c++: Merge the two generated headers. Insert a copyright
4745 notice in each output file.
4746
a75c057f
AD
47472002-02-28 Akim Demaille <akim@epita.fr>
4748
4749 * data/bison.c++: Copy the prologue of bison.simple to fetch
4750 useful M4 definitions, such as b4_header_guard.
4751
06b00abc
AD
47522002-02-25 Akim Demaille <akim@epita.fr>
4753
4754 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
4755 translator friendly scheme for the bgr
4756 copyright notice.
06b00abc 4757
70e7d534
AD
47582002-02-25 Akim Demaille <akim@epita.fr>
4759
4760 * src/output.c (header_output): Remove, now handled completely via
4761 M4.
4762
abe017f6
AD
47632002-02-25 Akim Demaille <akim@epita.fr>
4764
4765 * m4/m4.m4: New, from CVS Autoconf.
4766 * configure.in: Invoke it.
4767 * src/output.c (output_skeleton): Use its result instead of the
4768 hard coded name.
4769
381fb12e
AD
47702002-02-25 Akim Demaille <akim@epita.fr>
4771
4772 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4773 Fileutils 4.1.5.
4774 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4775 * src/output.c (output_skeleton): Use mkstemp to create a real
4776 temporary file.
4777 Move the filling of `skeleton' and its muscle to...
4778 (prepare): here.
4779 (output): Move the definition of the prologue muscle to...
4780 (prepare): here.
4781 * src/system.h (DEFAULT_TMPDIR): New.
4782
6f38107f
PE
47832002-02-14 Paul Eggert <eggert@twinsun.com>
4784
4785 Remove the support for C++ namespace cleanliness; it was
4786 causing more problems than it was curing, since it didn't work
4787 properly on some nonstandard C++ compilers. This can wait
4788 for a proper C++ parser.
4789
4790 * NEWS: Document this.
4791 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4792 of C++, as it's treated like C now.
4793 * src/bison.simple (YYSTD): Remove.
4794 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4795 Treat C++ just like Standard C instead of trying to support
4796 namespace cleanliness.
4797
80cce3da
AD
47982002-02-14 Akim Demaille <akim@epita.fr>
4799
4800 * tests/regression.at (else): Adjust to Andreas' change.
4801
842e8679
AD
48022002-02-14 Akim Demaille <akim@epita.fr>
4803
4804 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4805
4bda3f10
AD
48062002-02-13 Andreas Schwab <schwab@suse.de>
4807
4808 * src/output.c (output_rule_data): Don't output NULL, it might
4809 not be defined yet.
4810
4162fa07 48112002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 4812
4162fa07
RA
4813 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4814 (Copyright notice): Update.
b418ecd8 4815
bd16a5dc
AD
48162002-02-11 Akim Demaille <akim@epita.fr>
4817
4818 * tests/regression.at (%nonassoc and eof): Don't include
4819 nonportable headers.
4820
8d69a1a3
RA
48212002-02-08 Robert Anisko <robert@lrde.epita.fr>
4822
4823 * data/bison.c++: Correct error recovery. Make the user able to
4824 initialize the starting location.
4825
9b2d0677
AD
48262002-02-07 Akim Demaille <akim@epita.fr>
4827
4828 * tests/input.at: New.
4829
69e2658b
RA
48302002-02-07 Robert Anisko <robert@lrde.epita.fr>
4831
4832 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 4833 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
4834 directives around tables only needed for debugging.
4835
4aacc3a7
RA
48362002-02-07 Robert Anisko <robert@lrde.epita.fr>
4837
4838 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4839 C++ parsers.
4840 (yy::b4_name::parse): Use print_.
4841
762a801e
RA
48422002-02-07 Robert Anisko <robert@lrde.epita.fr>
4843
4844 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4845
4bb2bc3f
RA
48462002-02-07 Robert Anisko <robert@lrde.epita.fr>
4847
4848 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4849 C++ parsers.
4850 (yy::b4_name::parse): Build verbose error messages, and use error_.
4851
6b45a3ca
RA
48522002-02-06 Robert Anisko <robert@lrde.epita.fr>
4853
4854 * data/bison.c++: Fix m4 quoting in comments.
4855
50997c6e
RA
48562002-02-06 Robert Anisko <robert@lrde.epita.fr>
4857
4858 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4859 not expanded by m4.
4860
3f3eed27
AD
48612002-02-05 Akim Demaille <akim@epita.fr>
4862
4863 * data/bison.c++: Adjust to the M4 back end.
4864 More is certainly needed.
4865
be2a1a68
AD
48662002-02-05 Akim Demaille <akim@epita.fr>
4867
4868 Give a try to M4 as a back end.
4869
4870 * lib/readpipe.c: New, from wdiff.
4871 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4872 BISON_HAIRY.
4873 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4874 specific values. Now it is m4 that performs the lookup.
4875 * src/parse-skel.y: Remove.
4876 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4877 * src/output.c (actions_output, guards_output)
4878 (token_definitions_output): No longer keeps track of the output
4879 line number, hence remove the second argument.
4880 (guards_output): Check against the guard member of a rule, not the
4881 action member.
4882 Adjust callers.
4883 (output_skeleton): Don't look for the skeleton location, let m4 do
4884 that.
4885 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
4886 file will be used.
4887 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
4888 (prepare): Given that for the time being changesyntax is not
4889 usable in M4, rename the muscles using `-' to `_'.
4890 Define `defines_flag', `output_parser_name' and `output_header_name'.
4891 * src/output.h (actions_output, guards_output)
4892 (token_definitions_output): Adjust prototypes.
4893 * src/scan-skel.l: Instead of scanning the skeletons, it now
4894 processes the output of m4: `__oline__' and `#output'.
4895 * data/bison.simple: Adjust to be used by M4(sugar).
4896 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
4897 to date.
4898 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
4899 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
4900 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
4901 shamelessly stolen from CVS Autoconf.
4902
beda758b
AD
49032002-02-05 Akim Demaille <akim@epita.fr>
4904
4905 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
4906 * configure.in: Check for the declarations of free and malloc.
4907 * src/muscle_tab.c: Adjust.
4908
5ece6d43
AD
49092002-02-05 Akim Demaille <akim@epita.fr>
4910
4911 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
4912 which have no values.
4913
5bb18f9a
AD
49142002-02-05 Akim Demaille <akim@epita.fr>
4915
4916 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
4917 * data/: here.
4918
894dd62e
PE
49192002-01-29 Paul Eggert <eggert@twinsun.com>
4920
4921 * src/bison.simple (YYSIZE_T): Do not define merely because
4922 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
4923 On some platforms, <alloca.h> does not declare YYSTD (size_t).
4924
82841af7
AD
49252002-01-27 Akim Demaille <akim@epita.fr>
4926
4927 Fix `%nonassoc and eof'.
4928
4929 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
4930 which were not properly copied! Replace
4931 memcpy (res->errs, src->errs, src->nerrs);
4932 with
4933 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
4934 !!!
4935 * tests/regression.at (%nonassoc and eof): Adjust to newest
4936 Autotest: `.' is not in the PATH.
4937
318b76e9
AD
49382002-01-27 Akim Demaille <akim@epita.fr>
4939
4940 * tests/sets.at (AT_EXTRACT_SETS): New.
4941 (Nullable): Use it.
4942 (Firsts): New.
4943
30d2f3d5
AD
49442002-01-26 Akim Demaille <akim@epita.fr>
4945
4946 * tests/actions.at, tests/calc.at, tests/headers.at,
4947 * tests/torture.at: Adjust to the newest Autotest which no longer
4948 forces `.' in the PATH.
4949
30f8c395
AD
49502002-01-25 Akim Demaille <akim@epita.fr>
4951
4952 * tests/regression.at (%nonassoc and eof): New.
4953 Suggested by Robert Anisko.
4954
29ae55f1
AD
49552002-01-24 Akim Demaille <akim@epita.fr>
4956
4957 Bison dumps core when trying to complain about broken input files.
4958 Reported by Cris van Pelt.
4959
4960 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
4961 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
4962 into...
4963 (Invalid inputs): Strengthen: exercise parse_percent_token.
4964
2b548aa6
RA
49652002-01-24 Robert Anisko <robert.anisko@epita.fr>
4966
4967 * src/Makefile.am: Add bison.c++.
4968 * src/bison.c++: New skeleton.
4969
bb0146c2
AD
49702002-01-21 Paolo Bonzini <bonzini@gnu.org>
4971
4972 * po/it.po: New.
4973
bec30531
AD
49742002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
4975
4976 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
4977
fc6edc45
MA
49782002-01-20 Marc Autret <marc@gnu.org>
4979
4980 * src/files.c (compute_output_file_names): Fix
4981
5e5d5415
MA
49822002-01-20 Marc Autret <marc@gnu.org>
4983
4984 * tests/output.at: New test.
4985 * src/files.c (compute_base_names): Don't map extensions when
4986 the YACC flag is set, use defaults.
4987 Reported by Evgeny Stambulchik.
4988
44ea3fbd
MA
49892002-01-20 Marc Autret <marc@gnu.org>
4990
bb0146c2 4991 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
4992 compilers as well (i.e. the vendor C compiler).
4993 Suggested by Albert Chin-A-Young.
4994
338963d1
TVH
49952002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
4996
4997 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
4998 canonical definition.
4999 * src/system.h: Use the canonical definition for PARAMS (avoids
5000 a conflict with the macro from lib/hash.h).
5001
c57b2479
AD
50022002-01-11 Akim Demaille <akim@epita.fr>
5003
5004 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 5005 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 5006
b85810ae
AD
50072002-01-09 Akim Demaille <akim@epita.fr>
5008
5009 * src/files.c, src/files.h (output_infix): New.
5010 (tab_extension): Remove.
5011 (compute_base_names): Compute the former, drop the latter.
5012 * src/output.c (prepare): Insert the muscles `output-infix', and
5013 `output-suffix'.
5014 * src/parse-skel.y (string, string.1): New.
5015 (section.header): Use it.
5016 (section.yacc): Remove.
5017 (prefix): Remove too.
5018 * src/scan-skel.l: Adjust.
5019 * src/bison.simple, src/bison.hairy: Adjust.
5020
cae60122
AD
50212002-01-09 Akim Demaille <akim@epita.fr>
5022
5023 * configure.in (WERROR_CFLAGS): Compute it.
5024 * src/Makefile.am (CFLAGS): Pass it.
5025 * tests/atlocal.in (CFLAGS): Idem.
5026 * src/files.c: Fix a few warnings.
5027 (get_extension_index): Remove, unused.
5028
ae404801
AD
50292002-01-08 Akim Demaille <akim@epita.fr>
5030
5031 * src/getargs.c (AS_FILE_NAME): New.
5032 (getargs): Use it to convert DOSish file names.
5033 * src/files.c (base_name): Rename as full_base_name to avoid
5034 clashes with `base_name ()'.
5035 (filename_split): New.
5036 (compute_base_names): N-th rewrite, using filename_split.
5037
22312b71
AD
50382002-01-08 Akim Demaille <akim@epita.fr>
5039
5040 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
5041 New, stolen from the Fileutils 4.1.
5042 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
5043 * configure.in: Check for the presence of memrchr, and of its
5044 prototype.
5045
a67cef01
TVH
50462002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
5047
5048 * lib/hash.h (__P): Added definition for this macro.
5049 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
5050 BUILT_SOURCES, to ensure they are generated first.
5051 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
5052 %error-verbose to allow bootstrapping with bison 1.30x.
5053
2b25d624
AD
50542002-01-06 Akim Demaille <akim@epita.fr>
5055
5056 * src/reader.c (parse_braces): Don't fetch the next char, the
5057 convention is to fetch on entry.
5058 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
5059 'switch' without a following semicolon.
5060 * tests/regression.at (braces parsing): New.
5061
3460813b
AD
50622002-01-06 Akim Demaille <akim@epita.fr>
5063
5064 Bison is dead wrong in its RR conflict reports.
5065
5066 * tests/torture.at (GNU Cim Grammar): New.
5067 * src/conflicts.c (count_rr_conflicts): Fix.
5068
73784c64
AD
50692002-01-06 Akim Demaille <akim@epita.fr>
5070
5071 Creating package.m4 from configure.ac causes too many problems.
5072
5073 * tests/Makefile.am (package.m4): Create it by hand,
5074 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
5075
25d81090
AD
50762002-01-06 Akim Demaille <akim@epita.fr>
5077
5078 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
5079 skeleton.h.
5080
a9b8959e
PE
50812002-01-04 Paul Eggert <eggert@twinsun.com>
5082
5083 * doc/bison.texinfo (Debugging):
5084 Remove YYSTDERR; it's no longer defined or used.
5085 Also, s/cstdio.h/cstdio/.
5086
25d81090
AD
50872002-01-03 Akim Demaille <akim@epita.fr>
5088
5089 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
5090
1109455c
AD
50912002-01-03 Akim Demaille <akim@epita.fr>
5092
5093 * src/parse-skel.y (process_skeleton): Don't bind the parser's
5094 tracing code to --trace, wait for a better --trace option, with
5095 args.
5096
7ea5e977
AD
50972002-01-03 Akim Demaille <akim@epita.fr>
5098
5099 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
5100 The ISO C++ standard is extremely clear about it: stderr is
5101 considered a macro, not a regular symbol (see table 94 `Header
5102 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
5103 Therefore std:: does not apply to it. It still does with fprintf.
5104 Also, s/cstdio.h/cstdio/.
5105
fab5b110
AD
51062002-01-03 Akim Demaille <akim@epita.fr>
5107
5108 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
5109 for non system headers.
5110
aed7fd9b
AD
51112002-01-02 Akim Demaille <akim@epita.fr>
5112
5113 Equip the skeleton chain with location tracking, runtime trace,
5114 pure parser and scanner.
5115
5116 * src/parse-skel.y: Request a pure parser, locations, and prefix
5117 renaming.
5118 (%union): Having several members with the same type does not help
5119 type mismatches, simplify.
5120 (YYPRINT, yyprint): New.
5121 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
5122 (skel_error): this.
5123 Handle locations.
5124 * src/scan-skel.l: Adjust to these changes.
5125 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
5126 (LOCATION_PRINT, skel_control_t): New.
5127
24fad99e
AD
51282001-12-30 Akim Demaille <akim@epita.fr>
5129
5130 * src/parse-skel.y: Get rid of the shift/reduce conflict:
5131 replace `gb' with BLANKS.
5132 * src/scan-skel.l: Adjust.
5133
a4b36db4
AD
51342001-12-30 Akim Demaille <akim@epita.fr>
5135
5136 * src/system.h: We don't need nor want bcopy.
5137 Throw away MS-DOS crap: we don't need getpid.
5138 * configure.in: We don't need strndup. It was even causing
5139 problems: because Flex includes the headers *before* us,
5140 _GNU_SOURCE is not defined by config.h, and therefore strndup was
5141 not visible.
5142 * lib/xstrndup.c: New.
5143 * src/scan-skel.l: Use it.
5144 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
5145 * src/parse-skel.y: Use %directives instead of #defines.
5146
1239777d
AD
51472001-12-30 Akim Demaille <akim@epita.fr>
5148
5149 * src/skeleton.h: New.
5150 * src/output.c (output_parser, output_master_parser): Remove, dead
5151 code.
5152 * src/output.h (get_lines_number, actions_output, guards_output)
5153 (token_definitions_output): Prototype them.
5154 * src/parse-skel.y: Add the license notice.
5155 Include output.h and skeleton.h.
5156 (process_skeleton): Returns void, and takes a single parameter.
5157 * src/scan-skel.l: Add the license notice.
5158 Include skeleton.h.
5159 Don't use %option yylineno: it seems that then Flex imagines
5160 REJECT has been used, and therefore it won't reallocate its
5161 buffers (which makes no other sense to me than a bug). It results
5162 in warnings for `unused: yy_flex_realloc'.
5163
9b3add5b
RA
51642001-12-30 Robert Anisko <robert.anisko@epita.fr>
5165
5166 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5167 (MUSCLE_INSERT_PREFIX): ...to there.
5168 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5169 (MUSCLE_INSERT_PREFIX): Move from here...
5170
5171 * src/bison.hairy: Add a section directive. Put braces around muscle
5172 names. This parser skeleton is still broken, but Bison should not
5173 choke on a bad muscle 'syntax'.
5174 * src/bison.simple: Add a section directive. Put braces around muscle
5175 names.
5176
5177 * src/files.h (strsuffix, stringappend): Add declarations.
5178 (tab_extension): Add declaration.
5179 (short_base_name): Add declaration.
5180
5181 * src/files.c (strsuffix, stringappend): No longer static. These
5182 functions are used in the skeleton parser.
5183 (tab_extension): New.
5184 (compute_base_names): Use the computations done in this function
fab5b110 5185 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
5186 names.
5187 (short_base_name): No longer static.
5188
5189 * src/output.c (output_skeleton): New.
5190 (output): Disable call to output_master_parser, and give a try to
5191 a new skeleton handling system.
5192 (guards_output, actions_output): No longer static.
5193 (token_definitions_output, get_lines_number): No longer static.
5194
5195 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
5196
fab5b110 5197 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
5198 parse-skel.y.
5199
5200 * src/parse-skel.y: New file.
5201 * src/scan-skel.l: New file.
5202
b5b61c61
AD
52032001-12-29 Akim Demaille <akim@epita.fr>
5204
5205 %name-prefix is broken.
5206
5207 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
5208 Adjust all dependencies.
5209 * tests/headers.at (export YYLTYPE): Strengthen this test: use
5210 %name-prefix.
5211
5212 Renaming yylval but not yylloc is not consistent. Now we do.
5213
5214 * src/bison.simple: Prefix yylloc if used.
5215 * doc/bison.texinfo (Decl Summary): Document that.
5216
8c9a50be
AD
52172001-12-29 Akim Demaille <akim@epita.fr>
5218
5219 * doc/bison.texinfo: Promote `%long-directive' over
5220 `%long_directive'.
5221 Remove all references to fixed-output-files, yacc is enough.
5222
d99361e6
AD
52232001-12-29 Akim Demaille <akim@epita.fr>
5224
5225 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
5226 user prologue. These are defaults.
5227 * tests/actions.at (Mid-rule actions): Make sure the user can
5228 define YYDEBUG and YYERROR_VERBOSE.
5229
b9cecb91
AD
52302001-12-29 Akim Demaille <akim@epita.fr>
5231
5232 * src/output.c (header_output): Don't forget to export YYLTYPE and
5233 yylloc.
5234 * tests/headers.at (export YYLTYPE): New, make sure it does.
5235 * tests/regression.at (%union and --defines, Invalid CPP headers):
5236 Move to...
5237 * tests/headers.at: here.
5238
aea13e97
AD
52392001-12-29 Akim Demaille <akim@epita.fr>
5240
5241 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
5242
931394cb
AD
52432001-12-29 Akim Demaille <akim@epita.fr>
5244
5245 * tests/actions.at (Mid-rule actions): Output on a single line
5246 instead of several.
5247
704a47c4
AD
52482001-12-29 Akim Demaille <akim@epita.fr>
5249
5250 * doc/bison.texinfo: Formatting changes.
5251
091e20bb
AD
52522001-12-29 Akim Demaille <akim@epita.fr>
5253
5254 Don't store the token defs in a muscle, just be ready to output it
5255 on command. Now possible via `symbols'. Fixes a memory leak.
5256
5257 * src/output.c (token_definitions_output): New.
5258 (output_parser, header_output): Use it.
5259 * src/reader.c (symbols_save): Remove.
5260
cce71710
AD
52612001-12-29 Akim Demaille <akim@epita.fr>
5262
5263 * src/bison.simple: Do not provide a default for YYSTYPE and
5264 YYLTYPE before the user's prologue. Otherwise it's hardly... a
5265 default.
5266
82c035a8
AD
52672001-12-29 Akim Demaille <akim@epita.fr>
5268
5269 Mid-rule actions are simply... ignored!
5270
5271 * src/reader.c (readgram): Be sure to attach mid-rule actions to
5272 the empty-rule associated to the dummy symbol, not to the host
5273 rule.
5274 * tests/actions.at (Mid-rule actions): New.
5275
8419d367
AD
52762001-12-29 Akim Demaille <akim@epita.fr>
5277
5278 Memory leak.
5279
5280 * src/reader.c (reader): Free grammar.
5281
375d5806
AD
52822001-12-29 Akim Demaille <akim@epita.fr>
5283
5284 Memory leak.
5285
5286 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
5287 since it allocates it for each state, although only one is needed.
5288 (allocate_storage): Do it here.
5289
f51cb8ff
AD
52902001-12-29 Akim Demaille <akim@epita.fr>
5291
5292 * src/options.h, src/options.c (create_long_option_table): Rename
5293 as...
5294 (long_option_table_new): this, with a clearer prototype.
5295 (percent_table): Remove, unused,
5296 * src/getargs.c (getargs): Adjust.
5297
29e88316
AD
52982001-12-29 Akim Demaille <akim@epita.fr>
5299
5300 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
5301 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
5302 as states.
5303
b9f71f19
AD
53042001-12-29 Akim Demaille <akim@epita.fr>
5305
5306 * src/lalr.c (build_relations): Rename `states' as `states1'.
5307 Sorry, I don't understand exactly what it is, no better name...
5308
1a2b5d37
AD
53092001-12-29 Akim Demaille <akim@epita.fr>
5310
5311 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
5312 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
5313 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
5314 as rules.
5315
1cca533e
AD
53162001-12-29 Akim Demaille <akim@epita.fr>
5317
5318 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
5319 ago.
5320
c03ae966
AD
53212001-12-29 Akim Demaille <akim@epita.fr>
5322
5323 * src/reader.c, src/reader.h (user_toknums): Remove.
5324 Adjust all users to use symbols[i]->user_token_number.
5325
5a670b1e
AD
53262001-12-29 Akim Demaille <akim@epita.fr>
5327
5328 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
5329 Adjust all users to use symbols[i]->prec or ->assoc.
5330
ad949da9
AD
53312001-12-29 Akim Demaille <akim@epita.fr>
5332
5333 * src/reader.c, src/reader.h (tags): Remove.
5334 Adjust all users to use symbols[i]->tag.
5335
0e78e603
AD
53362001-12-29 Akim Demaille <akim@epita.fr>
5337
5338 * src/gram.h, src/gram.c (symbols): New, similar to state_table
5339 and rule_table.
5340 * src/reader.c (packsymbols): Fill this table.
5341 Drop sprec.
5342 * src/conflicts.c (resolve_sr_conflict): Adjust.
5343 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
5344 single table.
5345 Use symbols[i]->tag instead of tags[i].
5346
213e640e
AD
53472001-12-29 Akim Demaille <akim@epita.fr>
5348
5349 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
5350 In addition, put a comment in there, to replace...
5351 * tests/regression.at (%union and C comments): Remove.
5352
e7b8bef1
AD
53532001-12-29 Akim Demaille <akim@epita.fr>
5354
5355 * tests/regression.at (Web2c Actions): Blindly move the actual
5356 output as expected output. The contents *seem* right to me, but I
5357 can't pretend reading perfectly parser tables... Nonetheless, all
5358 the other tests pass correctly, the table look OK, even though the
5359 presence of `$axiom' is to be noted: AFAICS it is useless (but
5360 harmless).
5361
b68e7744
AD
53622001-12-29 Akim Demaille <akim@epita.fr>
5363
5364 * src/reader.c (readgram): Don't add the rule 0 if there were no
5365 rules read. In other words, add it _after_ having performed
5366 grammar sanity checks.
5367 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
5368
78d5bae9
AD
53692001-12-29 Akim Demaille <akim@epita.fr>
5370
5371 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
5372 visible, and some states have now a different number.
5373
ff442794
AD
53742001-12-29 Akim Demaille <akim@epita.fr>
5375
5376 * src/reader.c (readgram): Bind the initial rule's lineno to that
5377 of the first rule.
5378 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5379 (Solved SR Conflicts): Adjust rule 0's line number.
5380
610ab194
AD
53812001-12-29 Akim Demaille <akim@epita.fr>
5382
5383 Fix the `GAWK Grammar' failure.
5384
5385 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5386 the reductions of the first state which was mistakenly confused
5387 with the final state because precisely final_state was initialized
5388 to 0.
5389 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5390 now noticed by Bison.
5391 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5392 have a reduction on $default.
5393
29d29c8f
AD
53942001-12-29 Akim Demaille <akim@epita.fr>
5395
5396 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5397 rule line numbers.
5398 * src/closure.c (print_closure): Likewise.
5399 * src/derives.c (print_derives): Likewise.
5400 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5401 now.
5402
7c6b64d0
AD
54032001-12-29 Akim Demaille <akim@epita.fr>
5404
5405 * src/lalr.c (lookaheads_print): New.
5406 (lalr): Call it when --trace-flag.
5407 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5408 are dumped.
5409
3d4daee3
AD
54102001-12-29 Akim Demaille <akim@epita.fr>
5411
5412 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5413 when walking through ritem, even via rule->rhs.
5414 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5415 (useful_production, useless_nonterminals): Likewise.
5416 (reduce_grammar_tables): Likewise, plus update nritems.
5417 * src/nullable.c (set_nullable): Likewise.
5418 * src/lalr.c (build_relations): Likewise.
5419 * tests/sets.at (Nullable): Adjust.
5420 Fortunately, now, the $axiom is no longer nullable.
5421
9e7f6bbd
AD
54222001-12-29 Akim Demaille <akim@epita.fr>
5423
5424 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5425 the 0-sentinel.
5426 * src/gram.c (ritem_longest_rhs): Likewise.
5427 * src/reduce.c (nonterminals_reduce): Likewise.
5428 * src/print_graph.c (print_graph): Likewise.
5429 * src/output.c (output_rule_data): Likewise.
5430 * src/nullable.c (set_nullable): Likewise.
5431
255ef638
AD
54322001-12-29 Akim Demaille <akim@epita.fr>
5433
5434 * src/output.c: Comment changes.
5435
0d8a7363
AD
54362001-12-27 Paul Eggert <eggert@twinsun.com>
5437
5438 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5439 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5440 Sparc, as they were causing more porting problems than the
5441 (minor) performance improvement was worth.
5442
5443 Also, catch up with 1.31's YYSTD.
5444
3db472b9
AD
54452001-12-27 Akim Demaille <akim@epita.fr>
5446
5447 * src/output.c (output_gram): Rely on nritems, not the
5448 0-sentinel. See below.
5449 Use -1 as separator, not 0.
5450 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5451 Rely on -1 as separator in yyrhs, instead of 0.
5452 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5453 twice `Now at end of input', therefore there are two lines less to
5454 expect.
5455
b365aa05
AD
54562001-12-27 Akim Demaille <akim@epita.fr>
5457
5458 * tests/regression.at (Unresolved SR Conflicts):
5459 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5460 below.
5461
30171f79
AD
54622001-12-27 Akim Demaille <akim@epita.fr>
5463
5464 * src/LR0.c (new_state): Recognize the final state by the fact it
5465 is reached by eoftoken.
5466 (insert_start_shifting_state, insert_eof_shifting_state)
5467 (insert_accepting_state, augment_automaton): Remove, since now
5468 these states are automatically computed from the initial state.
5469 (generate_states): Adjust.
5470 * src/print.c: When reporting a rule number to the user, substract
5471 1, so that the axiom rule is rule 0, and the first user rule is 1.
5472 * src/reduce.c: Likewise.
5473 * src/print_graph.c (print_core): For the time being, just as for
5474 the report, depend upon --trace-flags to dump the full set of
5475 items.
5476 * src/reader.c (readgram): Once the grammar read, insert the rule
5477 0: `$axiom: START-SYMBOL $'.
5478 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5479 number of the states has changed (the final state is no longer
5480 necessarily the last), catch up.
5481
75142d45
AD
54822001-12-27 Akim Demaille <akim@epita.fr>
5483
5484 Try to make the use of the eoftoken valid. Given that its value
5485 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5486 is used instead of > 0 where appropriate, (ii), depend upon nritems
5487 instead of the 0-sentinel.
5488
5489 * src/gram.h, src/gram.c (nritems): New.
5490 Expected to be duplication of nitems, but for the time being...
5491 * src/reader.c (packgram): Assert nritems and nitems are equal.
5492 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5493 * src/closure.c (print_closure, print_fderives): Likewise.
5494 * src/gram.c (ritem_print): Likewise.
5495 * src/print.c (print_core, print_grammar): Likewise.
5496 * src/print_graph.c: Likewise.
5497
b7c49edf
AD
54982001-12-27 Akim Demaille <akim@epita.fr>
5499
5500 * src/main.c (main): If there are complains after grammar
5501 reductions, then output the report anyway if requested, then die.
5502 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5503 * src/reader.c (eoftoken): New.
5504 (parse_token_decl): If the token being defined has value `0', it
5505 is the eoftoken.
5506 (packsymbols): No longer hack `tags' to insert `$' by hand.
5507 Be sure to preserve the value of the eoftoken.
5508 (reader): Make sure eoftoken is defined.
5509 Initialize nsyms to 0: now eoftoken is created just like the others.
5510 * src/print.c (print_grammar): Don't special case the eof token.
5511 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5512 lie anyway, albeit pleasant.
5513 * tests/calc.at: Exercise error messages with eoftoken.
5514 Change the grammar so that empty input is invalid.
5515 Adjust expectations.
5516 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5517
ec2da99f
AD
55182001-12-27 Akim Demaille <akim@epita.fr>
5519
5520 * configure.in: Check the protos of strchr ans strspn.
5521 Replace strchr if needed.
5522 * src/system.h: Provide the protos of strchr, strspn and memchr if
5523 missing.
5524 * lib/strchr.c: New.
5525 * src/reader.c (symbols_save): Use strchr.
5526
8adfa272
AD
55272001-12-27 Akim Demaille <akim@epita.fr>
5528
5529 * src/print.c, src/print_graph.c (escape): New.
5530 Use it to quote the TAGS outputs.
5531 * src/print_graph.c (print_state): Now errors are in red, and
5532 reductions in green.
5533 Prefer high to wide: output the state number on a line of its own.
5534
80dac38c
AD
55352001-12-27 Akim Demaille <akim@epita.fr>
5536
5537 * src/state.h, src/state.c (reductions_new): New.
5538 * src/LR0.c (set_state_table): Let all the states have a
5539 `reductions', even if reduced to 0.
5540 (save_reductions): Adjust.
5541 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5542 * src/print.c (print_reductions, print_actions): Adjust.
5543 * src/output.c (action_row): Adjust.
5544
2cec70b9
AD
55452001-12-27 Akim Demaille <akim@epita.fr>
5546
5547 * src/state.h, src/state.c (errs_new, errs_dup): New.
5548 * src/LR0.c (set_state_table): Let all the states have an errs,
5549 even if reduced to 0.
5550 * src/print.c (print_errs, print_reductions): Adjust.
5551 * src/output.c (output_actions, action_row): Adjust.
5552 * src/conflicts.c (resolve_sr_conflict): Adjust.
5553
13ca549a
AD
55542001-12-27 Akim Demaille <akim@epita.fr>
5555
5556 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5557
5092aba5
AD
55582001-12-27 Akim Demaille <akim@epita.fr>
5559
5560 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5561 * src/print.c: here.
5562 (lookaheadset, shiftset): New, used as additional storage by
5563 print_reductions.
5564 (print_results): Adjust.
5565 (print_shifts, print_gotos, print_errs): New, extracted from...
5566 (print_actions): here.
5567 * src/print_graph.c (print_actions): Remove dead code.
5568
11e2beca
AD
55692001-12-27 Akim Demaille <akim@epita.fr>
5570
5571 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5572 `$n' and `@n'.
5573
dac3c910
AD
55742001-12-27 Akim Demaille <akim@epita.fr>
5575
5576 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5577 (build_relations): Adjust.
5578
d0b0fefa
AD
55792001-12-27 Akim Demaille <akim@epita.fr>
5580
5581 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5582 duplication.
5583
adc8c848
AD
55842001-12-27 Akim Demaille <akim@epita.fr>
5585
5586 * src/reader.c (packgram): Catch nitems overflows.
5587
14d293ac
AD
55882001-12-27 Akim Demaille <akim@epita.fr>
5589
5590 * src/files.c, src/files.h (guard_obstack): Remove.
5591 * src/output.c (output): Adjust.
5592 * src/reader.c (parse_braces): New, factoring...
5593 (copy_action, copy_guard): these two which are renamed as...
5594 (parse_action, parse_guard): these.
5595 As a voluntary consequence, using braces around guards is now
5596 mandatory.
5597
f499b062
AD
55982001-12-27 Akim Demaille <akim@epita.fr>
5599
5600 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5601 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5602 members.
5603 (symbol_list_new): Adjust.
5604 (copy_action): action_line is the first line, not the last.
5605 (copy_guard): Just as for actions, store the `action' only, not
5606 the switch/case/break flesh.
5607 Don't parse the user action that might follow the guard, let...
5608 (readgram): do it, i.e., now, there can be an action after a
5609 guard.
5610 In other words the guard is just explicitly optional.
5611 (packgram): Adjust.
5612 * src/output.c (guards_output): New.
5613 (output_parser): Call it when needed.
5614 (output): Also free the guard and attrs obstacks.
5615 * src/files.c, src/files.h (obstack_save): Remove.
5616 (output_files): Remove.
5617 As a result, if one needs the former `.act' file, using an
5618 appropriate skeleton which requires actions and guards is now
5619 required.
5620 * src/main.c (main): Adjust.
5621 * tests/semantic.at: New.
5622 * tests/regression.at: Use `input.y' as input file name.
5623 Avoid 8+3 problems by requiring input.c when the test needs the
5624 parser.
5625
d945f5cd
AD
56262001-12-27 Akim Demaille <akim@epita.fr>
5627
5628 * src/reader.c (symbol_list_new): Be sure to initialize all the
5629 fields.
5630
d200e455
AD
56312001-12-27 Akim Demaille <akim@epita.fr>
5632
5633 All the hacks using a final pseudo state are now useless.
5634
5635 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5636 * src/lalr.c (nLA): New.
5637 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5638 instead of lookaheadsp from the pseudo state (nstate + 1).
5639
f9507c28
AD
56402001-12-27 Akim Demaille <akim@epita.fr>
5641
5642 * src/output.c (action_row, token_actions): Use a state_t instead
5643 of a integer, and nlookaheads instead of the following state's
5644 lookaheadsp.
5645
065fbd27
AD
56462001-12-27 Akim Demaille <akim@epita.fr>
5647
5648 * src/conflicts.c (log_resolution, flush_shift)
5649 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5650 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5651 (conflicts_print, print_reductions): Use a state_t instead of an
5652 integer when referring to a state.
5653 As much as possible, depend upon nlookaheads, instead of the
5654 `lookaheadsp' member of the following state (since lookaheads of
5655 successive states are successive, the difference between state n + 1
5656 and n served as the number of lookaheads for state n).
5657 * src/lalr.c (add_lookback_edge): Likewise.
5658 * src/print.c (print_core, print_actions, print_state)
5659 (print_results): Likewise.
5660 * src/print_graph.c (print_core, print_actions, print_state)
5661 (print_graph): Likewise.
5662 * src/conflicts.h: Adjust.
5663
1b177bd7
AD
56642001-12-27 Akim Demaille <akim@epita.fr>
5665
5666 * src/bison.hairy: Formatting/comment changes.
5667 ANSIfy.
5668 Remove `register' indications.
5669 Add plenty of `static'.
5670
7742ddeb
AD
56712001-12-27 Akim Demaille <akim@epita.fr>
5672
5673 * src/output.c (prepare): Drop the muscle `ntbase' which
5674 duplicates ntokens.
5675 * src/bison.simple: Formatting/comment changes.
5676 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5677 is an undocumented synonym.
5678
1fa14068
AD
56792001-12-22 Akim Demaille <akim@epita.fr>
5680
5681 * src/output.c (output_table_data): Change the prototype to use
5682 `int' for array ranges: some invocations do pass an int, not a
5683 short.
5684 Reported by Wayne Green.
5685
b9752825
AD
56862001-12-22 Akim Demaille <akim@epita.fr>
5687
5688 Some actions of web2c.y are improperly triggered.
5689 Reported by Mike Castle.
5690
5691 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5692 * tests/regression.at (Web2c): Rename as...
5693 (Web2c Report): this.
5694 (Web2c Actions): New.
5695
776209d6
AD
56962001-12-22 Akim Demaille <akim@epita.fr>
5697
5698 Reductions in web2c.y are improperly reported.
5699 Reported by Mike Castle.
5700
5701 * src/conflicts.c (print_reductions): Fix.
5702 * tests/regression.at (Web2c): New.
5703
275fc3ad
AD
57042001-12-18 Akim Demaille <akim@epita.fr>
5705
5706 Some host fail on `assert (!"foo")', which expands to
5707 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5708 Reported by Nelson Beebee.
5709
5710 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5711 `#define it_succeeded 0' and `assert (it_succeeded)'.
5712
897668ee
MA
57132001-12-17 Marc Autret <autret_m@epita.fr>
5714
5715 * src/bison.simple: Don't hard code the skeleton line and filename.
5716 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5717 New line counter 'skeleton_line' (skeleton-line muscle).
5718
ab3399e0
PE
57192001-12-17 Paul Eggert <eggert@twinsun.com>
5720
5721 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5722 YYDEBUG must be defined to a nonzero value.
5723
5724 * src/bison.simple (yytname): Do not assume that the user defines
5725 YYDEBUG to a properly parenthesized expression.
5726
3877f72b
AD
57272001-12-17 Akim Demaille <akim@epita.fr>
5728
5729 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5730 nlookaheads is a new member.
5731 Adjust all users.
5732 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5733 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5734 state.
776209d6 5735
331dbc1b
AD
57362001-12-17 Akim Demaille <akim@epita.fr>
5737
5738 * src/files.h, src/files.c (open_files, close_files): Remove.
5739 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5740 let...
5741 * src/reader.c (reader): Do it.
776209d6 5742
be750e4c
AD
57432001-12-17 Akim Demaille <akim@epita.fr>
5744
5745 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 5746
709ae8c6
AD
57472001-12-17 Akim Demaille <akim@epita.fr>
5748
5749 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5750 (flush_reduce): New.
5751 (resolve_sr_conflict): Adjust.
776209d6 5752
f87685c3
AD
57532001-12-17 Akim Demaille <akim@epita.fr>
5754
5755 * src/output.c (output_obstack): Be static and rename as...
5756 (format_obstack): this, to avoid any confusion with files.c's
5757 output_obstack.
5758 * src/reader.h (muscle_obstack): Move to...
5759 * src/output.h: here, since it's defined in output.c.
5760
837491d8
AD
57612001-12-17 Akim Demaille <akim@epita.fr>
5762
5763 * src/output.c (action_row, save_column, default_goto)
5764 (sort_actions, matching_state, pack_vector): Better variable
5765 locality.
5766
796d61fb
AD
57672001-12-17 Akim Demaille <akim@epita.fr>
5768
5769 * src/output.c: Various formatting changes.
776209d6 5770
64d15509
AD
57712001-12-17 Akim Demaille <akim@epita.fr>
5772
5773 * src/files.c (output_files): Free the output_obstack.
5774 * src/main.c (main): Call print and print_graph conditionally.
5775 * src/print.c (print): Work unconditionally.
5776 * src/print_graph.c (print_graph): Work unconditionally.
5777 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5778
fbc8ecb7
MA
57792001-12-16 Marc Autret <autret_m@epita.fr>
5780
5781 * src/output.c (actions_output): Fix. When we use %no-lines,
5782 there is one less line per action.
5783
f0440388
MA
57842001-12-16 Marc Autret <autret_m@epita.fr>
5785
5786 * src/bison.simple: Remove a useless #line directive.
5787 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5788 * src/output.c (get_lines_number): New.
776209d6 5789 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
5790 output muscles.
5791 Fix line numbering.
5792 (actions_output): Computes the number of lines taken by actions.
5793 (output_master_parser): Insert new skeleton which is the name of
5794 the output parser file name.
5795
a79986b8
MA
57962001-12-15 Marc Autret <autret_m@epita.fr>
5797
5798 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5799
4ec8e00f
MA
58002001-12-15 Marc Autret <autret_m@epita.fr>
5801
5802 * src/output.c (output_gram): Keep track of the hairy one.
5803
1a4648ff
AD
58042001-12-15 Akim Demaille <akim@epita.fr>
5805
5806 Make `make distcheck' work.
5807
5808 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5809 system.h which uses libgettext.h.
5810
9c2c67e6
AD
58112001-12-15 Akim Demaille <akim@epita.fr>
5812
5813 * src/nullable.c (set_nullable): Useless rules must be skipped,
5814 otherwise, since we range over their symbols, we might look at a
5815 nonterminal which no longer ``exists'', i.e., it is not counted in
5816 `nvars', hence we overflow our arrays.
5817
93ede233
AD
58182001-12-15 Akim Demaille <akim@epita.fr>
5819
5820 The header can also be produced directly, without any obstack!
5821 Yahoo!
5822
5823 * src/files.c, src/files.h (defines_obstack): Remove.
5824 (compute_header_macro): Global.
5825 (defines_obstack_save): Remove.
5826 * src/reader.c (parse_union_decl): No longer output to
5827 defines_obstack: its content can be found in the `stype' muscle
5828 anyway.
5829 (output_token_translations): Merge into...
5830 (symbols_output): this.
5831 Rename as...
5832 (symbols_save): this.
5833 (reader): Adjust.
5834 * src/output.c (header_output): New.
5835 (output): Call it.
5836
2666f928
AD
58372001-12-15 Akim Demaille <akim@epita.fr>
5838
5839 * src/reader.c (parse_union_decl): Instead of handling two obstack
5840 simultaneously, use one to define the `stype' muscle, and use the
5841 value of the latter to fill defines_obstack.
5842 (copy_comment): Remove.
5843 (copy_comment2): Work for a single obstack.
5844 Rename as...
5845 (copy_comment): this.
5846
428046f8
AD
58472001-12-15 Akim Demaille <akim@epita.fr>
5848
5849 * src/lex.c, src/lex.h (xgetc): No longer static.
5850 * src/reader.c (parse_union_decl): Revamp.
5851
ea52d706
AD
58522001-12-15 Akim Demaille <akim@epita.fr>
5853
5854 Still making progress in separating Bison into (i) input, (ii)
5855 process, (iii) output: now we can directly output the parser file
5856 without using table_obstack at all.
5857
5858 * src/files.c, src/files.h (table_obstack): Bye bye.
5859 (parser_file_name): New.
5860 * src/files.c (compute_output_file_names): Compute it.
5861 * src/output.c (actions_output, output_parser)
5862 (output_master_parser): To a file instead of an obstack.
5863
3f96f4dc
AD
58642001-12-15 Akim Demaille <akim@epita.fr>
5865
5866 Attach actions to rules, instead of pre-outputting them to
5867 actions_obstack.
5868
5869 * src/gram.h (rule_t): action and action_line are new members.
5870 * src/reader.c (symbol_list): Likewise.
5871 (copy_action): Save the actions within the rule.
5872 (packgram): Save them in rule_table.
5873 * src/output.c (actions_output): New.
5874 (output_parser): Use it on `%%actions'.
5875 (output_rule_data): Don't free rule_table.
5876 (output): Do it.
5877 (prepare): Don't save the `action' muscle.
5878 * src/bison.simple: s/%%action/%%actions/.
5879
51576fb3
AD
58802001-12-15 Akim Demaille <akim@epita.fr>
5881
5882 * src/reader.c (copy_action): When --yacc, don't append a `;'
5883 to the user action: let it fail if lacking.
dee049eb 5884 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 5885
2648a72d
AD
58862001-12-14 Akim Demaille <akim@epita.fr>
5887
5888 * src/lex.c (literalchar): Simply return the char you decoded, non
5889 longer mess around with obstacks and int pointers.
5890 Adjust all callers.
5891
92790e5b
AD
58922001-12-14 Akim Demaille <akim@epita.fr>
5893
5894 * src/lex.c (literalchar): Don't escape the special characters,
5895 just decode them, and keep them as char (before, eol was output as
5896 the 2 char string `\n' etc.).
5897 * src/output.c (output_rule_data): Use quotearg to output the
5898 token strings.
5899
927c1557
PE
59002001-12-13 Paul Eggert <eggert@twinsun.com>
5901
5902 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
5903 Do not infringe on the global user namespace when using C++.
5904 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
5905 All uses of `fprintf' and `stderr' changed.
5906
5907 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
5908
ed8e1f68
AD
59092001-12-13 Akim Demaille <akim@epita.fr>
5910
5911 The computation of nullable is broken: it doesn't handle empty
5912 RHS's properly.
5913
5914 * tests/torture.at (GNU AWK Grammar): New.
5915 * tests/sets.at (Nullable): New.
5916 * src/nullable.c (set_nullable): Instead of blindly looping over
5917 `ritems', loop over the rules, and then over their rhs's.
5918
5919 Work around Autotest bugs.
5920
5921 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
5922 frame, because Autotest understand lines starting with a `+' as
5923 traces from the shell. Then, they are not processed properly.
5924 Admittedly an Autotest bug, but we don't have time to wait for
5925 Autotest to catch up.
5926 * tests/regression.at (Broken Closure): Adjust to the new table
5927 frames.
5928 Move to...
5929 * tests/sets.at: here.
5930
cb581495
AD
59312001-12-13 Akim Demaille <akim@epita.fr>
5932
5933 * src/closure.c (closure): Use nrules instead of playing tricks
5934 with BITS_PER_WORD.
5935
2e729273
AD
59362001-12-13 Akim Demaille <akim@epita.fr>
5937
5938 * src/print.c (print_actions): Output the handling of `$' as the
5939 traces do: shifting the token EOF. Before EOF was treated as a
5940 nonterminal.
5941 * tests/regression.at: Adjust some tests.
5942 * src/print_graph.c (print_core): Complete the set of items via
5943 closure. The next-to-final and final states are still unsatisfying,
5944 but that's to be addressed elsewhere.
5945 No longer output the rule numbers, but do output the state number.
5946 A single loop for the shifts + gotos is enough, but picked a
5947 distinct color for each.
5948 (print_graph): Initialize and finalize closure.
5949
107f7dfb
AD
59502001-12-13 Akim Demaille <akim@epita.fr>
5951
5952 * src/reader.c (readgram): Remove dead code, an strip useless
5953 braces.
5954 (get_type): Remove, unused.
5955
9b53a24f
AD
59562001-12-12 Akim Demaille <akim@epita.fr>
5957
5958 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
5959 on that of lib/error.c.
5960
dbfb6dcd
AD
59612001-12-12 Akim Demaille <akim@epita.fr>
5962
5963 Some hosts don't like `/' in includes.
5964
5965 * src/system.h: Include libgettext.h without qualifying the path.
5966 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
5967 $(top_srcdir).
5968
c25fb648
MA
59692001-12-11 Marc Autret <autret_m@epita.fr>
5970
5971 * src/output.c (output_parser): Remove useless muscle.
5972
710ddc4f
MA
59732001-12-11 Marc Autret <autret_m@epita.fr>
5974
5975 * src/bison.simple: Remove #line just before %%epilogue. It
5976 is now handled in ...
5977 * src/reader.c (read_additionnal_code): Add the output of a
5978 #line for the epilogue.
5979
e83d80b8
MA
59802001-12-10 Marc Autret <autret_m@epita.fr>
5981
927c1557 5982 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
5983 replace precedent remove.
5984 * src/bison.simple: Remove #line before %%prologue because
5985 %%input-line is wrong at this time.
5986
971d5158
MA
59872001-12-10 Marc Autret <autret_m@epita.fr>
5988
5989 * src/reader.c (symbols_output): Clean up.
927c1557 5990 * src/output.c (output_gram, output): Clean up.
971d5158 5991
5edafffd
AD
59922001-12-10 Akim Demaille <akim@epita.fr>
5993
5994 * src/lalr.c (initialize_lookaheads): New. Extracted from...
5995 * src/LR0.c (set_state_table): here.
5996 * src/lalr.c (lalr): Call it.
5997
0279f8e9
AD
59982001-12-10 Akim Demaille <akim@epita.fr>
5999
6000 * src/state.h (shifts): Remove the `number' member: shifts are
6001 attached to state, hence no longer need to be labelled with a
6002 state number.
6003
190c4f5f
AD
60042001-12-10 Akim Demaille <akim@epita.fr>
6005
6006 Now that states have a complete set of members, the linked list of
6007 shifts is useless: just fill directly the state's shifts member.
6008
6009 * src/state.h (shifts): Remove the `next' member.
6010 * src/LR0.c (first_state, last_state): Remove.
6011 Adjust the callers.
6012 (augment_automaton): Don't look for the shifts that must be added
6013 a shift on EOF: it is those of the state we looked for! But now,
6014 since shifts are attached, it is no longer needed to looking
6015 merely by its id: its number.
6016
2a73b93d
AD
60172001-12-10 Akim Demaille <akim@epita.fr>
6018
6019 * src/LR0.c (augment_automaton): Better variable locality.
6020 Remove an impossible branch: if there is a state corresponding to
6021 the start symbol being shifted, then there is shift for the start
6022 symbol from the initial state.
6023
74392f6a
AD
60242001-12-10 Akim Demaille <akim@epita.fr>
6025
6026 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
6027 only when appropriate: when insert_start_shifting_state' is not
6028 invoked.
6029 * tests/regression.at (Rule Line Numbers): Adjust.
6030
37c82725
AD
60312001-12-10 Akim Demaille <akim@epita.fr>
6032
6033 * src/LR0.c (augment_automaton): Now that all states have shifts,
6034 merge the two cases addition shifts to the initial state.
6035
6a164e0c
AD
60362001-12-10 Akim Demaille <akim@epita.fr>
6037
6038 * src/lalr.c (set_state_table): Move to...
6039 * src/LR0.c: here.
6040 * src/lalr.c (lalr): Don't call it...
6041 * src/LR0.c (generate_states): do it.
6042 * src/LR0.h (first_state): Remove, only the table is used.
6043
7215de24
AD
60442001-12-10 Akim Demaille <akim@epita.fr>
6045
6046 * src/LR0.h (first_shift, first_reduction): Remove.
6047 * src/lalr.c: Don't use first_shift: find shifts through the
6048 states.
6049
80e25d4d
AD
60502001-12-10 Akim Demaille <akim@epita.fr>
6051
6052 * src/LR0.c: Attach shifts to states as soon as they are
6053 computed.
6054 * src/lalr.c (set_state_table): Instead of assigning shifts to
6055 state, just assert that the mapping was properly done.
6056
0ab3728b
AD
60572001-12-10 Akim Demaille <akim@epita.fr>
6058
6059 * src/LR0.c (insert_start_shift): Rename as...
6060 (insert_start_shifting_state): this.
6061 (insert_eof_shifting_state, insert_accepting_state): New.
6062 (augment_automaton): Adjust.
6063 Better locality of the variables.
6064 When looking if the start_symbol is shifted from the initial
6065 state, using `while (... symbol != start_symbol ...)' sounds
6066 better than `while (... symbol < start_symbol ...)': If fail
6067 to see how the order between symbols could be relevant!
6068
78af9bbc
AD
60692001-12-10 Akim Demaille <akim@epita.fr>
6070
6071 * src/getargs.h: Don't declare `spec_name_prefix' and
6072 `spec_file_prefix', declared by src/files.h.
6073 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
6074 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
6075 * src/output.c (prepare): Adjust.
6076 * src/reader.c (symbols_output): Likewise.
6077 * src/vmsgetargs.c: Vaguely adjust, but who cares?
6078
bdef2a41
AD
60792001-12-10 Akim Demaille <akim@epita.fr>
6080
6081 * src/muscle_tab.c (muscle_init): NULL is a better default than
6082 `"0"'.
6083
3735969c
AD
60842001-12-10 Akim Demaille <akim@epita.fr>
6085
6086 * src/reader.c (reader): Calling symbols_output once is enough.
6087
49701457
AD
60882001-12-10 Akim Demaille <akim@epita.fr>
6089
6090 Now that states have a complete set of members, the linked list of
6091 reductions is useless: just fill directly the state's reductions
6092 member.
6093
6094 * src/state.h (struct reductions): Remove member `number' and
6095 `next'.
6096 * src/LR0.c (first_reduction, last_reduction): Remove.
6097 (save_reductions): Don't link the new reductions, store them in
6098 this_state.
6099 * src/lalr.c (set_state_table): No need to attach reductions to
6100 states, it's already done.
6101 * src/output.c (output_actions): No longer free the shifts, then
6102 the reductions, then the states: free all the states and their
6103 members.
6104
0edad749
AD
61052001-12-10 Akim Demaille <akim@epita.fr>
6106
6107 * src/options.c (OPTN, DRTV, BOTH): New.
6108 (option_table): Use them.
6109
0edad749
AD
6110 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
6111 the job of system.h.
6112 * src/options.c: Don't include stdio.h and xalloc.h for the same
6113 reasons.
6114
5449dd0f
AD
61152001-12-10 Akim Demaille <akim@epita.fr>
6116
6117 * src/output.c (output, prepare): Make sure the values of the
6118 muscles `action' and `prologue' are 0-terminated.
6119
a870c567
AD
61202001-12-10 Akim Demaille <akim@epita.fr>
6121
6122 Clean up GCC warnings.
6123
6124 * src/reader.c (copy_action): `buf' is not used.
6125 (parse_skel_decl): Be static.
6126 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
6127 * src/options.h (create_long_option_table): Have a real prototype.
6128 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
6129 (hash_delete_at): Return const void *.
6130 Adjust casts to preserve the const.
6131
80df8768
AD
61322001-12-10 Akim Demaille <akim@epita.fr>
6133
6134 * configure.in: Require 2.52g.
6135 M4 is not needed, but AUTOM4TE is.
6136 * m4/m4.m4: Remove.
6137 * tests/Makefile.am: Adjust.
6138
f693ad14
AD
61392001-12-10 Akim Demaille <akim@epita.fr>
6140
6141 One structure for states is enough, even though theoretically
6142 there are LR(0) states and LALR(1) states.
6143
6144 * src/lalr.h (state_t): Remove.
6145 (state_table): Be state_t **, not state_t *.
6146 * src/state.h (core, CORE_ALLOC): Rename as...
6147 (state_t, STATE_ALLOC): this.
6148 Add the LALR(1) members: shifts, reductions, errs.
6149 * src/LR0.c (state_table): Rename as...
6150 (state_hash): this, to avoid name clashes with the global
6151 `state_table'.
6152 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
6153 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
6154
74ffbcb6
AD
61552001-12-10 Akim Demaille <akim@epita.fr>
6156
6157 Bison dumps core on bash.y.
6158 Reported by Pascal Bart.
6159
6160 * src/warshall.c (bitmatrix_print): New.
6161 (TC): Use it.
6162 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
6163 j must be the outer loop.
6164 * tests/regression.at (Broken Closure): New.
6165
07708e19
AD
61662001-12-05 Akim Demaille <akim@epita.fr>
6167
6168 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
6169 its argument.
6170