]> git.saurik.com Git - bison.git/blame - ChangeLog
* src/scan-skel.l: Scan more than one inert character per yylex
[bison.git] / ChangeLog
CommitLineData
68e93ad5
AD
12003-02-02 Akim Demaille <akim@epita.fr>
2
3 * src/scan-skel.l: Scan more than one inert character per yylex
4 invocation.
5
92898986
PE
62003-02-01 Paul Eggert <eggert@twinsun.com>
7
8 Version 1.875a.
9
1d9d5d71
PE
10 * po/LINGUAS: Add ms.
11
0435d061
AD
122003-01-30 Akim Demaille <akim@epita.fr>
13
14 * doc/Makefile.am (CLEANFILES): Add bison.fns for distcheck.
15
6029a57f
PH
162003-01-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
17
18 * tests/cxx-type.at: Correct apparent typo in Bison input: $$ instead
19 of $1.
0435d061
AD
20
21 Changes in response to error report by S. Eken: GLR mode does not
6029a57f
PH
22 handle negative $ indices or $ indices in embedded rules correctly.
23 See <http://mail.gnu.org/archive/html/bug-bison/2003-01/msg00076.html>.
0435d061 24
6029a57f
PH
25 * data/glr.c (b4_rhs_value): Change to use YYFILL macro.
26 (b4_rhs_location): Ditto.
0435d061 27 (yyfill): New function to copy from stack tree into array
6029a57f 28 incrementally.
0435d061
AD
29 (yyuserAction): Modify to allow incremental move of semantic values
30 to rhs array when in GLR mode.
31 Define YYFILL to use in user-defined actions to fill semantic array
6029a57f
PH
32 as needed.
33 Remove dummy use of yystack, as there is now a guaranteed use.
34 (yydoAction): Modify to allow incremental move of semantic values
35 to rhs array when in GLR mode.
36 (yyresolveAction): Ditto.
37 (yyglrShiftDefer): Update comment.
0435d061 38 (yyresolveStates): Use X == NULL for pointers, not !X.
6029a57f
PH
39 (yyglrReduce): Ditto.
40 (yydoAction): Ditto
0435d061 41
6029a57f
PH
42 * tests/glr-regr1.at: Rename to ...
43 * tests/glr-regression.at: Add new regression test for the problems
44 described above (adapted from S. Eken).
45 Update copyright notice.
46 * tests/testsuite.at: Rename glr-regr1.at to glr-regression.at.
47 * tests/Makefile.am: Ditto.
48
6cee6297
PE
492003-01-28 Paul Eggert <eggert@twinsun.com>
50
51 * data/lalr1.cc: Do not use @output_header_name@ unless
52 b4_defines_flag is set. This fixes two bugs reported by
53 Tim Van Holder in
54 <http://mail.gnu.org/archive/html/bug-bison/2003-01/msg00071.html>
55 and <http://mail.gnu.org/archive/html/bug-bison/2003-01/msg00073.html>.
56
b2a836b5
PE
572003-01-21 Paul Eggert <eggert@twinsun.com>
58
59 * data/yacc.c (YYERROR): Move code from yyerrlab1 to here, so that
60 we don't need to worry about yyerrlab1 being reported as an
61 "unused label" by non-GCC C compilers. The downside is that if
62 locations are used then a couple of statements are duplicated each
63 time YYERROR is invoked, but the upside is that the warnings
64 should vanish.
65 (yyerrlab1): Move code to YERROR.
66 (yyerrlab2): Remove. Change uses back to yyerrlab1.
67 This reverts some of the 2002-12-27 change.
68
4196b931
PE
692003-01-17 Paul Eggert <eggert@twinsun.com>
70
71 * src/output.c (symbol_printers_output): Fix typo that led
72 to core dump. Problem reported by Antonio Rus in
73 <http://mail.gnu.org/archive/html/bug-bison/2003-01/msg00058.html>.
74
3ae831b4
AD
752003-01-13 Akim Demaille <akim@epita.fr>,
76 Quoc Peyrot <chojin@lrde.epita.fr>,
77 Robert Anisko <anisko_r@lrde.epita.fr>
78
79 * data/lalr1.cc (parse::yyerrlab1): When popping the stack, stop
80 when the stacks contain one element, as the loop would otherwise
81 free the last state, and then use the top state (the one we just
82 popped). This means that the initial elements will not be freed
83 explicitly, as is the case in yacc.c; it is not a problem, as
84 these elements have fake values.
85
e3aa65c5
PE
862003-01-11 Paul Eggert <eggert@twinsun.com>
87
88 * NEWS: %expect-violations are now just warnings, reverting
89 to Bison 1.30 and 1.75 behavior. This fixes the GCC 3.2
90 bootstrapping problem reported by Matthias Klose; see
91 <http://mail.gnu.org/archive/html/bug-bison/2003-01/msg00053.html>.
92 * src/conflicts.c (conflicts_print): Likewise.
93 * tests/conflicts.at (%expect not enough, %expect too much,
94 %expect with reduce conflicts): Likewise.
95 * doc/bison.texinfo (Expect Decl): Document this. Also mention
96 that the warning is enabled if the number of conflicts changes
97 (not necessarily increases).
98
99 * src/getargs.c (version): Update copyright year.
100
f0057011
AD
1012003-01-09 Akim Demaille <akim@epita.fr>
102
103 * src/Makefile.am, lib/Makefile.am: Use $(VAR) instead of @VAR@.
104
1ee6d2a0
PE
1052003-01-08 Paul Eggert <eggert@twinsun.com>
106
107 * Makefile.maint (WGETFLAGS):
108 New macro, containing "-C off" to disable proxy caches.
109 All uses of $(WGET) changed to $(WGET) $(WGETFLAGS).
110 (rel-check): Use $(WGET) instead of wget.
111
d4fd77c4
PE
1122003-01-06 Paul Eggert <eggert@twinsun.com>
113
114 * doc/bison.texinfo (Generalized LR Parsing): Add a reference to
115 the GLR paper of Scott, Johnstone and Hussain.
116
464c6927
PE
1172003-01-04 Paul Eggert <eggert@twinsun.com>
118
d600ee67
PE
119 * configure.ac (AC_ARG_ENABLE): Add --disable-yacc.
120 (YACC_SCRIPT, YACC_LIBRARY): New vars to AC_SUBST.
121 * lib/Makefile.am (lib_LIBRARIES): liby.a -> @YACC_LIBRARY@.
122 (EXTRA_LIBRARIES): New var, for liby.a.
123 * src/Makefile.am (bin_SCRIPTS): yacc -> @YACC_SCRIPT@.
124 (EXTRA_SCRIPTS): New var, for yacc.
125
464c6927
PE
126 * data/yacc.c (yyerrlab1): Omit attribute if __cplusplus is defined,
127 since GNU C++ (as of 3.2.1) does not allow attributes on labels.
128 Problem reported by Nelson H. F. Beebe.
129
1302003-01-03 Paul Eggert <eggert@twinsun.com>
131
132 * lib/obstack.h (__INT_TO_PTR) [__STDC__]: Cast result to
133 (void *) to avoid diagnostic with native c89 on SGI IRIX 6.5
134 when compiling Bison 1.875's `bitset bset = obstack_alloc
135 (bobstack, bytes);'. Problem reported by Nelson H. F. Beebe.
136
137 * src/scan-skel.l (QPUTS): Omit redundant `;' from macro definition.
138 ([^@\n]): Renamed from [^@\n]+ so that the token buffer does not
139 grow to a huge size with typical invocation.
d600ee67 140
464c6927
PE
141 * lib/hash.c (_Bool, bool, false, true, __bool_true_false_are_defined):
142 Use the pattern recommended by Autoconf 2.57, except also protect
143 against double-definition.
144 * src/system.h: Likewise.
145 Portability issues reported by Nelson H. F. Beebe.
d600ee67 146
464c6927
PE
147 * data/glr.c (yybool): Renamed from bool, to avoid collisions in C.
148 All uses changed. Provide a definition in both C and C++.
149 (yytrue, yyfalse): Define even if defined (__cplusplus).
150
151 * lib/bitset_stats.c (bitset_stats_list): Remove unused var.
152 Reported by Nelson H. F. Beebe.
d600ee67 153
464c6927
PE
154 * src/scan-skel.l ("@oline@"): Output lineno+1, not lineno.
155
0f42c7d5
PE
1562003-01-02 Paul Eggert <eggert@twinsun.com>
157
158 * data/yacc.c (yyerrlab1): Append `;' after attribute, to
159 pacify the buggy "smart preprocessor" in MacOS 10.2.3.
160 Bug reported by Nelson H. F. Beebe.
161
dc546b0f
PE
1622003-01-01 Paul Eggert <eggert@twinsun.com>
163
164 * Version 1.875.
165
2c09b6a7
PE
1662002-12-30 Paul Eggert <eggert@twinsun.com>
167
168 * src/scan-gram.l (<INITIAL,SC_AFTER_IDENTIFIER,SC_PRE_CODE>","):
169 Moved here from...
170 (<INITIAL>","): Here. This causes stray "," to be treated
171 more uniformly.
172
dc546b0f 173 * src/scan-gram.l (<SC_BRACED_CODE>"}"): Output ";" before the
2c09b6a7
PE
174 last brace in braced code when not in Yacc mode, for compatibility
175 with Bison 1.35. This resurrects the 2001-12-15 patch to
176 src/reader.c.
177
178 * src/reader.h (YYDECL): Use YYSTYPE, not its deprecated alias
179 yystype. This follows up the 2002-12-24 YYSTYPE bug fix.
180
535c0f63
PE
1812002-12-28 Paul Eggert <eggert@twinsun.com>
182
183 * src/symtab.c (symbol_make_alias): Set type of SYMVAL to be
184 that of SYM's type. This fixes Debian bug 168069, reported by
185 Thomas Olsson.
d600ee67 186
963fcc17
PE
1872002-12-28 Paul Eggert <eggert@twinsun.com>
188
189 Version 1.75f.
190
191 Switch back to the Yacc style of conflict reports, undoing some
192 of the 2002-07-30 change.
193 * doc/bison.texinfo (Understanding): Use Yacc style for
194 conflict reports. Also, use new way of locating rules.
195 * src/conflicts.c (conflict_report):
196 Renamed from conflict_report_yacc, removing the old
197 'conflict_report'. Translate the entire conflict report at once,
198 so that we don't assume that "," has the same interpretation in
199 all languages.
200 (conflicts_output): Use Yacc-style conflict report for each state,
201 instead of our more-complicated style.
202 (conflicts_print): Use Yacc-style conflict report, except print
203 the input file name when not emulating Yacc.
204 * tests/conflicts.at (Unresolved SR Conflicts, Defaulted
205 Conflicted Reduction, %expect not enough, %expect too much,
206 %expect with reduce conflicts): Switch to Yacc-style conflict reports.
207 * tests/existing.at (GNU Cim Grammar): Likewise.
208 * tests/glr-regr1.at (Badly Collapsed GLR States): Likewise.
209
210 * src/complain.c (warn_at, warn, complain_at, complain, fatal_at,
211 fatal): Don't invoke fflush; it's not needed and it might even be
212 harmful for stdout, as stdout might not be open.
213 * src/reduce.c (reduce_print): Likewise.
214
b1efe548
PE
2152002-12-27 Paul Eggert <eggert@twinsun.com>
216
217 Fix a bug where error locations were not being recorded correctly.
218 This problem was originally reported by Paul Hilfinger in
e3aa65c5 219 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00086.html>.
b1efe548
PE
220
221 * data/yacc.c (yyparse): New local var yylerrsp, to record the
222 top of the location stack's error locations.
223 (yyerrlab): Set it. When discarding a token, push its location
224 onto yylerrsp so that we don't lose track of the error's end.
225 (yyerrlab1): Now is only the target of YYERROR, so that we can
226 properly record the location of the action that failed. For GCC
227 2.93 and later, insert an __attribute__ ((__unused__)) to avoid
228 GCC warning about yyerrlab1 being unused if YYERROR is unused.
229 (yyerrlab2): New label, which yyerrlab now falls through to.
230 Compute the error's location by applying YYLLOC_DEFAULT to
231 the locations of all the symbols that went into the error.
232 * doc/bison.texinfo (Location Default Action): Mention that
233 YYLLOC_DEFAULT is also invoked for syntax errors.
234 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR):
235 Error locations include the locations of all the tokens that were
236 discarded, not just the last token.
d600ee67 237
983c5c2c
PE
2382002-12-26 Paul Eggert <eggert@twinsun.com>
239
b1efe548
PE
240 * src/files.c: Include quote.h.
241 (compute_output_file_names): Warn if we detect conflicting
242 outputs to the same file. This should catch the misunderstanding
243 exemplified by Debian Bug 165349, reported by Bruce Stephens..
244
245 * src/conflicts.c (conflicts_print): If the user specifies
246 "%expect N", report an error if there are any reduce/reduce
247 conflicts. This is what the manual says should happen.
248 This fixes Debian bug 130890, reported by Anthony DeRobertis.
249 * tests/conflicts.at (%expect with reduce conflicts): New test.
250
983c5c2c
PE
251 Don't use m4_include on relative file names, as it doesn't work as
252 desired if there happens to be a file with that name under ".".
d600ee67 253
983c5c2c
PE
254 * m4sugar/version.m4: Remove; it was included but it wasn't used.
255 * data/Makefile.am (dist_m4sugar_DATA): Remove m4sugar/version.m4.
256 * data/m4sugar/m4sugar.m4: Don't include m4sugar/version.m4.
257 * data/glr.c, data/lalr1.cc, data/yacc.c: Don't include c.m4.
258 * src/output.c (output_skeleton): Use full path names when
259 specifying a file to include; don't rely on include path, as
260 it's unreliable when the working file contains a file with
261 that name.
d600ee67 262
983c5c2c
PE
2632002-12-25 Paul Eggert <eggert@twinsun.com>
264
265 Remove obsolete references to bison.simple and bison.hairy.
266 Problem mentioned by Aubin Mahe in
e3aa65c5 267 <http://mail.gnu.org/archive/html/help-bison/2002-12/msg00010.html>.
983c5c2c
PE
268 * data/glr.c: Comment fix.
269 * doc/bison.1: Remove references. Also, mention "yacc".
270
271 * src/getargs.c (getargs) [MSDOS]: Don't assume optarg != NULL
272 with -g option.
273
274 * src/parse-gram.y (declaration): Use enum "report_states" rather
275 than its numeric value 1.
276
277 * src/scan-skel.l ("@output ".*\n): Close any old yyout before
278 opening a new one. This fixes Debian bug 165349, reported by
279 Bruce Stephens.
280
23f2d9dc
PE
2812002-12-24 Paul Eggert <eggert@twinsun.com>
282
283 Version 1.75e.
284
285 * Makefile.maint (cvs-update): Don't assume that the shell
286 supports $(...), as Solaris sh doesn't.
287
288 * src/parse-gram.y (lloc_default): Remove test for empty
289 nonterminals at the end, since it didn't change the result.
290
2912002-12-24 Paul Eggert <eggert@twinsun.com>
33167b8b
PE
292
293 If the user does not define YYSTYPE as a macro, Bison now declares it
294 using typedef instead of defining it as a macro. POSIX requires this.
295 For consistency, YYLTYPE is also declared instead of defined.
296
297 %union directives can now have a tag before the `{', e.g., the
298 directive `%union foo {...}' now generates the C code
299 `typedef union foo { ... } YYSTYPE;'; this is for Yacc compatibility.
300 The default union tag is `YYSTYPE', for compatibility with Solaris 9
301 Yacc. For consistency, YYLTYPE's struct tag is now `YYLTYPE'
302 instead of `yyltype'.
303
304 `yystype' and `yyltype' are now obsolescent macros instead of being
305 typedefs or tags; they are no longer documented and will be
306 withdrawn in a future release.
307
308 * data/glr.c (b4_location_type): Remove.
309 (YYSTYPE): Renamed from yystype.
310 (YYSTYPE_IS_DECLARED): New macro, used to prevent double-typedef.
311 (struct YYLTYPE): Renamed from struct yyltype.
312 (YYLTYPE): Renamed from yyltype.
313 (yyltype, yystype): New (and obsolescent) macros,
314 for backward compatibility.
315 * data/yacc.c: Likewise.
316
317 * data/yacc.c (YYSTYPE): Declare as union YYSTYPE if the user
318 does not specify a union tag. This is for compatibility with
319 Solaris 9 yacc.
320
321 * src/parse-gram.y (add_param): 2nd arg is now char * not char
322 const *, since it is now modified by stripping surrounding { }.
323 (current_braced_code): Remove.
324 (PERCENT_DESTRUCTOR, PERCENT_PRINTER, PERCENT_UNION,
325 PERCENT_LEX_PARAM, PERCENT_PARSE_PARAM): Change names to include
326 trailing " {...}". Now of type <chars>.
327 (grammar_declaration): Adjust to bundled tokens.
328 (code_content): Remove; stripping is now done by add_param.
329 (print_token_value): Print contents of bundled tokens.
330 (token_name): New function.
331
332 * src/reader.h (braced_code, current_braced_code): Remove.
333 (token_name): New decl.
334
335 * src/scan-gram.l (handle_dollar, handle_at): Now takes int
336 token_type, not braced_code code_kind. All uses changed.
337 (SC_PRE_CODE): New state, for scanning after a keyword that
338 has (or usually has) an immediately-following braced code.
339 (token_type): New local var, to keep track of which token type
340 to return when scanning braced code.
341 (<INITIAL>"%destructor", <INITIAL>"%lex-param",
dc546b0f 342 <INITIAL>"%parse-param", <INITIAL>"%printer",
33167b8b
PE
343 <INITIAL>"%union"): Set token type and BEGIN SC_PRE_CODE
344 instead of returning a token type immediately.
345 (<INITIAL>"{"): Set token type.
346 (<SC_BRACED_CODE>"}"): Use it.
347 (handle_action_dollar, handle_action_at): Now returns bool
348 indicating success. Fail if ! current_rule; this prevents a core dump.
349 (handle_symbol_code_dollar, handle_symbol_code_at):
350 Remove; merge body into caller.
351 (handle_dollar, handle_at): Complain in invalid contexts.
352
353 * NEWS, doc/bison.texinfo: Document the above.
354 * NEWS: Fix years and program names in copyright notice.
355
879ca4f8
PE
3562002-12-17 Paul Eggert <eggert@twinsun.com>
357
358 * NEWS, doc/bison.texinfo (Parser Function, Pure Calling, Error
359 Reporting, Table of Symbols): Omit mentions of %lex-param and
360 %parse-param from the documentation for now.
361
1c5fe69d
PE
3622002-12-15 Paul Eggert <eggert@twinsun.com>
363
364 Undo most of the 2002-11-12 yychar -> yytoken patch, as it broke
365 GCC 3.2.1 (which depends on yychar == YYEMPTY when there is no
366 lookahead symbol, and which sets yychar in parser actions) and it
7ea9026a
PE
367 disagreed with the Bison documentation. Bug
368 reported by Andrew Walrond.
d600ee67 369
1c5fe69d
PE
370 * data/yacc.c (YYTRANSLATE): Don't check for negative argument,
371 as the caller now does that.
372 (yyclearin, YYBACKUP, yyparse): Use yychar, not yytoken.
373 (YYEMPTY): Parenthesize right hand side, since others use it.
374 (yyparse): Don't assume that our generated code is the only code
375 that sets yychar.
376
d1de5372
PE
3772002-12-13 Paul Eggert <eggert@twinsun.com>
378
379 Version 1.75d.
380
381 POSIX requires a "yacc" command.
382 * src/Makefile.am (bin_SCRIPTS): New macro, for yacc.
383 (MOSTLYCLEANFILES): Add yacc.
384 (yacc): New rule.
1c5fe69d 385 * doc/bison.texinfo (Invocation, Bison Options): Mention yacc
d1de5372
PE
386 as an alias for bison y.
387
388 * po/LINGUAS: Add da.
d600ee67 389
d1de5372
PE
390 * src/getargs.c (__GNU_LIBRARY__) [lint]: Define to work around
391 problem with latest <getopt.h>.
392 (HACK_FOR___GNU_LIBRARY___PROTOTYPE): New macro.
393
394 * doc/fdl.texi: Upgrade to 1.2.
395 * lib/alloca.c, lib/error.c, lib/getopt.c, lib/getopt.h
396 lib/getopt1.c, lib/gettext.h, lib/memrchr.c, lib/obstack.c,
397 lib/obstack.h, lib/strnlen.c, lib/unlocked-io.h: Sync with
398 gnulib.
399 * config/install-sh: Sync with autotools.
400
401 Fix a bad interaction with flex 2.5.23 reported by Bruce Lilly in
e3aa65c5 402 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00114.html>.
d1de5372
PE
403 * data/yacc.c (YYLTYPE, struct yyltype): Do not define unless
404 locations are requested.
405 (union yyalloc): Do not depend on YYLTYPE_IS_TRIVIAL unless
406 locations are requested.
407
d0f3fe23
PE
4082002-12-12 Paul Eggert <eggert@twinsun.com>
409
410 Remove unportable casts and storage allocation tricks.
411 While we're at it, remove almost all casts, since they
412 usually aren't needed and are a sign of trouble.
413
414 * configure.ac (AC_CHECK_TYPES): Check for uintptr_t.
415
416 * src/derives.c (derives_compute): Do not subtract NTOKENS from
417 the pointer DSET returned by malloc; this isn't portable.
418 Instead, always use DSET[i - NTOKENS] rather than DSET[i].
419 Similarly for DERIVES.
420 * src/lalr.c (set_goto_map): Likewise, for GOTO_MAP and TEMP_MAP.
421 * src/nullable.c (nullable_compute): Likewise, for RSETS and NULLABLE.
422 * src/reduce.c (reduce_grammar_tables): Likewise, for nontermmap
423
424 * src/derives.c (derives_compute): Do not bother invoking
425 int_of_rule_number, since rule numbers are integers.
426
427 * src/files.c (concat2, tr, compute_base_name): Use xmalloc (N)
428 rather than XMALLOC (char, N).
429
430 * src/files.c (filename_split): Rewrite to avoid cast.
431
432 * src/gram.h (symbol_number_as_item_number,
433 item_number_as_symbol_number, rule_number_as_item_number,
434 item_number_as_rule_number):
435 Now inline functions rather than macros, to avoid casts.
436 * src/state.h (state_number_as_int): Likewise.
437 * src/tables.c (state_number_to_vector_number,
438 symbol_number_to_vector_number): Likewise.
439
440 * src/gram.h (int_of_rule_number): Remove; no longer used.
441
442 * src/lalr.c (add_lookback_edge): Use malloc rather than calloc,
443 since the resulting storage is always stored into.
444
445 * src/main.c (alloca) [C_ALLOCA]: Add decl here, the only place
446 where it's needed.
447
448 * src/muscle_tab.c (muscle_m4_output):
449 Now inline. Return bool, not int.
450 * src/state.c (state_compare): Likewise.
451 * src/symtab.c (symbol_check_defined,
452 symbol_check_alias_consistency, symbol_pack, symbol_translation,
453 hash_compare_symbol, hash_symbol):
454 Likewise.
455 * src/uniqstr.c (uniqstr_print): Likewise.
456 * src/muscle_tab.c (muscle_m4_output_processor):
457 New function, to avoid casts.
458 * src/state.c (state_comparator, stage_hasher): Likewise.
459 * src/symtab.c (symbol_check_defined_processor,
460 symbol_check_alias_consistency_processor, symbol_pack_processor,
461 symbol_translation_processor, hash_symbol_comparator,
462 hash_symbol_hasher): Likewise.
463 * src/uniqstr.c (uniqstr_print_processor): Likewise.
464 * src/muscle_tab.c (muscles_m4_output):
465 Use new functions instead of casting old functions unportably.
466 * src/state.c (state_hash_new): Likewise.
467 * src/symtab.c (symbols_new, symbols_do, symbols_check_defined,
468 symbols_token_translations_init):
469 Likewise.
470 * src/uniqstr.c (uniqstrs_new, hash_initialize, uniqstrs_do): Likewise.
471
472 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): Use long local
473 var instead of casting to long, to avoid casts.
474 (prepare_states): Use MALLOC rather than alloca, so that we don't
475 have to worry about alloca.
476 * src/state.c (state_hash_lookup): Likewise.
477
478 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>"'"): Use unsigned char
479 local var instead of casting to unsigned char, to avoid casts.
480
481 * src/state.c (TRANSITIONS_ALLOC, ERRS_ALLOC, REDUCTIONS_ALLOC,
482 STATE_ALLOC): Remove.
483 (transitions_new, errs_new, reductions_new, state_new): Use malloc
484 rather than calloc, and use offsetof to avoid allocating slightly
485 too much storage.
486 (state_new): Initialize all members.
487
488 * src/state.c (state_hash): Use unsigned accumulator, not signed.
489
490 * src/symtab.c (symbol_free): Remove; unused.
491 (symbol_get): Remove cast in lhs of assignment.
492 (symbols_do): Now static. Accept generic arguments, not
493 hashing-related ones.
494
495 * src/symtab.h: (NUMBER_UNDEFINED): Remove unnecessary cast.
496 (symbol_processor): Remove.
497 (symbols_do): Remove decl; now static.
498
499 * src/system.h (alloca): Remove; decl no longer needed.
500 (<stddef.h>): Include, for offsetof.
501 (<inttypes.>, <stdint.h>): Include if available.
502 (uintptr_t): New type, if system lacks it.
503 (CALLOC, MALLOC, REALLOC): New macros.
504 All uses of XCALLOC, XMALLOC, and XREALLOC changed to use these
505 new macros.
506
507 * src/tables.c (table_size): Now int, to pacify GCC.
508 (table_grow, table_ninf_remap): Use signed table size.
509 (save_row): Don't bother initializing locals when not needed.
510 (default_goto, goto_actions, pack_vector): Remove unnecessary casts.
511 * src/uniqstr.c (hash_compare_uniqstr): Likewise.
512
513 * src/vcg.h: Correct misspellings.
514
515 * src/vcg_defaults.h (G_CMAX): Now INT_MAX.
516
517
518 * src/getargs.c (getargs): Don't assume EOF == -1.
519
26b4a969
PE
5202002-12-09 Paul Eggert <eggert@twinsun.com>
521
522 Change identifier spellings to avoid collisions with names
523 that are reserved by POSIX.
524
525 Don't use names ending in _t, since POSIX reserves them.
526 For consistency, remove _e and _s endings -- they're weren't
527 needed to remove ambiguity. All uses changed.
528 * src/uniqstr.h (uniqstr): Renamed from uniqstr_t, which in
529 turn was just renamed from struniq_t.
530 * src/uniqstr.c (uniqstr_processor): Renamed from struniq_processor,
531 which in turn was just renamed from struniq_processor_t.
532 (hash_compare_uniqstr): Renamed from hash_compare_struniq, which
533 in turn was renamed from hash_compare_struniq_t.
534 * src/LR0.c (struct state_list): Renamed from struct state_list_s.
535 (state_list): Renamed from state_list_t.
536 * src/assoc.h (assoc): Renamed from assoc_t.
537 * src/conflicts.c (enum conflict_resolution): Renamed from
538 enum conflict_resolution_e.
539 * src/derives.c (struct rule_list): Renamed from struct rule_list_s.
540 (rule_list): Renamed from rule_list_t.
541 * src/getargs.h (enum trace): Renamed from enum trace_e.
542 (enum report): Renamed from enum report_e.
543 * src/gram.h (item_number): Renamed from item_number_t.
544 (rule_number): Renamed from rule_number_t.
545 (struct rule_s): Remove the "rule_s" part; not used.
546 (rule): Renamed from rule_t.
547 (rule_filter): Renamed from rule_filter_t.
548 * src/lalr.c (struct goto_list): Renamed from struct goto_list_s.
549 (goto_list): Renamed from goto_list_t.
550 * src/lalr.h (goto_number): Renamed from goto_number_t.
551 * src/location.h (location): Renamed from location_t.
552 * src/muscle_tab.c (muscle_entry): Renamed from muscle_entry_t,
553 and moved here from:
554 * src/muscle_tab.h (muscle_entry_t): here.
555 * src/nullable.c (struct rule_list): Renamed from struct rule_list_s.
556 (rule_list): Renamed from rule_list_t.
557 * src/print_graph.c (static_graph): Renamed from graph.
558 * src/reader.h (braced_code): Renamed from braced_code_t.
559 Remove brace_code_e tag.
560 * src/relation.h (relation_node): Renamed from relation_node_t.
561 (relation_nodes): Renamed from relation_nodes_t.
562 (relation): Renamed from relation_t.
563 * src/state.h (state_number): Renamed from state_number_t.
564 (struct state): Renamed from struct state_s.
565 (state): Renamed from state_t.
566 (transitions): Renamed from transitions_t. Unused (and
567 misspelled) transtion_s tag removed.
568 (errs): Renamed from errs_t. Unused errs_s tag removed.
569 (reductions): Renamed from reductions_t. Unused tag
570 reductions_s removed.
571 * src/symlist.h (symbol_list): Renamed from symbol_list_t.
572 (struct symbol_list): Renamed from struct symbol_list_s.
573 * src/symtab.h (symbol_number): Renamed from symbol_number_t.
574 (struct symbol): Renamed from struct symbol_s.
575 (symbol): Renamed from symbol_t.
576 * src/tables.c (vector_number): Renamed from vector_number_t.
577 (action_number): Renamed from action_t.
578 * src/tables.h (base_number): Renamed from base_t.
579 * src/vcg.h (enum color): Renamed from enum color_e.
580 (enum textmode): Renamed from enum textmode_e.
581 (enum shape): Renamed from enum shape_e.
582 (struct colorentry): Renamed from struct colorentry_s.
583 (struct classname): Renamed from struct classname_s.
584 (struct infoname): Renamed from struct infoname_s.
585 (enum layoutalgorithm): Renamed from enum layoutalgorithm_e.
586 (enum decision): Renamed from enum decision_e.
587 (enum orientation): Renamed from enum orientation_e.
588 (enum alignment): Renamed from enum alignment_e.
589 (enum arrow_mode): Renamed from enum arrow_mode_e.
590 (enum crossing_type): Renamed from enum crossing_type_e.
591 (enum view): Renamed from enum view_e.
592 (struct node): Renamed from struct node_s.
593 (node): Renamed from node_t.
594 (enum linestyle): Renamed from enum linestyle_e.
595 (enum arrowstyle): Renamed from enum arrowstyle_e.
596 (struct edge): Renamed from struct edge.
597 (edge): Renamed from edge_t.
598 (struct graph): Renamed from struct graph_s.
599 (graph): Renamed from graph_t.
600 * tests/calc.at (_AT_DATA_CALC_Y, Simple LALR Calculator):
601 Rename value_t -> value.
602 * tests/input.at (Torturing the Scanner): Rename value_t -> value,
603 value_t_as_yystype -> value_as_yystype.
604
605 Don't include <errno.h> in the mainstream code, since it
606 reserves E[A-Z0-9]* and we want to use symbols like 'EQUALS'.
607 * lib/get-errno.c, lib/get-errno.h: New files.
608 * lib/Makefile.am (libbison_a_SOURCES): Add get-errno.h,
609 get-errno.c.
610 * src/files.c (xfopen, xfclose): Use get_errno instead of errno.
611 * src/output.c (output_skeleton): Likewise.
612 * src/scan-gram.l (<INITIAL>{int}): Use set_errno and get_errno
613 instead of errno.
614 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>\\x[0-9abcdefABCDEF]+):
615 Likewise.
616 (handle_action_dollar, handle_action_at): Likewise.
617 * src/system.h: Do not include <errno.h>.
618 (TAB_EXT): Renamed from EXT_TAB.
619 (OUTPUT_EXT): Renamed from EXT_OUTPUT.
620
621 Avoid str[a-z]*, since <string.h> reserves that name space.
622 Change all instances of "struniq" in names to "uniqstr", and
623 likewise for "STRUNIQ" and "UNIQSTR".
624 * src/uniqstr.c: Renamed from src/struniq.c.
625 * src/uniqstr.h: Renamed from src/struniq.h.
626 * src/Makefile.am (bison_SOURCES): Adjust to these renamings.
627 * src/files.c (strsuffix): Remove; unused.
628 (concat2): Renamed from stringappend. Now static.
629 * src/files.h (strsuffix, stringappend): Remove; unused.
630 * src/parse-gram.y (<chars>): Renamed from <string>.
631 (<uniqstr>): Renamed from <struniq>.
632 * src/scan-gram.l (obstack_for_string): Renamed from string_obstack.
633 * src/vcg.h (struct node_s.expand): Renamed from struct node_s.stretch.
634 (struct graph_s.expand): Renamed from struct graph_s.stretch.
635 * src/vcg_defaults.h (G_EXPAND): Renamed from G_STRETCH.
636 (G_LONG_STRAIGHT_PHASE): Renamed from G_STRAIGHT_PHASE.
637 (N_EXPAND): Renamed from N_STRETCH.
638
639 Avoid *_MAX and *_MIN, since <limits.h> reserves that name space.
640 * data/yacc.c (YYSTACK_GAP_MAXIMUM): Renamed from YYSTACK_GAP_MAX.
641 * src/gram.h (ITEM_NUMBER_MAX, ITEM_NUMBER_MIN, RULE_NUMBER_MAX):
642 Remove; unused.
643 * src/lalr.h (GOTO_NUMBER_MAXIMUM): Renamed from GOTO_NUMBER_MAX.
644 * src/state.h (STATE_NUMBER_MAXIMUM): Renamed from STATE_NUMBER_MAX.
645 * src/symtab.h (SYMBOL_NUMBER_MAXIMUM): Renamed from SYMBOL_NUMBER_MAX.
646 * src/tables.c (VECTOR_NUMBER_MAX, VECTOR_NUMBER_MIN): Remove; unused.
647 (BASE_MAXIMUM): Renamed from BASE_MAX.
648 (BASE_MINIMUM): Renamed from BASE_MIN.
649 (ACTION_MAX): Remove; unused.
650 (ACTION_NUMBER_MINIMUM): Renamed from ACTION_MIN.
651 Unnecessary casts removed from above defines.
652
653
654 Fix misspelling in names.
655 * src/vcg.h (enum_alignment_e): Renamed from enum_alignement_e.
656 * src/vcg_defaults.h (G_NODE_ALIGNMENT): Renamed from
657 G_NODE_ALIGNEMENT.
658
659
660 * lib/timevar.c (timevar_report): Renamed from time_report,
661 for consistency with other names.
662 * lib/timevar.h (timevar_report): New decl.
663 * src/system.h (time_report): Remove; decl is now in lib/timevar.h.
664
665
666 Sort include-file uses.
667
668 Reorder all include files under src to be in the order "system.h".
669 then the ../lib include files in angle brackets (alphabetized),
670 then the . include files in double-quotes (alphabetized). Fix
671 dependency breakages encountered in this process, as follows:
672 * src/closure.h, src/derives.h, src/state.h: Include "gram.h".
673 * src/complain.c: Don't include stdlib.h, string.h _LIBC stuff.
674 * src/state.h: Include "symtab.h".
675
996b1c7e
PE
6762002-12-08 Paul Eggert <eggert@twinsun.com>
677
678 * data/glr.c, data/lalr1.cc, data/yacc.c: Do not use __file__,
679 since this causes problems when __file__ contains character
680 sequences like "@" that are treated specially by src/scan-skel.l.
681 Instead, just use the file's basename. This fixes the bug
682 reported by Martin Mokrejs in
e3aa65c5 683 <http://mail.gnu.org/archive/html/bug-bison/2002-12/msg00007.html>.
996b1c7e 684
e19c4e5d
PE
6852002-12-06 Paul Eggert <eggert@twinsun.com>
686
687 Add support for rules that do not have trailing semicolons, as
688 POSIX requires. Improve the quality of locations in Bison
689 diagnostics.
26b4a969 690
e19c4e5d
PE
691 * src/location.c: Include <quotearg.h>.
692 (empty_location): Now const.
693 (location_print): New function. Follow the recommendation of the
694 GNU Coding Standards for locations that span file boundaries.
695 * src/location.h: Do not include <quotearg.h>; no longer needed.
696 (boundary): New type.
697 (location_t): Use it. This allows locations to span file boundaries.
698 All member uses changed: file -> start.file or end.file (as needed),
699 first_line -> start.line, first_column -> start.column,
700 last_line -> end.line, last_column -> end.column.
701 (equal_boundaries): New function.
702 (LOCATION_RESET, LOCATION_STEP): Remove.
703 (LOCATION_PRINT): Remove. All callers changed to use location_print.
704 (empty_location): Now const.
705 (location_print): New decl.
706 * src/parse-gram.y (lloc_default): New function, which handles
707 empty locations more accurately.
708 (YYLLOC_DEFAULT): Use it.
709 (%token COLON): Remove.
710 (%token ID_COLON): New token.
26b4a969 711 (rules): Use it.
e19c4e5d
PE
712 (declarations, rules): Remove trailing semicolon.
713 (declaration, rules_or_grammar_declaration):
714 Allow empty (";") declaration.
715 (symbol_def): Remove empty actions; no longer needed.
716 (rules_or_grammar_declaration): Remove trailing semicolon.
717 (semi_colon.opt): Remove.
718 * src/reader.h: Include location.h.
719 (scanner_cursor): New decl.
720 * src/reduce.c (nonterminals_reduce): Use warn_at rather than
721 rolling our own.
722 * src/scan-gram.l (YY_USER_INIT): Initialize scanner_cursor instead
723 of *loc.
724 (STEP): Remove. No longer needed, now that adjust_location does
725 the work. All uses removed.
726 (scanner_cursor): New var.
727 (adjust_location): Renamed from extend_location. It now sets
728 *loc and adjusts the scanner cursor. All uses changed.
729 Don't bother testing for CR.
730 (handle_syncline): Remove location arg; now updates scanner cursor.
731 All callers changed.
732 (unexpected_end_of_file): Now accepts start boundary of token or
733 comment, not location. All callers changed. Update scanner cursor,
734 not the location.
735 (SC_AFTER_IDENTIFIER): New state.
736 (context_state): Renamed from c_context. All uses changed.
737 (id_loc, code_start, token_start): New local vars.
738 (<INITIAL,SC_AFTER_IDENTIFIER>): New initial context. Move all
739 processing of Yacc white space and equivalents here.
740 (<INITIAL>{id}): Save id_loc. Begin state SC_AFTER_IDENTIFIER
741 instead of returning ID immediately, since we need to search for
742 a subsequent colon.
743 (<INITIAL>"'", "\""): Save token_start.
744 (<INITIAL>"%{", "{", "%%"): Save code_start.
745 (<SC_AFTER_IDENTIFIER>): New state, looking for a colon.
746 (<SC_YACC_COMMENT>, <SC_COMMENT>, <SC_LINE_COMMENT>):
747 BEGIN context_state at end, not INITIAL.
748 (<SC_ESCAPED_STRING>"\"", <SC_ESCAPED_CHARACTER>"'",
749 <SC_BRACED_CODE>"}", <SC_PROLOGUE>"%}", <SC_EPILOGUE><<EOF>>):
750 Return correct token start.
751 (<SC_BRACED_CODE,SC_PROLOGUE,SC_EPILOGUE>): Save start boundary when
752 the start of a character, string or multiline comment is found.
753 * tests/conflicts.at (S/R in initial, Defaulted Conflicted
754 Reduction): Adjust reported locations to match the more-precise
755 results now expected.
756 * tests/input.at (Invalid $n, Invalid @n, Type Clashes): Likewise.
757 * tests/reduce.at (Useless Rules, Reduced Automaton,
758 Underivable Rules): Likewise.
759 * tests/regression.at (Invalid inputs): No longer `expecting ";"
760 or "|"' now that so many other tokens are allowed by the new grammar.
761
762 * src/complain.h (current_file): Remove duplicate decl;
763 current_file is now owned by files.h.
764 * src/complain.c, src/scan-gram.l: Include files.h.
765
7662002-12-06 Paul Eggert <eggert@twinsun.com>
26b4a969 767
e19c4e5d
PE
768 * data/glr.c (yy_reduce_print): Don't assume that yyrline[yyrule]
769 promotes to int; it might be unsigned int.
770 * data/yacc.c (yy_reduce_print): Likewise.
771
772 * doc/bison.texinfo (Table of Symbols): YYERROR_VERBOSE should
773 be #defined in the prologue, not in the Bison declarations.
774 This fixes Debian Bug 102878, reported by Shaul Karl.
26b4a969 775
b64755e3
PE
7762002-12-02 Paul Eggert <eggert@twinsun.com>
777
778 * configure.ac (AC_REPLACE_FUNCS): Add strtoul.
779 * lib/strtoul.c: New file, from gnulib.
780 This fixes a porting bug reported by Peter Klein in
e3aa65c5 781 <http://mail.gnu.org/archive/html/bug-bison/2002-12/msg00000.html>.
b64755e3 782
6e746484
PE
7832002-11-30 Paul Eggert <eggert@twinsun.com>
784
b64755e3
PE
785 * src/scan-gram.l (no_cr_read, extend_location): Move to epilogue,
786 and put only a forward declaration in the prologue. This is for
787 consistency with the other scanner helper functions.
788
6ba55592
PE
789 Type clashes now generate warnings, not errors, since it
790 appears that POSIX may allow some grammars with type clashes.
791 * src/reader.c (grammar_current_rule_check): Warn about
792 type clashes instead of complaining.
793 * tests/input.at (Type Clashes): Expect warnings, not complaints.
794
6e746484
PE
795 Add Yacc library, since POSIX requires it.
796 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
797 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
798 * lib/main.c, lib/yyerror.c: New files.
799
800 gram_error can be static; it need not be extern.
801 * src/reader.h (gram_error): Remove decl.
802 * src/parse-gram.y (gram_error): Now static. Add static decl.
803 (print_token_value): Omit parameter names from forward decl,
804 for consistency.
805
88510f9c
PE
8062002-11-29 Paul Eggert <eggert@twinsun.com>
807
6e746484
PE
808 * doc/bison.texinfo: Emphasize that yylex and yyerror must
809 be declared before being used. E.g., one should typically
810 declare them in the prologue. Use GNU coding style in examples.
811 Put "const" consistently after the type it modifies. Mention
812 that C99 supports "inline". Mention that yyerror traditionally
813 returns "int".
814
88510f9c
PE
815 %parse-param and %lex-param now take just one argument, the
816 declaration; the argument name is deduced from the declaration.
817
818 * doc/bison.texinfo (Parser Function, Pure Calling, Error
819 Reporting, Table of Symbols): Document this.
820 * src/parse-gram.y (add_param): New function.
821 (COMMA): Remove.
822 (declaration): Implement new rule for %parse-param and %lex-param.
823 * src/scan-gram.l: "," now elicits a warning, rather than being
824 a token; this is more compatible with byacc.
825 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
826
bb92250c
PE
8272002-11-27 Paul Eggert <eggert@twinsun.com>
828
829 Rename identifiers to avoid real and potential collisions.
830
831 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
832 to avoid collision with lex macro described by Bruce Lilly in
e3aa65c5 833 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00114.html>.
bb92250c
PE
834 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
835 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
836 * src/parse-gram.y (print_token_value): Renamed from yyprint.
837 All uses changed.
838 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
839 The name "yycontrol" violates the name space rules, and this stuff
840 wasn't being used anyway.
841 (input): Remove action; this stuff wasn't being used.
842 (gram_error): Rename local variable yylloc -> loc.
843 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
844 (YY_DECL): Don't use "yy" at start of local variables.
845 All uses changed, e.g., yylloc -> loc.
846 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
847 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
848 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
849 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
850
851 * src/parse-gram.y (gram_error): loc is now const *.
852 * src/reader.h (gram_error): Likewise.
853
3af4feb2
PE
8542002-11-24 Paul Eggert <eggert@twinsun.com>
855
856 Version 1.75c.
857
858 * tests/actions.at (Actions after errors): Use an output format
859 more similar to that of the Printers and Destructors test.
860 Test the position of the ';' token too.
861 (Printers and Destructors): Likewise.
862 (Printers and Destructors: %glr-parser): Remove for now, to avoid
863 unnecessarily alarming people when the test fails.
864
865 * data/yacc.c (yyerrlab1): Move this label down, so that the
866 parser does not discard the lookahead token if the user code
867 invokes YYERROR. This change is required for POSIX conformance.
868
869 * lib/error.c: Sync with gnulib.
870
8712002-11-22 Paul Eggert <eggert@twinsun.com>
872
873 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
874 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
875 * lib/xmalloc.c: Likewise.
26b4a969 876
58004308
PE
8772002-11-20 Paul Eggert <eggert@twinsun.com>
878
879 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
880
8812002-11-20 Paul Eggert <eggert@twinsun.com>
26b4a969 882
58004308
PE
883 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
884 should use `if (! x) abort ();' rather than `assert (x);', and
885 anyway it's one less thing to worry about configuring.
886
887 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
888 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
889 and replace all instances of assert with abort.
890 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
891 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
892
893 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
894 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
895 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
896 hash_find_entry, hash_rehash, hash_insert): Likewise.
897 * src/conflicts.c (resolve_sr_conflict): Likewise.
898 * src/lalr.c (set_goto_map, map_goto): Likewise.
899 * src/nullable.c (nullable_compute): Likewise.
900 * src/output.c (prepare_rules, token_definitions_output): Likewise.
901 * src/reader.c (packgram, reader): Likewise.
902 * src/state.c (state_new, state_free, state_transitions_set,
903 state_reduction_find): Likewise.
904 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
905 symbol_pack): Likewise.
906 * src/tables.c (conflict_row, pack_vector): Likewise.
907 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
908 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
909 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
910 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
911
912 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
913 (ARGMATCH_CONSTRAINT): New macro.
914 (ARGMATCH_ASSERT): Use it.
915
916 * src/system.h (verify): New macro.
917 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
918 rather than assert.
919 * src/tables.c (tables_generate): Likewise.
920
921 * src/struniq.c (struniq_assert): Now returns void, and aborts
922 if the assertion is false.
923 (struniq_assert_p): Remove.
924 * src/struniq.h: Likewise.
925
76ae8198
PE
9262002-11-18 Paul Eggert <eggert@twinsun.com>
927
928 * data/glr.c (yygetLRActions): Replace `yyindex' with
929 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
930 This fixes the regression with Sun ONE Studio 7 cc that I reported in
e3aa65c5 931 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00077.html>.
76ae8198 932
d3c4e709
AD
9332002-11-18 Akim Demaille <akim@epita.fr>
934
935 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
936 space.
937 From Tim Van Holder.
938
8d8a7238
PE
9392002-11-17 Paul Eggert <eggert@twinsun.com>
940
941 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
942 to "SyntaxError" for consistency with my 2002-11-15 change.
943
944 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
945 not define to {}, since this breaks the common use of `YYDPRINTF
946 ((...));' if a single statement is desired (e.g. before `else').
947 Work around GCC warnings by surrounding corresponding calls with
948 {} if needed.
949 (yyhasResolvedValue): Remove unused function.
950 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
951 loop body.
952 (yyreportSyntaxError): Renamed from yyreportParseError.
953 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
954 All uses changed.
955 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
956 extern when possible. Remove unused initializations.
957
b0937b22
AD
9582002-11-16 Akim Demaille <akim@epita.fr>
959
960 Augment the similarity between GLR and LALR traces.
961
962 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
963 (YY_REDUCE_PRINT): New.
964 (yyparse): Use them.
965 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
966 YYDPRINT here.
967 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
968 state reached after the reduction/recovery, since...
969 (yyparse, yyprocessOneStack): Report the state we are entering in.
970
c5e3e510
AD
9712002-11-16 Akim Demaille <akim@epita.fr>
972
973 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
974 Add support for --trace=skeleton.
975 * src/scan-skel.l: %option debug.
976 Scan strings of non-@ or \n instead of character by character.
977 (scan_skel): Handle trace_skeleton.
978 (QPUTS): New.
979 (@output_parser_name@, @output_header_name@): ``Restore'' their
980 support (used to be M4 macros).
981 * data/yacc.c: Quote larger chunks, a la glr.c.
982 * data/lalr1.cc: Likewise.
983 The header guards are no longer available, so use some other
984 string than `YYLSP_NEEDED'.
985
4c6cc1db
AD
9862002-11-16 Akim Demaille <akim@epita.fr>
987
988 Make the ``Printers and Destructors'' test more verbose, taking
989 `yacc.c''s behavior as (possibly wrong) reference.
990
991 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
992 instead of fprint on stdout.
993 Set and report the last_line of the symbols.
994 Consistently display values and locations.
995
6d9e8019
PE
9962002-11-16 Paul Eggert <eggert@twinsun.com>
997
998 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
999
6e649e65
PE
10002002-11-15 Paul Eggert <eggert@twinsun.com>
1001
b25d88f6
PE
1002 * tests/actions.at (Actions after errors): New test case.
1003
6e649e65
PE
1004 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
1005 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
1006 tests/action.at, tests/calc.at, tests/conflicts.at,
1007 tests/cxx-type.at, tests/regression.at:
1008 "parse error" -> "syntax error" for POSIX compatibility.
1009 "parsing stack overflow..." -> "parser stack overflow" so
1010 that code matches Bison documentation.
1011
0f39aab9
AD
10122002-11-15 Akim Demaille <akim@epita.fr>
1013
1014 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
1015 take two BRACED_CODE, not two string_content.
1016 Free the scanner's obstack when we are done.
1017 (code_content): New.
1018 * tests/calc.at: Adjust.
1019 * doc/bison.texinfo: Adjust.
1020 Also, make sure to include the `,' for these declarations.
1021
761c1926
AD
10222002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
1023
1024 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
1025 definition; avoids potential autoreconf problems.
1026
b0f98b10
AD
10272002-11-15 Akim Demaille <akim@epita.fr>
1028
1029 Always check the value returned by yyparse.
1030
1031 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
1032 returned by yyparse.
1033 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
1034 Adjust calls.
1035 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
1036 returned by yyparse.
1037
970785f1
PH
10382002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1039
1040 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
1041 on input.at test.
1042
8fcc7db1
PE
10432002-11-14 Paul Eggert <eggert@twinsun.com>
1044
7ec1b48e
PE
1045 * src/output.c (output_skeleton): Call xfopen instead of
1046 duplicating xfopen's body.
1047
cfff7583 1048 Fix bugs reported by Nelson H. F. Beebe in
e3aa65c5 1049 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00078.html>.
cfff7583 1050
8fcc7db1
PE
1051 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
1052 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
1053 Group compiler. Instead, use "$CC -E bar.c". Include the .h
1054 file twice in the grammar, as an extra check.
1055
1056 * tests/input.at (Torturing the Scanner): Surround the
1057 backslash-newline tests with "#if 0", to make it less likely that
1058 we'll run into compiler bugs. Bring back solitary \ inside
1059 comment, but add a closing comment to work around HP C bug. Don't
e3aa65c5 1060 test backslash-newline in C character constant.
8fcc7db1 1061
4e8d992c
AD
10622002-11-14 Akim Demaille <akim@epita.fr>
1063
1064 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
1065 status of the compiler.
f32b346d 1066 Calling `exit 1' is no longer needed.
4e8d992c
AD
1067 Reported by Nelson H. F. Beebe.
1068
9501dc6e
AD
10692002-11-14 Akim Demaille <akim@epita.fr>
1070
1071 * tests/atlocal.in (CPPFLAGS): We have config.h.
1072 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
1073 New.
1074 * tests/actions.at, tests/calc.at, tests/conflicts.at,
1075 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
1076 * tests/regression.at, tests/torture.at: Use them for all the
1077 grammars that are to be compiled.
1078 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
1079 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
1080 * doc/bison.texinfo (GLR Parsers): Document `inline'.
1081
18b519c0
AD
10822002-11-14 Akim Demaille <akim@epita.fr>
1083
1084 * doc/bison.texinfo: Various formatting changes (alignments in
1085 samples, additional @group/@end group, GCS in samples.
1086 Use @deffn instead of simple @table to define the directives,
1087 macros, variables etc.
1088
9a86cdb9
PE
10892002-11-13 Paul Eggert <eggert@twinsun.com>
1090
daa33def 1091 Fix some bugs reported by Albert Chin-A-Young in
e3aa65c5 1092 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00066.html>.
18b519c0 1093
daa33def 1094 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
8fcc7db1 1095 -o c"; the HP C compiler chatters during compilation.
daa33def
PE
1096 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
1097 * tests/headers.at (export YYLTYPE): Likewise.
1098
1099 * tests/input.at (Torturing the Scanner): Remove lines containing
8fcc7db1 1100 solitary backslashes, as they tickle a bug in the HP C compiler.
daa33def 1101
9a86cdb9
PE
1102 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
1103 comments, since they're not portable. Use GNU coding style.
1104
9c1e26bd
AD
11052002-11-13 Akim Demaille <akim@epita.fr>
1106
1107 * data/yacc.c: Leave bigger chunks of quoted text.
1108 (YYDSYMPRINTF): New.
1109 Use it to report symbol activities.
1110 * data/glr.c (YYDSYMPRINTF): New.
1111 Use it.
1112
87f721cc
PE
11132002-11-12 Paul Eggert <eggert@twinsun.com>
1114
1115 Version 1.75b.
1116
1117 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
1118 (yyglrReduce): Return yyok, not 0.
1119 This should avoid the enumerated-type warnings reported
464c6927 1120 by Nelson H. F. Beebe in
e3aa65c5 1121 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00057.html>.
87f721cc
PE
1122
1123 * lib/bbitset.h (BITSET_INLINE): Remove.
1124 * lib/bitset.h [! BITSET_INLINE]: Remove.
1125 (bitset_set, bitset_reset, bitset_test): Rename local vars
1126 to avoid shadowing warnings by GCC.
1127
1128 * data/glr.c (inline): Remove #define. It's the user's
1129 responsibility to #define it away, just like 'const'.
464c6927 1130 This fixes one of the bugs reported by Nelson H. F. Beebe in
e3aa65c5 1131 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00058.html>.
18b519c0 1132
87f721cc
PE
1133 * Makefile.maint (po-check): Scan .l and .y files instead of the
1134 .c and the .h files that they generate. This fixes the bug
1135 reported by Tim Van Holder in:
e3aa65c5 1136 <http://mail.gnu.org/archive/html/bison-patches/2002-11/msg00062.html>
87f721cc
PE
1137 Look for N_ as well as for _. Try to avoid matching #define for
1138 N_ and _.
1139 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
1140 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
1141 * src/scan-gram.l: Revamp regular expressions so that " and '
1142 do not confuse xgettext.
1143
1144 * src/struniq.h (struniq_new): Do not declare the return type
1145 to be 'const'; this violates the C standard.
1146 * src/struniq.c (struniq_new): Likewise.
1147
be14ade5
AD
11482002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
1149
1150 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
1151 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
1152 linker.
1153
05291fbc
AD
11542002-11-12 Akim Demaille <akim@epita.fr>
1155
1156 * Makefile.maint: Sync with Autoconf:
1157 (local_updates): New.
1158
1f5fd52e
AD
11592002-11-12 Akim Demaille <akim@epita.fr>
1160
1161 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
1162
283f1e64
AD
11632002-11-12 Akim Demaille <akim@epita.fr>
1164
1165 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
1166 locations.
1167
886b69d1
AD
11682002-11-12 Akim Demaille <akim@epita.fr>
1169
1170 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
1171 not yyvalue.
1172
3df37415
AD
11732002-11-12 Akim Demaille <akim@epita.fr>
1174
1175 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
1176 Use it to test the GLR parser.
1177
7bd6c77e
AD
11782002-11-12 Akim Demaille <akim@epita.fr>
1179
1180 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
1181 defines it.
1182 * data/glr.c (yystos): New.
1183 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
1184 (YYDSYMPRINT): New.
1185 (yyval): Don't define it, it is handled via M4.
1186 (yyrecoverParseError): Free verbosely the discarded symbols.
1187 * data/yacc.c (yysymprint): Remove, rather...
1188 (b4_yysymprint_generate): invoke.
1189 * data/c.m4 (b4_yysymprint_generate): New.
1190 Accept pointers as arguments, as opposed to the version from
1191 yacc.c.
1192 (b4_yydestruct_generate): Likewise.
1193 * tests/cations.at (Printers and Destructors): Use Bison directives
1194 instead of CPP macros.
1195 Don't rely on internal details.
1196
b0400cc6
AD
11972002-11-12 Akim Demaille <akim@epita.fr>
1198
1199 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
1200 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
1201 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
1202 it against YYEMPTY and so forth), work on yytoken (i.e., set
1203 it to YYEMPTY etc.).
1204 (yydestruct): Replace with a b4_yydestruct_generate invocation.
1205 (b4_symbol_actions): Remove.
1206 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
1207 for 0, end-of-input.
1208
72f889cc
AD
12092002-11-12 Akim Demaille <akim@epita.fr>
1210
1211 * doc/bison.texinfo (Destructor Decl): New.
1212
b1ae9233
AD
12132002-11-12 Akim Demaille <akim@epita.fr>
1214
1215 * src/tables.c (tables_generate): Use free for pointers that
1216 cannot be NULL, not XFREE.
1217 (pack_vector): Use assert, not fatal, for bound violations.
1218 * src/state.c (state_new): Likewise.
1219 * src/reader.c (reader): Likewise.
1220 * src/lalr.c (set_goto_map): Likewise.
72f889cc 1221 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
b1ae9233
AD
1222 the file name.
1223
7ec2d4cd
AD
12242002-11-12 Akim Demaille <akim@epita.fr>
1225
1226 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
1227 Restore.
1228 * src/scan-gram.l (last_string): Is global to the file, not to
1229 yylex.
1230 * src/parse-gram.y (input): Don't append the epilogue here,
1231 (epilogue.opt): do it here, and free the scanner's obstack.
1232 * src/reader.c (epilogue_set): Rename as...
1233 (epilogue_augment): this.
1234 * data/c.m4 (b4_epilogue): Defaults to empty.
1235
573a6cd3
AD
12362002-11-12 Akim Demaille <akim@epita.fr>
1237
1238 * src/getargs.c (long_options): Remove duplicates.
1239 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
1240 Remove.
1241 * doc/bison.rnh: Remove.
1242 * doc/bison.texinfo (VMS Invocation): Remove.
1243
95612cfa
AD
12442002-11-12 Akim Demaille <akim@epita.fr>
1245
1246 * src/struniq.h, src/struniq.c (struniq_t): Is const.
1247 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
1248
1249 Use struniq for symbols.
1250
1251 * src/symtab.h (symbol_t): The tag member is a struniq.
1252 (symbol_type_set): Adjust.
1253 * src/symtab.c (symbol_new): Takes a struniq.
1254 (symbol_free): Don't free the tag member.
1255 (hash_compare_symbol_t, hash_symbol_t): Rename as...
1256 (hash_compare_symbol, hash_symbol): these.
1257 Use the fact that tags as struniqs.
1258 (symbol_get): Use struniq_new.
1259 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
1260 Returns a strniq.
1261 * src/reader.h (merger_list, grammar_currentmerge_set): The name
1262 and type members are struniqs.
1263 * src/reader.c (get_merge_function)
1264 (grammar_current_rule_merge_set): Adjust.
1265 (TYPE, current_type): Are struniq.
1266
1267 Use struniq for file names.
1268
1269 * src/files.h, src/files.c (infile): Split into...
1270 (grammar_file, current_file): these.
1271 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
1272 * src/reduce.c (reduce_print): Likewise.
1273 * src/getargs.c (getargs): Likewise.
1274 * src/complain.h, src/complain.c: Likewise.
1275 * src/main.c (main): Call struniqs_new early enough to use it for
1276 file names.
1277 Don't free the input file name.
1278
3e6656f9
AD
12792002-11-12 Akim Demaille <akim@epita.fr>
1280
1281 * src/symtab.c (symbol_free): Remove dead deactivated code:
1282 type_name are properly removed.
1283 Don't use XFREE to free items that cannot be NULL.
1284 * src/struniq.h, src/struniq.c: New.
1285 * src/main.c (main): Initialize/free struniqs.
1286 * src/parse-gram.y (%union): Add astruniq member.
1287 (yyprint): Adjust.
1288 * src/scan-gram.l (<{tag}>): Return a struniq.
1289 Free the obstack bit that used to store it.
1290 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
1291
7672019c
PE
12922002-11-11 Paul Eggert <eggert@twinsun.com>
1293
1294 Revamp to fix many (but not all) of the C- and M4-related quoting
1295 problems. Among other things, this fixes the Bison bug reported
1296 by Jan Hubicka when processing the Bash grammar; see:
e3aa65c5 1297 <http://mail.gnu.org/archive/html/bison-patches/2002-11/msg00039.html>
7672019c
PE
1298
1299 Use new @ escapes consistently. Represent brackets with @{ and @}
1300 rather than @<:@ and @:>@, since this works a bit better with dumb
1301 editors like vi. Represent @ with @@, since @ is now consistently
1302 an escape. Use @oline@ and @ofile@ rather than __oline__ and
1303 __ofile__, to avoid unexpected expansions. Similarly, use @output
1304 rather than #output.
1305
1306 * data/c.m4 (b4_copyright): Omit file name from comment, since
1307 the file name could contain "*/".
1308 (b4_synclines_flag): Don't quote the 2nd argument; it should already
1309 be quoted. All uses changed.
1310
1311 * data/glr.c: Use new @ escapes consistently.
1312 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
1313 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
1314 Remove, since they couldn't handle arbitrary characters in file
1315 names.
1316 * data/lalr1.cc: Likewise.
1317 * data/yacc.c: Likewise.
1318
1319 * src/files.c (output_infix): Remove; all uses removed.
1320 * src/files.h: Likewise.
1321
1322 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
1323 mishandled funny characters in file names, and anyway it isn't
1324 needed any more.
1325 * data/yacc.c: Likewise.
1326 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
1327
1328 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
1329 * data/yacc.c: Likewise.
1330
1331 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
1332 strings now.
1333 (muscle_init): Quote filename as a C string.
1334 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
1335 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
1336 * src/output.c (escaped_file_name_output): New function.
1337 (prepare_symbols): Quote tokens for M4.
1338 (prepare): Don't insert output_infix, output_prefix,
1339 output_parser_name, output_header_name; this is now down by scan-skel.
1340 Insert skeleton as a C string.
1341
1342 * src/output.c (user_actions_output, symbol_destructors_output,
1343 symbol_printers_output): Quote filenames for C and M4.
1344 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1345
1346 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
1347 escapes other than \\ and \'; this simplifies the code.
1348 (<SC_STRING>): Likewise, for \\ and \".
1349 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
1350 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
1351 Use new escapes @{ and @} for [ and ].
1352
1353 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
1354 them with auto vars.
1355 Switch to new escape scheme, where @ is the escape character uniformly.
1356 Abort if a stray escape character is found. Avoid unbounded input
1357 buffer when parsing non-escaped text.
1358
1359 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
1360 __oline__, #output, $@, and @{ do not have unintended meanings.
1361
acea4f3b
PE
13622002-11-09 Paul Eggert <eggert@twinsun.com>
1363
1364 Fix the test failure due to GCC warnings described in
e3aa65c5 1365 <http://mail.gnu.org/archive/html/bug-bison/2002-11/msg00000.html>.
acea4f3b
PE
1366 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
1367 evaluate to 0 if it's impossible for NINF to be in the respective
1368 table.
1369 (yygetLRActions, yyrecoverParseError): Use them.
1370
1371 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
1372 counted in the token inserted at end of file. Now takes
1373 location_t *, not location_t, so that the location can be
1374 adjusted. All uses changed.
1375
1376 * tests/regression.at (Invalid inputs): Adjust wording in
1377 diagnostic to match the new behavior.
1378
1379 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
1380 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
1381 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
1382 abort ();'. This reduces the runtime of the "Many lookaheads"
1383 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
1384 GCC 3.2.
1385
20ef1ad5
PE
13862002-11-07 Paul Eggert <eggert@twinsun.com>
1387
1388 * src/parse-gram.y (CHARACTER): Remove unused token.
1389 All uses removed.
1390
1391 * src/scan-gram.l: Remove stack option. We no longer use the
1392 stack, since the stack was never deeper than 1; instead, use the
1393 new auto var c_context to record the stacked value.
1394
1395 Remove nounput option. At an unexpected end of file, we now unput
1396 the minimal input necessary to end cleanly; this simplifies the
1397 code.
1398
1399 Avoid unbounded token sizes where this is easy.
1400
1401 (unexpected_end_of_file): New function.
1402 Use it to systematize the error message on unexpected EOF.
1403 (last-string): Now auto, not static.
1404 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
1405 (scanner_last_string_free): Remove; not used.
1406 (percent_percent_count): Move decl to just before use.
1407 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
1408 not the (never otherwised-used) CHARACTER.
1409
93724f13
AD
14102002-11-07 Akim Demaille <akim@epita.fr>
1411
1412 Let yyerror always receive the msg as last argument, so that
1413 yyerror can be variadic.
1414
1415 * data/yacc.c (b4_yyerror_args): New.
1416 Use it when calling yyerror.
1417 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
1418 Use it when calling yyerror.
1419 * doc/bison.texinfo (Error Reporting): Adjust.
1420 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
1421 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
1422
6e40b4eb
AD
14232002-11-06 Akim Demaille <akim@epita.fr>
1424
1425 #line should have quoted strings.
1426 Ideally, this should be done by m4_quotearg.
1427
1428 * src/scan-skel.l: Include quotearg.h.
1429 Quote __ofile__.
1430 * src/output.c (symbol_printers_output)
1431 (symbol_destructors_output): Quote the file name.
1432
2dfbfc12
AD
14332002-11-06 Akim Demaille <akim@epita.fr>
1434
1435 * tests/regression.at (Invalid inputs): Adjust to the recent
1436 messages.
1437
437c2d80
AD
14382002-11-06 Akim Demaille <akim@epita.fr>
1439
1440 Restore --no-lines.
1441 Reported by Jim Kent.
1442
1443 * data/c.m4 (b4_syncline): New.
1444 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
1445 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
1446 * src/output.c (user_actions_output): Likewise.
1447 (prepare): Define 'b4_synclines_flag'.
2dfbfc12 1448 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
437c2d80 1449
900c5db5
AD
14502002-11-06 Akim Demaille <akim@epita.fr>
1451
1452 * src/main.c (main): Free `infile'.
1453 * src/scan-gram.l (handle_syncline): New.
1454 Recognize `#line'.
1455 * src/output.c (user_actions_output, symbol_destructors_output)
1456 (symbol_printers_output): Use the location's file name, not
1457 infile.
1458 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1459
e183b123 14602002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
51b4a04c 1461
e183b123 1462 * src/tables.c (matching_state): Don't allow states to match if
51b4a04c 1463 either has GLR conflict entries.
e183b123 1464
193eb6b7
PE
14652002-11-05 Paul Eggert <eggert@twinsun.com>
1466
e183b123
PE
1467 * src/scan-gram.l: Use more accurate diagnostics, e.g.
1468 "integer out of range" rather than "invalid value".
1469 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
1470 accordingly.
1471
193eb6b7
PE
1472 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
1473 Also, remove one static variable in the scanner.
1474
1475 * src/scan-gram.l (braces_level): Now auto, not static.
1476 Initialize to zero if the compiler is being picky.
1477 (INITIAL): Clear braces_level instead of incrementing it.
1478 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
1479 as POSIX 1003.1-2001 requires.
1480 * src/system.h (IF_LINT): New macro, taken from coreutils.
1481 * configure.ac: Define "lint" if --enable-gcc-warnings.
1482
29c01725
AD
14832002-11-05 Akim Demaille <akim@epita.fr>
1484
1485 * src/scan-gram.l: When it starts with `%', complain about the
1486 whole directive, not just that `invalid character: %'.
1487
8aeac3ca
AD
14882002-11-04 Akim Demaille <akim@epita.fr>
1489
1490 * Makefile.maint: Update from Autoconf.
1491 (update, cvs-update, po-update, do-po-update): New.
1492
793a58bb
AD
14932002-11-04 Akim Demaille <akim@epita.fr>
1494
1495 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
1496 and yyerror.
1497 Have yyerror `use' its arguments.
1498 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
1499 returns true when location & yacc & pure & parse-param.
1500 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
1501
c4d720cd
AD
15022002-11-04 Akim Demaille <akim@epita.fr>
1503
1504 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
1505 clashes.
1506 * src/scan-gram.l: Use [\'] instead of ['] to pacify
1507 font-lock-mode.
1508 Use complain_at.
1509 Use quote, not quote_n since LOCATION_PRINT no longer uses the
1510 slot 0.
1511
613a0dc5
PE
15122002-11-03 Paul Eggert <eggert@twinsun.com>
1513
1514 * src/reader.c (get_merge_function, grammar_current_rule_check):
1515 Use consistent diagnostics for reporting type name clashes.
1516 Quote the types with <>, for consistency with Yacc.
1517 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
1518
2a8d363a
AD
15192002-11-03 Akim Demaille <akim@epita.fr>
1520
1521 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
1522 New.
1523 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
1524 (b4_parse_param): Remove.
1525 Use b4_identification.
1526 Propagate b4_pure_args where needed to pass them to yyerror.
1527 * data/glr.m4 (b4_parse_param): Remove.
1528 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
1529 (b4_lpure_formals): New.
1530 Use b4_identification.
1531 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
1532 b4_user_formals and b4_user_args.
1533 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
1534 (yyreportAmbiguity): When using a pure parser, also need
1535 the location, and the parse-params.
1536 Adjust callers.
1537 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
1538 When using a pure parser, also need the parse-params.
1539 Adjust callers.
1540 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
1541 (%pure-parser + %parse-param) LALR and GLR parsers.
1542 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
1543 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
1544 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
1545 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
1546 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
1547 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
1548 * doc/bison.texinfo: Untabify the whole file.
1549 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
1550 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
1551 (Error Reporting): Adjust to these new directives.
1552 Document %error-verbose, deprecate YYERROR_VERBOSE.
1553
9e32add8
AD
15542002-11-03 Akim Demaille <akim@epita.fr>
1555
1556 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
1557 AT_CHECK_CALC_GLR invocations to use % directives, instead of
1558 command line options.
1559 * tests/cxx-type.at: Formatting changes.
1560
b02d90a5
PE
15612002-11-03 Paul Eggert <eggert@twinsun.com>
1562
1563 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
1564 to count columns correctly, and to check for invalid inputs.
9e32add8 1565
b02d90a5
PE
1566 Use mbsnwidth to count columns correctly. Account for tabs, too.
1567 Include mbswidth.h.
1568 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
1569 (extend_location): New function.
1570 (YY_LINES): Remove.
1571
1572 Handle CRLF in C code rather than in Lex code.
1573 (YY_INPUT): New macro.
1574 (no_cr_read): New function.
1575
1576 Scan UCNs, even though we don't fully handle them yet.
1577 (convert_ucn_to_byte): New function.
1578
1579 Handle backslash-newline correctly in C code.
1580 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
1581 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
1582 all uses changed.
1583 (tag, splice): New EREs. Do not allow NUL or newline in tags.
1584 Use {splice} wherever C allows backslash-newline.
1585 YY_STEP after space, newline, vertical-tab.
1586 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
9e32add8 1587
b02d90a5
PE
1588 (letter, id): Don't assume ASCII; e.g., spell out a-z.
1589
1590 ({int}, handle_action_dollar, handle_action_at): Check for integer
1591 overflow.
9e32add8 1592
b02d90a5
PE
1593 (YY_STEP): Omit trailing semicolon, so that it's more like C.
1594
1595 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
1596 as well as \000. Check for UCHAR_MAX, not 255.
1597 Allow \x with an arbitrary positive number of digits, as in C.
1598 Check for overflow here.
1599 Allow \? and UCNs, for compatibility with C.
1600
1601 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
1602 with quote slot used by complain_at.
1603
1604 * tests/input.at: Add tests for backslash-newline, m4 quotes
1605 in symbols, long literals, and funny escapes in strings.
1606
1607 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
1608 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
1609 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
1610 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
1611 * m4/mbswidth.m4: New file, from GNU coreutils.
1612
1613 * doc/bison.texinfo (Grammar Outline): Document // comments.
1614 (Symbols): Document that trigraphs have no special meaning in Bison,
1615 nor is backslash-newline allowed.
1616 (Actions): Document that trigraphs have no special meaning.
1617
1618 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
1619 no longer used.
1620
16212002-11-02 Paul Eggert <eggert@twinsun.com>
1622
1623 * src/reader.c: Don't include quote.h; not needed.
1624 (get_merge_function): Reword warning to be consistent with
1625 type clash diagnostic in grammar_current_rule_check.
1626
1627 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
1628 bug in trigraph handling.
1629
1630 * src/output.c (prepare_symbols): When printing token names,
1631 escape "[" as "@<:@" and likewise for "]".
1632
1633 * src/system.h (errno): Remove declaration, as we are now
1634 assuming C89 or better, and C89 guarantees errno.
1635
762b212b
PE
16362002-10-30 Paul Eggert <eggert@twinsun.com>
1637
1638 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
1639 Check for close failures.
1640 * src/files.h (xfclose): Return void, not int, since it always
1641 returned zero.
1642 * src/files.c (xfclose): Likewise. Report I/O error if ferror
1643 indicates one.
1644 * src/output.c (output_skeleton): Use xfclose rather than fclose
1645 and ferror. xfclose now checks ferror.
1646
1647 * data/glr.c (YYLEFTMOST_STATE): Remove.
1648 (yyreportTree): Use a stack-based leftmost state. This avoids
1649 our continuing battles with bogus warnings about initializers.
1650
56100c60
AD
16512002-10-30 Akim Demaille <akim@epita.fr>
1652
1653 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
1654 #if.
1655
51b4a04c
PH
16562002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1657
1658 * tests/glr-regr1.at: New test for reported regressions.
1659 * tests/testsuite.at: Add glr-regr1.at test.
1660 * tests/Makefile.am: Add glr-regr1.at test.
e183b123 1661
bf1ebda2
PE
16622002-10-24 Paul Eggert <eggert@twinsun.com>
1663
5c16c6b1
PE
1664 Version 1.75a.
1665
bf1ebda2
PE
1666 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
1667 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
1668 we use malloc. Don't assume 'A' through 'Z' are contiguous.
1669 Don't assume strdup exists; POSIX says its an XSI extension.
1670 Check for buffer overflow on input.
1671
b526ee61
AD
16722002-10-24 Akim Demaille <akim@epita.fr>
1673
1674 * src/output.c (output_skeleton): Don't disable M4sugar comments
1675 too soon: it results in comments being expanded.
1676 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
1677 first output.
1678
f1886bb2
AD
16792002-10-24 Akim Demaille <akim@epita.fr>
1680
1681 * data/yacc.c (m4_int_type): New.
1682 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
1683 char' as only yacc.c wants K&R portability.
1684 * data/glr.c (yysigned_char): Remove.
1685 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
1686 Reported by Quoc Peyrot.
1687
c5576256
PE
16882002-10-23 Paul Eggert <eggert@twinsun.com>
1689
1690 * src/main.c (main): With --trace=time, report times even if a
1691 non-fatal error occurs. Formerly, the times were reported in some
1692 such cases but not in others.
1693 * src/reader.c (reader): Just return if a complaint has been issued,
1694 instead of exiting, so that 'main' can report times.
1695
27b0ffea
AD
16962002-10-22 Akim Demaille <akim@epita.fr>
1697
1698 * src/system.h: Include sys/types.
1699 Reported by Bert Deknuydt.
1700
223a7883
PE
17012002-10-23 Paul Eggert <eggert@twinsun.com>
1702
1703 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
1704 Suggested by Art Haas.
1705
17062002-10-22 Paul Eggert <eggert@twinsun.com>
1707
1708 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
1709 decl; not needed any more.
1710 * src/main.c (main): Use return to exit, undoing yesterday's change.
1711 The last OS that we could find where this wouldn't work is
1712 SunOS 3.5, and that's too old to worry about now.
1713
1714 * data/glr.c (struct yyltype): Define members even when not
1715 doing locations. This is more consistent with yacc.c, and it
1716 works around the following bug reports:
e3aa65c5
PE
1717 http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00106.html
1718 http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00111.html
27b0ffea 1719
223a7883
PE
1720 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
1721 @acronym consistently. Standardize on "Yacc" instead of "YACC",
1722 "Algol" instead of "ALGOL". Give a bit more history about BNF.
1723
8b76775a
AD
17242002-10-22 Akim Demaille <akim@epita.fr>
1725
1726 * data/README: New.
1727
6db10d14
PE
17282002-10-21 Paul Eggert <eggert@twinsun.com>
1729
1730 Be consistent about 'bool'; the old code used an enum in one
1731 module and an int in another, and this violates the C standard.
1732 * m4/stdbool.m4: New file, from coreutils 4.5.3.
1733 * configure.ac (AC_HEADER_STDBOOL): Add.
1734 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
1735 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
1736 * src/symtab.c (hash_compare_symbol_t): Likewise.
1737 * src/system.h (bool, false, true): Use a definition consistent
1738 with ../lib/hash.c. All uses changed.
1739
1740 * src/complain.c (warning_issued): Renamed from warn_message_count,
1741 so that we needn't worry about integer overflow (!).
1742 Now of type bool. All uses changed.
1743 (complaint_issued): Renamed from complain_message_count; likewise.
1744
1745 * src/main.c (main): Use exit to exit with failure.
27b0ffea 1746
6db10d14
PE
1747 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
1748 rather than 1 and 0.
1749 * src/main.c (main): Likewise.
1750 * src/getargs.c (getargs): Likewise.
1751 * src/reader.c (reader): Likewise.
1752
1753 * src/getarg.c (getargs): Remove duplicate code for
1754 "Try `bison --help'".
1755
1756 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
1757 What was that "2" for?
1758
1759 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
1760 * src/getargs.c (usage): Likewise.
1761
1762 * src/getargs.c (getargs): When there are too few operands, report
1763 the last one. When there are too many, report the first extra
1764 one. This is how diffutils does it.
1765
92a060fd
PE
17662002-10-20 Paul Eggert <eggert@twinsun.com>
1767
1768 Remove K&R vestiges.
1769 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
1770 * src/complain.c (VA_START): Remove. Assume prototypes.
1771 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
1772 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
1773 fatal): Assume prototypes.
1774 * src/complain.h: Assume prototypes.
1775 * src/system.h (PARAMS): Remove.
1776 Include <limits.h> unconditionally, since it's guaranteeed even
1777 for a freestanding C89 compiler.
1778 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
1779 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 1780
e7cb57c0
AD
17812002-10-20 Akim Demaille <akim@epita.fr>
1782
1783 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1784 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1785 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1786 (yyresolveStates, yyresolveAction, yyresolveStack)
1787 (yyprocessOneStack): Use them.
1788 (yy_reduce_print): New.
1789 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1790
0245f82d
AD
17912002-10-20 Akim Demaille <akim@epita.fr>
1792
1793 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1794 arguments and output `void'.
1795 (b4_c_function): Rename as...
1796 (b4_c_function_def): this.
1797 (b4_c_function_decl, b4_c_ansi_function_def)
1798 (b4_c_ansi_function_decl): New.
1799 Change the interpretation of the arguments: before `int, foo', now
1800 `int foo, foo'.
1801 * data/yacc.c (yyparse): Prototype and define thanks to these.
1802 Adjust b4_c_function_def uses.
1803 * data/glr.c (yyparse): Likewise, but ANSI only.
1804
39912f52
AD
18052002-10-20 Akim Demaille <akim@epita.fr>
1806
1807 * src/output.c (prepare): Move the definition of `tokens_number',
1808 `nterms_number', `undef_token_number', `user_token_number_max'
1809 to...
1810 (prepare_tokens): Here.
1811 (prepare_tokens): Rename as...
1812 (prepare_symbols): this.
1813 (prepare): Move the definition of `rules_number' to...
1814 (prepare_rules): here.
1815 (prepare): Move the definition of `last', `final_state_number',
1816 `states_number' to...
1817 (prepare_states): here.
1818 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1819
20c1e2ad
AD
18202002-10-20 Akim Demaille <akim@epita.fr>
1821
1822 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1823
21964f43
AD
18242002-10-20 Akim Demaille <akim@epita.fr>
1825
1826 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1827 * data/c.m4: here.
1828
66d30cd4
AD
18292002-10-20 Akim Demaille <akim@epita.fr>
1830
1831 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1832 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1833 `pair'.
1834 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1835 `name' to...
1836 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1837 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1838 These.
1839
95f2c9fe
PE
18402002-10-19 Paul Eggert <eggert@twinsun.com>
1841
1842 Do not create a temporary file, as that involves security and
1843 cleanup headaches. Instead, use a pair of pipes.
1844 Derived from a suggestion by Florian Krohm.
1845 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1846 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1847 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1848 (BISON_PREREQ_SUBPIPE): Add.
1849 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1850 Add subpipe.h, subpipe.c.
1851 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1852 * po/POTFILES.in: Add lib/subpipe.c.
1853 * src/output.c: Include "subpipe.h".
1854 (m4_invoke): Remove decl.
1855 (scan_skel): New decl.
1856 (output_skeleton): Use pipe rather than temporary file for m4 input.
1857 Check that m4sugar.m4 is readable, to avoid deadlock.
1858 Check for pipe I/O error.
1859 * src/scan-skel.l (readpipe): Remove decl.
1860 (scan_skel): New function, to be used in place of m4_invoke.
1861 Read from stream rather than file.
66d30cd4 1862
95f2c9fe
PE
1863 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1864 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1865 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1866 this generates a more-accurate value anyway.
1867
1868 * lib/timevar.c (timervar_accumulate): Rename locals to
1869 avoid confusion with similarly-named more-global.
1870 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1871
1872 * src/output.c (prepare): Use xstrdup to convert char const *
1873 to char *, to avoid GCC warning.
1874
c19988b7
AD
18752002-10-19 Akim Demaille <akim@epita.fr>
1876
1877 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1878 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1879 Use them to have `calc.y' ready for %pure-parser.
1880 * data/yacc.c (YYLEX): Pass a yylex return type to
1881 b4_c_function_call.
1882
ae7453f2
AD
18832002-10-19 Akim Demaille <akim@epita.fr>
1884
1885 Prototype support of %lex-param and %parse-param.
1886
1887 * src/parse-gram.y: Add the definition of the %lex-param and
1888 %parse-param tokens, plus their rules.
1889 Drop the `_' version of %glr-parser.
1890 Add the "," token.
1891 * src/scan-gram.l (INITIAL): Scan them.
1892 * src/muscle_tab.c: Comment changes.
1893 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1894 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1895 (muscle_entry_s): The `value' member is no longer const.
1896 Adjust all dependencies.
1897 * src/muscle_tab.c (muscle_init): Adjust: use
1898 MUSCLE_INSERT_STRING.
1899 Initialize the obstack earlier.
1900 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1901 (muscle_pair_list_grow): New.
1902 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1903 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1904 * tests/calc.at: Use %locations, not --locations.
1905 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1906
0e575721
AD
19072002-10-19 Akim Demaille <akim@epita.fr>
1908
1909 * src/getargs.c (usage): Take status as argument and exit
1910 accordingly.
1911 Report the traditional `Try ... --help' message when status != 0.
1912 (usage, version): Don't take a FILE * as arg, it is pointless.
1913 (getargs): When there is an incorrect number of arguments, make it
1914 an error, and report it GNUlically thanks to `usage ()'.
1915
724ce7f5
PE
19162002-10-18 Paul Eggert <eggert@twinsun.com>
1917
3a781eb2
PE
1918 * data/glr.c (yyreportParseError): Don't assume that sprintf
1919 yields the length of the printed string, as this is not true
1920 on SunOS 4.1.4. Reported by Peter Klein.
1921
724ce7f5
PE
1922 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1923 * tests/conflicts.at (%nonassoc and eof): Likewise.
1924 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1925
473d0a75
AD
19262002-10-17 Akim Demaille <akim@epita.fr>
1927
1928 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1929 * src/getargs.c (trace_types, trace_args): Adjust.
1930 * src/reader.c (grammar_current_rule_prec_set)
1931 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1932 Standardize error messages.
1933 And s/@prec/%prec/!
1934 (reader): Use trace_flag to enable scanner/parser debugging,
1935 instead of an adhoc scheme.
1936 * src/scan-gram.l: Remove trailing debugging code.
1937
e76d2469
PE
19382002-10-16 Paul Eggert <eggert@twinsun.com>
1939
93e2236a
PE
1940 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1941 MUSCLE_TAB_H.
1942
e76d2469
PE
1943 * NEWS: Officially drop support for building Bison with K&R C,
1944 since it didn't work anyway and it's not worth worrying about.
1945 * Makefile.maint (wget_files): Remove ansi2knr.c.
1946 (ansi2knr.c-url_prefix): Remove.
1947 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1948 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1949 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1950
5bd1c419
PE
19512002-10-15 Paul Eggert <eggert@twinsun.com>
1952
1953 Stop using the "enum_" trick for K&R-style function definitions;
1954 it confused me, and I was the author! Instead, assume that people
1955 who want to use K&R C compilers (when using these modules in GCC,
1956 perhaps?) will run ansi2knr.
1957
1958 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1959 All uses of "enum_" changed to "enum ".
1960 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1961 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 1962
5bd1c419
PE
1963 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1964 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1965 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1966 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1967 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1968 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1969 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1970 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1971 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1972 Use function prototypes; this removes the need for declaring
1973 static functions simply to provide their prototypes.
1974 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1975 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1976 bitset_count_, bitset_create, bitset_dump, bitset_first,
1977 bitset_free, bitset_init, bitset_last, bitset_next,
1978 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1979 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1980 bitset_print, bitset_release_memory, bitset_toggle_,
1981 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1982 debug_bitset): Likewise.
1983 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1984 * lib/bitset_stats.c (bitset_log_histogram_print,
1985 bitset_percent_histogram_print, bitset_stats_and,
1986 bitset_stats_and_cmp, bitset_stats_and_or,
1987 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1988 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1989 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1990 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1991 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1992 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1993 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1994 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1995 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1996 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1997 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1998 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1999 bitset_stats_zero): Likewise.
2000 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
2001 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
2002 bitsetv_dump, debug_bitsetv): Likewise.
2003 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
2004 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
2005 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
2006 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
2007 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
2008 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
2009 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
2010 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
2011 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
2012 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
2013 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
2014 Likewise.
2015 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
2016 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
2017 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
2018 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
2019 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
2020 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
2021 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
2022 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
2023 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
2024 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
2025 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 2026
ae26e1f0
AD
20272002-10-14 Akim Demaille <akim@epita.fr>
2028
2029 Version 1.75.
2030
d43baf71
AD
20312002-10-14 Akim Demaille <akim@epita.fr>
2032
2033 * tests/Makefile.am (maintainer-check-posix): New.
2034
7ebc83e3
AD
20352002-10-14 Akim Demaille <akim@epita.fr>
2036
2037 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
2038 member.
2039
05846dae
AD
20402002-10-14 Akim Demaille <akim@epita.fr>
2041
2042 * src/tables.c (table_ninf_remap): base -> tab.
2043 Reported by Matt Rosing.
2044
1318e37d
PE
20452002-10-14 Paul Eggert <eggert@twinsun.com>
2046
447fbb17
PE
2047 * tests/action.at, tests/calc.at, tests/conflicts.at,
2048 tests/cxx-type.at, tests/headers.at, tests/input.at,
2049 tests/regression.at, tests/synclines.at, tests/torture.at:
2050 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
2051 so that the tests still work even if POSIXLY_CORRECT is set.
2052 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 2053
1318e37d
PE
2054 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
2055 for portability to K&R hosts. Fix typo: signed char is guaranteed
2056 only to 127, not to 128.
2057 * data/glr.c (yysigned_char): New type.
2058 * data/yacc.c (yysigned_char): Likewise.
2059 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
2060
cc0f0794
PE
20612002-10-13 Paul Eggert <eggert@twinsun.com>
2062
5038f418
PE
2063 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
2064 true due to limited range of data type" warning from GCC.
2065
cc0f0794
PE
2066 * data/c.m4 (b4_token_defines): Protect against double-inclusion
2067 by wrapping enum yytokentype's definition inside #ifndef
2068 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
2069
6fed0802
AD
20702002-10-13 Akim Demaille <akim@epita.fr>
2071
2072 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
2073 Un yy- yyrhs to avoid the name clash with the global YYRHS.
2074
32f0598d
AD
20752002-10-13 Akim Demaille <akim@epita.fr>
2076
2077 * Makefile.maint: Update from Autoconf 2.54.
2078 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
2079
7ea9a33f
AD
20802002-10-13 Akim Demaille <akim@epita.fr>
2081
2082 * src/print.c (print_state): Separate the list of solved conflicts
2083 from the other items.
2084 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
2085
ea99527d
AD
20862002-10-13 Akim Demaille <akim@epita.fr>
2087
2088 Let nondeterministic skeletons be usable with deterministic
2089 tables.
2090
2091 With the patch, GAWK compiled by GCC without -O2 passes its test
2092 suite using a GLR parser driven by LALR tables. It fails with -O2
2093 because `struct stat' gives two different answers on my machine:
2094 88 (definition of an auto var) and later 96 (memset on this var).
2095 Hence the stack is badly corrumpted. The headers inclusion is to
2096 blame: if I move the awk.h inclusion before GLR's system header
2097 inclusion, the two struct stat have the same size.
2098
2099 * src/tables.c (pack_table): Always create conflict_table.
2100 (token_actions): Always create conflict_list.
2101 * data/glr.c (YYFLAG): Remove, unused.
2102
f377f69f
AD
21032002-10-13 Akim Demaille <akim@epita.fr>
2104
2105 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
2106 (O0FLAGS): New.
2107 (VALGRIND, GXX): New.
2108 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
2109 * tests/bison.in: Run $PREBISON a pre-command.
2110 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
2111 (maintainer-check-g++): New.
2112 * Makefile.am (maintainer-check): New.
2113
2a1fe6ed
AD
21142002-10-13 Akim Demaille <akim@epita.fr>
2115
2116 * data/glr.c: Formatting changes.
2117 Tweak some trace messages to match yacc.c's.
2118
f50adbbd
AD
21192002-10-13 Akim Demaille <akim@epita.fr>
2120
2121 GLR parsers sometimes raise parse errors instead of performing the
2122 default reduction.
2123 Reported by Charles-Henry de Boysson.
2124
2125 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
2126 check the length of the traces when %glr.
2127 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
2128 GLR's traces.
2129 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
2130 Test GLR parsers.
2131 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
2132 (yyltype): Remove the yy prefix from the member names.
2133 (yytable): Complete its comment.
2134 (yygetLRActions): Map error action number from YYTABLE from
2135 YYTABLE_NINF to 0.
2136 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
2137 (which was a bug: it should have been YYTABEL_NINF, and yet it was
2138 not satisfying as we could compare an YYACTION computed from
2139 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
2140 only value for error actions.
2141 (yyreportParseError): In verbose parse error messages, don't issue
2142 `error' in the list of expected tokens.
2143 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
2144 next action to perform to match glr.c's decoding.
2145 (yytable): Complete its comment.
2146
bcbad5b9
PE
21472002-10-13 Paul Eggert <eggert@twinsun.com>
2148
2149 Fix problem reported by Henrik Grubbstroem in
e3aa65c5 2150 <http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00098.html>:
bcbad5b9
PE
2151 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
2152 because the Bison parser reads the second action before reducing
2153 the first one.
2154 * src/scan-gram.l (rule_length): New static var.
2155 Use it to keep track of the rule length in the scanner, since
2156 we can't expect the parser to be in lock-step sync with the scanner.
2157 (handle_action_dollar, handle_action_at): Use this var.
2158 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 2159
14904b89
PE
21602002-10-12 Paul Eggert <eggert@twinsun.com>
2161
1fe611e5
PE
2162 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
2163 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
2164 Include <sys/time.h> when checking for clock_t and struct tms.
2165 Use same include order as source.
2166 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
e3aa65c5 2167 <http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00016.html>.
05846dae 2168
1fe611e5
PE
2169 * lib/timevar.c: Update copyright date and clarify comments.
2170 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 2171
1fe611e5
PE
2172 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
2173 GCC version as of today, then merge Bison's changes.
2174 Change "GCC" to "Bison" in copyright notice. timevar.def's
2175 author is Akim, so change that too.
2176
98194095
PE
2177 * src/reader.c (grammar_current_rule_check):
2178 Don't worry about the default action if $$ is untyped.
2179 Prevents bogus warnings reported by Jim Gifford in
e3aa65c5 2180 <http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00015.html>.
98194095 2181
14904b89
PE
2182 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
2183 * data/glr.c, data/lalr1.cc, data/yacc.c:
2184 Output token definitions before the first part of user declarations.
2185 Fixes compatibility problem reported by Jim Gifford for kbd in
e3aa65c5 2186 <http://mail.gnu.org/archive/html/bug-bison/2002-10/msg00014.html>.
14904b89 2187
ff6dca18
PE
21882002-10-11 Paul Eggert <eggert@twinsun.com>
2189
2190 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
2191 (yyparse): here. This undoes some of the 2002-07-25 change.
2192 Compatibility problem reported by Ralf S. Engelschall with
2193 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
2194
eb714592
AD
21952002-10-11 Akim Demaille <akim@epita.fr>
2196
2197 * tests/regression.at Characters Escapes): New.
2198 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
2199 characters.
2200 Reported by Jan Nieuwenhuizen.
2201
b7195100
AD
22022002-10-11 Akim Demaille <akim@epita.fr>
2203
2204 * po/id.po: New.
2205
f28a0f2d
PE
22062002-10-10 Paul Eggert <eggert@twinsun.com>
2207
2208 Portability fixes for bitsets; this also avoids several GCC
2209 warnings.
2210
2211 * lib/abitset.c: Include <stddef.h>, for offsetof.
2212 * lib/lbitset.c: Likewise.
2213
2214 * lib/abitset.c (abitset_bytes): Return a size that is aligned
2215 properly for vectors of objects. Do not assume that adding a
2216 header size to a multiple of a word size yields a value that is
2217 properly aligned for the whole union.
2218 * lib/bitsetv.c (bitsetv_alloc): Likewise.
2219
2220 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
2221 unique names for structures.
2222 * lib/ebitset.c (ebitset_bytes): Likewise.
2223 * lib/lbitset.c (lbitset_bytes): Likewise.
2224
2225 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
2226 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
2227 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
2228 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
2229 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
2230 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
2231 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
2232 to improve the type-checking that GCC can do.
2233 * lib/bitset.c (bitset_op4_cmp): Likewise.
2234 * lib/bitset_stats.c (bitset_stats_count,
2235 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
2236 bitset_stats_copy, bitset_stats_disjoint_p,
2237 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
2238 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
2239 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
2240 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
2241 bitset_stats_and_or_cmp, bitset_stats_andn_or,
2242 bitset_stats_andn_or_cmp, bitset_stats_or_and,
2243 bitset_stats_or_and_cmp): Likewise.
2244 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
2245 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
2246 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
2247 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
2248
2249 * lib/abitset.h: Include bitset.h, not bbitset.h.
2250 * lib/ebitset.h: Likewise.
2251 * lib/lbitset.h: Likewise.
2252
2253 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
2254 All instances of parameters of type enum bitset_opts are now of
2255 type enum_bitset_opts, to conform to the C Standard, and similarly
2256 for enum_bitset_type.
2257 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
2258 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
2259
2260 Do not use "struct bitset_struct" to mean different things in
2261 different modules. Not only is this confusing, it violates
2262 the C Standard, which requires that structure types in different
2263 modules must be compatible if one is to be passed to the other.
2264 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
2265 All instances of "struct bitset_struct *" replaced with "bitset".
2266 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
2267 (union bitset_union, struct abitset_struct, struct ebitset_struct,
2268 struct lbitset_struct, struct bitset_stats_struct): New types.
2269 All uses of struct bitset_struct changed to union bitset_union,
2270 etc.
2271 * lib/abitset.c (struct abitset_struct, abitset,
2272 struct bitset_struct): Remove.
2273 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
2274 struct bitset_struct): Remove.
2275 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
2276 bitset_struct): Remove.
2277 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
2278 Likewise.
2279
2280 Do not call a function of type T using a call that assumes the
2281 function is of a different type U. Standard C requires that a
2282 function must be called with a type that is compatible with its
2283 definition.
2284 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2285 New decls.
2286 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2287 New functions.
2288 * lib/ebitset.c (PFV): Remove.
2289 * lib/lbitset.c (PFV): Likewise.
2290 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
2291 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
2292 decls.
2293 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
2294 (ebitset_vtable): Use them.
2295 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
2296 lbitset_xor): New functions.
2297 (lbitset_vtable): Use them.
2298
2299 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
2300 Declare.
2301
2302 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
2303 GCC warning.
2304 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
2305 Use offsetof, for simplicity.
2306
6fbe4984
PE
23072002-10-06 Paul Eggert <eggert@twinsun.com>
2308
2309 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
2310 the same width as int. This reapplies a hunk of the 2002-08-12 patch
e3aa65c5 2311 <http://mail.gnu.org/archive/html/bison-patches/2002-08/msg00007.html>,
6fbe4984
PE
2312 which was inadvertently undone by the 2002-09-30 patch.
2313 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
2314 the same width as int.
2315
420f93c8
PE
23162002-10-04 Paul Eggert <eggert@twinsun.com>
2317
2318 Version 1.50.
2319
2320 * configure.ac (AC_INIT), NEWS: Increment version number.
2321
2322 * doc/bison.texinfo: Minor spelling, grammar, and white space
2323 fixes.
2324 (Symbols): Mention that any negative value returned from yylex
2325 signifies end-of-input. Warn about negative chars. Mention
2326 the portable Standard C character set.
2327
2328 The GNU coding standard says CFLAGS and YFLAGS are reserved
2329 for the installer to set.
2330 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
2331 * src/Makefile.am (AM_CFLAGS): Likewise.
2332 (AM_YFLAGS): Renamed from YFLAGS.
2333
2334 Fix some MAX and MIN problems.
2335 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
2336 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
2337 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
2338 * src/reader.c (reader): Use it.
2339
2340 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
2341 POSIX 1003.1-2001 has removed fgrep.
2342
23432002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
2344
2345 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
2346 interpreted as signed.
2347 * lib/ebitset.c (ebitset_list): Fix bug.
2348
ff68026d
PE
23492002-10-01 Paul Eggert <eggert@twinsun.com>
2350
2351 More fixes for 64-bit hosts and large bitsets.
2352
2353 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
2354 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
2355 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
2356 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
2357 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
2358 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
2359 bitset_count_): Likewise.
2360 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
2361 bitset_first, bitset_last): Likewise.
2362 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
2363 bitset_stats_list_reverse, bitset_stats_size,
2364 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
2365 Likewise.
2366 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2367 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
2368 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
2369 bitsetv_reflexive_transitive_closure): Likewise.
2370 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
2371 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
2372 Likewise.
2373 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
2374 Likewise.
420f93c8 2375
ff68026d
PE
2376 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
2377 Use size_t, not unsigned int, to count bytes.
2378 * lib/abitset.h (abitset_bytes): Likewise.
2379 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
2380 Likewise.
2381 * lib/bitset.h (bitset_bytes): Likewise.
2382 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
2383 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
2384 * lib/bitsetv.c (bitsetv_alloc): Likewise.
2385 * lib/ebitset.c (ebitset_bytes): Likewise.
2386 * lib/ebitset.h (ebitset_bytes): Likewise.
2387 * lib/lbitset.c (lbitset_bytes): Likewise.
2388 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 2389
ff68026d
PE
2390 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
2391 abitset_subset_p, abitset_disjoint_p, abitset_and,
2392 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
2393 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
2394 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
2395 abitset_or_and, abitset_or_and_cmp):
2396 Use bitset_windex instead of unsigned int.
2397 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2398 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
2399 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
2400 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
2401 Likewise.
2402 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 2403
ff68026d
PE
2404 * lib/bitset.c (bitset_print):
2405 Use proper printf formats for widths of integer types.
2406 * lib/bitset_stats.c (bitset_percent_histogram_print,
2407 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
2408 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2409 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2410 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 2411
ff68026d
PE
2412 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
2413 BITSET_SIZE_MAX): New macros.
2414 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
2415 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
2416 to BITSET_WINDEX_MAX.
2417
2418 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
2419 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
2420 since we now return the bitset_bindex type (not int).
2421
2422 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
2423 when computing sizes.
2424 * lib/ebitset.c (ebitset_elts_grow): Likewise.
2425
2426 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
2427 and avoid cast to unsigned.
2428
6aa452a6
AD
24292002-09-30 Akim Demaille <akim@epita.fr>
2430
2431 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
2432 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
2433 Updates from Michael Hayes.
2434
927f7817
AD
24352002-09-30 Art Haas <ahaas@neosoft.com>
2436
2437 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
2438 invocations.
2439 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
2440 defined.
2441
9738f41e
AD
24422002-09-27 Akim Demaille <akim@epita.fr>
2443
2444 Version 1.49c.
2445
a5c75d7f
AD
24462002-09-27 Akim Demaille <akim@epita.fr>
2447
2448 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
2449 (Because of AC_LIBSOURCE).
2450
8280e179
AD
24512002-09-27 Akim Demaille <akim@epita.fr>
2452
2453 Playing with Autoscan.
2454
2455 * configure.ac: Remove the old LIBOBJ tweaks.
2456 (AC_REPLACE_FUNCS): Add strrchr and strtol.
2457 * lib/strrchr.c: New.
2458 * lib/strtol.c: New, from the Coreutils 4.5.1.
2459
ae64af35
AD
24602002-09-27 Akim Demaille <akim@epita.fr>
2461
2462 Playing with Autoscan.
2463
2464 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
2465 * lib/Makefile.am (libbison_a_SOURCES): No longer include
2466 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
2467 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
2468 Coreutils 4.5.1.
2469
d1a1114f
AD
24702002-09-24 Akim Demaille <akim@epita.fr>
2471
2472 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
2473 (Frequently Asked Questions, Parser Stack Overflow): New.
2474
b906441c
AD
24752002-09-13 Akim Demaille <akim@epita.fr>
2476
2477 Playing with autoscan.
2478
2479 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
2480 * src/files.c (skeleton_find): Remove, unused.
2481 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
2482 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
2483
bd701811
AD
24842002-09-13 Akim Demaille <akim@epita.fr>
2485
2486 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
2487 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
2488
e0a13e7b
AD
24892002-09-13 Akim Demaille <akim@epita.fr>
2490
2491 * configure.ac: Require 2.54.
2492 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
2493 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
2494 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
2495 Remove, provided by Autoconf macros.
2496
c97011bf
AD
24972002-09-12 Akim Demaille <akim@epita.fr>
2498
2499 * m4/prereq.m4: Update, from Coreutils 4.5.1.
2500
d862b1be
AD
25012002-09-12 Akim Demaille <akim@epita.fr>
2502
2503 * m4/prereq.m4: Update, from Fileutils 4.1.5.
2504 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
2505 Reported by Martin Mokrejs.
2506
3d38c03a
AD
25072002-09-10 Akim Demaille <akim@epita.fr>
2508
2509 * src/parse-gram.y: Associate a human readable string to each
2510 token type.
2511 * tests/regression.at (Invalid inputs): Adjust.
2512
b6347355
AD
25132002-09-10 Gary V. Vaughan <gary@gnu.org>
2514
2515 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
2516 with an Autoconf-2.5x style configure.ac.
2517
09ba4ab2
PE
25182002-09-06 Paul Eggert <eggert@twinsun.com>
2519
2520 * doc/bison.texinfo (Conditions): Make explicit that the GPL
2521 exception applies only to yacc.c. This is a modification of a
2522 patch originally suggested by Akim Demaille.
2523
21846f69
AD
25242002-09-06 Akim Demaille <akim@epita.fr>
2525
09ba4ab2
PE
2526 * data/c.m4 (b4_copyright): Move the GPL exception comment from
2527 here to...
2528 * data/yacc.c: here.
2529
21846f69
AD
2530 * data/lalr1.cc (struct yyltype): Don't define it, since we use
2531 LocationType.
2532 (b4_ltype): Default to yy::Location from location.hh.
2533
c0ad8bf3
AD
25342002-09-04 Jim Meyering <jim@meyering.net>
2535
2536 * data/yacc.c: Guard the declaration of yytoknum also with
2537 `#ifdef YYPRINT', so it is declared only when used.
2538
3a93251e
AD
25392002-09-04 Akim Demaille <akim@epita.fr>
2540
2541 * configure.in: Rename as...
2542 * configure.ac: this.
2543 Bump to 1.49c.
2544
427c0dda
AD
25452002-09-04 Akim Demaille <akim@epita.fr>
2546
2547 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
2548 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
2549 translate maintainer only messages.
2550
6a254321
PE
25512002-08-12 Paul Eggert <eggert@twinsun.com>
2552
645e30d1
PE
2553 Version 1.49b.
2554
6a254321
PE
2555 * Makefile.am (SUBDIRS): Remove intl.
2556 (DISTCLEANFILES): Remove.
2557 * NEWS: Mention that GNU M4 is now required. Clarify what is
2558 meant by "larger grammars". Mention the pt_BR translation.
2559 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
2560 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
2561 Bump version from 0.11.2 to 0.11.5.
2562 (BISON_PREREQ_STAGE): Remove.
2563 (AM_GNU_GETTEXT): Use external gettext.
2564 (AC_OUTPUT): Remove intl/Makefile.
2565
2566 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
2567
2568 * data/glr.c: Include string.h, for strlen.
2569 (yyreportParseError): Use size_t for yysize.
2570 (yy_yypstack): No longer nested inside yypstates, as nested
2571 functions are not portable. Do not assume size_t is the
2572 same width as int.
2573 (yypstates): Do not assume that ptrdiff_t is the same width
2574 as int, and similarly for yyposn and YYINDEX.
2575
2576 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
2577
2578 * lib/Makefile.am (INCLUDES): Do not include from the intl
2579 directory, which has been removed.
2580 * src/Makefile.am (INCLUDES): Likewise.
2581
2582 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
2583 (bitsets_sources, additional_bitsets_sources, timevars_sources):
2584 New vars.
2585
2586 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
2587 * tests/Makefile.am (EXTRA_DIST): Likewise.
2588
2589 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
2590 Do not assume that bitset_windex is the same width as unsigned.
2591
2592 * lib/abitset.c (abitset_unused_clear): Do not assume that
2593 bitset_word is the same width as int.
2594 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
2595 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
2596 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
2597 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
2598 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
2599
2600 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
2601 portability to one's complement hosts!).
2602 * lib/ebitset.c (ebitset_op1): Likewise.
2603 * lib/lbitset.c (lbitset_op1): Likewise.
2604
2605 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
2606 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
2607 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
2608 Sync with fileutils.
2609 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
2610 lib/gettext.h: Sync with diffutils.
2611
2612 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
2613 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
2614
2615 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
2616 PROTOTYPES to check for prototypes, and "defined __STDC__" to
2617 check for void *.
2618
2619 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
2620 size_t; the old version tried to do this but casted improperly.
2621 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
2622 (bitset_test): Now returns int, not unsigned long.
2623
2624 * lib/bitset_stats.c: Include "gettext.h".
2625 (_): New macro.
2626 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
2627 name locals "index", as it generates unnecessary warnings on some
2628 hosts that have an "index" function.
2629
2630 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
2631 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
2632 they need translation.
2633 * src/LR0.c (state_list_append, new_itemsets, get_state,
2634 append_states, generate_states): Likewise.
2635 * src/assoc.c (assoc_to_string): Likewise.
2636 * src/closure.c (print_closure, set_firsts, closure): Likewise.
2637 * src/gram.c (grammar_dump): Likewise.
2638 * src/injections.c (injections_compute): Likewise.
2639 * src/lalr.c (lookaheads_print): Likewise.
2640 * src/relation.c (relation_transpose): Likewise.
2641 * src/scan-gram.l: Likewise.
2642 * src/tables.c (table_grow, pack_vector): Likewise.
2643
2644 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
2645 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
2646 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
2647 * m4/mbstate_t.m4: Sync with fileutils.
2648 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
2649
2650 * po/LINGUAS: Add pt_BR.
2651 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
2652 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
2653 lib/timevar.c.
2654 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
2655 manual recommends.
2656 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
2657
2658 * src/complain.c (strerror_r): Remove decl; not needed.
2659 (strerror): Use same pattern as ../lib/error.c.
2660
2661 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
2662
2663 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
2664
2665 * src/main.c (main): Cast result of bindtextdomain and textdomain
2666 to void, to avoid a GCC warning when --disable-nls is in effect.
2667
2668 * src/scan-gram.l: Use strings rather than escapes when possible,
2669 to minimize the number of warnings from xgettext.
2670 (handle_action_dollar, handle_action_at): Don't use isdigit,
2671 as it mishandles negative chars and it may not work as expected
2672 outside the C locale.
2673
2674 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
2675 this is a GCC extension and is not portable to other compilers.
2676
2677 * src/system.h (alloca): Use same pattern as ../lib/error.c.
2678 Do not include <ctype.h>; no longer needed.
2679 Do not include <malloc.h>; no longer needed (and generates
2680 warnings on OpenBSD 3.0).
2681
2682 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
2683 it's not portable.
2684
2685 * tests/regression.at: Do not use 'cc -c input.c -o input';
2686 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
2687
2688 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
2689 exit status as failure, not just exit status 1. Sun C exits
2690 with status 2 sometimes.
2691
2692 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
2693 Use it for the two large tests.
2694
c8f002c7
AD
26952002-08-02 Akim Demaille <akim@epita.fr>
2696
2697 * src/conflicts.c (conflicts_output): Don't output rules never
2698 reduced here, since anyway that computation doesn't work.
2699 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
2700 (rule_useless_p, rule_never_reduced_p): New.
2701 (grammar_rules_partial_print): Use a filter instead of a range.
2702 Display the title only if needed.
2703 (grammar_rules_print): Adjust.
2704 (grammar_rules_never_reduced_report): New.
2705 * src/tables.c (action_row): Move the computation of rules never
2706 reduced to...
2707 (token_actions): here.
2708 * src/main.c (main): Make the parser before making the report, so
2709 that rules never reduced are computed.
2710 Call grammar_rules_never_reduced_report.
2711 * src/print.c (print_results): Report rules never reduced.
2712 * tests/conflicts.at, tests/reduce.at: Adjust.
2713
cd08e51e
AD
27142002-08-01 Akim Demaille <akim@epita.fr>
2715
2716 Instead of attaching lookaheads and duplicating the rules being
2717 reduced by a state, attach the lookaheads to the reductions.
2718
2719 * src/state.h (state_t): Remove the `lookaheads',
2720 `lookaheads_rule' member.
2721 (reductions_t): Add a `lookaheads' member.
2722 Use a regular array for the `rules'.
2723 * src/state.c (reductions_new): Initialize the lookaheads member
2724 to 0.
2725 (state_rule_lookaheads_print): Adjust.
2726 * src/state.h, src/state.c (state_reductions_find): New.
2727 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
2728 (count_rr_conflicts): Adjust.
2729 * src/lalr.c (LArule): Remove.
2730 (add_lookback_edge): Adjust.
2731 (state_lookaheads_count): New.
2732 (states_lookaheads_initialize): Merge into...
2733 (initialize_LA): this.
2734 (lalr_free): Adjust.
2735 * src/main.c (main): Don't free nullable and derives too early: it
2736 is used by --verbose.
2737 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
2738
bb0027a9
AD
27392002-08-01 Akim Demaille <akim@epita.fr>
2740
2741 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
2742 `rule_number_t**'.
2743 (set_derives, free_derives): Rename as...
2744 (derives_compute, derives_free): this.
2745 Adjust all dependencies.
2746 * src/nullable.c (set_nullable, free_nullable): Rename as...
2747 (nullable_compute, nullable_free): these.
2748 (rule_list_t): Store rule_t *, not rule_number_t.
2749 * src/state.c (state_rule_lookaheads_print): Directly compare rule
2750 pointers, instead of their numbers.
2751 * src/main.c (main): Call nullable_free, and derives_free earlier,
2752 as they were lo longer used.
2753
3325ddc4
AD
27542002-08-01 Akim Demaille <akim@epita.fr>
2755
2756 * lib/timevar.c (get_time): Include children time.
2757 * src/lalr.h (LA, LArule): Don't export them: used with the
2758 state_t.
2759 * src/lalr.c (LA, LArule): Static.
2760 * src/lalr.h, src/lalr.c (lalr_free): New.
2761 * src/main.c (main): Call it.
2762 * src/tables.c (pack_vector): Check whether loc is >= to the
2763 table_size, not >.
2764 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
2765 (tables_generate): do it, since that's also it which allocates
2766 them.
2767 Don't free LA and LArule, main does.
2768
c6f1a33c
AD
27692002-07-31 Akim Demaille <akim@epita.fr>
2770
2771 Separate parser tables computation and output.
2772
2773 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
2774 (conflict_list, conflict_list_cnt, table, check, table_ninf)
2775 (yydefgoto, yydefact, high): Move to...
2776 * src/tables.h, src/tables.c: here.
2777 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2778 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2779 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
2780 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
2781 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2782 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2783 (action_row, save_row, token_actions, save_column, default_goto)
2784 (goto_actions, sort_actions, matching_state, pack_vector)
2785 (table_ninf_remap, pack_table, prepare_actions): Move to...
2786 * src/tables.c: here.
2787 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2788 * src/output.c (token_actions, output_base, output_conflicts)
2789 (output_check): Merge into...
2790 (prepare_actions): this.
2791 (actions_output): Rename as...
2792 (user_actions_output): this.
2793 * src/main.c (main): Call tables_generate and tables_free.
2794
1509d42f
AD
27952002-07-31 Akim Demaille <akim@epita.fr>
2796
2797 Steal GCC's --time-report support.
2798
2799 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2800 stolen/adjusted from GCC.
2801 * m4/stage.m4: Remove time related checks.
2802 * m4/timevar.m4: New.
2803 * configure.in: Adjust.
2804 * src/system.h: Adjust to using timevar.h.
2805 * src/getargs.h, src/getargs.c: Support trace_time for
2806 --trace=time.
2807 * src/main.c (stage): Remove.
2808 (main): Replace `stage' invocations with timevar calls.
2809 * src/output.c: Insert pertinent timevar calls.
2810
273a74fa
AD
28112002-07-31 Akim Demaille <akim@epita.fr>
2812
2813 Let --trace have arguments.
2814
2815 * src/getargs.h (enum trace_e): New.
2816 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2817 (long_options, short_options): --trace/-T takes an optional
2818 argument.
2819 Change all the uses of trace_flag to reflect the new flags.
2820 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2821
2822 Strengthen `stage' portability.
2823
2824 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2825 * configure.in: Use it.
2826 Don't check for malloc.h and sys/times.h.
2827 * src/system.h: Include them when appropriate.
2828 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2829 times and struct tms are available.
2830
217598da
AD
28312002-07-30 Akim Demaille <akim@epita.fr>
2832
2833 In verbose parse error message, don't report `error' as an
2834 expected token.
2835 * tests/actions.at (Printers and Destructors): Adjust.
2836 * tests/calc.at (Calculator $1): Adjust.
2837 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2838 error message, do not report the parser accepts the error token in
2839 that state.
2840
52489d44
AD
28412002-07-30 Akim Demaille <akim@epita.fr>
2842
2843 Normalize conflict related messages.
2844
2845 * src/complain.h, src/complain.c (warn, complain): New.
2846 * src/conflicts.c (conflicts_print): Use them.
2847 (conflict_report_yacc): New, extracted from...
2848 (conflicts_print): here.
2849 * tests/conflicts.at, tests/existing.at: Adjust.
2850
e8832397
AD
28512002-07-30 Akim Demaille <akim@epita.fr>
2852
2853 Report rules which are never reduced by the parser: those hidden
2854 by conflicts.
2855
2856 * src/LR0.c (save_reductions): Don't make the final state too
2857 different: save its reduction (accept) instead of having a state
2858 without any action (no shift or goto, no reduce).
2859 Note: the final state is now a ``regular'' state, i.e., the
2860 parsers now contain `reduce 0' as default reduction.
2861 Nevertheless, since they decide to `accept' when yystate =
2862 final_state, they still will not reduce rule 0.
2863 * src/print.c (print_actions, print_reduction): Adjust.
2864 * src/output.c (action_row): Track reduced rules.
2865 (token_actions): Report rules never reduced.
2866 * tests/conflicts.at, tests/regression.at: Adjust.
2867
caf23d24
AD
28682002-07-30 Akim Demaille <akim@epita.fr>
2869
2870 `stage' was accidently included in a previous patch.
2871 Initiate its autoconfiscation.
2872
2873 * configure.in: Look for malloc.h and sys/times.h.
2874 * src/main.c (stage): Adjust.
2875 Report only when trace_flag.
2876
640748ee
AD
28772002-07-29 Akim Demaille <akim@epita.fr>
2878
2879 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2880 state_number_t.
2881 (errs_t): symbol_t*, not symbol_number_t.
2882 (reductions_t): rule_t*, not rule_number_t.
2883 (FOR_EACH_SHIFT): New.
2884 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2885 * src/print.c, src/print_graph.c: Adjust.
2886
88bce5a2
AD
28872002-07-29 Akim Demaille <akim@epita.fr>
2888
2889 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2890
2891 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2892 (endtoken, accept): these.
2893 * src/reader.c (reader): Set endtoken's default tag to "$end".
2894 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2895 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2896 Adjust.
2897
1bfb97db
AD
28982002-07-29 Akim Demaille <akim@epita.fr>
2899
2900 * src/reduce.c (reduce_grammar): When the language is empty,
2901 complain about the start symbol, not the axiom.
2902 Use its location.
2903 * tests/reduce.at (Empty Language): New.
2904
fc5734fe
AD
29052002-07-26 Akim Demaille <akim@epita.fr>
2906
2907 * src/reader.h, src/reader.c (gram_error): ... can't get
2908 yycontrol without making too strong assumptions on the parser
2909 itself.
2910 * src/output.c (prepare_tokens): Use the real 0th value of
2911 token_translations instead of `0'.
2912 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2913 visible here.
2914 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2915 for the time being: %locations ought to provide it to yyerror.
2916
3650b4b8
AD
29172002-07-25 Akim Demaille <akim@epita.fr>
2918
2919 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2920 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2921 * tests/regression.at (Web2c Actions): Adjust.
2922
4b3d3a8e
AD
29232002-07-25 Akim Demaille <akim@epita.fr>
2924
2925 Stop storing rules from 1 to nrules + 1.
2926
2927 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2928 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2929 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2930 Iterate from 0 to nrules.
2931 Use rule_number_as_item_number and item_number_as_rule_number.
2932 Adjust to `derive' now containing possibly 0.
2933 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2934 Handle the `- 1' part in rule numbers from/to item numbers.
2935 * src/conflicts.c (log_resolution): Fix the message which reversed
2936 shift and reduce.
2937 * src/output.c (action_row): Initialize default_rule to -1.
2938 (token_actions): Adjust.
2939 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2940 expected output.
2941 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2942
4a2a22f4
AD
29432002-07-25 Akim Demaille <akim@epita.fr>
2944
2945 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2946 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2947 (b4_c_knr_arg_decl): New.
2948 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2949 yyreport_parse_error.
2950
b8df3223
AD
29512002-07-25 Akim Demaille <akim@epita.fr>
2952
2953 * data/yacc.c (yyreport_parse_error): New, extracted from...
2954 (yyparse): here.
2955 (yydestruct, yysymprint): Move above yyparse.
2956 Be K&R compliant.
2957
a762e609
AD
29582002-07-25 Akim Demaille <akim@epita.fr>
2959
2960 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2961 replace...
2962 (b4_sint_type, b4_uint_type): these.
2963 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2964 * tests/regression.at (Web2c Actions): Adjust.
2965
12b0043a
AD
29662002-07-25 Akim Demaille <akim@epita.fr>
2967
2968 * src/gram.h (TIEM_NUMBER_MAX): New.
2969 (item_number_of_rule_number, rule_number_of_item_number): Rename
2970 as...
2971 (rule_number_as_item_number, item_number_as_rule_number): these.
2972 Adjust dependencies.
2973 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2974 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2975 (symbol_number_to_vector_number): New.
2976 (order): Of vector_number_t* type.
2977 (base_t, BASE_MAX, BASE_MIN): New.
2978 (froms, tos, width, pos, check): Of base_t type.
2979 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2980 (actrow): Of action_number_t type.
2981 (conflrow): Of unsigned int type.
2982 (table_ninf, base_ninf): New.
2983 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2984 (muscle_insert_int_table, muscle_insert_base_table)
2985 (muscle_insert_rule_number_table): New.
2986 (prepare_tokens): Output `toknum' as int_table.
2987 (action_row): Returns a rule_number_t.
2988 Use ACTION_MIN, not SHRT_MIN.
2989 (token_actions): yydefact is rule_number_t*.
2990 (table_ninf_remap): New.
2991 (pack_table): Use it for `base' and `table'.
2992 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2993 replaced with...
2994 (YYPACT_NINF, YYTABLE_NINF): these.
2995 (yypact, yytable): Compute their types instead of hard-coded
2996 `short'.
2997 * tests/regression.at (Web2c Actions): Adjust.
2998
5dde258a
AD
29992002-07-19 Akim Demaille <akim@epita.fr>
3000
3001 * src/scan-gram.l (id): Can start with an underscore.
3002
a945ec39
AD
30032002-07-16 Akim Demaille <akim@epita.fr>
3004
3005 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
3006 Adjust all former `associativity' dependencies.
3007 * src/symtab.c (symbol_new): Default associativity is `undef', not
3008 `right'.
3009 (symbol_check_alias_consistence): Adjust.
3010
fae437e8
AD
30112002-07-09 Akim Demaille <akim@epita.fr>
3012
3013 * doc/bison.texinfo: Properly set the ``header'' part.
3014 Use @dircategory ``GNU programming tools'' as per Texinfo's
3015 documentation.
3016 Use @copying.
3017
1a715ef2
AD
30182002-07-09 Akim Demaille <akim@epita.fr>
3019
3020 * lib/quotearg.h: Protect against multiple inclusions.
3021 * src/location.h (location_t): Add a `file' member.
3022 (LOCATION_RESET, LOCATION_PRINT): Adjust.
3023 * src/complain.c (warn_at, complain_at, fatal_at): Drop
3024 `error_one_per_line' support.
3025
a5d50994
AD
30262002-07-09 Akim Demaille <akim@epita.fr>
3027
3028 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
3029 * src/reader.c (lineno): Remove.
3030 Adjust all dependencies.
3031 (get_merge_function): Take a location and use complain_at.
3032 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
3033 * tests/regression.at (Invalid inputs, Mixing %token styles):
3034 Adjust.
3035
b275314e
AD
30362002-07-09 Akim Demaille <akim@epita.fr>
3037
3038 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
3039 recovery rule, and forbid extensions when --yacc.
3040 (gram_error): Use complain_at.
3041 * src/reader.c (reader): Exit if there were parse errors.
3042
865b9df1
AD
30432002-07-09 Akim Demaille <akim@epita.fr>
3044
3045 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
3046 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
3047 Reported by R Blake <blakers@mac.com>.
3048
c76e14da
AD
30492002-07-09 Akim Demaille <akim@epita.fr>
3050
3051 * data/yacc.c: Output the copyright notive in the header.
3052
7db2ed2d
AD
30532002-07-03 Akim Demaille <akim@epita.fr>
3054
3055 * src/output.c (froms, tos): Are state_number_t.
3056 (save_column): sp, sp1, and sp2 are state_number_t.
3057 (prepare): Rename `final' as `final_state_number', `nnts' as
3058 `nterms_number', `nrules' as `rules_number', `nstates' as
3059 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
3060 unused.
3061 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
3062 * data/lalr1.cc (nsym_): Remove, unused.
3063
e68e0410
AD
30642002-07-03 Akim Demaille <akim@epita.fr>
3065
3066 * src/lalr.h, src/lalr.c (goto_number_t): New.
3067 * src/lalr.c (goto_list_t): New.
3068 Propagate them.
3069 * src/nullable.c (rule_list_t): New.
3070 Propagate.
3071 * src/types.h: Remove.
3072
e1a4f3a4
AD
30732002-07-03 Akim Demaille <akim@epita.fr>
3074
3075 * src/closure.c (print_fderives): Use rule_rhs_print.
3076 * src/derives.c (print_derives): Use rule_rhs_print.
3077 (rule_list_t): New, replaces `shorts'.
3078 (set_derives): Add comments.
3079 * tests/sets.at (Nullable, Firsts): Adjust.
3080
536545f3
AD
30812002-07-03 Akim Demaille <akim@epita.fr>
3082
3083 * src/output.c (prepare_actions): Free `tally' and `width'.
3084 (prepare_actions): Allocate and free `order'.
3085 * src/symtab.c (symbols_free): Free `symbols'.
3086 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
3087 * src/output.c (m4_invoke): Move to...
3088 * src/scan-skel.l: here.
3089 (<<EOF>>): Close yyout, and free its name.
3090
8b752b00
AD
30912002-07-03 Akim Demaille <akim@epita.fr>
3092
3093 Fix some memory leaks, and fix a bug: state 0 was examined twice.
3094
3095 * src/LR0.c (new_state): Merge into...
3096 (state_list_append): this.
3097 (new_states): Merge into...
3098 (generate_states): here.
3099 (set_states): Don't ensure a proper `errs' state member here, do it...
3100 * src/conflicts.c (conflicts_solve): here.
3101 * src/state.h, src/state.c: Comment changes.
3102 (state_t): Rename member `shifts' as `transitions'.
3103 Adjust all dependencies.
3104 (errs_new): For consistency, also take the values as argument.
3105 (errs_dup): Remove.
3106 (state_errs_set): New.
3107 (state_reductions_set, state_transitions_set): Assert that no
3108 previous value was assigned.
3109 (state_free): New.
3110 (states_free): Use it.
3111 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
3112 temporary storage: use `errs' and `nerrs' as elsewhere.
3113 (set_conflicts): Allocate and free this `errs'.
3114
613f5e1a
AD
31152002-07-02 Akim Demaille <akim@epita.fr>
3116
3117 * lib/libiberty.h: New.
3118 * lib: Update the bitset implementation from upstream.
3119 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
3120 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
3121 * src/main.c: Adjust bitset stats calls.
3122
26e0cadc
PE
31232002-07-01 Paul Eggert <eggert@twinsun.com>
3124
3125 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
3126 char, so that negative chars don't collide with $.
3127
1154cced
AD
31282002-06-30 Akim Demaille <akim@epita.fr>
3129
3130 Have the GLR tests be `warning' checked, and fix the warnings.
3131
3132 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
3133 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
3134 (yyremoveDeletes): `yyi' and `yyj' are size_t.
3135 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
3136 (yyaddDeferredAction): static.
3137 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
3138 (yyreportParseError): yyprefix is const.
3139 yytokenp is used only when verbose.
3140 (yy__GNUC__): Replace with __GNUC__.
3141 (yypdumpstack): yyi is size_t.
3142 (yypreference): Un-yy local variables and arguments, to avoid
3143 clashes with `yyr1'. Anyway, we are not in the user name space.
3144 (yytname_size): be an int, as is compared with ints.
3145 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
3146 Use them.
3147 * tests/cxx-gram.at: Use quotation to protect $1.
3148 Use AT_COMPILE to enable warnings hunts.
3149 Prototype yylex and yyerror.
3150 `Use' argc.
3151 Include `string.h', not `strings.h'.
3152 Produce and prototype stmtMerge only when used.
3153 yylex takes a location.
3154
97650f4e
AD
31552002-06-30 Akim Demaille <akim@epita.fr>
3156
3157 We spend a lot of time in quotearg, in particular when --verbose.
3158
3159 * src/symtab.c (symbol_get): Store a quoted version of the key.
3160 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
3161 Adjust all callers.
3162
d2576365
AD
31632002-06-30 Akim Demaille <akim@epita.fr>
3164
3165 * src/state.h (reductions_t): Rename member `nreds' as num.
3166 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
3167 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
3168
ccaf65bc
AD
31692002-06-30 Akim Demaille <akim@epita.fr>
3170
3171 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
3172 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
3173 (shifts_to): Rename as...
3174 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
3175 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
3176 (TRANSITION_IS_DISABLED, transitions_to): these.
3177
87675353
AD
31782002-06-30 Akim Demaille <akim@epita.fr>
3179
3180 * src/print.c (print_shifts, print_gotos): Merge into...
3181 (print_transitions): this.
3182 (print_transitions, print_errs, print_reductions): Align the
3183 lookaheads columns.
3184 (print_core, print_transitions, print_errs, print_state,
3185 print_grammar): Output empty lines separator before, not after.
3186 (state_default_rule_compute): Rename as...
3187 (state_default_rule): this.
3188 * tests/conflicts.at (Defaulted Conflicted Reduction),
3189 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
3190 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
3191
ce4ccb4b
AD
31922002-06-30 Akim Demaille <akim@epita.fr>
3193
3194 Display items as we display rules.
3195
3196 * src/gram.h, src/gram.c (rule_lhs_print): New.
3197 * src/gram.c (grammar_rules_partial_print): Use it.
3198 * src/print.c (print_core): Likewise.
3199 * tests/conflicts.at (Defaulted Conflicted Reduction),
3200 (Unresolved SR Conflicts): Adjust.
3201 (Unresolved SR Conflicts): Adjust and rename as...
3202 (Resolved SR Conflicts): this, as was meant.
3203 * tests/regression.at (Web2c Report): Adjust.
3204
bc933ef1
AD
32052002-06-30 Akim Demaille <akim@epita.fr>
3206
3207 * src/print.c (state_default_rule_compute): New, extracted from...
3208 (print_reductions): here.
3209 Pessimize, but clarify the code.
3210 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
3211
53d4308d
AD
32122002-06-30 Akim Demaille <akim@epita.fr>
3213
3214 * src/output.c (action_row): Let default_rule be always a rule
3215 number.
3216
574fb2d5
AD
32172002-06-30 Akim Demaille <akim@epita.fr>
3218
3219 * src/closure.c (print_firsts, print_fderives, closure):
3220 Use BITSET_EXECUTE.
3221 * src/lalr.c (lookaheads_print): Likewise.
3222 * src/state.c (state_rule_lookaheads_print): Likewise.
3223 * src/print_graph.c (print_core): Likewise.
3224 * src/print.c (print_reductions): Likewise.
3225 * src/output.c (action_row): Likewise.
3226 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
3227
05811fd7
AD
32282002-06-30 Akim Demaille <akim@epita.fr>
3229
3230 * src/print_graph.c: Use report_flag.
3231
0e4d5753
AD
32322002-06-30 Akim Demaille <akim@epita.fr>
3233
3234 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
3235 to...
3236 * src/relation.h, src/relation.c (traverse, relation_digraph)
3237 (relation_print, relation_transpose): New.
3238
24c7d800
AD
32392002-06-30 Akim Demaille <akim@epita.fr>
3240
3241 * src/state.h, src/state.c (shifts_to): New.
3242 * src/lalr.c (build_relations): Use it.
3243
9222837b
AD
32442002-06-30 Akim Demaille <akim@epita.fr>
3245
3246 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
3247 (item_number_of_rule_number, rule_number_of_item_number): New.
3248 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
3249 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
3250 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
3251 Propagate their use.
3252 Much remains to be done, in particular wrt `shorts' from types.h.
3253
260008e5
AD
32542002-06-30 Akim Demaille <akim@epita.fr>
3255
3256 * src/symtab.c (symbol_new): Initialize the `printer' member.
3257
8a731ca8
AD
32582002-06-30 Akim Demaille <akim@epita.fr>
3259
3260 * src/LR0.c (save_reductions): Remove, replaced by...
3261 * src/state.h, src/state.c (state_reductions_set): New.
3262 (reductions, errs): Rename as...
3263 (reductions_t, errs_t): these.
3264 Adjust all dependencies.
3265
32e1e0a4
AD
32662002-06-30 Akim Demaille <akim@epita.fr>
3267
3268 * src/LR0.c (state_list_t, state_list_append): New.
3269 (first_state, last_state): Now symbol_list_t.
3270 (this_state): Remove.
3271 (new_itemsets, append_states, save_reductions): Take a state_t as
3272 argument.
3273 (set_states, generate_states): Adjust.
3274 (save_shifts): Remove, replaced by...
3275 * src/state.h, src/state.c (state_shifts_set): New.
3276 (shifts): Rename as...
3277 (shifts_t): this.
3278 Adjust all dependencies.
3279 * src/state.h (state_t): Remove the `next' member.
3280
e5fb6710
AD
32812002-06-30 Akim Demaille <akim@epita.fr>
3282
3283 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
3284 escaped in slot 0.
3285
c7ca99d4
AD
32862002-06-30 Akim Demaille <akim@epita.fr>
3287
3288 Use hash.h for the state hash table.
3289
3290 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
3291 (allocate_storage): Use state_hash_new.
3292 (free_storage): Use state_hash_free.
3293 (new_state, get_state): Adjust.
3294 * src/lalr.h, src/lalr.c (states): Move to...
3295 * src/states.h (state_t): Remove the `link' member, no longer
3296 used.
3297 * src/states.h, src/states.c: here.
3298 (state_hash_new, state_hash_free, state_hash_lookup)
3299 (state_hash_insert, states_free): New.
3300 * src/states.c (state_table, state_compare, state_hash): New.
3301 * src/output.c (output_actions): Do not free states now, since we
3302 still need to know the final_state number in `prepare', called
3303 afterwards. Do it...
3304 * src/main.c (main): here: call states_free after `output'.
3305
df0e7316
AD
33062002-06-30 Akim Demaille <akim@epita.fr>
3307
3308 * src/state.h, src/state.c (state_new): New, extracted from...
3309 * src/LR0.c (new_state): here.
3310 * src/state.h (STATE_ALLOC): Move to...
3311 * src/state.c: here.
3312 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
3313 * src/state.h, src/state.c: here.
3314
39f41916
AD
33152002-06-30 Akim Demaille <akim@epita.fr>
3316
3317 * src/reader.c (gensym): Rename as...
3318 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
3319 (getsym): Rename as...
3320 (symbol_get): this.
3321
d57650a5
AD
33222002-06-30 Akim Demaille <akim@epita.fr>
3323
3324 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
3325 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
3326 * src/output.c, src/print.c, src/print_graph.c: Propagate.
3327 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
3328
5a08f1ce
AD
33292002-06-30 Akim Demaille <akim@epita.fr>
3330
3331 Make the test suite pass with warnings checked.
3332
3333 * tests/actions.at (Printers and Destructors): Improve.
3334 Avoid unsigned vs. signed issues.
3335 * tests/calc.at: Don't exercise the scanner here, do it...
3336 * tests/input.at (Torturing the Scanner): here.
3337
720623af
PH
33382002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3339
88e7e941 3340 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
3341 reorganize first lines parallel to yacc.c.
3342
fb8135fa
AD
33432002-06-28 Akim Demaille <akim@epita.fr>
3344
3345 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
3346 (b4_token_enum, b4_token_defines): New, factored from...
3347 * data/lalr1.cc, data/yacc.c, glr.c: here.
3348
41442480
AD
33492002-06-28 Akim Demaille <akim@epita.fr>
3350
3351 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
3352 unused variables.
3353 * src/output.c (merger_output): static.
3354
e0e5bf84
AD
33552002-06-28 Akim Demaille <akim@epita.fr>
3356
3357 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
3358 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
3359 pacify GCC.
3360 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 3361
676385e2
PH
33622002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3363
3364 Accumulated changelog for new GLR parsing features.
3365
6a254321 3366 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
3367 conflicts_total_count.
3368 * src/conflicts.h: Ditto.
3369 * src/output.c (token_actions): Use the new name.
3370 (output_conflicts): Change conflp => conflict_list_heads, and
3371 confl => conflict_list for better readability.
3372 * data/glr.c: Use the new names.
3373 * NEWS: Add self to GLR announcement.
e0e5bf84 3374
676385e2
PH
3375 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
3376
3377 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
3378 Akim Demaille.
3379
3380 * data/bison.glr: Change name to glr.c
3381 * data/glr.c: Renamed from bison.glr.
3382 * data/Makefile.am: Add glr.c
e0e5bf84
AD
3383
3384 * src/getargs.c:
3385
676385e2
PH
3386 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
3387 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 3388
676385e2
PH
3389 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3390
3391 * data/bison.glr: Be sure to restore the
3392 current #line when returning to the skeleton contents after having
3393 exposed the input file's #line.
3394
3395 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3396
3397 * data/bison.glr: Bring up to date with changes to bison.simple.
3398
3399 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3400
3401 * data/bison.glr: Correct definitions that use b4_prefix.
3402 Various reformatting.
3403 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
3404 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
3405 yytokenp argument; now part of stack.
3406 (yychar): Define to behave as documented.
3407 (yyclearin): Ditto.
e0e5bf84 3408
676385e2
PH
3409 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3410
3411 * src/reader.h: Add declaration for free_merger_functions.
3412
3413 * src/reader.c (merge_functions): New variable.
3414 (get_merge_function): New function.
3415 (free_merger_functions): New function.
3416 (readgram): Check for %prec that is not followed by a symbol.
3417 Handle %dprec and %merge declarations.
3418 (packgram): Initialize dprec and merger fields in rules array.
3419
3420 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
3421 conflict_list_cnt, conflict_list_free): New variables.
3422 (table_grow): Also grow conflict_table.
e0e5bf84 3423 (prepare_rules): Output dprec and merger tables.
676385e2 3424 (conflict_row): New function.
e0e5bf84 3425 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
3426 default reduction in conflicted states for GLR parser so that there
3427 are spaces for the conflict lists.
3428 (save_row): Also save conflict information.
3429 (token_actions): Allocate conflict list.
3430 (merger_output): New function.
3431 (pack_vector): Pack conflict table, too.
3432 (output_conflicts): New function to output yyconflp and yyconfl.
3433 (output_check): Allocate conflict_tos.
3434 (output_actions): Output conflict tables, also.
3435 (output_skeleton): Output b4_mergers definition.
3436 (prepare): Output b4_max_rhs_length definition.
3437 Use 'bison.glr' as default skeleton for GLR parsers.
3438
3439 * src/gram.c (glr_parser): New flag.
3440 (grammar_free): Call free_merger_functions.
3441
3442 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
3443 all pairs of conflicting reductions, rather than just all tokens
3444 causing conflicts. Needed to size conflict tables.
e0e5bf84 3445 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
3446 interface.
3447 (conflicts_print): Ditto.
3448 (count_total_conflicts): New function.
3449
3450 * src/reader.h (merger_list): New type.
3451 (merge_functions): New variable.
3452
3453 * src/lex.h (tok_dprec, tok_merge): New token types.
3454
3455 * src/gram.h (rule_s): Add dprec and merger fields.
3456 (glr_parser): New flag.
3457
3458 * src/conflicts.h (count_total_conflicts): New function.
3459
3460 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
3461
3462 * doc/bison.texinfo (Generalized LR Parsing): New section.
3463 (GLR Parsers): New section.
3464 (Language and Grammar): Mention GLR parsing.
3465 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
3466 Correct typo ("tge" -> "the").
3467
3468 * data/bison.glr: New skeleton for GLR parsing.
3469
3470 * tests/cxx-gram.at: New tests for GLR parsing.
3471
3472 * tests/testsuite.at: Include cxx-gram.at.
3473
3474 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 3475
676385e2
PH
3476 * src/parse-gram.y:
3477
3478 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
3479
3480 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 3481
b5480d74 34822002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
3483
3484 * src/options.h, src/options.c: Remove.
3485 * src/getargs.c (short_options, long_options): New.
3486
60491a94
AD
34872002-06-27 Akim Demaille <akim@epita.fr>
3488
3489 * data/bison.simple, data/bison.c++: Rename as...
3490 * data/yacc.c, data/lalr1.cc: these.
3491 * doc/bison.texinfo (Environment Variables): Remove.
3492
9be0c25b
AD
34932002-06-25 Raja R Harinath <harinath@cs.umn.edu>
3494
3495 * src/getargs.c (report_argmatch): Initialize strtok().
3496
1ae72863
AD
34972002-06-20 Akim Demaille <akim@epita.fr>
3498
3499 * data/bison.simple (b4_symbol_actions): New, replaces...
3500 (b4_symbol_destructor, b4_symbol_printer): these.
3501 (yysymprint): Be sure to call YYPRINT only for tokens, and using
3502 user token numbers.
3503
87542d29
AD
35042002-06-20 Akim Demaille <akim@epita.fr>
3505
3506 * data/bison.simple (yydestructor): Rename as...
3507 (yydestruct): this.
3508
1a31ed21
AD
35092002-06-20 Akim Demaille <akim@epita.fr>
3510
3511 * src/symtab.h, src/symtab.c (symbol_type_set)
3512 (symbol_destructor_set, symbol_precedence_set): The location is
3513 the last argument.
3514 Adjust all callers.
3515
e776192e
AD
35162002-06-20 Akim Demaille <akim@epita.fr>
3517
3518 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
3519 internals.
3520 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
3521 Takes a location.
3522 * src/symtab.h, src/symtab.c (symbol_class_set)
3523 (symbol_user_token_number_set): Likewise.
3524 Adjust all callers.
3525 Promote complain_at.
3526 * tests/input.at (Type Clashes): Adjust.
3527
5c1180b3
AD
35282002-06-20 Akim Demaille <akim@epita.fr>
3529
3530 * data/bison.simple (YYLEX): Fix the declaration when
3531 %pure-parser.
3532
e3170060
AD
35332002-06-20 Akim Demaille <akim@epita.fr>
3534
3535 * data/bison.simple (yysymprint): Don't print the token number,
3536 just its name.
3537 * tests/actions.at (Destructors): Rename as...
3538 (Printers and Destructors): this.
3539 Also exercise %printer.
3540
253862fd
AD
35412002-06-20 Akim Demaille <akim@epita.fr>
3542
3543 * data/bison.simple (YYDSYMPRINT): New.
3544 Use it to remove many of the #if YYDEBUG/if (yydebug).
3545
366eea36
AD
35462002-06-20 Akim Demaille <akim@epita.fr>
3547
3548 * src/symtab.h, src/symtab.c (symbol_t): printer and
3549 printer_location are new members.
3550 (symbol_printer_set): New.
3551 * src/parse-gram.y (PERCENT_PRINTER): New token.
3552 Handle its associated rule.
3553 * src/scan-gram.l: Adjust.
3554 (handle_destructor_at, handle_destructor_dollar): Rename as...
3555 (handle_symbol_code_at, handle_symbol_code_dollar): these.
3556 * src/output.c (symbol_printers_output): New.
3557 (output_skeleton): Call it.
3558 * data/bison.simple (yysymprint): New. Cannot be named yyprint
3559 since there are already many grammar files with a user `yyprint'.
3560 Replace the calls to YYPRINT to calls to yysymprint.
3561 * tests/calc.at: Adjust.
3562 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
3563 taking advantage of parser very internal details (stack size!).
3564
4f25ebb0
AD
35652002-06-20 Akim Demaille <akim@epita.fr>
3566
3567 * src/scan-gram.l: Complete the scanner with the missing patterns
3568 to pacify Flex.
3569 Use `quote' and `symbol_tag_get' where appropriate.
3570
93b68a0e
AD
35712002-06-19 Akim Demaille <akim@epita.fr>
3572
3573 * tests/actions.at (Destructors): Augment to test locations.
3574 * data/bison.simple (yydestructor): Pass it the current location
3575 if locations are enabled.
3576 Prototype only when __STDC__ or C++.
3577 Change the argument names to move into the yy name space: there is
3578 user code here.
3579
58612f1d
AD
35802002-06-19 Akim Demaille <akim@epita.fr>
3581
74310291
AD
3582 * data/bison.simple (b4_pure_if): New.
3583 Use it instead of #ifdef YYPURE.
3584
35852002-06-19 Akim Demaille <akim@epita.fr>
3586
3587 * data/bison.simple (b4_location_if): New.
58612f1d
AD
3588 Use it instead of #ifdef YYLSP_NEEDED.
3589
f25bfb75
AD
35902002-06-19 Akim Demaille <akim@epita.fr>
3591
3592 Prepare @$ in %destructor, but currently don't bind it in the
3593 skeleton, as %location use is not cleaned up yet.
3594
3595 * src/scan-gram.l (handle_dollar, handle_destructor_at)
3596 (handle_action_at): New.
3597 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
3598 a braced_code_t and a location as additional arguments.
3599 (handle_destructor_dollar): Instead of requiring `b4_eval', just
3600 unquote one when outputting `b4_dollar_dollar'.
3601 Adjust callers.
3602 * data/bison.simple (b4_eval): Remove.
3603 (b4_symbol_destructor): Adjust.
3604 * tests/input.at (Invalid @n): Adjust.
3605
c732d2c6
AD
36062002-06-19 Zack Weinberg <zack@codesourcery.com>
3607
3608 * doc/bison.texinfo: Document ability to have multiple
3609 prologue sections.
3610
8c165d89
AD
36112002-06-18 Akim Demaille <akim@epita.fr>
3612
3613 * src/files.c (compute_base_names): When computing the output file
3614 names from the input file name, strip the directory part.
3615
ca98bf57
AD
36162002-06-18 Akim Demaille <akim@epita.fr>
3617
3618 * data/bison.simple.new: Comment changes.
3619 Reported by Andreas Schwab.
3620
0bfb02ff
AD
36212002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
3622
3623 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
3624 there are no `label `yyoverflowlab' defined but not used' warnings
3625 when yyoverflow is defined.
3626
24c0aad7
AD
36272002-06-18 Akim Demaille <akim@epita.fr>
3628
3629 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
3630 new member.
3631 (symbol_destructor_set): Adjust.
3632 * src/output.c (symbol_destructors_output): Output the destructor
3633 locations.
3634 Output the symbol name.
3635 * data/bison.simple (b4_symbol_destructor): Adjust.
3636
5719c109
AD
36372002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
3638 and Akim Demaille <akim@epita.fr>
3639
3640 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
3641 what's left on the stack when the error recovery hits EOF.
3642 * tests/actions.at (Destructors): Complete to exercise this case.
3643
9280d3ef
AD
36442002-06-17 Akim Demaille <akim@epita.fr>
3645
3646 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
3647 arguments is really empty, not only equal to `[]'.
3648 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
3649 member.
3650 (symbol_destructor_set): New.
3651 * src/output.c (symbol_destructors_output): New.
3652 * src/reader.h (brace_code_t, current_braced_code): New.
3653 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
3654 (handle_dollar): Rename as...
3655 (handle_action_dollar): this.
3656 (handle_destructor_dollar): New.
3657 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
3658 (grammar_declaration): Use it.
3659 * data/bison.simple (yystos): Is always defined.
3660 (yydestructor): New.
3661 * tests/actions.at (Destructors): New.
3662 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
3663
dafdc66f
AD
36642002-06-17 Akim Demaille <akim@epita.fr>
3665
3666 * src/symlist.h, src/symlist.c (symbol_list_length): New.
3667 * src/scan-gram.l (handle_dollar, handle_at): Compute the
3668 rule_length only when needed.
3669 * src/output.c (actions_output, token_definitions_output): Output
3670 the full M4 block.
3671 * src/symtab.c: Don't access directly to the symbol tag, use
3672 symbol_tag_get.
3673 * src/parse-gram.y: Use symbol_list_free.
3674
56c47203
AD
36752002-06-17 Akim Demaille <akim@epita.fr>
3676
3677 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
3678 (symbol_list_prepend, get_type_name): Move to...
3679 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
3680 (symbol_list_prepend, symbol_list_n_type_name_get): here.
3681 Adjust all callers.
3682 (symbol_list_free): New.
3683 * src/scan-gram.l (handle_dollar): Takes a location.
3684 * tests/input.at (Invalid $n): Adjust.
3685
1e0bab92
AD
36862002-06-17 Akim Demaille <akim@epita.fr>
3687
3688 * src/reader.h, src/reader.c (symbol_list_new): Export it.
3689 (symbol_list_prepend): New.
3690 * src/parse-gram.y (%union): `list' is a new member.
3691 (symbols.1): New, replaces...
3692 (terms_to_prec.1, nterms_to_type.1): these.
3693 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
3694 Take a location as additional argument.
3695 Adjust all callers.
3696
04e60654
AD
36972002-06-15 Akim Demaille <akim@epita.fr>
3698
3699 * src/parse-gram.y: Move %token in the declaration section so that
3700 we don't depend upon CVS Bison.
3701
10e5b8bd
AD
37022002-06-15 Akim Demaille <akim@epita.fr>
3703
3704 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
3705 * src/print.c (print_core): Use it.
3706
9801d40c
AD
37072002-06-15 Akim Demaille <akim@epita.fr>
3708
3709 * src/conflicts.c (log_resolution): Accept the rule involved in
3710 the sr conflicts instead of the lookahead number that points to
3711 that rule.
3712 (flush_reduce): Accept the current lookahead vector as argument,
3713 instead of the index in LA.
3714 (resolve_sr_conflict): Accept the current number of lookahead
3715 bitset to consider for the STATE, instead of the index in LA.
3716 (set_conflicts): Adjust.
3717 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
3718
c0263492
AD
37192002-06-15 Akim Demaille <akim@epita.fr>
3720
3721 * src/state.h (state_t): Replace the `lookaheadsp' member, a
3722 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
3723 Adjust all dependencies.
3724 * src/lalr.c (initialize_lookaheads): Split into...
3725 (states_lookaheads_count, states_lookaheads_initialize): these.
3726 (lalr): Adjust.
3727
9757c359
AD
37282002-06-15 Akim Demaille <akim@epita.fr>
3729
3730 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
3731 out of...
3732 (grammar_rules_print): here.
3733 * src/reduce.c (reduce_output): Use it.
3734 * tests/reduce.at (Useless Rules, Reduced Automaton)
3735 (Underivable Rules): Adjust.
3736
6b98e4b5
AD
37372002-06-15 Akim Demaille <akim@epita.fr>
3738
3739 Copy BYacc's nice way to report the grammar.
3740
3741 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
3742 New.
3743 Don't print the rules' location, it is confusing and useless.
3744 (rule_print): Use grammar_rhs_print.
3745 * src/print.c (print_grammar): Use grammar_rules_print.
3746
6b98e4b5
AD
37472002-06-15 Akim Demaille <akim@epita.fr>
3748
3749 Complete and rationalize `useless thing' warnings.
3750
3751 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
3752 (symbol_tag_print): New.
3753 Use them everywhere in place of accessing directly the tag member.
3754 * src/gram.h, src/gram.c (rule_print): New.
3755 Use it where a rule used to be printed `by hand'.
3756 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
3757 (reduce_grammar_tables): Report the useless rules.
3758 (reduce_print): Useless things are a warning, not an error.
3759 Report it as such.
3760 * tests/reduce.at (Useless Nonterminals, Useless Rules):
3761 (Reduced Automaton, Underivable Rules): Adjust.
3762 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
3763 * tests/conflicts.at (Unresolved SR Conflicts)
3764 (Solved SR Conflicts): Adjust.
3765
ee000ba4
AD
37662002-06-15 Akim Demaille <akim@epita.fr>
3767
3768 Let symbols have a location.
3769
3770 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
3771 (getsym): Adjust.
3772 Adjust all callers.
3773 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
3774 Use location_t, not int.
3775 * src/symtab.c (symbol_check_defined): Take advantage of the
3776 location.
3777 * tests/regression.at (Invalid inputs): Adjust.
3778
8efe435c
AD
37792002-06-15 Akim Demaille <akim@epita.fr>
3780
3781 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3782 (input): Don't try to initialize yylloc here, do it in the
3783 scanner.
3784 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3785 * src/gram.h (rule_t): Change line and action_line into location
3786 and action_location, of location_t type.
3787 Adjust all dependencies.
3788 * src/location.h, src/location.c (empty_location): New.
3789 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3790 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3791 (grammar_current_rule_symbol_append)
3792 (grammar_current_rule_action_append): Expect a location as argument.
3793 * src/reader.c (grammar_midrule_action): Adjust to attach an
3794 action's location as dummy symbol location.
3795 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3796 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3797 the line numbers.
3798
1921f1d7
AD
37992002-06-14 Akim Demaille <akim@epita.fr>
3800
3801 Grammar declarations may be found in the grammar section.
3802
3803 * src/parse-gram.y (rules_or_grammar_declaration): New.
3804 (declarations): Each declaration may end with a semicolon, not
3805 just...
3806 (grammar_declaration): `"%union"'.
3807 (grammar): Branch to rules_or_grammar_declaration.
3808
4515534c
AD
38092002-06-14 Akim Demaille <akim@epita.fr>
3810
3811 * src/main.c (main): Invoke scanner_free.
3812
f958596b
AD
38132002-06-14 Akim Demaille <akim@epita.fr>
3814
3815 * src/output.c (m4_invoke): Extracted from...
3816 (output_skeleton): here.
3817 Free tempfile.
3818
2c569025
AD
38192002-06-14 Akim Demaille <akim@epita.fr>
3820
3821 * src/parse-gram.y (directives, directive, gram)
3822 (grammar_directives, precedence_directives, precedence_directive):
3823 Rename as...
3824 (declarations, declaration, grammar, grammar_declaration)
3825 (precedence_declaration, precedence_declarator): these.
3826 (symbol_declaration): New.
3827
592e8d4d
AD
38282002-06-14 Akim Demaille <akim@epita.fr>
3829
3830 * src/files.c (action_obstack): Remove, unused.
3831 (output_obstack): Remove it, and all its dependencies, as it is no
3832 longer needed.
3833 * src/reader.c (epilogue_set): Build the epilogue in the
3834 muscle_obstack.
3835 * src/output.h, src/output.c (muscle_obstack): Move to...
3836 * src/muscle_tab.h, src/muscle_tab.h: here.
3837 (muscle_init): Initialize muscle_obstack.
3838 (muscle_free): New.
3839 * src/main.c (main): Call it.
3840
0c15323d
AD
38412002-06-14 Akim Demaille <akim@epita.fr>
3842
3843 * src/location.h: New, extracted from...
3844 * src/reader.h: here.
3845 * src/Makefile.am (noinst_HEADERS): Merge into
3846 (bison_SOURCES): this.
3847 Add location.h.
3848 * src/parse-gram.y: Use location_t instead of Bison's.
3849 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3850 Use location_t instead of ints.
3851
e96c9728
AD
38522002-06-14 Akim Demaille <akim@epita.fr>
3853
3854 * data/bison.simple, data/bison.c++: Be sure to restore the
3855 current #line when returning to the skeleton contents after having
3856 exposed the input file's #line.
3857
75d1fe16
AD
38582002-06-12 Akim Demaille <akim@epita.fr>
3859
3860 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3861 eager.
3862 * tests/actions.at (Exotic Dollars): New.
3863
6c35d22c
AD
38642002-06-12 Akim Demaille <akim@epita.fr>
3865
3866 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3867 ['"/] too eagerly.
3868 * tests/input.at (Torturing the Scanner): New.
3869
1d6412ad
AD
38702002-06-11 Akim Demaille <akim@epita.fr>
3871
3872 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3873 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3874 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3875 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3876 * src/reader.c (reader): Use it.
3877
4cdb01db
AD
38782002-06-11 Akim Demaille <akim@epita.fr>
3879
3880 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3881 Adjust all callers.
3882 (scanner_last_string_free): New.
3883
44995b2e
AD
38842002-06-11 Akim Demaille <akim@epita.fr>
3885
3886 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3887 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3888 (last_string, YY_OBS_FREE): New.
3889 Use them when returning an ID.
3890
e9955c83
AD
38912002-06-11 Akim Demaille <akim@epita.fr>
3892
3893 Have Bison grammars parsed by a Bison grammar.
3894
3895 * src/reader.c, src/reader.h (prologue_augment): New.
3896 * src/reader.c (copy_definition): Remove.
3897
3898 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3899 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3900 (grammar_current_rule_prec_set, grammar_current_rule_check)
3901 (grammar_current_rule_symbol_append)
3902 (grammar_current_rule_action_append): Export.
3903 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3904 (symbol_list_action_append): Remove.
3905 Hook the routines from reader.
3906 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3907 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3908
3909 * src/reader.c (read_declarations): Remove, unused.
3910
3911 * src/parse-gram.y: Handle the epilogue.
3912 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3913 (grammar_start_symbol_set): this.
3914 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3915 * src/reader.c (readgram): Remove, unused.
3916 (reader): Adjust to insert eoftoken and axiom where appropriate.
3917
3918 * src/reader.c (copy_dollar): Replace with...
3919 * src/scan-gram.h (handle_dollar): this.
3920 * src/parse-gram.y: Remove `%thong'.
3921
3922 * src/reader.c (copy_at): Replace with...
3923 * src/scan-gram.h (handle_at): this.
3924
3925 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3926 New.
3927
3928 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3929 time being.
3930
3931 * src/reader.h, src/reader.c (grammar_rule_end): New.
3932
3933 * src/parse.y (current_type, current_class): New.
3934 Implement `%nterm', `%token' support.
3935 Merge `%term' into `%token'.
3936 (string_as_id): New.
3937 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3938 type name.
3939
3940 * src/parse-gram.y: Be sure to handle properly the beginning of
3941 rules.
3942
3943 * src/parse-gram.y: Handle %type.
3944 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3945
3946 * src/parse-gram.y: More directives support.
3947 * src/options.c: No longer handle source directives.
3948
3949 * src/parse-gram.y: Fix %output.
3950
3951 * src/parse-gram.y: Handle %union.
3952 Use the prologue locations.
3953 * src/reader.c (parse_union_decl): Remove.
3954
3955 * src/reader.h, src/reader.c (epilogue_set): New.
3956 * src/parse-gram.y: Use it.
3957
3958 * data/bison.simple, data/bison.c++: b4_stype is now either not
3959 defined, then default to int, or to the contents of %union,
3960 without `union' itself.
3961 Adjust.
3962 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3963
3964 * src/output.c (actions_output): Don't output braces, as they are
3965 already handled by the scanner.
3966
3967 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3968 characters to themselves.
3969
3970 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3971 that the epilogue has a proper #line.
3972
3973 * src/parse-gram.y: Handle precedence/associativity.
3974
3975 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3976 a terminal.
3977 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3978 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3979 at all to define terminals that cannot be emitted.
3980
3981 * src/scan-gram.l: Escape M4 characters.
3982
3983 * src/scan-gram.l: Working properly with escapes in user
3984 strings/characters.
3985
3986 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3987 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3988 grammar.
3989 Use more modest sizes, as for the time being the parser does not
3990 release memory, and therefore the process swallows a huge amount
3991 of memory.
3992
3993 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3994 stricter %token grammar.
3995
3996 * src/symtab.h (associativity): Add `undef_assoc'.
3997 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3998 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3999
4000 * tests/regression.at (Invalid %directive): Remove, as it is now
4001 meaningless.
4002 (Invalid inputs): Adjust to the new error messages.
4003 (Token definitions): The new grammar doesn't allow too many
4004 eccentricities.
4005
4006 * src/lex.h, src/lex.c: Remove.
4007 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
4008 (copy_character, copy_string2, copy_string, copy_identifier)
4009 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
4010 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
4011 (parse_action): Remove.
4012 * po/POTFILES.in: Adjust.
4013
2e047461
AD
40142002-06-11 Akim Demaille <akim@epita.fr>
4015
4016 * src/reader.c (parse_action): Don't store directly into the
4017 rule's action member: return the action as a string.
4018 Don't require `rule_length' as an argument: compute it.
4019 (grammar_current_rule_symbol_append)
4020 (grammar_current_rule_action_append): New, eved out from
4021 (readgram): here.
4022 Remove `action_flag', `rulelength', unused now.
4023
9af3fbce
AD
40242002-06-11 Akim Demaille <akim@epita.fr>
4025
4026 * src/reader.c (grammar_current_rule_prec_set).
4027 (grammar_current_rule_check): New, eved out from...
4028 (readgram): here.
4029 Remove `xaction', `first_rhs': useless.
4030 * tests/input.at (Type clashes): New.
4031 * tests/existing.at (GNU Cim Grammar): Adjust.
4032
1485e106
AD
40332002-06-11 Akim Demaille <akim@epita.fr>
4034
4035 * src/reader.c (grammar_midrule_action): New, Eved out from
4036 (readgram): here.
4037
da4160c3
AD
40382002-06-11 Akim Demaille <akim@epita.fr>
4039
4040 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
4041 New.
4042 (readgram): Use them as replacement of inlined code, crule and
4043 crule1.
4044
f6d0f937
AD
40452002-06-11 Akim Demaille <akim@epita.fr>
4046
4047 * src/reader.c (grammar_end, grammar_symbol_append): New.
4048 (readgram): Use them.
4049 Make the use of `p' as local as possible.
4050
69078d4b
AD
40512002-06-10 Akim Demaille <akim@epita.fr>
4052
4053 GCJ's parser requires the tokens to be defined before the prologue.
4054
4055 * data/bison.simple: Output the token definition before the user's
4056 prologue.
4057 * tests/regression.at (Braces parsing, Duplicate string)
4058 (Mixing %token styles): Check the output from bison.
4059 (Early token definitions): New.
4060
5e424082
AD
40612002-06-10 Akim Demaille <akim@epita.fr>
4062
4063 * src/symtab.c (symbol_user_token_number_set): Don't complain when
4064 assigning twice the same user number to a token, so that we can
4065 use it in...
4066 * src/lex.c (lex): here.
4067 Also use `symbol_class_set' instead of hand written code.
4068 * src/reader.c (parse_assoc_decl): Likewise.
4069
44536b35
AD
40702002-06-10 Akim Demaille <akim@epita.fr>
4071
4072 * src/symtab.c, src/symtab.c (symbol_class_set)
4073 (symbol_user_token_number_set): New.
4074 * src/reader.c (parse_token_decl): Use them.
4075 Use a switch instead of ifs.
4076 Use a single argument.
4077
8b9f2372
AD
40782002-06-10 Akim Demaille <akim@epita.fr>
4079
4080 Remove `%thong' support as it is undocumented, unused, duplicates
4081 `%token's job, and creates useless e-mail traffic with people who
4082 want to know what it is, why it is undocumented, unused, and
4083 duplicates `%token's job.
4084
4085 * src/reader.c (parse_thong_decl): Remove.
4086 * src/options.c (option_table): Remove "thong".
4087 * src/lex.h (tok_thong): Remove.
4088
3ae2b51f
AD
40892002-06-10 Akim Demaille <akim@epita.fr>
4090
4091 * src/symtab.c, src/symtab.c (symbol_type_set)
4092 (symbol_precedence_set): New.
4093 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
4094 (value_components_used): Remove, unused.
4095
2f1afb73
AD
40962002-06-09 Akim Demaille <akim@epita.fr>
4097
4098 Move symbols handling code out of the reader.
4099
4100 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
4101 (axiom): Move to...
4102 * src/symtab.h, src/symtab.c: here.
4103
4104 * src/gram.c (start_symbol): Remove: use startsymbol->number.
4105 * src/reader.c (startval): Rename as...
4106 * src/symtab.h, src/symtab.c (startsymbol): this.
4107 * src/reader.c: Adjust.
4108
4109 * src/reader.c (symbol_check_defined, symbol_make_alias)
4110 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4111 (token_translations_init)
4112 Move to...
4113 * src/symtab.c: here.
4114 * src/reader.c (packsymbols): Move to...
4115 * src/symtab.h, src/symtab.c (symbols_pack): here.
4116 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
4117 argument.
4118
e9bca3ad
AD
41192002-06-03 Akim Demaille <akim@epita.fr>
4120
4121 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
4122 then statements.
4123
86eff183
AD
41242002-06-03 Akim Demaille <akim@epita.fr>
4125
4126 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
4127 structs with non literals.
4128 * src/scan-skel.l: never-interactive.
4129 * src/conflicts.c (enum conflict_resolution_e): No trailing
4130 comma.
4131 * src/getargs.c (usage): Split long literal strings.
4132 Reported by Hans Aberg.
4133
717be197
AD
41342002-05-28 Akim Demaille <akim@epita.fr>
4135
4136 * data/bison.c++: Use C++ ostreams.
4137 (cdebug_): New member.
4138
670ddffd
AD
41392002-05-28 Akim Demaille <akim@epita.fr>
4140
4141 * src/output.c (output_skeleton): Be sure to allocate enough room
4142 for `/' _and_ for `\0' in full_skeleton.
4143
769b430f
AD
41442002-05-28 Akim Demaille <akim@epita.fr>
4145
4146 * data/bison.c++: Catch up with bison.simple:
4147 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4148 and Paul Eggert <eggert@twinsun.com>: `error' handing.
4149 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
4150 and popping traces.
4151
7067cb36
PH
41522002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4153
4154 * src/output.c (output_skeleton): Put an explicit path in front of
4155 the skeleton file name, rather than relying on the -I directory,
4156 to partially alleviate effects of having a skeleton file lying around
4157 in the current directory.
769b430f 4158
4a713ec2
PH
41592002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4160
769b430f 4161 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
4162 obstack_printf should be obstack_fgrow1.
4163
b408954b
AD
41642002-05-26 Akim Demaille <akim@epita.fr>
4165
4166 * src/state.h (state_t): `solved_conflicts' is a new member.
4167 * src/LR0.c (new_state): Set it to 0.
4168 * src/conflicts.h, src/conflicts.c (print_conflicts)
4169 (free_conflicts, solve_conflicts): Rename as...
4170 (conflicts_print, conflicts_free, conflicts_solve): these.
4171 Adjust callers.
4172 * src/conflicts.c (enum conflict_resolution_e)
4173 (solved_conflicts_obstack): New, used by...
4174 (log_resolution): this.
4175 Adjust to attach the conflict resolution to each state.
4176 Complete the description with the precedence/associativity
4177 information.
4178 (resolve_sr_conflict): Adjust.
4179 * src/print.c (print_state): Output its solved_conflicts.
4180 * tests/conflicts.at (Unresolved SR Conflicts)
4181 (Solved SR Conflicts): Exercise --report=all.
4182
a49aecd5
AD
41832002-05-26 Akim Demaille <akim@epita.fr>
4184
4185 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4186 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4187 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
4188 (token_number_t, item_number_as_token_number)
4189 (token_number_as_item_number, muscle_insert_token_number_table):
4190 Rename as...
4191 (symbol_number_t, item_number_as_symbol_number)
4192 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
4193 these, since it is more appropriate.
4194
5504898e
AD
41952002-05-26 Akim Demaille <akim@epita.fr>
4196
4197 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
4198 `Error:' lines.
4199 * data/bison.simple (yystos) [YYDEBUG]: New.
4200 (yyparse) [YYDEBUG]: Display the symbols which are popped during
4201 error recovery.
4202 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
4203
ec3bc396
AD
42042002-05-25 Akim Demaille <akim@epita.fr>
4205
4206 * doc/bison.texinfo (Debugging): Split into...
4207 (Tracing): this new section, its former contents, and...
4208 (Understanding): this new section.
4209 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
4210 by...
4211 (report_flag): this.
4212 Adjust all dependencies.
4213 (report_args, report_types, report_argmatch): New.
4214 (usage, getargs): Report/support -r, --report.
4215 * src/options.h
4216 (struct option_table_struct): Rename as..,
4217 (struct option_table_s): this.
4218 Rename the `set_flag' member to `flag' to match with getopt_long's
4219 struct.
4220 * src/options.c (option_table): Split verbose into an entry for
4221 %verbose, and another for --verbose.
4222 Support --report/-r, so remove -r from the obsolete --raw.
4223 * src/print.c: Attach full item sets and lookaheads reports to
4224 report_flag instead of trace_flag.
4225 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
4226
78df8250
PE
42272002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4228 and Paul Eggert <eggert@twinsun.com>
769b430f 4229
78df8250
PE
4230 * data/bison.simple (yyparse): Correct error handling to conform to
4231 POSIX and yacc. Specifically, after syntax error is discovered,
4232 do not reduce further before shifting the error token.
4233 Clean up the code a bit by removing the labels yyerrdefault,
4234 yyerrhandle, yyerrpop.
4235 * NEWS: Document the above.
4236
c0c9ea05
PH
42372002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4238
4239 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
4240 type; it isn't always big enough, since it doesn't necessarily
4241 include non-terminals.
769b430f 4242 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
4243 the latter can be removed.
4244 (yy_token_number_type): Remove, only one use.
4245 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
4246 don't use TokenNumberType as element type.
769b430f 4247
c0c9ea05
PH
4248 * tests/regression.at: Modify expected output to agree with change
4249 to yyr1 and yytranslate.
769b430f 4250
6390a83f
FK
42512002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
4252
4253 * src/reader.c (parse_action): Use copy_character instead of
4254 obstack_1grow.
4255
db7c8e9a
AD
42562002-05-13 Akim Demaille <akim@epita.fr>
4257
4258 * tests/regression.at (Token definitions): Prototype yylex and
4259 yyerror.
4260
fcc61800
PH
42612002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4262
158c687b 4263 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
4264 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
4265 32-bit arithmetic.
4266 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
4267
5683e9b2
AD
42682002-05-07 Akim Demaille <akim@epita.fr>
4269
4270 * tests/synclines.at: Be sure to prototype yylex and yyerror to
4271 avoid GCC warnings.
4272
0c2d3f4c
AD
42732002-05-07 Akim Demaille <akim@epita.fr>
4274
4275 Kill GCC warnings.
4276
4277 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
4278 over the RHS of each rule.
4279 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
4280 * src/state.h (state_t): Member `nitems' is unsigned short.
4281 * src/LR0.c (get_state): Adjust.
4282 * src/reader.c (packgram): Likewise.
4283 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
4284 `Type'.
4285 (muscle_insert_int_table): Remove, unused.
4286 (prepare_rules): Remove `max'.
4287
1565b720
AD
42882002-05-06 Akim Demaille <akim@epita.fr>
4289
4290 * src/closure.c (print_firsts): Display of the symbol tags.
4291 (bitmatrix_print): Move to...
4292 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
4293 here.
4294 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
4295
cfaee611
AD
42962002-05-06 Akim Demaille <akim@epita.fr>
4297
4298 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
4299 hash_do_for_each.
4300
458be8e0
AD
43012002-05-06 Akim Demaille <akim@epita.fr>
4302
4303 * src/LR0.c (new_state, get_state): Instead of using the global
4304 `kernel_size' and `kernel_base', have two new arguments:
4305 `core_size' and `core'.
4306 Adjust callers.
4307
a900a624
AD
43082002-05-06 Akim Demaille <akim@epita.fr>
4309
4310 * src/reader.c (packgram): No longer end `ritem' with a 0
4311 sentinel: it is not used.
4312
d4e7d3a1
AD
43132002-05-05 Akim Demaille <akim@epita.fr>
4314
4315 New experimental feature: display the lookaheads in the report and
4316 graph.
4317
4318 * src/print (print_core): When --trace-flag, display the rules
4319 lookaheads.
4320 * src/print_graph.c (print_core): Likewise.
4321 Swap the arguments.
4322 Adjust caller.
4323
39ceb25b
AD
43242002-05-05 Akim Demaille <akim@epita.fr>
4325
4326 * tests/torture.at (Many lookaheads): New test.
4327
5372019f
AD
43282002-05-05 Akim Demaille <akim@epita.fr>
4329
4330 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
4331 (GENERATE_MUSCLE_INSERT_TABLE): this.
4332 (output_int_table, output_unsigned_int_table, output_short_table)
4333 (output_token_number_table, output_item_number_table): Replace with...
4334 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
4335 (muscle_insert_short_table, muscle_insert_token_number_table)
4336 (muscle_insert_item_number_table): these.
4337 Adjust all callers.
4338 (prepare_tokens): Don't free `translations', since...
4339 * src/reader.h, src/reader.c (grammar_free): do it.
4340 Move to...
4341 * src/gram.h, src/gram.c (grammar_free): here.
4342 * data/bison.simple, data/bison.c++: b4_token_number_max is now
4343 b4_translate_max.
4344
5df5f6d5
AD
43452002-05-05 Akim Demaille <akim@epita.fr>
4346
4347 * src/output.c (output_unsigned_int_table): New.
4348 (prepare_rules): `i' is unsigned.
4349 `prhs', `rline', `r2' are unsigned int.
4350 Rename muscle `rhs_number_max' as `rhs_max'.
4351 Output muscles `prhs_max', `rline_max', and `r2_max'.
4352 Free rline and r1.
4353 * data/bison.simple, data/bison.c++: Adjust to use these muscles
4354 to compute types instead of constant types.
4355 * tests/regression.at (Web2c Actions): Adjust.
4356
b87f8b21
AD
43572002-05-04 Akim Demaille <akim@epita.fr>
4358
4359 * src/symtab.h (SALIAS, SUNDEF): Rename as...
4360 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
4361 Adjust dependencies.
4362 * src/output.c (token_definitions_output): Be sure not to output a
4363 `#define 'a'' when fed with `%token 'a' "a"'.
4364 * tests/regression.at (Token definitions): New.
4365
8bb936e4
PE
43662002-05-03 Paul Eggert <eggert@twinsun.com>
4367
4368 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
4369 for K&R C.
4370
43712002-05-03 gettextize <bug-gnu-gettext@gnu.org>
4372
4373 * Makefile.am (SUBDIRS): Remove intl.
4374 (EXTRA_DIST): Add config/config.rpath.
4375
53c71a12
AD
43762002-05-03 Akim Demaille <akim@epita.fr>
4377
4378 * data/bison.simple (m4_if): Don't output empty enums.
4379 And actually, output valid enum definitions :(.
4380
289dd0cf
AD
43812002-05-03 Akim Demaille <akim@epita.fr>
4382
4383 * configure.bat: Remove, completely obsolete.
4384 * Makefile.am (EXTRA_DIST): Adjust.
4385 Don't distribute config.rpath...
4386 * config/Makefile.am (EXTRA_DIST): Do it.
4387
db85e524
AD
43882002-05-03 Akim Demaille <akim@epita.fr>
4389
4390 * configure.in (GETTEXT_VERSION): New.
4391 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
4392
83ccf991
AD
43932002-05-03 Akim Demaille <akim@epita.fr>
4394
4395 * data/bison.simple (b4_token_enum): New.
4396 (b4_token_defines): Use it to output tokens both as #define and
4397 enums.
4398 Suggested by Paul Eggert.
4399 * src/output.c (token_definitions_output): Don't output spurious
4400 white spaces.
4401
1f418995
AD
44022002-05-03 Akim Demaille <akim@epita.fr>
4403
4404 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4405
45119f04
RA
44062002-05-02 Robert Anisko <robert@lrde.epita.fr>
4407
4408 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
4409 Update the stack class, give a try to deque as the default container.
4410
b2d52318
AD
44112002-05-02 Akim Demaille <akim@epita.fr>
4412
4413 * data/bison.simple (yyparse): Do not implement @$ = @1.
4414 (YYLLOC_DEFAULT): Adjust to do it.
4415 * doc/bison.texinfo (Location Default Action): Fix.
4416
3a8b4109
AD
44172002-05-02 Akim Demaille <akim@epita.fr>
4418
4419 * src/reader.c (parse_braces): Merge into...
4420 (parse_action): this.
4421
84614e13
AD
44222002-05-02 Akim Demaille <akim@epita.fr>
4423
4424 * configure.in (ALL_LINGUAS): Remove.
4425 * po/LINGUAS, hr.po: New.
4426
fdbcd8e2
AD
44272002-05-02 Akim Demaille <akim@epita.fr>
4428
4429 Remove the so called hairy (semantic) parsers.
4430
4431 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
4432 * src/gram.h, src/gram.c (semantic_parser): Remove.
4433 (rule_t): Remove the guard and guard_line members.
4434 * src/lex.h (token_t): remove tok_guard.
4435 * src/options.c (option_table): Remove %guard and %semantic_parser
4436 support.
4437 * src/output.c, src/output.h (guards_output): Remove.
4438 (prepare): Adjust.
4439 (token_definitions_output): Don't output the `T'
4440 tokens (???).
4441 (output_skeleton): Don't output the guards.
4442 * src/files.c, src/files.c (attrsfile): Remove.
4443 * src/reader.c (symbol_list): Remove the guard and guard_line
4444 members.
4445 Adjust dependencies.
4446 (parse_guard): Remove.
4447 * data/bison.hairy: Remove.
4448 * doc/bison.texinfo (Environment Variables): Remove occurrences of
4449 BISON_HAIRY.
4450
82b6cb3f
AD
44512002-05-02 Akim Demaille <akim@epita.fr>
4452
4453 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
4454 (parse_guard): Rename the formal argument `stack_offset' as
4455 `rule_length', which is more readable.
4456 Adjust callers.
4457 (copy_at, copy_dollar): Instead of outputting the hard coded
4458 values of $$, $n and so forth, output invocation to b4_lhs_value,
4459 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
4460 Note: this patch partially drops `semantic-parser' support: it
4461 always does `rule_length - n', where semantic parsers ought to
4462 always use `-n'.
82b6cb3f
AD
4463 * data/bison.simple, data/bison.c++ (b4_lhs_value)
4464 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
4465
6cbfbcc5
AD
44662002-05-02 Akim Demaille <akim@epita.fr>
4467
4468 * configure.in (AC_INIT): Bump to 1.49b.
4469 (AM_INIT_AUTOMAKE): Short invocation.
4470
b8548114
AD
44712002-05-02 Akim Demaille <akim@epita.fr>
4472
4473 Version 1.49a.
4474
c20cd1fa
AD
44752002-05-01 Akim Demaille <akim@epita.fr>
4476
4477 * src/skeleton.h: Remove.
4478
8a9566d4
AD
44792002-05-01 Akim Demaille <akim@epita.fr>
4480
4481 * src/skeleton.h: Fix the #endif.
4482 Reported by Magnus Fromreide.
4483
8c6d399a
PE
44842002-04-26 Paul Eggert <eggert@twinsun.com>
4485
4486 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
4487 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 4488 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 4489
2b7ed18a
RA
44902002-04-25 Robert Anisko <robert@lrde.epita.fr>
4491
4492 * src/scan-skel.l: Postprocess quadrigraphs.
4493
4494 * src/reader.c (copy_character): New function, used to output
4495 single characters while replacing `[' and `]' with quadrigraphs, to
4496 avoid troubles with M4 quotes.
4497 (copy_comment): Output characters with copy_character.
4498 (read_additionnal_code): Likewise.
4499 (copy_string2): Likewise.
4500 (copy_definition): Likewise.
4501
4502 * tests/calc.at: Exercise M4 quoting.
4503
34a89c50
AD
45042002-04-25 Akim Demaille <akim@epita.fr>
4505
4506 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
4507 between `!' and the command.
4508 Reported by Paul Eggert.
4509
0dd1580a
RA
45102002-04-24 Robert Anisko <robert@lrde.epita.fr>
4511
4512 * tests/calc.at: Exercise prologue splitting.
4513
4514 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
4515 `b4_post_prologue' instead of `b4_prologue'.
4516
4517 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
4518 muscles.
4519 (output): Free pre_prologue_obstack and post_prologue_obstack.
4520 * src/files.h, src/files.c (attrs_obstack): Remove.
4521 (pre_prologue_obstack, post_prologue_obstack): New.
4522 * src/reader.c (copy_definition): Add a parameter to specify the
4523 obstack to fill, instead of using attrs_obstack unconditionally.
4524 (read_declarations): Pass pre_prologue_obstack to copy_definition if
4525 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
4526
83c1796f
PE
45272002-04-23 Paul Eggert <eggert@twinsun.com>
4528
4529 * data/bison.simple: Remove unnecessary commentary and white
4530 space differences from 1_29-branch.
4531 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
4532
4533 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
4534 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
4535 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
4536 constructors or destructors.
4537
4538 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
4539
1207eeac
AD
45402002-04-23 Akim Demaille <akim@epita.fr>
4541
4542 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
4543 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
4544 location with columns.
4545 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
4546 All reported by Paul Eggert.
4547
78ab8f67
AD
45482002-04-22 Akim Demaille <akim@epita.fr>
4549
4550 * src/reduce.c (dump_grammar): Move to...
4551 * src/gram.h, src/gram.c (grammar_dump): here.
4552 Be sure to separate long item numbers.
4553 Don't read the members of a rule's prec if its nil.
4554
133c20e2
AD
45552002-04-22 Akim Demaille <akim@epita.fr>
4556
4557 * src/output.c (table_size, table_grow): New.
4558 (MAXTABLE): Remove, replace uses with table_size.
4559 (pack_vector): Instead of dying when the table is too big, grow it.
4560
9515e8a7
AD
45612002-04-22 Akim Demaille <akim@epita.fr>
4562
4563 * data/bison.simple (yyr1): Its type is that of a token number.
4564 * data/bison.c++ (r1_): Likewise.
4565 * tests/regression.at (Web2c Actions): Adjust.
4566
23c5a174
AD
45672002-04-22 Akim Demaille <akim@epita.fr>
4568
4569 * src/reader.c (token_translations_init): 256 is now the default
4570 value for the error token, i.e., it will be assigned another
4571 number if the user assigned 256 to one of her tokens.
4572 (reader): Don't force 256 to error.
4573 * doc/bison.texinfo (Symbols): Adjust.
4574 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
4575 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
4576 etc. instead of 10, 20, 30 (which was used to `jump' over error
4577 (256) and undefined (2)).
4578
5fbb0954
AD
45792002-04-22 Akim Demaille <akim@epita.fr>
4580
4581 Propagate more token_number_t.
4582
4583 * src/gram.h (token_number_as_item_number)
4584 (item_number_as_token_number): New.
4585 * src/output.c (GENERATE_OUTPUT_TABLE): New.
4586 Use it to create output_item_number_table and
4587 output_token_number_table.
4588 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4589 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
4590 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
4591 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
4592
4f940944
AD
45932002-04-22 Akim Demaille <akim@epita.fr>
4594
4595 * src/output.h, src/output.c (get_lines_number): Remove.
4596
3ded9a63
AD
45972002-04-19 Akim Demaille <akim@epita.fr>
4598
4599 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
4600 as Lex/Flex'.
4601 (Debugging): More details about enabling the debugging features.
4602 (Table of Symbols): Describe $$, $n, @$, and @n.
4603 Suggested by Tim Josling.
4604
e0c471a9
AD
46052002-04-19 Akim Demaille <akim@epita.fr>
4606
4607 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
4608
fecc10cd
AD
46092002-04-10 Akim Demaille <akim@epita.fr>
4610
4611 * src/system.h: Rely on HAVE_LIMITS_H.
4612 Suggested by Paul Eggert.
4613
51dec47b
AD
46142002-04-09 Akim Demaille <akim@epita.fr>
4615
4616 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
4617 full stderr, and strip it according to the bison options, instead
4618 of composing the error message from different bits.
4619 This makes it easier to check for several error messages.
4620 Adjust all the invocations.
4621 Add an invocation exercising the error token.
4622 Add an invocation demonstrating a stupid error message.
4623 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
4624 Adjust the tests.
4625 Error message are for stderr, not stdout.
4626
007a50a4
AD
46272002-04-09 Akim Demaille <akim@epita.fr>
4628
4629 * src/gram.h, src/gram.c (error_token_number): Remove, use
4630 errtoken->number.
4631 * src/reader.c (reader): Don't specify the user token number (2)
4632 for $undefined, as it uselessly prevents using it.
4633 * src/gram.h (token_number_t): Move to...
4634 * src/symtab.h: here.
4635 (state_t.number): Is a token_number_t.
4636 * src/print.c, src/reader.c: Use undeftoken->number instead of
4637 hard coded 2.
4638 (Even though this 2 is not the same as above: the number of the
4639 undeftoken remains being 2, it is its user token number which
4640 might not be 2).
4641 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
4642 `user_token_number_max'.
4643 Output `undef_token_number'.
4644 * data/bison.simple, data/bison.c++: Use them.
4645 Be sure to map invalid yylex return values to
4646 `undef_token_number'. This saves us from gratuitous SEGV.
4647
4648 * tests/conflicts.at (Solved SR Conflicts)
4649 (Unresolved SR Conflicts): Adjust.
4650 * tests/regression.at (Web2c Actions): Adjust.
4651
06446ccf
AD
46522002-04-08 Akim Demaille <akim@epita.fr>
4653
4654 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
4655 Adding #line.
4656 Remove the duplicate `typedefs'.
4657 (RhsNumberType): Fix the declaration and various other typos.
4658 Use __ofile__.
4659 * data/bison.simple: Use __ofile__.
4660 * src/scan-skel.l: Handle __ofile__.
4661
62a3e4f0
AD
46622002-04-08 Akim Demaille <akim@epita.fr>
4663
4664 * src/gram.h (item_number_t): New, the type of item numbers in
4665 RITEM. Note that it must be able to code symbol numbers as
4666 positive number, and the negation of rule numbers as negative
4667 numbers.
4668 Adjust all dependencies (pretty many).
4669 * src/reduce.c (rule): Remove this `short *' pointer: use
4670 item_number_t.
4671 * src/system.h (MINSHORT, MAXSHORT): Remove.
4672 Include `limits.h'.
4673 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
4674 (shortcpy): Remove.
4675 (MAXTABLE): Move to...
4676 * src/output.c (MAXTABLE): here.
4677 (prepare_rules): Use output_int_table to output rhs.
4678 * data/bison.simple, data/bison.c++: Adjust.
4679 * tests/torture.at (Big triangle): Move the limit from 254 to
4680 500.
4681 * tests/regression.at (Web2c Actions): Ajust.
4682
4683 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
4684 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
4685 passes, but produces negative #line number, once fixed, GCC is
4686 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
4687 C), it passes.
4688 * src/state.h (state_h): Code input lines on ints, not shorts.
4689
bb88b0fc
AD
46902002-04-08 Akim Demaille <akim@epita.fr>
4691
4692 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
4693 and then the grammar.
4694
9a636f47
AD
46952002-04-08 Akim Demaille <akim@epita.fr>
4696
4697 * src/system.h: No longer using strndup.
4698
680e8701
AD
46992002-04-07 Akim Demaille <akim@epita.fr>
4700
4701 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
4702 * src/output.c (output_table_data): Return the longest number.
4703 (prepare_tokens): Output `token_number_max').
4704 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
4705 New.
4706 Use them to define yy_token_number_type/TokenNumberType.
4707 Use this type for yytranslate.
4708 * tests/torture.at (Big triangle): Push the limit from 124 to
4709 253.
4710 * tests/regression.at (Web2c Actions): Adjust.
4711
817e9f41
AD
47122002-04-07 Akim Demaille <akim@epita.fr>
4713
4714 * tests/torture.at (Big triangle): New.
4715 (GNU AWK Grammar, GNU Cim Grammar): Move to...
4716 * tests/existing.at: here.
4717
5123689b
AD
47182002-04-07 Akim Demaille <akim@epita.fr>
4719
4720 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
4721 nritems.
4722 Adjust dependencies.
4723
f3849179
AD
47242002-04-07 Akim Demaille <akim@epita.fr>
4725
4726 * src/reader.c: Normalize increments to prefix form.
4727
bd02036a
AD
47282002-04-07 Akim Demaille <akim@epita.fr>
4729
4730 * src/reader.c, symtab.c: Remove debugging code.
4731
db8837cb
AD
47322002-04-07 Akim Demaille <akim@epita.fr>
4733
4734 Rename all the `bucket's as `symbol_t'.
4735
4736 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
4737 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
4738 * src/symtab.c, src/symtab.h (bucket): Rename as...
4739 (symbol_t): this.
4740 (symbol_list_new, bucket_check_defined, bucket_make_alias)
4741 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
4742 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4743 (buckets_new, buckets_free, buckets_do): Rename as...
4744 (symbol_list_new, symbol_check_defined, symbol_make_alias)
4745 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4746 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
4747 (symbols_new, symbols_free, symbols_do): these.
4748
72a23c97
AD
47492002-04-07 Akim Demaille <akim@epita.fr>
4750
4751 Use lib/hash for the symbol table.
4752
4753 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
4754 EOF.
4755 * src/lex.c (lex): Set the `number' member of new terminals.
4756 * src/reader.c (bucket_check_defined, bucket_make_alias)
4757 (bucket_check_alias_consistence, bucket_translation): New.
4758 (reader, grammar_free, readgram, token_translations_init)
4759 (packsymbols): Adjust.
4760 (reader): Number the predefined tokens.
4761 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
4762 for predefined tokens.
4763 * src/symtab.h (bucket): Remove all the hash table related
4764 members.
4765 * src/symtab.c (symtab): Replace by...
4766 (bucket_table): this.
4767 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4768 (buckets_new, buckets_do): New.
4769
280a38c3
AD
47702002-04-07 Akim Demaille <akim@epita.fr>
4771
4772 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
4773 (start_symbol, max_user_token_number, semantic_parser)
4774 (error_token_number): Initialize.
4775 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
4776 Initialize.
4777 (reader): Don't.
4778 (errtoken, eoftoken, undeftoken, axiom): Extern.
4779
03b31c0c
AD
47802002-04-07 Akim Demaille <akim@epita.fr>
4781
4782 * src/gram.h (rule_s): prec and precsym are now pointers
4783 to the bucket giving the priority/associativity.
4784 Member `associativity' removed: useless.
4785 * src/reduce.c, src/conflicts.c: Adjust.
4786
8b3df748
AD
47872002-04-07 Akim Demaille <akim@epita.fr>
4788
4789 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4790 Properly escape the symbols' TAG when outputting them.
4791
e601aa1d
AD
47922002-04-07 Akim Demaille <akim@epita.fr>
4793
4794 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4795
b0299a2e
AD
47962002-04-07 Akim Demaille <akim@epita.fr>
4797
4798 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4799 (LArule): this, which is an array to rule_t*.
4800 * src/print.c, src/conflicts.c: Adjust.
4801
d7e1f00c
AD
48022002-04-07 Akim Demaille <akim@epita.fr>
4803
4804 * src/gram.h (rule_t): Rename `number' as `user_number'.
4805 `number' is a new member.
4806 Adjust dependencies.
4807 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4808
cc9305dd
AD
48092002-04-07 Akim Demaille <akim@epita.fr>
4810
4811 As a result of the previous patch, it is no longer needed
4812 to reorder ritem itself.
4813
4814 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4815
b0940840
AD
48162002-04-07 Akim Demaille <akim@epita.fr>
4817
4818 Be sure never to walk through RITEMS, but use only data related to
4819 the rules themselves. RITEMS should be banished.
4820
4821 * src/output.c (output_token_translations): Rename as...
4822 (prepare_tokens): this.
4823 In addition to `translate', prepare the muscles `tname' and
4824 `toknum', which were handled by...
4825 (output_rule_data): this.
4826 Remove, and move the remainder of its outputs into...
4827 (prepare_rules): this new routines, which also merges content from
4828 (output_gram): this.
4829 (prepare_rules): Be sure never to walk through RITEMS.
4830 (output_stos): Rename as...
4831 (prepare_stos): this.
4832 (output): Always invoke prepare_states, after all, just don't use it
4833 in the output if you don't need it.
4834
643a5994
AD
48352002-04-07 Akim Demaille <akim@epita.fr>
4836
4837 * src/LR0.c (new_state): Display `nstates' as the name of the
4838 newly created state.
4839 Adjust to initialize first_state and last_state if needed.
4840 Be sure to distinguish the initial from the final state.
4841 (new_states): Create the itemset of the initial state, and use
4842 new_state.
4843 * src/closure.c (closure): Now that the initial state has its
4844 items properly set, there is no need for a special case when
4845 creating `ruleset'.
4846
4847 As a result, now the rule 0, reducing to $axiom, is visible in the
4848 outputs. Adjust the test suite.
4849
4850 * tests/conflicts.at (Solved SR Conflicts)
4851 (Unresolved SR Conflicts): Adjust.
4852 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4853 * tests/conflicts.at (S/R in initial): New.
4854
b4c4ccc2
AD
48552002-04-07 Akim Demaille <akim@epita.fr>
4856
4857 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4858 the RHS of the rules.
4859 * src/output.c (output_gram): Likewise.
4860
bba97eb2
AD
48612002-04-07 Akim Demaille <akim@epita.fr>
4862
4863 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4864 bucket.
4865 Adjust all dependencies.
4866 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4867 `number' of the buckets too.
4868 * src/gram.h: Include `symtab.h'.
4869 (associativity): Move to...
4870 * src/symtab.h: here.
4871 No longer include `gram.h'.
4872
c3b407f4
AD
48732002-04-07 Akim Demaille <akim@epita.fr>
4874
4875 * src/gram.h, src/gram.c (rules_rhs_length): New.
4876 (ritem_longest_rhs): Use it.
4877 * src/gram.h (rule_t): `number' is a new member.
4878 * src/reader.c (packgram): Set it.
4879 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4880 the end of `rules', and count them out of `nrules'.
4881 (reduce_output, dump_grammar): Adjust.
4882 * src/print.c (print_grammar): It is no longer needed to check for
4883 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4884 * tests/reduce.at (Reduced Automaton): New test.
4885
11652ab3
AD
48862002-04-07 Akim Demaille <akim@epita.fr>
4887
4888 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4889 lacking `+ 1' to nrules, Bison reported as useless a token if it
4890 was used solely to set the precedence of the last rule...
4891
26b23c1a
AD
48922002-04-07 Akim Demaille <akim@epita.fr>
4893
4894 * data/bison.c++, data/bison.simple: Don't output the current file
4895 name in #line, to avoid useless diffs between two identical
4896 outputs under different names.
4897
18bcecb0
AD
48982002-04-07 Akim Demaille <akim@epita.fr>
4899
4900 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4901 Normalize loops to using `< nrules + 1', not `<= nrules'.
4902
fa770c86
AD
49032002-04-07 Akim Demaille <akim@epita.fr>
4904
4905 * TODO: Update.
4906
d9b739c3
AD
49072002-04-07 Akim Demaille <akim@epita.fr>
4908
4909 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4910 bucket.value as bucket.number.
4911
99013900
AD
49122002-04-07 Akim Demaille <akim@epita.fr>
4913
4914 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4915 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4916 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4917 RHS, instead of being an index in RITEMS.
4918
e966383b
PE
49192002-04-04 Paul Eggert <eggert@twinsun.com>
4920
4921 * doc/bison.texinfo: Update copyright date.
4922 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4923 (Symbols): Warn about running Bison in one character set,
4924 but compiling and/or running in an incompatible one.
4925 Warn about character code 256, too.
4926
49272002-04-03 Paul Eggert <eggert@twinsun.com>
4928
4929 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4930 YYERROR_VERBOSE is nonzero, not whether it is defined.
4931
4932 Merge changes from bison-1_29-branch.
c307773e 4933
8d6c48b9
PE
49342002-03-20 Paul Eggert <eggert@twinsun.com>
4935
4936 Merge fixes from Debian bison_1.34-1.diff.
4937
4938 * configure.in (AC_PREREQ): 2.53.
4939
e53c6322
AD
49402002-03-20 Akim Demaille <akim@epita.fr>
4941
4942 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4943
9ffbeca7
PE
49442002-03-19 Paul Eggert <eggert@twinsun.com>
4945
21db0b2a
PE
4946 * src/bison.simple (YYCOPY): New macro.
4947 (YYSTACK_RELOCATE): Use it.
4948 Remove Type arg; no longer needed. All callers changed.
4949 (yymemcpy): Remove; no longer needed.
4950
9ffbeca7
PE
4951 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4952 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4953
642cb8f8
AD
49542002-03-19 Akim Demaille <akim@epita.fr>
4955
4956 Test and fix the #line outputs.
4957
4958 * tests/atlocal.at (GCC): New.
4959 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4960 (Prologue synch line, ,%union synch line, Postprologue synch line)
4961 (Action synch line, Epilogue synch line): New tests.
4962 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4963 * data/bison.simple, data/bison.c++: Use it.
4964
3c31a486
AD
49652002-03-19 Akim Demaille <akim@epita.fr>
4966
4967 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4968 (Solved SR Conflicts, %expect not enough, %expect right)
4969 (%expect too much): Move to...
4970 * tests/conflicts.at: this new file.
4971
0d8bed56
AD
49722002-03-19 Akim Demaille <akim@epita.fr>
4973
4974 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4975 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4976 that we can move to enums for instance.
4977 * src/output.c (token_definitions_output): Output a list of
4978 `token-name, token-number' instead of the #define.
4979 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4980
9208d17f
AD
49812002-03-14 Akim Demaille <akim@epita.fr>
4982
4983 Use Gettext 0.11.1.
4984
af27eacb
RA
49852002-03-09 Robert Anisko <robert@lrde.epita.fr>
4986
4987 * data/bison.c++: Make the user able to add members to the generated
4988 parser by subclassing.
4989
9101a310
RA
49902002-03-05 Robert Anisko <robert@lrde.epita.fr>
4991
4992 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4993 a character.
4994 Reported by Nicolas Tisserand and Nicolas Burrus.
4995
fff9bf0b
RA
49962002-03-04 Robert Anisko <robert@lrde.epita.fr>
4997
4998 * src/reader.c: Warn about lacking semi-colons, do not complain.
4999
64dba31e
RA
50002002-03-04 Robert Anisko <robert@lrde.epita.fr>
5001
5002 * data/bison.c++: Remove a debug line.
5003
374f5a14
RA
50042002-03-04 Robert Anisko <robert@lrde.epita.fr>
5005
5006 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
5007 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
5008 provide a default implementation.
5009
bfcf1f3a
AD
50102002-03-04 Akim Demaille <akim@epita.fr>
5011
5012 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
5013 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
5014 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
5015 * tests/semantic.at (Parsing Guards): Similarly.
5016 * src/reader.at (readgram): Complain if the last rule is not ended
5017 with a semi-colon.
5018
65ccf9fc
AD
50192002-03-04 Akim Demaille <akim@epita.fr>
5020
5021 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
5022 * src/closure.c: here.
5023 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
5024 RTC.
5025 * src/warshall.h, src/warshall.c: Remove.
5026 * tests/sets.at (Broken Closure): Adjust.
5027
d0039cbc
AD
50282002-03-04 Akim Demaille <akim@epita.fr>
5029
5030 * src/output.c (output_skeleton): tempdir is const.
5031 bytes_read is unused.
5032
345cea78
AD
50332002-03-04 Akim Demaille <akim@epita.fr>
5034
5035 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
5036 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
5037 Update.
5038 From Michael Hayes.
5039
564801f7
AD
50402002-03-04 Akim Demaille <akim@epita.fr>
5041
5042 * src/closure.c (closure): `r' is unused.
5043
e5352bc7
AD
50442002-03-04 Akim Demaille <akim@epita.fr>
5045
5046 * tests/sets.at (Broken Closure): Add the ending `;'.
5047 * src/reader.at (readgram): Complain if a rule is not ended with a
5048 semi-colon.
5049
914feea9
AD
50502002-03-04 Akim Demaille <akim@epita.fr>
5051
5052 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
5053 (count_sr_conflicts): Use bitset_count.
5054 * src/reduce.c (inaccessable_symbols): Ditto.
5055 (bits_size): Remove.
5056 * src/warshall.h, src/warshall.c: Convert to bitsetv.
5057
f0250de6
AD
50582002-03-04 Akim Demaille <akim@epita.fr>
5059
5060 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
5061 * src/reduce.c: Remove the `bitset_zero's following the
5062 `bitset_create's, as now it is performed by the latter.
5063
ef017502
AD
50642002-03-04 Akim Demaille <akim@epita.fr>
5065
5066 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
5067 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
5068 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
5069 latest sources from Michael.
5070
76514394
AD
50712002-03-04 Akim Demaille <akim@epita.fr>
5072
5073 * src/output.c (output): Don't free the grammar.
5074 * src/reader.c (grammar_free): New.
5075 * src/main.c (main): Call it and don't free symtab here.
5076
55024580
AD
50772002-03-04 Akim Demaille <akim@epita.fr>
5078
5079 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
5080 before returning.
5081 Reported by Benoit Perrot.
5082
f9abaa2c
AD
50832002-03-04 Akim Demaille <akim@epita.fr>
5084
5085 Use bitset operations when possible, not loops over bits.
5086
5087 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
5088 bitset_or.
5089 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
5090 * src/reduce.c (useless_nonterminals): Formatting changes.
5091 * src/warshall.c (TC): Use bitset_or.
5092
0e721e75
AD
50932002-03-04 Akim Demaille <akim@epita.fr>
5094
5095 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
5096 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
5097 Ditto.
5098
0fb1ffb1
AD
50992002-03-04 Akim Demaille <akim@epita.fr>
5100
5101 * src/lalr.c (F): Now a bitset*.
5102 Adjust all dependencies.
5103
b86796bf
AD
51042002-03-04 Akim Demaille <akim@epita.fr>
5105
5106 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
5107 Adjust all dependencies.
5108
602bbf31
AD
51092002-03-04 Akim Demaille <akim@epita.fr>
5110
5111 * src/L0.c, src/LR0.h (nstates): Be size_t.
5112 Adjust comparisons (signed vs unsigned).
5113 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
5114 bitset*.
5115 Adjust all dependencies.
5116
d8a0245c
AD
51172002-03-04 Akim Demaille <akim@epita.fr>
5118
5119 * src/closure.c (firsts): Now, also a bitset.
5120 Adjust all dependencies.
5121 (varsetsize): Remove, now unused.
5122 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
5123
34ba9743
AD
51242002-03-04 Akim Demaille <akim@epita.fr>
5125
5126 * src/print.c: Convert to use bitset.h, not hand coded iterations
5127 over ints.
5128
ed86e78c
AD
51292002-03-04 Akim Demaille <akim@epita.fr>
5130
5131 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
5132
dfdb1797
AD
51332002-03-04 Akim Demaille <akim@epita.fr>
5134
5135 * src/closure.c (ruleset): Be a bitset.
5136 (rulesetsize): Remove.
5137
7086e707
AD
51382002-03-04 Akim Demaille <akim@epita.fr>
5139
5140 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
5141 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
5142 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
5143 * src/closure.c (fderives): Be an array of bitsets.
5144
98254360
RA
51452002-02-28 Robert Anisko <robert@lrde.epita.fr>
5146
5147 * data/bison.c++: Merge the two generated headers. Insert a copyright
5148 notice in each output file.
5149
a75c057f
AD
51502002-02-28 Akim Demaille <akim@epita.fr>
5151
5152 * data/bison.c++: Copy the prologue of bison.simple to fetch
5153 useful M4 definitions, such as b4_header_guard.
5154
06b00abc
AD
51552002-02-25 Akim Demaille <akim@epita.fr>
5156
5157 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
5158 translator friendly scheme for the bgr
5159 copyright notice.
06b00abc 5160
70e7d534
AD
51612002-02-25 Akim Demaille <akim@epita.fr>
5162
5163 * src/output.c (header_output): Remove, now handled completely via
5164 M4.
5165
abe017f6
AD
51662002-02-25 Akim Demaille <akim@epita.fr>
5167
5168 * m4/m4.m4: New, from CVS Autoconf.
5169 * configure.in: Invoke it.
5170 * src/output.c (output_skeleton): Use its result instead of the
5171 hard coded name.
5172
381fb12e
AD
51732002-02-25 Akim Demaille <akim@epita.fr>
5174
5175 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
5176 Fileutils 4.1.5.
5177 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
5178 * src/output.c (output_skeleton): Use mkstemp to create a real
5179 temporary file.
5180 Move the filling of `skeleton' and its muscle to...
5181 (prepare): here.
5182 (output): Move the definition of the prologue muscle to...
5183 (prepare): here.
5184 * src/system.h (DEFAULT_TMPDIR): New.
5185
6f38107f
PE
51862002-02-14 Paul Eggert <eggert@twinsun.com>
5187
5188 Remove the support for C++ namespace cleanliness; it was
5189 causing more problems than it was curing, since it didn't work
5190 properly on some nonstandard C++ compilers. This can wait
5191 for a proper C++ parser.
5192
5193 * NEWS: Document this.
5194 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
5195 of C++, as it's treated like C now.
5196 * src/bison.simple (YYSTD): Remove.
5197 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
5198 Treat C++ just like Standard C instead of trying to support
5199 namespace cleanliness.
5200
80cce3da
AD
52012002-02-14 Akim Demaille <akim@epita.fr>
5202
5203 * tests/regression.at (else): Adjust to Andreas' change.
5204
842e8679
AD
52052002-02-14 Akim Demaille <akim@epita.fr>
5206
5207 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
5208
4bda3f10
AD
52092002-02-13 Andreas Schwab <schwab@suse.de>
5210
5211 * src/output.c (output_rule_data): Don't output NULL, it might
5212 not be defined yet.
5213
4162fa07 52142002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 5215
4162fa07
RA
5216 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
5217 (Copyright notice): Update.
b418ecd8 5218
bd16a5dc
AD
52192002-02-11 Akim Demaille <akim@epita.fr>
5220
5221 * tests/regression.at (%nonassoc and eof): Don't include
5222 nonportable headers.
5223
8d69a1a3
RA
52242002-02-08 Robert Anisko <robert@lrde.epita.fr>
5225
5226 * data/bison.c++: Correct error recovery. Make the user able to
5227 initialize the starting location.
5228
9b2d0677
AD
52292002-02-07 Akim Demaille <akim@epita.fr>
5230
5231 * tests/input.at: New.
5232
69e2658b
RA
52332002-02-07 Robert Anisko <robert@lrde.epita.fr>
5234
5235 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 5236 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
5237 directives around tables only needed for debugging.
5238
4aacc3a7
RA
52392002-02-07 Robert Anisko <robert@lrde.epita.fr>
5240
5241 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
5242 C++ parsers.
5243 (yy::b4_name::parse): Use print_.
5244
762a801e
RA
52452002-02-07 Robert Anisko <robert@lrde.epita.fr>
5246
5247 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
5248
4bb2bc3f
RA
52492002-02-07 Robert Anisko <robert@lrde.epita.fr>
5250
5251 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
5252 C++ parsers.
5253 (yy::b4_name::parse): Build verbose error messages, and use error_.
5254
6b45a3ca
RA
52552002-02-06 Robert Anisko <robert@lrde.epita.fr>
5256
5257 * data/bison.c++: Fix m4 quoting in comments.
5258
50997c6e
RA
52592002-02-06 Robert Anisko <robert@lrde.epita.fr>
5260
5261 * data/bison.c++: Adjust the parser code. Fix some muscles that were
5262 not expanded by m4.
5263
3f3eed27
AD
52642002-02-05 Akim Demaille <akim@epita.fr>
5265
5266 * data/bison.c++: Adjust to the M4 back end.
5267 More is certainly needed.
5268
be2a1a68
AD
52692002-02-05 Akim Demaille <akim@epita.fr>
5270
5271 Give a try to M4 as a back end.
5272
5273 * lib/readpipe.c: New, from wdiff.
5274 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
5275 BISON_HAIRY.
5276 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
5277 specific values. Now it is m4 that performs the lookup.
5278 * src/parse-skel.y: Remove.
5279 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
5280 * src/output.c (actions_output, guards_output)
5281 (token_definitions_output): No longer keeps track of the output
5282 line number, hence remove the second argument.
5283 (guards_output): Check against the guard member of a rule, not the
5284 action member.
5285 Adjust callers.
5286 (output_skeleton): Don't look for the skeleton location, let m4 do
5287 that.
5288 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
5289 file will be used.
5290 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
5291 (prepare): Given that for the time being changesyntax is not
5292 usable in M4, rename the muscles using `-' to `_'.
5293 Define `defines_flag', `output_parser_name' and `output_header_name'.
5294 * src/output.h (actions_output, guards_output)
5295 (token_definitions_output): Adjust prototypes.
5296 * src/scan-skel.l: Instead of scanning the skeletons, it now
5297 processes the output of m4: `__oline__' and `#output'.
5298 * data/bison.simple: Adjust to be used by M4(sugar).
5299 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
5300 to date.
5301 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
5302 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
5303 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
5304 shamelessly stolen from CVS Autoconf.
5305
beda758b
AD
53062002-02-05 Akim Demaille <akim@epita.fr>
5307
5308 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
5309 * configure.in: Check for the declarations of free and malloc.
5310 * src/muscle_tab.c: Adjust.
5311
5ece6d43
AD
53122002-02-05 Akim Demaille <akim@epita.fr>
5313
5314 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
5315 which have no values.
5316
5bb18f9a
AD
53172002-02-05 Akim Demaille <akim@epita.fr>
5318
5319 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
5320 * data/: here.
5321
894dd62e
PE
53222002-01-29 Paul Eggert <eggert@twinsun.com>
5323
5324 * src/bison.simple (YYSIZE_T): Do not define merely because
5325 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
5326 On some platforms, <alloca.h> does not declare YYSTD (size_t).
5327
82841af7
AD
53282002-01-27 Akim Demaille <akim@epita.fr>
5329
5330 Fix `%nonassoc and eof'.
5331
5332 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
5333 which were not properly copied! Replace
5334 memcpy (res->errs, src->errs, src->nerrs);
5335 with
5336 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
5337 !!!
5338 * tests/regression.at (%nonassoc and eof): Adjust to newest
5339 Autotest: `.' is not in the PATH.
5340
318b76e9
AD
53412002-01-27 Akim Demaille <akim@epita.fr>
5342
5343 * tests/sets.at (AT_EXTRACT_SETS): New.
5344 (Nullable): Use it.
5345 (Firsts): New.
5346
30d2f3d5
AD
53472002-01-26 Akim Demaille <akim@epita.fr>
5348
5349 * tests/actions.at, tests/calc.at, tests/headers.at,
5350 * tests/torture.at: Adjust to the newest Autotest which no longer
5351 forces `.' in the PATH.
5352
30f8c395
AD
53532002-01-25 Akim Demaille <akim@epita.fr>
5354
5355 * tests/regression.at (%nonassoc and eof): New.
5356 Suggested by Robert Anisko.
5357
29ae55f1
AD
53582002-01-24 Akim Demaille <akim@epita.fr>
5359
5360 Bison dumps core when trying to complain about broken input files.
5361 Reported by Cris van Pelt.
5362
5363 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
5364 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
5365 into...
5366 (Invalid inputs): Strengthen: exercise parse_percent_token.
5367
2b548aa6
RA
53682002-01-24 Robert Anisko <robert.anisko@epita.fr>
5369
5370 * src/Makefile.am: Add bison.c++.
5371 * src/bison.c++: New skeleton.
5372
bb0146c2
AD
53732002-01-21 Paolo Bonzini <bonzini@gnu.org>
5374
5375 * po/it.po: New.
5376
bec30531
AD
53772002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
5378
5379 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
5380
fc6edc45
MA
53812002-01-20 Marc Autret <marc@gnu.org>
5382
5383 * src/files.c (compute_output_file_names): Fix
5384
5e5d5415
MA
53852002-01-20 Marc Autret <marc@gnu.org>
5386
5387 * tests/output.at: New test.
5388 * src/files.c (compute_base_names): Don't map extensions when
5389 the YACC flag is set, use defaults.
5390 Reported by Evgeny Stambulchik.
5391
44ea3fbd
MA
53922002-01-20 Marc Autret <marc@gnu.org>
5393
bb0146c2 5394 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
5395 compilers as well (i.e. the vendor C compiler).
5396 Suggested by Albert Chin-A-Young.
5397
338963d1
TVH
53982002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
5399
5400 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
5401 canonical definition.
5402 * src/system.h: Use the canonical definition for PARAMS (avoids
5403 a conflict with the macro from lib/hash.h).
5404
c57b2479
AD
54052002-01-11 Akim Demaille <akim@epita.fr>
5406
5407 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 5408 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 5409
b85810ae
AD
54102002-01-09 Akim Demaille <akim@epita.fr>
5411
5412 * src/files.c, src/files.h (output_infix): New.
5413 (tab_extension): Remove.
5414 (compute_base_names): Compute the former, drop the latter.
5415 * src/output.c (prepare): Insert the muscles `output-infix', and
5416 `output-suffix'.
5417 * src/parse-skel.y (string, string.1): New.
5418 (section.header): Use it.
5419 (section.yacc): Remove.
5420 (prefix): Remove too.
5421 * src/scan-skel.l: Adjust.
5422 * src/bison.simple, src/bison.hairy: Adjust.
5423
cae60122
AD
54242002-01-09 Akim Demaille <akim@epita.fr>
5425
5426 * configure.in (WERROR_CFLAGS): Compute it.
5427 * src/Makefile.am (CFLAGS): Pass it.
5428 * tests/atlocal.in (CFLAGS): Idem.
5429 * src/files.c: Fix a few warnings.
5430 (get_extension_index): Remove, unused.
5431
ae404801
AD
54322002-01-08 Akim Demaille <akim@epita.fr>
5433
5434 * src/getargs.c (AS_FILE_NAME): New.
5435 (getargs): Use it to convert DOSish file names.
5436 * src/files.c (base_name): Rename as full_base_name to avoid
5437 clashes with `base_name ()'.
5438 (filename_split): New.
5439 (compute_base_names): N-th rewrite, using filename_split.
5440
22312b71
AD
54412002-01-08 Akim Demaille <akim@epita.fr>
5442
5443 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
5444 New, stolen from the Fileutils 4.1.
5445 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
5446 * configure.in: Check for the presence of memrchr, and of its
5447 prototype.
5448
a67cef01
TVH
54492002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
5450
5451 * lib/hash.h (__P): Added definition for this macro.
5452 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
5453 BUILT_SOURCES, to ensure they are generated first.
5454 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
5455 %error-verbose to allow bootstrapping with bison 1.30x.
5456
2b25d624
AD
54572002-01-06 Akim Demaille <akim@epita.fr>
5458
5459 * src/reader.c (parse_braces): Don't fetch the next char, the
5460 convention is to fetch on entry.
5461 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
5462 'switch' without a following semicolon.
5463 * tests/regression.at (braces parsing): New.
5464
3460813b
AD
54652002-01-06 Akim Demaille <akim@epita.fr>
5466
5467 Bison is dead wrong in its RR conflict reports.
5468
5469 * tests/torture.at (GNU Cim Grammar): New.
5470 * src/conflicts.c (count_rr_conflicts): Fix.
5471
73784c64
AD
54722002-01-06 Akim Demaille <akim@epita.fr>
5473
5474 Creating package.m4 from configure.ac causes too many problems.
5475
5476 * tests/Makefile.am (package.m4): Create it by hand,
5477 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
5478
25d81090
AD
54792002-01-06 Akim Demaille <akim@epita.fr>
5480
5481 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
5482 skeleton.h.
5483
a9b8959e
PE
54842002-01-04 Paul Eggert <eggert@twinsun.com>
5485
5486 * doc/bison.texinfo (Debugging):
5487 Remove YYSTDERR; it's no longer defined or used.
5488 Also, s/cstdio.h/cstdio/.
5489
25d81090
AD
54902002-01-03 Akim Demaille <akim@epita.fr>
5491
5492 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
5493
1109455c
AD
54942002-01-03 Akim Demaille <akim@epita.fr>
5495
5496 * src/parse-skel.y (process_skeleton): Don't bind the parser's
5497 tracing code to --trace, wait for a better --trace option, with
5498 args.
5499
7ea5e977
AD
55002002-01-03 Akim Demaille <akim@epita.fr>
5501
5502 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
5503 The ISO C++ standard is extremely clear about it: stderr is
5504 considered a macro, not a regular symbol (see table 94 `Header
5505 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
5506 Therefore std:: does not apply to it. It still does with fprintf.
5507 Also, s/cstdio.h/cstdio/.
5508
fab5b110
AD
55092002-01-03 Akim Demaille <akim@epita.fr>
5510
5511 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
5512 for non system headers.
5513
aed7fd9b
AD
55142002-01-02 Akim Demaille <akim@epita.fr>
5515
5516 Equip the skeleton chain with location tracking, runtime trace,
5517 pure parser and scanner.
5518
5519 * src/parse-skel.y: Request a pure parser, locations, and prefix
5520 renaming.
5521 (%union): Having several members with the same type does not help
5522 type mismatches, simplify.
5523 (YYPRINT, yyprint): New.
5524 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
5525 (skel_error): this.
5526 Handle locations.
5527 * src/scan-skel.l: Adjust to these changes.
5528 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
5529 (LOCATION_PRINT, skel_control_t): New.
5530
24fad99e
AD
55312001-12-30 Akim Demaille <akim@epita.fr>
5532
5533 * src/parse-skel.y: Get rid of the shift/reduce conflict:
5534 replace `gb' with BLANKS.
5535 * src/scan-skel.l: Adjust.
5536
a4b36db4
AD
55372001-12-30 Akim Demaille <akim@epita.fr>
5538
5539 * src/system.h: We don't need nor want bcopy.
5540 Throw away MS-DOS crap: we don't need getpid.
5541 * configure.in: We don't need strndup. It was even causing
5542 problems: because Flex includes the headers *before* us,
5543 _GNU_SOURCE is not defined by config.h, and therefore strndup was
5544 not visible.
5545 * lib/xstrndup.c: New.
5546 * src/scan-skel.l: Use it.
5547 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
5548 * src/parse-skel.y: Use %directives instead of #defines.
5549
1239777d
AD
55502001-12-30 Akim Demaille <akim@epita.fr>
5551
5552 * src/skeleton.h: New.
5553 * src/output.c (output_parser, output_master_parser): Remove, dead
5554 code.
5555 * src/output.h (get_lines_number, actions_output, guards_output)
5556 (token_definitions_output): Prototype them.
5557 * src/parse-skel.y: Add the license notice.
5558 Include output.h and skeleton.h.
5559 (process_skeleton): Returns void, and takes a single parameter.
5560 * src/scan-skel.l: Add the license notice.
5561 Include skeleton.h.
5562 Don't use %option yylineno: it seems that then Flex imagines
5563 REJECT has been used, and therefore it won't reallocate its
5564 buffers (which makes no other sense to me than a bug). It results
5565 in warnings for `unused: yy_flex_realloc'.
5566
9b3add5b
RA
55672001-12-30 Robert Anisko <robert.anisko@epita.fr>
5568
5569 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5570 (MUSCLE_INSERT_PREFIX): ...to there.
5571 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5572 (MUSCLE_INSERT_PREFIX): Move from here...
5573
5574 * src/bison.hairy: Add a section directive. Put braces around muscle
5575 names. This parser skeleton is still broken, but Bison should not
5576 choke on a bad muscle 'syntax'.
5577 * src/bison.simple: Add a section directive. Put braces around muscle
5578 names.
5579
5580 * src/files.h (strsuffix, stringappend): Add declarations.
5581 (tab_extension): Add declaration.
5582 (short_base_name): Add declaration.
5583
5584 * src/files.c (strsuffix, stringappend): No longer static. These
5585 functions are used in the skeleton parser.
5586 (tab_extension): New.
5587 (compute_base_names): Use the computations done in this function
fab5b110 5588 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
5589 names.
5590 (short_base_name): No longer static.
5591
5592 * src/output.c (output_skeleton): New.
5593 (output): Disable call to output_master_parser, and give a try to
5594 a new skeleton handling system.
5595 (guards_output, actions_output): No longer static.
5596 (token_definitions_output, get_lines_number): No longer static.
5597
5598 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
5599
fab5b110 5600 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
5601 parse-skel.y.
5602
5603 * src/parse-skel.y: New file.
5604 * src/scan-skel.l: New file.
5605
b5b61c61
AD
56062001-12-29 Akim Demaille <akim@epita.fr>
5607
5608 %name-prefix is broken.
5609
5610 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
5611 Adjust all dependencies.
5612 * tests/headers.at (export YYLTYPE): Strengthen this test: use
5613 %name-prefix.
5614
5615 Renaming yylval but not yylloc is not consistent. Now we do.
5616
5617 * src/bison.simple: Prefix yylloc if used.
5618 * doc/bison.texinfo (Decl Summary): Document that.
5619
8c9a50be
AD
56202001-12-29 Akim Demaille <akim@epita.fr>
5621
5622 * doc/bison.texinfo: Promote `%long-directive' over
5623 `%long_directive'.
5624 Remove all references to fixed-output-files, yacc is enough.
5625
d99361e6
AD
56262001-12-29 Akim Demaille <akim@epita.fr>
5627
5628 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
5629 user prologue. These are defaults.
5630 * tests/actions.at (Mid-rule actions): Make sure the user can
5631 define YYDEBUG and YYERROR_VERBOSE.
5632
b9cecb91
AD
56332001-12-29 Akim Demaille <akim@epita.fr>
5634
5635 * src/output.c (header_output): Don't forget to export YYLTYPE and
5636 yylloc.
5637 * tests/headers.at (export YYLTYPE): New, make sure it does.
5638 * tests/regression.at (%union and --defines, Invalid CPP headers):
5639 Move to...
5640 * tests/headers.at: here.
5641
aea13e97
AD
56422001-12-29 Akim Demaille <akim@epita.fr>
5643
5644 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
5645
931394cb
AD
56462001-12-29 Akim Demaille <akim@epita.fr>
5647
5648 * tests/actions.at (Mid-rule actions): Output on a single line
5649 instead of several.
5650
704a47c4
AD
56512001-12-29 Akim Demaille <akim@epita.fr>
5652
5653 * doc/bison.texinfo: Formatting changes.
5654
091e20bb
AD
56552001-12-29 Akim Demaille <akim@epita.fr>
5656
5657 Don't store the token defs in a muscle, just be ready to output it
5658 on command. Now possible via `symbols'. Fixes a memory leak.
5659
5660 * src/output.c (token_definitions_output): New.
5661 (output_parser, header_output): Use it.
5662 * src/reader.c (symbols_save): Remove.
5663
cce71710
AD
56642001-12-29 Akim Demaille <akim@epita.fr>
5665
5666 * src/bison.simple: Do not provide a default for YYSTYPE and
5667 YYLTYPE before the user's prologue. Otherwise it's hardly... a
5668 default.
5669
82c035a8
AD
56702001-12-29 Akim Demaille <akim@epita.fr>
5671
5672 Mid-rule actions are simply... ignored!
5673
5674 * src/reader.c (readgram): Be sure to attach mid-rule actions to
5675 the empty-rule associated to the dummy symbol, not to the host
5676 rule.
5677 * tests/actions.at (Mid-rule actions): New.
5678
8419d367
AD
56792001-12-29 Akim Demaille <akim@epita.fr>
5680
5681 Memory leak.
5682
5683 * src/reader.c (reader): Free grammar.
5684
375d5806
AD
56852001-12-29 Akim Demaille <akim@epita.fr>
5686
5687 Memory leak.
5688
5689 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
5690 since it allocates it for each state, although only one is needed.
5691 (allocate_storage): Do it here.
5692
f51cb8ff
AD
56932001-12-29 Akim Demaille <akim@epita.fr>
5694
5695 * src/options.h, src/options.c (create_long_option_table): Rename
5696 as...
5697 (long_option_table_new): this, with a clearer prototype.
5698 (percent_table): Remove, unused,
5699 * src/getargs.c (getargs): Adjust.
5700
29e88316
AD
57012001-12-29 Akim Demaille <akim@epita.fr>
5702
5703 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
5704 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
5705 as states.
5706
b9f71f19
AD
57072001-12-29 Akim Demaille <akim@epita.fr>
5708
5709 * src/lalr.c (build_relations): Rename `states' as `states1'.
5710 Sorry, I don't understand exactly what it is, no better name...
5711
1a2b5d37
AD
57122001-12-29 Akim Demaille <akim@epita.fr>
5713
5714 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
5715 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
5716 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
5717 as rules.
5718
1cca533e
AD
57192001-12-29 Akim Demaille <akim@epita.fr>
5720
5721 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
5722 ago.
5723
c03ae966
AD
57242001-12-29 Akim Demaille <akim@epita.fr>
5725
5726 * src/reader.c, src/reader.h (user_toknums): Remove.
5727 Adjust all users to use symbols[i]->user_token_number.
5728
5a670b1e
AD
57292001-12-29 Akim Demaille <akim@epita.fr>
5730
5731 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
5732 Adjust all users to use symbols[i]->prec or ->assoc.
5733
ad949da9
AD
57342001-12-29 Akim Demaille <akim@epita.fr>
5735
5736 * src/reader.c, src/reader.h (tags): Remove.
5737 Adjust all users to use symbols[i]->tag.
5738
0e78e603
AD
57392001-12-29 Akim Demaille <akim@epita.fr>
5740
5741 * src/gram.h, src/gram.c (symbols): New, similar to state_table
5742 and rule_table.
5743 * src/reader.c (packsymbols): Fill this table.
5744 Drop sprec.
5745 * src/conflicts.c (resolve_sr_conflict): Adjust.
5746 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
5747 single table.
5748 Use symbols[i]->tag instead of tags[i].
5749
213e640e
AD
57502001-12-29 Akim Demaille <akim@epita.fr>
5751
5752 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
5753 In addition, put a comment in there, to replace...
5754 * tests/regression.at (%union and C comments): Remove.
5755
e7b8bef1
AD
57562001-12-29 Akim Demaille <akim@epita.fr>
5757
5758 * tests/regression.at (Web2c Actions): Blindly move the actual
5759 output as expected output. The contents *seem* right to me, but I
5760 can't pretend reading perfectly parser tables... Nonetheless, all
5761 the other tests pass correctly, the table look OK, even though the
5762 presence of `$axiom' is to be noted: AFAICS it is useless (but
5763 harmless).
5764
b68e7744
AD
57652001-12-29 Akim Demaille <akim@epita.fr>
5766
5767 * src/reader.c (readgram): Don't add the rule 0 if there were no
5768 rules read. In other words, add it _after_ having performed
5769 grammar sanity checks.
5770 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
5771
78d5bae9
AD
57722001-12-29 Akim Demaille <akim@epita.fr>
5773
5774 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
5775 visible, and some states have now a different number.
5776
ff442794
AD
57772001-12-29 Akim Demaille <akim@epita.fr>
5778
5779 * src/reader.c (readgram): Bind the initial rule's lineno to that
5780 of the first rule.
5781 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5782 (Solved SR Conflicts): Adjust rule 0's line number.
5783
610ab194
AD
57842001-12-29 Akim Demaille <akim@epita.fr>
5785
5786 Fix the `GAWK Grammar' failure.
5787
5788 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5789 the reductions of the first state which was mistakenly confused
5790 with the final state because precisely final_state was initialized
5791 to 0.
5792 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5793 now noticed by Bison.
5794 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5795 have a reduction on $default.
5796
29d29c8f
AD
57972001-12-29 Akim Demaille <akim@epita.fr>
5798
5799 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5800 rule line numbers.
5801 * src/closure.c (print_closure): Likewise.
5802 * src/derives.c (print_derives): Likewise.
5803 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5804 now.
5805
7c6b64d0
AD
58062001-12-29 Akim Demaille <akim@epita.fr>
5807
5808 * src/lalr.c (lookaheads_print): New.
5809 (lalr): Call it when --trace-flag.
5810 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5811 are dumped.
5812
3d4daee3
AD
58132001-12-29 Akim Demaille <akim@epita.fr>
5814
5815 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5816 when walking through ritem, even via rule->rhs.
5817 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5818 (useful_production, useless_nonterminals): Likewise.
5819 (reduce_grammar_tables): Likewise, plus update nritems.
5820 * src/nullable.c (set_nullable): Likewise.
5821 * src/lalr.c (build_relations): Likewise.
5822 * tests/sets.at (Nullable): Adjust.
5823 Fortunately, now, the $axiom is no longer nullable.
5824
9e7f6bbd
AD
58252001-12-29 Akim Demaille <akim@epita.fr>
5826
5827 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5828 the 0-sentinel.
5829 * src/gram.c (ritem_longest_rhs): Likewise.
5830 * src/reduce.c (nonterminals_reduce): Likewise.
5831 * src/print_graph.c (print_graph): Likewise.
5832 * src/output.c (output_rule_data): Likewise.
5833 * src/nullable.c (set_nullable): Likewise.
5834
255ef638
AD
58352001-12-29 Akim Demaille <akim@epita.fr>
5836
5837 * src/output.c: Comment changes.
5838
0d8a7363
AD
58392001-12-27 Paul Eggert <eggert@twinsun.com>
5840
5841 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5842 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5843 Sparc, as they were causing more porting problems than the
5844 (minor) performance improvement was worth.
5845
5846 Also, catch up with 1.31's YYSTD.
5847
3db472b9
AD
58482001-12-27 Akim Demaille <akim@epita.fr>
5849
5850 * src/output.c (output_gram): Rely on nritems, not the
5851 0-sentinel. See below.
5852 Use -1 as separator, not 0.
5853 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5854 Rely on -1 as separator in yyrhs, instead of 0.
5855 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5856 twice `Now at end of input', therefore there are two lines less to
5857 expect.
5858
b365aa05
AD
58592001-12-27 Akim Demaille <akim@epita.fr>
5860
5861 * tests/regression.at (Unresolved SR Conflicts):
5862 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5863 below.
5864
30171f79
AD
58652001-12-27 Akim Demaille <akim@epita.fr>
5866
5867 * src/LR0.c (new_state): Recognize the final state by the fact it
5868 is reached by eoftoken.
5869 (insert_start_shifting_state, insert_eof_shifting_state)
5870 (insert_accepting_state, augment_automaton): Remove, since now
5871 these states are automatically computed from the initial state.
5872 (generate_states): Adjust.
5873 * src/print.c: When reporting a rule number to the user, substract
5874 1, so that the axiom rule is rule 0, and the first user rule is 1.
5875 * src/reduce.c: Likewise.
5876 * src/print_graph.c (print_core): For the time being, just as for
5877 the report, depend upon --trace-flags to dump the full set of
5878 items.
5879 * src/reader.c (readgram): Once the grammar read, insert the rule
5880 0: `$axiom: START-SYMBOL $'.
5881 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5882 number of the states has changed (the final state is no longer
5883 necessarily the last), catch up.
5884
75142d45
AD
58852001-12-27 Akim Demaille <akim@epita.fr>
5886
5887 Try to make the use of the eoftoken valid. Given that its value
5888 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5889 is used instead of > 0 where appropriate, (ii), depend upon nritems
5890 instead of the 0-sentinel.
5891
5892 * src/gram.h, src/gram.c (nritems): New.
5893 Expected to be duplication of nitems, but for the time being...
5894 * src/reader.c (packgram): Assert nritems and nitems are equal.
5895 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5896 * src/closure.c (print_closure, print_fderives): Likewise.
5897 * src/gram.c (ritem_print): Likewise.
5898 * src/print.c (print_core, print_grammar): Likewise.
5899 * src/print_graph.c: Likewise.
5900
b7c49edf
AD
59012001-12-27 Akim Demaille <akim@epita.fr>
5902
5903 * src/main.c (main): If there are complains after grammar
5904 reductions, then output the report anyway if requested, then die.
5905 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5906 * src/reader.c (eoftoken): New.
5907 (parse_token_decl): If the token being defined has value `0', it
5908 is the eoftoken.
5909 (packsymbols): No longer hack `tags' to insert `$' by hand.
5910 Be sure to preserve the value of the eoftoken.
5911 (reader): Make sure eoftoken is defined.
5912 Initialize nsyms to 0: now eoftoken is created just like the others.
5913 * src/print.c (print_grammar): Don't special case the eof token.
5914 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5915 lie anyway, albeit pleasant.
5916 * tests/calc.at: Exercise error messages with eoftoken.
5917 Change the grammar so that empty input is invalid.
5918 Adjust expectations.
5919 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5920
ec2da99f
AD
59212001-12-27 Akim Demaille <akim@epita.fr>
5922
5923 * configure.in: Check the protos of strchr ans strspn.
5924 Replace strchr if needed.
5925 * src/system.h: Provide the protos of strchr, strspn and memchr if
5926 missing.
5927 * lib/strchr.c: New.
5928 * src/reader.c (symbols_save): Use strchr.
5929
8adfa272
AD
59302001-12-27 Akim Demaille <akim@epita.fr>
5931
5932 * src/print.c, src/print_graph.c (escape): New.
5933 Use it to quote the TAGS outputs.
5934 * src/print_graph.c (print_state): Now errors are in red, and
5935 reductions in green.
5936 Prefer high to wide: output the state number on a line of its own.
5937
80dac38c
AD
59382001-12-27 Akim Demaille <akim@epita.fr>
5939
5940 * src/state.h, src/state.c (reductions_new): New.
5941 * src/LR0.c (set_state_table): Let all the states have a
5942 `reductions', even if reduced to 0.
5943 (save_reductions): Adjust.
5944 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5945 * src/print.c (print_reductions, print_actions): Adjust.
5946 * src/output.c (action_row): Adjust.
5947
2cec70b9
AD
59482001-12-27 Akim Demaille <akim@epita.fr>
5949
5950 * src/state.h, src/state.c (errs_new, errs_dup): New.
5951 * src/LR0.c (set_state_table): Let all the states have an errs,
5952 even if reduced to 0.
5953 * src/print.c (print_errs, print_reductions): Adjust.
5954 * src/output.c (output_actions, action_row): Adjust.
5955 * src/conflicts.c (resolve_sr_conflict): Adjust.
5956
13ca549a
AD
59572001-12-27 Akim Demaille <akim@epita.fr>
5958
5959 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5960
5092aba5
AD
59612001-12-27 Akim Demaille <akim@epita.fr>
5962
5963 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5964 * src/print.c: here.
5965 (lookaheadset, shiftset): New, used as additional storage by
5966 print_reductions.
5967 (print_results): Adjust.
5968 (print_shifts, print_gotos, print_errs): New, extracted from...
5969 (print_actions): here.
5970 * src/print_graph.c (print_actions): Remove dead code.
5971
11e2beca
AD
59722001-12-27 Akim Demaille <akim@epita.fr>
5973
5974 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5975 `$n' and `@n'.
5976
dac3c910
AD
59772001-12-27 Akim Demaille <akim@epita.fr>
5978
5979 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5980 (build_relations): Adjust.
5981
d0b0fefa
AD
59822001-12-27 Akim Demaille <akim@epita.fr>
5983
5984 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5985 duplication.
5986
adc8c848
AD
59872001-12-27 Akim Demaille <akim@epita.fr>
5988
5989 * src/reader.c (packgram): Catch nitems overflows.
5990
14d293ac
AD
59912001-12-27 Akim Demaille <akim@epita.fr>
5992
5993 * src/files.c, src/files.h (guard_obstack): Remove.
5994 * src/output.c (output): Adjust.
5995 * src/reader.c (parse_braces): New, factoring...
5996 (copy_action, copy_guard): these two which are renamed as...
5997 (parse_action, parse_guard): these.
5998 As a voluntary consequence, using braces around guards is now
5999 mandatory.
6000
f499b062
AD
60012001-12-27 Akim Demaille <akim@epita.fr>
6002
6003 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
6004 * src/reader.c (symbol_list): `guard' and `guard_line' are new
6005 members.
6006 (symbol_list_new): Adjust.
6007 (copy_action): action_line is the first line, not the last.
6008 (copy_guard): Just as for actions, store the `action' only, not
6009 the switch/case/break flesh.
6010 Don't parse the user action that might follow the guard, let...
6011 (readgram): do it, i.e., now, there can be an action after a
6012 guard.
6013 In other words the guard is just explicitly optional.
6014 (packgram): Adjust.
6015 * src/output.c (guards_output): New.
6016 (output_parser): Call it when needed.
6017 (output): Also free the guard and attrs obstacks.
6018 * src/files.c, src/files.h (obstack_save): Remove.
6019 (output_files): Remove.
6020 As a result, if one needs the former `.act' file, using an
6021 appropriate skeleton which requires actions and guards is now
6022 required.
6023 * src/main.c (main): Adjust.
6024 * tests/semantic.at: New.
6025 * tests/regression.at: Use `input.y' as input file name.
6026 Avoid 8+3 problems by requiring input.c when the test needs the
6027 parser.
6028
d945f5cd
AD
60292001-12-27 Akim Demaille <akim@epita.fr>
6030
6031 * src/reader.c (symbol_list_new): Be sure to initialize all the
6032 fields.
6033
d200e455
AD
60342001-12-27 Akim Demaille <akim@epita.fr>
6035
6036 All the hacks using a final pseudo state are now useless.
6037
6038 * src/LR0.c (set_state_table): state_table holds exactly nstates.
6039 * src/lalr.c (nLA): New.
6040 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
6041 instead of lookaheadsp from the pseudo state (nstate + 1).
6042
f9507c28
AD
60432001-12-27 Akim Demaille <akim@epita.fr>
6044
6045 * src/output.c (action_row, token_actions): Use a state_t instead
6046 of a integer, and nlookaheads instead of the following state's
6047 lookaheadsp.
6048
065fbd27
AD
60492001-12-27 Akim Demaille <akim@epita.fr>
6050
6051 * src/conflicts.c (log_resolution, flush_shift)
6052 (resolve_sr_conflict, set_conflicts, solve_conflicts)
6053 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
6054 (conflicts_print, print_reductions): Use a state_t instead of an
6055 integer when referring to a state.
6056 As much as possible, depend upon nlookaheads, instead of the
6057 `lookaheadsp' member of the following state (since lookaheads of
6058 successive states are successive, the difference between state n + 1
6059 and n served as the number of lookaheads for state n).
6060 * src/lalr.c (add_lookback_edge): Likewise.
6061 * src/print.c (print_core, print_actions, print_state)
6062 (print_results): Likewise.
6063 * src/print_graph.c (print_core, print_actions, print_state)
6064 (print_graph): Likewise.
6065 * src/conflicts.h: Adjust.
6066
1b177bd7
AD
60672001-12-27 Akim Demaille <akim@epita.fr>
6068
6069 * src/bison.hairy: Formatting/comment changes.
6070 ANSIfy.
6071 Remove `register' indications.
6072 Add plenty of `static'.
6073
7742ddeb
AD
60742001-12-27 Akim Demaille <akim@epita.fr>
6075
6076 * src/output.c (prepare): Drop the muscle `ntbase' which
6077 duplicates ntokens.
6078 * src/bison.simple: Formatting/comment changes.
6079 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
6080 is an undocumented synonym.
6081
1fa14068
AD
60822001-12-22 Akim Demaille <akim@epita.fr>
6083
6084 * src/output.c (output_table_data): Change the prototype to use
6085 `int' for array ranges: some invocations do pass an int, not a
6086 short.
6087 Reported by Wayne Green.
6088
b9752825
AD
60892001-12-22 Akim Demaille <akim@epita.fr>
6090
6091 Some actions of web2c.y are improperly triggered.
6092 Reported by Mike Castle.
6093
6094 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
6095 * tests/regression.at (Web2c): Rename as...
6096 (Web2c Report): this.
6097 (Web2c Actions): New.
6098
776209d6
AD
60992001-12-22 Akim Demaille <akim@epita.fr>
6100
6101 Reductions in web2c.y are improperly reported.
6102 Reported by Mike Castle.
6103
6104 * src/conflicts.c (print_reductions): Fix.
6105 * tests/regression.at (Web2c): New.
6106
275fc3ad
AD
61072001-12-18 Akim Demaille <akim@epita.fr>
6108
6109 Some host fail on `assert (!"foo")', which expands to
6110 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
6111 Reported by Nelson Beebee.
6112
6113 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
6114 `#define it_succeeded 0' and `assert (it_succeeded)'.
6115
897668ee
MA
61162001-12-17 Marc Autret <autret_m@epita.fr>
6117
6118 * src/bison.simple: Don't hard code the skeleton line and filename.
6119 * src/output.c (output_parser): Rename 'line' as 'output_line'.
6120 New line counter 'skeleton_line' (skeleton-line muscle).
6121
ab3399e0
PE
61222001-12-17 Paul Eggert <eggert@twinsun.com>
6123
6124 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
6125 YYDEBUG must be defined to a nonzero value.
6126
6127 * src/bison.simple (yytname): Do not assume that the user defines
6128 YYDEBUG to a properly parenthesized expression.
6129
3877f72b
AD
61302001-12-17 Akim Demaille <akim@epita.fr>
6131
6132 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
6133 nlookaheads is a new member.
6134 Adjust all users.
6135 * src/lalr.h (nlookaheads): Remove this orphan declaration.
6136 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
6137 state.
776209d6 6138
331dbc1b
AD
61392001-12-17 Akim Demaille <akim@epita.fr>
6140
6141 * src/files.h, src/files.c (open_files, close_files): Remove.
6142 * src/main.c (main): Don't open/close files, nor invoke lex_free,
6143 let...
6144 * src/reader.c (reader): Do it.
776209d6 6145
be750e4c
AD
61462001-12-17 Akim Demaille <akim@epita.fr>
6147
6148 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 6149
709ae8c6
AD
61502001-12-17 Akim Demaille <akim@epita.fr>
6151
6152 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
6153 (flush_reduce): New.
6154 (resolve_sr_conflict): Adjust.
776209d6 6155
f87685c3
AD
61562001-12-17 Akim Demaille <akim@epita.fr>
6157
6158 * src/output.c (output_obstack): Be static and rename as...
6159 (format_obstack): this, to avoid any confusion with files.c's
6160 output_obstack.
6161 * src/reader.h (muscle_obstack): Move to...
6162 * src/output.h: here, since it's defined in output.c.
6163
837491d8
AD
61642001-12-17 Akim Demaille <akim@epita.fr>
6165
6166 * src/output.c (action_row, save_column, default_goto)
6167 (sort_actions, matching_state, pack_vector): Better variable
6168 locality.
6169
796d61fb
AD
61702001-12-17 Akim Demaille <akim@epita.fr>
6171
6172 * src/output.c: Various formatting changes.
776209d6 6173
64d15509
AD
61742001-12-17 Akim Demaille <akim@epita.fr>
6175
6176 * src/files.c (output_files): Free the output_obstack.
6177 * src/main.c (main): Call print and print_graph conditionally.
6178 * src/print.c (print): Work unconditionally.
6179 * src/print_graph.c (print_graph): Work unconditionally.
6180 * src/conflicts.c (log_resolution): Output only if verbose_flag.
6181
fbc8ecb7
MA
61822001-12-16 Marc Autret <autret_m@epita.fr>
6183
6184 * src/output.c (actions_output): Fix. When we use %no-lines,
6185 there is one less line per action.
6186
f0440388
MA
61872001-12-16 Marc Autret <autret_m@epita.fr>
6188
6189 * src/bison.simple: Remove a useless #line directive.
6190 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
6191 * src/output.c (get_lines_number): New.
776209d6 6192 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
6193 output muscles.
6194 Fix line numbering.
6195 (actions_output): Computes the number of lines taken by actions.
6196 (output_master_parser): Insert new skeleton which is the name of
6197 the output parser file name.
6198
a79986b8
MA
61992001-12-15 Marc Autret <autret_m@epita.fr>
6200
6201 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
6202
4ec8e00f
MA
62032001-12-15 Marc Autret <autret_m@epita.fr>
6204
6205 * src/output.c (output_gram): Keep track of the hairy one.
6206
1a4648ff
AD
62072001-12-15 Akim Demaille <akim@epita.fr>
6208
6209 Make `make distcheck' work.
6210
6211 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
6212 system.h which uses libgettext.h.
6213
9c2c67e6
AD
62142001-12-15 Akim Demaille <akim@epita.fr>
6215
6216 * src/nullable.c (set_nullable): Useless rules must be skipped,
6217 otherwise, since we range over their symbols, we might look at a
6218 nonterminal which no longer ``exists'', i.e., it is not counted in
6219 `nvars', hence we overflow our arrays.
6220
93ede233
AD
62212001-12-15 Akim Demaille <akim@epita.fr>
6222
6223 The header can also be produced directly, without any obstack!
6224 Yahoo!
6225
6226 * src/files.c, src/files.h (defines_obstack): Remove.
6227 (compute_header_macro): Global.
6228 (defines_obstack_save): Remove.
6229 * src/reader.c (parse_union_decl): No longer output to
6230 defines_obstack: its content can be found in the `stype' muscle
6231 anyway.
6232 (output_token_translations): Merge into...
6233 (symbols_output): this.
6234 Rename as...
6235 (symbols_save): this.
6236 (reader): Adjust.
6237 * src/output.c (header_output): New.
6238 (output): Call it.
6239
2666f928
AD
62402001-12-15 Akim Demaille <akim@epita.fr>
6241
6242 * src/reader.c (parse_union_decl): Instead of handling two obstack
6243 simultaneously, use one to define the `stype' muscle, and use the
6244 value of the latter to fill defines_obstack.
6245 (copy_comment): Remove.
6246 (copy_comment2): Work for a single obstack.
6247 Rename as...
6248 (copy_comment): this.
6249
428046f8
AD
62502001-12-15 Akim Demaille <akim@epita.fr>
6251
6252 * src/lex.c, src/lex.h (xgetc): No longer static.
6253 * src/reader.c (parse_union_decl): Revamp.
6254
ea52d706
AD
62552001-12-15 Akim Demaille <akim@epita.fr>
6256
6257 Still making progress in separating Bison into (i) input, (ii)
6258 process, (iii) output: now we can directly output the parser file
6259 without using table_obstack at all.
6260
6261 * src/files.c, src/files.h (table_obstack): Bye bye.
6262 (parser_file_name): New.
6263 * src/files.c (compute_output_file_names): Compute it.
6264 * src/output.c (actions_output, output_parser)
6265 (output_master_parser): To a file instead of an obstack.
6266
3f96f4dc
AD
62672001-12-15 Akim Demaille <akim@epita.fr>
6268
6269 Attach actions to rules, instead of pre-outputting them to
6270 actions_obstack.
6271
6272 * src/gram.h (rule_t): action and action_line are new members.
6273 * src/reader.c (symbol_list): Likewise.
6274 (copy_action): Save the actions within the rule.
6275 (packgram): Save them in rule_table.
6276 * src/output.c (actions_output): New.
6277 (output_parser): Use it on `%%actions'.
6278 (output_rule_data): Don't free rule_table.
6279 (output): Do it.
6280 (prepare): Don't save the `action' muscle.
6281 * src/bison.simple: s/%%action/%%actions/.
6282
51576fb3
AD
62832001-12-15 Akim Demaille <akim@epita.fr>
6284
6285 * src/reader.c (copy_action): When --yacc, don't append a `;'
6286 to the user action: let it fail if lacking.
dee049eb 6287 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 6288
2648a72d
AD
62892001-12-14 Akim Demaille <akim@epita.fr>
6290
6291 * src/lex.c (literalchar): Simply return the char you decoded, non
6292 longer mess around with obstacks and int pointers.
6293 Adjust all callers.
6294
92790e5b
AD
62952001-12-14 Akim Demaille <akim@epita.fr>
6296
6297 * src/lex.c (literalchar): Don't escape the special characters,
6298 just decode them, and keep them as char (before, eol was output as
6299 the 2 char string `\n' etc.).
6300 * src/output.c (output_rule_data): Use quotearg to output the
6301 token strings.
6302
927c1557
PE
63032001-12-13 Paul Eggert <eggert@twinsun.com>
6304
6305 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
6306 Do not infringe on the global user namespace when using C++.
6307 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
6308 All uses of `fprintf' and `stderr' changed.
6309
6310 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
6311
ed8e1f68
AD
63122001-12-13 Akim Demaille <akim@epita.fr>
6313
6314 The computation of nullable is broken: it doesn't handle empty
6315 RHS's properly.
6316
6317 * tests/torture.at (GNU AWK Grammar): New.
6318 * tests/sets.at (Nullable): New.
6319 * src/nullable.c (set_nullable): Instead of blindly looping over
6320 `ritems', loop over the rules, and then over their rhs's.
6321
6322 Work around Autotest bugs.
6323
6324 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
6325 frame, because Autotest understand lines starting with a `+' as
6326 traces from the shell. Then, they are not processed properly.
6327 Admittedly an Autotest bug, but we don't have time to wait for
6328 Autotest to catch up.
6329 * tests/regression.at (Broken Closure): Adjust to the new table
6330 frames.
6331 Move to...
6332 * tests/sets.at: here.
6333
cb581495
AD
63342001-12-13 Akim Demaille <akim@epita.fr>
6335
6336 * src/closure.c (closure): Use nrules instead of playing tricks
6337 with BITS_PER_WORD.
6338
2e729273
AD
63392001-12-13 Akim Demaille <akim@epita.fr>
6340
6341 * src/print.c (print_actions): Output the handling of `$' as the
6342 traces do: shifting the token EOF. Before EOF was treated as a
6343 nonterminal.
6344 * tests/regression.at: Adjust some tests.
6345 * src/print_graph.c (print_core): Complete the set of items via
6346 closure. The next-to-final and final states are still unsatisfying,
6347 but that's to be addressed elsewhere.
6348 No longer output the rule numbers, but do output the state number.
6349 A single loop for the shifts + gotos is enough, but picked a
6350 distinct color for each.
6351 (print_graph): Initialize and finalize closure.
6352
107f7dfb
AD
63532001-12-13 Akim Demaille <akim@epita.fr>
6354
6355 * src/reader.c (readgram): Remove dead code, an strip useless
6356 braces.
6357 (get_type): Remove, unused.
6358
9b53a24f
AD
63592001-12-12 Akim Demaille <akim@epita.fr>
6360
6361 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
6362 on that of lib/error.c.
6363
dbfb6dcd
AD
63642001-12-12 Akim Demaille <akim@epita.fr>
6365
6366 Some hosts don't like `/' in includes.
6367
6368 * src/system.h: Include libgettext.h without qualifying the path.
6369 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
6370 $(top_srcdir).
6371
c25fb648
MA
63722001-12-11 Marc Autret <autret_m@epita.fr>
6373
6374 * src/output.c (output_parser): Remove useless muscle.
6375
710ddc4f
MA
63762001-12-11 Marc Autret <autret_m@epita.fr>
6377
6378 * src/bison.simple: Remove #line just before %%epilogue. It
6379 is now handled in ...
6380 * src/reader.c (read_additionnal_code): Add the output of a
6381 #line for the epilogue.
6382
e83d80b8
MA
63832001-12-10 Marc Autret <autret_m@epita.fr>
6384
927c1557 6385 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
6386 replace precedent remove.
6387 * src/bison.simple: Remove #line before %%prologue because
6388 %%input-line is wrong at this time.
6389
971d5158
MA
63902001-12-10 Marc Autret <autret_m@epita.fr>
6391
6392 * src/reader.c (symbols_output): Clean up.
927c1557 6393 * src/output.c (output_gram, output): Clean up.
971d5158 6394
5edafffd
AD
63952001-12-10 Akim Demaille <akim@epita.fr>
6396
6397 * src/lalr.c (initialize_lookaheads): New. Extracted from...
6398 * src/LR0.c (set_state_table): here.
6399 * src/lalr.c (lalr): Call it.
6400
0279f8e9
AD
64012001-12-10 Akim Demaille <akim@epita.fr>
6402
6403 * src/state.h (shifts): Remove the `number' member: shifts are
6404 attached to state, hence no longer need to be labelled with a
6405 state number.
6406
190c4f5f
AD
64072001-12-10 Akim Demaille <akim@epita.fr>
6408
6409 Now that states have a complete set of members, the linked list of
6410 shifts is useless: just fill directly the state's shifts member.
6411
6412 * src/state.h (shifts): Remove the `next' member.
6413 * src/LR0.c (first_state, last_state): Remove.
6414 Adjust the callers.
6415 (augment_automaton): Don't look for the shifts that must be added
6416 a shift on EOF: it is those of the state we looked for! But now,
6417 since shifts are attached, it is no longer needed to looking
6418 merely by its id: its number.
6419
2a73b93d
AD
64202001-12-10 Akim Demaille <akim@epita.fr>
6421
6422 * src/LR0.c (augment_automaton): Better variable locality.
6423 Remove an impossible branch: if there is a state corresponding to
6424 the start symbol being shifted, then there is shift for the start
6425 symbol from the initial state.
6426
74392f6a
AD
64272001-12-10 Akim Demaille <akim@epita.fr>
6428
6429 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
6430 only when appropriate: when insert_start_shifting_state' is not
6431 invoked.
6432 * tests/regression.at (Rule Line Numbers): Adjust.
6433
37c82725
AD
64342001-12-10 Akim Demaille <akim@epita.fr>
6435
6436 * src/LR0.c (augment_automaton): Now that all states have shifts,
6437 merge the two cases addition shifts to the initial state.
6438
6a164e0c
AD
64392001-12-10 Akim Demaille <akim@epita.fr>
6440
6441 * src/lalr.c (set_state_table): Move to...
6442 * src/LR0.c: here.
6443 * src/lalr.c (lalr): Don't call it...
6444 * src/LR0.c (generate_states): do it.
6445 * src/LR0.h (first_state): Remove, only the table is used.
6446
7215de24
AD
64472001-12-10 Akim Demaille <akim@epita.fr>
6448
6449 * src/LR0.h (first_shift, first_reduction): Remove.
6450 * src/lalr.c: Don't use first_shift: find shifts through the
6451 states.
6452
80e25d4d
AD
64532001-12-10 Akim Demaille <akim@epita.fr>
6454
6455 * src/LR0.c: Attach shifts to states as soon as they are
6456 computed.
6457 * src/lalr.c (set_state_table): Instead of assigning shifts to
6458 state, just assert that the mapping was properly done.
6459
0ab3728b
AD
64602001-12-10 Akim Demaille <akim@epita.fr>
6461
6462 * src/LR0.c (insert_start_shift): Rename as...
6463 (insert_start_shifting_state): this.
6464 (insert_eof_shifting_state, insert_accepting_state): New.
6465 (augment_automaton): Adjust.
6466 Better locality of the variables.
6467 When looking if the start_symbol is shifted from the initial
6468 state, using `while (... symbol != start_symbol ...)' sounds
6469 better than `while (... symbol < start_symbol ...)': If fail
6470 to see how the order between symbols could be relevant!
6471
78af9bbc
AD
64722001-12-10 Akim Demaille <akim@epita.fr>
6473
6474 * src/getargs.h: Don't declare `spec_name_prefix' and
6475 `spec_file_prefix', declared by src/files.h.
6476 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
6477 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
6478 * src/output.c (prepare): Adjust.
6479 * src/reader.c (symbols_output): Likewise.
6480 * src/vmsgetargs.c: Vaguely adjust, but who cares?
6481
bdef2a41
AD
64822001-12-10 Akim Demaille <akim@epita.fr>
6483
6484 * src/muscle_tab.c (muscle_init): NULL is a better default than
6485 `"0"'.
6486
3735969c
AD
64872001-12-10 Akim Demaille <akim@epita.fr>
6488
6489 * src/reader.c (reader): Calling symbols_output once is enough.
6490
49701457
AD
64912001-12-10 Akim Demaille <akim@epita.fr>
6492
6493 Now that states have a complete set of members, the linked list of
6494 reductions is useless: just fill directly the state's reductions
6495 member.
6496
6497 * src/state.h (struct reductions): Remove member `number' and
6498 `next'.
6499 * src/LR0.c (first_reduction, last_reduction): Remove.
6500 (save_reductions): Don't link the new reductions, store them in
6501 this_state.
6502 * src/lalr.c (set_state_table): No need to attach reductions to
6503 states, it's already done.
6504 * src/output.c (output_actions): No longer free the shifts, then
6505 the reductions, then the states: free all the states and their
6506 members.
6507
0edad749
AD
65082001-12-10 Akim Demaille <akim@epita.fr>
6509
6510 * src/options.c (OPTN, DRTV, BOTH): New.
6511 (option_table): Use them.
6512
0edad749
AD
6513 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
6514 the job of system.h.
6515 * src/options.c: Don't include stdio.h and xalloc.h for the same
6516 reasons.
6517
5449dd0f
AD
65182001-12-10 Akim Demaille <akim@epita.fr>
6519
6520 * src/output.c (output, prepare): Make sure the values of the
6521 muscles `action' and `prologue' are 0-terminated.
6522
a870c567
AD
65232001-12-10 Akim Demaille <akim@epita.fr>
6524
6525 Clean up GCC warnings.
6526
6527 * src/reader.c (copy_action): `buf' is not used.
6528 (parse_skel_decl): Be static.
6529 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
6530 * src/options.h (create_long_option_table): Have a real prototype.
6531 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
6532 (hash_delete_at): Return const void *.
6533 Adjust casts to preserve the const.
6534
80df8768
AD
65352001-12-10 Akim Demaille <akim@epita.fr>
6536
6537 * configure.in: Require 2.52g.
6538 M4 is not needed, but AUTOM4TE is.
6539 * m4/m4.m4: Remove.
6540 * tests/Makefile.am: Adjust.
6541
f693ad14
AD
65422001-12-10 Akim Demaille <akim@epita.fr>
6543
6544 One structure for states is enough, even though theoretically
6545 there are LR(0) states and LALR(1) states.
6546
6547 * src/lalr.h (state_t): Remove.
6548 (state_table): Be state_t **, not state_t *.
6549 * src/state.h (core, CORE_ALLOC): Rename as...
6550 (state_t, STATE_ALLOC): this.
6551 Add the LALR(1) members: shifts, reductions, errs.
6552 * src/LR0.c (state_table): Rename as...
6553 (state_hash): this, to avoid name clashes with the global
6554 `state_table'.
6555 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
6556 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
6557
74ffbcb6
AD
65582001-12-10 Akim Demaille <akim@epita.fr>
6559
6560 Bison dumps core on bash.y.
6561 Reported by Pascal Bart.
6562
6563 * src/warshall.c (bitmatrix_print): New.
6564 (TC): Use it.
6565 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
6566 j must be the outer loop.
6567 * tests/regression.at (Broken Closure): New.
6568
07708e19
AD
65692001-12-05 Akim Demaille <akim@epita.fr>
6570
6571 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
6572 its argument.
6573