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