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