]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
Regenerate.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-12-21 Paul Eggert <eggert@twinsun.com>
2
3 If the user does not define YYSTYPE as a macro, Bison now declares it
4 using typedef instead of defining it as a macro. POSIX requires this.
5 For consistency, YYLTYPE is also declared instead of defined.
6
7 %union directives can now have a tag before the `{', e.g., the
8 directive `%union foo {...}' now generates the C code
9 `typedef union foo { ... } YYSTYPE;'; this is for Yacc compatibility.
10 The default union tag is `YYSTYPE', for compatibility with Solaris 9
11 Yacc. For consistency, YYLTYPE's struct tag is now `YYLTYPE'
12 instead of `yyltype'.
13
14 `yystype' and `yyltype' are now obsolescent macros instead of being
15 typedefs or tags; they are no longer documented and will be
16 withdrawn in a future release.
17
18 * data/glr.c (b4_location_type): Remove.
19 (YYSTYPE): Renamed from yystype.
20 (YYSTYPE_IS_DECLARED): New macro, used to prevent double-typedef.
21 (struct YYLTYPE): Renamed from struct yyltype.
22 (YYLTYPE): Renamed from yyltype.
23 (yyltype, yystype): New (and obsolescent) macros,
24 for backward compatibility.
25 * data/yacc.c: Likewise.
26
27 * data/yacc.c (YYSTYPE): Declare as union YYSTYPE if the user
28 does not specify a union tag. This is for compatibility with
29 Solaris 9 yacc.
30
31 * src/parse-gram.y (add_param): 2nd arg is now char * not char
32 const *, since it is now modified by stripping surrounding { }.
33 (current_braced_code): Remove.
34 (PERCENT_DESTRUCTOR, PERCENT_PRINTER, PERCENT_UNION,
35 PERCENT_LEX_PARAM, PERCENT_PARSE_PARAM): Change names to include
36 trailing " {...}". Now of type <chars>.
37 (grammar_declaration): Adjust to bundled tokens.
38 (code_content): Remove; stripping is now done by add_param.
39 (print_token_value): Print contents of bundled tokens.
40 (token_name): New function.
41
42 * src/reader.h (braced_code, current_braced_code): Remove.
43 (token_name): New decl.
44
45 * src/scan-gram.l (handle_dollar, handle_at): Now takes int
46 token_type, not braced_code code_kind. All uses changed.
47 (SC_PRE_CODE): New state, for scanning after a keyword that
48 has (or usually has) an immediately-following braced code.
49 (token_type): New local var, to keep track of which token type
50 to return when scanning braced code.
51 (<INITIAL>"%destructor", <INITIAL>"%lex-param",
52 <INITIAL>"%parse-param", <INITIAL>"%printer,
53 <INITIAL>"%union"): Set token type and BEGIN SC_PRE_CODE
54 instead of returning a token type immediately.
55 (<INITIAL>"{"): Set token type.
56 (<SC_BRACED_CODE>"}"): Use it.
57 (handle_action_dollar, handle_action_at): Now returns bool
58 indicating success. Fail if ! current_rule; this prevents a core dump.
59 (handle_symbol_code_dollar, handle_symbol_code_at):
60 Remove; merge body into caller.
61 (handle_dollar, handle_at): Complain in invalid contexts.
62
63 * NEWS, doc/bison.texinfo: Document the above.
64 * NEWS: Fix years and program names in copyright notice.
65
662002-12-17 Paul Eggert <eggert@twinsun.com>
67
68 * NEWS, doc/bison.texinfo (Parser Function, Pure Calling, Error
69 Reporting, Table of Symbols): Omit mentions of %lex-param and
70 %parse-param from the documentation for now.
71
722002-12-15 Paul Eggert <eggert@twinsun.com>
73
74 Undo most of the 2002-11-12 yychar -> yytoken patch, as it broke
75 GCC 3.2.1 (which depends on yychar == YYEMPTY when there is no
76 lookahead symbol, and which sets yychar in parser actions) and it
77 disagreed with the Bison documentation. This should fix the bug
78 reported by Andrew Walrond in
79 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001949.html>.
80
81 * data/yacc.c (YYTRANSLATE): Don't check for negative argument,
82 as the caller now does that.
83 (yyclearin, YYBACKUP, yyparse): Use yychar, not yytoken.
84 (YYEMPTY): Parenthesize right hand side, since others use it.
85 (yyparse): Don't assume that our generated code is the only code
86 that sets yychar.
87
882002-12-13 Paul Eggert <eggert@twinsun.com>
89
90 Version 1.75d.
91
92 POSIX requires a "yacc" command.
93 * src/Makefile.am (bin_SCRIPTS): New macro, for yacc.
94 (MOSTLYCLEANFILES): Add yacc.
95 (yacc): New rule.
96 * doc/bison.texinfo (Invocation, Bison Options): Mention yacc
97 as an alias for bison y.
98
99 * po/LINGUAS: Add da.
100
101 * src/getargs.c (__GNU_LIBRARY__) [lint]: Define to work around
102 problem with latest <getopt.h>.
103 (HACK_FOR___GNU_LIBRARY___PROTOTYPE): New macro.
104
105 * doc/fdl.texi: Upgrade to 1.2.
106 * lib/alloca.c, lib/error.c, lib/getopt.c, lib/getopt.h
107 lib/getopt1.c, lib/gettext.h, lib/memrchr.c, lib/obstack.c,
108 lib/obstack.h, lib/strnlen.c, lib/unlocked-io.h: Sync with
109 gnulib.
110 * config/install-sh: Sync with autotools.
111
112 Fix a bad interaction with flex 2.5.23 reported by Bruce Lilly in
113 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
114 * data/yacc.c (YYLTYPE, struct yyltype): Do not define unless
115 locations are requested.
116 (union yyalloc): Do not depend on YYLTYPE_IS_TRIVIAL unless
117 locations are requested.
118
1192002-12-12 Paul Eggert <eggert@twinsun.com>
120
121 Remove unportable casts and storage allocation tricks.
122 While we're at it, remove almost all casts, since they
123 usually aren't needed and are a sign of trouble.
124
125 * configure.ac (AC_CHECK_TYPES): Check for uintptr_t.
126
127 * src/derives.c (derives_compute): Do not subtract NTOKENS from
128 the pointer DSET returned by malloc; this isn't portable.
129 Instead, always use DSET[i - NTOKENS] rather than DSET[i].
130 Similarly for DERIVES.
131 * src/lalr.c (set_goto_map): Likewise, for GOTO_MAP and TEMP_MAP.
132 * src/nullable.c (nullable_compute): Likewise, for RSETS and NULLABLE.
133 * src/reduce.c (reduce_grammar_tables): Likewise, for nontermmap
134
135 * src/derives.c (derives_compute): Do not bother invoking
136 int_of_rule_number, since rule numbers are integers.
137
138 * src/files.c (concat2, tr, compute_base_name): Use xmalloc (N)
139 rather than XMALLOC (char, N).
140
141 * src/files.c (filename_split): Rewrite to avoid cast.
142
143 * src/gram.h (symbol_number_as_item_number,
144 item_number_as_symbol_number, rule_number_as_item_number,
145 item_number_as_rule_number):
146 Now inline functions rather than macros, to avoid casts.
147 * src/state.h (state_number_as_int): Likewise.
148 * src/tables.c (state_number_to_vector_number,
149 symbol_number_to_vector_number): Likewise.
150
151 * src/gram.h (int_of_rule_number): Remove; no longer used.
152
153 * src/lalr.c (add_lookback_edge): Use malloc rather than calloc,
154 since the resulting storage is always stored into.
155
156 * src/main.c (alloca) [C_ALLOCA]: Add decl here, the only place
157 where it's needed.
158
159 * src/muscle_tab.c (muscle_m4_output):
160 Now inline. Return bool, not int.
161 * src/state.c (state_compare): Likewise.
162 * src/symtab.c (symbol_check_defined,
163 symbol_check_alias_consistency, symbol_pack, symbol_translation,
164 hash_compare_symbol, hash_symbol):
165 Likewise.
166 * src/uniqstr.c (uniqstr_print): Likewise.
167 * src/muscle_tab.c (muscle_m4_output_processor):
168 New function, to avoid casts.
169 * src/state.c (state_comparator, stage_hasher): Likewise.
170 * src/symtab.c (symbol_check_defined_processor,
171 symbol_check_alias_consistency_processor, symbol_pack_processor,
172 symbol_translation_processor, hash_symbol_comparator,
173 hash_symbol_hasher): Likewise.
174 * src/uniqstr.c (uniqstr_print_processor): Likewise.
175 * src/muscle_tab.c (muscles_m4_output):
176 Use new functions instead of casting old functions unportably.
177 * src/state.c (state_hash_new): Likewise.
178 * src/symtab.c (symbols_new, symbols_do, symbols_check_defined,
179 symbols_token_translations_init):
180 Likewise.
181 * src/uniqstr.c (uniqstrs_new, hash_initialize, uniqstrs_do): Likewise.
182
183 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): Use long local
184 var instead of casting to long, to avoid casts.
185 (prepare_states): Use MALLOC rather than alloca, so that we don't
186 have to worry about alloca.
187 * src/state.c (state_hash_lookup): Likewise.
188
189 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>"'"): Use unsigned char
190 local var instead of casting to unsigned char, to avoid casts.
191
192 * src/state.c (TRANSITIONS_ALLOC, ERRS_ALLOC, REDUCTIONS_ALLOC,
193 STATE_ALLOC): Remove.
194 (transitions_new, errs_new, reductions_new, state_new): Use malloc
195 rather than calloc, and use offsetof to avoid allocating slightly
196 too much storage.
197 (state_new): Initialize all members.
198
199 * src/state.c (state_hash): Use unsigned accumulator, not signed.
200
201 * src/symtab.c (symbol_free): Remove; unused.
202 (symbol_get): Remove cast in lhs of assignment.
203 (symbols_do): Now static. Accept generic arguments, not
204 hashing-related ones.
205
206 * src/symtab.h: (NUMBER_UNDEFINED): Remove unnecessary cast.
207 (symbol_processor): Remove.
208 (symbols_do): Remove decl; now static.
209
210 * src/system.h (alloca): Remove; decl no longer needed.
211 (<stddef.h>): Include, for offsetof.
212 (<inttypes.>, <stdint.h>): Include if available.
213 (uintptr_t): New type, if system lacks it.
214 (CALLOC, MALLOC, REALLOC): New macros.
215 All uses of XCALLOC, XMALLOC, and XREALLOC changed to use these
216 new macros.
217
218 * src/tables.c (table_size): Now int, to pacify GCC.
219 (table_grow, table_ninf_remap): Use signed table size.
220 (save_row): Don't bother initializing locals when not needed.
221 (default_goto, goto_actions, pack_vector): Remove unnecessary casts.
222 * src/uniqstr.c (hash_compare_uniqstr): Likewise.
223
224 * src/vcg.h: Correct misspellings.
225
226 * src/vcg_defaults.h (G_CMAX): Now INT_MAX.
227
228
229 * src/getargs.c (getargs): Don't assume EOF == -1.
230
2312002-12-09 Paul Eggert <eggert@twinsun.com>
232
233 Change identifier spellings to avoid collisions with names
234 that are reserved by POSIX.
235
236 Don't use names ending in _t, since POSIX reserves them.
237 For consistency, remove _e and _s endings -- they're weren't
238 needed to remove ambiguity. All uses changed.
239 * src/uniqstr.h (uniqstr): Renamed from uniqstr_t, which in
240 turn was just renamed from struniq_t.
241 * src/uniqstr.c (uniqstr_processor): Renamed from struniq_processor,
242 which in turn was just renamed from struniq_processor_t.
243 (hash_compare_uniqstr): Renamed from hash_compare_struniq, which
244 in turn was renamed from hash_compare_struniq_t.
245 * src/LR0.c (struct state_list): Renamed from struct state_list_s.
246 (state_list): Renamed from state_list_t.
247 * src/assoc.h (assoc): Renamed from assoc_t.
248 * src/conflicts.c (enum conflict_resolution): Renamed from
249 enum conflict_resolution_e.
250 * src/derives.c (struct rule_list): Renamed from struct rule_list_s.
251 (rule_list): Renamed from rule_list_t.
252 * src/getargs.h (enum trace): Renamed from enum trace_e.
253 (enum report): Renamed from enum report_e.
254 * src/gram.h (item_number): Renamed from item_number_t.
255 (rule_number): Renamed from rule_number_t.
256 (struct rule_s): Remove the "rule_s" part; not used.
257 (rule): Renamed from rule_t.
258 (rule_filter): Renamed from rule_filter_t.
259 * src/lalr.c (struct goto_list): Renamed from struct goto_list_s.
260 (goto_list): Renamed from goto_list_t.
261 * src/lalr.h (goto_number): Renamed from goto_number_t.
262 * src/location.h (location): Renamed from location_t.
263 * src/muscle_tab.c (muscle_entry): Renamed from muscle_entry_t,
264 and moved here from:
265 * src/muscle_tab.h (muscle_entry_t): here.
266 * src/nullable.c (struct rule_list): Renamed from struct rule_list_s.
267 (rule_list): Renamed from rule_list_t.
268 * src/print_graph.c (static_graph): Renamed from graph.
269 * src/reader.h (braced_code): Renamed from braced_code_t.
270 Remove brace_code_e tag.
271 * src/relation.h (relation_node): Renamed from relation_node_t.
272 (relation_nodes): Renamed from relation_nodes_t.
273 (relation): Renamed from relation_t.
274 * src/state.h (state_number): Renamed from state_number_t.
275 (struct state): Renamed from struct state_s.
276 (state): Renamed from state_t.
277 (transitions): Renamed from transitions_t. Unused (and
278 misspelled) transtion_s tag removed.
279 (errs): Renamed from errs_t. Unused errs_s tag removed.
280 (reductions): Renamed from reductions_t. Unused tag
281 reductions_s removed.
282 * src/symlist.h (symbol_list): Renamed from symbol_list_t.
283 (struct symbol_list): Renamed from struct symbol_list_s.
284 * src/symtab.h (symbol_number): Renamed from symbol_number_t.
285 (struct symbol): Renamed from struct symbol_s.
286 (symbol): Renamed from symbol_t.
287 * src/tables.c (vector_number): Renamed from vector_number_t.
288 (action_number): Renamed from action_t.
289 * src/tables.h (base_number): Renamed from base_t.
290 * src/vcg.h (enum color): Renamed from enum color_e.
291 (enum textmode): Renamed from enum textmode_e.
292 (enum shape): Renamed from enum shape_e.
293 (struct colorentry): Renamed from struct colorentry_s.
294 (struct classname): Renamed from struct classname_s.
295 (struct infoname): Renamed from struct infoname_s.
296 (enum layoutalgorithm): Renamed from enum layoutalgorithm_e.
297 (enum decision): Renamed from enum decision_e.
298 (enum orientation): Renamed from enum orientation_e.
299 (enum alignment): Renamed from enum alignment_e.
300 (enum arrow_mode): Renamed from enum arrow_mode_e.
301 (enum crossing_type): Renamed from enum crossing_type_e.
302 (enum view): Renamed from enum view_e.
303 (struct node): Renamed from struct node_s.
304 (node): Renamed from node_t.
305 (enum linestyle): Renamed from enum linestyle_e.
306 (enum arrowstyle): Renamed from enum arrowstyle_e.
307 (struct edge): Renamed from struct edge.
308 (edge): Renamed from edge_t.
309 (struct graph): Renamed from struct graph_s.
310 (graph): Renamed from graph_t.
311 * tests/calc.at (_AT_DATA_CALC_Y, Simple LALR Calculator):
312 Rename value_t -> value.
313 * tests/input.at (Torturing the Scanner): Rename value_t -> value,
314 value_t_as_yystype -> value_as_yystype.
315
316 Don't include <errno.h> in the mainstream code, since it
317 reserves E[A-Z0-9]* and we want to use symbols like 'EQUALS'.
318 * lib/get-errno.c, lib/get-errno.h: New files.
319 * lib/Makefile.am (libbison_a_SOURCES): Add get-errno.h,
320 get-errno.c.
321 * src/files.c (xfopen, xfclose): Use get_errno instead of errno.
322 * src/output.c (output_skeleton): Likewise.
323 * src/scan-gram.l (<INITIAL>{int}): Use set_errno and get_errno
324 instead of errno.
325 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>\\x[0-9abcdefABCDEF]+):
326 Likewise.
327 (handle_action_dollar, handle_action_at): Likewise.
328 * src/system.h: Do not include <errno.h>.
329 (TAB_EXT): Renamed from EXT_TAB.
330 (OUTPUT_EXT): Renamed from EXT_OUTPUT.
331
332 Avoid str[a-z]*, since <string.h> reserves that name space.
333 Change all instances of "struniq" in names to "uniqstr", and
334 likewise for "STRUNIQ" and "UNIQSTR".
335 * src/uniqstr.c: Renamed from src/struniq.c.
336 * src/uniqstr.h: Renamed from src/struniq.h.
337 * src/Makefile.am (bison_SOURCES): Adjust to these renamings.
338 * src/files.c (strsuffix): Remove; unused.
339 (concat2): Renamed from stringappend. Now static.
340 * src/files.h (strsuffix, stringappend): Remove; unused.
341 * src/parse-gram.y (<chars>): Renamed from <string>.
342 (<uniqstr>): Renamed from <struniq>.
343 * src/scan-gram.l (obstack_for_string): Renamed from string_obstack.
344 * src/vcg.h (struct node_s.expand): Renamed from struct node_s.stretch.
345 (struct graph_s.expand): Renamed from struct graph_s.stretch.
346 * src/vcg_defaults.h (G_EXPAND): Renamed from G_STRETCH.
347 (G_LONG_STRAIGHT_PHASE): Renamed from G_STRAIGHT_PHASE.
348 (N_EXPAND): Renamed from N_STRETCH.
349
350 Avoid *_MAX and *_MIN, since <limits.h> reserves that name space.
351 * data/yacc.c (YYSTACK_GAP_MAXIMUM): Renamed from YYSTACK_GAP_MAX.
352 * src/gram.h (ITEM_NUMBER_MAX, ITEM_NUMBER_MIN, RULE_NUMBER_MAX):
353 Remove; unused.
354 * src/lalr.h (GOTO_NUMBER_MAXIMUM): Renamed from GOTO_NUMBER_MAX.
355 * src/state.h (STATE_NUMBER_MAXIMUM): Renamed from STATE_NUMBER_MAX.
356 * src/symtab.h (SYMBOL_NUMBER_MAXIMUM): Renamed from SYMBOL_NUMBER_MAX.
357 * src/tables.c (VECTOR_NUMBER_MAX, VECTOR_NUMBER_MIN): Remove; unused.
358 (BASE_MAXIMUM): Renamed from BASE_MAX.
359 (BASE_MINIMUM): Renamed from BASE_MIN.
360 (ACTION_MAX): Remove; unused.
361 (ACTION_NUMBER_MINIMUM): Renamed from ACTION_MIN.
362 Unnecessary casts removed from above defines.
363
364
365 Fix misspelling in names.
366 * src/vcg.h (enum_alignment_e): Renamed from enum_alignement_e.
367 * src/vcg_defaults.h (G_NODE_ALIGNMENT): Renamed from
368 G_NODE_ALIGNEMENT.
369
370
371 * lib/timevar.c (timevar_report): Renamed from time_report,
372 for consistency with other names.
373 * lib/timevar.h (timevar_report): New decl.
374 * src/system.h (time_report): Remove; decl is now in lib/timevar.h.
375
376
377 Sort include-file uses.
378
379 Reorder all include files under src to be in the order "system.h".
380 then the ../lib include files in angle brackets (alphabetized),
381 then the . include files in double-quotes (alphabetized). Fix
382 dependency breakages encountered in this process, as follows:
383 * src/closure.h, src/derives.h, src/state.h: Include "gram.h".
384 * src/complain.c: Don't include stdlib.h, string.h _LIBC stuff.
385 * src/state.h: Include "symtab.h".
386
3872002-12-08 Paul Eggert <eggert@twinsun.com>
388
389 * data/glr.c, data/lalr1.cc, data/yacc.c: Do not use __file__,
390 since this causes problems when __file__ contains character
391 sequences like "@" that are treated specially by src/scan-skel.l.
392 Instead, just use the file's basename. This fixes the bug
393 reported by Martin Mokrejs in
394 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001945.html>.
395
3962002-12-06 Paul Eggert <eggert@twinsun.com>
397
398 Add support for rules that do not have trailing semicolons, as
399 POSIX requires. Improve the quality of locations in Bison
400 diagnostics.
401
402 * src/location.c: Include <quotearg.h>.
403 (empty_location): Now const.
404 (location_print): New function. Follow the recommendation of the
405 GNU Coding Standards for locations that span file boundaries.
406 * src/location.h: Do not include <quotearg.h>; no longer needed.
407 (boundary): New type.
408 (location_t): Use it. This allows locations to span file boundaries.
409 All member uses changed: file -> start.file or end.file (as needed),
410 first_line -> start.line, first_column -> start.column,
411 last_line -> end.line, last_column -> end.column.
412 (equal_boundaries): New function.
413 (LOCATION_RESET, LOCATION_STEP): Remove.
414 (LOCATION_PRINT): Remove. All callers changed to use location_print.
415 (empty_location): Now const.
416 (location_print): New decl.
417 * src/parse-gram.y (lloc_default): New function, which handles
418 empty locations more accurately.
419 (YYLLOC_DEFAULT): Use it.
420 (%token COLON): Remove.
421 (%token ID_COLON): New token.
422 (rules): Use it.
423 (declarations, rules): Remove trailing semicolon.
424 (declaration, rules_or_grammar_declaration):
425 Allow empty (";") declaration.
426 (symbol_def): Remove empty actions; no longer needed.
427 (rules_or_grammar_declaration): Remove trailing semicolon.
428 (semi_colon.opt): Remove.
429 * src/reader.h: Include location.h.
430 (scanner_cursor): New decl.
431 * src/reduce.c (nonterminals_reduce): Use warn_at rather than
432 rolling our own.
433 * src/scan-gram.l (YY_USER_INIT): Initialize scanner_cursor instead
434 of *loc.
435 (STEP): Remove. No longer needed, now that adjust_location does
436 the work. All uses removed.
437 (scanner_cursor): New var.
438 (adjust_location): Renamed from extend_location. It now sets
439 *loc and adjusts the scanner cursor. All uses changed.
440 Don't bother testing for CR.
441 (handle_syncline): Remove location arg; now updates scanner cursor.
442 All callers changed.
443 (unexpected_end_of_file): Now accepts start boundary of token or
444 comment, not location. All callers changed. Update scanner cursor,
445 not the location.
446 (SC_AFTER_IDENTIFIER): New state.
447 (context_state): Renamed from c_context. All uses changed.
448 (id_loc, code_start, token_start): New local vars.
449 (<INITIAL,SC_AFTER_IDENTIFIER>): New initial context. Move all
450 processing of Yacc white space and equivalents here.
451 (<INITIAL>{id}): Save id_loc. Begin state SC_AFTER_IDENTIFIER
452 instead of returning ID immediately, since we need to search for
453 a subsequent colon.
454 (<INITIAL>"'", "\""): Save token_start.
455 (<INITIAL>"%{", "{", "%%"): Save code_start.
456 (<SC_AFTER_IDENTIFIER>): New state, looking for a colon.
457 (<SC_YACC_COMMENT>, <SC_COMMENT>, <SC_LINE_COMMENT>):
458 BEGIN context_state at end, not INITIAL.
459 (<SC_ESCAPED_STRING>"\"", <SC_ESCAPED_CHARACTER>"'",
460 <SC_BRACED_CODE>"}", <SC_PROLOGUE>"%}", <SC_EPILOGUE><<EOF>>):
461 Return correct token start.
462 (<SC_BRACED_CODE,SC_PROLOGUE,SC_EPILOGUE>): Save start boundary when
463 the start of a character, string or multiline comment is found.
464 * tests/conflicts.at (S/R in initial, Defaulted Conflicted
465 Reduction): Adjust reported locations to match the more-precise
466 results now expected.
467 * tests/input.at (Invalid $n, Invalid @n, Type Clashes): Likewise.
468 * tests/reduce.at (Useless Rules, Reduced Automaton,
469 Underivable Rules): Likewise.
470 * tests/regression.at (Invalid inputs): No longer `expecting ";"
471 or "|"' now that so many other tokens are allowed by the new grammar.
472
473 * src/complain.h (current_file): Remove duplicate decl;
474 current_file is now owned by files.h.
475 * src/complain.c, src/scan-gram.l: Include files.h.
476
4772002-12-06 Paul Eggert <eggert@twinsun.com>
478
479 * data/glr.c (yy_reduce_print): Don't assume that yyrline[yyrule]
480 promotes to int; it might be unsigned int.
481 * data/yacc.c (yy_reduce_print): Likewise.
482
483 * doc/bison.texinfo (Table of Symbols): YYERROR_VERBOSE should
484 be #defined in the prologue, not in the Bison declarations.
485 This fixes Debian Bug 102878, reported by Shaul Karl.
486
4872002-12-02 Paul Eggert <eggert@twinsun.com>
488
489 * configure.ac (AC_REPLACE_FUNCS): Add strtoul.
490 * lib/strtoul.c: New file, from gnulib.
491 This fixes a porting bug reported by Peter Klein in
492 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001944.html>.
493
4942002-11-30 Paul Eggert <eggert@twinsun.com>
495
496 * src/scan-gram.l (no_cr_read, extend_location): Move to epilogue,
497 and put only a forward declaration in the prologue. This is for
498 consistency with the other scanner helper functions.
499
500 Type clashes now generate warnings, not errors, since it
501 appears that POSIX may allow some grammars with type clashes.
502 * src/reader.c (grammar_current_rule_check): Warn about
503 type clashes instead of complaining.
504 * tests/input.at (Type Clashes): Expect warnings, not complaints.
505
506 Add Yacc library, since POSIX requires it.
507 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
508 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
509 * lib/main.c, lib/yyerror.c: New files.
510
511 gram_error can be static; it need not be extern.
512 * src/reader.h (gram_error): Remove decl.
513 * src/parse-gram.y (gram_error): Now static. Add static decl.
514 (print_token_value): Omit parameter names from forward decl,
515 for consistency.
516
5172002-11-29 Paul Eggert <eggert@twinsun.com>
518
519 * doc/bison.texinfo: Emphasize that yylex and yyerror must
520 be declared before being used. E.g., one should typically
521 declare them in the prologue. Use GNU coding style in examples.
522 Put "const" consistently after the type it modifies. Mention
523 that C99 supports "inline". Mention that yyerror traditionally
524 returns "int".
525
526 %parse-param and %lex-param now take just one argument, the
527 declaration; the argument name is deduced from the declaration.
528
529 * doc/bison.texinfo (Parser Function, Pure Calling, Error
530 Reporting, Table of Symbols): Document this.
531 * src/parse-gram.y (add_param): New function.
532 (COMMA): Remove.
533 (declaration): Implement new rule for %parse-param and %lex-param.
534 * src/scan-gram.l: "," now elicits a warning, rather than being
535 a token; this is more compatible with byacc.
536 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
537
5382002-11-27 Paul Eggert <eggert@twinsun.com>
539
540 Rename identifiers to avoid real and potential collisions.
541
542 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
543 to avoid collision with lex macro described by Bruce Lilly in
544 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
545 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
546 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
547 * src/parse-gram.y (print_token_value): Renamed from yyprint.
548 All uses changed.
549 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
550 The name "yycontrol" violates the name space rules, and this stuff
551 wasn't being used anyway.
552 (input): Remove action; this stuff wasn't being used.
553 (gram_error): Rename local variable yylloc -> loc.
554 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
555 (YY_DECL): Don't use "yy" at start of local variables.
556 All uses changed, e.g., yylloc -> loc.
557 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
558 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
559 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
560 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
561
562 * src/parse-gram.y (gram_error): loc is now const *.
563 * src/reader.h (gram_error): Likewise.
564
5652002-11-24 Paul Eggert <eggert@twinsun.com>
566
567 Version 1.75c.
568
569 * tests/actions.at (Actions after errors): Use an output format
570 more similar to that of the Printers and Destructors test.
571 Test the position of the ';' token too.
572 (Printers and Destructors): Likewise.
573 (Printers and Destructors: %glr-parser): Remove for now, to avoid
574 unnecessarily alarming people when the test fails.
575
576 * data/yacc.c (yyerrlab1): Move this label down, so that the
577 parser does not discard the lookahead token if the user code
578 invokes YYERROR. This change is required for POSIX conformance.
579
580 * lib/error.c: Sync with gnulib.
581
5822002-11-22 Paul Eggert <eggert@twinsun.com>
583
584 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
585 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
586 * lib/xmalloc.c: Likewise.
587
5882002-11-20 Paul Eggert <eggert@twinsun.com>
589
590 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
591
5922002-11-20 Paul Eggert <eggert@twinsun.com>
593
594 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
595 should use `if (! x) abort ();' rather than `assert (x);', and
596 anyway it's one less thing to worry about configuring.
597
598 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
599 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
600 and replace all instances of assert with abort.
601 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
602 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
603
604 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
605 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
606 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
607 hash_find_entry, hash_rehash, hash_insert): Likewise.
608 * src/conflicts.c (resolve_sr_conflict): Likewise.
609 * src/lalr.c (set_goto_map, map_goto): Likewise.
610 * src/nullable.c (nullable_compute): Likewise.
611 * src/output.c (prepare_rules, token_definitions_output): Likewise.
612 * src/reader.c (packgram, reader): Likewise.
613 * src/state.c (state_new, state_free, state_transitions_set,
614 state_reduction_find): Likewise.
615 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
616 symbol_pack): Likewise.
617 * src/tables.c (conflict_row, pack_vector): Likewise.
618 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
619 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
620 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
621 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
622
623 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
624 (ARGMATCH_CONSTRAINT): New macro.
625 (ARGMATCH_ASSERT): Use it.
626
627 * src/system.h (verify): New macro.
628 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
629 rather than assert.
630 * src/tables.c (tables_generate): Likewise.
631
632 * src/struniq.c (struniq_assert): Now returns void, and aborts
633 if the assertion is false.
634 (struniq_assert_p): Remove.
635 * src/struniq.h: Likewise.
636
6372002-11-18 Paul Eggert <eggert@twinsun.com>
638
639 * data/glr.c (yygetLRActions): Replace `yyindex' with
640 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
641 This fixes the regression with Sun ONE Studio 7 cc that I reported in
642 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001892.html>.
643
6442002-11-18 Akim Demaille <akim@epita.fr>
645
646 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
647 space.
648 From Tim Van Holder.
649
6502002-11-17 Paul Eggert <eggert@twinsun.com>
651
652 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
653 to "SyntaxError" for consistency with my 2002-11-15 change.
654
655 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
656 not define to {}, since this breaks the common use of `YYDPRINTF
657 ((...));' if a single statement is desired (e.g. before `else').
658 Work around GCC warnings by surrounding corresponding calls with
659 {} if needed.
660 (yyhasResolvedValue): Remove unused function.
661 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
662 loop body.
663 (yyreportSyntaxError): Renamed from yyreportParseError.
664 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
665 All uses changed.
666 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
667 extern when possible. Remove unused initializations.
668
6692002-11-16 Akim Demaille <akim@epita.fr>
670
671 Augment the similarity between GLR and LALR traces.
672
673 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
674 (YY_REDUCE_PRINT): New.
675 (yyparse): Use them.
676 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
677 YYDPRINT here.
678 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
679 state reached after the reduction/recovery, since...
680 (yyparse, yyprocessOneStack): Report the state we are entering in.
681
6822002-11-16 Akim Demaille <akim@epita.fr>
683
684 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
685 Add support for --trace=skeleton.
686 * src/scan-skel.l: %option debug.
687 Scan strings of non-@ or \n instead of character by character.
688 (scan_skel): Handle trace_skeleton.
689 (QPUTS): New.
690 (@output_parser_name@, @output_header_name@): ``Restore'' their
691 support (used to be M4 macros).
692 * data/yacc.c: Quote larger chunks, a la glr.c.
693 * data/lalr1.cc: Likewise.
694 The header guards are no longer available, so use some other
695 string than `YYLSP_NEEDED'.
696
6972002-11-16 Akim Demaille <akim@epita.fr>
698
699 Make the ``Printers and Destructors'' test more verbose, taking
700 `yacc.c''s behavior as (possibly wrong) reference.
701
702 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
703 instead of fprint on stdout.
704 Set and report the last_line of the symbols.
705 Consistently display values and locations.
706
7072002-11-16 Paul Eggert <eggert@twinsun.com>
708
709 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
710
7112002-11-15 Paul Eggert <eggert@twinsun.com>
712
713 * tests/actions.at (Actions after errors): New test case.
714
715 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
716 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
717 tests/action.at, tests/calc.at, tests/conflicts.at,
718 tests/cxx-type.at, tests/regression.at:
719 "parse error" -> "syntax error" for POSIX compatibility.
720 "parsing stack overflow..." -> "parser stack overflow" so
721 that code matches Bison documentation.
722
7232002-11-15 Akim Demaille <akim@epita.fr>
724
725 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
726 take two BRACED_CODE, not two string_content.
727 Free the scanner's obstack when we are done.
728 (code_content): New.
729 * tests/calc.at: Adjust.
730 * doc/bison.texinfo: Adjust.
731 Also, make sure to include the `,' for these declarations.
732
7332002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
734
735 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
736 definition; avoids potential autoreconf problems.
737
7382002-11-15 Akim Demaille <akim@epita.fr>
739
740 Always check the value returned by yyparse.
741
742 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
743 returned by yyparse.
744 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
745 Adjust calls.
746 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
747 returned by yyparse.
748
7492002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
750
751 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
752 on input.at test.
753
7542002-11-14 Paul Eggert <eggert@twinsun.com>
755
756 * src/output.c (output_skeleton): Call xfopen instead of
757 duplicating xfopen's body.
758
759 Fix bugs reported by Nelson H. F. Beebe in
760 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
761
762 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
763 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
764 Group compiler. Instead, use "$CC -E bar.c". Include the .h
765 file twice in the grammar, as an extra check.
766
767 * tests/input.at (Torturing the Scanner): Surround the
768 backslash-newline tests with "#if 0", to make it less likely that
769 we'll run into compiler bugs. Bring back solitary \ inside
770 comment, but add a closing comment to work around HP C bug. Don't
771 test backslash-newline in C character constant. This should fix
772 the input.at bug reported by Nelson H. F. Beebe in
773 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
774
7752002-11-14 Akim Demaille <akim@epita.fr>
776
777 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
778 status of the compiler.
779 Calling `exit 1' is no longer needed.
780 Reported by Nelson H. F. Beebe.
781
7822002-11-14 Akim Demaille <akim@epita.fr>
783
784 * tests/atlocal.in (CPPFLAGS): We have config.h.
785 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
786 New.
787 * tests/actions.at, tests/calc.at, tests/conflicts.at,
788 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
789 * tests/regression.at, tests/torture.at: Use them for all the
790 grammars that are to be compiled.
791 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
792 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
793 * doc/bison.texinfo (GLR Parsers): Document `inline'.
794
7952002-11-14 Akim Demaille <akim@epita.fr>
796
797 * doc/bison.texinfo: Various formatting changes (alignments in
798 samples, additional @group/@end group, GCS in samples.
799 Use @deffn instead of simple @table to define the directives,
800 macros, variables etc.
801
8022002-11-13 Paul Eggert <eggert@twinsun.com>
803
804 Fix some bugs reported by Albert Chin-A-Young in
805 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
806
807 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
808 -o c"; the HP C compiler chatters during compilation.
809 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
810 * tests/headers.at (export YYLTYPE): Likewise.
811
812 * tests/input.at (Torturing the Scanner): Remove lines containing
813 solitary backslashes, as they tickle a bug in the HP C compiler.
814
815 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
816 comments, since they're not portable. Use GNU coding style.
817
8182002-11-13 Akim Demaille <akim@epita.fr>
819
820 * data/yacc.c: Leave bigger chunks of quoted text.
821 (YYDSYMPRINTF): New.
822 Use it to report symbol activities.
823 * data/glr.c (YYDSYMPRINTF): New.
824 Use it.
825
8262002-11-12 Paul Eggert <eggert@twinsun.com>
827
828 Version 1.75b.
829
830 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
831 (yyglrReduce): Return yyok, not 0.
832 This should avoid the enumerated-type warnings reported
833 by Nelson H.F. Beebe in
834 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
835
836 * lib/bbitset.h (BITSET_INLINE): Remove.
837 * lib/bitset.h [! BITSET_INLINE]: Remove.
838 (bitset_set, bitset_reset, bitset_test): Rename local vars
839 to avoid shadowing warnings by GCC.
840
841 * data/glr.c (inline): Remove #define. It's the user's
842 responsibility to #define it away, just like 'const'.
843 This fixes one of the bugs reported by Nelson H.F. Beebe in
844 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
845
846 * Makefile.maint (po-check): Scan .l and .y files instead of the
847 .c and the .h files that they generate. This fixes the bug
848 reported by Tim Van Holder in:
849 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
850 Look for N_ as well as for _. Try to avoid matching #define for
851 N_ and _.
852 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
853 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
854 * src/scan-gram.l: Revamp regular expressions so that " and '
855 do not confuse xgettext.
856
857 * src/struniq.h (struniq_new): Do not declare the return type
858 to be 'const'; this violates the C standard.
859 * src/struniq.c (struniq_new): Likewise.
860
8612002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
862
863 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
864 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
865 linker.
866
8672002-11-12 Akim Demaille <akim@epita.fr>
868
869 * Makefile.maint: Sync with Autoconf:
870 (local_updates): New.
871
8722002-11-12 Akim Demaille <akim@epita.fr>
873
874 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
875
8762002-11-12 Akim Demaille <akim@epita.fr>
877
878 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
879 locations.
880
8812002-11-12 Akim Demaille <akim@epita.fr>
882
883 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
884 not yyvalue.
885
8862002-11-12 Akim Demaille <akim@epita.fr>
887
888 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
889 Use it to test the GLR parser.
890
8912002-11-12 Akim Demaille <akim@epita.fr>
892
893 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
894 defines it.
895 * data/glr.c (yystos): New.
896 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
897 (YYDSYMPRINT): New.
898 (yyval): Don't define it, it is handled via M4.
899 (yyrecoverParseError): Free verbosely the discarded symbols.
900 * data/yacc.c (yysymprint): Remove, rather...
901 (b4_yysymprint_generate): invoke.
902 * data/c.m4 (b4_yysymprint_generate): New.
903 Accept pointers as arguments, as opposed to the version from
904 yacc.c.
905 (b4_yydestruct_generate): Likewise.
906 * tests/cations.at (Printers and Destructors): Use Bison directives
907 instead of CPP macros.
908 Don't rely on internal details.
909
9102002-11-12 Akim Demaille <akim@epita.fr>
911
912 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
913 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
914 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
915 it against YYEMPTY and so forth), work on yytoken (i.e., set
916 it to YYEMPTY etc.).
917 (yydestruct): Replace with a b4_yydestruct_generate invocation.
918 (b4_symbol_actions): Remove.
919 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
920 for 0, end-of-input.
921
9222002-11-12 Akim Demaille <akim@epita.fr>
923
924 * doc/bison.texinfo (Destructor Decl): New.
925
9262002-11-12 Akim Demaille <akim@epita.fr>
927
928 * src/tables.c (tables_generate): Use free for pointers that
929 cannot be NULL, not XFREE.
930 (pack_vector): Use assert, not fatal, for bound violations.
931 * src/state.c (state_new): Likewise.
932 * src/reader.c (reader): Likewise.
933 * src/lalr.c (set_goto_map): Likewise.
934 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
935 the file name.
936
9372002-11-12 Akim Demaille <akim@epita.fr>
938
939 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
940 Restore.
941 * src/scan-gram.l (last_string): Is global to the file, not to
942 yylex.
943 * src/parse-gram.y (input): Don't append the epilogue here,
944 (epilogue.opt): do it here, and free the scanner's obstack.
945 * src/reader.c (epilogue_set): Rename as...
946 (epilogue_augment): this.
947 * data/c.m4 (b4_epilogue): Defaults to empty.
948
9492002-11-12 Akim Demaille <akim@epita.fr>
950
951 * src/getargs.c (long_options): Remove duplicates.
952 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
953 Remove.
954 * doc/bison.rnh: Remove.
955 * doc/bison.texinfo (VMS Invocation): Remove.
956
9572002-11-12 Akim Demaille <akim@epita.fr>
958
959 * src/struniq.h, src/struniq.c (struniq_t): Is const.
960 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
961
962 Use struniq for symbols.
963
964 * src/symtab.h (symbol_t): The tag member is a struniq.
965 (symbol_type_set): Adjust.
966 * src/symtab.c (symbol_new): Takes a struniq.
967 (symbol_free): Don't free the tag member.
968 (hash_compare_symbol_t, hash_symbol_t): Rename as...
969 (hash_compare_symbol, hash_symbol): these.
970 Use the fact that tags as struniqs.
971 (symbol_get): Use struniq_new.
972 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
973 Returns a strniq.
974 * src/reader.h (merger_list, grammar_currentmerge_set): The name
975 and type members are struniqs.
976 * src/reader.c (get_merge_function)
977 (grammar_current_rule_merge_set): Adjust.
978 (TYPE, current_type): Are struniq.
979
980 Use struniq for file names.
981
982 * src/files.h, src/files.c (infile): Split into...
983 (grammar_file, current_file): these.
984 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
985 * src/reduce.c (reduce_print): Likewise.
986 * src/getargs.c (getargs): Likewise.
987 * src/complain.h, src/complain.c: Likewise.
988 * src/main.c (main): Call struniqs_new early enough to use it for
989 file names.
990 Don't free the input file name.
991
9922002-11-12 Akim Demaille <akim@epita.fr>
993
994 * src/symtab.c (symbol_free): Remove dead deactivated code:
995 type_name are properly removed.
996 Don't use XFREE to free items that cannot be NULL.
997 * src/struniq.h, src/struniq.c: New.
998 * src/main.c (main): Initialize/free struniqs.
999 * src/parse-gram.y (%union): Add astruniq member.
1000 (yyprint): Adjust.
1001 * src/scan-gram.l (<{tag}>): Return a struniq.
1002 Free the obstack bit that used to store it.
1003 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
1004
10052002-11-11 Paul Eggert <eggert@twinsun.com>
1006
1007 Revamp to fix many (but not all) of the C- and M4-related quoting
1008 problems. Among other things, this fixes the Bison bug reported
1009 by Jan Hubicka when processing the Bash grammar; see:
1010 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
1011
1012 Use new @ escapes consistently. Represent brackets with @{ and @}
1013 rather than @<:@ and @:>@, since this works a bit better with dumb
1014 editors like vi. Represent @ with @@, since @ is now consistently
1015 an escape. Use @oline@ and @ofile@ rather than __oline__ and
1016 __ofile__, to avoid unexpected expansions. Similarly, use @output
1017 rather than #output.
1018
1019 * data/c.m4 (b4_copyright): Omit file name from comment, since
1020 the file name could contain "*/".
1021 (b4_synclines_flag): Don't quote the 2nd argument; it should already
1022 be quoted. All uses changed.
1023
1024 * data/glr.c: Use new @ escapes consistently.
1025 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
1026 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
1027 Remove, since they couldn't handle arbitrary characters in file
1028 names.
1029 * data/lalr1.cc: Likewise.
1030 * data/yacc.c: Likewise.
1031
1032 * src/files.c (output_infix): Remove; all uses removed.
1033 * src/files.h: Likewise.
1034
1035 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
1036 mishandled funny characters in file names, and anyway it isn't
1037 needed any more.
1038 * data/yacc.c: Likewise.
1039 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
1040
1041 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
1042 * data/yacc.c: Likewise.
1043
1044 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
1045 strings now.
1046 (muscle_init): Quote filename as a C string.
1047 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
1048 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
1049 * src/output.c (escaped_file_name_output): New function.
1050 (prepare_symbols): Quote tokens for M4.
1051 (prepare): Don't insert output_infix, output_prefix,
1052 output_parser_name, output_header_name; this is now down by scan-skel.
1053 Insert skeleton as a C string.
1054
1055 * src/output.c (user_actions_output, symbol_destructors_output,
1056 symbol_printers_output): Quote filenames for C and M4.
1057 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1058
1059 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
1060 escapes other than \\ and \'; this simplifies the code.
1061 (<SC_STRING>): Likewise, for \\ and \".
1062 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
1063 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
1064 Use new escapes @{ and @} for [ and ].
1065
1066 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
1067 them with auto vars.
1068 Switch to new escape scheme, where @ is the escape character uniformly.
1069 Abort if a stray escape character is found. Avoid unbounded input
1070 buffer when parsing non-escaped text.
1071
1072 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
1073 __oline__, #output, $@, and @{ do not have unintended meanings.
1074
10752002-11-09 Paul Eggert <eggert@twinsun.com>
1076
1077 Fix the test failure due to GCC warnings described in
1078 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
1079 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
1080 evaluate to 0 if it's impossible for NINF to be in the respective
1081 table.
1082 (yygetLRActions, yyrecoverParseError): Use them.
1083
1084 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
1085 counted in the token inserted at end of file. Now takes
1086 location_t *, not location_t, so that the location can be
1087 adjusted. All uses changed.
1088
1089 * tests/regression.at (Invalid inputs): Adjust wording in
1090 diagnostic to match the new behavior.
1091
1092 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
1093 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
1094 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
1095 abort ();'. This reduces the runtime of the "Many lookaheads"
1096 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
1097 GCC 3.2.
1098
10992002-11-07 Paul Eggert <eggert@twinsun.com>
1100
1101 * src/parse-gram.y (CHARACTER): Remove unused token.
1102 All uses removed.
1103
1104 * src/scan-gram.l: Remove stack option. We no longer use the
1105 stack, since the stack was never deeper than 1; instead, use the
1106 new auto var c_context to record the stacked value.
1107
1108 Remove nounput option. At an unexpected end of file, we now unput
1109 the minimal input necessary to end cleanly; this simplifies the
1110 code.
1111
1112 Avoid unbounded token sizes where this is easy.
1113
1114 (unexpected_end_of_file): New function.
1115 Use it to systematize the error message on unexpected EOF.
1116 (last-string): Now auto, not static.
1117 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
1118 (scanner_last_string_free): Remove; not used.
1119 (percent_percent_count): Move decl to just before use.
1120 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
1121 not the (never otherwised-used) CHARACTER.
1122
11232002-11-07 Akim Demaille <akim@epita.fr>
1124
1125 Let yyerror always receive the msg as last argument, so that
1126 yyerror can be variadic.
1127
1128 * data/yacc.c (b4_yyerror_args): New.
1129 Use it when calling yyerror.
1130 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
1131 Use it when calling yyerror.
1132 * doc/bison.texinfo (Error Reporting): Adjust.
1133 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
1134 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
1135
11362002-11-06 Akim Demaille <akim@epita.fr>
1137
1138 #line should have quoted strings.
1139 Ideally, this should be done by m4_quotearg.
1140
1141 * src/scan-skel.l: Include quotearg.h.
1142 Quote __ofile__.
1143 * src/output.c (symbol_printers_output)
1144 (symbol_destructors_output): Quote the file name.
1145
11462002-11-06 Akim Demaille <akim@epita.fr>
1147
1148 * tests/regression.at (Invalid inputs): Adjust to the recent
1149 messages.
1150
11512002-11-06 Akim Demaille <akim@epita.fr>
1152
1153 Restore --no-lines.
1154 Reported by Jim Kent.
1155
1156 * data/c.m4 (b4_syncline): New.
1157 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
1158 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
1159 * src/output.c (user_actions_output): Likewise.
1160 (prepare): Define 'b4_synclines_flag'.
1161 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
1162
11632002-11-06 Akim Demaille <akim@epita.fr>
1164
1165 * src/main.c (main): Free `infile'.
1166 * src/scan-gram.l (handle_syncline): New.
1167 Recognize `#line'.
1168 * src/output.c (user_actions_output, symbol_destructors_output)
1169 (symbol_printers_output): Use the location's file name, not
1170 infile.
1171 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1172
11732002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1174
1175 * src/tables.c (matching_state): Don't allow states to match if
1176 either has GLR conflict entries.
1177
11782002-11-05 Paul Eggert <eggert@twinsun.com>
1179
1180 * src/scan-gram.l: Use more accurate diagnostics, e.g.
1181 "integer out of range" rather than "invalid value".
1182 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
1183 accordingly.
1184
1185 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
1186 Also, remove one static variable in the scanner.
1187
1188 * src/scan-gram.l (braces_level): Now auto, not static.
1189 Initialize to zero if the compiler is being picky.
1190 (INITIAL): Clear braces_level instead of incrementing it.
1191 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
1192 as POSIX 1003.1-2001 requires.
1193 * src/system.h (IF_LINT): New macro, taken from coreutils.
1194 * configure.ac: Define "lint" if --enable-gcc-warnings.
1195
11962002-11-05 Akim Demaille <akim@epita.fr>
1197
1198 * src/scan-gram.l: When it starts with `%', complain about the
1199 whole directive, not just that `invalid character: %'.
1200
12012002-11-04 Akim Demaille <akim@epita.fr>
1202
1203 * Makefile.maint: Update from Autoconf.
1204 (update, cvs-update, po-update, do-po-update): New.
1205
12062002-11-04 Akim Demaille <akim@epita.fr>
1207
1208 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
1209 and yyerror.
1210 Have yyerror `use' its arguments.
1211 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
1212 returns true when location & yacc & pure & parse-param.
1213 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
1214
12152002-11-04 Akim Demaille <akim@epita.fr>
1216
1217 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
1218 clashes.
1219 * src/scan-gram.l: Use [\'] instead of ['] to pacify
1220 font-lock-mode.
1221 Use complain_at.
1222 Use quote, not quote_n since LOCATION_PRINT no longer uses the
1223 slot 0.
1224
12252002-11-03 Paul Eggert <eggert@twinsun.com>
1226
1227 * src/reader.c (get_merge_function, grammar_current_rule_check):
1228 Use consistent diagnostics for reporting type name clashes.
1229 Quote the types with <>, for consistency with Yacc.
1230 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
1231
12322002-11-03 Akim Demaille <akim@epita.fr>
1233
1234 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
1235 New.
1236 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
1237 (b4_parse_param): Remove.
1238 Use b4_identification.
1239 Propagate b4_pure_args where needed to pass them to yyerror.
1240 * data/glr.m4 (b4_parse_param): Remove.
1241 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
1242 (b4_lpure_formals): New.
1243 Use b4_identification.
1244 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
1245 b4_user_formals and b4_user_args.
1246 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
1247 (yyreportAmbiguity): When using a pure parser, also need
1248 the location, and the parse-params.
1249 Adjust callers.
1250 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
1251 When using a pure parser, also need the parse-params.
1252 Adjust callers.
1253 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
1254 (%pure-parser + %parse-param) LALR and GLR parsers.
1255 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
1256 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
1257 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
1258 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
1259 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
1260 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
1261 * doc/bison.texinfo: Untabify the whole file.
1262 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
1263 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
1264 (Error Reporting): Adjust to these new directives.
1265 Document %error-verbose, deprecate YYERROR_VERBOSE.
1266
12672002-11-03 Akim Demaille <akim@epita.fr>
1268
1269 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
1270 AT_CHECK_CALC_GLR invocations to use % directives, instead of
1271 command line options.
1272 * tests/cxx-type.at: Formatting changes.
1273
12742002-11-03 Paul Eggert <eggert@twinsun.com>
1275
1276 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
1277 to count columns correctly, and to check for invalid inputs.
1278
1279 Use mbsnwidth to count columns correctly. Account for tabs, too.
1280 Include mbswidth.h.
1281 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
1282 (extend_location): New function.
1283 (YY_LINES): Remove.
1284
1285 Handle CRLF in C code rather than in Lex code.
1286 (YY_INPUT): New macro.
1287 (no_cr_read): New function.
1288
1289 Scan UCNs, even though we don't fully handle them yet.
1290 (convert_ucn_to_byte): New function.
1291
1292 Handle backslash-newline correctly in C code.
1293 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
1294 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
1295 all uses changed.
1296 (tag, splice): New EREs. Do not allow NUL or newline in tags.
1297 Use {splice} wherever C allows backslash-newline.
1298 YY_STEP after space, newline, vertical-tab.
1299 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
1300
1301 (letter, id): Don't assume ASCII; e.g., spell out a-z.
1302
1303 ({int}, handle_action_dollar, handle_action_at): Check for integer
1304 overflow.
1305
1306 (YY_STEP): Omit trailing semicolon, so that it's more like C.
1307
1308 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
1309 as well as \000. Check for UCHAR_MAX, not 255.
1310 Allow \x with an arbitrary positive number of digits, as in C.
1311 Check for overflow here.
1312 Allow \? and UCNs, for compatibility with C.
1313
1314 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
1315 with quote slot used by complain_at.
1316
1317 * tests/input.at: Add tests for backslash-newline, m4 quotes
1318 in symbols, long literals, and funny escapes in strings.
1319
1320 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
1321 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
1322 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
1323 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
1324 * m4/mbswidth.m4: New file, from GNU coreutils.
1325
1326 * doc/bison.texinfo (Grammar Outline): Document // comments.
1327 (Symbols): Document that trigraphs have no special meaning in Bison,
1328 nor is backslash-newline allowed.
1329 (Actions): Document that trigraphs have no special meaning.
1330
1331 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
1332 no longer used.
1333
13342002-11-02 Paul Eggert <eggert@twinsun.com>
1335
1336 * src/reader.c: Don't include quote.h; not needed.
1337 (get_merge_function): Reword warning to be consistent with
1338 type clash diagnostic in grammar_current_rule_check.
1339
1340 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
1341 bug in trigraph handling.
1342
1343 * src/output.c (prepare_symbols): When printing token names,
1344 escape "[" as "@<:@" and likewise for "]".
1345
1346 * src/system.h (errno): Remove declaration, as we are now
1347 assuming C89 or better, and C89 guarantees errno.
1348
13492002-10-30 Paul Eggert <eggert@twinsun.com>
1350
1351 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
1352 Check for close failures.
1353 * src/files.h (xfclose): Return void, not int, since it always
1354 returned zero.
1355 * src/files.c (xfclose): Likewise. Report I/O error if ferror
1356 indicates one.
1357 * src/output.c (output_skeleton): Use xfclose rather than fclose
1358 and ferror. xfclose now checks ferror.
1359
1360 * data/glr.c (YYLEFTMOST_STATE): Remove.
1361 (yyreportTree): Use a stack-based leftmost state. This avoids
1362 our continuing battles with bogus warnings about initializers.
1363
13642002-10-30 Akim Demaille <akim@epita.fr>
1365
1366 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
1367 #if.
1368
13692002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1370
1371 * tests/glr-regr1.at: New test for reported regressions.
1372 * tests/testsuite.at: Add glr-regr1.at test.
1373 * tests/Makefile.am: Add glr-regr1.at test.
1374
13752002-10-24 Paul Eggert <eggert@twinsun.com>
1376
1377 Version 1.75a.
1378
1379 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
1380 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
1381 we use malloc. Don't assume 'A' through 'Z' are contiguous.
1382 Don't assume strdup exists; POSIX says its an XSI extension.
1383 Check for buffer overflow on input.
1384
13852002-10-24 Akim Demaille <akim@epita.fr>
1386
1387 * src/output.c (output_skeleton): Don't disable M4sugar comments
1388 too soon: it results in comments being expanded.
1389 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
1390 first output.
1391
13922002-10-24 Akim Demaille <akim@epita.fr>
1393
1394 * data/yacc.c (m4_int_type): New.
1395 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
1396 char' as only yacc.c wants K&R portability.
1397 * data/glr.c (yysigned_char): Remove.
1398 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
1399 Reported by Quoc Peyrot.
1400
14012002-10-23 Paul Eggert <eggert@twinsun.com>
1402
1403 * src/main.c (main): With --trace=time, report times even if a
1404 non-fatal error occurs. Formerly, the times were reported in some
1405 such cases but not in others.
1406 * src/reader.c (reader): Just return if a complaint has been issued,
1407 instead of exiting, so that 'main' can report times.
1408
14092002-10-22 Akim Demaille <akim@epita.fr>
1410
1411 * src/system.h: Include sys/types.
1412 Reported by Bert Deknuydt.
1413
14142002-10-23 Paul Eggert <eggert@twinsun.com>
1415
1416 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
1417 Suggested by Art Haas.
1418
14192002-10-22 Paul Eggert <eggert@twinsun.com>
1420
1421 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
1422 decl; not needed any more.
1423 * src/main.c (main): Use return to exit, undoing yesterday's change.
1424 The last OS that we could find where this wouldn't work is
1425 SunOS 3.5, and that's too old to worry about now.
1426
1427 * data/glr.c (struct yyltype): Define members even when not
1428 doing locations. This is more consistent with yacc.c, and it
1429 works around the following bug reports:
1430 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
1431 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
1432 and I hope it also fixes this bug report:
1433 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
1434
1435 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
1436 @acronym consistently. Standardize on "Yacc" instead of "YACC",
1437 "Algol" instead of "ALGOL". Give a bit more history about BNF.
1438
14392002-10-22 Akim Demaille <akim@epita.fr>
1440
1441 * data/README: New.
1442
14432002-10-21 Paul Eggert <eggert@twinsun.com>
1444
1445 Be consistent about 'bool'; the old code used an enum in one
1446 module and an int in another, and this violates the C standard.
1447 * m4/stdbool.m4: New file, from coreutils 4.5.3.
1448 * configure.ac (AC_HEADER_STDBOOL): Add.
1449 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
1450 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
1451 * src/symtab.c (hash_compare_symbol_t): Likewise.
1452 * src/system.h (bool, false, true): Use a definition consistent
1453 with ../lib/hash.c. All uses changed.
1454
1455 * src/complain.c (warning_issued): Renamed from warn_message_count,
1456 so that we needn't worry about integer overflow (!).
1457 Now of type bool. All uses changed.
1458 (complaint_issued): Renamed from complain_message_count; likewise.
1459
1460 * src/main.c (main): Use exit to exit with failure.
1461
1462 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
1463 rather than 1 and 0.
1464 * src/main.c (main): Likewise.
1465 * src/getargs.c (getargs): Likewise.
1466 * src/reader.c (reader): Likewise.
1467
1468 * src/getarg.c (getargs): Remove duplicate code for
1469 "Try `bison --help'".
1470
1471 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
1472 What was that "2" for?
1473
1474 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
1475 * src/getargs.c (usage): Likewise.
1476
1477 * src/getargs.c (getargs): When there are too few operands, report
1478 the last one. When there are too many, report the first extra
1479 one. This is how diffutils does it.
1480
14812002-10-20 Paul Eggert <eggert@twinsun.com>
1482
1483 Remove K&R vestiges.
1484 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
1485 * src/complain.c (VA_START): Remove. Assume prototypes.
1486 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
1487 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
1488 fatal): Assume prototypes.
1489 * src/complain.h: Assume prototypes.
1490 * src/system.h (PARAMS): Remove.
1491 Include <limits.h> unconditionally, since it's guaranteeed even
1492 for a freestanding C89 compiler.
1493 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
1494 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
1495
14962002-10-20 Akim Demaille <akim@epita.fr>
1497
1498 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1499 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1500 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1501 (yyresolveStates, yyresolveAction, yyresolveStack)
1502 (yyprocessOneStack): Use them.
1503 (yy_reduce_print): New.
1504 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1505
15062002-10-20 Akim Demaille <akim@epita.fr>
1507
1508 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1509 arguments and output `void'.
1510 (b4_c_function): Rename as...
1511 (b4_c_function_def): this.
1512 (b4_c_function_decl, b4_c_ansi_function_def)
1513 (b4_c_ansi_function_decl): New.
1514 Change the interpretation of the arguments: before `int, foo', now
1515 `int foo, foo'.
1516 * data/yacc.c (yyparse): Prototype and define thanks to these.
1517 Adjust b4_c_function_def uses.
1518 * data/glr.c (yyparse): Likewise, but ANSI only.
1519
15202002-10-20 Akim Demaille <akim@epita.fr>
1521
1522 * src/output.c (prepare): Move the definition of `tokens_number',
1523 `nterms_number', `undef_token_number', `user_token_number_max'
1524 to...
1525 (prepare_tokens): Here.
1526 (prepare_tokens): Rename as...
1527 (prepare_symbols): this.
1528 (prepare): Move the definition of `rules_number' to...
1529 (prepare_rules): here.
1530 (prepare): Move the definition of `last', `final_state_number',
1531 `states_number' to...
1532 (prepare_states): here.
1533 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1534
15352002-10-20 Akim Demaille <akim@epita.fr>
1536
1537 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1538
15392002-10-20 Akim Demaille <akim@epita.fr>
1540
1541 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1542 * data/c.m4: here.
1543
15442002-10-20 Akim Demaille <akim@epita.fr>
1545
1546 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1547 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1548 `pair'.
1549 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1550 `name' to...
1551 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1552 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1553 These.
1554
15552002-10-19 Paul Eggert <eggert@twinsun.com>
1556
1557 Do not create a temporary file, as that involves security and
1558 cleanup headaches. Instead, use a pair of pipes.
1559 Derived from a suggestion by Florian Krohm.
1560 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1561 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1562 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1563 (BISON_PREREQ_SUBPIPE): Add.
1564 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1565 Add subpipe.h, subpipe.c.
1566 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1567 * po/POTFILES.in: Add lib/subpipe.c.
1568 * src/output.c: Include "subpipe.h".
1569 (m4_invoke): Remove decl.
1570 (scan_skel): New decl.
1571 (output_skeleton): Use pipe rather than temporary file for m4 input.
1572 Check that m4sugar.m4 is readable, to avoid deadlock.
1573 Check for pipe I/O error.
1574 * src/scan-skel.l (readpipe): Remove decl.
1575 (scan_skel): New function, to be used in place of m4_invoke.
1576 Read from stream rather than file.
1577
1578 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1579 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1580 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1581 this generates a more-accurate value anyway.
1582
1583 * lib/timevar.c (timervar_accumulate): Rename locals to
1584 avoid confusion with similarly-named more-global.
1585 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1586
1587 * src/output.c (prepare): Use xstrdup to convert char const *
1588 to char *, to avoid GCC warning.
1589
15902002-10-19 Akim Demaille <akim@epita.fr>
1591
1592 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1593 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1594 Use them to have `calc.y' ready for %pure-parser.
1595 * data/yacc.c (YYLEX): Pass a yylex return type to
1596 b4_c_function_call.
1597
15982002-10-19 Akim Demaille <akim@epita.fr>
1599
1600 Prototype support of %lex-param and %parse-param.
1601
1602 * src/parse-gram.y: Add the definition of the %lex-param and
1603 %parse-param tokens, plus their rules.
1604 Drop the `_' version of %glr-parser.
1605 Add the "," token.
1606 * src/scan-gram.l (INITIAL): Scan them.
1607 * src/muscle_tab.c: Comment changes.
1608 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1609 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1610 (muscle_entry_s): The `value' member is no longer const.
1611 Adjust all dependencies.
1612 * src/muscle_tab.c (muscle_init): Adjust: use
1613 MUSCLE_INSERT_STRING.
1614 Initialize the obstack earlier.
1615 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1616 (muscle_pair_list_grow): New.
1617 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1618 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1619 * tests/calc.at: Use %locations, not --locations.
1620 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1621
16222002-10-19 Akim Demaille <akim@epita.fr>
1623
1624 * src/getargs.c (usage): Take status as argument and exit
1625 accordingly.
1626 Report the traditional `Try ... --help' message when status != 0.
1627 (usage, version): Don't take a FILE * as arg, it is pointless.
1628 (getargs): When there is an incorrect number of arguments, make it
1629 an error, and report it GNUlically thanks to `usage ()'.
1630
16312002-10-18 Paul Eggert <eggert@twinsun.com>
1632
1633 * data/glr.c (yyreportParseError): Don't assume that sprintf
1634 yields the length of the printed string, as this is not true
1635 on SunOS 4.1.4. Reported by Peter Klein.
1636
1637 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1638 * tests/conflicts.at (%nonassoc and eof): Likewise.
1639 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1640
16412002-10-17 Akim Demaille <akim@epita.fr>
1642
1643 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1644 * src/getargs.c (trace_types, trace_args): Adjust.
1645 * src/reader.c (grammar_current_rule_prec_set)
1646 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1647 Standardize error messages.
1648 And s/@prec/%prec/!
1649 (reader): Use trace_flag to enable scanner/parser debugging,
1650 instead of an adhoc scheme.
1651 * src/scan-gram.l: Remove trailing debugging code.
1652
16532002-10-16 Paul Eggert <eggert@twinsun.com>
1654
1655 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1656 MUSCLE_TAB_H.
1657
1658 * NEWS: Officially drop support for building Bison with K&R C,
1659 since it didn't work anyway and it's not worth worrying about.
1660 * Makefile.maint (wget_files): Remove ansi2knr.c.
1661 (ansi2knr.c-url_prefix): Remove.
1662 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1663 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1664 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1665
16662002-10-15 Paul Eggert <eggert@twinsun.com>
1667
1668 Stop using the "enum_" trick for K&R-style function definitions;
1669 it confused me, and I was the author! Instead, assume that people
1670 who want to use K&R C compilers (when using these modules in GCC,
1671 perhaps?) will run ansi2knr.
1672
1673 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1674 All uses of "enum_" changed to "enum ".
1675 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1676 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1677
1678 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1679 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1680 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1681 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1682 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1683 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1684 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1685 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1686 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1687 Use function prototypes; this removes the need for declaring
1688 static functions simply to provide their prototypes.
1689 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1690 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1691 bitset_count_, bitset_create, bitset_dump, bitset_first,
1692 bitset_free, bitset_init, bitset_last, bitset_next,
1693 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1694 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1695 bitset_print, bitset_release_memory, bitset_toggle_,
1696 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1697 debug_bitset): Likewise.
1698 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1699 * lib/bitset_stats.c (bitset_log_histogram_print,
1700 bitset_percent_histogram_print, bitset_stats_and,
1701 bitset_stats_and_cmp, bitset_stats_and_or,
1702 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1703 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1704 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1705 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1706 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1707 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1708 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1709 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1710 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1711 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1712 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1713 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1714 bitset_stats_zero): Likewise.
1715 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1716 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1717 bitsetv_dump, debug_bitsetv): Likewise.
1718 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1719 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1720 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1721 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1722 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1723 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1724 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1725 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1726 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1727 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1728 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1729 Likewise.
1730 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1731 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1732 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1733 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1734 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1735 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1736 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1737 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1738 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1739 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1740 lbitset_xor_cmp, lbitset_zero): Likewise.
1741
17422002-10-14 Akim Demaille <akim@epita.fr>
1743
1744 Version 1.75.
1745
17462002-10-14 Akim Demaille <akim@epita.fr>
1747
1748 * tests/Makefile.am (maintainer-check-posix): New.
1749
17502002-10-14 Akim Demaille <akim@epita.fr>
1751
1752 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1753 member.
1754
17552002-10-14 Akim Demaille <akim@epita.fr>
1756
1757 * src/tables.c (table_ninf_remap): base -> tab.
1758 Reported by Matt Rosing.
1759
17602002-10-14 Paul Eggert <eggert@twinsun.com>
1761
1762 * tests/action.at, tests/calc.at, tests/conflicts.at,
1763 tests/cxx-type.at, tests/headers.at, tests/input.at,
1764 tests/regression.at, tests/synclines.at, tests/torture.at:
1765 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1766 so that the tests still work even if POSIXLY_CORRECT is set.
1767 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
1768
1769 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1770 for portability to K&R hosts. Fix typo: signed char is guaranteed
1771 only to 127, not to 128.
1772 * data/glr.c (yysigned_char): New type.
1773 * data/yacc.c (yysigned_char): Likewise.
1774 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1775
17762002-10-13 Paul Eggert <eggert@twinsun.com>
1777
1778 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1779 true due to limited range of data type" warning from GCC.
1780
1781 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1782 by wrapping enum yytokentype's definition inside #ifndef
1783 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1784
17852002-10-13 Akim Demaille <akim@epita.fr>
1786
1787 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1788 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1789
17902002-10-13 Akim Demaille <akim@epita.fr>
1791
1792 * Makefile.maint: Update from Autoconf 2.54.
1793 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1794
17952002-10-13 Akim Demaille <akim@epita.fr>
1796
1797 * src/print.c (print_state): Separate the list of solved conflicts
1798 from the other items.
1799 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1800
18012002-10-13 Akim Demaille <akim@epita.fr>
1802
1803 Let nondeterministic skeletons be usable with deterministic
1804 tables.
1805
1806 With the patch, GAWK compiled by GCC without -O2 passes its test
1807 suite using a GLR parser driven by LALR tables. It fails with -O2
1808 because `struct stat' gives two different answers on my machine:
1809 88 (definition of an auto var) and later 96 (memset on this var).
1810 Hence the stack is badly corrumpted. The headers inclusion is to
1811 blame: if I move the awk.h inclusion before GLR's system header
1812 inclusion, the two struct stat have the same size.
1813
1814 * src/tables.c (pack_table): Always create conflict_table.
1815 (token_actions): Always create conflict_list.
1816 * data/glr.c (YYFLAG): Remove, unused.
1817
18182002-10-13 Akim Demaille <akim@epita.fr>
1819
1820 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1821 (O0FLAGS): New.
1822 (VALGRIND, GXX): New.
1823 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1824 * tests/bison.in: Run $PREBISON a pre-command.
1825 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1826 (maintainer-check-g++): New.
1827 * Makefile.am (maintainer-check): New.
1828
18292002-10-13 Akim Demaille <akim@epita.fr>
1830
1831 * data/glr.c: Formatting changes.
1832 Tweak some trace messages to match yacc.c's.
1833
18342002-10-13 Akim Demaille <akim@epita.fr>
1835
1836 GLR parsers sometimes raise parse errors instead of performing the
1837 default reduction.
1838 Reported by Charles-Henry de Boysson.
1839
1840 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1841 check the length of the traces when %glr.
1842 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1843 GLR's traces.
1844 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1845 Test GLR parsers.
1846 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1847 (yyltype): Remove the yy prefix from the member names.
1848 (yytable): Complete its comment.
1849 (yygetLRActions): Map error action number from YYTABLE from
1850 YYTABLE_NINF to 0.
1851 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1852 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1853 not satisfying as we could compare an YYACTION computed from
1854 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1855 only value for error actions.
1856 (yyreportParseError): In verbose parse error messages, don't issue
1857 `error' in the list of expected tokens.
1858 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1859 next action to perform to match glr.c's decoding.
1860 (yytable): Complete its comment.
1861
18622002-10-13 Paul Eggert <eggert@twinsun.com>
1863
1864 Fix problem reported by Henrik Grubbstroem in
1865 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1866 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1867 because the Bison parser reads the second action before reducing
1868 the first one.
1869 * src/scan-gram.l (rule_length): New static var.
1870 Use it to keep track of the rule length in the scanner, since
1871 we can't expect the parser to be in lock-step sync with the scanner.
1872 (handle_action_dollar, handle_action_at): Use this var.
1873 * tests/actions.at (Exotic Dollars): Test for the problem.
1874
18752002-10-12 Paul Eggert <eggert@twinsun.com>
1876
1877 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1878 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1879 Include <sys/time.h> when checking for clock_t and struct tms.
1880 Use same include order as source.
1881 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1882 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
1883
1884 * lib/timevar.c: Update copyright date and clarify comments.
1885 (get_time) [IN_GCC]: Keep the GCC version for reference.
1886
1887 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1888 GCC version as of today, then merge Bison's changes.
1889 Change "GCC" to "Bison" in copyright notice. timevar.def's
1890 author is Akim, so change that too.
1891
1892 * src/reader.c (grammar_current_rule_check):
1893 Don't worry about the default action if $$ is untyped.
1894 Prevents bogus warnings reported by Jim Gifford in
1895 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1896
1897 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
1898 * data/glr.c, data/lalr1.cc, data/yacc.c:
1899 Output token definitions before the first part of user declarations.
1900 Fixes compatibility problem reported by Jim Gifford for kbd in
1901 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
1902
19032002-10-11 Paul Eggert <eggert@twinsun.com>
1904
1905 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
1906 (yyparse): here. This undoes some of the 2002-07-25 change.
1907 Compatibility problem reported by Ralf S. Engelschall with
1908 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
1909
19102002-10-11 Akim Demaille <akim@epita.fr>
1911
1912 * tests/regression.at Characters Escapes): New.
1913 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
1914 characters.
1915 Reported by Jan Nieuwenhuizen.
1916
19172002-10-11 Akim Demaille <akim@epita.fr>
1918
1919 * po/id.po: New.
1920
19212002-10-10 Paul Eggert <eggert@twinsun.com>
1922
1923 Portability fixes for bitsets; this also avoids several GCC
1924 warnings.
1925
1926 * lib/abitset.c: Include <stddef.h>, for offsetof.
1927 * lib/lbitset.c: Likewise.
1928
1929 * lib/abitset.c (abitset_bytes): Return a size that is aligned
1930 properly for vectors of objects. Do not assume that adding a
1931 header size to a multiple of a word size yields a value that is
1932 properly aligned for the whole union.
1933 * lib/bitsetv.c (bitsetv_alloc): Likewise.
1934
1935 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
1936 unique names for structures.
1937 * lib/ebitset.c (ebitset_bytes): Likewise.
1938 * lib/lbitset.c (lbitset_bytes): Likewise.
1939
1940 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
1941 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
1942 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
1943 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
1944 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
1945 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
1946 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
1947 to improve the type-checking that GCC can do.
1948 * lib/bitset.c (bitset_op4_cmp): Likewise.
1949 * lib/bitset_stats.c (bitset_stats_count,
1950 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
1951 bitset_stats_copy, bitset_stats_disjoint_p,
1952 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
1953 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
1954 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
1955 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
1956 bitset_stats_and_or_cmp, bitset_stats_andn_or,
1957 bitset_stats_andn_or_cmp, bitset_stats_or_and,
1958 bitset_stats_or_and_cmp): Likewise.
1959 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
1960 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
1961 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
1962 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
1963
1964 * lib/abitset.h: Include bitset.h, not bbitset.h.
1965 * lib/ebitset.h: Likewise.
1966 * lib/lbitset.h: Likewise.
1967
1968 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
1969 All instances of parameters of type enum bitset_opts are now of
1970 type enum_bitset_opts, to conform to the C Standard, and similarly
1971 for enum_bitset_type.
1972 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1973 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1974
1975 Do not use "struct bitset_struct" to mean different things in
1976 different modules. Not only is this confusing, it violates
1977 the C Standard, which requires that structure types in different
1978 modules must be compatible if one is to be passed to the other.
1979 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
1980 All instances of "struct bitset_struct *" replaced with "bitset".
1981 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
1982 (union bitset_union, struct abitset_struct, struct ebitset_struct,
1983 struct lbitset_struct, struct bitset_stats_struct): New types.
1984 All uses of struct bitset_struct changed to union bitset_union,
1985 etc.
1986 * lib/abitset.c (struct abitset_struct, abitset,
1987 struct bitset_struct): Remove.
1988 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
1989 struct bitset_struct): Remove.
1990 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
1991 bitset_struct): Remove.
1992 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
1993 Likewise.
1994
1995 Do not call a function of type T using a call that assumes the
1996 function is of a different type U. Standard C requires that a
1997 function must be called with a type that is compatible with its
1998 definition.
1999 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2000 New decls.
2001 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2002 New functions.
2003 * lib/ebitset.c (PFV): Remove.
2004 * lib/lbitset.c (PFV): Likewise.
2005 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
2006 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
2007 decls.
2008 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
2009 (ebitset_vtable): Use them.
2010 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
2011 lbitset_xor): New functions.
2012 (lbitset_vtable): Use them.
2013
2014 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
2015 Declare.
2016
2017 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
2018 GCC warning.
2019 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
2020 Use offsetof, for simplicity.
2021
20222002-10-06 Paul Eggert <eggert@twinsun.com>
2023
2024 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
2025 the same width as int. This reapplies a hunk of the 2002-08-12 patch
2026 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
2027 which was inadvertently undone by the 2002-09-30 patch.
2028 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
2029 the same width as int.
2030
20312002-10-04 Paul Eggert <eggert@twinsun.com>
2032
2033 Version 1.50.
2034
2035 * configure.ac (AC_INIT), NEWS: Increment version number.
2036
2037 * doc/bison.texinfo: Minor spelling, grammar, and white space
2038 fixes.
2039 (Symbols): Mention that any negative value returned from yylex
2040 signifies end-of-input. Warn about negative chars. Mention
2041 the portable Standard C character set.
2042
2043 The GNU coding standard says CFLAGS and YFLAGS are reserved
2044 for the installer to set.
2045 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
2046 * src/Makefile.am (AM_CFLAGS): Likewise.
2047 (AM_YFLAGS): Renamed from YFLAGS.
2048
2049 Fix some MAX and MIN problems.
2050 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
2051 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
2052 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
2053 * src/reader.c (reader): Use it.
2054
2055 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
2056 POSIX 1003.1-2001 has removed fgrep.
2057
20582002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
2059
2060 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
2061 interpreted as signed.
2062 * lib/ebitset.c (ebitset_list): Fix bug.
2063
20642002-10-01 Paul Eggert <eggert@twinsun.com>
2065
2066 More fixes for 64-bit hosts and large bitsets.
2067
2068 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
2069 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
2070 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
2071 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
2072 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
2073 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
2074 bitset_count_): Likewise.
2075 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
2076 bitset_first, bitset_last): Likewise.
2077 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
2078 bitset_stats_list_reverse, bitset_stats_size,
2079 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
2080 Likewise.
2081 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2082 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
2083 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
2084 bitsetv_reflexive_transitive_closure): Likewise.
2085 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
2086 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
2087 Likewise.
2088 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
2089 Likewise.
2090
2091 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
2092 Use size_t, not unsigned int, to count bytes.
2093 * lib/abitset.h (abitset_bytes): Likewise.
2094 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
2095 Likewise.
2096 * lib/bitset.h (bitset_bytes): Likewise.
2097 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
2098 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
2099 * lib/bitsetv.c (bitsetv_alloc): Likewise.
2100 * lib/ebitset.c (ebitset_bytes): Likewise.
2101 * lib/ebitset.h (ebitset_bytes): Likewise.
2102 * lib/lbitset.c (lbitset_bytes): Likewise.
2103 * lib/lbitset.h (lbitset_bytes): Likewise.
2104
2105 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
2106 abitset_subset_p, abitset_disjoint_p, abitset_and,
2107 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
2108 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
2109 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
2110 abitset_or_and, abitset_or_and_cmp):
2111 Use bitset_windex instead of unsigned int.
2112 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2113 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
2114 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
2115 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
2116 Likewise.
2117 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
2118
2119 * lib/bitset.c (bitset_print):
2120 Use proper printf formats for widths of integer types.
2121 * lib/bitset_stats.c (bitset_percent_histogram_print,
2122 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
2123 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2124 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2125 * lib/lbitset.c (lbitset_bytes): Likewise.
2126
2127 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
2128 BITSET_SIZE_MAX): New macros.
2129 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
2130 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
2131 to BITSET_WINDEX_MAX.
2132
2133 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
2134 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
2135 since we now return the bitset_bindex type (not int).
2136
2137 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
2138 when computing sizes.
2139 * lib/ebitset.c (ebitset_elts_grow): Likewise.
2140
2141 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
2142 and avoid cast to unsigned.
2143
21442002-09-30 Akim Demaille <akim@epita.fr>
2145
2146 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
2147 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
2148 Updates from Michael Hayes.
2149
21502002-09-30 Art Haas <ahaas@neosoft.com>
2151
2152 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
2153 invocations.
2154 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
2155 defined.
2156
21572002-09-27 Akim Demaille <akim@epita.fr>
2158
2159 Version 1.49c.
2160
21612002-09-27 Akim Demaille <akim@epita.fr>
2162
2163 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
2164 (Because of AC_LIBSOURCE).
2165
21662002-09-27 Akim Demaille <akim@epita.fr>
2167
2168 Playing with Autoscan.
2169
2170 * configure.ac: Remove the old LIBOBJ tweaks.
2171 (AC_REPLACE_FUNCS): Add strrchr and strtol.
2172 * lib/strrchr.c: New.
2173 * lib/strtol.c: New, from the Coreutils 4.5.1.
2174
21752002-09-27 Akim Demaille <akim@epita.fr>
2176
2177 Playing with Autoscan.
2178
2179 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
2180 * lib/Makefile.am (libbison_a_SOURCES): No longer include
2181 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
2182 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
2183 Coreutils 4.5.1.
2184
21852002-09-24 Akim Demaille <akim@epita.fr>
2186
2187 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
2188 (Frequently Asked Questions, Parser Stack Overflow): New.
2189
21902002-09-13 Akim Demaille <akim@epita.fr>
2191
2192 Playing with autoscan.
2193
2194 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
2195 * src/files.c (skeleton_find): Remove, unused.
2196 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
2197 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
2198
21992002-09-13 Akim Demaille <akim@epita.fr>
2200
2201 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
2202 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
2203
22042002-09-13 Akim Demaille <akim@epita.fr>
2205
2206 * configure.ac: Require 2.54.
2207 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
2208 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
2209 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
2210 Remove, provided by Autoconf macros.
2211
22122002-09-12 Akim Demaille <akim@epita.fr>
2213
2214 * m4/prereq.m4: Update, from Coreutils 4.5.1.
2215
22162002-09-12 Akim Demaille <akim@epita.fr>
2217
2218 * m4/prereq.m4: Update, from Fileutils 4.1.5.
2219 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
2220 Reported by Martin Mokrejs.
2221
22222002-09-10 Akim Demaille <akim@epita.fr>
2223
2224 * src/parse-gram.y: Associate a human readable string to each
2225 token type.
2226 * tests/regression.at (Invalid inputs): Adjust.
2227
22282002-09-10 Gary V. Vaughan <gary@gnu.org>
2229
2230 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
2231 with an Autoconf-2.5x style configure.ac.
2232
22332002-09-06 Paul Eggert <eggert@twinsun.com>
2234
2235 * doc/bison.texinfo (Conditions): Make explicit that the GPL
2236 exception applies only to yacc.c. This is a modification of a
2237 patch originally suggested by Akim Demaille.
2238
22392002-09-06 Akim Demaille <akim@epita.fr>
2240
2241 * data/c.m4 (b4_copyright): Move the GPL exception comment from
2242 here to...
2243 * data/yacc.c: here.
2244
2245 * data/lalr1.cc (struct yyltype): Don't define it, since we use
2246 LocationType.
2247 (b4_ltype): Default to yy::Location from location.hh.
2248
22492002-09-04 Jim Meyering <jim@meyering.net>
2250
2251 * data/yacc.c: Guard the declaration of yytoknum also with
2252 `#ifdef YYPRINT', so it is declared only when used.
2253
22542002-09-04 Akim Demaille <akim@epita.fr>
2255
2256 * configure.in: Rename as...
2257 * configure.ac: this.
2258 Bump to 1.49c.
2259
22602002-09-04 Akim Demaille <akim@epita.fr>
2261
2262 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
2263 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
2264 translate maintainer only messages.
2265
22662002-08-12 Paul Eggert <eggert@twinsun.com>
2267
2268 Version 1.49b.
2269
2270 * Makefile.am (SUBDIRS): Remove intl.
2271 (DISTCLEANFILES): Remove.
2272 * NEWS: Mention that GNU M4 is now required. Clarify what is
2273 meant by "larger grammars". Mention the pt_BR translation.
2274 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
2275 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
2276 Bump version from 0.11.2 to 0.11.5.
2277 (BISON_PREREQ_STAGE): Remove.
2278 (AM_GNU_GETTEXT): Use external gettext.
2279 (AC_OUTPUT): Remove intl/Makefile.
2280
2281 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
2282
2283 * data/glr.c: Include string.h, for strlen.
2284 (yyreportParseError): Use size_t for yysize.
2285 (yy_yypstack): No longer nested inside yypstates, as nested
2286 functions are not portable. Do not assume size_t is the
2287 same width as int.
2288 (yypstates): Do not assume that ptrdiff_t is the same width
2289 as int, and similarly for yyposn and YYINDEX.
2290
2291 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
2292
2293 * lib/Makefile.am (INCLUDES): Do not include from the intl
2294 directory, which has been removed.
2295 * src/Makefile.am (INCLUDES): Likewise.
2296
2297 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
2298 (bitsets_sources, additional_bitsets_sources, timevars_sources):
2299 New vars.
2300
2301 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
2302 * tests/Makefile.am (EXTRA_DIST): Likewise.
2303
2304 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
2305 Do not assume that bitset_windex is the same width as unsigned.
2306
2307 * lib/abitset.c (abitset_unused_clear): Do not assume that
2308 bitset_word is the same width as int.
2309 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
2310 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
2311 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
2312 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
2313 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
2314
2315 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
2316 portability to one's complement hosts!).
2317 * lib/ebitset.c (ebitset_op1): Likewise.
2318 * lib/lbitset.c (lbitset_op1): Likewise.
2319
2320 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
2321 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
2322 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
2323 Sync with fileutils.
2324 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
2325 lib/gettext.h: Sync with diffutils.
2326
2327 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
2328 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
2329
2330 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
2331 PROTOTYPES to check for prototypes, and "defined __STDC__" to
2332 check for void *.
2333
2334 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
2335 size_t; the old version tried to do this but casted improperly.
2336 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
2337 (bitset_test): Now returns int, not unsigned long.
2338
2339 * lib/bitset_stats.c: Include "gettext.h".
2340 (_): New macro.
2341 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
2342 name locals "index", as it generates unnecessary warnings on some
2343 hosts that have an "index" function.
2344
2345 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
2346 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
2347 they need translation.
2348 * src/LR0.c (state_list_append, new_itemsets, get_state,
2349 append_states, generate_states): Likewise.
2350 * src/assoc.c (assoc_to_string): Likewise.
2351 * src/closure.c (print_closure, set_firsts, closure): Likewise.
2352 * src/gram.c (grammar_dump): Likewise.
2353 * src/injections.c (injections_compute): Likewise.
2354 * src/lalr.c (lookaheads_print): Likewise.
2355 * src/relation.c (relation_transpose): Likewise.
2356 * src/scan-gram.l: Likewise.
2357 * src/tables.c (table_grow, pack_vector): Likewise.
2358
2359 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
2360 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
2361 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
2362 * m4/mbstate_t.m4: Sync with fileutils.
2363 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
2364
2365 * po/LINGUAS: Add pt_BR.
2366 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
2367 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
2368 lib/timevar.c.
2369 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
2370 manual recommends.
2371 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
2372
2373 * src/complain.c (strerror_r): Remove decl; not needed.
2374 (strerror): Use same pattern as ../lib/error.c.
2375
2376 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
2377
2378 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
2379
2380 * src/main.c (main): Cast result of bindtextdomain and textdomain
2381 to void, to avoid a GCC warning when --disable-nls is in effect.
2382
2383 * src/scan-gram.l: Use strings rather than escapes when possible,
2384 to minimize the number of warnings from xgettext.
2385 (handle_action_dollar, handle_action_at): Don't use isdigit,
2386 as it mishandles negative chars and it may not work as expected
2387 outside the C locale.
2388
2389 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
2390 this is a GCC extension and is not portable to other compilers.
2391
2392 * src/system.h (alloca): Use same pattern as ../lib/error.c.
2393 Do not include <ctype.h>; no longer needed.
2394 Do not include <malloc.h>; no longer needed (and generates
2395 warnings on OpenBSD 3.0).
2396
2397 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
2398 it's not portable.
2399
2400 * tests/regression.at: Do not use 'cc -c input.c -o input';
2401 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
2402
2403 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
2404 exit status as failure, not just exit status 1. Sun C exits
2405 with status 2 sometimes.
2406
2407 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
2408 Use it for the two large tests.
2409
24102002-08-02 Akim Demaille <akim@epita.fr>
2411
2412 * src/conflicts.c (conflicts_output): Don't output rules never
2413 reduced here, since anyway that computation doesn't work.
2414 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
2415 (rule_useless_p, rule_never_reduced_p): New.
2416 (grammar_rules_partial_print): Use a filter instead of a range.
2417 Display the title only if needed.
2418 (grammar_rules_print): Adjust.
2419 (grammar_rules_never_reduced_report): New.
2420 * src/tables.c (action_row): Move the computation of rules never
2421 reduced to...
2422 (token_actions): here.
2423 * src/main.c (main): Make the parser before making the report, so
2424 that rules never reduced are computed.
2425 Call grammar_rules_never_reduced_report.
2426 * src/print.c (print_results): Report rules never reduced.
2427 * tests/conflicts.at, tests/reduce.at: Adjust.
2428
24292002-08-01 Akim Demaille <akim@epita.fr>
2430
2431 Instead of attaching lookaheads and duplicating the rules being
2432 reduced by a state, attach the lookaheads to the reductions.
2433
2434 * src/state.h (state_t): Remove the `lookaheads',
2435 `lookaheads_rule' member.
2436 (reductions_t): Add a `lookaheads' member.
2437 Use a regular array for the `rules'.
2438 * src/state.c (reductions_new): Initialize the lookaheads member
2439 to 0.
2440 (state_rule_lookaheads_print): Adjust.
2441 * src/state.h, src/state.c (state_reductions_find): New.
2442 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
2443 (count_rr_conflicts): Adjust.
2444 * src/lalr.c (LArule): Remove.
2445 (add_lookback_edge): Adjust.
2446 (state_lookaheads_count): New.
2447 (states_lookaheads_initialize): Merge into...
2448 (initialize_LA): this.
2449 (lalr_free): Adjust.
2450 * src/main.c (main): Don't free nullable and derives too early: it
2451 is used by --verbose.
2452 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
2453
24542002-08-01 Akim Demaille <akim@epita.fr>
2455
2456 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
2457 `rule_number_t**'.
2458 (set_derives, free_derives): Rename as...
2459 (derives_compute, derives_free): this.
2460 Adjust all dependencies.
2461 * src/nullable.c (set_nullable, free_nullable): Rename as...
2462 (nullable_compute, nullable_free): these.
2463 (rule_list_t): Store rule_t *, not rule_number_t.
2464 * src/state.c (state_rule_lookaheads_print): Directly compare rule
2465 pointers, instead of their numbers.
2466 * src/main.c (main): Call nullable_free, and derives_free earlier,
2467 as they were lo longer used.
2468
24692002-08-01 Akim Demaille <akim@epita.fr>
2470
2471 * lib/timevar.c (get_time): Include children time.
2472 * src/lalr.h (LA, LArule): Don't export them: used with the
2473 state_t.
2474 * src/lalr.c (LA, LArule): Static.
2475 * src/lalr.h, src/lalr.c (lalr_free): New.
2476 * src/main.c (main): Call it.
2477 * src/tables.c (pack_vector): Check whether loc is >= to the
2478 table_size, not >.
2479 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
2480 (tables_generate): do it, since that's also it which allocates
2481 them.
2482 Don't free LA and LArule, main does.
2483
24842002-07-31 Akim Demaille <akim@epita.fr>
2485
2486 Separate parser tables computation and output.
2487
2488 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
2489 (conflict_list, conflict_list_cnt, table, check, table_ninf)
2490 (yydefgoto, yydefact, high): Move to...
2491 * src/tables.h, src/tables.c: here.
2492 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2493 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2494 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
2495 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
2496 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2497 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2498 (action_row, save_row, token_actions, save_column, default_goto)
2499 (goto_actions, sort_actions, matching_state, pack_vector)
2500 (table_ninf_remap, pack_table, prepare_actions): Move to...
2501 * src/tables.c: here.
2502 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2503 * src/output.c (token_actions, output_base, output_conflicts)
2504 (output_check): Merge into...
2505 (prepare_actions): this.
2506 (actions_output): Rename as...
2507 (user_actions_output): this.
2508 * src/main.c (main): Call tables_generate and tables_free.
2509
25102002-07-31 Akim Demaille <akim@epita.fr>
2511
2512 Steal GCC's --time-report support.
2513
2514 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2515 stolen/adjusted from GCC.
2516 * m4/stage.m4: Remove time related checks.
2517 * m4/timevar.m4: New.
2518 * configure.in: Adjust.
2519 * src/system.h: Adjust to using timevar.h.
2520 * src/getargs.h, src/getargs.c: Support trace_time for
2521 --trace=time.
2522 * src/main.c (stage): Remove.
2523 (main): Replace `stage' invocations with timevar calls.
2524 * src/output.c: Insert pertinent timevar calls.
2525
25262002-07-31 Akim Demaille <akim@epita.fr>
2527
2528 Let --trace have arguments.
2529
2530 * src/getargs.h (enum trace_e): New.
2531 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2532 (long_options, short_options): --trace/-T takes an optional
2533 argument.
2534 Change all the uses of trace_flag to reflect the new flags.
2535 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2536
2537 Strengthen `stage' portability.
2538
2539 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2540 * configure.in: Use it.
2541 Don't check for malloc.h and sys/times.h.
2542 * src/system.h: Include them when appropriate.
2543 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2544 times and struct tms are available.
2545
25462002-07-30 Akim Demaille <akim@epita.fr>
2547
2548 In verbose parse error message, don't report `error' as an
2549 expected token.
2550 * tests/actions.at (Printers and Destructors): Adjust.
2551 * tests/calc.at (Calculator $1): Adjust.
2552 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2553 error message, do not report the parser accepts the error token in
2554 that state.
2555
25562002-07-30 Akim Demaille <akim@epita.fr>
2557
2558 Normalize conflict related messages.
2559
2560 * src/complain.h, src/complain.c (warn, complain): New.
2561 * src/conflicts.c (conflicts_print): Use them.
2562 (conflict_report_yacc): New, extracted from...
2563 (conflicts_print): here.
2564 * tests/conflicts.at, tests/existing.at: Adjust.
2565
25662002-07-30 Akim Demaille <akim@epita.fr>
2567
2568 Report rules which are never reduced by the parser: those hidden
2569 by conflicts.
2570
2571 * src/LR0.c (save_reductions): Don't make the final state too
2572 different: save its reduction (accept) instead of having a state
2573 without any action (no shift or goto, no reduce).
2574 Note: the final state is now a ``regular'' state, i.e., the
2575 parsers now contain `reduce 0' as default reduction.
2576 Nevertheless, since they decide to `accept' when yystate =
2577 final_state, they still will not reduce rule 0.
2578 * src/print.c (print_actions, print_reduction): Adjust.
2579 * src/output.c (action_row): Track reduced rules.
2580 (token_actions): Report rules never reduced.
2581 * tests/conflicts.at, tests/regression.at: Adjust.
2582
25832002-07-30 Akim Demaille <akim@epita.fr>
2584
2585 `stage' was accidently included in a previous patch.
2586 Initiate its autoconfiscation.
2587
2588 * configure.in: Look for malloc.h and sys/times.h.
2589 * src/main.c (stage): Adjust.
2590 Report only when trace_flag.
2591
25922002-07-29 Akim Demaille <akim@epita.fr>
2593
2594 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2595 state_number_t.
2596 (errs_t): symbol_t*, not symbol_number_t.
2597 (reductions_t): rule_t*, not rule_number_t.
2598 (FOR_EACH_SHIFT): New.
2599 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2600 * src/print.c, src/print_graph.c: Adjust.
2601
26022002-07-29 Akim Demaille <akim@epita.fr>
2603
2604 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2605
2606 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2607 (endtoken, accept): these.
2608 * src/reader.c (reader): Set endtoken's default tag to "$end".
2609 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2610 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2611 Adjust.
2612
26132002-07-29 Akim Demaille <akim@epita.fr>
2614
2615 * src/reduce.c (reduce_grammar): When the language is empty,
2616 complain about the start symbol, not the axiom.
2617 Use its location.
2618 * tests/reduce.at (Empty Language): New.
2619
26202002-07-26 Akim Demaille <akim@epita.fr>
2621
2622 * src/reader.h, src/reader.c (gram_error): ... can't get
2623 yycontrol without making too strong assumptions on the parser
2624 itself.
2625 * src/output.c (prepare_tokens): Use the real 0th value of
2626 token_translations instead of `0'.
2627 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2628 visible here.
2629 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2630 for the time being: %locations ought to provide it to yyerror.
2631
26322002-07-25 Akim Demaille <akim@epita.fr>
2633
2634 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2635 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2636 * tests/regression.at (Web2c Actions): Adjust.
2637
26382002-07-25 Akim Demaille <akim@epita.fr>
2639
2640 Stop storing rules from 1 to nrules + 1.
2641
2642 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2643 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2644 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2645 Iterate from 0 to nrules.
2646 Use rule_number_as_item_number and item_number_as_rule_number.
2647 Adjust to `derive' now containing possibly 0.
2648 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2649 Handle the `- 1' part in rule numbers from/to item numbers.
2650 * src/conflicts.c (log_resolution): Fix the message which reversed
2651 shift and reduce.
2652 * src/output.c (action_row): Initialize default_rule to -1.
2653 (token_actions): Adjust.
2654 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2655 expected output.
2656 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2657
26582002-07-25 Akim Demaille <akim@epita.fr>
2659
2660 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2661 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2662 (b4_c_knr_arg_decl): New.
2663 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2664 yyreport_parse_error.
2665
26662002-07-25 Akim Demaille <akim@epita.fr>
2667
2668 * data/yacc.c (yyreport_parse_error): New, extracted from...
2669 (yyparse): here.
2670 (yydestruct, yysymprint): Move above yyparse.
2671 Be K&R compliant.
2672
26732002-07-25 Akim Demaille <akim@epita.fr>
2674
2675 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2676 replace...
2677 (b4_sint_type, b4_uint_type): these.
2678 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2679 * tests/regression.at (Web2c Actions): Adjust.
2680
26812002-07-25 Akim Demaille <akim@epita.fr>
2682
2683 * src/gram.h (TIEM_NUMBER_MAX): New.
2684 (item_number_of_rule_number, rule_number_of_item_number): Rename
2685 as...
2686 (rule_number_as_item_number, item_number_as_rule_number): these.
2687 Adjust dependencies.
2688 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2689 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2690 (symbol_number_to_vector_number): New.
2691 (order): Of vector_number_t* type.
2692 (base_t, BASE_MAX, BASE_MIN): New.
2693 (froms, tos, width, pos, check): Of base_t type.
2694 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2695 (actrow): Of action_number_t type.
2696 (conflrow): Of unsigned int type.
2697 (table_ninf, base_ninf): New.
2698 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2699 (muscle_insert_int_table, muscle_insert_base_table)
2700 (muscle_insert_rule_number_table): New.
2701 (prepare_tokens): Output `toknum' as int_table.
2702 (action_row): Returns a rule_number_t.
2703 Use ACTION_MIN, not SHRT_MIN.
2704 (token_actions): yydefact is rule_number_t*.
2705 (table_ninf_remap): New.
2706 (pack_table): Use it for `base' and `table'.
2707 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2708 replaced with...
2709 (YYPACT_NINF, YYTABLE_NINF): these.
2710 (yypact, yytable): Compute their types instead of hard-coded
2711 `short'.
2712 * tests/regression.at (Web2c Actions): Adjust.
2713
27142002-07-19 Akim Demaille <akim@epita.fr>
2715
2716 * src/scan-gram.l (id): Can start with an underscore.
2717
27182002-07-16 Akim Demaille <akim@epita.fr>
2719
2720 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2721 Adjust all former `associativity' dependencies.
2722 * src/symtab.c (symbol_new): Default associativity is `undef', not
2723 `right'.
2724 (symbol_check_alias_consistence): Adjust.
2725
27262002-07-09 Akim Demaille <akim@epita.fr>
2727
2728 * doc/bison.texinfo: Properly set the ``header'' part.
2729 Use @dircategory ``GNU programming tools'' as per Texinfo's
2730 documentation.
2731 Use @copying.
2732
27332002-07-09 Akim Demaille <akim@epita.fr>
2734
2735 * lib/quotearg.h: Protect against multiple inclusions.
2736 * src/location.h (location_t): Add a `file' member.
2737 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2738 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2739 `error_one_per_line' support.
2740
27412002-07-09 Akim Demaille <akim@epita.fr>
2742
2743 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2744 * src/reader.c (lineno): Remove.
2745 Adjust all dependencies.
2746 (get_merge_function): Take a location and use complain_at.
2747 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2748 * tests/regression.at (Invalid inputs, Mixing %token styles):
2749 Adjust.
2750
27512002-07-09 Akim Demaille <akim@epita.fr>
2752
2753 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2754 recovery rule, and forbid extensions when --yacc.
2755 (gram_error): Use complain_at.
2756 * src/reader.c (reader): Exit if there were parse errors.
2757
27582002-07-09 Akim Demaille <akim@epita.fr>
2759
2760 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2761 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2762 Reported by R Blake <blakers@mac.com>.
2763
27642002-07-09 Akim Demaille <akim@epita.fr>
2765
2766 * data/yacc.c: Output the copyright notive in the header.
2767
27682002-07-03 Akim Demaille <akim@epita.fr>
2769
2770 * src/output.c (froms, tos): Are state_number_t.
2771 (save_column): sp, sp1, and sp2 are state_number_t.
2772 (prepare): Rename `final' as `final_state_number', `nnts' as
2773 `nterms_number', `nrules' as `rules_number', `nstates' as
2774 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2775 unused.
2776 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2777 * data/lalr1.cc (nsym_): Remove, unused.
2778
27792002-07-03 Akim Demaille <akim@epita.fr>
2780
2781 * src/lalr.h, src/lalr.c (goto_number_t): New.
2782 * src/lalr.c (goto_list_t): New.
2783 Propagate them.
2784 * src/nullable.c (rule_list_t): New.
2785 Propagate.
2786 * src/types.h: Remove.
2787
27882002-07-03 Akim Demaille <akim@epita.fr>
2789
2790 * src/closure.c (print_fderives): Use rule_rhs_print.
2791 * src/derives.c (print_derives): Use rule_rhs_print.
2792 (rule_list_t): New, replaces `shorts'.
2793 (set_derives): Add comments.
2794 * tests/sets.at (Nullable, Firsts): Adjust.
2795
27962002-07-03 Akim Demaille <akim@epita.fr>
2797
2798 * src/output.c (prepare_actions): Free `tally' and `width'.
2799 (prepare_actions): Allocate and free `order'.
2800 * src/symtab.c (symbols_free): Free `symbols'.
2801 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2802 * src/output.c (m4_invoke): Move to...
2803 * src/scan-skel.l: here.
2804 (<<EOF>>): Close yyout, and free its name.
2805
28062002-07-03 Akim Demaille <akim@epita.fr>
2807
2808 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2809
2810 * src/LR0.c (new_state): Merge into...
2811 (state_list_append): this.
2812 (new_states): Merge into...
2813 (generate_states): here.
2814 (set_states): Don't ensure a proper `errs' state member here, do it...
2815 * src/conflicts.c (conflicts_solve): here.
2816 * src/state.h, src/state.c: Comment changes.
2817 (state_t): Rename member `shifts' as `transitions'.
2818 Adjust all dependencies.
2819 (errs_new): For consistency, also take the values as argument.
2820 (errs_dup): Remove.
2821 (state_errs_set): New.
2822 (state_reductions_set, state_transitions_set): Assert that no
2823 previous value was assigned.
2824 (state_free): New.
2825 (states_free): Use it.
2826 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2827 temporary storage: use `errs' and `nerrs' as elsewhere.
2828 (set_conflicts): Allocate and free this `errs'.
2829
28302002-07-02 Akim Demaille <akim@epita.fr>
2831
2832 * lib/libiberty.h: New.
2833 * lib: Update the bitset implementation from upstream.
2834 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2835 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2836 * src/main.c: Adjust bitset stats calls.
2837
28382002-07-01 Paul Eggert <eggert@twinsun.com>
2839
2840 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2841 char, so that negative chars don't collide with $.
2842
28432002-06-30 Akim Demaille <akim@epita.fr>
2844
2845 Have the GLR tests be `warning' checked, and fix the warnings.
2846
2847 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2848 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2849 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2850 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2851 (yyaddDeferredAction): static.
2852 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2853 (yyreportParseError): yyprefix is const.
2854 yytokenp is used only when verbose.
2855 (yy__GNUC__): Replace with __GNUC__.
2856 (yypdumpstack): yyi is size_t.
2857 (yypreference): Un-yy local variables and arguments, to avoid
2858 clashes with `yyr1'. Anyway, we are not in the user name space.
2859 (yytname_size): be an int, as is compared with ints.
2860 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2861 Use them.
2862 * tests/cxx-gram.at: Use quotation to protect $1.
2863 Use AT_COMPILE to enable warnings hunts.
2864 Prototype yylex and yyerror.
2865 `Use' argc.
2866 Include `string.h', not `strings.h'.
2867 Produce and prototype stmtMerge only when used.
2868 yylex takes a location.
2869
28702002-06-30 Akim Demaille <akim@epita.fr>
2871
2872 We spend a lot of time in quotearg, in particular when --verbose.
2873
2874 * src/symtab.c (symbol_get): Store a quoted version of the key.
2875 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2876 Adjust all callers.
2877
28782002-06-30 Akim Demaille <akim@epita.fr>
2879
2880 * src/state.h (reductions_t): Rename member `nreds' as num.
2881 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2882 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2883
28842002-06-30 Akim Demaille <akim@epita.fr>
2885
2886 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2887 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2888 (shifts_to): Rename as...
2889 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2890 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2891 (TRANSITION_IS_DISABLED, transitions_to): these.
2892
28932002-06-30 Akim Demaille <akim@epita.fr>
2894
2895 * src/print.c (print_shifts, print_gotos): Merge into...
2896 (print_transitions): this.
2897 (print_transitions, print_errs, print_reductions): Align the
2898 lookaheads columns.
2899 (print_core, print_transitions, print_errs, print_state,
2900 print_grammar): Output empty lines separator before, not after.
2901 (state_default_rule_compute): Rename as...
2902 (state_default_rule): this.
2903 * tests/conflicts.at (Defaulted Conflicted Reduction),
2904 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
2905 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
2906
29072002-06-30 Akim Demaille <akim@epita.fr>
2908
2909 Display items as we display rules.
2910
2911 * src/gram.h, src/gram.c (rule_lhs_print): New.
2912 * src/gram.c (grammar_rules_partial_print): Use it.
2913 * src/print.c (print_core): Likewise.
2914 * tests/conflicts.at (Defaulted Conflicted Reduction),
2915 (Unresolved SR Conflicts): Adjust.
2916 (Unresolved SR Conflicts): Adjust and rename as...
2917 (Resolved SR Conflicts): this, as was meant.
2918 * tests/regression.at (Web2c Report): Adjust.
2919
29202002-06-30 Akim Demaille <akim@epita.fr>
2921
2922 * src/print.c (state_default_rule_compute): New, extracted from...
2923 (print_reductions): here.
2924 Pessimize, but clarify the code.
2925 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
2926
29272002-06-30 Akim Demaille <akim@epita.fr>
2928
2929 * src/output.c (action_row): Let default_rule be always a rule
2930 number.
2931
29322002-06-30 Akim Demaille <akim@epita.fr>
2933
2934 * src/closure.c (print_firsts, print_fderives, closure):
2935 Use BITSET_EXECUTE.
2936 * src/lalr.c (lookaheads_print): Likewise.
2937 * src/state.c (state_rule_lookaheads_print): Likewise.
2938 * src/print_graph.c (print_core): Likewise.
2939 * src/print.c (print_reductions): Likewise.
2940 * src/output.c (action_row): Likewise.
2941 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
2942
29432002-06-30 Akim Demaille <akim@epita.fr>
2944
2945 * src/print_graph.c: Use report_flag.
2946
29472002-06-30 Akim Demaille <akim@epita.fr>
2948
2949 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
2950 to...
2951 * src/relation.h, src/relation.c (traverse, relation_digraph)
2952 (relation_print, relation_transpose): New.
2953
29542002-06-30 Akim Demaille <akim@epita.fr>
2955
2956 * src/state.h, src/state.c (shifts_to): New.
2957 * src/lalr.c (build_relations): Use it.
2958
29592002-06-30 Akim Demaille <akim@epita.fr>
2960
2961 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
2962 (item_number_of_rule_number, rule_number_of_item_number): New.
2963 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
2964 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
2965 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
2966 Propagate their use.
2967 Much remains to be done, in particular wrt `shorts' from types.h.
2968
29692002-06-30 Akim Demaille <akim@epita.fr>
2970
2971 * src/symtab.c (symbol_new): Initialize the `printer' member.
2972
29732002-06-30 Akim Demaille <akim@epita.fr>
2974
2975 * src/LR0.c (save_reductions): Remove, replaced by...
2976 * src/state.h, src/state.c (state_reductions_set): New.
2977 (reductions, errs): Rename as...
2978 (reductions_t, errs_t): these.
2979 Adjust all dependencies.
2980
29812002-06-30 Akim Demaille <akim@epita.fr>
2982
2983 * src/LR0.c (state_list_t, state_list_append): New.
2984 (first_state, last_state): Now symbol_list_t.
2985 (this_state): Remove.
2986 (new_itemsets, append_states, save_reductions): Take a state_t as
2987 argument.
2988 (set_states, generate_states): Adjust.
2989 (save_shifts): Remove, replaced by...
2990 * src/state.h, src/state.c (state_shifts_set): New.
2991 (shifts): Rename as...
2992 (shifts_t): this.
2993 Adjust all dependencies.
2994 * src/state.h (state_t): Remove the `next' member.
2995
29962002-06-30 Akim Demaille <akim@epita.fr>
2997
2998 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
2999 escaped in slot 0.
3000
30012002-06-30 Akim Demaille <akim@epita.fr>
3002
3003 Use hash.h for the state hash table.
3004
3005 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
3006 (allocate_storage): Use state_hash_new.
3007 (free_storage): Use state_hash_free.
3008 (new_state, get_state): Adjust.
3009 * src/lalr.h, src/lalr.c (states): Move to...
3010 * src/states.h (state_t): Remove the `link' member, no longer
3011 used.
3012 * src/states.h, src/states.c: here.
3013 (state_hash_new, state_hash_free, state_hash_lookup)
3014 (state_hash_insert, states_free): New.
3015 * src/states.c (state_table, state_compare, state_hash): New.
3016 * src/output.c (output_actions): Do not free states now, since we
3017 still need to know the final_state number in `prepare', called
3018 afterwards. Do it...
3019 * src/main.c (main): here: call states_free after `output'.
3020
30212002-06-30 Akim Demaille <akim@epita.fr>
3022
3023 * src/state.h, src/state.c (state_new): New, extracted from...
3024 * src/LR0.c (new_state): here.
3025 * src/state.h (STATE_ALLOC): Move to...
3026 * src/state.c: here.
3027 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
3028 * src/state.h, src/state.c: here.
3029
30302002-06-30 Akim Demaille <akim@epita.fr>
3031
3032 * src/reader.c (gensym): Rename as...
3033 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
3034 (getsym): Rename as...
3035 (symbol_get): this.
3036
30372002-06-30 Akim Demaille <akim@epita.fr>
3038
3039 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
3040 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
3041 * src/output.c, src/print.c, src/print_graph.c: Propagate.
3042 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
3043
30442002-06-30 Akim Demaille <akim@epita.fr>
3045
3046 Make the test suite pass with warnings checked.
3047
3048 * tests/actions.at (Printers and Destructors): Improve.
3049 Avoid unsigned vs. signed issues.
3050 * tests/calc.at: Don't exercise the scanner here, do it...
3051 * tests/input.at (Torturing the Scanner): here.
3052
30532002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3054
3055 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
3056 reorganize first lines parallel to yacc.c.
3057
30582002-06-28 Akim Demaille <akim@epita.fr>
3059
3060 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
3061 (b4_token_enum, b4_token_defines): New, factored from...
3062 * data/lalr1.cc, data/yacc.c, glr.c: here.
3063
30642002-06-28 Akim Demaille <akim@epita.fr>
3065
3066 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
3067 unused variables.
3068 * src/output.c (merger_output): static.
3069
30702002-06-28 Akim Demaille <akim@epita.fr>
3071
3072 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
3073 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
3074 pacify GCC.
3075 * src/output.c (save_row): Initialize all the variables to pacify GCC.
3076
30772002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3078
3079 Accumulated changelog for new GLR parsing features.
3080
3081 * src/conflicts.c (count_total_conflicts): Change name to
3082 conflicts_total_count.
3083 * src/conflicts.h: Ditto.
3084 * src/output.c (token_actions): Use the new name.
3085 (output_conflicts): Change conflp => conflict_list_heads, and
3086 confl => conflict_list for better readability.
3087 * data/glr.c: Use the new names.
3088 * NEWS: Add self to GLR announcement.
3089
3090 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
3091
3092 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
3093 Akim Demaille.
3094
3095 * data/bison.glr: Change name to glr.c
3096 * data/glr.c: Renamed from bison.glr.
3097 * data/Makefile.am: Add glr.c
3098
3099 * src/getargs.c:
3100
3101 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
3102 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
3103
3104 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3105
3106 * data/bison.glr: Be sure to restore the
3107 current #line when returning to the skeleton contents after having
3108 exposed the input file's #line.
3109
3110 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3111
3112 * data/bison.glr: Bring up to date with changes to bison.simple.
3113
3114 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3115
3116 * data/bison.glr: Correct definitions that use b4_prefix.
3117 Various reformatting.
3118 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
3119 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
3120 yytokenp argument; now part of stack.
3121 (yychar): Define to behave as documented.
3122 (yyclearin): Ditto.
3123
3124 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3125
3126 * src/reader.h: Add declaration for free_merger_functions.
3127
3128 * src/reader.c (merge_functions): New variable.
3129 (get_merge_function): New function.
3130 (free_merger_functions): New function.
3131 (readgram): Check for %prec that is not followed by a symbol.
3132 Handle %dprec and %merge declarations.
3133 (packgram): Initialize dprec and merger fields in rules array.
3134
3135 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
3136 conflict_list_cnt, conflict_list_free): New variables.
3137 (table_grow): Also grow conflict_table.
3138 (prepare_rules): Output dprec and merger tables.
3139 (conflict_row): New function.
3140 (action_row): Output conflict lists for GLR parser. Don't use
3141 default reduction in conflicted states for GLR parser so that there
3142 are spaces for the conflict lists.
3143 (save_row): Also save conflict information.
3144 (token_actions): Allocate conflict list.
3145 (merger_output): New function.
3146 (pack_vector): Pack conflict table, too.
3147 (output_conflicts): New function to output yyconflp and yyconfl.
3148 (output_check): Allocate conflict_tos.
3149 (output_actions): Output conflict tables, also.
3150 (output_skeleton): Output b4_mergers definition.
3151 (prepare): Output b4_max_rhs_length definition.
3152 Use 'bison.glr' as default skeleton for GLR parsers.
3153
3154 * src/gram.c (glr_parser): New flag.
3155 (grammar_free): Call free_merger_functions.
3156
3157 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
3158 all pairs of conflicting reductions, rather than just all tokens
3159 causing conflicts. Needed to size conflict tables.
3160 (conflicts_output): Modify call to count_rr_conflicts for new
3161 interface.
3162 (conflicts_print): Ditto.
3163 (count_total_conflicts): New function.
3164
3165 * src/reader.h (merger_list): New type.
3166 (merge_functions): New variable.
3167
3168 * src/lex.h (tok_dprec, tok_merge): New token types.
3169
3170 * src/gram.h (rule_s): Add dprec and merger fields.
3171 (glr_parser): New flag.
3172
3173 * src/conflicts.h (count_total_conflicts): New function.
3174
3175 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
3176
3177 * doc/bison.texinfo (Generalized LR Parsing): New section.
3178 (GLR Parsers): New section.
3179 (Language and Grammar): Mention GLR parsing.
3180 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
3181 Correct typo ("tge" -> "the").
3182
3183 * data/bison.glr: New skeleton for GLR parsing.
3184
3185 * tests/cxx-gram.at: New tests for GLR parsing.
3186
3187 * tests/testsuite.at: Include cxx-gram.at.
3188
3189 * tests/Makefile.am: Add cxx-gram.at.
3190
3191 * src/parse-gram.y:
3192
3193 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
3194
3195 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
3196
31972002-06-27 Akim Demaille <akim@epita.fr>
3198
3199 * src/options.h, src/options.c: Remove.
3200 * src/getargs.c (short_options, long_options): New.
3201
32022002-06-27 Akim Demaille <akim@epita.fr>
3203
3204 * data/bison.simple, data/bison.c++: Rename as...
3205 * data/yacc.c, data/lalr1.cc: these.
3206 * doc/bison.texinfo (Environment Variables): Remove.
3207
32082002-06-25 Raja R Harinath <harinath@cs.umn.edu>
3209
3210 * src/getargs.c (report_argmatch): Initialize strtok().
3211
32122002-06-20 Akim Demaille <akim@epita.fr>
3213
3214 * data/bison.simple (b4_symbol_actions): New, replaces...
3215 (b4_symbol_destructor, b4_symbol_printer): these.
3216 (yysymprint): Be sure to call YYPRINT only for tokens, and using
3217 user token numbers.
3218
32192002-06-20 Akim Demaille <akim@epita.fr>
3220
3221 * data/bison.simple (yydestructor): Rename as...
3222 (yydestruct): this.
3223
32242002-06-20 Akim Demaille <akim@epita.fr>
3225
3226 * src/symtab.h, src/symtab.c (symbol_type_set)
3227 (symbol_destructor_set, symbol_precedence_set): The location is
3228 the last argument.
3229 Adjust all callers.
3230
32312002-06-20 Akim Demaille <akim@epita.fr>
3232
3233 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
3234 internals.
3235 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
3236 Takes a location.
3237 * src/symtab.h, src/symtab.c (symbol_class_set)
3238 (symbol_user_token_number_set): Likewise.
3239 Adjust all callers.
3240 Promote complain_at.
3241 * tests/input.at (Type Clashes): Adjust.
3242
32432002-06-20 Akim Demaille <akim@epita.fr>
3244
3245 * data/bison.simple (YYLEX): Fix the declaration when
3246 %pure-parser.
3247
32482002-06-20 Akim Demaille <akim@epita.fr>
3249
3250 * data/bison.simple (yysymprint): Don't print the token number,
3251 just its name.
3252 * tests/actions.at (Destructors): Rename as...
3253 (Printers and Destructors): this.
3254 Also exercise %printer.
3255
32562002-06-20 Akim Demaille <akim@epita.fr>
3257
3258 * data/bison.simple (YYDSYMPRINT): New.
3259 Use it to remove many of the #if YYDEBUG/if (yydebug).
3260
32612002-06-20 Akim Demaille <akim@epita.fr>
3262
3263 * src/symtab.h, src/symtab.c (symbol_t): printer and
3264 printer_location are new members.
3265 (symbol_printer_set): New.
3266 * src/parse-gram.y (PERCENT_PRINTER): New token.
3267 Handle its associated rule.
3268 * src/scan-gram.l: Adjust.
3269 (handle_destructor_at, handle_destructor_dollar): Rename as...
3270 (handle_symbol_code_at, handle_symbol_code_dollar): these.
3271 * src/output.c (symbol_printers_output): New.
3272 (output_skeleton): Call it.
3273 * data/bison.simple (yysymprint): New. Cannot be named yyprint
3274 since there are already many grammar files with a user `yyprint'.
3275 Replace the calls to YYPRINT to calls to yysymprint.
3276 * tests/calc.at: Adjust.
3277 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
3278 taking advantage of parser very internal details (stack size!).
3279
32802002-06-20 Akim Demaille <akim@epita.fr>
3281
3282 * src/scan-gram.l: Complete the scanner with the missing patterns
3283 to pacify Flex.
3284 Use `quote' and `symbol_tag_get' where appropriate.
3285
32862002-06-19 Akim Demaille <akim@epita.fr>
3287
3288 * tests/actions.at (Destructors): Augment to test locations.
3289 * data/bison.simple (yydestructor): Pass it the current location
3290 if locations are enabled.
3291 Prototype only when __STDC__ or C++.
3292 Change the argument names to move into the yy name space: there is
3293 user code here.
3294
32952002-06-19 Akim Demaille <akim@epita.fr>
3296
3297 * data/bison.simple (b4_pure_if): New.
3298 Use it instead of #ifdef YYPURE.
3299
33002002-06-19 Akim Demaille <akim@epita.fr>
3301
3302 * data/bison.simple (b4_location_if): New.
3303 Use it instead of #ifdef YYLSP_NEEDED.
3304
33052002-06-19 Akim Demaille <akim@epita.fr>
3306
3307 Prepare @$ in %destructor, but currently don't bind it in the
3308 skeleton, as %location use is not cleaned up yet.
3309
3310 * src/scan-gram.l (handle_dollar, handle_destructor_at)
3311 (handle_action_at): New.
3312 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
3313 a braced_code_t and a location as additional arguments.
3314 (handle_destructor_dollar): Instead of requiring `b4_eval', just
3315 unquote one when outputting `b4_dollar_dollar'.
3316 Adjust callers.
3317 * data/bison.simple (b4_eval): Remove.
3318 (b4_symbol_destructor): Adjust.
3319 * tests/input.at (Invalid @n): Adjust.
3320
33212002-06-19 Zack Weinberg <zack@codesourcery.com>
3322
3323 * doc/bison.texinfo: Document ability to have multiple
3324 prologue sections.
3325
33262002-06-18 Akim Demaille <akim@epita.fr>
3327
3328 * src/files.c (compute_base_names): When computing the output file
3329 names from the input file name, strip the directory part.
3330
33312002-06-18 Akim Demaille <akim@epita.fr>
3332
3333 * data/bison.simple.new: Comment changes.
3334 Reported by Andreas Schwab.
3335
33362002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
3337
3338 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
3339 there are no `label `yyoverflowlab' defined but not used' warnings
3340 when yyoverflow is defined.
3341
33422002-06-18 Akim Demaille <akim@epita.fr>
3343
3344 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
3345 new member.
3346 (symbol_destructor_set): Adjust.
3347 * src/output.c (symbol_destructors_output): Output the destructor
3348 locations.
3349 Output the symbol name.
3350 * data/bison.simple (b4_symbol_destructor): Adjust.
3351
33522002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
3353 and Akim Demaille <akim@epita.fr>
3354
3355 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
3356 what's left on the stack when the error recovery hits EOF.
3357 * tests/actions.at (Destructors): Complete to exercise this case.
3358
33592002-06-17 Akim Demaille <akim@epita.fr>
3360
3361 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
3362 arguments is really empty, not only equal to `[]'.
3363 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
3364 member.
3365 (symbol_destructor_set): New.
3366 * src/output.c (symbol_destructors_output): New.
3367 * src/reader.h (brace_code_t, current_braced_code): New.
3368 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
3369 (handle_dollar): Rename as...
3370 (handle_action_dollar): this.
3371 (handle_destructor_dollar): New.
3372 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
3373 (grammar_declaration): Use it.
3374 * data/bison.simple (yystos): Is always defined.
3375 (yydestructor): New.
3376 * tests/actions.at (Destructors): New.
3377 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
3378
33792002-06-17 Akim Demaille <akim@epita.fr>
3380
3381 * src/symlist.h, src/symlist.c (symbol_list_length): New.
3382 * src/scan-gram.l (handle_dollar, handle_at): Compute the
3383 rule_length only when needed.
3384 * src/output.c (actions_output, token_definitions_output): Output
3385 the full M4 block.
3386 * src/symtab.c: Don't access directly to the symbol tag, use
3387 symbol_tag_get.
3388 * src/parse-gram.y: Use symbol_list_free.
3389
33902002-06-17 Akim Demaille <akim@epita.fr>
3391
3392 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
3393 (symbol_list_prepend, get_type_name): Move to...
3394 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
3395 (symbol_list_prepend, symbol_list_n_type_name_get): here.
3396 Adjust all callers.
3397 (symbol_list_free): New.
3398 * src/scan-gram.l (handle_dollar): Takes a location.
3399 * tests/input.at (Invalid $n): Adjust.
3400
34012002-06-17 Akim Demaille <akim@epita.fr>
3402
3403 * src/reader.h, src/reader.c (symbol_list_new): Export it.
3404 (symbol_list_prepend): New.
3405 * src/parse-gram.y (%union): `list' is a new member.
3406 (symbols.1): New, replaces...
3407 (terms_to_prec.1, nterms_to_type.1): these.
3408 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
3409 Take a location as additional argument.
3410 Adjust all callers.
3411
34122002-06-15 Akim Demaille <akim@epita.fr>
3413
3414 * src/parse-gram.y: Move %token in the declaration section so that
3415 we don't depend upon CVS Bison.
3416
34172002-06-15 Akim Demaille <akim@epita.fr>
3418
3419 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
3420 * src/print.c (print_core): Use it.
3421
34222002-06-15 Akim Demaille <akim@epita.fr>
3423
3424 * src/conflicts.c (log_resolution): Accept the rule involved in
3425 the sr conflicts instead of the lookahead number that points to
3426 that rule.
3427 (flush_reduce): Accept the current lookahead vector as argument,
3428 instead of the index in LA.
3429 (resolve_sr_conflict): Accept the current number of lookahead
3430 bitset to consider for the STATE, instead of the index in LA.
3431 (set_conflicts): Adjust.
3432 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
3433
34342002-06-15 Akim Demaille <akim@epita.fr>
3435
3436 * src/state.h (state_t): Replace the `lookaheadsp' member, a
3437 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
3438 Adjust all dependencies.
3439 * src/lalr.c (initialize_lookaheads): Split into...
3440 (states_lookaheads_count, states_lookaheads_initialize): these.
3441 (lalr): Adjust.
3442
34432002-06-15 Akim Demaille <akim@epita.fr>
3444
3445 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
3446 out of...
3447 (grammar_rules_print): here.
3448 * src/reduce.c (reduce_output): Use it.
3449 * tests/reduce.at (Useless Rules, Reduced Automaton)
3450 (Underivable Rules): Adjust.
3451
34522002-06-15 Akim Demaille <akim@epita.fr>
3453
3454 Copy BYacc's nice way to report the grammar.
3455
3456 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
3457 New.
3458 Don't print the rules' location, it is confusing and useless.
3459 (rule_print): Use grammar_rhs_print.
3460 * src/print.c (print_grammar): Use grammar_rules_print.
3461
34622002-06-15 Akim Demaille <akim@epita.fr>
3463
3464 Complete and rationalize `useless thing' warnings.
3465
3466 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
3467 (symbol_tag_print): New.
3468 Use them everywhere in place of accessing directly the tag member.
3469 * src/gram.h, src/gram.c (rule_print): New.
3470 Use it where a rule used to be printed `by hand'.
3471 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
3472 (reduce_grammar_tables): Report the useless rules.
3473 (reduce_print): Useless things are a warning, not an error.
3474 Report it as such.
3475 * tests/reduce.at (Useless Nonterminals, Useless Rules):
3476 (Reduced Automaton, Underivable Rules): Adjust.
3477 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
3478 * tests/conflicts.at (Unresolved SR Conflicts)
3479 (Solved SR Conflicts): Adjust.
3480
34812002-06-15 Akim Demaille <akim@epita.fr>
3482
3483 Let symbols have a location.
3484
3485 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
3486 (getsym): Adjust.
3487 Adjust all callers.
3488 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
3489 Use location_t, not int.
3490 * src/symtab.c (symbol_check_defined): Take advantage of the
3491 location.
3492 * tests/regression.at (Invalid inputs): Adjust.
3493
34942002-06-15 Akim Demaille <akim@epita.fr>
3495
3496 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3497 (input): Don't try to initialize yylloc here, do it in the
3498 scanner.
3499 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3500 * src/gram.h (rule_t): Change line and action_line into location
3501 and action_location, of location_t type.
3502 Adjust all dependencies.
3503 * src/location.h, src/location.c (empty_location): New.
3504 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3505 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3506 (grammar_current_rule_symbol_append)
3507 (grammar_current_rule_action_append): Expect a location as argument.
3508 * src/reader.c (grammar_midrule_action): Adjust to attach an
3509 action's location as dummy symbol location.
3510 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3511 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3512 the line numbers.
3513
35142002-06-14 Akim Demaille <akim@epita.fr>
3515
3516 Grammar declarations may be found in the grammar section.
3517
3518 * src/parse-gram.y (rules_or_grammar_declaration): New.
3519 (declarations): Each declaration may end with a semicolon, not
3520 just...
3521 (grammar_declaration): `"%union"'.
3522 (grammar): Branch to rules_or_grammar_declaration.
3523
35242002-06-14 Akim Demaille <akim@epita.fr>
3525
3526 * src/main.c (main): Invoke scanner_free.
3527
35282002-06-14 Akim Demaille <akim@epita.fr>
3529
3530 * src/output.c (m4_invoke): Extracted from...
3531 (output_skeleton): here.
3532 Free tempfile.
3533
35342002-06-14 Akim Demaille <akim@epita.fr>
3535
3536 * src/parse-gram.y (directives, directive, gram)
3537 (grammar_directives, precedence_directives, precedence_directive):
3538 Rename as...
3539 (declarations, declaration, grammar, grammar_declaration)
3540 (precedence_declaration, precedence_declarator): these.
3541 (symbol_declaration): New.
3542
35432002-06-14 Akim Demaille <akim@epita.fr>
3544
3545 * src/files.c (action_obstack): Remove, unused.
3546 (output_obstack): Remove it, and all its dependencies, as it is no
3547 longer needed.
3548 * src/reader.c (epilogue_set): Build the epilogue in the
3549 muscle_obstack.
3550 * src/output.h, src/output.c (muscle_obstack): Move to...
3551 * src/muscle_tab.h, src/muscle_tab.h: here.
3552 (muscle_init): Initialize muscle_obstack.
3553 (muscle_free): New.
3554 * src/main.c (main): Call it.
3555
35562002-06-14 Akim Demaille <akim@epita.fr>
3557
3558 * src/location.h: New, extracted from...
3559 * src/reader.h: here.
3560 * src/Makefile.am (noinst_HEADERS): Merge into
3561 (bison_SOURCES): this.
3562 Add location.h.
3563 * src/parse-gram.y: Use location_t instead of Bison's.
3564 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3565 Use location_t instead of ints.
3566
35672002-06-14 Akim Demaille <akim@epita.fr>
3568
3569 * data/bison.simple, data/bison.c++: Be sure to restore the
3570 current #line when returning to the skeleton contents after having
3571 exposed the input file's #line.
3572
35732002-06-12 Akim Demaille <akim@epita.fr>
3574
3575 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3576 eager.
3577 * tests/actions.at (Exotic Dollars): New.
3578
35792002-06-12 Akim Demaille <akim@epita.fr>
3580
3581 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3582 ['"/] too eagerly.
3583 * tests/input.at (Torturing the Scanner): New.
3584
35852002-06-11 Akim Demaille <akim@epita.fr>
3586
3587 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3588 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3589 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3590 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3591 * src/reader.c (reader): Use it.
3592
35932002-06-11 Akim Demaille <akim@epita.fr>
3594
3595 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3596 Adjust all callers.
3597 (scanner_last_string_free): New.
3598
35992002-06-11 Akim Demaille <akim@epita.fr>
3600
3601 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3602 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3603 (last_string, YY_OBS_FREE): New.
3604 Use them when returning an ID.
3605
36062002-06-11 Akim Demaille <akim@epita.fr>
3607
3608 Have Bison grammars parsed by a Bison grammar.
3609
3610 * src/reader.c, src/reader.h (prologue_augment): New.
3611 * src/reader.c (copy_definition): Remove.
3612
3613 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3614 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3615 (grammar_current_rule_prec_set, grammar_current_rule_check)
3616 (grammar_current_rule_symbol_append)
3617 (grammar_current_rule_action_append): Export.
3618 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3619 (symbol_list_action_append): Remove.
3620 Hook the routines from reader.
3621 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3622 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3623
3624 * src/reader.c (read_declarations): Remove, unused.
3625
3626 * src/parse-gram.y: Handle the epilogue.
3627 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3628 (grammar_start_symbol_set): this.
3629 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3630 * src/reader.c (readgram): Remove, unused.
3631 (reader): Adjust to insert eoftoken and axiom where appropriate.
3632
3633 * src/reader.c (copy_dollar): Replace with...
3634 * src/scan-gram.h (handle_dollar): this.
3635 * src/parse-gram.y: Remove `%thong'.
3636
3637 * src/reader.c (copy_at): Replace with...
3638 * src/scan-gram.h (handle_at): this.
3639
3640 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3641 New.
3642
3643 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3644 time being.
3645
3646 * src/reader.h, src/reader.c (grammar_rule_end): New.
3647
3648 * src/parse.y (current_type, current_class): New.
3649 Implement `%nterm', `%token' support.
3650 Merge `%term' into `%token'.
3651 (string_as_id): New.
3652 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3653 type name.
3654
3655 * src/parse-gram.y: Be sure to handle properly the beginning of
3656 rules.
3657
3658 * src/parse-gram.y: Handle %type.
3659 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3660
3661 * src/parse-gram.y: More directives support.
3662 * src/options.c: No longer handle source directives.
3663
3664 * src/parse-gram.y: Fix %output.
3665
3666 * src/parse-gram.y: Handle %union.
3667 Use the prologue locations.
3668 * src/reader.c (parse_union_decl): Remove.
3669
3670 * src/reader.h, src/reader.c (epilogue_set): New.
3671 * src/parse-gram.y: Use it.
3672
3673 * data/bison.simple, data/bison.c++: b4_stype is now either not
3674 defined, then default to int, or to the contents of %union,
3675 without `union' itself.
3676 Adjust.
3677 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3678
3679 * src/output.c (actions_output): Don't output braces, as they are
3680 already handled by the scanner.
3681
3682 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3683 characters to themselves.
3684
3685 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3686 that the epilogue has a proper #line.
3687
3688 * src/parse-gram.y: Handle precedence/associativity.
3689
3690 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3691 a terminal.
3692 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3693 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3694 at all to define terminals that cannot be emitted.
3695
3696 * src/scan-gram.l: Escape M4 characters.
3697
3698 * src/scan-gram.l: Working properly with escapes in user
3699 strings/characters.
3700
3701 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3702 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3703 grammar.
3704 Use more modest sizes, as for the time being the parser does not
3705 release memory, and therefore the process swallows a huge amount
3706 of memory.
3707
3708 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3709 stricter %token grammar.
3710
3711 * src/symtab.h (associativity): Add `undef_assoc'.
3712 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3713 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3714
3715 * tests/regression.at (Invalid %directive): Remove, as it is now
3716 meaningless.
3717 (Invalid inputs): Adjust to the new error messages.
3718 (Token definitions): The new grammar doesn't allow too many
3719 eccentricities.
3720
3721 * src/lex.h, src/lex.c: Remove.
3722 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3723 (copy_character, copy_string2, copy_string, copy_identifier)
3724 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3725 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3726 (parse_action): Remove.
3727 * po/POTFILES.in: Adjust.
3728
37292002-06-11 Akim Demaille <akim@epita.fr>
3730
3731 * src/reader.c (parse_action): Don't store directly into the
3732 rule's action member: return the action as a string.
3733 Don't require `rule_length' as an argument: compute it.
3734 (grammar_current_rule_symbol_append)
3735 (grammar_current_rule_action_append): New, eved out from
3736 (readgram): here.
3737 Remove `action_flag', `rulelength', unused now.
3738
37392002-06-11 Akim Demaille <akim@epita.fr>
3740
3741 * src/reader.c (grammar_current_rule_prec_set).
3742 (grammar_current_rule_check): New, eved out from...
3743 (readgram): here.
3744 Remove `xaction', `first_rhs': useless.
3745 * tests/input.at (Type clashes): New.
3746 * tests/existing.at (GNU Cim Grammar): Adjust.
3747
37482002-06-11 Akim Demaille <akim@epita.fr>
3749
3750 * src/reader.c (grammar_midrule_action): New, Eved out from
3751 (readgram): here.
3752
37532002-06-11 Akim Demaille <akim@epita.fr>
3754
3755 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3756 New.
3757 (readgram): Use them as replacement of inlined code, crule and
3758 crule1.
3759
37602002-06-11 Akim Demaille <akim@epita.fr>
3761
3762 * src/reader.c (grammar_end, grammar_symbol_append): New.
3763 (readgram): Use them.
3764 Make the use of `p' as local as possible.
3765
37662002-06-10 Akim Demaille <akim@epita.fr>
3767
3768 GCJ's parser requires the tokens to be defined before the prologue.
3769
3770 * data/bison.simple: Output the token definition before the user's
3771 prologue.
3772 * tests/regression.at (Braces parsing, Duplicate string)
3773 (Mixing %token styles): Check the output from bison.
3774 (Early token definitions): New.
3775
37762002-06-10 Akim Demaille <akim@epita.fr>
3777
3778 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3779 assigning twice the same user number to a token, so that we can
3780 use it in...
3781 * src/lex.c (lex): here.
3782 Also use `symbol_class_set' instead of hand written code.
3783 * src/reader.c (parse_assoc_decl): Likewise.
3784
37852002-06-10 Akim Demaille <akim@epita.fr>
3786
3787 * src/symtab.c, src/symtab.c (symbol_class_set)
3788 (symbol_user_token_number_set): New.
3789 * src/reader.c (parse_token_decl): Use them.
3790 Use a switch instead of ifs.
3791 Use a single argument.
3792
37932002-06-10 Akim Demaille <akim@epita.fr>
3794
3795 Remove `%thong' support as it is undocumented, unused, duplicates
3796 `%token's job, and creates useless e-mail traffic with people who
3797 want to know what it is, why it is undocumented, unused, and
3798 duplicates `%token's job.
3799
3800 * src/reader.c (parse_thong_decl): Remove.
3801 * src/options.c (option_table): Remove "thong".
3802 * src/lex.h (tok_thong): Remove.
3803
38042002-06-10 Akim Demaille <akim@epita.fr>
3805
3806 * src/symtab.c, src/symtab.c (symbol_type_set)
3807 (symbol_precedence_set): New.
3808 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3809 (value_components_used): Remove, unused.
3810
38112002-06-09 Akim Demaille <akim@epita.fr>
3812
3813 Move symbols handling code out of the reader.
3814
3815 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3816 (axiom): Move to...
3817 * src/symtab.h, src/symtab.c: here.
3818
3819 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3820 * src/reader.c (startval): Rename as...
3821 * src/symtab.h, src/symtab.c (startsymbol): this.
3822 * src/reader.c: Adjust.
3823
3824 * src/reader.c (symbol_check_defined, symbol_make_alias)
3825 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3826 (token_translations_init)
3827 Move to...
3828 * src/symtab.c: here.
3829 * src/reader.c (packsymbols): Move to...
3830 * src/symtab.h, src/symtab.c (symbols_pack): here.
3831 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3832 argument.
3833
38342002-06-03 Akim Demaille <akim@epita.fr>
3835
3836 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3837 then statements.
3838
38392002-06-03 Akim Demaille <akim@epita.fr>
3840
3841 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3842 structs with non literals.
3843 * src/scan-skel.l: never-interactive.
3844 * src/conflicts.c (enum conflict_resolution_e): No trailing
3845 comma.
3846 * src/getargs.c (usage): Split long literal strings.
3847 Reported by Hans Aberg.
3848
38492002-05-28 Akim Demaille <akim@epita.fr>
3850
3851 * data/bison.c++: Use C++ ostreams.
3852 (cdebug_): New member.
3853
38542002-05-28 Akim Demaille <akim@epita.fr>
3855
3856 * src/output.c (output_skeleton): Be sure to allocate enough room
3857 for `/' _and_ for `\0' in full_skeleton.
3858
38592002-05-28 Akim Demaille <akim@epita.fr>
3860
3861 * data/bison.c++: Catch up with bison.simple:
3862 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3863 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3864 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3865 and popping traces.
3866
38672002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3868
3869 * src/output.c (output_skeleton): Put an explicit path in front of
3870 the skeleton file name, rather than relying on the -I directory,
3871 to partially alleviate effects of having a skeleton file lying around
3872 in the current directory.
3873
38742002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3875
3876 * src/conflicts.c (log_resolution): Correct typo:
3877 obstack_printf should be obstack_fgrow1.
3878
38792002-05-26 Akim Demaille <akim@epita.fr>
3880
3881 * src/state.h (state_t): `solved_conflicts' is a new member.
3882 * src/LR0.c (new_state): Set it to 0.
3883 * src/conflicts.h, src/conflicts.c (print_conflicts)
3884 (free_conflicts, solve_conflicts): Rename as...
3885 (conflicts_print, conflicts_free, conflicts_solve): these.
3886 Adjust callers.
3887 * src/conflicts.c (enum conflict_resolution_e)
3888 (solved_conflicts_obstack): New, used by...
3889 (log_resolution): this.
3890 Adjust to attach the conflict resolution to each state.
3891 Complete the description with the precedence/associativity
3892 information.
3893 (resolve_sr_conflict): Adjust.
3894 * src/print.c (print_state): Output its solved_conflicts.
3895 * tests/conflicts.at (Unresolved SR Conflicts)
3896 (Solved SR Conflicts): Exercise --report=all.
3897
38982002-05-26 Akim Demaille <akim@epita.fr>
3899
3900 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3901 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3902 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
3903 (token_number_t, item_number_as_token_number)
3904 (token_number_as_item_number, muscle_insert_token_number_table):
3905 Rename as...
3906 (symbol_number_t, item_number_as_symbol_number)
3907 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
3908 these, since it is more appropriate.
3909
39102002-05-26 Akim Demaille <akim@epita.fr>
3911
3912 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
3913 `Error:' lines.
3914 * data/bison.simple (yystos) [YYDEBUG]: New.
3915 (yyparse) [YYDEBUG]: Display the symbols which are popped during
3916 error recovery.
3917 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
3918
39192002-05-25 Akim Demaille <akim@epita.fr>
3920
3921 * doc/bison.texinfo (Debugging): Split into...
3922 (Tracing): this new section, its former contents, and...
3923 (Understanding): this new section.
3924 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
3925 by...
3926 (report_flag): this.
3927 Adjust all dependencies.
3928 (report_args, report_types, report_argmatch): New.
3929 (usage, getargs): Report/support -r, --report.
3930 * src/options.h
3931 (struct option_table_struct): Rename as..,
3932 (struct option_table_s): this.
3933 Rename the `set_flag' member to `flag' to match with getopt_long's
3934 struct.
3935 * src/options.c (option_table): Split verbose into an entry for
3936 %verbose, and another for --verbose.
3937 Support --report/-r, so remove -r from the obsolete --raw.
3938 * src/print.c: Attach full item sets and lookaheads reports to
3939 report_flag instead of trace_flag.
3940 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
3941
39422002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3943 and Paul Eggert <eggert@twinsun.com>
3944
3945 * data/bison.simple (yyparse): Correct error handling to conform to
3946 POSIX and yacc. Specifically, after syntax error is discovered,
3947 do not reduce further before shifting the error token.
3948 Clean up the code a bit by removing the labels yyerrdefault,
3949 yyerrhandle, yyerrpop.
3950 * NEWS: Document the above.
3951
39522002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3953
3954 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
3955 type; it isn't always big enough, since it doesn't necessarily
3956 include non-terminals.
3957 (yytranslate): Expand definition of yy_token_number_type, so that
3958 the latter can be removed.
3959 (yy_token_number_type): Remove, only one use.
3960 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
3961 don't use TokenNumberType as element type.
3962
3963 * tests/regression.at: Modify expected output to agree with change
3964 to yyr1 and yytranslate.
3965
39662002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
3967
3968 * src/reader.c (parse_action): Use copy_character instead of
3969 obstack_1grow.
3970
39712002-05-13 Akim Demaille <akim@epita.fr>
3972
3973 * tests/regression.at (Token definitions): Prototype yylex and
3974 yyerror.
3975
39762002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3977
3978 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
3979 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
3980 32-bit arithmetic.
3981 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
3982
39832002-05-07 Akim Demaille <akim@epita.fr>
3984
3985 * tests/synclines.at: Be sure to prototype yylex and yyerror to
3986 avoid GCC warnings.
3987
39882002-05-07 Akim Demaille <akim@epita.fr>
3989
3990 Kill GCC warnings.
3991
3992 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
3993 over the RHS of each rule.
3994 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
3995 * src/state.h (state_t): Member `nitems' is unsigned short.
3996 * src/LR0.c (get_state): Adjust.
3997 * src/reader.c (packgram): Likewise.
3998 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
3999 `Type'.
4000 (muscle_insert_int_table): Remove, unused.
4001 (prepare_rules): Remove `max'.
4002
40032002-05-06 Akim Demaille <akim@epita.fr>
4004
4005 * src/closure.c (print_firsts): Display of the symbol tags.
4006 (bitmatrix_print): Move to...
4007 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
4008 here.
4009 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
4010
40112002-05-06 Akim Demaille <akim@epita.fr>
4012
4013 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
4014 hash_do_for_each.
4015
40162002-05-06 Akim Demaille <akim@epita.fr>
4017
4018 * src/LR0.c (new_state, get_state): Instead of using the global
4019 `kernel_size' and `kernel_base', have two new arguments:
4020 `core_size' and `core'.
4021 Adjust callers.
4022
40232002-05-06 Akim Demaille <akim@epita.fr>
4024
4025 * src/reader.c (packgram): No longer end `ritem' with a 0
4026 sentinel: it is not used.
4027
40282002-05-05 Akim Demaille <akim@epita.fr>
4029
4030 New experimental feature: display the lookaheads in the report and
4031 graph.
4032
4033 * src/print (print_core): When --trace-flag, display the rules
4034 lookaheads.
4035 * src/print_graph.c (print_core): Likewise.
4036 Swap the arguments.
4037 Adjust caller.
4038
40392002-05-05 Akim Demaille <akim@epita.fr>
4040
4041 * tests/torture.at (Many lookaheads): New test.
4042
40432002-05-05 Akim Demaille <akim@epita.fr>
4044
4045 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
4046 (GENERATE_MUSCLE_INSERT_TABLE): this.
4047 (output_int_table, output_unsigned_int_table, output_short_table)
4048 (output_token_number_table, output_item_number_table): Replace with...
4049 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
4050 (muscle_insert_short_table, muscle_insert_token_number_table)
4051 (muscle_insert_item_number_table): these.
4052 Adjust all callers.
4053 (prepare_tokens): Don't free `translations', since...
4054 * src/reader.h, src/reader.c (grammar_free): do it.
4055 Move to...
4056 * src/gram.h, src/gram.c (grammar_free): here.
4057 * data/bison.simple, data/bison.c++: b4_token_number_max is now
4058 b4_translate_max.
4059
40602002-05-05 Akim Demaille <akim@epita.fr>
4061
4062 * src/output.c (output_unsigned_int_table): New.
4063 (prepare_rules): `i' is unsigned.
4064 `prhs', `rline', `r2' are unsigned int.
4065 Rename muscle `rhs_number_max' as `rhs_max'.
4066 Output muscles `prhs_max', `rline_max', and `r2_max'.
4067 Free rline and r1.
4068 * data/bison.simple, data/bison.c++: Adjust to use these muscles
4069 to compute types instead of constant types.
4070 * tests/regression.at (Web2c Actions): Adjust.
4071
40722002-05-04 Akim Demaille <akim@epita.fr>
4073
4074 * src/symtab.h (SALIAS, SUNDEF): Rename as...
4075 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
4076 Adjust dependencies.
4077 * src/output.c (token_definitions_output): Be sure not to output a
4078 `#define 'a'' when fed with `%token 'a' "a"'.
4079 * tests/regression.at (Token definitions): New.
4080
40812002-05-03 Paul Eggert <eggert@twinsun.com>
4082
4083 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
4084 for K&R C.
4085
40862002-05-03 gettextize <bug-gnu-gettext@gnu.org>
4087
4088 * Makefile.am (SUBDIRS): Remove intl.
4089 (EXTRA_DIST): Add config/config.rpath.
4090
40912002-05-03 Akim Demaille <akim@epita.fr>
4092
4093 * data/bison.simple (m4_if): Don't output empty enums.
4094 And actually, output valid enum definitions :(.
4095
40962002-05-03 Akim Demaille <akim@epita.fr>
4097
4098 * configure.bat: Remove, completely obsolete.
4099 * Makefile.am (EXTRA_DIST): Adjust.
4100 Don't distribute config.rpath...
4101 * config/Makefile.am (EXTRA_DIST): Do it.
4102
41032002-05-03 Akim Demaille <akim@epita.fr>
4104
4105 * configure.in (GETTEXT_VERSION): New.
4106 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
4107
41082002-05-03 Akim Demaille <akim@epita.fr>
4109
4110 * data/bison.simple (b4_token_enum): New.
4111 (b4_token_defines): Use it to output tokens both as #define and
4112 enums.
4113 Suggested by Paul Eggert.
4114 * src/output.c (token_definitions_output): Don't output spurious
4115 white spaces.
4116
41172002-05-03 Akim Demaille <akim@epita.fr>
4118
4119 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4120
41212002-05-02 Robert Anisko <robert@lrde.epita.fr>
4122
4123 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
4124 Update the stack class, give a try to deque as the default container.
4125
41262002-05-02 Akim Demaille <akim@epita.fr>
4127
4128 * data/bison.simple (yyparse): Do not implement @$ = @1.
4129 (YYLLOC_DEFAULT): Adjust to do it.
4130 * doc/bison.texinfo (Location Default Action): Fix.
4131
41322002-05-02 Akim Demaille <akim@epita.fr>
4133
4134 * src/reader.c (parse_braces): Merge into...
4135 (parse_action): this.
4136
41372002-05-02 Akim Demaille <akim@epita.fr>
4138
4139 * configure.in (ALL_LINGUAS): Remove.
4140 * po/LINGUAS, hr.po: New.
4141
41422002-05-02 Akim Demaille <akim@epita.fr>
4143
4144 Remove the so called hairy (semantic) parsers.
4145
4146 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
4147 * src/gram.h, src/gram.c (semantic_parser): Remove.
4148 (rule_t): Remove the guard and guard_line members.
4149 * src/lex.h (token_t): remove tok_guard.
4150 * src/options.c (option_table): Remove %guard and %semantic_parser
4151 support.
4152 * src/output.c, src/output.h (guards_output): Remove.
4153 (prepare): Adjust.
4154 (token_definitions_output): Don't output the `T'
4155 tokens (???).
4156 (output_skeleton): Don't output the guards.
4157 * src/files.c, src/files.c (attrsfile): Remove.
4158 * src/reader.c (symbol_list): Remove the guard and guard_line
4159 members.
4160 Adjust dependencies.
4161 (parse_guard): Remove.
4162 * data/bison.hairy: Remove.
4163 * doc/bison.texinfo (Environment Variables): Remove occurrences of
4164 BISON_HAIRY.
4165
41662002-05-02 Akim Demaille <akim@epita.fr>
4167
4168 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
4169 (parse_guard): Rename the formal argument `stack_offset' as
4170 `rule_length', which is more readable.
4171 Adjust callers.
4172 (copy_at, copy_dollar): Instead of outputting the hard coded
4173 values of $$, $n and so forth, output invocation to b4_lhs_value,
4174 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
4175 Note: this patch partially drops `semantic-parser' support: it
4176 always does `rule_length - n', where semantic parsers ought to
4177 always use `-n'.
4178 * data/bison.simple, data/bison.c++ (b4_lhs_value)
4179 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
4180
41812002-05-02 Akim Demaille <akim@epita.fr>
4182
4183 * configure.in (AC_INIT): Bump to 1.49b.
4184 (AM_INIT_AUTOMAKE): Short invocation.
4185
41862002-05-02 Akim Demaille <akim@epita.fr>
4187
4188 Version 1.49a.
4189
41902002-05-01 Akim Demaille <akim@epita.fr>
4191
4192 * src/skeleton.h: Remove.
4193
41942002-05-01 Akim Demaille <akim@epita.fr>
4195
4196 * src/skeleton.h: Fix the #endif.
4197 Reported by Magnus Fromreide.
4198
41992002-04-26 Paul Eggert <eggert@twinsun.com>
4200
4201 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
4202 Define if we define YYSTYPE and YYLTYPE, respectively.
4203 (YYCOPY): Fix [] quoting problem in the non-GCC case.
4204
42052002-04-25 Robert Anisko <robert@lrde.epita.fr>
4206
4207 * src/scan-skel.l: Postprocess quadrigraphs.
4208
4209 * src/reader.c (copy_character): New function, used to output
4210 single characters while replacing `[' and `]' with quadrigraphs, to
4211 avoid troubles with M4 quotes.
4212 (copy_comment): Output characters with copy_character.
4213 (read_additionnal_code): Likewise.
4214 (copy_string2): Likewise.
4215 (copy_definition): Likewise.
4216
4217 * tests/calc.at: Exercise M4 quoting.
4218
42192002-04-25 Akim Demaille <akim@epita.fr>
4220
4221 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
4222 between `!' and the command.
4223 Reported by Paul Eggert.
4224
42252002-04-24 Robert Anisko <robert@lrde.epita.fr>
4226
4227 * tests/calc.at: Exercise prologue splitting.
4228
4229 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
4230 `b4_post_prologue' instead of `b4_prologue'.
4231
4232 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
4233 muscles.
4234 (output): Free pre_prologue_obstack and post_prologue_obstack.
4235 * src/files.h, src/files.c (attrs_obstack): Remove.
4236 (pre_prologue_obstack, post_prologue_obstack): New.
4237 * src/reader.c (copy_definition): Add a parameter to specify the
4238 obstack to fill, instead of using attrs_obstack unconditionally.
4239 (read_declarations): Pass pre_prologue_obstack to copy_definition if
4240 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
4241
42422002-04-23 Paul Eggert <eggert@twinsun.com>
4243
4244 * data/bison.simple: Remove unnecessary commentary and white
4245 space differences from 1_29-branch.
4246 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
4247
4248 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
4249 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
4250 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
4251 constructors or destructors.
4252
4253 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
4254
42552002-04-23 Akim Demaille <akim@epita.fr>
4256
4257 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
4258 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
4259 location with columns.
4260 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
4261 All reported by Paul Eggert.
4262
42632002-04-22 Akim Demaille <akim@epita.fr>
4264
4265 * src/reduce.c (dump_grammar): Move to...
4266 * src/gram.h, src/gram.c (grammar_dump): here.
4267 Be sure to separate long item numbers.
4268 Don't read the members of a rule's prec if its nil.
4269
42702002-04-22 Akim Demaille <akim@epita.fr>
4271
4272 * src/output.c (table_size, table_grow): New.
4273 (MAXTABLE): Remove, replace uses with table_size.
4274 (pack_vector): Instead of dying when the table is too big, grow it.
4275
42762002-04-22 Akim Demaille <akim@epita.fr>
4277
4278 * data/bison.simple (yyr1): Its type is that of a token number.
4279 * data/bison.c++ (r1_): Likewise.
4280 * tests/regression.at (Web2c Actions): Adjust.
4281
42822002-04-22 Akim Demaille <akim@epita.fr>
4283
4284 * src/reader.c (token_translations_init): 256 is now the default
4285 value for the error token, i.e., it will be assigned another
4286 number if the user assigned 256 to one of her tokens.
4287 (reader): Don't force 256 to error.
4288 * doc/bison.texinfo (Symbols): Adjust.
4289 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
4290 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
4291 etc. instead of 10, 20, 30 (which was used to `jump' over error
4292 (256) and undefined (2)).
4293
42942002-04-22 Akim Demaille <akim@epita.fr>
4295
4296 Propagate more token_number_t.
4297
4298 * src/gram.h (token_number_as_item_number)
4299 (item_number_as_token_number): New.
4300 * src/output.c (GENERATE_OUTPUT_TABLE): New.
4301 Use it to create output_item_number_table and
4302 output_token_number_table.
4303 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4304 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
4305 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
4306 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
4307
43082002-04-22 Akim Demaille <akim@epita.fr>
4309
4310 * src/output.h, src/output.c (get_lines_number): Remove.
4311
43122002-04-19 Akim Demaille <akim@epita.fr>
4313
4314 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
4315 as Lex/Flex'.
4316 (Debugging): More details about enabling the debugging features.
4317 (Table of Symbols): Describe $$, $n, @$, and @n.
4318 Suggested by Tim Josling.
4319
43202002-04-19 Akim Demaille <akim@epita.fr>
4321
4322 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
4323
43242002-04-10 Akim Demaille <akim@epita.fr>
4325
4326 * src/system.h: Rely on HAVE_LIMITS_H.
4327 Suggested by Paul Eggert.
4328
43292002-04-09 Akim Demaille <akim@epita.fr>
4330
4331 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
4332 full stderr, and strip it according to the bison options, instead
4333 of composing the error message from different bits.
4334 This makes it easier to check for several error messages.
4335 Adjust all the invocations.
4336 Add an invocation exercising the error token.
4337 Add an invocation demonstrating a stupid error message.
4338 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
4339 Adjust the tests.
4340 Error message are for stderr, not stdout.
4341
43422002-04-09 Akim Demaille <akim@epita.fr>
4343
4344 * src/gram.h, src/gram.c (error_token_number): Remove, use
4345 errtoken->number.
4346 * src/reader.c (reader): Don't specify the user token number (2)
4347 for $undefined, as it uselessly prevents using it.
4348 * src/gram.h (token_number_t): Move to...
4349 * src/symtab.h: here.
4350 (state_t.number): Is a token_number_t.
4351 * src/print.c, src/reader.c: Use undeftoken->number instead of
4352 hard coded 2.
4353 (Even though this 2 is not the same as above: the number of the
4354 undeftoken remains being 2, it is its user token number which
4355 might not be 2).
4356 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
4357 `user_token_number_max'.
4358 Output `undef_token_number'.
4359 * data/bison.simple, data/bison.c++: Use them.
4360 Be sure to map invalid yylex return values to
4361 `undef_token_number'. This saves us from gratuitous SEGV.
4362
4363 * tests/conflicts.at (Solved SR Conflicts)
4364 (Unresolved SR Conflicts): Adjust.
4365 * tests/regression.at (Web2c Actions): Adjust.
4366
43672002-04-08 Akim Demaille <akim@epita.fr>
4368
4369 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
4370 Adding #line.
4371 Remove the duplicate `typedefs'.
4372 (RhsNumberType): Fix the declaration and various other typos.
4373 Use __ofile__.
4374 * data/bison.simple: Use __ofile__.
4375 * src/scan-skel.l: Handle __ofile__.
4376
43772002-04-08 Akim Demaille <akim@epita.fr>
4378
4379 * src/gram.h (item_number_t): New, the type of item numbers in
4380 RITEM. Note that it must be able to code symbol numbers as
4381 positive number, and the negation of rule numbers as negative
4382 numbers.
4383 Adjust all dependencies (pretty many).
4384 * src/reduce.c (rule): Remove this `short *' pointer: use
4385 item_number_t.
4386 * src/system.h (MINSHORT, MAXSHORT): Remove.
4387 Include `limits.h'.
4388 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
4389 (shortcpy): Remove.
4390 (MAXTABLE): Move to...
4391 * src/output.c (MAXTABLE): here.
4392 (prepare_rules): Use output_int_table to output rhs.
4393 * data/bison.simple, data/bison.c++: Adjust.
4394 * tests/torture.at (Big triangle): Move the limit from 254 to
4395 500.
4396 * tests/regression.at (Web2c Actions): Ajust.
4397
4398 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
4399 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
4400 passes, but produces negative #line number, once fixed, GCC is
4401 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
4402 C), it passes.
4403 * src/state.h (state_h): Code input lines on ints, not shorts.
4404
44052002-04-08 Akim Demaille <akim@epita.fr>
4406
4407 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
4408 and then the grammar.
4409
44102002-04-08 Akim Demaille <akim@epita.fr>
4411
4412 * src/system.h: No longer using strndup.
4413
44142002-04-07 Akim Demaille <akim@epita.fr>
4415
4416 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
4417 * src/output.c (output_table_data): Return the longest number.
4418 (prepare_tokens): Output `token_number_max').
4419 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
4420 New.
4421 Use them to define yy_token_number_type/TokenNumberType.
4422 Use this type for yytranslate.
4423 * tests/torture.at (Big triangle): Push the limit from 124 to
4424 253.
4425 * tests/regression.at (Web2c Actions): Adjust.
4426
44272002-04-07 Akim Demaille <akim@epita.fr>
4428
4429 * tests/torture.at (Big triangle): New.
4430 (GNU AWK Grammar, GNU Cim Grammar): Move to...
4431 * tests/existing.at: here.
4432
44332002-04-07 Akim Demaille <akim@epita.fr>
4434
4435 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
4436 nritems.
4437 Adjust dependencies.
4438
44392002-04-07 Akim Demaille <akim@epita.fr>
4440
4441 * src/reader.c: Normalize increments to prefix form.
4442
44432002-04-07 Akim Demaille <akim@epita.fr>
4444
4445 * src/reader.c, symtab.c: Remove debugging code.
4446
44472002-04-07 Akim Demaille <akim@epita.fr>
4448
4449 Rename all the `bucket's as `symbol_t'.
4450
4451 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
4452 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
4453 * src/symtab.c, src/symtab.h (bucket): Rename as...
4454 (symbol_t): this.
4455 (symbol_list_new, bucket_check_defined, bucket_make_alias)
4456 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
4457 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4458 (buckets_new, buckets_free, buckets_do): Rename as...
4459 (symbol_list_new, symbol_check_defined, symbol_make_alias)
4460 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4461 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
4462 (symbols_new, symbols_free, symbols_do): these.
4463
44642002-04-07 Akim Demaille <akim@epita.fr>
4465
4466 Use lib/hash for the symbol table.
4467
4468 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
4469 EOF.
4470 * src/lex.c (lex): Set the `number' member of new terminals.
4471 * src/reader.c (bucket_check_defined, bucket_make_alias)
4472 (bucket_check_alias_consistence, bucket_translation): New.
4473 (reader, grammar_free, readgram, token_translations_init)
4474 (packsymbols): Adjust.
4475 (reader): Number the predefined tokens.
4476 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
4477 for predefined tokens.
4478 * src/symtab.h (bucket): Remove all the hash table related
4479 members.
4480 * src/symtab.c (symtab): Replace by...
4481 (bucket_table): this.
4482 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4483 (buckets_new, buckets_do): New.
4484
44852002-04-07 Akim Demaille <akim@epita.fr>
4486
4487 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
4488 (start_symbol, max_user_token_number, semantic_parser)
4489 (error_token_number): Initialize.
4490 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
4491 Initialize.
4492 (reader): Don't.
4493 (errtoken, eoftoken, undeftoken, axiom): Extern.
4494
44952002-04-07 Akim Demaille <akim@epita.fr>
4496
4497 * src/gram.h (rule_s): prec and precsym are now pointers
4498 to the bucket giving the priority/associativity.
4499 Member `associativity' removed: useless.
4500 * src/reduce.c, src/conflicts.c: Adjust.
4501
45022002-04-07 Akim Demaille <akim@epita.fr>
4503
4504 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4505 Properly escape the symbols' TAG when outputting them.
4506
45072002-04-07 Akim Demaille <akim@epita.fr>
4508
4509 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4510
45112002-04-07 Akim Demaille <akim@epita.fr>
4512
4513 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4514 (LArule): this, which is an array to rule_t*.
4515 * src/print.c, src/conflicts.c: Adjust.
4516
45172002-04-07 Akim Demaille <akim@epita.fr>
4518
4519 * src/gram.h (rule_t): Rename `number' as `user_number'.
4520 `number' is a new member.
4521 Adjust dependencies.
4522 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4523
45242002-04-07 Akim Demaille <akim@epita.fr>
4525
4526 As a result of the previous patch, it is no longer needed
4527 to reorder ritem itself.
4528
4529 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4530
45312002-04-07 Akim Demaille <akim@epita.fr>
4532
4533 Be sure never to walk through RITEMS, but use only data related to
4534 the rules themselves. RITEMS should be banished.
4535
4536 * src/output.c (output_token_translations): Rename as...
4537 (prepare_tokens): this.
4538 In addition to `translate', prepare the muscles `tname' and
4539 `toknum', which were handled by...
4540 (output_rule_data): this.
4541 Remove, and move the remainder of its outputs into...
4542 (prepare_rules): this new routines, which also merges content from
4543 (output_gram): this.
4544 (prepare_rules): Be sure never to walk through RITEMS.
4545 (output_stos): Rename as...
4546 (prepare_stos): this.
4547 (output): Always invoke prepare_states, after all, just don't use it
4548 in the output if you don't need it.
4549
45502002-04-07 Akim Demaille <akim@epita.fr>
4551
4552 * src/LR0.c (new_state): Display `nstates' as the name of the
4553 newly created state.
4554 Adjust to initialize first_state and last_state if needed.
4555 Be sure to distinguish the initial from the final state.
4556 (new_states): Create the itemset of the initial state, and use
4557 new_state.
4558 * src/closure.c (closure): Now that the initial state has its
4559 items properly set, there is no need for a special case when
4560 creating `ruleset'.
4561
4562 As a result, now the rule 0, reducing to $axiom, is visible in the
4563 outputs. Adjust the test suite.
4564
4565 * tests/conflicts.at (Solved SR Conflicts)
4566 (Unresolved SR Conflicts): Adjust.
4567 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4568 * tests/conflicts.at (S/R in initial): New.
4569
45702002-04-07 Akim Demaille <akim@epita.fr>
4571
4572 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4573 the RHS of the rules.
4574 * src/output.c (output_gram): Likewise.
4575
45762002-04-07 Akim Demaille <akim@epita.fr>
4577
4578 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4579 bucket.
4580 Adjust all dependencies.
4581 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4582 `number' of the buckets too.
4583 * src/gram.h: Include `symtab.h'.
4584 (associativity): Move to...
4585 * src/symtab.h: here.
4586 No longer include `gram.h'.
4587
45882002-04-07 Akim Demaille <akim@epita.fr>
4589
4590 * src/gram.h, src/gram.c (rules_rhs_length): New.
4591 (ritem_longest_rhs): Use it.
4592 * src/gram.h (rule_t): `number' is a new member.
4593 * src/reader.c (packgram): Set it.
4594 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4595 the end of `rules', and count them out of `nrules'.
4596 (reduce_output, dump_grammar): Adjust.
4597 * src/print.c (print_grammar): It is no longer needed to check for
4598 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4599 * tests/reduce.at (Reduced Automaton): New test.
4600
46012002-04-07 Akim Demaille <akim@epita.fr>
4602
4603 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4604 lacking `+ 1' to nrules, Bison reported as useless a token if it
4605 was used solely to set the precedence of the last rule...
4606
46072002-04-07 Akim Demaille <akim@epita.fr>
4608
4609 * data/bison.c++, data/bison.simple: Don't output the current file
4610 name in #line, to avoid useless diffs between two identical
4611 outputs under different names.
4612
46132002-04-07 Akim Demaille <akim@epita.fr>
4614
4615 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4616 Normalize loops to using `< nrules + 1', not `<= nrules'.
4617
46182002-04-07 Akim Demaille <akim@epita.fr>
4619
4620 * TODO: Update.
4621
46222002-04-07 Akim Demaille <akim@epita.fr>
4623
4624 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4625 bucket.value as bucket.number.
4626
46272002-04-07 Akim Demaille <akim@epita.fr>
4628
4629 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4630 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4631 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4632 RHS, instead of being an index in RITEMS.
4633
46342002-04-04 Paul Eggert <eggert@twinsun.com>
4635
4636 * doc/bison.texinfo: Update copyright date.
4637 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4638 (Symbols): Warn about running Bison in one character set,
4639 but compiling and/or running in an incompatible one.
4640 Warn about character code 256, too.
4641
46422002-04-03 Paul Eggert <eggert@twinsun.com>
4643
4644 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4645 YYERROR_VERBOSE is nonzero, not whether it is defined.
4646
4647 Merge changes from bison-1_29-branch.
4648
46492002-03-20 Paul Eggert <eggert@twinsun.com>
4650
4651 Merge fixes from Debian bison_1.34-1.diff.
4652
4653 * configure.in (AC_PREREQ): 2.53.
4654
46552002-03-20 Akim Demaille <akim@epita.fr>
4656
4657 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4658
46592002-03-19 Paul Eggert <eggert@twinsun.com>
4660
4661 * src/bison.simple (YYCOPY): New macro.
4662 (YYSTACK_RELOCATE): Use it.
4663 Remove Type arg; no longer needed. All callers changed.
4664 (yymemcpy): Remove; no longer needed.
4665
4666 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4667 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4668
46692002-03-19 Akim Demaille <akim@epita.fr>
4670
4671 Test and fix the #line outputs.
4672
4673 * tests/atlocal.at (GCC): New.
4674 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4675 (Prologue synch line, ,%union synch line, Postprologue synch line)
4676 (Action synch line, Epilogue synch line): New tests.
4677 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4678 * data/bison.simple, data/bison.c++: Use it.
4679
46802002-03-19 Akim Demaille <akim@epita.fr>
4681
4682 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4683 (Solved SR Conflicts, %expect not enough, %expect right)
4684 (%expect too much): Move to...
4685 * tests/conflicts.at: this new file.
4686
46872002-03-19 Akim Demaille <akim@epita.fr>
4688
4689 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4690 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4691 that we can move to enums for instance.
4692 * src/output.c (token_definitions_output): Output a list of
4693 `token-name, token-number' instead of the #define.
4694 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4695
46962002-03-14 Akim Demaille <akim@epita.fr>
4697
4698 Use Gettext 0.11.1.
4699
47002002-03-09 Robert Anisko <robert@lrde.epita.fr>
4701
4702 * data/bison.c++: Make the user able to add members to the generated
4703 parser by subclassing.
4704
47052002-03-05 Robert Anisko <robert@lrde.epita.fr>
4706
4707 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4708 a character.
4709 Reported by Nicolas Tisserand and Nicolas Burrus.
4710
47112002-03-04 Robert Anisko <robert@lrde.epita.fr>
4712
4713 * src/reader.c: Warn about lacking semi-colons, do not complain.
4714
47152002-03-04 Robert Anisko <robert@lrde.epita.fr>
4716
4717 * data/bison.c++: Remove a debug line.
4718
47192002-03-04 Robert Anisko <robert@lrde.epita.fr>
4720
4721 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4722 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4723 provide a default implementation.
4724
47252002-03-04 Akim Demaille <akim@epita.fr>
4726
4727 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4728 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4729 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4730 * tests/semantic.at (Parsing Guards): Similarly.
4731 * src/reader.at (readgram): Complain if the last rule is not ended
4732 with a semi-colon.
4733
47342002-03-04 Akim Demaille <akim@epita.fr>
4735
4736 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4737 * src/closure.c: here.
4738 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4739 RTC.
4740 * src/warshall.h, src/warshall.c: Remove.
4741 * tests/sets.at (Broken Closure): Adjust.
4742
47432002-03-04 Akim Demaille <akim@epita.fr>
4744
4745 * src/output.c (output_skeleton): tempdir is const.
4746 bytes_read is unused.
4747
47482002-03-04 Akim Demaille <akim@epita.fr>
4749
4750 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4751 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4752 Update.
4753 From Michael Hayes.
4754
47552002-03-04 Akim Demaille <akim@epita.fr>
4756
4757 * src/closure.c (closure): `r' is unused.
4758
47592002-03-04 Akim Demaille <akim@epita.fr>
4760
4761 * tests/sets.at (Broken Closure): Add the ending `;'.
4762 * src/reader.at (readgram): Complain if a rule is not ended with a
4763 semi-colon.
4764
47652002-03-04 Akim Demaille <akim@epita.fr>
4766
4767 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4768 (count_sr_conflicts): Use bitset_count.
4769 * src/reduce.c (inaccessable_symbols): Ditto.
4770 (bits_size): Remove.
4771 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4772
47732002-03-04 Akim Demaille <akim@epita.fr>
4774
4775 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4776 * src/reduce.c: Remove the `bitset_zero's following the
4777 `bitset_create's, as now it is performed by the latter.
4778
47792002-03-04 Akim Demaille <akim@epita.fr>
4780
4781 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4782 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4783 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4784 latest sources from Michael.
4785
47862002-03-04 Akim Demaille <akim@epita.fr>
4787
4788 * src/output.c (output): Don't free the grammar.
4789 * src/reader.c (grammar_free): New.
4790 * src/main.c (main): Call it and don't free symtab here.
4791
47922002-03-04 Akim Demaille <akim@epita.fr>
4793
4794 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4795 before returning.
4796 Reported by Benoit Perrot.
4797
47982002-03-04 Akim Demaille <akim@epita.fr>
4799
4800 Use bitset operations when possible, not loops over bits.
4801
4802 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4803 bitset_or.
4804 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4805 * src/reduce.c (useless_nonterminals): Formatting changes.
4806 * src/warshall.c (TC): Use bitset_or.
4807
48082002-03-04 Akim Demaille <akim@epita.fr>
4809
4810 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4811 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4812 Ditto.
4813
48142002-03-04 Akim Demaille <akim@epita.fr>
4815
4816 * src/lalr.c (F): Now a bitset*.
4817 Adjust all dependencies.
4818
48192002-03-04 Akim Demaille <akim@epita.fr>
4820
4821 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4822 Adjust all dependencies.
4823
48242002-03-04 Akim Demaille <akim@epita.fr>
4825
4826 * src/L0.c, src/LR0.h (nstates): Be size_t.
4827 Adjust comparisons (signed vs unsigned).
4828 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4829 bitset*.
4830 Adjust all dependencies.
4831
48322002-03-04 Akim Demaille <akim@epita.fr>
4833
4834 * src/closure.c (firsts): Now, also a bitset.
4835 Adjust all dependencies.
4836 (varsetsize): Remove, now unused.
4837 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4838
48392002-03-04 Akim Demaille <akim@epita.fr>
4840
4841 * src/print.c: Convert to use bitset.h, not hand coded iterations
4842 over ints.
4843
48442002-03-04 Akim Demaille <akim@epita.fr>
4845
4846 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4847
48482002-03-04 Akim Demaille <akim@epita.fr>
4849
4850 * src/closure.c (ruleset): Be a bitset.
4851 (rulesetsize): Remove.
4852
48532002-03-04 Akim Demaille <akim@epita.fr>
4854
4855 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4856 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4857 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4858 * src/closure.c (fderives): Be an array of bitsets.
4859
48602002-02-28 Robert Anisko <robert@lrde.epita.fr>
4861
4862 * data/bison.c++: Merge the two generated headers. Insert a copyright
4863 notice in each output file.
4864
48652002-02-28 Akim Demaille <akim@epita.fr>
4866
4867 * data/bison.c++: Copy the prologue of bison.simple to fetch
4868 useful M4 definitions, such as b4_header_guard.
4869
48702002-02-25 Akim Demaille <akim@epita.fr>
4871
4872 * src/getargs.c (version): Give the name of the authors, and use a
4873 translator friendly scheme for the bgr
4874 copyright notice.
4875
48762002-02-25 Akim Demaille <akim@epita.fr>
4877
4878 * src/output.c (header_output): Remove, now handled completely via
4879 M4.
4880
48812002-02-25 Akim Demaille <akim@epita.fr>
4882
4883 * m4/m4.m4: New, from CVS Autoconf.
4884 * configure.in: Invoke it.
4885 * src/output.c (output_skeleton): Use its result instead of the
4886 hard coded name.
4887
48882002-02-25 Akim Demaille <akim@epita.fr>
4889
4890 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4891 Fileutils 4.1.5.
4892 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4893 * src/output.c (output_skeleton): Use mkstemp to create a real
4894 temporary file.
4895 Move the filling of `skeleton' and its muscle to...
4896 (prepare): here.
4897 (output): Move the definition of the prologue muscle to...
4898 (prepare): here.
4899 * src/system.h (DEFAULT_TMPDIR): New.
4900
49012002-02-14 Paul Eggert <eggert@twinsun.com>
4902
4903 Remove the support for C++ namespace cleanliness; it was
4904 causing more problems than it was curing, since it didn't work
4905 properly on some nonstandard C++ compilers. This can wait
4906 for a proper C++ parser.
4907
4908 * NEWS: Document this.
4909 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
4910 of C++, as it's treated like C now.
4911 * src/bison.simple (YYSTD): Remove.
4912 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
4913 Treat C++ just like Standard C instead of trying to support
4914 namespace cleanliness.
4915
49162002-02-14 Akim Demaille <akim@epita.fr>
4917
4918 * tests/regression.at (else): Adjust to Andreas' change.
4919
49202002-02-14 Akim Demaille <akim@epita.fr>
4921
4922 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
4923
49242002-02-13 Andreas Schwab <schwab@suse.de>
4925
4926 * src/output.c (output_rule_data): Don't output NULL, it might
4927 not be defined yet.
4928
49292002-02-11 Robert Anisko <robert@lrde.epita.fr>
4930
4931 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
4932 (Copyright notice): Update.
4933
49342002-02-11 Akim Demaille <akim@epita.fr>
4935
4936 * tests/regression.at (%nonassoc and eof): Don't include
4937 nonportable headers.
4938
49392002-02-08 Robert Anisko <robert@lrde.epita.fr>
4940
4941 * data/bison.c++: Correct error recovery. Make the user able to
4942 initialize the starting location.
4943
49442002-02-07 Akim Demaille <akim@epita.fr>
4945
4946 * tests/input.at: New.
4947
49482002-02-07 Robert Anisko <robert@lrde.epita.fr>
4949
4950 * data/bison.c++: Replace some direct m4 expansions by constants. Be
4951 more consistent when naming methods and variables. Put preprocessor
4952 directives around tables only needed for debugging.
4953
49542002-02-07 Robert Anisko <robert@lrde.epita.fr>
4955
4956 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
4957 C++ parsers.
4958 (yy::b4_name::parse): Use print_.
4959
49602002-02-07 Robert Anisko <robert@lrde.epita.fr>
4961
4962 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
4963
49642002-02-07 Robert Anisko <robert@lrde.epita.fr>
4965
4966 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
4967 C++ parsers.
4968 (yy::b4_name::parse): Build verbose error messages, and use error_.
4969
49702002-02-06 Robert Anisko <robert@lrde.epita.fr>
4971
4972 * data/bison.c++: Fix m4 quoting in comments.
4973
49742002-02-06 Robert Anisko <robert@lrde.epita.fr>
4975
4976 * data/bison.c++: Adjust the parser code. Fix some muscles that were
4977 not expanded by m4.
4978
49792002-02-05 Akim Demaille <akim@epita.fr>
4980
4981 * data/bison.c++: Adjust to the M4 back end.
4982 More is certainly needed.
4983
49842002-02-05 Akim Demaille <akim@epita.fr>
4985
4986 Give a try to M4 as a back end.
4987
4988 * lib/readpipe.c: New, from wdiff.
4989 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
4990 BISON_HAIRY.
4991 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
4992 specific values. Now it is m4 that performs the lookup.
4993 * src/parse-skel.y: Remove.
4994 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
4995 * src/output.c (actions_output, guards_output)
4996 (token_definitions_output): No longer keeps track of the output
4997 line number, hence remove the second argument.
4998 (guards_output): Check against the guard member of a rule, not the
4999 action member.
5000 Adjust callers.
5001 (output_skeleton): Don't look for the skeleton location, let m4 do
5002 that.
5003 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
5004 file will be used.
5005 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
5006 (prepare): Given that for the time being changesyntax is not
5007 usable in M4, rename the muscles using `-' to `_'.
5008 Define `defines_flag', `output_parser_name' and `output_header_name'.
5009 * src/output.h (actions_output, guards_output)
5010 (token_definitions_output): Adjust prototypes.
5011 * src/scan-skel.l: Instead of scanning the skeletons, it now
5012 processes the output of m4: `__oline__' and `#output'.
5013 * data/bison.simple: Adjust to be used by M4(sugar).
5014 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
5015 to date.
5016 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
5017 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
5018 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
5019 shamelessly stolen from CVS Autoconf.
5020
50212002-02-05 Akim Demaille <akim@epita.fr>
5022
5023 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
5024 * configure.in: Check for the declarations of free and malloc.
5025 * src/muscle_tab.c: Adjust.
5026
50272002-02-05 Akim Demaille <akim@epita.fr>
5028
5029 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
5030 which have no values.
5031
50322002-02-05 Akim Demaille <akim@epita.fr>
5033
5034 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
5035 * data/: here.
5036
50372002-01-29 Paul Eggert <eggert@twinsun.com>
5038
5039 * src/bison.simple (YYSIZE_T): Do not define merely because
5040 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
5041 On some platforms, <alloca.h> does not declare YYSTD (size_t).
5042
50432002-01-27 Akim Demaille <akim@epita.fr>
5044
5045 Fix `%nonassoc and eof'.
5046
5047 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
5048 which were not properly copied! Replace
5049 memcpy (res->errs, src->errs, src->nerrs);
5050 with
5051 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
5052 !!!
5053 * tests/regression.at (%nonassoc and eof): Adjust to newest
5054 Autotest: `.' is not in the PATH.
5055
50562002-01-27 Akim Demaille <akim@epita.fr>
5057
5058 * tests/sets.at (AT_EXTRACT_SETS): New.
5059 (Nullable): Use it.
5060 (Firsts): New.
5061
50622002-01-26 Akim Demaille <akim@epita.fr>
5063
5064 * tests/actions.at, tests/calc.at, tests/headers.at,
5065 * tests/torture.at: Adjust to the newest Autotest which no longer
5066 forces `.' in the PATH.
5067
50682002-01-25 Akim Demaille <akim@epita.fr>
5069
5070 * tests/regression.at (%nonassoc and eof): New.
5071 Suggested by Robert Anisko.
5072
50732002-01-24 Akim Demaille <akim@epita.fr>
5074
5075 Bison dumps core when trying to complain about broken input files.
5076 Reported by Cris van Pelt.
5077
5078 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
5079 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
5080 into...
5081 (Invalid inputs): Strengthen: exercise parse_percent_token.
5082
50832002-01-24 Robert Anisko <robert.anisko@epita.fr>
5084
5085 * src/Makefile.am: Add bison.c++.
5086 * src/bison.c++: New skeleton.
5087
50882002-01-21 Paolo Bonzini <bonzini@gnu.org>
5089
5090 * po/it.po: New.
5091
50922002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
5093
5094 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
5095
50962002-01-20 Marc Autret <marc@gnu.org>
5097
5098 * src/files.c (compute_output_file_names): Fix
5099
51002002-01-20 Marc Autret <marc@gnu.org>
5101
5102 * tests/output.at: New test.
5103 * src/files.c (compute_base_names): Don't map extensions when
5104 the YACC flag is set, use defaults.
5105 Reported by Evgeny Stambulchik.
5106
51072002-01-20 Marc Autret <marc@gnu.org>
5108
5109 * src/system.h: Need to define __attribute__ away for non-GCC
5110 compilers as well (i.e. the vendor C compiler).
5111 Suggested by Albert Chin-A-Young.
5112
51132002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
5114
5115 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
5116 canonical definition.
5117 * src/system.h: Use the canonical definition for PARAMS (avoids
5118 a conflict with the macro from lib/hash.h).
5119
51202002-01-11 Akim Demaille <akim@epita.fr>
5121
5122 * configure.in: Use AC_FUNC_STRNLEN.
5123 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
5124
51252002-01-09 Akim Demaille <akim@epita.fr>
5126
5127 * src/files.c, src/files.h (output_infix): New.
5128 (tab_extension): Remove.
5129 (compute_base_names): Compute the former, drop the latter.
5130 * src/output.c (prepare): Insert the muscles `output-infix', and
5131 `output-suffix'.
5132 * src/parse-skel.y (string, string.1): New.
5133 (section.header): Use it.
5134 (section.yacc): Remove.
5135 (prefix): Remove too.
5136 * src/scan-skel.l: Adjust.
5137 * src/bison.simple, src/bison.hairy: Adjust.
5138
51392002-01-09 Akim Demaille <akim@epita.fr>
5140
5141 * configure.in (WERROR_CFLAGS): Compute it.
5142 * src/Makefile.am (CFLAGS): Pass it.
5143 * tests/atlocal.in (CFLAGS): Idem.
5144 * src/files.c: Fix a few warnings.
5145 (get_extension_index): Remove, unused.
5146
51472002-01-08 Akim Demaille <akim@epita.fr>
5148
5149 * src/getargs.c (AS_FILE_NAME): New.
5150 (getargs): Use it to convert DOSish file names.
5151 * src/files.c (base_name): Rename as full_base_name to avoid
5152 clashes with `base_name ()'.
5153 (filename_split): New.
5154 (compute_base_names): N-th rewrite, using filename_split.
5155
51562002-01-08 Akim Demaille <akim@epita.fr>
5157
5158 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
5159 New, stolen from the Fileutils 4.1.
5160 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
5161 * configure.in: Check for the presence of memrchr, and of its
5162 prototype.
5163
51642002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
5165
5166 * lib/hash.h (__P): Added definition for this macro.
5167 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
5168 BUILT_SOURCES, to ensure they are generated first.
5169 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
5170 %error-verbose to allow bootstrapping with bison 1.30x.
5171
51722002-01-06 Akim Demaille <akim@epita.fr>
5173
5174 * src/reader.c (parse_braces): Don't fetch the next char, the
5175 convention is to fetch on entry.
5176 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
5177 'switch' without a following semicolon.
5178 * tests/regression.at (braces parsing): New.
5179
51802002-01-06 Akim Demaille <akim@epita.fr>
5181
5182 Bison is dead wrong in its RR conflict reports.
5183
5184 * tests/torture.at (GNU Cim Grammar): New.
5185 * src/conflicts.c (count_rr_conflicts): Fix.
5186
51872002-01-06 Akim Demaille <akim@epita.fr>
5188
5189 Creating package.m4 from configure.ac causes too many problems.
5190
5191 * tests/Makefile.am (package.m4): Create it by hand,
5192 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
5193
51942002-01-06 Akim Demaille <akim@epita.fr>
5195
5196 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
5197 skeleton.h.
5198
51992002-01-04 Paul Eggert <eggert@twinsun.com>
5200
5201 * doc/bison.texinfo (Debugging):
5202 Remove YYSTDERR; it's no longer defined or used.
5203 Also, s/cstdio.h/cstdio/.
5204
52052002-01-03 Akim Demaille <akim@epita.fr>
5206
5207 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
5208
52092002-01-03 Akim Demaille <akim@epita.fr>
5210
5211 * src/parse-skel.y (process_skeleton): Don't bind the parser's
5212 tracing code to --trace, wait for a better --trace option, with
5213 args.
5214
52152002-01-03 Akim Demaille <akim@epita.fr>
5216
5217 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
5218 The ISO C++ standard is extremely clear about it: stderr is
5219 considered a macro, not a regular symbol (see table 94 `Header
5220 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
5221 Therefore std:: does not apply to it. It still does with fprintf.
5222 Also, s/cstdio.h/cstdio/.
5223
52242002-01-03 Akim Demaille <akim@epita.fr>
5225
5226 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
5227 for non system headers.
5228
52292002-01-02 Akim Demaille <akim@epita.fr>
5230
5231 Equip the skeleton chain with location tracking, runtime trace,
5232 pure parser and scanner.
5233
5234 * src/parse-skel.y: Request a pure parser, locations, and prefix
5235 renaming.
5236 (%union): Having several members with the same type does not help
5237 type mismatches, simplify.
5238 (YYPRINT, yyprint): New.
5239 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
5240 (skel_error): this.
5241 Handle locations.
5242 * src/scan-skel.l: Adjust to these changes.
5243 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
5244 (LOCATION_PRINT, skel_control_t): New.
5245
52462001-12-30 Akim Demaille <akim@epita.fr>
5247
5248 * src/parse-skel.y: Get rid of the shift/reduce conflict:
5249 replace `gb' with BLANKS.
5250 * src/scan-skel.l: Adjust.
5251
52522001-12-30 Akim Demaille <akim@epita.fr>
5253
5254 * src/system.h: We don't need nor want bcopy.
5255 Throw away MS-DOS crap: we don't need getpid.
5256 * configure.in: We don't need strndup. It was even causing
5257 problems: because Flex includes the headers *before* us,
5258 _GNU_SOURCE is not defined by config.h, and therefore strndup was
5259 not visible.
5260 * lib/xstrndup.c: New.
5261 * src/scan-skel.l: Use it.
5262 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
5263 * src/parse-skel.y: Use %directives instead of #defines.
5264
52652001-12-30 Akim Demaille <akim@epita.fr>
5266
5267 * src/skeleton.h: New.
5268 * src/output.c (output_parser, output_master_parser): Remove, dead
5269 code.
5270 * src/output.h (get_lines_number, actions_output, guards_output)
5271 (token_definitions_output): Prototype them.
5272 * src/parse-skel.y: Add the license notice.
5273 Include output.h and skeleton.h.
5274 (process_skeleton): Returns void, and takes a single parameter.
5275 * src/scan-skel.l: Add the license notice.
5276 Include skeleton.h.
5277 Don't use %option yylineno: it seems that then Flex imagines
5278 REJECT has been used, and therefore it won't reallocate its
5279 buffers (which makes no other sense to me than a bug). It results
5280 in warnings for `unused: yy_flex_realloc'.
5281
52822001-12-30 Robert Anisko <robert.anisko@epita.fr>
5283
5284 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5285 (MUSCLE_INSERT_PREFIX): ...to there.
5286 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5287 (MUSCLE_INSERT_PREFIX): Move from here...
5288
5289 * src/bison.hairy: Add a section directive. Put braces around muscle
5290 names. This parser skeleton is still broken, but Bison should not
5291 choke on a bad muscle 'syntax'.
5292 * src/bison.simple: Add a section directive. Put braces around muscle
5293 names.
5294
5295 * src/files.h (strsuffix, stringappend): Add declarations.
5296 (tab_extension): Add declaration.
5297 (short_base_name): Add declaration.
5298
5299 * src/files.c (strsuffix, stringappend): No longer static. These
5300 functions are used in the skeleton parser.
5301 (tab_extension): New.
5302 (compute_base_names): Use the computations done in this function
5303 to guess if the generated parsers should have '.tab' in their
5304 names.
5305 (short_base_name): No longer static.
5306
5307 * src/output.c (output_skeleton): New.
5308 (output): Disable call to output_master_parser, and give a try to
5309 a new skeleton handling system.
5310 (guards_output, actions_output): No longer static.
5311 (token_definitions_output, get_lines_number): No longer static.
5312
5313 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
5314
5315 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
5316 parse-skel.y.
5317
5318 * src/parse-skel.y: New file.
5319 * src/scan-skel.l: New file.
5320
53212001-12-29 Akim Demaille <akim@epita.fr>
5322
5323 %name-prefix is broken.
5324
5325 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
5326 Adjust all dependencies.
5327 * tests/headers.at (export YYLTYPE): Strengthen this test: use
5328 %name-prefix.
5329
5330 Renaming yylval but not yylloc is not consistent. Now we do.
5331
5332 * src/bison.simple: Prefix yylloc if used.
5333 * doc/bison.texinfo (Decl Summary): Document that.
5334
53352001-12-29 Akim Demaille <akim@epita.fr>
5336
5337 * doc/bison.texinfo: Promote `%long-directive' over
5338 `%long_directive'.
5339 Remove all references to fixed-output-files, yacc is enough.
5340
53412001-12-29 Akim Demaille <akim@epita.fr>
5342
5343 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
5344 user prologue. These are defaults.
5345 * tests/actions.at (Mid-rule actions): Make sure the user can
5346 define YYDEBUG and YYERROR_VERBOSE.
5347
53482001-12-29 Akim Demaille <akim@epita.fr>
5349
5350 * src/output.c (header_output): Don't forget to export YYLTYPE and
5351 yylloc.
5352 * tests/headers.at (export YYLTYPE): New, make sure it does.
5353 * tests/regression.at (%union and --defines, Invalid CPP headers):
5354 Move to...
5355 * tests/headers.at: here.
5356
53572001-12-29 Akim Demaille <akim@epita.fr>
5358
5359 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
5360
53612001-12-29 Akim Demaille <akim@epita.fr>
5362
5363 * tests/actions.at (Mid-rule actions): Output on a single line
5364 instead of several.
5365
53662001-12-29 Akim Demaille <akim@epita.fr>
5367
5368 * doc/bison.texinfo: Formatting changes.
5369
53702001-12-29 Akim Demaille <akim@epita.fr>
5371
5372 Don't store the token defs in a muscle, just be ready to output it
5373 on command. Now possible via `symbols'. Fixes a memory leak.
5374
5375 * src/output.c (token_definitions_output): New.
5376 (output_parser, header_output): Use it.
5377 * src/reader.c (symbols_save): Remove.
5378
53792001-12-29 Akim Demaille <akim@epita.fr>
5380
5381 * src/bison.simple: Do not provide a default for YYSTYPE and
5382 YYLTYPE before the user's prologue. Otherwise it's hardly... a
5383 default.
5384
53852001-12-29 Akim Demaille <akim@epita.fr>
5386
5387 Mid-rule actions are simply... ignored!
5388
5389 * src/reader.c (readgram): Be sure to attach mid-rule actions to
5390 the empty-rule associated to the dummy symbol, not to the host
5391 rule.
5392 * tests/actions.at (Mid-rule actions): New.
5393
53942001-12-29 Akim Demaille <akim@epita.fr>
5395
5396 Memory leak.
5397
5398 * src/reader.c (reader): Free grammar.
5399
54002001-12-29 Akim Demaille <akim@epita.fr>
5401
5402 Memory leak.
5403
5404 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
5405 since it allocates it for each state, although only one is needed.
5406 (allocate_storage): Do it here.
5407
54082001-12-29 Akim Demaille <akim@epita.fr>
5409
5410 * src/options.h, src/options.c (create_long_option_table): Rename
5411 as...
5412 (long_option_table_new): this, with a clearer prototype.
5413 (percent_table): Remove, unused,
5414 * src/getargs.c (getargs): Adjust.
5415
54162001-12-29 Akim Demaille <akim@epita.fr>
5417
5418 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
5419 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
5420 as states.
5421
54222001-12-29 Akim Demaille <akim@epita.fr>
5423
5424 * src/lalr.c (build_relations): Rename `states' as `states1'.
5425 Sorry, I don't understand exactly what it is, no better name...
5426
54272001-12-29 Akim Demaille <akim@epita.fr>
5428
5429 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
5430 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
5431 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
5432 as rules.
5433
54342001-12-29 Akim Demaille <akim@epita.fr>
5435
5436 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
5437 ago.
5438
54392001-12-29 Akim Demaille <akim@epita.fr>
5440
5441 * src/reader.c, src/reader.h (user_toknums): Remove.
5442 Adjust all users to use symbols[i]->user_token_number.
5443
54442001-12-29 Akim Demaille <akim@epita.fr>
5445
5446 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
5447 Adjust all users to use symbols[i]->prec or ->assoc.
5448
54492001-12-29 Akim Demaille <akim@epita.fr>
5450
5451 * src/reader.c, src/reader.h (tags): Remove.
5452 Adjust all users to use symbols[i]->tag.
5453
54542001-12-29 Akim Demaille <akim@epita.fr>
5455
5456 * src/gram.h, src/gram.c (symbols): New, similar to state_table
5457 and rule_table.
5458 * src/reader.c (packsymbols): Fill this table.
5459 Drop sprec.
5460 * src/conflicts.c (resolve_sr_conflict): Adjust.
5461 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
5462 single table.
5463 Use symbols[i]->tag instead of tags[i].
5464
54652001-12-29 Akim Demaille <akim@epita.fr>
5466
5467 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
5468 In addition, put a comment in there, to replace...
5469 * tests/regression.at (%union and C comments): Remove.
5470
54712001-12-29 Akim Demaille <akim@epita.fr>
5472
5473 * tests/regression.at (Web2c Actions): Blindly move the actual
5474 output as expected output. The contents *seem* right to me, but I
5475 can't pretend reading perfectly parser tables... Nonetheless, all
5476 the other tests pass correctly, the table look OK, even though the
5477 presence of `$axiom' is to be noted: AFAICS it is useless (but
5478 harmless).
5479
54802001-12-29 Akim Demaille <akim@epita.fr>
5481
5482 * src/reader.c (readgram): Don't add the rule 0 if there were no
5483 rules read. In other words, add it _after_ having performed
5484 grammar sanity checks.
5485 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
5486
54872001-12-29 Akim Demaille <akim@epita.fr>
5488
5489 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
5490 visible, and some states have now a different number.
5491
54922001-12-29 Akim Demaille <akim@epita.fr>
5493
5494 * src/reader.c (readgram): Bind the initial rule's lineno to that
5495 of the first rule.
5496 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5497 (Solved SR Conflicts): Adjust rule 0's line number.
5498
54992001-12-29 Akim Demaille <akim@epita.fr>
5500
5501 Fix the `GAWK Grammar' failure.
5502
5503 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5504 the reductions of the first state which was mistakenly confused
5505 with the final state because precisely final_state was initialized
5506 to 0.
5507 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5508 now noticed by Bison.
5509 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5510 have a reduction on $default.
5511
55122001-12-29 Akim Demaille <akim@epita.fr>
5513
5514 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5515 rule line numbers.
5516 * src/closure.c (print_closure): Likewise.
5517 * src/derives.c (print_derives): Likewise.
5518 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5519 now.
5520
55212001-12-29 Akim Demaille <akim@epita.fr>
5522
5523 * src/lalr.c (lookaheads_print): New.
5524 (lalr): Call it when --trace-flag.
5525 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5526 are dumped.
5527
55282001-12-29 Akim Demaille <akim@epita.fr>
5529
5530 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5531 when walking through ritem, even via rule->rhs.
5532 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5533 (useful_production, useless_nonterminals): Likewise.
5534 (reduce_grammar_tables): Likewise, plus update nritems.
5535 * src/nullable.c (set_nullable): Likewise.
5536 * src/lalr.c (build_relations): Likewise.
5537 * tests/sets.at (Nullable): Adjust.
5538 Fortunately, now, the $axiom is no longer nullable.
5539
55402001-12-29 Akim Demaille <akim@epita.fr>
5541
5542 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5543 the 0-sentinel.
5544 * src/gram.c (ritem_longest_rhs): Likewise.
5545 * src/reduce.c (nonterminals_reduce): Likewise.
5546 * src/print_graph.c (print_graph): Likewise.
5547 * src/output.c (output_rule_data): Likewise.
5548 * src/nullable.c (set_nullable): Likewise.
5549
55502001-12-29 Akim Demaille <akim@epita.fr>
5551
5552 * src/output.c: Comment changes.
5553
55542001-12-27 Paul Eggert <eggert@twinsun.com>
5555
5556 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5557 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5558 Sparc, as they were causing more porting problems than the
5559 (minor) performance improvement was worth.
5560
5561 Also, catch up with 1.31's YYSTD.
5562
55632001-12-27 Akim Demaille <akim@epita.fr>
5564
5565 * src/output.c (output_gram): Rely on nritems, not the
5566 0-sentinel. See below.
5567 Use -1 as separator, not 0.
5568 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5569 Rely on -1 as separator in yyrhs, instead of 0.
5570 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5571 twice `Now at end of input', therefore there are two lines less to
5572 expect.
5573
55742001-12-27 Akim Demaille <akim@epita.fr>
5575
5576 * tests/regression.at (Unresolved SR Conflicts):
5577 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5578 below.
5579
55802001-12-27 Akim Demaille <akim@epita.fr>
5581
5582 * src/LR0.c (new_state): Recognize the final state by the fact it
5583 is reached by eoftoken.
5584 (insert_start_shifting_state, insert_eof_shifting_state)
5585 (insert_accepting_state, augment_automaton): Remove, since now
5586 these states are automatically computed from the initial state.
5587 (generate_states): Adjust.
5588 * src/print.c: When reporting a rule number to the user, substract
5589 1, so that the axiom rule is rule 0, and the first user rule is 1.
5590 * src/reduce.c: Likewise.
5591 * src/print_graph.c (print_core): For the time being, just as for
5592 the report, depend upon --trace-flags to dump the full set of
5593 items.
5594 * src/reader.c (readgram): Once the grammar read, insert the rule
5595 0: `$axiom: START-SYMBOL $'.
5596 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5597 number of the states has changed (the final state is no longer
5598 necessarily the last), catch up.
5599
56002001-12-27 Akim Demaille <akim@epita.fr>
5601
5602 Try to make the use of the eoftoken valid. Given that its value
5603 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5604 is used instead of > 0 where appropriate, (ii), depend upon nritems
5605 instead of the 0-sentinel.
5606
5607 * src/gram.h, src/gram.c (nritems): New.
5608 Expected to be duplication of nitems, but for the time being...
5609 * src/reader.c (packgram): Assert nritems and nitems are equal.
5610 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5611 * src/closure.c (print_closure, print_fderives): Likewise.
5612 * src/gram.c (ritem_print): Likewise.
5613 * src/print.c (print_core, print_grammar): Likewise.
5614 * src/print_graph.c: Likewise.
5615
56162001-12-27 Akim Demaille <akim@epita.fr>
5617
5618 * src/main.c (main): If there are complains after grammar
5619 reductions, then output the report anyway if requested, then die.
5620 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5621 * src/reader.c (eoftoken): New.
5622 (parse_token_decl): If the token being defined has value `0', it
5623 is the eoftoken.
5624 (packsymbols): No longer hack `tags' to insert `$' by hand.
5625 Be sure to preserve the value of the eoftoken.
5626 (reader): Make sure eoftoken is defined.
5627 Initialize nsyms to 0: now eoftoken is created just like the others.
5628 * src/print.c (print_grammar): Don't special case the eof token.
5629 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5630 lie anyway, albeit pleasant.
5631 * tests/calc.at: Exercise error messages with eoftoken.
5632 Change the grammar so that empty input is invalid.
5633 Adjust expectations.
5634 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5635
56362001-12-27 Akim Demaille <akim@epita.fr>
5637
5638 * configure.in: Check the protos of strchr ans strspn.
5639 Replace strchr if needed.
5640 * src/system.h: Provide the protos of strchr, strspn and memchr if
5641 missing.
5642 * lib/strchr.c: New.
5643 * src/reader.c (symbols_save): Use strchr.
5644
56452001-12-27 Akim Demaille <akim@epita.fr>
5646
5647 * src/print.c, src/print_graph.c (escape): New.
5648 Use it to quote the TAGS outputs.
5649 * src/print_graph.c (print_state): Now errors are in red, and
5650 reductions in green.
5651 Prefer high to wide: output the state number on a line of its own.
5652
56532001-12-27 Akim Demaille <akim@epita.fr>
5654
5655 * src/state.h, src/state.c (reductions_new): New.
5656 * src/LR0.c (set_state_table): Let all the states have a
5657 `reductions', even if reduced to 0.
5658 (save_reductions): Adjust.
5659 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5660 * src/print.c (print_reductions, print_actions): Adjust.
5661 * src/output.c (action_row): Adjust.
5662
56632001-12-27 Akim Demaille <akim@epita.fr>
5664
5665 * src/state.h, src/state.c (errs_new, errs_dup): New.
5666 * src/LR0.c (set_state_table): Let all the states have an errs,
5667 even if reduced to 0.
5668 * src/print.c (print_errs, print_reductions): Adjust.
5669 * src/output.c (output_actions, action_row): Adjust.
5670 * src/conflicts.c (resolve_sr_conflict): Adjust.
5671
56722001-12-27 Akim Demaille <akim@epita.fr>
5673
5674 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5675
56762001-12-27 Akim Demaille <akim@epita.fr>
5677
5678 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5679 * src/print.c: here.
5680 (lookaheadset, shiftset): New, used as additional storage by
5681 print_reductions.
5682 (print_results): Adjust.
5683 (print_shifts, print_gotos, print_errs): New, extracted from...
5684 (print_actions): here.
5685 * src/print_graph.c (print_actions): Remove dead code.
5686
56872001-12-27 Akim Demaille <akim@epita.fr>
5688
5689 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5690 `$n' and `@n'.
5691
56922001-12-27 Akim Demaille <akim@epita.fr>
5693
5694 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5695 (build_relations): Adjust.
5696
56972001-12-27 Akim Demaille <akim@epita.fr>
5698
5699 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5700 duplication.
5701
57022001-12-27 Akim Demaille <akim@epita.fr>
5703
5704 * src/reader.c (packgram): Catch nitems overflows.
5705
57062001-12-27 Akim Demaille <akim@epita.fr>
5707
5708 * src/files.c, src/files.h (guard_obstack): Remove.
5709 * src/output.c (output): Adjust.
5710 * src/reader.c (parse_braces): New, factoring...
5711 (copy_action, copy_guard): these two which are renamed as...
5712 (parse_action, parse_guard): these.
5713 As a voluntary consequence, using braces around guards is now
5714 mandatory.
5715
57162001-12-27 Akim Demaille <akim@epita.fr>
5717
5718 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5719 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5720 members.
5721 (symbol_list_new): Adjust.
5722 (copy_action): action_line is the first line, not the last.
5723 (copy_guard): Just as for actions, store the `action' only, not
5724 the switch/case/break flesh.
5725 Don't parse the user action that might follow the guard, let...
5726 (readgram): do it, i.e., now, there can be an action after a
5727 guard.
5728 In other words the guard is just explicitly optional.
5729 (packgram): Adjust.
5730 * src/output.c (guards_output): New.
5731 (output_parser): Call it when needed.
5732 (output): Also free the guard and attrs obstacks.
5733 * src/files.c, src/files.h (obstack_save): Remove.
5734 (output_files): Remove.
5735 As a result, if one needs the former `.act' file, using an
5736 appropriate skeleton which requires actions and guards is now
5737 required.
5738 * src/main.c (main): Adjust.
5739 * tests/semantic.at: New.
5740 * tests/regression.at: Use `input.y' as input file name.
5741 Avoid 8+3 problems by requiring input.c when the test needs the
5742 parser.
5743
57442001-12-27 Akim Demaille <akim@epita.fr>
5745
5746 * src/reader.c (symbol_list_new): Be sure to initialize all the
5747 fields.
5748
57492001-12-27 Akim Demaille <akim@epita.fr>
5750
5751 All the hacks using a final pseudo state are now useless.
5752
5753 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5754 * src/lalr.c (nLA): New.
5755 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5756 instead of lookaheadsp from the pseudo state (nstate + 1).
5757
57582001-12-27 Akim Demaille <akim@epita.fr>
5759
5760 * src/output.c (action_row, token_actions): Use a state_t instead
5761 of a integer, and nlookaheads instead of the following state's
5762 lookaheadsp.
5763
57642001-12-27 Akim Demaille <akim@epita.fr>
5765
5766 * src/conflicts.c (log_resolution, flush_shift)
5767 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5768 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5769 (conflicts_print, print_reductions): Use a state_t instead of an
5770 integer when referring to a state.
5771 As much as possible, depend upon nlookaheads, instead of the
5772 `lookaheadsp' member of the following state (since lookaheads of
5773 successive states are successive, the difference between state n + 1
5774 and n served as the number of lookaheads for state n).
5775 * src/lalr.c (add_lookback_edge): Likewise.
5776 * src/print.c (print_core, print_actions, print_state)
5777 (print_results): Likewise.
5778 * src/print_graph.c (print_core, print_actions, print_state)
5779 (print_graph): Likewise.
5780 * src/conflicts.h: Adjust.
5781
57822001-12-27 Akim Demaille <akim@epita.fr>
5783
5784 * src/bison.hairy: Formatting/comment changes.
5785 ANSIfy.
5786 Remove `register' indications.
5787 Add plenty of `static'.
5788
57892001-12-27 Akim Demaille <akim@epita.fr>
5790
5791 * src/output.c (prepare): Drop the muscle `ntbase' which
5792 duplicates ntokens.
5793 * src/bison.simple: Formatting/comment changes.
5794 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5795 is an undocumented synonym.
5796
57972001-12-22 Akim Demaille <akim@epita.fr>
5798
5799 * src/output.c (output_table_data): Change the prototype to use
5800 `int' for array ranges: some invocations do pass an int, not a
5801 short.
5802 Reported by Wayne Green.
5803
58042001-12-22 Akim Demaille <akim@epita.fr>
5805
5806 Some actions of web2c.y are improperly triggered.
5807 Reported by Mike Castle.
5808
5809 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5810 * tests/regression.at (Web2c): Rename as...
5811 (Web2c Report): this.
5812 (Web2c Actions): New.
5813
58142001-12-22 Akim Demaille <akim@epita.fr>
5815
5816 Reductions in web2c.y are improperly reported.
5817 Reported by Mike Castle.
5818
5819 * src/conflicts.c (print_reductions): Fix.
5820 * tests/regression.at (Web2c): New.
5821
58222001-12-18 Akim Demaille <akim@epita.fr>
5823
5824 Some host fail on `assert (!"foo")', which expands to
5825 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5826 Reported by Nelson Beebee.
5827
5828 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5829 `#define it_succeeded 0' and `assert (it_succeeded)'.
5830
58312001-12-17 Marc Autret <autret_m@epita.fr>
5832
5833 * src/bison.simple: Don't hard code the skeleton line and filename.
5834 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5835 New line counter 'skeleton_line' (skeleton-line muscle).
5836
58372001-12-17 Paul Eggert <eggert@twinsun.com>
5838
5839 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5840 YYDEBUG must be defined to a nonzero value.
5841
5842 * src/bison.simple (yytname): Do not assume that the user defines
5843 YYDEBUG to a properly parenthesized expression.
5844
58452001-12-17 Akim Demaille <akim@epita.fr>
5846
5847 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5848 nlookaheads is a new member.
5849 Adjust all users.
5850 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5851 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5852 state.
5853
58542001-12-17 Akim Demaille <akim@epita.fr>
5855
5856 * src/files.h, src/files.c (open_files, close_files): Remove.
5857 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5858 let...
5859 * src/reader.c (reader): Do it.
5860
58612001-12-17 Akim Demaille <akim@epita.fr>
5862
5863 * src/conflicts.c (print_reductions): Formatting changes.
5864
58652001-12-17 Akim Demaille <akim@epita.fr>
5866
5867 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5868 (flush_reduce): New.
5869 (resolve_sr_conflict): Adjust.
5870
58712001-12-17 Akim Demaille <akim@epita.fr>
5872
5873 * src/output.c (output_obstack): Be static and rename as...
5874 (format_obstack): this, to avoid any confusion with files.c's
5875 output_obstack.
5876 * src/reader.h (muscle_obstack): Move to...
5877 * src/output.h: here, since it's defined in output.c.
5878
58792001-12-17 Akim Demaille <akim@epita.fr>
5880
5881 * src/output.c (action_row, save_column, default_goto)
5882 (sort_actions, matching_state, pack_vector): Better variable
5883 locality.
5884
58852001-12-17 Akim Demaille <akim@epita.fr>
5886
5887 * src/output.c: Various formatting changes.
5888
58892001-12-17 Akim Demaille <akim@epita.fr>
5890
5891 * src/files.c (output_files): Free the output_obstack.
5892 * src/main.c (main): Call print and print_graph conditionally.
5893 * src/print.c (print): Work unconditionally.
5894 * src/print_graph.c (print_graph): Work unconditionally.
5895 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5896
58972001-12-16 Marc Autret <autret_m@epita.fr>
5898
5899 * src/output.c (actions_output): Fix. When we use %no-lines,
5900 there is one less line per action.
5901
59022001-12-16 Marc Autret <autret_m@epita.fr>
5903
5904 * src/bison.simple: Remove a useless #line directive.
5905 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
5906 * src/output.c (get_lines_number): New.
5907 (output_parser): Adjust, now takes care about the lines of a
5908 output muscles.
5909 Fix line numbering.
5910 (actions_output): Computes the number of lines taken by actions.
5911 (output_master_parser): Insert new skeleton which is the name of
5912 the output parser file name.
5913
59142001-12-15 Marc Autret <autret_m@epita.fr>
5915
5916 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
5917
59182001-12-15 Marc Autret <autret_m@epita.fr>
5919
5920 * src/output.c (output_gram): Keep track of the hairy one.
5921
59222001-12-15 Akim Demaille <akim@epita.fr>
5923
5924 Make `make distcheck' work.
5925
5926 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
5927 system.h which uses libgettext.h.
5928
59292001-12-15 Akim Demaille <akim@epita.fr>
5930
5931 * src/nullable.c (set_nullable): Useless rules must be skipped,
5932 otherwise, since we range over their symbols, we might look at a
5933 nonterminal which no longer ``exists'', i.e., it is not counted in
5934 `nvars', hence we overflow our arrays.
5935
59362001-12-15 Akim Demaille <akim@epita.fr>
5937
5938 The header can also be produced directly, without any obstack!
5939 Yahoo!
5940
5941 * src/files.c, src/files.h (defines_obstack): Remove.
5942 (compute_header_macro): Global.
5943 (defines_obstack_save): Remove.
5944 * src/reader.c (parse_union_decl): No longer output to
5945 defines_obstack: its content can be found in the `stype' muscle
5946 anyway.
5947 (output_token_translations): Merge into...
5948 (symbols_output): this.
5949 Rename as...
5950 (symbols_save): this.
5951 (reader): Adjust.
5952 * src/output.c (header_output): New.
5953 (output): Call it.
5954
59552001-12-15 Akim Demaille <akim@epita.fr>
5956
5957 * src/reader.c (parse_union_decl): Instead of handling two obstack
5958 simultaneously, use one to define the `stype' muscle, and use the
5959 value of the latter to fill defines_obstack.
5960 (copy_comment): Remove.
5961 (copy_comment2): Work for a single obstack.
5962 Rename as...
5963 (copy_comment): this.
5964
59652001-12-15 Akim Demaille <akim@epita.fr>
5966
5967 * src/lex.c, src/lex.h (xgetc): No longer static.
5968 * src/reader.c (parse_union_decl): Revamp.
5969
59702001-12-15 Akim Demaille <akim@epita.fr>
5971
5972 Still making progress in separating Bison into (i) input, (ii)
5973 process, (iii) output: now we can directly output the parser file
5974 without using table_obstack at all.
5975
5976 * src/files.c, src/files.h (table_obstack): Bye bye.
5977 (parser_file_name): New.
5978 * src/files.c (compute_output_file_names): Compute it.
5979 * src/output.c (actions_output, output_parser)
5980 (output_master_parser): To a file instead of an obstack.
5981
59822001-12-15 Akim Demaille <akim@epita.fr>
5983
5984 Attach actions to rules, instead of pre-outputting them to
5985 actions_obstack.
5986
5987 * src/gram.h (rule_t): action and action_line are new members.
5988 * src/reader.c (symbol_list): Likewise.
5989 (copy_action): Save the actions within the rule.
5990 (packgram): Save them in rule_table.
5991 * src/output.c (actions_output): New.
5992 (output_parser): Use it on `%%actions'.
5993 (output_rule_data): Don't free rule_table.
5994 (output): Do it.
5995 (prepare): Don't save the `action' muscle.
5996 * src/bison.simple: s/%%action/%%actions/.
5997
59982001-12-15 Akim Demaille <akim@epita.fr>
5999
6000 * src/reader.c (copy_action): When --yacc, don't append a `;'
6001 to the user action: let it fail if lacking.
6002 Suggested by Arnold Robbins and Tom Tromey.
6003
60042001-12-14 Akim Demaille <akim@epita.fr>
6005
6006 * src/lex.c (literalchar): Simply return the char you decoded, non
6007 longer mess around with obstacks and int pointers.
6008 Adjust all callers.
6009
60102001-12-14 Akim Demaille <akim@epita.fr>
6011
6012 * src/lex.c (literalchar): Don't escape the special characters,
6013 just decode them, and keep them as char (before, eol was output as
6014 the 2 char string `\n' etc.).
6015 * src/output.c (output_rule_data): Use quotearg to output the
6016 token strings.
6017
60182001-12-13 Paul Eggert <eggert@twinsun.com>
6019
6020 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
6021 Do not infringe on the global user namespace when using C++.
6022 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
6023 All uses of `fprintf' and `stderr' changed.
6024
6025 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
6026
60272001-12-13 Akim Demaille <akim@epita.fr>
6028
6029 The computation of nullable is broken: it doesn't handle empty
6030 RHS's properly.
6031
6032 * tests/torture.at (GNU AWK Grammar): New.
6033 * tests/sets.at (Nullable): New.
6034 * src/nullable.c (set_nullable): Instead of blindly looping over
6035 `ritems', loop over the rules, and then over their rhs's.
6036
6037 Work around Autotest bugs.
6038
6039 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
6040 frame, because Autotest understand lines starting with a `+' as
6041 traces from the shell. Then, they are not processed properly.
6042 Admittedly an Autotest bug, but we don't have time to wait for
6043 Autotest to catch up.
6044 * tests/regression.at (Broken Closure): Adjust to the new table
6045 frames.
6046 Move to...
6047 * tests/sets.at: here.
6048
60492001-12-13 Akim Demaille <akim@epita.fr>
6050
6051 * src/closure.c (closure): Use nrules instead of playing tricks
6052 with BITS_PER_WORD.
6053
60542001-12-13 Akim Demaille <akim@epita.fr>
6055
6056 * src/print.c (print_actions): Output the handling of `$' as the
6057 traces do: shifting the token EOF. Before EOF was treated as a
6058 nonterminal.
6059 * tests/regression.at: Adjust some tests.
6060 * src/print_graph.c (print_core): Complete the set of items via
6061 closure. The next-to-final and final states are still unsatisfying,
6062 but that's to be addressed elsewhere.
6063 No longer output the rule numbers, but do output the state number.
6064 A single loop for the shifts + gotos is enough, but picked a
6065 distinct color for each.
6066 (print_graph): Initialize and finalize closure.
6067
60682001-12-13 Akim Demaille <akim@epita.fr>
6069
6070 * src/reader.c (readgram): Remove dead code, an strip useless
6071 braces.
6072 (get_type): Remove, unused.
6073
60742001-12-12 Akim Demaille <akim@epita.fr>
6075
6076 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
6077 on that of lib/error.c.
6078
60792001-12-12 Akim Demaille <akim@epita.fr>
6080
6081 Some hosts don't like `/' in includes.
6082
6083 * src/system.h: Include libgettext.h without qualifying the path.
6084 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
6085 $(top_srcdir).
6086
60872001-12-11 Marc Autret <autret_m@epita.fr>
6088
6089 * src/output.c (output_parser): Remove useless muscle.
6090
60912001-12-11 Marc Autret <autret_m@epita.fr>
6092
6093 * src/bison.simple: Remove #line just before %%epilogue. It
6094 is now handled in ...
6095 * src/reader.c (read_additionnal_code): Add the output of a
6096 #line for the epilogue.
6097
60982001-12-10 Marc Autret <autret_m@epita.fr>
6099
6100 * src/reader.c (copy_definition): Re-use CPP-outed code which
6101 replace precedent remove.
6102 * src/bison.simple: Remove #line before %%prologue because
6103 %%input-line is wrong at this time.
6104
61052001-12-10 Marc Autret <autret_m@epita.fr>
6106
6107 * src/reader.c (symbols_output): Clean up.
6108 * src/output.c (output_gram, output): Clean up.
6109
61102001-12-10 Akim Demaille <akim@epita.fr>
6111
6112 * src/lalr.c (initialize_lookaheads): New. Extracted from...
6113 * src/LR0.c (set_state_table): here.
6114 * src/lalr.c (lalr): Call it.
6115
61162001-12-10 Akim Demaille <akim@epita.fr>
6117
6118 * src/state.h (shifts): Remove the `number' member: shifts are
6119 attached to state, hence no longer need to be labelled with a
6120 state number.
6121
61222001-12-10 Akim Demaille <akim@epita.fr>
6123
6124 Now that states have a complete set of members, the linked list of
6125 shifts is useless: just fill directly the state's shifts member.
6126
6127 * src/state.h (shifts): Remove the `next' member.
6128 * src/LR0.c (first_state, last_state): Remove.
6129 Adjust the callers.
6130 (augment_automaton): Don't look for the shifts that must be added
6131 a shift on EOF: it is those of the state we looked for! But now,
6132 since shifts are attached, it is no longer needed to looking
6133 merely by its id: its number.
6134
61352001-12-10 Akim Demaille <akim@epita.fr>
6136
6137 * src/LR0.c (augment_automaton): Better variable locality.
6138 Remove an impossible branch: if there is a state corresponding to
6139 the start symbol being shifted, then there is shift for the start
6140 symbol from the initial state.
6141
61422001-12-10 Akim Demaille <akim@epita.fr>
6143
6144 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
6145 only when appropriate: when insert_start_shifting_state' is not
6146 invoked.
6147 * tests/regression.at (Rule Line Numbers): Adjust.
6148
61492001-12-10 Akim Demaille <akim@epita.fr>
6150
6151 * src/LR0.c (augment_automaton): Now that all states have shifts,
6152 merge the two cases addition shifts to the initial state.
6153
61542001-12-10 Akim Demaille <akim@epita.fr>
6155
6156 * src/lalr.c (set_state_table): Move to...
6157 * src/LR0.c: here.
6158 * src/lalr.c (lalr): Don't call it...
6159 * src/LR0.c (generate_states): do it.
6160 * src/LR0.h (first_state): Remove, only the table is used.
6161
61622001-12-10 Akim Demaille <akim@epita.fr>
6163
6164 * src/LR0.h (first_shift, first_reduction): Remove.
6165 * src/lalr.c: Don't use first_shift: find shifts through the
6166 states.
6167
61682001-12-10 Akim Demaille <akim@epita.fr>
6169
6170 * src/LR0.c: Attach shifts to states as soon as they are
6171 computed.
6172 * src/lalr.c (set_state_table): Instead of assigning shifts to
6173 state, just assert that the mapping was properly done.
6174
61752001-12-10 Akim Demaille <akim@epita.fr>
6176
6177 * src/LR0.c (insert_start_shift): Rename as...
6178 (insert_start_shifting_state): this.
6179 (insert_eof_shifting_state, insert_accepting_state): New.
6180 (augment_automaton): Adjust.
6181 Better locality of the variables.
6182 When looking if the start_symbol is shifted from the initial
6183 state, using `while (... symbol != start_symbol ...)' sounds
6184 better than `while (... symbol < start_symbol ...)': If fail
6185 to see how the order between symbols could be relevant!
6186
61872001-12-10 Akim Demaille <akim@epita.fr>
6188
6189 * src/getargs.h: Don't declare `spec_name_prefix' and
6190 `spec_file_prefix', declared by src/files.h.
6191 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
6192 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
6193 * src/output.c (prepare): Adjust.
6194 * src/reader.c (symbols_output): Likewise.
6195 * src/vmsgetargs.c: Vaguely adjust, but who cares?
6196
61972001-12-10 Akim Demaille <akim@epita.fr>
6198
6199 * src/muscle_tab.c (muscle_init): NULL is a better default than
6200 `"0"'.
6201
62022001-12-10 Akim Demaille <akim@epita.fr>
6203
6204 * src/reader.c (reader): Calling symbols_output once is enough.
6205
62062001-12-10 Akim Demaille <akim@epita.fr>
6207
6208 Now that states have a complete set of members, the linked list of
6209 reductions is useless: just fill directly the state's reductions
6210 member.
6211
6212 * src/state.h (struct reductions): Remove member `number' and
6213 `next'.
6214 * src/LR0.c (first_reduction, last_reduction): Remove.
6215 (save_reductions): Don't link the new reductions, store them in
6216 this_state.
6217 * src/lalr.c (set_state_table): No need to attach reductions to
6218 states, it's already done.
6219 * src/output.c (output_actions): No longer free the shifts, then
6220 the reductions, then the states: free all the states and their
6221 members.
6222
62232001-12-10 Akim Demaille <akim@epita.fr>
6224
6225 * src/options.c (OPTN, DRTV, BOTH): New.
6226 (option_table): Use them.
6227
6228 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
6229 the job of system.h.
6230 * src/options.c: Don't include stdio.h and xalloc.h for the same
6231 reasons.
6232
62332001-12-10 Akim Demaille <akim@epita.fr>
6234
6235 * src/output.c (output, prepare): Make sure the values of the
6236 muscles `action' and `prologue' are 0-terminated.
6237
62382001-12-10 Akim Demaille <akim@epita.fr>
6239
6240 Clean up GCC warnings.
6241
6242 * src/reader.c (copy_action): `buf' is not used.
6243 (parse_skel_decl): Be static.
6244 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
6245 * src/options.h (create_long_option_table): Have a real prototype.
6246 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
6247 (hash_delete_at): Return const void *.
6248 Adjust casts to preserve the const.
6249
62502001-12-10 Akim Demaille <akim@epita.fr>
6251
6252 * configure.in: Require 2.52g.
6253 M4 is not needed, but AUTOM4TE is.
6254 * m4/m4.m4: Remove.
6255 * tests/Makefile.am: Adjust.
6256
62572001-12-10 Akim Demaille <akim@epita.fr>
6258
6259 One structure for states is enough, even though theoretically
6260 there are LR(0) states and LALR(1) states.
6261
6262 * src/lalr.h (state_t): Remove.
6263 (state_table): Be state_t **, not state_t *.
6264 * src/state.h (core, CORE_ALLOC): Rename as...
6265 (state_t, STATE_ALLOC): this.
6266 Add the LALR(1) members: shifts, reductions, errs.
6267 * src/LR0.c (state_table): Rename as...
6268 (state_hash): this, to avoid name clashes with the global
6269 `state_table'.
6270 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
6271 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
6272
62732001-12-10 Akim Demaille <akim@epita.fr>
6274
6275 Bison dumps core on bash.y.
6276 Reported by Pascal Bart.
6277
6278 * src/warshall.c (bitmatrix_print): New.
6279 (TC): Use it.
6280 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
6281 j must be the outer loop.
6282 * tests/regression.at (Broken Closure): New.
6283
62842001-12-05 Akim Demaille <akim@epita.fr>
6285
6286 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
6287 its argument.
6288