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