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