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