]> git.saurik.com Git - bison.git/blame - ChangeLog
Restore --no-lines.
[bison.git] / ChangeLog
CommitLineData
437c2d80
AD
12002-11-06 Akim Demaille <akim@epita.fr>
2
3 Restore --no-lines.
4 Reported by Jim Kent.
5
6 * data/c.m4 (b4_syncline): New.
7 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
8 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
9 * src/output.c (user_actions_output): Likewise.
10 (prepare): Define 'b4_synclines_flag'.
11
900c5db5
AD
122002-11-06 Akim Demaille <akim@epita.fr>
13
14 * src/main.c (main): Free `infile'.
15 * src/scan-gram.l (handle_syncline): New.
16 Recognize `#line'.
17 * src/output.c (user_actions_output, symbol_destructors_output)
18 (symbol_printers_output): Use the location's file name, not
19 infile.
20 * src/reader.c (prologue_augment, epilogue_set): Likewise.
21
e183b123 222002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
51b4a04c 23
e183b123 24 * src/tables.c (matching_state): Don't allow states to match if
51b4a04c 25 either has GLR conflict entries.
e183b123 26
193eb6b7
PE
272002-11-05 Paul Eggert <eggert@twinsun.com>
28
e183b123
PE
29 * src/scan-gram.l: Use more accurate diagnostics, e.g.
30 "integer out of range" rather than "invalid value".
31 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
32 accordingly.
33
193eb6b7
PE
34 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
35 Also, remove one static variable in the scanner.
36
37 * src/scan-gram.l (braces_level): Now auto, not static.
38 Initialize to zero if the compiler is being picky.
39 (INITIAL): Clear braces_level instead of incrementing it.
40 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
41 as POSIX 1003.1-2001 requires.
42 * src/system.h (IF_LINT): New macro, taken from coreutils.
43 * configure.ac: Define "lint" if --enable-gcc-warnings.
44
29c01725
AD
452002-11-05 Akim Demaille <akim@epita.fr>
46
47 * src/scan-gram.l: When it starts with `%', complain about the
48 whole directive, not just that `invalid character: %'.
49
8aeac3ca
AD
502002-11-04 Akim Demaille <akim@epita.fr>
51
52 * Makefile.maint: Update from Autoconf.
53 (update, cvs-update, po-update, do-po-update): New.
54
793a58bb
AD
552002-11-04 Akim Demaille <akim@epita.fr>
56
57 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
58 and yyerror.
59 Have yyerror `use' its arguments.
60 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
61 returns true when location & yacc & pure & parse-param.
62 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
63
c4d720cd
AD
642002-11-04 Akim Demaille <akim@epita.fr>
65
66 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
67 clashes.
68 * src/scan-gram.l: Use [\'] instead of ['] to pacify
69 font-lock-mode.
70 Use complain_at.
71 Use quote, not quote_n since LOCATION_PRINT no longer uses the
72 slot 0.
73
613a0dc5
PE
742002-11-03 Paul Eggert <eggert@twinsun.com>
75
76 * src/reader.c (get_merge_function, grammar_current_rule_check):
77 Use consistent diagnostics for reporting type name clashes.
78 Quote the types with <>, for consistency with Yacc.
79 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
80
2a8d363a
AD
812002-11-03 Akim Demaille <akim@epita.fr>
82
83 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
84 New.
85 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
86 (b4_parse_param): Remove.
87 Use b4_identification.
88 Propagate b4_pure_args where needed to pass them to yyerror.
89 * data/glr.m4 (b4_parse_param): Remove.
90 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
91 (b4_lpure_formals): New.
92 Use b4_identification.
93 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
94 b4_user_formals and b4_user_args.
95 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
96 (yyreportAmbiguity): When using a pure parser, also need
97 the location, and the parse-params.
98 Adjust callers.
99 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
100 When using a pure parser, also need the parse-params.
101 Adjust callers.
102 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
103 (%pure-parser + %parse-param) LALR and GLR parsers.
104 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
105 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
106 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
107 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
108 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
109 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
110 * doc/bison.texinfo: Untabify the whole file.
111 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
112 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
113 (Error Reporting): Adjust to these new directives.
114 Document %error-verbose, deprecate YYERROR_VERBOSE.
115
9e32add8
AD
1162002-11-03 Akim Demaille <akim@epita.fr>
117
118 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
119 AT_CHECK_CALC_GLR invocations to use % directives, instead of
120 command line options.
121 * tests/cxx-type.at: Formatting changes.
122
b02d90a5
PE
1232002-11-03 Paul Eggert <eggert@twinsun.com>
124
125 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
126 to count columns correctly, and to check for invalid inputs.
9e32add8 127
b02d90a5
PE
128 Use mbsnwidth to count columns correctly. Account for tabs, too.
129 Include mbswidth.h.
130 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
131 (extend_location): New function.
132 (YY_LINES): Remove.
133
134 Handle CRLF in C code rather than in Lex code.
135 (YY_INPUT): New macro.
136 (no_cr_read): New function.
137
138 Scan UCNs, even though we don't fully handle them yet.
139 (convert_ucn_to_byte): New function.
140
141 Handle backslash-newline correctly in C code.
142 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
143 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
144 all uses changed.
145 (tag, splice): New EREs. Do not allow NUL or newline in tags.
146 Use {splice} wherever C allows backslash-newline.
147 YY_STEP after space, newline, vertical-tab.
148 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
9e32add8 149
b02d90a5
PE
150 (letter, id): Don't assume ASCII; e.g., spell out a-z.
151
152 ({int}, handle_action_dollar, handle_action_at): Check for integer
153 overflow.
9e32add8 154
b02d90a5
PE
155 (YY_STEP): Omit trailing semicolon, so that it's more like C.
156
157 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
158 as well as \000. Check for UCHAR_MAX, not 255.
159 Allow \x with an arbitrary positive number of digits, as in C.
160 Check for overflow here.
161 Allow \? and UCNs, for compatibility with C.
162
163 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
164 with quote slot used by complain_at.
165
166 * tests/input.at: Add tests for backslash-newline, m4 quotes
167 in symbols, long literals, and funny escapes in strings.
168
169 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
170 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
171 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
172 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
173 * m4/mbswidth.m4: New file, from GNU coreutils.
174
175 * doc/bison.texinfo (Grammar Outline): Document // comments.
176 (Symbols): Document that trigraphs have no special meaning in Bison,
177 nor is backslash-newline allowed.
178 (Actions): Document that trigraphs have no special meaning.
179
180 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
181 no longer used.
182
1832002-11-02 Paul Eggert <eggert@twinsun.com>
184
185 * src/reader.c: Don't include quote.h; not needed.
186 (get_merge_function): Reword warning to be consistent with
187 type clash diagnostic in grammar_current_rule_check.
188
189 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
190 bug in trigraph handling.
191
192 * src/output.c (prepare_symbols): When printing token names,
193 escape "[" as "@<:@" and likewise for "]".
194
195 * src/system.h (errno): Remove declaration, as we are now
196 assuming C89 or better, and C89 guarantees errno.
197
762b212b
PE
1982002-10-30 Paul Eggert <eggert@twinsun.com>
199
200 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
201 Check for close failures.
202 * src/files.h (xfclose): Return void, not int, since it always
203 returned zero.
204 * src/files.c (xfclose): Likewise. Report I/O error if ferror
205 indicates one.
206 * src/output.c (output_skeleton): Use xfclose rather than fclose
207 and ferror. xfclose now checks ferror.
208
209 * data/glr.c (YYLEFTMOST_STATE): Remove.
210 (yyreportTree): Use a stack-based leftmost state. This avoids
211 our continuing battles with bogus warnings about initializers.
212
56100c60
AD
2132002-10-30 Akim Demaille <akim@epita.fr>
214
215 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
216 #if.
217
51b4a04c
PH
2182002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
219
220 * tests/glr-regr1.at: New test for reported regressions.
221 * tests/testsuite.at: Add glr-regr1.at test.
222 * tests/Makefile.am: Add glr-regr1.at test.
e183b123 223
bf1ebda2
PE
2242002-10-24 Paul Eggert <eggert@twinsun.com>
225
5c16c6b1
PE
226 Version 1.75a.
227
bf1ebda2
PE
228 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
229 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
230 we use malloc. Don't assume 'A' through 'Z' are contiguous.
231 Don't assume strdup exists; POSIX says its an XSI extension.
232 Check for buffer overflow on input.
233
b526ee61
AD
2342002-10-24 Akim Demaille <akim@epita.fr>
235
236 * src/output.c (output_skeleton): Don't disable M4sugar comments
237 too soon: it results in comments being expanded.
238 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
239 first output.
240
f1886bb2
AD
2412002-10-24 Akim Demaille <akim@epita.fr>
242
243 * data/yacc.c (m4_int_type): New.
244 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
245 char' as only yacc.c wants K&R portability.
246 * data/glr.c (yysigned_char): Remove.
247 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
248 Reported by Quoc Peyrot.
249
c5576256
PE
2502002-10-23 Paul Eggert <eggert@twinsun.com>
251
252 * src/main.c (main): With --trace=time, report times even if a
253 non-fatal error occurs. Formerly, the times were reported in some
254 such cases but not in others.
255 * src/reader.c (reader): Just return if a complaint has been issued,
256 instead of exiting, so that 'main' can report times.
257
27b0ffea
AD
2582002-10-22 Akim Demaille <akim@epita.fr>
259
260 * src/system.h: Include sys/types.
261 Reported by Bert Deknuydt.
262
223a7883
PE
2632002-10-23 Paul Eggert <eggert@twinsun.com>
264
265 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
266 Suggested by Art Haas.
267
2682002-10-22 Paul Eggert <eggert@twinsun.com>
269
270 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
271 decl; not needed any more.
272 * src/main.c (main): Use return to exit, undoing yesterday's change.
273 The last OS that we could find where this wouldn't work is
274 SunOS 3.5, and that's too old to worry about now.
275
276 * data/glr.c (struct yyltype): Define members even when not
277 doing locations. This is more consistent with yacc.c, and it
278 works around the following bug reports:
279 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
280 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
281 and I hope it also fixes this bug report:
282 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
27b0ffea 283
223a7883
PE
284 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
285 @acronym consistently. Standardize on "Yacc" instead of "YACC",
286 "Algol" instead of "ALGOL". Give a bit more history about BNF.
287
8b76775a
AD
2882002-10-22 Akim Demaille <akim@epita.fr>
289
290 * data/README: New.
291
6db10d14
PE
2922002-10-21 Paul Eggert <eggert@twinsun.com>
293
294 Be consistent about 'bool'; the old code used an enum in one
295 module and an int in another, and this violates the C standard.
296 * m4/stdbool.m4: New file, from coreutils 4.5.3.
297 * configure.ac (AC_HEADER_STDBOOL): Add.
298 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
299 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
300 * src/symtab.c (hash_compare_symbol_t): Likewise.
301 * src/system.h (bool, false, true): Use a definition consistent
302 with ../lib/hash.c. All uses changed.
303
304 * src/complain.c (warning_issued): Renamed from warn_message_count,
305 so that we needn't worry about integer overflow (!).
306 Now of type bool. All uses changed.
307 (complaint_issued): Renamed from complain_message_count; likewise.
308
309 * src/main.c (main): Use exit to exit with failure.
27b0ffea 310
6db10d14
PE
311 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
312 rather than 1 and 0.
313 * src/main.c (main): Likewise.
314 * src/getargs.c (getargs): Likewise.
315 * src/reader.c (reader): Likewise.
316
317 * src/getarg.c (getargs): Remove duplicate code for
318 "Try `bison --help'".
319
320 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
321 What was that "2" for?
322
323 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
324 * src/getargs.c (usage): Likewise.
325
326 * src/getargs.c (getargs): When there are too few operands, report
327 the last one. When there are too many, report the first extra
328 one. This is how diffutils does it.
329
92a060fd
PE
3302002-10-20 Paul Eggert <eggert@twinsun.com>
331
332 Remove K&R vestiges.
333 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
334 * src/complain.c (VA_START): Remove. Assume prototypes.
335 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
336 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
337 fatal): Assume prototypes.
338 * src/complain.h: Assume prototypes.
339 * src/system.h (PARAMS): Remove.
340 Include <limits.h> unconditionally, since it's guaranteeed even
341 for a freestanding C89 compiler.
342 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
343 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 344
e7cb57c0
AD
3452002-10-20 Akim Demaille <akim@epita.fr>
346
347 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
348 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
349 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
350 (yyresolveStates, yyresolveAction, yyresolveStack)
351 (yyprocessOneStack): Use them.
352 (yy_reduce_print): New.
353 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
354
0245f82d
AD
3552002-10-20 Akim Demaille <akim@epita.fr>
356
357 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
358 arguments and output `void'.
359 (b4_c_function): Rename as...
360 (b4_c_function_def): this.
361 (b4_c_function_decl, b4_c_ansi_function_def)
362 (b4_c_ansi_function_decl): New.
363 Change the interpretation of the arguments: before `int, foo', now
364 `int foo, foo'.
365 * data/yacc.c (yyparse): Prototype and define thanks to these.
366 Adjust b4_c_function_def uses.
367 * data/glr.c (yyparse): Likewise, but ANSI only.
368
39912f52
AD
3692002-10-20 Akim Demaille <akim@epita.fr>
370
371 * src/output.c (prepare): Move the definition of `tokens_number',
372 `nterms_number', `undef_token_number', `user_token_number_max'
373 to...
374 (prepare_tokens): Here.
375 (prepare_tokens): Rename as...
376 (prepare_symbols): this.
377 (prepare): Move the definition of `rules_number' to...
378 (prepare_rules): here.
379 (prepare): Move the definition of `last', `final_state_number',
380 `states_number' to...
381 (prepare_states): here.
382 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
383
20c1e2ad
AD
3842002-10-20 Akim Demaille <akim@epita.fr>
385
386 * src/tables.h, src/tables.c, src/output.c: Comment changes.
387
21964f43
AD
3882002-10-20 Akim Demaille <akim@epita.fr>
389
390 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
391 * data/c.m4: here.
392
66d30cd4
AD
3932002-10-20 Akim Demaille <akim@epita.fr>
394
395 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
396 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
397 `pair'.
398 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
399 `name' to...
400 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
401 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
402 These.
403
95f2c9fe
PE
4042002-10-19 Paul Eggert <eggert@twinsun.com>
405
406 Do not create a temporary file, as that involves security and
407 cleanup headaches. Instead, use a pair of pipes.
408 Derived from a suggestion by Florian Krohm.
409 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
410 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
411 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
412 (BISON_PREREQ_SUBPIPE): Add.
413 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
414 Add subpipe.h, subpipe.c.
415 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
416 * po/POTFILES.in: Add lib/subpipe.c.
417 * src/output.c: Include "subpipe.h".
418 (m4_invoke): Remove decl.
419 (scan_skel): New decl.
420 (output_skeleton): Use pipe rather than temporary file for m4 input.
421 Check that m4sugar.m4 is readable, to avoid deadlock.
422 Check for pipe I/O error.
423 * src/scan-skel.l (readpipe): Remove decl.
424 (scan_skel): New function, to be used in place of m4_invoke.
425 Read from stream rather than file.
66d30cd4 426
95f2c9fe
PE
427 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
428 float, as this generates a warning on Solaris 8 + GCC 3.2 with
429 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
430 this generates a more-accurate value anyway.
431
432 * lib/timevar.c (timervar_accumulate): Rename locals to
433 avoid confusion with similarly-named more-global.
434 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
435
436 * src/output.c (prepare): Use xstrdup to convert char const *
437 to char *, to avoid GCC warning.
438
c19988b7
AD
4392002-10-19 Akim Demaille <akim@epita.fr>
440
441 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
442 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
443 Use them to have `calc.y' ready for %pure-parser.
444 * data/yacc.c (YYLEX): Pass a yylex return type to
445 b4_c_function_call.
446
ae7453f2
AD
4472002-10-19 Akim Demaille <akim@epita.fr>
448
449 Prototype support of %lex-param and %parse-param.
450
451 * src/parse-gram.y: Add the definition of the %lex-param and
452 %parse-param tokens, plus their rules.
453 Drop the `_' version of %glr-parser.
454 Add the "," token.
455 * src/scan-gram.l (INITIAL): Scan them.
456 * src/muscle_tab.c: Comment changes.
457 (muscle_insert, muscle_find): Rename `pair' as `probe'.
458 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
459 (muscle_entry_s): The `value' member is no longer const.
460 Adjust all dependencies.
461 * src/muscle_tab.c (muscle_init): Adjust: use
462 MUSCLE_INSERT_STRING.
463 Initialize the obstack earlier.
464 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
465 (muscle_pair_list_grow): New.
466 * data/c.m4 (b4_c_function_call, b4_c_args): New.
467 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
468 * tests/calc.at: Use %locations, not --locations.
469 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
470
0e575721
AD
4712002-10-19 Akim Demaille <akim@epita.fr>
472
473 * src/getargs.c (usage): Take status as argument and exit
474 accordingly.
475 Report the traditional `Try ... --help' message when status != 0.
476 (usage, version): Don't take a FILE * as arg, it is pointless.
477 (getargs): When there is an incorrect number of arguments, make it
478 an error, and report it GNUlically thanks to `usage ()'.
479
724ce7f5
PE
4802002-10-18 Paul Eggert <eggert@twinsun.com>
481
3a781eb2
PE
482 * data/glr.c (yyreportParseError): Don't assume that sprintf
483 yields the length of the printed string, as this is not true
484 on SunOS 4.1.4. Reported by Peter Klein.
485
724ce7f5
PE
486 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
487 * tests/conflicts.at (%nonassoc and eof): Likewise.
488 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
489
473d0a75
AD
4902002-10-17 Akim Demaille <akim@epita.fr>
491
492 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
493 * src/getargs.c (trace_types, trace_args): Adjust.
494 * src/reader.c (grammar_current_rule_prec_set)
495 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
496 Standardize error messages.
497 And s/@prec/%prec/!
498 (reader): Use trace_flag to enable scanner/parser debugging,
499 instead of an adhoc scheme.
500 * src/scan-gram.l: Remove trailing debugging code.
501
e76d2469
PE
5022002-10-16 Paul Eggert <eggert@twinsun.com>
503
93e2236a
PE
504 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
505 MUSCLE_TAB_H.
506
e76d2469
PE
507 * NEWS: Officially drop support for building Bison with K&R C,
508 since it didn't work anyway and it's not worth worrying about.
509 * Makefile.maint (wget_files): Remove ansi2knr.c.
510 (ansi2knr.c-url_prefix): Remove.
511 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
512 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
513 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
514
5bd1c419
PE
5152002-10-15 Paul Eggert <eggert@twinsun.com>
516
517 Stop using the "enum_" trick for K&R-style function definitions;
518 it confused me, and I was the author! Instead, assume that people
519 who want to use K&R C compilers (when using these modules in GCC,
520 perhaps?) will run ansi2knr.
521
522 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
523 All uses of "enum_" changed to "enum ".
524 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
525 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 526
5bd1c419
PE
527 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
528 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
529 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
530 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
531 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
532 abitset_not, abitset_ones, abitset_or, abitset_or_and,
533 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
534 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
535 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
536 Use function prototypes; this removes the need for declaring
537 static functions simply to provide their prototypes.
538 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
539 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
540 bitset_count_, bitset_create, bitset_dump, bitset_first,
541 bitset_free, bitset_init, bitset_last, bitset_next,
542 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
543 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
544 bitset_print, bitset_release_memory, bitset_toggle_,
545 bitset_type_choose, bitset_type_get, bitset_type_name_get,
546 debug_bitset): Likewise.
547 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
548 * lib/bitset_stats.c (bitset_log_histogram_print,
549 bitset_percent_histogram_print, bitset_stats_and,
550 bitset_stats_and_cmp, bitset_stats_and_or,
551 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
552 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
553 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
554 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
555 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
556 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
557 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
558 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
559 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
560 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
561 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
562 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
563 bitset_stats_zero): Likewise.
564 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
565 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
566 bitsetv_dump, debug_bitsetv): Likewise.
567 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
568 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
569 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
570 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
571 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
572 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
573 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
574 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
575 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
576 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
577 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
578 Likewise.
579 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
580 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
581 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
582 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
583 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
584 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
585 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
586 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
587 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
588 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
589 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 590
ae26e1f0
AD
5912002-10-14 Akim Demaille <akim@epita.fr>
592
593 Version 1.75.
594
d43baf71
AD
5952002-10-14 Akim Demaille <akim@epita.fr>
596
597 * tests/Makefile.am (maintainer-check-posix): New.
598
7ebc83e3
AD
5992002-10-14 Akim Demaille <akim@epita.fr>
600
601 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
602 member.
603
05846dae
AD
6042002-10-14 Akim Demaille <akim@epita.fr>
605
606 * src/tables.c (table_ninf_remap): base -> tab.
607 Reported by Matt Rosing.
608
1318e37d
PE
6092002-10-14 Paul Eggert <eggert@twinsun.com>
610
447fbb17
PE
611 * tests/action.at, tests/calc.at, tests/conflicts.at,
612 tests/cxx-type.at, tests/headers.at, tests/input.at,
613 tests/regression.at, tests/synclines.at, tests/torture.at:
614 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
615 so that the tests still work even if POSIXLY_CORRECT is set.
616 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 617
1318e37d
PE
618 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
619 for portability to K&R hosts. Fix typo: signed char is guaranteed
620 only to 127, not to 128.
621 * data/glr.c (yysigned_char): New type.
622 * data/yacc.c (yysigned_char): Likewise.
623 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
624
cc0f0794
PE
6252002-10-13 Paul Eggert <eggert@twinsun.com>
626
5038f418
PE
627 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
628 true due to limited range of data type" warning from GCC.
629
cc0f0794
PE
630 * data/c.m4 (b4_token_defines): Protect against double-inclusion
631 by wrapping enum yytokentype's definition inside #ifndef
632 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
633
6fed0802
AD
6342002-10-13 Akim Demaille <akim@epita.fr>
635
636 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
637 Un yy- yyrhs to avoid the name clash with the global YYRHS.
638
32f0598d
AD
6392002-10-13 Akim Demaille <akim@epita.fr>
640
641 * Makefile.maint: Update from Autoconf 2.54.
642 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
643
7ea9a33f
AD
6442002-10-13 Akim Demaille <akim@epita.fr>
645
646 * src/print.c (print_state): Separate the list of solved conflicts
647 from the other items.
648 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
649
ea99527d
AD
6502002-10-13 Akim Demaille <akim@epita.fr>
651
652 Let nondeterministic skeletons be usable with deterministic
653 tables.
654
655 With the patch, GAWK compiled by GCC without -O2 passes its test
656 suite using a GLR parser driven by LALR tables. It fails with -O2
657 because `struct stat' gives two different answers on my machine:
658 88 (definition of an auto var) and later 96 (memset on this var).
659 Hence the stack is badly corrumpted. The headers inclusion is to
660 blame: if I move the awk.h inclusion before GLR's system header
661 inclusion, the two struct stat have the same size.
662
663 * src/tables.c (pack_table): Always create conflict_table.
664 (token_actions): Always create conflict_list.
665 * data/glr.c (YYFLAG): Remove, unused.
666
f377f69f
AD
6672002-10-13 Akim Demaille <akim@epita.fr>
668
669 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
670 (O0FLAGS): New.
671 (VALGRIND, GXX): New.
672 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
673 * tests/bison.in: Run $PREBISON a pre-command.
674 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
675 (maintainer-check-g++): New.
676 * Makefile.am (maintainer-check): New.
677
2a1fe6ed
AD
6782002-10-13 Akim Demaille <akim@epita.fr>
679
680 * data/glr.c: Formatting changes.
681 Tweak some trace messages to match yacc.c's.
682
f50adbbd
AD
6832002-10-13 Akim Demaille <akim@epita.fr>
684
685 GLR parsers sometimes raise parse errors instead of performing the
686 default reduction.
687 Reported by Charles-Henry de Boysson.
688
689 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
690 check the length of the traces when %glr.
691 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
692 GLR's traces.
693 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
694 Test GLR parsers.
695 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
696 (yyltype): Remove the yy prefix from the member names.
697 (yytable): Complete its comment.
698 (yygetLRActions): Map error action number from YYTABLE from
699 YYTABLE_NINF to 0.
700 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
701 (which was a bug: it should have been YYTABEL_NINF, and yet it was
702 not satisfying as we could compare an YYACTION computed from
703 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
704 only value for error actions.
705 (yyreportParseError): In verbose parse error messages, don't issue
706 `error' in the list of expected tokens.
707 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
708 next action to perform to match glr.c's decoding.
709 (yytable): Complete its comment.
710
bcbad5b9
PE
7112002-10-13 Paul Eggert <eggert@twinsun.com>
712
713 Fix problem reported by Henrik Grubbstroem in
714 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
715 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
716 because the Bison parser reads the second action before reducing
717 the first one.
718 * src/scan-gram.l (rule_length): New static var.
719 Use it to keep track of the rule length in the scanner, since
720 we can't expect the parser to be in lock-step sync with the scanner.
721 (handle_action_dollar, handle_action_at): Use this var.
722 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 723
14904b89
PE
7242002-10-12 Paul Eggert <eggert@twinsun.com>
725
1fe611e5
PE
726 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
727 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
728 Include <sys/time.h> when checking for clock_t and struct tms.
729 Use same include order as source.
730 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
731 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
05846dae 732
1fe611e5
PE
733 * lib/timevar.c: Update copyright date and clarify comments.
734 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 735
1fe611e5
PE
736 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
737 GCC version as of today, then merge Bison's changes.
738 Change "GCC" to "Bison" in copyright notice. timevar.def's
739 author is Akim, so change that too.
740
98194095
PE
741 * src/reader.c (grammar_current_rule_check):
742 Don't worry about the default action if $$ is untyped.
743 Prevents bogus warnings reported by Jim Gifford in
744 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
745
14904b89
PE
746 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
747 * data/glr.c, data/lalr1.cc, data/yacc.c:
748 Output token definitions before the first part of user declarations.
749 Fixes compatibility problem reported by Jim Gifford for kbd in
750 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
751
ff6dca18
PE
7522002-10-11 Paul Eggert <eggert@twinsun.com>
753
754 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
755 (yyparse): here. This undoes some of the 2002-07-25 change.
756 Compatibility problem reported by Ralf S. Engelschall with
757 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
758
eb714592
AD
7592002-10-11 Akim Demaille <akim@epita.fr>
760
761 * tests/regression.at Characters Escapes): New.
762 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
763 characters.
764 Reported by Jan Nieuwenhuizen.
765
b7195100
AD
7662002-10-11 Akim Demaille <akim@epita.fr>
767
768 * po/id.po: New.
769
f28a0f2d
PE
7702002-10-10 Paul Eggert <eggert@twinsun.com>
771
772 Portability fixes for bitsets; this also avoids several GCC
773 warnings.
774
775 * lib/abitset.c: Include <stddef.h>, for offsetof.
776 * lib/lbitset.c: Likewise.
777
778 * lib/abitset.c (abitset_bytes): Return a size that is aligned
779 properly for vectors of objects. Do not assume that adding a
780 header size to a multiple of a word size yields a value that is
781 properly aligned for the whole union.
782 * lib/bitsetv.c (bitsetv_alloc): Likewise.
783
784 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
785 unique names for structures.
786 * lib/ebitset.c (ebitset_bytes): Likewise.
787 * lib/lbitset.c (lbitset_bytes): Likewise.
788
789 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
790 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
791 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
792 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
793 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
794 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
795 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
796 to improve the type-checking that GCC can do.
797 * lib/bitset.c (bitset_op4_cmp): Likewise.
798 * lib/bitset_stats.c (bitset_stats_count,
799 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
800 bitset_stats_copy, bitset_stats_disjoint_p,
801 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
802 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
803 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
804 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
805 bitset_stats_and_or_cmp, bitset_stats_andn_or,
806 bitset_stats_andn_or_cmp, bitset_stats_or_and,
807 bitset_stats_or_and_cmp): Likewise.
808 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
809 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
810 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
811 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
812
813 * lib/abitset.h: Include bitset.h, not bbitset.h.
814 * lib/ebitset.h: Likewise.
815 * lib/lbitset.h: Likewise.
816
817 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
818 All instances of parameters of type enum bitset_opts are now of
819 type enum_bitset_opts, to conform to the C Standard, and similarly
820 for enum_bitset_type.
821 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
822 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
823
824 Do not use "struct bitset_struct" to mean different things in
825 different modules. Not only is this confusing, it violates
826 the C Standard, which requires that structure types in different
827 modules must be compatible if one is to be passed to the other.
828 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
829 All instances of "struct bitset_struct *" replaced with "bitset".
830 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
831 (union bitset_union, struct abitset_struct, struct ebitset_struct,
832 struct lbitset_struct, struct bitset_stats_struct): New types.
833 All uses of struct bitset_struct changed to union bitset_union,
834 etc.
835 * lib/abitset.c (struct abitset_struct, abitset,
836 struct bitset_struct): Remove.
837 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
838 struct bitset_struct): Remove.
839 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
840 bitset_struct): Remove.
841 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
842 Likewise.
843
844 Do not call a function of type T using a call that assumes the
845 function is of a different type U. Standard C requires that a
846 function must be called with a type that is compatible with its
847 definition.
848 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
849 New decls.
850 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
851 New functions.
852 * lib/ebitset.c (PFV): Remove.
853 * lib/lbitset.c (PFV): Likewise.
854 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
855 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
856 decls.
857 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
858 (ebitset_vtable): Use them.
859 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
860 lbitset_xor): New functions.
861 (lbitset_vtable): Use them.
862
863 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
864 Declare.
865
866 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
867 GCC warning.
868 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
869 Use offsetof, for simplicity.
870
6fbe4984
PE
8712002-10-06 Paul Eggert <eggert@twinsun.com>
872
873 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
874 the same width as int. This reapplies a hunk of the 2002-08-12 patch
875 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
876 which was inadvertently undone by the 2002-09-30 patch.
877 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
878 the same width as int.
879
420f93c8
PE
8802002-10-04 Paul Eggert <eggert@twinsun.com>
881
882 Version 1.50.
883
884 * configure.ac (AC_INIT), NEWS: Increment version number.
885
886 * doc/bison.texinfo: Minor spelling, grammar, and white space
887 fixes.
888 (Symbols): Mention that any negative value returned from yylex
889 signifies end-of-input. Warn about negative chars. Mention
890 the portable Standard C character set.
891
892 The GNU coding standard says CFLAGS and YFLAGS are reserved
893 for the installer to set.
894 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
895 * src/Makefile.am (AM_CFLAGS): Likewise.
896 (AM_YFLAGS): Renamed from YFLAGS.
897
898 Fix some MAX and MIN problems.
899 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
900 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
901 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
902 * src/reader.c (reader): Use it.
903
904 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
905 POSIX 1003.1-2001 has removed fgrep.
906
9072002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
908
909 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
910 interpreted as signed.
911 * lib/ebitset.c (ebitset_list): Fix bug.
912
ff68026d
PE
9132002-10-01 Paul Eggert <eggert@twinsun.com>
914
915 More fixes for 64-bit hosts and large bitsets.
916
917 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
918 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
919 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
920 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
921 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
922 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
923 bitset_count_): Likewise.
924 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
925 bitset_first, bitset_last): Likewise.
926 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
927 bitset_stats_list_reverse, bitset_stats_size,
928 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
929 Likewise.
930 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
931 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
932 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
933 bitsetv_reflexive_transitive_closure): Likewise.
934 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
935 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
936 Likewise.
937 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
938 Likewise.
420f93c8 939
ff68026d
PE
940 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
941 Use size_t, not unsigned int, to count bytes.
942 * lib/abitset.h (abitset_bytes): Likewise.
943 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
944 Likewise.
945 * lib/bitset.h (bitset_bytes): Likewise.
946 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
947 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
948 * lib/bitsetv.c (bitsetv_alloc): Likewise.
949 * lib/ebitset.c (ebitset_bytes): Likewise.
950 * lib/ebitset.h (ebitset_bytes): Likewise.
951 * lib/lbitset.c (lbitset_bytes): Likewise.
952 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 953
ff68026d
PE
954 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
955 abitset_subset_p, abitset_disjoint_p, abitset_and,
956 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
957 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
958 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
959 abitset_or_and, abitset_or_and_cmp):
960 Use bitset_windex instead of unsigned int.
961 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
962 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
963 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
964 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
965 Likewise.
966 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 967
ff68026d
PE
968 * lib/bitset.c (bitset_print):
969 Use proper printf formats for widths of integer types.
970 * lib/bitset_stats.c (bitset_percent_histogram_print,
971 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
972 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
973 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
974 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 975
ff68026d
PE
976 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
977 BITSET_SIZE_MAX): New macros.
978 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
979 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
980 to BITSET_WINDEX_MAX.
981
982 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
983 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
984 since we now return the bitset_bindex type (not int).
985
986 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
987 when computing sizes.
988 * lib/ebitset.c (ebitset_elts_grow): Likewise.
989
990 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
991 and avoid cast to unsigned.
992
6aa452a6
AD
9932002-09-30 Akim Demaille <akim@epita.fr>
994
995 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
996 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
997 Updates from Michael Hayes.
998
927f7817
AD
9992002-09-30 Art Haas <ahaas@neosoft.com>
1000
1001 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
1002 invocations.
1003 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
1004 defined.
1005
9738f41e
AD
10062002-09-27 Akim Demaille <akim@epita.fr>
1007
1008 Version 1.49c.
1009
a5c75d7f
AD
10102002-09-27 Akim Demaille <akim@epita.fr>
1011
1012 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
1013 (Because of AC_LIBSOURCE).
1014
8280e179
AD
10152002-09-27 Akim Demaille <akim@epita.fr>
1016
1017 Playing with Autoscan.
1018
1019 * configure.ac: Remove the old LIBOBJ tweaks.
1020 (AC_REPLACE_FUNCS): Add strrchr and strtol.
1021 * lib/strrchr.c: New.
1022 * lib/strtol.c: New, from the Coreutils 4.5.1.
1023
ae64af35
AD
10242002-09-27 Akim Demaille <akim@epita.fr>
1025
1026 Playing with Autoscan.
1027
1028 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
1029 * lib/Makefile.am (libbison_a_SOURCES): No longer include
1030 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
1031 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
1032 Coreutils 4.5.1.
1033
d1a1114f
AD
10342002-09-24 Akim Demaille <akim@epita.fr>
1035
1036 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
1037 (Frequently Asked Questions, Parser Stack Overflow): New.
1038
b906441c
AD
10392002-09-13 Akim Demaille <akim@epita.fr>
1040
1041 Playing with autoscan.
1042
1043 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
1044 * src/files.c (skeleton_find): Remove, unused.
1045 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
1046 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
1047
bd701811
AD
10482002-09-13 Akim Demaille <akim@epita.fr>
1049
1050 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
1051 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
1052
e0a13e7b
AD
10532002-09-13 Akim Demaille <akim@epita.fr>
1054
1055 * configure.ac: Require 2.54.
1056 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
1057 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
1058 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
1059 Remove, provided by Autoconf macros.
1060
c97011bf
AD
10612002-09-12 Akim Demaille <akim@epita.fr>
1062
1063 * m4/prereq.m4: Update, from Coreutils 4.5.1.
1064
d862b1be
AD
10652002-09-12 Akim Demaille <akim@epita.fr>
1066
1067 * m4/prereq.m4: Update, from Fileutils 4.1.5.
1068 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
1069 Reported by Martin Mokrejs.
1070
3d38c03a
AD
10712002-09-10 Akim Demaille <akim@epita.fr>
1072
1073 * src/parse-gram.y: Associate a human readable string to each
1074 token type.
1075 * tests/regression.at (Invalid inputs): Adjust.
1076
b6347355
AD
10772002-09-10 Gary V. Vaughan <gary@gnu.org>
1078
1079 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
1080 with an Autoconf-2.5x style configure.ac.
1081
09ba4ab2
PE
10822002-09-06 Paul Eggert <eggert@twinsun.com>
1083
1084 * doc/bison.texinfo (Conditions): Make explicit that the GPL
1085 exception applies only to yacc.c. This is a modification of a
1086 patch originally suggested by Akim Demaille.
1087
21846f69
AD
10882002-09-06 Akim Demaille <akim@epita.fr>
1089
09ba4ab2
PE
1090 * data/c.m4 (b4_copyright): Move the GPL exception comment from
1091 here to...
1092 * data/yacc.c: here.
1093
21846f69
AD
1094 * data/lalr1.cc (struct yyltype): Don't define it, since we use
1095 LocationType.
1096 (b4_ltype): Default to yy::Location from location.hh.
1097
c0ad8bf3
AD
10982002-09-04 Jim Meyering <jim@meyering.net>
1099
1100 * data/yacc.c: Guard the declaration of yytoknum also with
1101 `#ifdef YYPRINT', so it is declared only when used.
1102
3a93251e
AD
11032002-09-04 Akim Demaille <akim@epita.fr>
1104
1105 * configure.in: Rename as...
1106 * configure.ac: this.
1107 Bump to 1.49c.
1108
427c0dda
AD
11092002-09-04 Akim Demaille <akim@epita.fr>
1110
1111 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
1112 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
1113 translate maintainer only messages.
1114
6a254321
PE
11152002-08-12 Paul Eggert <eggert@twinsun.com>
1116
645e30d1
PE
1117 Version 1.49b.
1118
6a254321
PE
1119 * Makefile.am (SUBDIRS): Remove intl.
1120 (DISTCLEANFILES): Remove.
1121 * NEWS: Mention that GNU M4 is now required. Clarify what is
1122 meant by "larger grammars". Mention the pt_BR translation.
1123 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
1124 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
1125 Bump version from 0.11.2 to 0.11.5.
1126 (BISON_PREREQ_STAGE): Remove.
1127 (AM_GNU_GETTEXT): Use external gettext.
1128 (AC_OUTPUT): Remove intl/Makefile.
1129
1130 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
1131
1132 * data/glr.c: Include string.h, for strlen.
1133 (yyreportParseError): Use size_t for yysize.
1134 (yy_yypstack): No longer nested inside yypstates, as nested
1135 functions are not portable. Do not assume size_t is the
1136 same width as int.
1137 (yypstates): Do not assume that ptrdiff_t is the same width
1138 as int, and similarly for yyposn and YYINDEX.
1139
1140 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
1141
1142 * lib/Makefile.am (INCLUDES): Do not include from the intl
1143 directory, which has been removed.
1144 * src/Makefile.am (INCLUDES): Likewise.
1145
1146 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
1147 (bitsets_sources, additional_bitsets_sources, timevars_sources):
1148 New vars.
1149
1150 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
1151 * tests/Makefile.am (EXTRA_DIST): Likewise.
1152
1153 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
1154 Do not assume that bitset_windex is the same width as unsigned.
1155
1156 * lib/abitset.c (abitset_unused_clear): Do not assume that
1157 bitset_word is the same width as int.
1158 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
1159 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
1160 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
1161 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
1162 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
1163
1164 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
1165 portability to one's complement hosts!).
1166 * lib/ebitset.c (ebitset_op1): Likewise.
1167 * lib/lbitset.c (lbitset_op1): Likewise.
1168
1169 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
1170 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
1171 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
1172 Sync with fileutils.
1173 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
1174 lib/gettext.h: Sync with diffutils.
1175
1176 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
1177 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
1178
1179 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
1180 PROTOTYPES to check for prototypes, and "defined __STDC__" to
1181 check for void *.
1182
1183 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
1184 size_t; the old version tried to do this but casted improperly.
1185 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
1186 (bitset_test): Now returns int, not unsigned long.
1187
1188 * lib/bitset_stats.c: Include "gettext.h".
1189 (_): New macro.
1190 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
1191 name locals "index", as it generates unnecessary warnings on some
1192 hosts that have an "index" function.
1193
1194 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
1195 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
1196 they need translation.
1197 * src/LR0.c (state_list_append, new_itemsets, get_state,
1198 append_states, generate_states): Likewise.
1199 * src/assoc.c (assoc_to_string): Likewise.
1200 * src/closure.c (print_closure, set_firsts, closure): Likewise.
1201 * src/gram.c (grammar_dump): Likewise.
1202 * src/injections.c (injections_compute): Likewise.
1203 * src/lalr.c (lookaheads_print): Likewise.
1204 * src/relation.c (relation_transpose): Likewise.
1205 * src/scan-gram.l: Likewise.
1206 * src/tables.c (table_grow, pack_vector): Likewise.
1207
1208 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
1209 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
1210 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
1211 * m4/mbstate_t.m4: Sync with fileutils.
1212 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
1213
1214 * po/LINGUAS: Add pt_BR.
1215 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
1216 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
1217 lib/timevar.c.
1218 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
1219 manual recommends.
1220 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
1221
1222 * src/complain.c (strerror_r): Remove decl; not needed.
1223 (strerror): Use same pattern as ../lib/error.c.
1224
1225 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
1226
1227 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
1228
1229 * src/main.c (main): Cast result of bindtextdomain and textdomain
1230 to void, to avoid a GCC warning when --disable-nls is in effect.
1231
1232 * src/scan-gram.l: Use strings rather than escapes when possible,
1233 to minimize the number of warnings from xgettext.
1234 (handle_action_dollar, handle_action_at): Don't use isdigit,
1235 as it mishandles negative chars and it may not work as expected
1236 outside the C locale.
1237
1238 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
1239 this is a GCC extension and is not portable to other compilers.
1240
1241 * src/system.h (alloca): Use same pattern as ../lib/error.c.
1242 Do not include <ctype.h>; no longer needed.
1243 Do not include <malloc.h>; no longer needed (and generates
1244 warnings on OpenBSD 3.0).
1245
1246 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
1247 it's not portable.
1248
1249 * tests/regression.at: Do not use 'cc -c input.c -o input';
1250 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
1251
1252 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
1253 exit status as failure, not just exit status 1. Sun C exits
1254 with status 2 sometimes.
1255
1256 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
1257 Use it for the two large tests.
1258
c8f002c7
AD
12592002-08-02 Akim Demaille <akim@epita.fr>
1260
1261 * src/conflicts.c (conflicts_output): Don't output rules never
1262 reduced here, since anyway that computation doesn't work.
1263 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
1264 (rule_useless_p, rule_never_reduced_p): New.
1265 (grammar_rules_partial_print): Use a filter instead of a range.
1266 Display the title only if needed.
1267 (grammar_rules_print): Adjust.
1268 (grammar_rules_never_reduced_report): New.
1269 * src/tables.c (action_row): Move the computation of rules never
1270 reduced to...
1271 (token_actions): here.
1272 * src/main.c (main): Make the parser before making the report, so
1273 that rules never reduced are computed.
1274 Call grammar_rules_never_reduced_report.
1275 * src/print.c (print_results): Report rules never reduced.
1276 * tests/conflicts.at, tests/reduce.at: Adjust.
1277
cd08e51e
AD
12782002-08-01 Akim Demaille <akim@epita.fr>
1279
1280 Instead of attaching lookaheads and duplicating the rules being
1281 reduced by a state, attach the lookaheads to the reductions.
1282
1283 * src/state.h (state_t): Remove the `lookaheads',
1284 `lookaheads_rule' member.
1285 (reductions_t): Add a `lookaheads' member.
1286 Use a regular array for the `rules'.
1287 * src/state.c (reductions_new): Initialize the lookaheads member
1288 to 0.
1289 (state_rule_lookaheads_print): Adjust.
1290 * src/state.h, src/state.c (state_reductions_find): New.
1291 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
1292 (count_rr_conflicts): Adjust.
1293 * src/lalr.c (LArule): Remove.
1294 (add_lookback_edge): Adjust.
1295 (state_lookaheads_count): New.
1296 (states_lookaheads_initialize): Merge into...
1297 (initialize_LA): this.
1298 (lalr_free): Adjust.
1299 * src/main.c (main): Don't free nullable and derives too early: it
1300 is used by --verbose.
1301 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
1302
bb0027a9
AD
13032002-08-01 Akim Demaille <akim@epita.fr>
1304
1305 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
1306 `rule_number_t**'.
1307 (set_derives, free_derives): Rename as...
1308 (derives_compute, derives_free): this.
1309 Adjust all dependencies.
1310 * src/nullable.c (set_nullable, free_nullable): Rename as...
1311 (nullable_compute, nullable_free): these.
1312 (rule_list_t): Store rule_t *, not rule_number_t.
1313 * src/state.c (state_rule_lookaheads_print): Directly compare rule
1314 pointers, instead of their numbers.
1315 * src/main.c (main): Call nullable_free, and derives_free earlier,
1316 as they were lo longer used.
1317
3325ddc4
AD
13182002-08-01 Akim Demaille <akim@epita.fr>
1319
1320 * lib/timevar.c (get_time): Include children time.
1321 * src/lalr.h (LA, LArule): Don't export them: used with the
1322 state_t.
1323 * src/lalr.c (LA, LArule): Static.
1324 * src/lalr.h, src/lalr.c (lalr_free): New.
1325 * src/main.c (main): Call it.
1326 * src/tables.c (pack_vector): Check whether loc is >= to the
1327 table_size, not >.
1328 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1329 (tables_generate): do it, since that's also it which allocates
1330 them.
1331 Don't free LA and LArule, main does.
1332
c6f1a33c
AD
13332002-07-31 Akim Demaille <akim@epita.fr>
1334
1335 Separate parser tables computation and output.
1336
1337 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1338 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1339 (yydefgoto, yydefact, high): Move to...
1340 * src/tables.h, src/tables.c: here.
1341 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1342 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1343 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1344 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1345 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1346 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1347 (action_row, save_row, token_actions, save_column, default_goto)
1348 (goto_actions, sort_actions, matching_state, pack_vector)
1349 (table_ninf_remap, pack_table, prepare_actions): Move to...
1350 * src/tables.c: here.
1351 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1352 * src/output.c (token_actions, output_base, output_conflicts)
1353 (output_check): Merge into...
1354 (prepare_actions): this.
1355 (actions_output): Rename as...
1356 (user_actions_output): this.
1357 * src/main.c (main): Call tables_generate and tables_free.
1358
1509d42f
AD
13592002-07-31 Akim Demaille <akim@epita.fr>
1360
1361 Steal GCC's --time-report support.
1362
1363 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1364 stolen/adjusted from GCC.
1365 * m4/stage.m4: Remove time related checks.
1366 * m4/timevar.m4: New.
1367 * configure.in: Adjust.
1368 * src/system.h: Adjust to using timevar.h.
1369 * src/getargs.h, src/getargs.c: Support trace_time for
1370 --trace=time.
1371 * src/main.c (stage): Remove.
1372 (main): Replace `stage' invocations with timevar calls.
1373 * src/output.c: Insert pertinent timevar calls.
1374
273a74fa
AD
13752002-07-31 Akim Demaille <akim@epita.fr>
1376
1377 Let --trace have arguments.
1378
1379 * src/getargs.h (enum trace_e): New.
1380 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1381 (long_options, short_options): --trace/-T takes an optional
1382 argument.
1383 Change all the uses of trace_flag to reflect the new flags.
1384 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1385
1386 Strengthen `stage' portability.
1387
1388 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1389 * configure.in: Use it.
1390 Don't check for malloc.h and sys/times.h.
1391 * src/system.h: Include them when appropriate.
1392 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1393 times and struct tms are available.
1394
217598da
AD
13952002-07-30 Akim Demaille <akim@epita.fr>
1396
1397 In verbose parse error message, don't report `error' as an
1398 expected token.
1399 * tests/actions.at (Printers and Destructors): Adjust.
1400 * tests/calc.at (Calculator $1): Adjust.
1401 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1402 error message, do not report the parser accepts the error token in
1403 that state.
1404
52489d44
AD
14052002-07-30 Akim Demaille <akim@epita.fr>
1406
1407 Normalize conflict related messages.
1408
1409 * src/complain.h, src/complain.c (warn, complain): New.
1410 * src/conflicts.c (conflicts_print): Use them.
1411 (conflict_report_yacc): New, extracted from...
1412 (conflicts_print): here.
1413 * tests/conflicts.at, tests/existing.at: Adjust.
1414
e8832397
AD
14152002-07-30 Akim Demaille <akim@epita.fr>
1416
1417 Report rules which are never reduced by the parser: those hidden
1418 by conflicts.
1419
1420 * src/LR0.c (save_reductions): Don't make the final state too
1421 different: save its reduction (accept) instead of having a state
1422 without any action (no shift or goto, no reduce).
1423 Note: the final state is now a ``regular'' state, i.e., the
1424 parsers now contain `reduce 0' as default reduction.
1425 Nevertheless, since they decide to `accept' when yystate =
1426 final_state, they still will not reduce rule 0.
1427 * src/print.c (print_actions, print_reduction): Adjust.
1428 * src/output.c (action_row): Track reduced rules.
1429 (token_actions): Report rules never reduced.
1430 * tests/conflicts.at, tests/regression.at: Adjust.
1431
caf23d24
AD
14322002-07-30 Akim Demaille <akim@epita.fr>
1433
1434 `stage' was accidently included in a previous patch.
1435 Initiate its autoconfiscation.
1436
1437 * configure.in: Look for malloc.h and sys/times.h.
1438 * src/main.c (stage): Adjust.
1439 Report only when trace_flag.
1440
640748ee
AD
14412002-07-29 Akim Demaille <akim@epita.fr>
1442
1443 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1444 state_number_t.
1445 (errs_t): symbol_t*, not symbol_number_t.
1446 (reductions_t): rule_t*, not rule_number_t.
1447 (FOR_EACH_SHIFT): New.
1448 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1449 * src/print.c, src/print_graph.c: Adjust.
1450
88bce5a2
AD
14512002-07-29 Akim Demaille <akim@epita.fr>
1452
1453 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1454
1455 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1456 (endtoken, accept): these.
1457 * src/reader.c (reader): Set endtoken's default tag to "$end".
1458 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1459 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1460 Adjust.
1461
1bfb97db
AD
14622002-07-29 Akim Demaille <akim@epita.fr>
1463
1464 * src/reduce.c (reduce_grammar): When the language is empty,
1465 complain about the start symbol, not the axiom.
1466 Use its location.
1467 * tests/reduce.at (Empty Language): New.
1468
fc5734fe
AD
14692002-07-26 Akim Demaille <akim@epita.fr>
1470
1471 * src/reader.h, src/reader.c (gram_error): ... can't get
1472 yycontrol without making too strong assumptions on the parser
1473 itself.
1474 * src/output.c (prepare_tokens): Use the real 0th value of
1475 token_translations instead of `0'.
1476 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1477 visible here.
1478 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1479 for the time being: %locations ought to provide it to yyerror.
1480
3650b4b8
AD
14812002-07-25 Akim Demaille <akim@epita.fr>
1482
1483 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1484 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1485 * tests/regression.at (Web2c Actions): Adjust.
1486
4b3d3a8e
AD
14872002-07-25 Akim Demaille <akim@epita.fr>
1488
1489 Stop storing rules from 1 to nrules + 1.
1490
1491 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1492 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1493 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1494 Iterate from 0 to nrules.
1495 Use rule_number_as_item_number and item_number_as_rule_number.
1496 Adjust to `derive' now containing possibly 0.
1497 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1498 Handle the `- 1' part in rule numbers from/to item numbers.
1499 * src/conflicts.c (log_resolution): Fix the message which reversed
1500 shift and reduce.
1501 * src/output.c (action_row): Initialize default_rule to -1.
1502 (token_actions): Adjust.
1503 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1504 expected output.
1505 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1506
4a2a22f4
AD
15072002-07-25 Akim Demaille <akim@epita.fr>
1508
1509 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1510 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1511 (b4_c_knr_arg_decl): New.
1512 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1513 yyreport_parse_error.
1514
b8df3223
AD
15152002-07-25 Akim Demaille <akim@epita.fr>
1516
1517 * data/yacc.c (yyreport_parse_error): New, extracted from...
1518 (yyparse): here.
1519 (yydestruct, yysymprint): Move above yyparse.
1520 Be K&R compliant.
1521
a762e609
AD
15222002-07-25 Akim Demaille <akim@epita.fr>
1523
1524 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1525 replace...
1526 (b4_sint_type, b4_uint_type): these.
1527 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1528 * tests/regression.at (Web2c Actions): Adjust.
1529
12b0043a
AD
15302002-07-25 Akim Demaille <akim@epita.fr>
1531
1532 * src/gram.h (TIEM_NUMBER_MAX): New.
1533 (item_number_of_rule_number, rule_number_of_item_number): Rename
1534 as...
1535 (rule_number_as_item_number, item_number_as_rule_number): these.
1536 Adjust dependencies.
1537 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1538 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1539 (symbol_number_to_vector_number): New.
1540 (order): Of vector_number_t* type.
1541 (base_t, BASE_MAX, BASE_MIN): New.
1542 (froms, tos, width, pos, check): Of base_t type.
1543 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1544 (actrow): Of action_number_t type.
1545 (conflrow): Of unsigned int type.
1546 (table_ninf, base_ninf): New.
1547 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1548 (muscle_insert_int_table, muscle_insert_base_table)
1549 (muscle_insert_rule_number_table): New.
1550 (prepare_tokens): Output `toknum' as int_table.
1551 (action_row): Returns a rule_number_t.
1552 Use ACTION_MIN, not SHRT_MIN.
1553 (token_actions): yydefact is rule_number_t*.
1554 (table_ninf_remap): New.
1555 (pack_table): Use it for `base' and `table'.
1556 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1557 replaced with...
1558 (YYPACT_NINF, YYTABLE_NINF): these.
1559 (yypact, yytable): Compute their types instead of hard-coded
1560 `short'.
1561 * tests/regression.at (Web2c Actions): Adjust.
1562
5dde258a
AD
15632002-07-19 Akim Demaille <akim@epita.fr>
1564
1565 * src/scan-gram.l (id): Can start with an underscore.
1566
a945ec39
AD
15672002-07-16 Akim Demaille <akim@epita.fr>
1568
1569 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
1570 Adjust all former `associativity' dependencies.
1571 * src/symtab.c (symbol_new): Default associativity is `undef', not
1572 `right'.
1573 (symbol_check_alias_consistence): Adjust.
1574
fae437e8
AD
15752002-07-09 Akim Demaille <akim@epita.fr>
1576
1577 * doc/bison.texinfo: Properly set the ``header'' part.
1578 Use @dircategory ``GNU programming tools'' as per Texinfo's
1579 documentation.
1580 Use @copying.
1581
1a715ef2
AD
15822002-07-09 Akim Demaille <akim@epita.fr>
1583
1584 * lib/quotearg.h: Protect against multiple inclusions.
1585 * src/location.h (location_t): Add a `file' member.
1586 (LOCATION_RESET, LOCATION_PRINT): Adjust.
1587 * src/complain.c (warn_at, complain_at, fatal_at): Drop
1588 `error_one_per_line' support.
1589
a5d50994
AD
15902002-07-09 Akim Demaille <akim@epita.fr>
1591
1592 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
1593 * src/reader.c (lineno): Remove.
1594 Adjust all dependencies.
1595 (get_merge_function): Take a location and use complain_at.
1596 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
1597 * tests/regression.at (Invalid inputs, Mixing %token styles):
1598 Adjust.
1599
b275314e
AD
16002002-07-09 Akim Demaille <akim@epita.fr>
1601
1602 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
1603 recovery rule, and forbid extensions when --yacc.
1604 (gram_error): Use complain_at.
1605 * src/reader.c (reader): Exit if there were parse errors.
1606
865b9df1
AD
16072002-07-09 Akim Demaille <akim@epita.fr>
1608
1609 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
1610 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
1611 Reported by R Blake <blakers@mac.com>.
1612
c76e14da
AD
16132002-07-09 Akim Demaille <akim@epita.fr>
1614
1615 * data/yacc.c: Output the copyright notive in the header.
1616
7db2ed2d
AD
16172002-07-03 Akim Demaille <akim@epita.fr>
1618
1619 * src/output.c (froms, tos): Are state_number_t.
1620 (save_column): sp, sp1, and sp2 are state_number_t.
1621 (prepare): Rename `final' as `final_state_number', `nnts' as
1622 `nterms_number', `nrules' as `rules_number', `nstates' as
1623 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
1624 unused.
1625 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
1626 * data/lalr1.cc (nsym_): Remove, unused.
1627
e68e0410
AD
16282002-07-03 Akim Demaille <akim@epita.fr>
1629
1630 * src/lalr.h, src/lalr.c (goto_number_t): New.
1631 * src/lalr.c (goto_list_t): New.
1632 Propagate them.
1633 * src/nullable.c (rule_list_t): New.
1634 Propagate.
1635 * src/types.h: Remove.
1636
e1a4f3a4
AD
16372002-07-03 Akim Demaille <akim@epita.fr>
1638
1639 * src/closure.c (print_fderives): Use rule_rhs_print.
1640 * src/derives.c (print_derives): Use rule_rhs_print.
1641 (rule_list_t): New, replaces `shorts'.
1642 (set_derives): Add comments.
1643 * tests/sets.at (Nullable, Firsts): Adjust.
1644
536545f3
AD
16452002-07-03 Akim Demaille <akim@epita.fr>
1646
1647 * src/output.c (prepare_actions): Free `tally' and `width'.
1648 (prepare_actions): Allocate and free `order'.
1649 * src/symtab.c (symbols_free): Free `symbols'.
1650 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
1651 * src/output.c (m4_invoke): Move to...
1652 * src/scan-skel.l: here.
1653 (<<EOF>>): Close yyout, and free its name.
1654
8b752b00
AD
16552002-07-03 Akim Demaille <akim@epita.fr>
1656
1657 Fix some memory leaks, and fix a bug: state 0 was examined twice.
1658
1659 * src/LR0.c (new_state): Merge into...
1660 (state_list_append): this.
1661 (new_states): Merge into...
1662 (generate_states): here.
1663 (set_states): Don't ensure a proper `errs' state member here, do it...
1664 * src/conflicts.c (conflicts_solve): here.
1665 * src/state.h, src/state.c: Comment changes.
1666 (state_t): Rename member `shifts' as `transitions'.
1667 Adjust all dependencies.
1668 (errs_new): For consistency, also take the values as argument.
1669 (errs_dup): Remove.
1670 (state_errs_set): New.
1671 (state_reductions_set, state_transitions_set): Assert that no
1672 previous value was assigned.
1673 (state_free): New.
1674 (states_free): Use it.
1675 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
1676 temporary storage: use `errs' and `nerrs' as elsewhere.
1677 (set_conflicts): Allocate and free this `errs'.
1678
613f5e1a
AD
16792002-07-02 Akim Demaille <akim@epita.fr>
1680
1681 * lib/libiberty.h: New.
1682 * lib: Update the bitset implementation from upstream.
1683 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
1684 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
1685 * src/main.c: Adjust bitset stats calls.
1686
26e0cadc
PE
16872002-07-01 Paul Eggert <eggert@twinsun.com>
1688
1689 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
1690 char, so that negative chars don't collide with $.
1691
1154cced
AD
16922002-06-30 Akim Demaille <akim@epita.fr>
1693
1694 Have the GLR tests be `warning' checked, and fix the warnings.
1695
1696 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
1697 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
1698 (yyremoveDeletes): `yyi' and `yyj' are size_t.
1699 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
1700 (yyaddDeferredAction): static.
1701 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
1702 (yyreportParseError): yyprefix is const.
1703 yytokenp is used only when verbose.
1704 (yy__GNUC__): Replace with __GNUC__.
1705 (yypdumpstack): yyi is size_t.
1706 (yypreference): Un-yy local variables and arguments, to avoid
1707 clashes with `yyr1'. Anyway, we are not in the user name space.
1708 (yytname_size): be an int, as is compared with ints.
1709 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
1710 Use them.
1711 * tests/cxx-gram.at: Use quotation to protect $1.
1712 Use AT_COMPILE to enable warnings hunts.
1713 Prototype yylex and yyerror.
1714 `Use' argc.
1715 Include `string.h', not `strings.h'.
1716 Produce and prototype stmtMerge only when used.
1717 yylex takes a location.
1718
97650f4e
AD
17192002-06-30 Akim Demaille <akim@epita.fr>
1720
1721 We spend a lot of time in quotearg, in particular when --verbose.
1722
1723 * src/symtab.c (symbol_get): Store a quoted version of the key.
1724 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
1725 Adjust all callers.
1726
d2576365
AD
17272002-06-30 Akim Demaille <akim@epita.fr>
1728
1729 * src/state.h (reductions_t): Rename member `nreds' as num.
1730 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
1731 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
1732
ccaf65bc
AD
17332002-06-30 Akim Demaille <akim@epita.fr>
1734
1735 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
1736 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
1737 (shifts_to): Rename as...
1738 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1739 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1740 (TRANSITION_IS_DISABLED, transitions_to): these.
1741
87675353
AD
17422002-06-30 Akim Demaille <akim@epita.fr>
1743
1744 * src/print.c (print_shifts, print_gotos): Merge into...
1745 (print_transitions): this.
1746 (print_transitions, print_errs, print_reductions): Align the
1747 lookaheads columns.
1748 (print_core, print_transitions, print_errs, print_state,
1749 print_grammar): Output empty lines separator before, not after.
1750 (state_default_rule_compute): Rename as...
1751 (state_default_rule): this.
1752 * tests/conflicts.at (Defaulted Conflicted Reduction),
1753 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1754 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1755
ce4ccb4b
AD
17562002-06-30 Akim Demaille <akim@epita.fr>
1757
1758 Display items as we display rules.
1759
1760 * src/gram.h, src/gram.c (rule_lhs_print): New.
1761 * src/gram.c (grammar_rules_partial_print): Use it.
1762 * src/print.c (print_core): Likewise.
1763 * tests/conflicts.at (Defaulted Conflicted Reduction),
1764 (Unresolved SR Conflicts): Adjust.
1765 (Unresolved SR Conflicts): Adjust and rename as...
1766 (Resolved SR Conflicts): this, as was meant.
1767 * tests/regression.at (Web2c Report): Adjust.
1768
bc933ef1
AD
17692002-06-30 Akim Demaille <akim@epita.fr>
1770
1771 * src/print.c (state_default_rule_compute): New, extracted from...
1772 (print_reductions): here.
1773 Pessimize, but clarify the code.
1774 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1775
53d4308d
AD
17762002-06-30 Akim Demaille <akim@epita.fr>
1777
1778 * src/output.c (action_row): Let default_rule be always a rule
1779 number.
1780
574fb2d5
AD
17812002-06-30 Akim Demaille <akim@epita.fr>
1782
1783 * src/closure.c (print_firsts, print_fderives, closure):
1784 Use BITSET_EXECUTE.
1785 * src/lalr.c (lookaheads_print): Likewise.
1786 * src/state.c (state_rule_lookaheads_print): Likewise.
1787 * src/print_graph.c (print_core): Likewise.
1788 * src/print.c (print_reductions): Likewise.
1789 * src/output.c (action_row): Likewise.
1790 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1791
05811fd7
AD
17922002-06-30 Akim Demaille <akim@epita.fr>
1793
1794 * src/print_graph.c: Use report_flag.
1795
0e4d5753
AD
17962002-06-30 Akim Demaille <akim@epita.fr>
1797
1798 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1799 to...
1800 * src/relation.h, src/relation.c (traverse, relation_digraph)
1801 (relation_print, relation_transpose): New.
1802
24c7d800
AD
18032002-06-30 Akim Demaille <akim@epita.fr>
1804
1805 * src/state.h, src/state.c (shifts_to): New.
1806 * src/lalr.c (build_relations): Use it.
1807
9222837b
AD
18082002-06-30 Akim Demaille <akim@epita.fr>
1809
1810 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1811 (item_number_of_rule_number, rule_number_of_item_number): New.
1812 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1813 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1814 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1815 Propagate their use.
1816 Much remains to be done, in particular wrt `shorts' from types.h.
1817
260008e5
AD
18182002-06-30 Akim Demaille <akim@epita.fr>
1819
1820 * src/symtab.c (symbol_new): Initialize the `printer' member.
1821
8a731ca8
AD
18222002-06-30 Akim Demaille <akim@epita.fr>
1823
1824 * src/LR0.c (save_reductions): Remove, replaced by...
1825 * src/state.h, src/state.c (state_reductions_set): New.
1826 (reductions, errs): Rename as...
1827 (reductions_t, errs_t): these.
1828 Adjust all dependencies.
1829
32e1e0a4
AD
18302002-06-30 Akim Demaille <akim@epita.fr>
1831
1832 * src/LR0.c (state_list_t, state_list_append): New.
1833 (first_state, last_state): Now symbol_list_t.
1834 (this_state): Remove.
1835 (new_itemsets, append_states, save_reductions): Take a state_t as
1836 argument.
1837 (set_states, generate_states): Adjust.
1838 (save_shifts): Remove, replaced by...
1839 * src/state.h, src/state.c (state_shifts_set): New.
1840 (shifts): Rename as...
1841 (shifts_t): this.
1842 Adjust all dependencies.
1843 * src/state.h (state_t): Remove the `next' member.
1844
e5fb6710
AD
18452002-06-30 Akim Demaille <akim@epita.fr>
1846
1847 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1848 escaped in slot 0.
1849
c7ca99d4
AD
18502002-06-30 Akim Demaille <akim@epita.fr>
1851
1852 Use hash.h for the state hash table.
1853
1854 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1855 (allocate_storage): Use state_hash_new.
1856 (free_storage): Use state_hash_free.
1857 (new_state, get_state): Adjust.
1858 * src/lalr.h, src/lalr.c (states): Move to...
1859 * src/states.h (state_t): Remove the `link' member, no longer
1860 used.
1861 * src/states.h, src/states.c: here.
1862 (state_hash_new, state_hash_free, state_hash_lookup)
1863 (state_hash_insert, states_free): New.
1864 * src/states.c (state_table, state_compare, state_hash): New.
1865 * src/output.c (output_actions): Do not free states now, since we
1866 still need to know the final_state number in `prepare', called
1867 afterwards. Do it...
1868 * src/main.c (main): here: call states_free after `output'.
1869
df0e7316
AD
18702002-06-30 Akim Demaille <akim@epita.fr>
1871
1872 * src/state.h, src/state.c (state_new): New, extracted from...
1873 * src/LR0.c (new_state): here.
1874 * src/state.h (STATE_ALLOC): Move to...
1875 * src/state.c: here.
1876 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1877 * src/state.h, src/state.c: here.
1878
39f41916
AD
18792002-06-30 Akim Demaille <akim@epita.fr>
1880
1881 * src/reader.c (gensym): Rename as...
1882 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1883 (getsym): Rename as...
1884 (symbol_get): this.
1885
d57650a5
AD
18862002-06-30 Akim Demaille <akim@epita.fr>
1887
1888 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1889 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1890 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1891 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1892
5a08f1ce
AD
18932002-06-30 Akim Demaille <akim@epita.fr>
1894
1895 Make the test suite pass with warnings checked.
1896
1897 * tests/actions.at (Printers and Destructors): Improve.
1898 Avoid unsigned vs. signed issues.
1899 * tests/calc.at: Don't exercise the scanner here, do it...
1900 * tests/input.at (Torturing the Scanner): here.
1901
720623af
PH
19022002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1903
88e7e941 1904 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
1905 reorganize first lines parallel to yacc.c.
1906
fb8135fa
AD
19072002-06-28 Akim Demaille <akim@epita.fr>
1908
1909 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1910 (b4_token_enum, b4_token_defines): New, factored from...
1911 * data/lalr1.cc, data/yacc.c, glr.c: here.
1912
41442480
AD
19132002-06-28 Akim Demaille <akim@epita.fr>
1914
1915 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1916 unused variables.
1917 * src/output.c (merger_output): static.
1918
e0e5bf84
AD
19192002-06-28 Akim Demaille <akim@epita.fr>
1920
1921 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1922 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1923 pacify GCC.
1924 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 1925
676385e2
PH
19262002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1927
1928 Accumulated changelog for new GLR parsing features.
1929
6a254321 1930 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
1931 conflicts_total_count.
1932 * src/conflicts.h: Ditto.
1933 * src/output.c (token_actions): Use the new name.
1934 (output_conflicts): Change conflp => conflict_list_heads, and
1935 confl => conflict_list for better readability.
1936 * data/glr.c: Use the new names.
1937 * NEWS: Add self to GLR announcement.
e0e5bf84 1938
676385e2
PH
1939 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1940
1941 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1942 Akim Demaille.
1943
1944 * data/bison.glr: Change name to glr.c
1945 * data/glr.c: Renamed from bison.glr.
1946 * data/Makefile.am: Add glr.c
e0e5bf84
AD
1947
1948 * src/getargs.c:
1949
676385e2
PH
1950 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1951 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 1952
676385e2
PH
1953 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1954
1955 * data/bison.glr: Be sure to restore the
1956 current #line when returning to the skeleton contents after having
1957 exposed the input file's #line.
1958
1959 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1960
1961 * data/bison.glr: Bring up to date with changes to bison.simple.
1962
1963 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1964
1965 * data/bison.glr: Correct definitions that use b4_prefix.
1966 Various reformatting.
1967 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1968 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1969 yytokenp argument; now part of stack.
1970 (yychar): Define to behave as documented.
1971 (yyclearin): Ditto.
e0e5bf84 1972
676385e2
PH
1973 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1974
1975 * src/reader.h: Add declaration for free_merger_functions.
1976
1977 * src/reader.c (merge_functions): New variable.
1978 (get_merge_function): New function.
1979 (free_merger_functions): New function.
1980 (readgram): Check for %prec that is not followed by a symbol.
1981 Handle %dprec and %merge declarations.
1982 (packgram): Initialize dprec and merger fields in rules array.
1983
1984 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1985 conflict_list_cnt, conflict_list_free): New variables.
1986 (table_grow): Also grow conflict_table.
e0e5bf84 1987 (prepare_rules): Output dprec and merger tables.
676385e2 1988 (conflict_row): New function.
e0e5bf84 1989 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
1990 default reduction in conflicted states for GLR parser so that there
1991 are spaces for the conflict lists.
1992 (save_row): Also save conflict information.
1993 (token_actions): Allocate conflict list.
1994 (merger_output): New function.
1995 (pack_vector): Pack conflict table, too.
1996 (output_conflicts): New function to output yyconflp and yyconfl.
1997 (output_check): Allocate conflict_tos.
1998 (output_actions): Output conflict tables, also.
1999 (output_skeleton): Output b4_mergers definition.
2000 (prepare): Output b4_max_rhs_length definition.
2001 Use 'bison.glr' as default skeleton for GLR parsers.
2002
2003 * src/gram.c (glr_parser): New flag.
2004 (grammar_free): Call free_merger_functions.
2005
2006 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
2007 all pairs of conflicting reductions, rather than just all tokens
2008 causing conflicts. Needed to size conflict tables.
e0e5bf84 2009 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
2010 interface.
2011 (conflicts_print): Ditto.
2012 (count_total_conflicts): New function.
2013
2014 * src/reader.h (merger_list): New type.
2015 (merge_functions): New variable.
2016
2017 * src/lex.h (tok_dprec, tok_merge): New token types.
2018
2019 * src/gram.h (rule_s): Add dprec and merger fields.
2020 (glr_parser): New flag.
2021
2022 * src/conflicts.h (count_total_conflicts): New function.
2023
2024 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
2025
2026 * doc/bison.texinfo (Generalized LR Parsing): New section.
2027 (GLR Parsers): New section.
2028 (Language and Grammar): Mention GLR parsing.
2029 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
2030 Correct typo ("tge" -> "the").
2031
2032 * data/bison.glr: New skeleton for GLR parsing.
2033
2034 * tests/cxx-gram.at: New tests for GLR parsing.
2035
2036 * tests/testsuite.at: Include cxx-gram.at.
2037
2038 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 2039
676385e2
PH
2040 * src/parse-gram.y:
2041
2042 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
2043
2044 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 2045
b5480d74 20462002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
2047
2048 * src/options.h, src/options.c: Remove.
2049 * src/getargs.c (short_options, long_options): New.
2050
60491a94
AD
20512002-06-27 Akim Demaille <akim@epita.fr>
2052
2053 * data/bison.simple, data/bison.c++: Rename as...
2054 * data/yacc.c, data/lalr1.cc: these.
2055 * doc/bison.texinfo (Environment Variables): Remove.
2056
9be0c25b
AD
20572002-06-25 Raja R Harinath <harinath@cs.umn.edu>
2058
2059 * src/getargs.c (report_argmatch): Initialize strtok().
2060
1ae72863
AD
20612002-06-20 Akim Demaille <akim@epita.fr>
2062
2063 * data/bison.simple (b4_symbol_actions): New, replaces...
2064 (b4_symbol_destructor, b4_symbol_printer): these.
2065 (yysymprint): Be sure to call YYPRINT only for tokens, and using
2066 user token numbers.
2067
87542d29
AD
20682002-06-20 Akim Demaille <akim@epita.fr>
2069
2070 * data/bison.simple (yydestructor): Rename as...
2071 (yydestruct): this.
2072
1a31ed21
AD
20732002-06-20 Akim Demaille <akim@epita.fr>
2074
2075 * src/symtab.h, src/symtab.c (symbol_type_set)
2076 (symbol_destructor_set, symbol_precedence_set): The location is
2077 the last argument.
2078 Adjust all callers.
2079
e776192e
AD
20802002-06-20 Akim Demaille <akim@epita.fr>
2081
2082 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
2083 internals.
2084 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
2085 Takes a location.
2086 * src/symtab.h, src/symtab.c (symbol_class_set)
2087 (symbol_user_token_number_set): Likewise.
2088 Adjust all callers.
2089 Promote complain_at.
2090 * tests/input.at (Type Clashes): Adjust.
2091
5c1180b3
AD
20922002-06-20 Akim Demaille <akim@epita.fr>
2093
2094 * data/bison.simple (YYLEX): Fix the declaration when
2095 %pure-parser.
2096
e3170060
AD
20972002-06-20 Akim Demaille <akim@epita.fr>
2098
2099 * data/bison.simple (yysymprint): Don't print the token number,
2100 just its name.
2101 * tests/actions.at (Destructors): Rename as...
2102 (Printers and Destructors): this.
2103 Also exercise %printer.
2104
253862fd
AD
21052002-06-20 Akim Demaille <akim@epita.fr>
2106
2107 * data/bison.simple (YYDSYMPRINT): New.
2108 Use it to remove many of the #if YYDEBUG/if (yydebug).
2109
366eea36
AD
21102002-06-20 Akim Demaille <akim@epita.fr>
2111
2112 * src/symtab.h, src/symtab.c (symbol_t): printer and
2113 printer_location are new members.
2114 (symbol_printer_set): New.
2115 * src/parse-gram.y (PERCENT_PRINTER): New token.
2116 Handle its associated rule.
2117 * src/scan-gram.l: Adjust.
2118 (handle_destructor_at, handle_destructor_dollar): Rename as...
2119 (handle_symbol_code_at, handle_symbol_code_dollar): these.
2120 * src/output.c (symbol_printers_output): New.
2121 (output_skeleton): Call it.
2122 * data/bison.simple (yysymprint): New. Cannot be named yyprint
2123 since there are already many grammar files with a user `yyprint'.
2124 Replace the calls to YYPRINT to calls to yysymprint.
2125 * tests/calc.at: Adjust.
2126 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
2127 taking advantage of parser very internal details (stack size!).
2128
4f25ebb0
AD
21292002-06-20 Akim Demaille <akim@epita.fr>
2130
2131 * src/scan-gram.l: Complete the scanner with the missing patterns
2132 to pacify Flex.
2133 Use `quote' and `symbol_tag_get' where appropriate.
2134
93b68a0e
AD
21352002-06-19 Akim Demaille <akim@epita.fr>
2136
2137 * tests/actions.at (Destructors): Augment to test locations.
2138 * data/bison.simple (yydestructor): Pass it the current location
2139 if locations are enabled.
2140 Prototype only when __STDC__ or C++.
2141 Change the argument names to move into the yy name space: there is
2142 user code here.
2143
58612f1d
AD
21442002-06-19 Akim Demaille <akim@epita.fr>
2145
74310291
AD
2146 * data/bison.simple (b4_pure_if): New.
2147 Use it instead of #ifdef YYPURE.
2148
21492002-06-19 Akim Demaille <akim@epita.fr>
2150
2151 * data/bison.simple (b4_location_if): New.
58612f1d
AD
2152 Use it instead of #ifdef YYLSP_NEEDED.
2153
f25bfb75
AD
21542002-06-19 Akim Demaille <akim@epita.fr>
2155
2156 Prepare @$ in %destructor, but currently don't bind it in the
2157 skeleton, as %location use is not cleaned up yet.
2158
2159 * src/scan-gram.l (handle_dollar, handle_destructor_at)
2160 (handle_action_at): New.
2161 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
2162 a braced_code_t and a location as additional arguments.
2163 (handle_destructor_dollar): Instead of requiring `b4_eval', just
2164 unquote one when outputting `b4_dollar_dollar'.
2165 Adjust callers.
2166 * data/bison.simple (b4_eval): Remove.
2167 (b4_symbol_destructor): Adjust.
2168 * tests/input.at (Invalid @n): Adjust.
2169
c732d2c6
AD
21702002-06-19 Zack Weinberg <zack@codesourcery.com>
2171
2172 * doc/bison.texinfo: Document ability to have multiple
2173 prologue sections.
2174
8c165d89
AD
21752002-06-18 Akim Demaille <akim@epita.fr>
2176
2177 * src/files.c (compute_base_names): When computing the output file
2178 names from the input file name, strip the directory part.
2179
ca98bf57
AD
21802002-06-18 Akim Demaille <akim@epita.fr>
2181
2182 * data/bison.simple.new: Comment changes.
2183 Reported by Andreas Schwab.
2184
0bfb02ff
AD
21852002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
2186
2187 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
2188 there are no `label `yyoverflowlab' defined but not used' warnings
2189 when yyoverflow is defined.
2190
24c0aad7
AD
21912002-06-18 Akim Demaille <akim@epita.fr>
2192
2193 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
2194 new member.
2195 (symbol_destructor_set): Adjust.
2196 * src/output.c (symbol_destructors_output): Output the destructor
2197 locations.
2198 Output the symbol name.
2199 * data/bison.simple (b4_symbol_destructor): Adjust.
2200
5719c109
AD
22012002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
2202 and Akim Demaille <akim@epita.fr>
2203
2204 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
2205 what's left on the stack when the error recovery hits EOF.
2206 * tests/actions.at (Destructors): Complete to exercise this case.
2207
9280d3ef
AD
22082002-06-17 Akim Demaille <akim@epita.fr>
2209
2210 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
2211 arguments is really empty, not only equal to `[]'.
2212 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
2213 member.
2214 (symbol_destructor_set): New.
2215 * src/output.c (symbol_destructors_output): New.
2216 * src/reader.h (brace_code_t, current_braced_code): New.
2217 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
2218 (handle_dollar): Rename as...
2219 (handle_action_dollar): this.
2220 (handle_destructor_dollar): New.
2221 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
2222 (grammar_declaration): Use it.
2223 * data/bison.simple (yystos): Is always defined.
2224 (yydestructor): New.
2225 * tests/actions.at (Destructors): New.
2226 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
2227
dafdc66f
AD
22282002-06-17 Akim Demaille <akim@epita.fr>
2229
2230 * src/symlist.h, src/symlist.c (symbol_list_length): New.
2231 * src/scan-gram.l (handle_dollar, handle_at): Compute the
2232 rule_length only when needed.
2233 * src/output.c (actions_output, token_definitions_output): Output
2234 the full M4 block.
2235 * src/symtab.c: Don't access directly to the symbol tag, use
2236 symbol_tag_get.
2237 * src/parse-gram.y: Use symbol_list_free.
2238
56c47203
AD
22392002-06-17 Akim Demaille <akim@epita.fr>
2240
2241 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
2242 (symbol_list_prepend, get_type_name): Move to...
2243 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
2244 (symbol_list_prepend, symbol_list_n_type_name_get): here.
2245 Adjust all callers.
2246 (symbol_list_free): New.
2247 * src/scan-gram.l (handle_dollar): Takes a location.
2248 * tests/input.at (Invalid $n): Adjust.
2249
1e0bab92
AD
22502002-06-17 Akim Demaille <akim@epita.fr>
2251
2252 * src/reader.h, src/reader.c (symbol_list_new): Export it.
2253 (symbol_list_prepend): New.
2254 * src/parse-gram.y (%union): `list' is a new member.
2255 (symbols.1): New, replaces...
2256 (terms_to_prec.1, nterms_to_type.1): these.
2257 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
2258 Take a location as additional argument.
2259 Adjust all callers.
2260
04e60654
AD
22612002-06-15 Akim Demaille <akim@epita.fr>
2262
2263 * src/parse-gram.y: Move %token in the declaration section so that
2264 we don't depend upon CVS Bison.
2265
10e5b8bd
AD
22662002-06-15 Akim Demaille <akim@epita.fr>
2267
2268 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
2269 * src/print.c (print_core): Use it.
2270
9801d40c
AD
22712002-06-15 Akim Demaille <akim@epita.fr>
2272
2273 * src/conflicts.c (log_resolution): Accept the rule involved in
2274 the sr conflicts instead of the lookahead number that points to
2275 that rule.
2276 (flush_reduce): Accept the current lookahead vector as argument,
2277 instead of the index in LA.
2278 (resolve_sr_conflict): Accept the current number of lookahead
2279 bitset to consider for the STATE, instead of the index in LA.
2280 (set_conflicts): Adjust.
2281 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
2282
c0263492
AD
22832002-06-15 Akim Demaille <akim@epita.fr>
2284
2285 * src/state.h (state_t): Replace the `lookaheadsp' member, a
2286 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
2287 Adjust all dependencies.
2288 * src/lalr.c (initialize_lookaheads): Split into...
2289 (states_lookaheads_count, states_lookaheads_initialize): these.
2290 (lalr): Adjust.
2291
9757c359
AD
22922002-06-15 Akim Demaille <akim@epita.fr>
2293
2294 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
2295 out of...
2296 (grammar_rules_print): here.
2297 * src/reduce.c (reduce_output): Use it.
2298 * tests/reduce.at (Useless Rules, Reduced Automaton)
2299 (Underivable Rules): Adjust.
2300
6b98e4b5
AD
23012002-06-15 Akim Demaille <akim@epita.fr>
2302
2303 Copy BYacc's nice way to report the grammar.
2304
2305 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
2306 New.
2307 Don't print the rules' location, it is confusing and useless.
2308 (rule_print): Use grammar_rhs_print.
2309 * src/print.c (print_grammar): Use grammar_rules_print.
2310
6b98e4b5
AD
23112002-06-15 Akim Demaille <akim@epita.fr>
2312
2313 Complete and rationalize `useless thing' warnings.
2314
2315 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
2316 (symbol_tag_print): New.
2317 Use them everywhere in place of accessing directly the tag member.
2318 * src/gram.h, src/gram.c (rule_print): New.
2319 Use it where a rule used to be printed `by hand'.
2320 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
2321 (reduce_grammar_tables): Report the useless rules.
2322 (reduce_print): Useless things are a warning, not an error.
2323 Report it as such.
2324 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2325 (Reduced Automaton, Underivable Rules): Adjust.
2326 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2327 * tests/conflicts.at (Unresolved SR Conflicts)
2328 (Solved SR Conflicts): Adjust.
2329
ee000ba4
AD
23302002-06-15 Akim Demaille <akim@epita.fr>
2331
2332 Let symbols have a location.
2333
2334 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2335 (getsym): Adjust.
2336 Adjust all callers.
2337 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2338 Use location_t, not int.
2339 * src/symtab.c (symbol_check_defined): Take advantage of the
2340 location.
2341 * tests/regression.at (Invalid inputs): Adjust.
2342
8efe435c
AD
23432002-06-15 Akim Demaille <akim@epita.fr>
2344
2345 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2346 (input): Don't try to initialize yylloc here, do it in the
2347 scanner.
2348 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2349 * src/gram.h (rule_t): Change line and action_line into location
2350 and action_location, of location_t type.
2351 Adjust all dependencies.
2352 * src/location.h, src/location.c (empty_location): New.
2353 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2354 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2355 (grammar_current_rule_symbol_append)
2356 (grammar_current_rule_action_append): Expect a location as argument.
2357 * src/reader.c (grammar_midrule_action): Adjust to attach an
2358 action's location as dummy symbol location.
2359 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2360 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2361 the line numbers.
2362
1921f1d7
AD
23632002-06-14 Akim Demaille <akim@epita.fr>
2364
2365 Grammar declarations may be found in the grammar section.
2366
2367 * src/parse-gram.y (rules_or_grammar_declaration): New.
2368 (declarations): Each declaration may end with a semicolon, not
2369 just...
2370 (grammar_declaration): `"%union"'.
2371 (grammar): Branch to rules_or_grammar_declaration.
2372
4515534c
AD
23732002-06-14 Akim Demaille <akim@epita.fr>
2374
2375 * src/main.c (main): Invoke scanner_free.
2376
f958596b
AD
23772002-06-14 Akim Demaille <akim@epita.fr>
2378
2379 * src/output.c (m4_invoke): Extracted from...
2380 (output_skeleton): here.
2381 Free tempfile.
2382
2c569025
AD
23832002-06-14 Akim Demaille <akim@epita.fr>
2384
2385 * src/parse-gram.y (directives, directive, gram)
2386 (grammar_directives, precedence_directives, precedence_directive):
2387 Rename as...
2388 (declarations, declaration, grammar, grammar_declaration)
2389 (precedence_declaration, precedence_declarator): these.
2390 (symbol_declaration): New.
2391
592e8d4d
AD
23922002-06-14 Akim Demaille <akim@epita.fr>
2393
2394 * src/files.c (action_obstack): Remove, unused.
2395 (output_obstack): Remove it, and all its dependencies, as it is no
2396 longer needed.
2397 * src/reader.c (epilogue_set): Build the epilogue in the
2398 muscle_obstack.
2399 * src/output.h, src/output.c (muscle_obstack): Move to...
2400 * src/muscle_tab.h, src/muscle_tab.h: here.
2401 (muscle_init): Initialize muscle_obstack.
2402 (muscle_free): New.
2403 * src/main.c (main): Call it.
2404
0c15323d
AD
24052002-06-14 Akim Demaille <akim@epita.fr>
2406
2407 * src/location.h: New, extracted from...
2408 * src/reader.h: here.
2409 * src/Makefile.am (noinst_HEADERS): Merge into
2410 (bison_SOURCES): this.
2411 Add location.h.
2412 * src/parse-gram.y: Use location_t instead of Bison's.
2413 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2414 Use location_t instead of ints.
2415
e96c9728
AD
24162002-06-14 Akim Demaille <akim@epita.fr>
2417
2418 * data/bison.simple, data/bison.c++: Be sure to restore the
2419 current #line when returning to the skeleton contents after having
2420 exposed the input file's #line.
2421
75d1fe16
AD
24222002-06-12 Akim Demaille <akim@epita.fr>
2423
2424 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2425 eager.
2426 * tests/actions.at (Exotic Dollars): New.
2427
6c35d22c
AD
24282002-06-12 Akim Demaille <akim@epita.fr>
2429
2430 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2431 ['"/] too eagerly.
2432 * tests/input.at (Torturing the Scanner): New.
2433
1d6412ad
AD
24342002-06-11 Akim Demaille <akim@epita.fr>
2435
2436 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2437 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2438 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2439 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2440 * src/reader.c (reader): Use it.
2441
4cdb01db
AD
24422002-06-11 Akim Demaille <akim@epita.fr>
2443
2444 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2445 Adjust all callers.
2446 (scanner_last_string_free): New.
2447
44995b2e
AD
24482002-06-11 Akim Demaille <akim@epita.fr>
2449
2450 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2451 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2452 (last_string, YY_OBS_FREE): New.
2453 Use them when returning an ID.
2454
e9955c83
AD
24552002-06-11 Akim Demaille <akim@epita.fr>
2456
2457 Have Bison grammars parsed by a Bison grammar.
2458
2459 * src/reader.c, src/reader.h (prologue_augment): New.
2460 * src/reader.c (copy_definition): Remove.
2461
2462 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2463 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2464 (grammar_current_rule_prec_set, grammar_current_rule_check)
2465 (grammar_current_rule_symbol_append)
2466 (grammar_current_rule_action_append): Export.
2467 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2468 (symbol_list_action_append): Remove.
2469 Hook the routines from reader.
2470 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2471 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2472
2473 * src/reader.c (read_declarations): Remove, unused.
2474
2475 * src/parse-gram.y: Handle the epilogue.
2476 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2477 (grammar_start_symbol_set): this.
2478 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2479 * src/reader.c (readgram): Remove, unused.
2480 (reader): Adjust to insert eoftoken and axiom where appropriate.
2481
2482 * src/reader.c (copy_dollar): Replace with...
2483 * src/scan-gram.h (handle_dollar): this.
2484 * src/parse-gram.y: Remove `%thong'.
2485
2486 * src/reader.c (copy_at): Replace with...
2487 * src/scan-gram.h (handle_at): this.
2488
2489 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2490 New.
2491
2492 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2493 time being.
2494
2495 * src/reader.h, src/reader.c (grammar_rule_end): New.
2496
2497 * src/parse.y (current_type, current_class): New.
2498 Implement `%nterm', `%token' support.
2499 Merge `%term' into `%token'.
2500 (string_as_id): New.
2501 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2502 type name.
2503
2504 * src/parse-gram.y: Be sure to handle properly the beginning of
2505 rules.
2506
2507 * src/parse-gram.y: Handle %type.
2508 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2509
2510 * src/parse-gram.y: More directives support.
2511 * src/options.c: No longer handle source directives.
2512
2513 * src/parse-gram.y: Fix %output.
2514
2515 * src/parse-gram.y: Handle %union.
2516 Use the prologue locations.
2517 * src/reader.c (parse_union_decl): Remove.
2518
2519 * src/reader.h, src/reader.c (epilogue_set): New.
2520 * src/parse-gram.y: Use it.
2521
2522 * data/bison.simple, data/bison.c++: b4_stype is now either not
2523 defined, then default to int, or to the contents of %union,
2524 without `union' itself.
2525 Adjust.
2526 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2527
2528 * src/output.c (actions_output): Don't output braces, as they are
2529 already handled by the scanner.
2530
2531 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2532 characters to themselves.
2533
2534 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2535 that the epilogue has a proper #line.
2536
2537 * src/parse-gram.y: Handle precedence/associativity.
2538
2539 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2540 a terminal.
2541 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2542 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2543 at all to define terminals that cannot be emitted.
2544
2545 * src/scan-gram.l: Escape M4 characters.
2546
2547 * src/scan-gram.l: Working properly with escapes in user
2548 strings/characters.
2549
2550 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2551 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2552 grammar.
2553 Use more modest sizes, as for the time being the parser does not
2554 release memory, and therefore the process swallows a huge amount
2555 of memory.
2556
2557 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2558 stricter %token grammar.
2559
2560 * src/symtab.h (associativity): Add `undef_assoc'.
2561 (symbol_precedence_set): Do nothing when passed an undef_assoc.
2562 * src/symtab.c (symbol_check_alias_consistence): Adjust.
2563
2564 * tests/regression.at (Invalid %directive): Remove, as it is now
2565 meaningless.
2566 (Invalid inputs): Adjust to the new error messages.
2567 (Token definitions): The new grammar doesn't allow too many
2568 eccentricities.
2569
2570 * src/lex.h, src/lex.c: Remove.
2571 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
2572 (copy_character, copy_string2, copy_string, copy_identifier)
2573 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
2574 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
2575 (parse_action): Remove.
2576 * po/POTFILES.in: Adjust.
2577
2e047461
AD
25782002-06-11 Akim Demaille <akim@epita.fr>
2579
2580 * src/reader.c (parse_action): Don't store directly into the
2581 rule's action member: return the action as a string.
2582 Don't require `rule_length' as an argument: compute it.
2583 (grammar_current_rule_symbol_append)
2584 (grammar_current_rule_action_append): New, eved out from
2585 (readgram): here.
2586 Remove `action_flag', `rulelength', unused now.
2587
9af3fbce
AD
25882002-06-11 Akim Demaille <akim@epita.fr>
2589
2590 * src/reader.c (grammar_current_rule_prec_set).
2591 (grammar_current_rule_check): New, eved out from...
2592 (readgram): here.
2593 Remove `xaction', `first_rhs': useless.
2594 * tests/input.at (Type clashes): New.
2595 * tests/existing.at (GNU Cim Grammar): Adjust.
2596
1485e106
AD
25972002-06-11 Akim Demaille <akim@epita.fr>
2598
2599 * src/reader.c (grammar_midrule_action): New, Eved out from
2600 (readgram): here.
2601
da4160c3
AD
26022002-06-11 Akim Demaille <akim@epita.fr>
2603
2604 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
2605 New.
2606 (readgram): Use them as replacement of inlined code, crule and
2607 crule1.
2608
f6d0f937
AD
26092002-06-11 Akim Demaille <akim@epita.fr>
2610
2611 * src/reader.c (grammar_end, grammar_symbol_append): New.
2612 (readgram): Use them.
2613 Make the use of `p' as local as possible.
2614
69078d4b
AD
26152002-06-10 Akim Demaille <akim@epita.fr>
2616
2617 GCJ's parser requires the tokens to be defined before the prologue.
2618
2619 * data/bison.simple: Output the token definition before the user's
2620 prologue.
2621 * tests/regression.at (Braces parsing, Duplicate string)
2622 (Mixing %token styles): Check the output from bison.
2623 (Early token definitions): New.
2624
5e424082
AD
26252002-06-10 Akim Demaille <akim@epita.fr>
2626
2627 * src/symtab.c (symbol_user_token_number_set): Don't complain when
2628 assigning twice the same user number to a token, so that we can
2629 use it in...
2630 * src/lex.c (lex): here.
2631 Also use `symbol_class_set' instead of hand written code.
2632 * src/reader.c (parse_assoc_decl): Likewise.
2633
44536b35
AD
26342002-06-10 Akim Demaille <akim@epita.fr>
2635
2636 * src/symtab.c, src/symtab.c (symbol_class_set)
2637 (symbol_user_token_number_set): New.
2638 * src/reader.c (parse_token_decl): Use them.
2639 Use a switch instead of ifs.
2640 Use a single argument.
2641
8b9f2372
AD
26422002-06-10 Akim Demaille <akim@epita.fr>
2643
2644 Remove `%thong' support as it is undocumented, unused, duplicates
2645 `%token's job, and creates useless e-mail traffic with people who
2646 want to know what it is, why it is undocumented, unused, and
2647 duplicates `%token's job.
2648
2649 * src/reader.c (parse_thong_decl): Remove.
2650 * src/options.c (option_table): Remove "thong".
2651 * src/lex.h (tok_thong): Remove.
2652
3ae2b51f
AD
26532002-06-10 Akim Demaille <akim@epita.fr>
2654
2655 * src/symtab.c, src/symtab.c (symbol_type_set)
2656 (symbol_precedence_set): New.
2657 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
2658 (value_components_used): Remove, unused.
2659
2f1afb73
AD
26602002-06-09 Akim Demaille <akim@epita.fr>
2661
2662 Move symbols handling code out of the reader.
2663
2664 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
2665 (axiom): Move to...
2666 * src/symtab.h, src/symtab.c: here.
2667
2668 * src/gram.c (start_symbol): Remove: use startsymbol->number.
2669 * src/reader.c (startval): Rename as...
2670 * src/symtab.h, src/symtab.c (startsymbol): this.
2671 * src/reader.c: Adjust.
2672
2673 * src/reader.c (symbol_check_defined, symbol_make_alias)
2674 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2675 (token_translations_init)
2676 Move to...
2677 * src/symtab.c: here.
2678 * src/reader.c (packsymbols): Move to...
2679 * src/symtab.h, src/symtab.c (symbols_pack): here.
2680 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
2681 argument.
2682
e9bca3ad
AD
26832002-06-03 Akim Demaille <akim@epita.fr>
2684
2685 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
2686 then statements.
2687
86eff183
AD
26882002-06-03 Akim Demaille <akim@epita.fr>
2689
2690 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
2691 structs with non literals.
2692 * src/scan-skel.l: never-interactive.
2693 * src/conflicts.c (enum conflict_resolution_e): No trailing
2694 comma.
2695 * src/getargs.c (usage): Split long literal strings.
2696 Reported by Hans Aberg.
2697
717be197
AD
26982002-05-28 Akim Demaille <akim@epita.fr>
2699
2700 * data/bison.c++: Use C++ ostreams.
2701 (cdebug_): New member.
2702
670ddffd
AD
27032002-05-28 Akim Demaille <akim@epita.fr>
2704
2705 * src/output.c (output_skeleton): Be sure to allocate enough room
2706 for `/' _and_ for `\0' in full_skeleton.
2707
769b430f
AD
27082002-05-28 Akim Demaille <akim@epita.fr>
2709
2710 * data/bison.c++: Catch up with bison.simple:
2711 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2712 and Paul Eggert <eggert@twinsun.com>: `error' handing.
2713 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
2714 and popping traces.
2715
7067cb36
PH
27162002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2717
2718 * src/output.c (output_skeleton): Put an explicit path in front of
2719 the skeleton file name, rather than relying on the -I directory,
2720 to partially alleviate effects of having a skeleton file lying around
2721 in the current directory.
769b430f 2722
4a713ec2
PH
27232002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2724
769b430f 2725 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
2726 obstack_printf should be obstack_fgrow1.
2727
b408954b
AD
27282002-05-26 Akim Demaille <akim@epita.fr>
2729
2730 * src/state.h (state_t): `solved_conflicts' is a new member.
2731 * src/LR0.c (new_state): Set it to 0.
2732 * src/conflicts.h, src/conflicts.c (print_conflicts)
2733 (free_conflicts, solve_conflicts): Rename as...
2734 (conflicts_print, conflicts_free, conflicts_solve): these.
2735 Adjust callers.
2736 * src/conflicts.c (enum conflict_resolution_e)
2737 (solved_conflicts_obstack): New, used by...
2738 (log_resolution): this.
2739 Adjust to attach the conflict resolution to each state.
2740 Complete the description with the precedence/associativity
2741 information.
2742 (resolve_sr_conflict): Adjust.
2743 * src/print.c (print_state): Output its solved_conflicts.
2744 * tests/conflicts.at (Unresolved SR Conflicts)
2745 (Solved SR Conflicts): Exercise --report=all.
2746
a49aecd5
AD
27472002-05-26 Akim Demaille <akim@epita.fr>
2748
2749 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2750 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2751 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2752 (token_number_t, item_number_as_token_number)
2753 (token_number_as_item_number, muscle_insert_token_number_table):
2754 Rename as...
2755 (symbol_number_t, item_number_as_symbol_number)
2756 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2757 these, since it is more appropriate.
2758
5504898e
AD
27592002-05-26 Akim Demaille <akim@epita.fr>
2760
2761 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2762 `Error:' lines.
2763 * data/bison.simple (yystos) [YYDEBUG]: New.
2764 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2765 error recovery.
2766 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2767
ec3bc396
AD
27682002-05-25 Akim Demaille <akim@epita.fr>
2769
2770 * doc/bison.texinfo (Debugging): Split into...
2771 (Tracing): this new section, its former contents, and...
2772 (Understanding): this new section.
2773 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2774 by...
2775 (report_flag): this.
2776 Adjust all dependencies.
2777 (report_args, report_types, report_argmatch): New.
2778 (usage, getargs): Report/support -r, --report.
2779 * src/options.h
2780 (struct option_table_struct): Rename as..,
2781 (struct option_table_s): this.
2782 Rename the `set_flag' member to `flag' to match with getopt_long's
2783 struct.
2784 * src/options.c (option_table): Split verbose into an entry for
2785 %verbose, and another for --verbose.
2786 Support --report/-r, so remove -r from the obsolete --raw.
2787 * src/print.c: Attach full item sets and lookaheads reports to
2788 report_flag instead of trace_flag.
2789 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2790
78df8250
PE
27912002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2792 and Paul Eggert <eggert@twinsun.com>
769b430f 2793
78df8250
PE
2794 * data/bison.simple (yyparse): Correct error handling to conform to
2795 POSIX and yacc. Specifically, after syntax error is discovered,
2796 do not reduce further before shifting the error token.
2797 Clean up the code a bit by removing the labels yyerrdefault,
2798 yyerrhandle, yyerrpop.
2799 * NEWS: Document the above.
2800
c0c9ea05
PH
28012002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2802
2803 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2804 type; it isn't always big enough, since it doesn't necessarily
2805 include non-terminals.
769b430f 2806 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
2807 the latter can be removed.
2808 (yy_token_number_type): Remove, only one use.
2809 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2810 don't use TokenNumberType as element type.
769b430f 2811
c0c9ea05
PH
2812 * tests/regression.at: Modify expected output to agree with change
2813 to yyr1 and yytranslate.
769b430f 2814
6390a83f
FK
28152002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2816
2817 * src/reader.c (parse_action): Use copy_character instead of
2818 obstack_1grow.
2819
db7c8e9a
AD
28202002-05-13 Akim Demaille <akim@epita.fr>
2821
2822 * tests/regression.at (Token definitions): Prototype yylex and
2823 yyerror.
2824
fcc61800
PH
28252002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2826
158c687b 2827 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
2828 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2829 32-bit arithmetic.
2830 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2831
5683e9b2
AD
28322002-05-07 Akim Demaille <akim@epita.fr>
2833
2834 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2835 avoid GCC warnings.
2836
0c2d3f4c
AD
28372002-05-07 Akim Demaille <akim@epita.fr>
2838
2839 Kill GCC warnings.
2840
2841 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2842 over the RHS of each rule.
2843 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2844 * src/state.h (state_t): Member `nitems' is unsigned short.
2845 * src/LR0.c (get_state): Adjust.
2846 * src/reader.c (packgram): Likewise.
2847 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2848 `Type'.
2849 (muscle_insert_int_table): Remove, unused.
2850 (prepare_rules): Remove `max'.
2851
1565b720
AD
28522002-05-06 Akim Demaille <akim@epita.fr>
2853
2854 * src/closure.c (print_firsts): Display of the symbol tags.
2855 (bitmatrix_print): Move to...
2856 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2857 here.
2858 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2859
cfaee611
AD
28602002-05-06 Akim Demaille <akim@epita.fr>
2861
2862 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2863 hash_do_for_each.
2864
458be8e0
AD
28652002-05-06 Akim Demaille <akim@epita.fr>
2866
2867 * src/LR0.c (new_state, get_state): Instead of using the global
2868 `kernel_size' and `kernel_base', have two new arguments:
2869 `core_size' and `core'.
2870 Adjust callers.
2871
a900a624
AD
28722002-05-06 Akim Demaille <akim@epita.fr>
2873
2874 * src/reader.c (packgram): No longer end `ritem' with a 0
2875 sentinel: it is not used.
2876
d4e7d3a1
AD
28772002-05-05 Akim Demaille <akim@epita.fr>
2878
2879 New experimental feature: display the lookaheads in the report and
2880 graph.
2881
2882 * src/print (print_core): When --trace-flag, display the rules
2883 lookaheads.
2884 * src/print_graph.c (print_core): Likewise.
2885 Swap the arguments.
2886 Adjust caller.
2887
39ceb25b
AD
28882002-05-05 Akim Demaille <akim@epita.fr>
2889
2890 * tests/torture.at (Many lookaheads): New test.
2891
5372019f
AD
28922002-05-05 Akim Demaille <akim@epita.fr>
2893
2894 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2895 (GENERATE_MUSCLE_INSERT_TABLE): this.
2896 (output_int_table, output_unsigned_int_table, output_short_table)
2897 (output_token_number_table, output_item_number_table): Replace with...
2898 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2899 (muscle_insert_short_table, muscle_insert_token_number_table)
2900 (muscle_insert_item_number_table): these.
2901 Adjust all callers.
2902 (prepare_tokens): Don't free `translations', since...
2903 * src/reader.h, src/reader.c (grammar_free): do it.
2904 Move to...
2905 * src/gram.h, src/gram.c (grammar_free): here.
2906 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2907 b4_translate_max.
2908
5df5f6d5
AD
29092002-05-05 Akim Demaille <akim@epita.fr>
2910
2911 * src/output.c (output_unsigned_int_table): New.
2912 (prepare_rules): `i' is unsigned.
2913 `prhs', `rline', `r2' are unsigned int.
2914 Rename muscle `rhs_number_max' as `rhs_max'.
2915 Output muscles `prhs_max', `rline_max', and `r2_max'.
2916 Free rline and r1.
2917 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2918 to compute types instead of constant types.
2919 * tests/regression.at (Web2c Actions): Adjust.
2920
b87f8b21
AD
29212002-05-04 Akim Demaille <akim@epita.fr>
2922
2923 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2924 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2925 Adjust dependencies.
2926 * src/output.c (token_definitions_output): Be sure not to output a
2927 `#define 'a'' when fed with `%token 'a' "a"'.
2928 * tests/regression.at (Token definitions): New.
2929
8bb936e4
PE
29302002-05-03 Paul Eggert <eggert@twinsun.com>
2931
2932 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2933 for K&R C.
2934
29352002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2936
2937 * Makefile.am (SUBDIRS): Remove intl.
2938 (EXTRA_DIST): Add config/config.rpath.
2939
53c71a12
AD
29402002-05-03 Akim Demaille <akim@epita.fr>
2941
2942 * data/bison.simple (m4_if): Don't output empty enums.
2943 And actually, output valid enum definitions :(.
2944
289dd0cf
AD
29452002-05-03 Akim Demaille <akim@epita.fr>
2946
2947 * configure.bat: Remove, completely obsolete.
2948 * Makefile.am (EXTRA_DIST): Adjust.
2949 Don't distribute config.rpath...
2950 * config/Makefile.am (EXTRA_DIST): Do it.
2951
db85e524
AD
29522002-05-03 Akim Demaille <akim@epita.fr>
2953
2954 * configure.in (GETTEXT_VERSION): New.
2955 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2956
83ccf991
AD
29572002-05-03 Akim Demaille <akim@epita.fr>
2958
2959 * data/bison.simple (b4_token_enum): New.
2960 (b4_token_defines): Use it to output tokens both as #define and
2961 enums.
2962 Suggested by Paul Eggert.
2963 * src/output.c (token_definitions_output): Don't output spurious
2964 white spaces.
2965
1f418995
AD
29662002-05-03 Akim Demaille <akim@epita.fr>
2967
2968 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2969
45119f04
RA
29702002-05-02 Robert Anisko <robert@lrde.epita.fr>
2971
2972 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2973 Update the stack class, give a try to deque as the default container.
2974
b2d52318
AD
29752002-05-02 Akim Demaille <akim@epita.fr>
2976
2977 * data/bison.simple (yyparse): Do not implement @$ = @1.
2978 (YYLLOC_DEFAULT): Adjust to do it.
2979 * doc/bison.texinfo (Location Default Action): Fix.
2980
3a8b4109
AD
29812002-05-02 Akim Demaille <akim@epita.fr>
2982
2983 * src/reader.c (parse_braces): Merge into...
2984 (parse_action): this.
2985
84614e13
AD
29862002-05-02 Akim Demaille <akim@epita.fr>
2987
2988 * configure.in (ALL_LINGUAS): Remove.
2989 * po/LINGUAS, hr.po: New.
2990
fdbcd8e2
AD
29912002-05-02 Akim Demaille <akim@epita.fr>
2992
2993 Remove the so called hairy (semantic) parsers.
2994
2995 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2996 * src/gram.h, src/gram.c (semantic_parser): Remove.
2997 (rule_t): Remove the guard and guard_line members.
2998 * src/lex.h (token_t): remove tok_guard.
2999 * src/options.c (option_table): Remove %guard and %semantic_parser
3000 support.
3001 * src/output.c, src/output.h (guards_output): Remove.
3002 (prepare): Adjust.
3003 (token_definitions_output): Don't output the `T'
3004 tokens (???).
3005 (output_skeleton): Don't output the guards.
3006 * src/files.c, src/files.c (attrsfile): Remove.
3007 * src/reader.c (symbol_list): Remove the guard and guard_line
3008 members.
3009 Adjust dependencies.
3010 (parse_guard): Remove.
3011 * data/bison.hairy: Remove.
3012 * doc/bison.texinfo (Environment Variables): Remove occurrences of
3013 BISON_HAIRY.
3014
82b6cb3f
AD
30152002-05-02 Akim Demaille <akim@epita.fr>
3016
3017 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
3018 (parse_guard): Rename the formal argument `stack_offset' as
3019 `rule_length', which is more readable.
3020 Adjust callers.
3021 (copy_at, copy_dollar): Instead of outputting the hard coded
3022 values of $$, $n and so forth, output invocation to b4_lhs_value,
3023 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
3024 Note: this patch partially drops `semantic-parser' support: it
3025 always does `rule_length - n', where semantic parsers ought to
3026 always use `-n'.
82b6cb3f
AD
3027 * data/bison.simple, data/bison.c++ (b4_lhs_value)
3028 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
3029
6cbfbcc5
AD
30302002-05-02 Akim Demaille <akim@epita.fr>
3031
3032 * configure.in (AC_INIT): Bump to 1.49b.
3033 (AM_INIT_AUTOMAKE): Short invocation.
3034
b8548114
AD
30352002-05-02 Akim Demaille <akim@epita.fr>
3036
3037 Version 1.49a.
3038
c20cd1fa
AD
30392002-05-01 Akim Demaille <akim@epita.fr>
3040
3041 * src/skeleton.h: Remove.
3042
8a9566d4
AD
30432002-05-01 Akim Demaille <akim@epita.fr>
3044
3045 * src/skeleton.h: Fix the #endif.
3046 Reported by Magnus Fromreide.
3047
8c6d399a
PE
30482002-04-26 Paul Eggert <eggert@twinsun.com>
3049
3050 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
3051 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 3052 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 3053
2b7ed18a
RA
30542002-04-25 Robert Anisko <robert@lrde.epita.fr>
3055
3056 * src/scan-skel.l: Postprocess quadrigraphs.
3057
3058 * src/reader.c (copy_character): New function, used to output
3059 single characters while replacing `[' and `]' with quadrigraphs, to
3060 avoid troubles with M4 quotes.
3061 (copy_comment): Output characters with copy_character.
3062 (read_additionnal_code): Likewise.
3063 (copy_string2): Likewise.
3064 (copy_definition): Likewise.
3065
3066 * tests/calc.at: Exercise M4 quoting.
3067
34a89c50
AD
30682002-04-25 Akim Demaille <akim@epita.fr>
3069
3070 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
3071 between `!' and the command.
3072 Reported by Paul Eggert.
3073
0dd1580a
RA
30742002-04-24 Robert Anisko <robert@lrde.epita.fr>
3075
3076 * tests/calc.at: Exercise prologue splitting.
3077
3078 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
3079 `b4_post_prologue' instead of `b4_prologue'.
3080
3081 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
3082 muscles.
3083 (output): Free pre_prologue_obstack and post_prologue_obstack.
3084 * src/files.h, src/files.c (attrs_obstack): Remove.
3085 (pre_prologue_obstack, post_prologue_obstack): New.
3086 * src/reader.c (copy_definition): Add a parameter to specify the
3087 obstack to fill, instead of using attrs_obstack unconditionally.
3088 (read_declarations): Pass pre_prologue_obstack to copy_definition if
3089 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
3090
83c1796f
PE
30912002-04-23 Paul Eggert <eggert@twinsun.com>
3092
3093 * data/bison.simple: Remove unnecessary commentary and white
3094 space differences from 1_29-branch.
3095 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
3096
3097 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
3098 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
3099 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
3100 constructors or destructors.
3101
3102 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
3103
1207eeac
AD
31042002-04-23 Akim Demaille <akim@epita.fr>
3105
3106 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
3107 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
3108 location with columns.
3109 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
3110 All reported by Paul Eggert.
3111
78ab8f67
AD
31122002-04-22 Akim Demaille <akim@epita.fr>
3113
3114 * src/reduce.c (dump_grammar): Move to...
3115 * src/gram.h, src/gram.c (grammar_dump): here.
3116 Be sure to separate long item numbers.
3117 Don't read the members of a rule's prec if its nil.
3118
133c20e2
AD
31192002-04-22 Akim Demaille <akim@epita.fr>
3120
3121 * src/output.c (table_size, table_grow): New.
3122 (MAXTABLE): Remove, replace uses with table_size.
3123 (pack_vector): Instead of dying when the table is too big, grow it.
3124
9515e8a7
AD
31252002-04-22 Akim Demaille <akim@epita.fr>
3126
3127 * data/bison.simple (yyr1): Its type is that of a token number.
3128 * data/bison.c++ (r1_): Likewise.
3129 * tests/regression.at (Web2c Actions): Adjust.
3130
23c5a174
AD
31312002-04-22 Akim Demaille <akim@epita.fr>
3132
3133 * src/reader.c (token_translations_init): 256 is now the default
3134 value for the error token, i.e., it will be assigned another
3135 number if the user assigned 256 to one of her tokens.
3136 (reader): Don't force 256 to error.
3137 * doc/bison.texinfo (Symbols): Adjust.
3138 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
3139 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
3140 etc. instead of 10, 20, 30 (which was used to `jump' over error
3141 (256) and undefined (2)).
3142
5fbb0954
AD
31432002-04-22 Akim Demaille <akim@epita.fr>
3144
3145 Propagate more token_number_t.
3146
3147 * src/gram.h (token_number_as_item_number)
3148 (item_number_as_token_number): New.
3149 * src/output.c (GENERATE_OUTPUT_TABLE): New.
3150 Use it to create output_item_number_table and
3151 output_token_number_table.
3152 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
3153 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
3154 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
3155 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
3156
4f940944
AD
31572002-04-22 Akim Demaille <akim@epita.fr>
3158
3159 * src/output.h, src/output.c (get_lines_number): Remove.
3160
3ded9a63
AD
31612002-04-19 Akim Demaille <akim@epita.fr>
3162
3163 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
3164 as Lex/Flex'.
3165 (Debugging): More details about enabling the debugging features.
3166 (Table of Symbols): Describe $$, $n, @$, and @n.
3167 Suggested by Tim Josling.
3168
e0c471a9
AD
31692002-04-19 Akim Demaille <akim@epita.fr>
3170
3171 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
3172
fecc10cd
AD
31732002-04-10 Akim Demaille <akim@epita.fr>
3174
3175 * src/system.h: Rely on HAVE_LIMITS_H.
3176 Suggested by Paul Eggert.
3177
51dec47b
AD
31782002-04-09 Akim Demaille <akim@epita.fr>
3179
3180 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
3181 full stderr, and strip it according to the bison options, instead
3182 of composing the error message from different bits.
3183 This makes it easier to check for several error messages.
3184 Adjust all the invocations.
3185 Add an invocation exercising the error token.
3186 Add an invocation demonstrating a stupid error message.
3187 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
3188 Adjust the tests.
3189 Error message are for stderr, not stdout.
3190
007a50a4
AD
31912002-04-09 Akim Demaille <akim@epita.fr>
3192
3193 * src/gram.h, src/gram.c (error_token_number): Remove, use
3194 errtoken->number.
3195 * src/reader.c (reader): Don't specify the user token number (2)
3196 for $undefined, as it uselessly prevents using it.
3197 * src/gram.h (token_number_t): Move to...
3198 * src/symtab.h: here.
3199 (state_t.number): Is a token_number_t.
3200 * src/print.c, src/reader.c: Use undeftoken->number instead of
3201 hard coded 2.
3202 (Even though this 2 is not the same as above: the number of the
3203 undeftoken remains being 2, it is its user token number which
3204 might not be 2).
3205 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
3206 `user_token_number_max'.
3207 Output `undef_token_number'.
3208 * data/bison.simple, data/bison.c++: Use them.
3209 Be sure to map invalid yylex return values to
3210 `undef_token_number'. This saves us from gratuitous SEGV.
3211
3212 * tests/conflicts.at (Solved SR Conflicts)
3213 (Unresolved SR Conflicts): Adjust.
3214 * tests/regression.at (Web2c Actions): Adjust.
3215
06446ccf
AD
32162002-04-08 Akim Demaille <akim@epita.fr>
3217
3218 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
3219 Adding #line.
3220 Remove the duplicate `typedefs'.
3221 (RhsNumberType): Fix the declaration and various other typos.
3222 Use __ofile__.
3223 * data/bison.simple: Use __ofile__.
3224 * src/scan-skel.l: Handle __ofile__.
3225
62a3e4f0
AD
32262002-04-08 Akim Demaille <akim@epita.fr>
3227
3228 * src/gram.h (item_number_t): New, the type of item numbers in
3229 RITEM. Note that it must be able to code symbol numbers as
3230 positive number, and the negation of rule numbers as negative
3231 numbers.
3232 Adjust all dependencies (pretty many).
3233 * src/reduce.c (rule): Remove this `short *' pointer: use
3234 item_number_t.
3235 * src/system.h (MINSHORT, MAXSHORT): Remove.
3236 Include `limits.h'.
3237 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
3238 (shortcpy): Remove.
3239 (MAXTABLE): Move to...
3240 * src/output.c (MAXTABLE): here.
3241 (prepare_rules): Use output_int_table to output rhs.
3242 * data/bison.simple, data/bison.c++: Adjust.
3243 * tests/torture.at (Big triangle): Move the limit from 254 to
3244 500.
3245 * tests/regression.at (Web2c Actions): Ajust.
3246
3247 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
3248 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
3249 passes, but produces negative #line number, once fixed, GCC is
3250 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
3251 C), it passes.
3252 * src/state.h (state_h): Code input lines on ints, not shorts.
3253
bb88b0fc
AD
32542002-04-08 Akim Demaille <akim@epita.fr>
3255
3256 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
3257 and then the grammar.
3258
9a636f47
AD
32592002-04-08 Akim Demaille <akim@epita.fr>
3260
3261 * src/system.h: No longer using strndup.
3262
680e8701
AD
32632002-04-07 Akim Demaille <akim@epita.fr>
3264
3265 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
3266 * src/output.c (output_table_data): Return the longest number.
3267 (prepare_tokens): Output `token_number_max').
3268 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
3269 New.
3270 Use them to define yy_token_number_type/TokenNumberType.
3271 Use this type for yytranslate.
3272 * tests/torture.at (Big triangle): Push the limit from 124 to
3273 253.
3274 * tests/regression.at (Web2c Actions): Adjust.
3275
817e9f41
AD
32762002-04-07 Akim Demaille <akim@epita.fr>
3277
3278 * tests/torture.at (Big triangle): New.
3279 (GNU AWK Grammar, GNU Cim Grammar): Move to...
3280 * tests/existing.at: here.
3281
5123689b
AD
32822002-04-07 Akim Demaille <akim@epita.fr>
3283
3284 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
3285 nritems.
3286 Adjust dependencies.
3287
f3849179
AD
32882002-04-07 Akim Demaille <akim@epita.fr>
3289
3290 * src/reader.c: Normalize increments to prefix form.
3291
bd02036a
AD
32922002-04-07 Akim Demaille <akim@epita.fr>
3293
3294 * src/reader.c, symtab.c: Remove debugging code.
3295
db8837cb
AD
32962002-04-07 Akim Demaille <akim@epita.fr>
3297
3298 Rename all the `bucket's as `symbol_t'.
3299
3300 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
3301 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
3302 * src/symtab.c, src/symtab.h (bucket): Rename as...
3303 (symbol_t): this.
3304 (symbol_list_new, bucket_check_defined, bucket_make_alias)
3305 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
3306 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3307 (buckets_new, buckets_free, buckets_do): Rename as...
3308 (symbol_list_new, symbol_check_defined, symbol_make_alias)
3309 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3310 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
3311 (symbols_new, symbols_free, symbols_do): these.
3312
72a23c97
AD
33132002-04-07 Akim Demaille <akim@epita.fr>
3314
3315 Use lib/hash for the symbol table.
3316
3317 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
3318 EOF.
3319 * src/lex.c (lex): Set the `number' member of new terminals.
3320 * src/reader.c (bucket_check_defined, bucket_make_alias)
3321 (bucket_check_alias_consistence, bucket_translation): New.
3322 (reader, grammar_free, readgram, token_translations_init)
3323 (packsymbols): Adjust.
3324 (reader): Number the predefined tokens.
3325 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3326 for predefined tokens.
3327 * src/symtab.h (bucket): Remove all the hash table related
3328 members.
3329 * src/symtab.c (symtab): Replace by...
3330 (bucket_table): this.
3331 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3332 (buckets_new, buckets_do): New.
3333
280a38c3
AD
33342002-04-07 Akim Demaille <akim@epita.fr>
3335
3336 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3337 (start_symbol, max_user_token_number, semantic_parser)
3338 (error_token_number): Initialize.
3339 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3340 Initialize.
3341 (reader): Don't.
3342 (errtoken, eoftoken, undeftoken, axiom): Extern.
3343
03b31c0c
AD
33442002-04-07 Akim Demaille <akim@epita.fr>
3345
3346 * src/gram.h (rule_s): prec and precsym are now pointers
3347 to the bucket giving the priority/associativity.
3348 Member `associativity' removed: useless.
3349 * src/reduce.c, src/conflicts.c: Adjust.
3350
8b3df748
AD
33512002-04-07 Akim Demaille <akim@epita.fr>
3352
3353 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3354 Properly escape the symbols' TAG when outputting them.
3355
e601aa1d
AD
33562002-04-07 Akim Demaille <akim@epita.fr>
3357
3358 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3359
b0299a2e
AD
33602002-04-07 Akim Demaille <akim@epita.fr>
3361
3362 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3363 (LArule): this, which is an array to rule_t*.
3364 * src/print.c, src/conflicts.c: Adjust.
3365
d7e1f00c
AD
33662002-04-07 Akim Demaille <akim@epita.fr>
3367
3368 * src/gram.h (rule_t): Rename `number' as `user_number'.
3369 `number' is a new member.
3370 Adjust dependencies.
3371 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3372
cc9305dd
AD
33732002-04-07 Akim Demaille <akim@epita.fr>
3374
3375 As a result of the previous patch, it is no longer needed
3376 to reorder ritem itself.
3377
3378 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3379
b0940840
AD
33802002-04-07 Akim Demaille <akim@epita.fr>
3381
3382 Be sure never to walk through RITEMS, but use only data related to
3383 the rules themselves. RITEMS should be banished.
3384
3385 * src/output.c (output_token_translations): Rename as...
3386 (prepare_tokens): this.
3387 In addition to `translate', prepare the muscles `tname' and
3388 `toknum', which were handled by...
3389 (output_rule_data): this.
3390 Remove, and move the remainder of its outputs into...
3391 (prepare_rules): this new routines, which also merges content from
3392 (output_gram): this.
3393 (prepare_rules): Be sure never to walk through RITEMS.
3394 (output_stos): Rename as...
3395 (prepare_stos): this.
3396 (output): Always invoke prepare_states, after all, just don't use it
3397 in the output if you don't need it.
3398
643a5994
AD
33992002-04-07 Akim Demaille <akim@epita.fr>
3400
3401 * src/LR0.c (new_state): Display `nstates' as the name of the
3402 newly created state.
3403 Adjust to initialize first_state and last_state if needed.
3404 Be sure to distinguish the initial from the final state.
3405 (new_states): Create the itemset of the initial state, and use
3406 new_state.
3407 * src/closure.c (closure): Now that the initial state has its
3408 items properly set, there is no need for a special case when
3409 creating `ruleset'.
3410
3411 As a result, now the rule 0, reducing to $axiom, is visible in the
3412 outputs. Adjust the test suite.
3413
3414 * tests/conflicts.at (Solved SR Conflicts)
3415 (Unresolved SR Conflicts): Adjust.
3416 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3417 * tests/conflicts.at (S/R in initial): New.
3418
b4c4ccc2
AD
34192002-04-07 Akim Demaille <akim@epita.fr>
3420
3421 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3422 the RHS of the rules.
3423 * src/output.c (output_gram): Likewise.
3424
bba97eb2
AD
34252002-04-07 Akim Demaille <akim@epita.fr>
3426
3427 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3428 bucket.
3429 Adjust all dependencies.
3430 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3431 `number' of the buckets too.
3432 * src/gram.h: Include `symtab.h'.
3433 (associativity): Move to...
3434 * src/symtab.h: here.
3435 No longer include `gram.h'.
3436
c3b407f4
AD
34372002-04-07 Akim Demaille <akim@epita.fr>
3438
3439 * src/gram.h, src/gram.c (rules_rhs_length): New.
3440 (ritem_longest_rhs): Use it.
3441 * src/gram.h (rule_t): `number' is a new member.
3442 * src/reader.c (packgram): Set it.
3443 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3444 the end of `rules', and count them out of `nrules'.
3445 (reduce_output, dump_grammar): Adjust.
3446 * src/print.c (print_grammar): It is no longer needed to check for
3447 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3448 * tests/reduce.at (Reduced Automaton): New test.
3449
11652ab3
AD
34502002-04-07 Akim Demaille <akim@epita.fr>
3451
3452 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3453 lacking `+ 1' to nrules, Bison reported as useless a token if it
3454 was used solely to set the precedence of the last rule...
3455
26b23c1a
AD
34562002-04-07 Akim Demaille <akim@epita.fr>
3457
3458 * data/bison.c++, data/bison.simple: Don't output the current file
3459 name in #line, to avoid useless diffs between two identical
3460 outputs under different names.
3461
18bcecb0
AD
34622002-04-07 Akim Demaille <akim@epita.fr>
3463
3464 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3465 Normalize loops to using `< nrules + 1', not `<= nrules'.
3466
fa770c86
AD
34672002-04-07 Akim Demaille <akim@epita.fr>
3468
3469 * TODO: Update.
3470
d9b739c3
AD
34712002-04-07 Akim Demaille <akim@epita.fr>
3472
3473 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3474 bucket.value as bucket.number.
3475
99013900
AD
34762002-04-07 Akim Demaille <akim@epita.fr>
3477
3478 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3479 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3480 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3481 RHS, instead of being an index in RITEMS.
3482
e966383b
PE
34832002-04-04 Paul Eggert <eggert@twinsun.com>
3484
3485 * doc/bison.texinfo: Update copyright date.
3486 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3487 (Symbols): Warn about running Bison in one character set,
3488 but compiling and/or running in an incompatible one.
3489 Warn about character code 256, too.
3490
34912002-04-03 Paul Eggert <eggert@twinsun.com>
3492
3493 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3494 YYERROR_VERBOSE is nonzero, not whether it is defined.
3495
3496 Merge changes from bison-1_29-branch.
c307773e 3497
8d6c48b9
PE
34982002-03-20 Paul Eggert <eggert@twinsun.com>
3499
3500 Merge fixes from Debian bison_1.34-1.diff.
3501
3502 * configure.in (AC_PREREQ): 2.53.
3503
e53c6322
AD
35042002-03-20 Akim Demaille <akim@epita.fr>
3505
3506 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3507
9ffbeca7
PE
35082002-03-19 Paul Eggert <eggert@twinsun.com>
3509
21db0b2a
PE
3510 * src/bison.simple (YYCOPY): New macro.
3511 (YYSTACK_RELOCATE): Use it.
3512 Remove Type arg; no longer needed. All callers changed.
3513 (yymemcpy): Remove; no longer needed.
3514
9ffbeca7
PE
3515 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3516 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3517
642cb8f8
AD
35182002-03-19 Akim Demaille <akim@epita.fr>
3519
3520 Test and fix the #line outputs.
3521
3522 * tests/atlocal.at (GCC): New.
3523 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3524 (Prologue synch line, ,%union synch line, Postprologue synch line)
3525 (Action synch line, Epilogue synch line): New tests.
3526 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3527 * data/bison.simple, data/bison.c++: Use it.
3528
3c31a486
AD
35292002-03-19 Akim Demaille <akim@epita.fr>
3530
3531 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3532 (Solved SR Conflicts, %expect not enough, %expect right)
3533 (%expect too much): Move to...
3534 * tests/conflicts.at: this new file.
3535
0d8bed56
AD
35362002-03-19 Akim Demaille <akim@epita.fr>
3537
3538 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3539 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3540 that we can move to enums for instance.
3541 * src/output.c (token_definitions_output): Output a list of
3542 `token-name, token-number' instead of the #define.
3543 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3544
9208d17f
AD
35452002-03-14 Akim Demaille <akim@epita.fr>
3546
3547 Use Gettext 0.11.1.
3548
af27eacb
RA
35492002-03-09 Robert Anisko <robert@lrde.epita.fr>
3550
3551 * data/bison.c++: Make the user able to add members to the generated
3552 parser by subclassing.
3553
9101a310
RA
35542002-03-05 Robert Anisko <robert@lrde.epita.fr>
3555
3556 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3557 a character.
3558 Reported by Nicolas Tisserand and Nicolas Burrus.
3559
fff9bf0b
RA
35602002-03-04 Robert Anisko <robert@lrde.epita.fr>
3561
3562 * src/reader.c: Warn about lacking semi-colons, do not complain.
3563
64dba31e
RA
35642002-03-04 Robert Anisko <robert@lrde.epita.fr>
3565
3566 * data/bison.c++: Remove a debug line.
3567
374f5a14
RA
35682002-03-04 Robert Anisko <robert@lrde.epita.fr>
3569
3570 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
3571 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
3572 provide a default implementation.
3573
bfcf1f3a
AD
35742002-03-04 Akim Demaille <akim@epita.fr>
3575
3576 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
3577 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
3578 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
3579 * tests/semantic.at (Parsing Guards): Similarly.
3580 * src/reader.at (readgram): Complain if the last rule is not ended
3581 with a semi-colon.
3582
65ccf9fc
AD
35832002-03-04 Akim Demaille <akim@epita.fr>
3584
3585 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
3586 * src/closure.c: here.
3587 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
3588 RTC.
3589 * src/warshall.h, src/warshall.c: Remove.
3590 * tests/sets.at (Broken Closure): Adjust.
3591
d0039cbc
AD
35922002-03-04 Akim Demaille <akim@epita.fr>
3593
3594 * src/output.c (output_skeleton): tempdir is const.
3595 bytes_read is unused.
3596
345cea78
AD
35972002-03-04 Akim Demaille <akim@epita.fr>
3598
3599 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3600 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
3601 Update.
3602 From Michael Hayes.
3603
564801f7
AD
36042002-03-04 Akim Demaille <akim@epita.fr>
3605
3606 * src/closure.c (closure): `r' is unused.
3607
e5352bc7
AD
36082002-03-04 Akim Demaille <akim@epita.fr>
3609
3610 * tests/sets.at (Broken Closure): Add the ending `;'.
3611 * src/reader.at (readgram): Complain if a rule is not ended with a
3612 semi-colon.
3613
914feea9
AD
36142002-03-04 Akim Demaille <akim@epita.fr>
3615
3616 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
3617 (count_sr_conflicts): Use bitset_count.
3618 * src/reduce.c (inaccessable_symbols): Ditto.
3619 (bits_size): Remove.
3620 * src/warshall.h, src/warshall.c: Convert to bitsetv.
3621
f0250de6
AD
36222002-03-04 Akim Demaille <akim@epita.fr>
3623
3624 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
3625 * src/reduce.c: Remove the `bitset_zero's following the
3626 `bitset_create's, as now it is performed by the latter.
3627
ef017502
AD
36282002-03-04 Akim Demaille <akim@epita.fr>
3629
3630 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
3631 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
3632 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
3633 latest sources from Michael.
3634
76514394
AD
36352002-03-04 Akim Demaille <akim@epita.fr>
3636
3637 * src/output.c (output): Don't free the grammar.
3638 * src/reader.c (grammar_free): New.
3639 * src/main.c (main): Call it and don't free symtab here.
3640
55024580
AD
36412002-03-04 Akim Demaille <akim@epita.fr>
3642
3643 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
3644 before returning.
3645 Reported by Benoit Perrot.
3646
f9abaa2c
AD
36472002-03-04 Akim Demaille <akim@epita.fr>
3648
3649 Use bitset operations when possible, not loops over bits.
3650
3651 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
3652 bitset_or.
3653 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
3654 * src/reduce.c (useless_nonterminals): Formatting changes.
3655 * src/warshall.c (TC): Use bitset_or.
3656
0e721e75
AD
36572002-03-04 Akim Demaille <akim@epita.fr>
3658
3659 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
3660 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
3661 Ditto.
3662
0fb1ffb1
AD
36632002-03-04 Akim Demaille <akim@epita.fr>
3664
3665 * src/lalr.c (F): Now a bitset*.
3666 Adjust all dependencies.
3667
b86796bf
AD
36682002-03-04 Akim Demaille <akim@epita.fr>
3669
3670 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
3671 Adjust all dependencies.
3672
602bbf31
AD
36732002-03-04 Akim Demaille <akim@epita.fr>
3674
3675 * src/L0.c, src/LR0.h (nstates): Be size_t.
3676 Adjust comparisons (signed vs unsigned).
3677 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
3678 bitset*.
3679 Adjust all dependencies.
3680
d8a0245c
AD
36812002-03-04 Akim Demaille <akim@epita.fr>
3682
3683 * src/closure.c (firsts): Now, also a bitset.
3684 Adjust all dependencies.
3685 (varsetsize): Remove, now unused.
3686 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
3687
34ba9743
AD
36882002-03-04 Akim Demaille <akim@epita.fr>
3689
3690 * src/print.c: Convert to use bitset.h, not hand coded iterations
3691 over ints.
3692
ed86e78c
AD
36932002-03-04 Akim Demaille <akim@epita.fr>
3694
3695 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
3696
dfdb1797
AD
36972002-03-04 Akim Demaille <akim@epita.fr>
3698
3699 * src/closure.c (ruleset): Be a bitset.
3700 (rulesetsize): Remove.
3701
7086e707
AD
37022002-03-04 Akim Demaille <akim@epita.fr>
3703
3704 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3705 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
3706 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
3707 * src/closure.c (fderives): Be an array of bitsets.
3708
98254360
RA
37092002-02-28 Robert Anisko <robert@lrde.epita.fr>
3710
3711 * data/bison.c++: Merge the two generated headers. Insert a copyright
3712 notice in each output file.
3713
a75c057f
AD
37142002-02-28 Akim Demaille <akim@epita.fr>
3715
3716 * data/bison.c++: Copy the prologue of bison.simple to fetch
3717 useful M4 definitions, such as b4_header_guard.
3718
06b00abc
AD
37192002-02-25 Akim Demaille <akim@epita.fr>
3720
3721 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
3722 translator friendly scheme for the bgr
3723 copyright notice.
06b00abc 3724
70e7d534
AD
37252002-02-25 Akim Demaille <akim@epita.fr>
3726
3727 * src/output.c (header_output): Remove, now handled completely via
3728 M4.
3729
abe017f6
AD
37302002-02-25 Akim Demaille <akim@epita.fr>
3731
3732 * m4/m4.m4: New, from CVS Autoconf.
3733 * configure.in: Invoke it.
3734 * src/output.c (output_skeleton): Use its result instead of the
3735 hard coded name.
3736
381fb12e
AD
37372002-02-25 Akim Demaille <akim@epita.fr>
3738
3739 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3740 Fileutils 4.1.5.
3741 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3742 * src/output.c (output_skeleton): Use mkstemp to create a real
3743 temporary file.
3744 Move the filling of `skeleton' and its muscle to...
3745 (prepare): here.
3746 (output): Move the definition of the prologue muscle to...
3747 (prepare): here.
3748 * src/system.h (DEFAULT_TMPDIR): New.
3749
6f38107f
PE
37502002-02-14 Paul Eggert <eggert@twinsun.com>
3751
3752 Remove the support for C++ namespace cleanliness; it was
3753 causing more problems than it was curing, since it didn't work
3754 properly on some nonstandard C++ compilers. This can wait
3755 for a proper C++ parser.
3756
3757 * NEWS: Document this.
3758 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3759 of C++, as it's treated like C now.
3760 * src/bison.simple (YYSTD): Remove.
3761 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3762 Treat C++ just like Standard C instead of trying to support
3763 namespace cleanliness.
3764
80cce3da
AD
37652002-02-14 Akim Demaille <akim@epita.fr>
3766
3767 * tests/regression.at (else): Adjust to Andreas' change.
3768
842e8679
AD
37692002-02-14 Akim Demaille <akim@epita.fr>
3770
3771 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3772
4bda3f10
AD
37732002-02-13 Andreas Schwab <schwab@suse.de>
3774
3775 * src/output.c (output_rule_data): Don't output NULL, it might
3776 not be defined yet.
3777
4162fa07 37782002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 3779
4162fa07
RA
3780 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3781 (Copyright notice): Update.
b418ecd8 3782
bd16a5dc
AD
37832002-02-11 Akim Demaille <akim@epita.fr>
3784
3785 * tests/regression.at (%nonassoc and eof): Don't include
3786 nonportable headers.
3787
8d69a1a3
RA
37882002-02-08 Robert Anisko <robert@lrde.epita.fr>
3789
3790 * data/bison.c++: Correct error recovery. Make the user able to
3791 initialize the starting location.
3792
9b2d0677
AD
37932002-02-07 Akim Demaille <akim@epita.fr>
3794
3795 * tests/input.at: New.
3796
69e2658b
RA
37972002-02-07 Robert Anisko <robert@lrde.epita.fr>
3798
3799 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 3800 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
3801 directives around tables only needed for debugging.
3802
4aacc3a7
RA
38032002-02-07 Robert Anisko <robert@lrde.epita.fr>
3804
3805 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3806 C++ parsers.
3807 (yy::b4_name::parse): Use print_.
3808
762a801e
RA
38092002-02-07 Robert Anisko <robert@lrde.epita.fr>
3810
3811 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3812
4bb2bc3f
RA
38132002-02-07 Robert Anisko <robert@lrde.epita.fr>
3814
3815 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3816 C++ parsers.
3817 (yy::b4_name::parse): Build verbose error messages, and use error_.
3818
6b45a3ca
RA
38192002-02-06 Robert Anisko <robert@lrde.epita.fr>
3820
3821 * data/bison.c++: Fix m4 quoting in comments.
3822
50997c6e
RA
38232002-02-06 Robert Anisko <robert@lrde.epita.fr>
3824
3825 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3826 not expanded by m4.
3827
3f3eed27
AD
38282002-02-05 Akim Demaille <akim@epita.fr>
3829
3830 * data/bison.c++: Adjust to the M4 back end.
3831 More is certainly needed.
3832
be2a1a68
AD
38332002-02-05 Akim Demaille <akim@epita.fr>
3834
3835 Give a try to M4 as a back end.
3836
3837 * lib/readpipe.c: New, from wdiff.
3838 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3839 BISON_HAIRY.
3840 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3841 specific values. Now it is m4 that performs the lookup.
3842 * src/parse-skel.y: Remove.
3843 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3844 * src/output.c (actions_output, guards_output)
3845 (token_definitions_output): No longer keeps track of the output
3846 line number, hence remove the second argument.
3847 (guards_output): Check against the guard member of a rule, not the
3848 action member.
3849 Adjust callers.
3850 (output_skeleton): Don't look for the skeleton location, let m4 do
3851 that.
3852 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3853 file will be used.
3854 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3855 (prepare): Given that for the time being changesyntax is not
3856 usable in M4, rename the muscles using `-' to `_'.
3857 Define `defines_flag', `output_parser_name' and `output_header_name'.
3858 * src/output.h (actions_output, guards_output)
3859 (token_definitions_output): Adjust prototypes.
3860 * src/scan-skel.l: Instead of scanning the skeletons, it now
3861 processes the output of m4: `__oline__' and `#output'.
3862 * data/bison.simple: Adjust to be used by M4(sugar).
3863 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3864 to date.
3865 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3866 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3867 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3868 shamelessly stolen from CVS Autoconf.
3869
beda758b
AD
38702002-02-05 Akim Demaille <akim@epita.fr>
3871
3872 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3873 * configure.in: Check for the declarations of free and malloc.
3874 * src/muscle_tab.c: Adjust.
3875
5ece6d43
AD
38762002-02-05 Akim Demaille <akim@epita.fr>
3877
3878 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3879 which have no values.
3880
5bb18f9a
AD
38812002-02-05 Akim Demaille <akim@epita.fr>
3882
3883 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3884 * data/: here.
3885
894dd62e
PE
38862002-01-29 Paul Eggert <eggert@twinsun.com>
3887
3888 * src/bison.simple (YYSIZE_T): Do not define merely because
3889 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3890 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3891
82841af7
AD
38922002-01-27 Akim Demaille <akim@epita.fr>
3893
3894 Fix `%nonassoc and eof'.
3895
3896 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3897 which were not properly copied! Replace
3898 memcpy (res->errs, src->errs, src->nerrs);
3899 with
3900 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3901 !!!
3902 * tests/regression.at (%nonassoc and eof): Adjust to newest
3903 Autotest: `.' is not in the PATH.
3904
318b76e9
AD
39052002-01-27 Akim Demaille <akim@epita.fr>
3906
3907 * tests/sets.at (AT_EXTRACT_SETS): New.
3908 (Nullable): Use it.
3909 (Firsts): New.
3910
30d2f3d5
AD
39112002-01-26 Akim Demaille <akim@epita.fr>
3912
3913 * tests/actions.at, tests/calc.at, tests/headers.at,
3914 * tests/torture.at: Adjust to the newest Autotest which no longer
3915 forces `.' in the PATH.
3916
30f8c395
AD
39172002-01-25 Akim Demaille <akim@epita.fr>
3918
3919 * tests/regression.at (%nonassoc and eof): New.
3920 Suggested by Robert Anisko.
3921
29ae55f1
AD
39222002-01-24 Akim Demaille <akim@epita.fr>
3923
3924 Bison dumps core when trying to complain about broken input files.
3925 Reported by Cris van Pelt.
3926
3927 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3928 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3929 into...
3930 (Invalid inputs): Strengthen: exercise parse_percent_token.
3931
2b548aa6
RA
39322002-01-24 Robert Anisko <robert.anisko@epita.fr>
3933
3934 * src/Makefile.am: Add bison.c++.
3935 * src/bison.c++: New skeleton.
3936
bb0146c2
AD
39372002-01-21 Paolo Bonzini <bonzini@gnu.org>
3938
3939 * po/it.po: New.
3940
bec30531
AD
39412002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3942
3943 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3944
fc6edc45
MA
39452002-01-20 Marc Autret <marc@gnu.org>
3946
3947 * src/files.c (compute_output_file_names): Fix
3948
5e5d5415
MA
39492002-01-20 Marc Autret <marc@gnu.org>
3950
3951 * tests/output.at: New test.
3952 * src/files.c (compute_base_names): Don't map extensions when
3953 the YACC flag is set, use defaults.
3954 Reported by Evgeny Stambulchik.
3955
44ea3fbd
MA
39562002-01-20 Marc Autret <marc@gnu.org>
3957
bb0146c2 3958 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
3959 compilers as well (i.e. the vendor C compiler).
3960 Suggested by Albert Chin-A-Young.
3961
338963d1
TVH
39622002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3963
3964 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3965 canonical definition.
3966 * src/system.h: Use the canonical definition for PARAMS (avoids
3967 a conflict with the macro from lib/hash.h).
3968
c57b2479
AD
39692002-01-11 Akim Demaille <akim@epita.fr>
3970
3971 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 3972 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 3973
b85810ae
AD
39742002-01-09 Akim Demaille <akim@epita.fr>
3975
3976 * src/files.c, src/files.h (output_infix): New.
3977 (tab_extension): Remove.
3978 (compute_base_names): Compute the former, drop the latter.
3979 * src/output.c (prepare): Insert the muscles `output-infix', and
3980 `output-suffix'.
3981 * src/parse-skel.y (string, string.1): New.
3982 (section.header): Use it.
3983 (section.yacc): Remove.
3984 (prefix): Remove too.
3985 * src/scan-skel.l: Adjust.
3986 * src/bison.simple, src/bison.hairy: Adjust.
3987
cae60122
AD
39882002-01-09 Akim Demaille <akim@epita.fr>
3989
3990 * configure.in (WERROR_CFLAGS): Compute it.
3991 * src/Makefile.am (CFLAGS): Pass it.
3992 * tests/atlocal.in (CFLAGS): Idem.
3993 * src/files.c: Fix a few warnings.
3994 (get_extension_index): Remove, unused.
3995
ae404801
AD
39962002-01-08 Akim Demaille <akim@epita.fr>
3997
3998 * src/getargs.c (AS_FILE_NAME): New.
3999 (getargs): Use it to convert DOSish file names.
4000 * src/files.c (base_name): Rename as full_base_name to avoid
4001 clashes with `base_name ()'.
4002 (filename_split): New.
4003 (compute_base_names): N-th rewrite, using filename_split.
4004
22312b71
AD
40052002-01-08 Akim Demaille <akim@epita.fr>
4006
4007 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
4008 New, stolen from the Fileutils 4.1.
4009 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
4010 * configure.in: Check for the presence of memrchr, and of its
4011 prototype.
4012
a67cef01
TVH
40132002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
4014
4015 * lib/hash.h (__P): Added definition for this macro.
4016 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
4017 BUILT_SOURCES, to ensure they are generated first.
4018 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
4019 %error-verbose to allow bootstrapping with bison 1.30x.
4020
2b25d624
AD
40212002-01-06 Akim Demaille <akim@epita.fr>
4022
4023 * src/reader.c (parse_braces): Don't fetch the next char, the
4024 convention is to fetch on entry.
4025 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
4026 'switch' without a following semicolon.
4027 * tests/regression.at (braces parsing): New.
4028
3460813b
AD
40292002-01-06 Akim Demaille <akim@epita.fr>
4030
4031 Bison is dead wrong in its RR conflict reports.
4032
4033 * tests/torture.at (GNU Cim Grammar): New.
4034 * src/conflicts.c (count_rr_conflicts): Fix.
4035
73784c64
AD
40362002-01-06 Akim Demaille <akim@epita.fr>
4037
4038 Creating package.m4 from configure.ac causes too many problems.
4039
4040 * tests/Makefile.am (package.m4): Create it by hand,
4041 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
4042
25d81090
AD
40432002-01-06 Akim Demaille <akim@epita.fr>
4044
4045 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
4046 skeleton.h.
4047
a9b8959e
PE
40482002-01-04 Paul Eggert <eggert@twinsun.com>
4049
4050 * doc/bison.texinfo (Debugging):
4051 Remove YYSTDERR; it's no longer defined or used.
4052 Also, s/cstdio.h/cstdio/.
4053
25d81090
AD
40542002-01-03 Akim Demaille <akim@epita.fr>
4055
4056 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
4057
1109455c
AD
40582002-01-03 Akim Demaille <akim@epita.fr>
4059
4060 * src/parse-skel.y (process_skeleton): Don't bind the parser's
4061 tracing code to --trace, wait for a better --trace option, with
4062 args.
4063
7ea5e977
AD
40642002-01-03 Akim Demaille <akim@epita.fr>
4065
4066 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
4067 The ISO C++ standard is extremely clear about it: stderr is
4068 considered a macro, not a regular symbol (see table 94 `Header
4069 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
4070 Therefore std:: does not apply to it. It still does with fprintf.
4071 Also, s/cstdio.h/cstdio/.
4072
fab5b110
AD
40732002-01-03 Akim Demaille <akim@epita.fr>
4074
4075 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
4076 for non system headers.
4077
aed7fd9b
AD
40782002-01-02 Akim Demaille <akim@epita.fr>
4079
4080 Equip the skeleton chain with location tracking, runtime trace,
4081 pure parser and scanner.
4082
4083 * src/parse-skel.y: Request a pure parser, locations, and prefix
4084 renaming.
4085 (%union): Having several members with the same type does not help
4086 type mismatches, simplify.
4087 (YYPRINT, yyprint): New.
4088 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
4089 (skel_error): this.
4090 Handle locations.
4091 * src/scan-skel.l: Adjust to these changes.
4092 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
4093 (LOCATION_PRINT, skel_control_t): New.
4094
24fad99e
AD
40952001-12-30 Akim Demaille <akim@epita.fr>
4096
4097 * src/parse-skel.y: Get rid of the shift/reduce conflict:
4098 replace `gb' with BLANKS.
4099 * src/scan-skel.l: Adjust.
4100
a4b36db4
AD
41012001-12-30 Akim Demaille <akim@epita.fr>
4102
4103 * src/system.h: We don't need nor want bcopy.
4104 Throw away MS-DOS crap: we don't need getpid.
4105 * configure.in: We don't need strndup. It was even causing
4106 problems: because Flex includes the headers *before* us,
4107 _GNU_SOURCE is not defined by config.h, and therefore strndup was
4108 not visible.
4109 * lib/xstrndup.c: New.
4110 * src/scan-skel.l: Use it.
4111 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
4112 * src/parse-skel.y: Use %directives instead of #defines.
4113
1239777d
AD
41142001-12-30 Akim Demaille <akim@epita.fr>
4115
4116 * src/skeleton.h: New.
4117 * src/output.c (output_parser, output_master_parser): Remove, dead
4118 code.
4119 * src/output.h (get_lines_number, actions_output, guards_output)
4120 (token_definitions_output): Prototype them.
4121 * src/parse-skel.y: Add the license notice.
4122 Include output.h and skeleton.h.
4123 (process_skeleton): Returns void, and takes a single parameter.
4124 * src/scan-skel.l: Add the license notice.
4125 Include skeleton.h.
4126 Don't use %option yylineno: it seems that then Flex imagines
4127 REJECT has been used, and therefore it won't reallocate its
4128 buffers (which makes no other sense to me than a bug). It results
4129 in warnings for `unused: yy_flex_realloc'.
4130
9b3add5b
RA
41312001-12-30 Robert Anisko <robert.anisko@epita.fr>
4132
4133 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4134 (MUSCLE_INSERT_PREFIX): ...to there.
4135 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
4136 (MUSCLE_INSERT_PREFIX): Move from here...
4137
4138 * src/bison.hairy: Add a section directive. Put braces around muscle
4139 names. This parser skeleton is still broken, but Bison should not
4140 choke on a bad muscle 'syntax'.
4141 * src/bison.simple: Add a section directive. Put braces around muscle
4142 names.
4143
4144 * src/files.h (strsuffix, stringappend): Add declarations.
4145 (tab_extension): Add declaration.
4146 (short_base_name): Add declaration.
4147
4148 * src/files.c (strsuffix, stringappend): No longer static. These
4149 functions are used in the skeleton parser.
4150 (tab_extension): New.
4151 (compute_base_names): Use the computations done in this function
fab5b110 4152 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
4153 names.
4154 (short_base_name): No longer static.
4155
4156 * src/output.c (output_skeleton): New.
4157 (output): Disable call to output_master_parser, and give a try to
4158 a new skeleton handling system.
4159 (guards_output, actions_output): No longer static.
4160 (token_definitions_output, get_lines_number): No longer static.
4161
4162 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
4163
fab5b110 4164 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
4165 parse-skel.y.
4166
4167 * src/parse-skel.y: New file.
4168 * src/scan-skel.l: New file.
4169
b5b61c61
AD
41702001-12-29 Akim Demaille <akim@epita.fr>
4171
4172 %name-prefix is broken.
4173
4174 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
4175 Adjust all dependencies.
4176 * tests/headers.at (export YYLTYPE): Strengthen this test: use
4177 %name-prefix.
4178
4179 Renaming yylval but not yylloc is not consistent. Now we do.
4180
4181 * src/bison.simple: Prefix yylloc if used.
4182 * doc/bison.texinfo (Decl Summary): Document that.
4183
8c9a50be
AD
41842001-12-29 Akim Demaille <akim@epita.fr>
4185
4186 * doc/bison.texinfo: Promote `%long-directive' over
4187 `%long_directive'.
4188 Remove all references to fixed-output-files, yacc is enough.
4189
d99361e6
AD
41902001-12-29 Akim Demaille <akim@epita.fr>
4191
4192 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
4193 user prologue. These are defaults.
4194 * tests/actions.at (Mid-rule actions): Make sure the user can
4195 define YYDEBUG and YYERROR_VERBOSE.
4196
b9cecb91
AD
41972001-12-29 Akim Demaille <akim@epita.fr>
4198
4199 * src/output.c (header_output): Don't forget to export YYLTYPE and
4200 yylloc.
4201 * tests/headers.at (export YYLTYPE): New, make sure it does.
4202 * tests/regression.at (%union and --defines, Invalid CPP headers):
4203 Move to...
4204 * tests/headers.at: here.
4205
aea13e97
AD
42062001-12-29 Akim Demaille <akim@epita.fr>
4207
4208 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
4209
931394cb
AD
42102001-12-29 Akim Demaille <akim@epita.fr>
4211
4212 * tests/actions.at (Mid-rule actions): Output on a single line
4213 instead of several.
4214
704a47c4
AD
42152001-12-29 Akim Demaille <akim@epita.fr>
4216
4217 * doc/bison.texinfo: Formatting changes.
4218
091e20bb
AD
42192001-12-29 Akim Demaille <akim@epita.fr>
4220
4221 Don't store the token defs in a muscle, just be ready to output it
4222 on command. Now possible via `symbols'. Fixes a memory leak.
4223
4224 * src/output.c (token_definitions_output): New.
4225 (output_parser, header_output): Use it.
4226 * src/reader.c (symbols_save): Remove.
4227
cce71710
AD
42282001-12-29 Akim Demaille <akim@epita.fr>
4229
4230 * src/bison.simple: Do not provide a default for YYSTYPE and
4231 YYLTYPE before the user's prologue. Otherwise it's hardly... a
4232 default.
4233
82c035a8
AD
42342001-12-29 Akim Demaille <akim@epita.fr>
4235
4236 Mid-rule actions are simply... ignored!
4237
4238 * src/reader.c (readgram): Be sure to attach mid-rule actions to
4239 the empty-rule associated to the dummy symbol, not to the host
4240 rule.
4241 * tests/actions.at (Mid-rule actions): New.
4242
8419d367
AD
42432001-12-29 Akim Demaille <akim@epita.fr>
4244
4245 Memory leak.
4246
4247 * src/reader.c (reader): Free grammar.
4248
375d5806
AD
42492001-12-29 Akim Demaille <akim@epita.fr>
4250
4251 Memory leak.
4252
4253 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
4254 since it allocates it for each state, although only one is needed.
4255 (allocate_storage): Do it here.
4256
f51cb8ff
AD
42572001-12-29 Akim Demaille <akim@epita.fr>
4258
4259 * src/options.h, src/options.c (create_long_option_table): Rename
4260 as...
4261 (long_option_table_new): this, with a clearer prototype.
4262 (percent_table): Remove, unused,
4263 * src/getargs.c (getargs): Adjust.
4264
29e88316
AD
42652001-12-29 Akim Demaille <akim@epita.fr>
4266
4267 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
4268 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
4269 as states.
4270
b9f71f19
AD
42712001-12-29 Akim Demaille <akim@epita.fr>
4272
4273 * src/lalr.c (build_relations): Rename `states' as `states1'.
4274 Sorry, I don't understand exactly what it is, no better name...
4275
1a2b5d37
AD
42762001-12-29 Akim Demaille <akim@epita.fr>
4277
4278 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
4279 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
4280 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
4281 as rules.
4282
1cca533e
AD
42832001-12-29 Akim Demaille <akim@epita.fr>
4284
4285 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
4286 ago.
4287
c03ae966
AD
42882001-12-29 Akim Demaille <akim@epita.fr>
4289
4290 * src/reader.c, src/reader.h (user_toknums): Remove.
4291 Adjust all users to use symbols[i]->user_token_number.
4292
5a670b1e
AD
42932001-12-29 Akim Demaille <akim@epita.fr>
4294
4295 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
4296 Adjust all users to use symbols[i]->prec or ->assoc.
4297
ad949da9
AD
42982001-12-29 Akim Demaille <akim@epita.fr>
4299
4300 * src/reader.c, src/reader.h (tags): Remove.
4301 Adjust all users to use symbols[i]->tag.
4302
0e78e603
AD
43032001-12-29 Akim Demaille <akim@epita.fr>
4304
4305 * src/gram.h, src/gram.c (symbols): New, similar to state_table
4306 and rule_table.
4307 * src/reader.c (packsymbols): Fill this table.
4308 Drop sprec.
4309 * src/conflicts.c (resolve_sr_conflict): Adjust.
4310 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
4311 single table.
4312 Use symbols[i]->tag instead of tags[i].
4313
213e640e
AD
43142001-12-29 Akim Demaille <akim@epita.fr>
4315
4316 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
4317 In addition, put a comment in there, to replace...
4318 * tests/regression.at (%union and C comments): Remove.
4319
e7b8bef1
AD
43202001-12-29 Akim Demaille <akim@epita.fr>
4321
4322 * tests/regression.at (Web2c Actions): Blindly move the actual
4323 output as expected output. The contents *seem* right to me, but I
4324 can't pretend reading perfectly parser tables... Nonetheless, all
4325 the other tests pass correctly, the table look OK, even though the
4326 presence of `$axiom' is to be noted: AFAICS it is useless (but
4327 harmless).
4328
b68e7744
AD
43292001-12-29 Akim Demaille <akim@epita.fr>
4330
4331 * src/reader.c (readgram): Don't add the rule 0 if there were no
4332 rules read. In other words, add it _after_ having performed
4333 grammar sanity checks.
4334 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4335
78d5bae9
AD
43362001-12-29 Akim Demaille <akim@epita.fr>
4337
4338 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4339 visible, and some states have now a different number.
4340
ff442794
AD
43412001-12-29 Akim Demaille <akim@epita.fr>
4342
4343 * src/reader.c (readgram): Bind the initial rule's lineno to that
4344 of the first rule.
4345 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4346 (Solved SR Conflicts): Adjust rule 0's line number.
4347
610ab194
AD
43482001-12-29 Akim Demaille <akim@epita.fr>
4349
4350 Fix the `GAWK Grammar' failure.
4351
4352 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4353 the reductions of the first state which was mistakenly confused
4354 with the final state because precisely final_state was initialized
4355 to 0.
4356 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4357 now noticed by Bison.
4358 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4359 have a reduction on $default.
4360
29d29c8f
AD
43612001-12-29 Akim Demaille <akim@epita.fr>
4362
4363 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4364 rule line numbers.
4365 * src/closure.c (print_closure): Likewise.
4366 * src/derives.c (print_derives): Likewise.
4367 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4368 now.
4369
7c6b64d0
AD
43702001-12-29 Akim Demaille <akim@epita.fr>
4371
4372 * src/lalr.c (lookaheads_print): New.
4373 (lalr): Call it when --trace-flag.
4374 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4375 are dumped.
4376
3d4daee3
AD
43772001-12-29 Akim Demaille <akim@epita.fr>
4378
4379 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4380 when walking through ritem, even via rule->rhs.
4381 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4382 (useful_production, useless_nonterminals): Likewise.
4383 (reduce_grammar_tables): Likewise, plus update nritems.
4384 * src/nullable.c (set_nullable): Likewise.
4385 * src/lalr.c (build_relations): Likewise.
4386 * tests/sets.at (Nullable): Adjust.
4387 Fortunately, now, the $axiom is no longer nullable.
4388
9e7f6bbd
AD
43892001-12-29 Akim Demaille <akim@epita.fr>
4390
4391 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4392 the 0-sentinel.
4393 * src/gram.c (ritem_longest_rhs): Likewise.
4394 * src/reduce.c (nonterminals_reduce): Likewise.
4395 * src/print_graph.c (print_graph): Likewise.
4396 * src/output.c (output_rule_data): Likewise.
4397 * src/nullable.c (set_nullable): Likewise.
4398
255ef638
AD
43992001-12-29 Akim Demaille <akim@epita.fr>
4400
4401 * src/output.c: Comment changes.
4402
0d8a7363
AD
44032001-12-27 Paul Eggert <eggert@twinsun.com>
4404
4405 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4406 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4407 Sparc, as they were causing more porting problems than the
4408 (minor) performance improvement was worth.
4409
4410 Also, catch up with 1.31's YYSTD.
4411
3db472b9
AD
44122001-12-27 Akim Demaille <akim@epita.fr>
4413
4414 * src/output.c (output_gram): Rely on nritems, not the
4415 0-sentinel. See below.
4416 Use -1 as separator, not 0.
4417 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4418 Rely on -1 as separator in yyrhs, instead of 0.
4419 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4420 twice `Now at end of input', therefore there are two lines less to
4421 expect.
4422
b365aa05
AD
44232001-12-27 Akim Demaille <akim@epita.fr>
4424
4425 * tests/regression.at (Unresolved SR Conflicts):
4426 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4427 below.
4428
30171f79
AD
44292001-12-27 Akim Demaille <akim@epita.fr>
4430
4431 * src/LR0.c (new_state): Recognize the final state by the fact it
4432 is reached by eoftoken.
4433 (insert_start_shifting_state, insert_eof_shifting_state)
4434 (insert_accepting_state, augment_automaton): Remove, since now
4435 these states are automatically computed from the initial state.
4436 (generate_states): Adjust.
4437 * src/print.c: When reporting a rule number to the user, substract
4438 1, so that the axiom rule is rule 0, and the first user rule is 1.
4439 * src/reduce.c: Likewise.
4440 * src/print_graph.c (print_core): For the time being, just as for
4441 the report, depend upon --trace-flags to dump the full set of
4442 items.
4443 * src/reader.c (readgram): Once the grammar read, insert the rule
4444 0: `$axiom: START-SYMBOL $'.
4445 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4446 number of the states has changed (the final state is no longer
4447 necessarily the last), catch up.
4448
75142d45
AD
44492001-12-27 Akim Demaille <akim@epita.fr>
4450
4451 Try to make the use of the eoftoken valid. Given that its value
4452 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4453 is used instead of > 0 where appropriate, (ii), depend upon nritems
4454 instead of the 0-sentinel.
4455
4456 * src/gram.h, src/gram.c (nritems): New.
4457 Expected to be duplication of nitems, but for the time being...
4458 * src/reader.c (packgram): Assert nritems and nitems are equal.
4459 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4460 * src/closure.c (print_closure, print_fderives): Likewise.
4461 * src/gram.c (ritem_print): Likewise.
4462 * src/print.c (print_core, print_grammar): Likewise.
4463 * src/print_graph.c: Likewise.
4464
b7c49edf
AD
44652001-12-27 Akim Demaille <akim@epita.fr>
4466
4467 * src/main.c (main): If there are complains after grammar
4468 reductions, then output the report anyway if requested, then die.
4469 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4470 * src/reader.c (eoftoken): New.
4471 (parse_token_decl): If the token being defined has value `0', it
4472 is the eoftoken.
4473 (packsymbols): No longer hack `tags' to insert `$' by hand.
4474 Be sure to preserve the value of the eoftoken.
4475 (reader): Make sure eoftoken is defined.
4476 Initialize nsyms to 0: now eoftoken is created just like the others.
4477 * src/print.c (print_grammar): Don't special case the eof token.
4478 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4479 lie anyway, albeit pleasant.
4480 * tests/calc.at: Exercise error messages with eoftoken.
4481 Change the grammar so that empty input is invalid.
4482 Adjust expectations.
4483 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4484
ec2da99f
AD
44852001-12-27 Akim Demaille <akim@epita.fr>
4486
4487 * configure.in: Check the protos of strchr ans strspn.
4488 Replace strchr if needed.
4489 * src/system.h: Provide the protos of strchr, strspn and memchr if
4490 missing.
4491 * lib/strchr.c: New.
4492 * src/reader.c (symbols_save): Use strchr.
4493
8adfa272
AD
44942001-12-27 Akim Demaille <akim@epita.fr>
4495
4496 * src/print.c, src/print_graph.c (escape): New.
4497 Use it to quote the TAGS outputs.
4498 * src/print_graph.c (print_state): Now errors are in red, and
4499 reductions in green.
4500 Prefer high to wide: output the state number on a line of its own.
4501
80dac38c
AD
45022001-12-27 Akim Demaille <akim@epita.fr>
4503
4504 * src/state.h, src/state.c (reductions_new): New.
4505 * src/LR0.c (set_state_table): Let all the states have a
4506 `reductions', even if reduced to 0.
4507 (save_reductions): Adjust.
4508 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4509 * src/print.c (print_reductions, print_actions): Adjust.
4510 * src/output.c (action_row): Adjust.
4511
2cec70b9
AD
45122001-12-27 Akim Demaille <akim@epita.fr>
4513
4514 * src/state.h, src/state.c (errs_new, errs_dup): New.
4515 * src/LR0.c (set_state_table): Let all the states have an errs,
4516 even if reduced to 0.
4517 * src/print.c (print_errs, print_reductions): Adjust.
4518 * src/output.c (output_actions, action_row): Adjust.
4519 * src/conflicts.c (resolve_sr_conflict): Adjust.
4520
13ca549a
AD
45212001-12-27 Akim Demaille <akim@epita.fr>
4522
4523 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4524
5092aba5
AD
45252001-12-27 Akim Demaille <akim@epita.fr>
4526
4527 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4528 * src/print.c: here.
4529 (lookaheadset, shiftset): New, used as additional storage by
4530 print_reductions.
4531 (print_results): Adjust.
4532 (print_shifts, print_gotos, print_errs): New, extracted from...
4533 (print_actions): here.
4534 * src/print_graph.c (print_actions): Remove dead code.
4535
11e2beca
AD
45362001-12-27 Akim Demaille <akim@epita.fr>
4537
4538 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4539 `$n' and `@n'.
4540
dac3c910
AD
45412001-12-27 Akim Demaille <akim@epita.fr>
4542
4543 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4544 (build_relations): Adjust.
4545
d0b0fefa
AD
45462001-12-27 Akim Demaille <akim@epita.fr>
4547
4548 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4549 duplication.
4550
adc8c848
AD
45512001-12-27 Akim Demaille <akim@epita.fr>
4552
4553 * src/reader.c (packgram): Catch nitems overflows.
4554
14d293ac
AD
45552001-12-27 Akim Demaille <akim@epita.fr>
4556
4557 * src/files.c, src/files.h (guard_obstack): Remove.
4558 * src/output.c (output): Adjust.
4559 * src/reader.c (parse_braces): New, factoring...
4560 (copy_action, copy_guard): these two which are renamed as...
4561 (parse_action, parse_guard): these.
4562 As a voluntary consequence, using braces around guards is now
4563 mandatory.
4564
f499b062
AD
45652001-12-27 Akim Demaille <akim@epita.fr>
4566
4567 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
4568 * src/reader.c (symbol_list): `guard' and `guard_line' are new
4569 members.
4570 (symbol_list_new): Adjust.
4571 (copy_action): action_line is the first line, not the last.
4572 (copy_guard): Just as for actions, store the `action' only, not
4573 the switch/case/break flesh.
4574 Don't parse the user action that might follow the guard, let...
4575 (readgram): do it, i.e., now, there can be an action after a
4576 guard.
4577 In other words the guard is just explicitly optional.
4578 (packgram): Adjust.
4579 * src/output.c (guards_output): New.
4580 (output_parser): Call it when needed.
4581 (output): Also free the guard and attrs obstacks.
4582 * src/files.c, src/files.h (obstack_save): Remove.
4583 (output_files): Remove.
4584 As a result, if one needs the former `.act' file, using an
4585 appropriate skeleton which requires actions and guards is now
4586 required.
4587 * src/main.c (main): Adjust.
4588 * tests/semantic.at: New.
4589 * tests/regression.at: Use `input.y' as input file name.
4590 Avoid 8+3 problems by requiring input.c when the test needs the
4591 parser.
4592
d945f5cd
AD
45932001-12-27 Akim Demaille <akim@epita.fr>
4594
4595 * src/reader.c (symbol_list_new): Be sure to initialize all the
4596 fields.
4597
d200e455
AD
45982001-12-27 Akim Demaille <akim@epita.fr>
4599
4600 All the hacks using a final pseudo state are now useless.
4601
4602 * src/LR0.c (set_state_table): state_table holds exactly nstates.
4603 * src/lalr.c (nLA): New.
4604 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
4605 instead of lookaheadsp from the pseudo state (nstate + 1).
4606
f9507c28
AD
46072001-12-27 Akim Demaille <akim@epita.fr>
4608
4609 * src/output.c (action_row, token_actions): Use a state_t instead
4610 of a integer, and nlookaheads instead of the following state's
4611 lookaheadsp.
4612
065fbd27
AD
46132001-12-27 Akim Demaille <akim@epita.fr>
4614
4615 * src/conflicts.c (log_resolution, flush_shift)
4616 (resolve_sr_conflict, set_conflicts, solve_conflicts)
4617 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
4618 (conflicts_print, print_reductions): Use a state_t instead of an
4619 integer when referring to a state.
4620 As much as possible, depend upon nlookaheads, instead of the
4621 `lookaheadsp' member of the following state (since lookaheads of
4622 successive states are successive, the difference between state n + 1
4623 and n served as the number of lookaheads for state n).
4624 * src/lalr.c (add_lookback_edge): Likewise.
4625 * src/print.c (print_core, print_actions, print_state)
4626 (print_results): Likewise.
4627 * src/print_graph.c (print_core, print_actions, print_state)
4628 (print_graph): Likewise.
4629 * src/conflicts.h: Adjust.
4630
1b177bd7
AD
46312001-12-27 Akim Demaille <akim@epita.fr>
4632
4633 * src/bison.hairy: Formatting/comment changes.
4634 ANSIfy.
4635 Remove `register' indications.
4636 Add plenty of `static'.
4637
7742ddeb
AD
46382001-12-27 Akim Demaille <akim@epita.fr>
4639
4640 * src/output.c (prepare): Drop the muscle `ntbase' which
4641 duplicates ntokens.
4642 * src/bison.simple: Formatting/comment changes.
4643 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
4644 is an undocumented synonym.
4645
1fa14068
AD
46462001-12-22 Akim Demaille <akim@epita.fr>
4647
4648 * src/output.c (output_table_data): Change the prototype to use
4649 `int' for array ranges: some invocations do pass an int, not a
4650 short.
4651 Reported by Wayne Green.
4652
b9752825
AD
46532001-12-22 Akim Demaille <akim@epita.fr>
4654
4655 Some actions of web2c.y are improperly triggered.
4656 Reported by Mike Castle.
4657
4658 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
4659 * tests/regression.at (Web2c): Rename as...
4660 (Web2c Report): this.
4661 (Web2c Actions): New.
4662
776209d6
AD
46632001-12-22 Akim Demaille <akim@epita.fr>
4664
4665 Reductions in web2c.y are improperly reported.
4666 Reported by Mike Castle.
4667
4668 * src/conflicts.c (print_reductions): Fix.
4669 * tests/regression.at (Web2c): New.
4670
275fc3ad
AD
46712001-12-18 Akim Demaille <akim@epita.fr>
4672
4673 Some host fail on `assert (!"foo")', which expands to
4674 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
4675 Reported by Nelson Beebee.
4676
4677 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
4678 `#define it_succeeded 0' and `assert (it_succeeded)'.
4679
897668ee
MA
46802001-12-17 Marc Autret <autret_m@epita.fr>
4681
4682 * src/bison.simple: Don't hard code the skeleton line and filename.
4683 * src/output.c (output_parser): Rename 'line' as 'output_line'.
4684 New line counter 'skeleton_line' (skeleton-line muscle).
4685
ab3399e0
PE
46862001-12-17 Paul Eggert <eggert@twinsun.com>
4687
4688 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
4689 YYDEBUG must be defined to a nonzero value.
4690
4691 * src/bison.simple (yytname): Do not assume that the user defines
4692 YYDEBUG to a properly parenthesized expression.
4693
3877f72b
AD
46942001-12-17 Akim Demaille <akim@epita.fr>
4695
4696 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
4697 nlookaheads is a new member.
4698 Adjust all users.
4699 * src/lalr.h (nlookaheads): Remove this orphan declaration.
4700 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
4701 state.
776209d6 4702
331dbc1b
AD
47032001-12-17 Akim Demaille <akim@epita.fr>
4704
4705 * src/files.h, src/files.c (open_files, close_files): Remove.
4706 * src/main.c (main): Don't open/close files, nor invoke lex_free,
4707 let...
4708 * src/reader.c (reader): Do it.
776209d6 4709
be750e4c
AD
47102001-12-17 Akim Demaille <akim@epita.fr>
4711
4712 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 4713
709ae8c6
AD
47142001-12-17 Akim Demaille <akim@epita.fr>
4715
4716 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
4717 (flush_reduce): New.
4718 (resolve_sr_conflict): Adjust.
776209d6 4719
f87685c3
AD
47202001-12-17 Akim Demaille <akim@epita.fr>
4721
4722 * src/output.c (output_obstack): Be static and rename as...
4723 (format_obstack): this, to avoid any confusion with files.c's
4724 output_obstack.
4725 * src/reader.h (muscle_obstack): Move to...
4726 * src/output.h: here, since it's defined in output.c.
4727
837491d8
AD
47282001-12-17 Akim Demaille <akim@epita.fr>
4729
4730 * src/output.c (action_row, save_column, default_goto)
4731 (sort_actions, matching_state, pack_vector): Better variable
4732 locality.
4733
796d61fb
AD
47342001-12-17 Akim Demaille <akim@epita.fr>
4735
4736 * src/output.c: Various formatting changes.
776209d6 4737
64d15509
AD
47382001-12-17 Akim Demaille <akim@epita.fr>
4739
4740 * src/files.c (output_files): Free the output_obstack.
4741 * src/main.c (main): Call print and print_graph conditionally.
4742 * src/print.c (print): Work unconditionally.
4743 * src/print_graph.c (print_graph): Work unconditionally.
4744 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4745
fbc8ecb7
MA
47462001-12-16 Marc Autret <autret_m@epita.fr>
4747
4748 * src/output.c (actions_output): Fix. When we use %no-lines,
4749 there is one less line per action.
4750
f0440388
MA
47512001-12-16 Marc Autret <autret_m@epita.fr>
4752
4753 * src/bison.simple: Remove a useless #line directive.
4754 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4755 * src/output.c (get_lines_number): New.
776209d6 4756 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
4757 output muscles.
4758 Fix line numbering.
4759 (actions_output): Computes the number of lines taken by actions.
4760 (output_master_parser): Insert new skeleton which is the name of
4761 the output parser file name.
4762
a79986b8
MA
47632001-12-15 Marc Autret <autret_m@epita.fr>
4764
4765 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4766
4ec8e00f
MA
47672001-12-15 Marc Autret <autret_m@epita.fr>
4768
4769 * src/output.c (output_gram): Keep track of the hairy one.
4770
1a4648ff
AD
47712001-12-15 Akim Demaille <akim@epita.fr>
4772
4773 Make `make distcheck' work.
4774
4775 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4776 system.h which uses libgettext.h.
4777
9c2c67e6
AD
47782001-12-15 Akim Demaille <akim@epita.fr>
4779
4780 * src/nullable.c (set_nullable): Useless rules must be skipped,
4781 otherwise, since we range over their symbols, we might look at a
4782 nonterminal which no longer ``exists'', i.e., it is not counted in
4783 `nvars', hence we overflow our arrays.
4784
93ede233
AD
47852001-12-15 Akim Demaille <akim@epita.fr>
4786
4787 The header can also be produced directly, without any obstack!
4788 Yahoo!
4789
4790 * src/files.c, src/files.h (defines_obstack): Remove.
4791 (compute_header_macro): Global.
4792 (defines_obstack_save): Remove.
4793 * src/reader.c (parse_union_decl): No longer output to
4794 defines_obstack: its content can be found in the `stype' muscle
4795 anyway.
4796 (output_token_translations): Merge into...
4797 (symbols_output): this.
4798 Rename as...
4799 (symbols_save): this.
4800 (reader): Adjust.
4801 * src/output.c (header_output): New.
4802 (output): Call it.
4803
2666f928
AD
48042001-12-15 Akim Demaille <akim@epita.fr>
4805
4806 * src/reader.c (parse_union_decl): Instead of handling two obstack
4807 simultaneously, use one to define the `stype' muscle, and use the
4808 value of the latter to fill defines_obstack.
4809 (copy_comment): Remove.
4810 (copy_comment2): Work for a single obstack.
4811 Rename as...
4812 (copy_comment): this.
4813
428046f8
AD
48142001-12-15 Akim Demaille <akim@epita.fr>
4815
4816 * src/lex.c, src/lex.h (xgetc): No longer static.
4817 * src/reader.c (parse_union_decl): Revamp.
4818
ea52d706
AD
48192001-12-15 Akim Demaille <akim@epita.fr>
4820
4821 Still making progress in separating Bison into (i) input, (ii)
4822 process, (iii) output: now we can directly output the parser file
4823 without using table_obstack at all.
4824
4825 * src/files.c, src/files.h (table_obstack): Bye bye.
4826 (parser_file_name): New.
4827 * src/files.c (compute_output_file_names): Compute it.
4828 * src/output.c (actions_output, output_parser)
4829 (output_master_parser): To a file instead of an obstack.
4830
3f96f4dc
AD
48312001-12-15 Akim Demaille <akim@epita.fr>
4832
4833 Attach actions to rules, instead of pre-outputting them to
4834 actions_obstack.
4835
4836 * src/gram.h (rule_t): action and action_line are new members.
4837 * src/reader.c (symbol_list): Likewise.
4838 (copy_action): Save the actions within the rule.
4839 (packgram): Save them in rule_table.
4840 * src/output.c (actions_output): New.
4841 (output_parser): Use it on `%%actions'.
4842 (output_rule_data): Don't free rule_table.
4843 (output): Do it.
4844 (prepare): Don't save the `action' muscle.
4845 * src/bison.simple: s/%%action/%%actions/.
4846
51576fb3
AD
48472001-12-15 Akim Demaille <akim@epita.fr>
4848
4849 * src/reader.c (copy_action): When --yacc, don't append a `;'
4850 to the user action: let it fail if lacking.
dee049eb 4851 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 4852
2648a72d
AD
48532001-12-14 Akim Demaille <akim@epita.fr>
4854
4855 * src/lex.c (literalchar): Simply return the char you decoded, non
4856 longer mess around with obstacks and int pointers.
4857 Adjust all callers.
4858
92790e5b
AD
48592001-12-14 Akim Demaille <akim@epita.fr>
4860
4861 * src/lex.c (literalchar): Don't escape the special characters,
4862 just decode them, and keep them as char (before, eol was output as
4863 the 2 char string `\n' etc.).
4864 * src/output.c (output_rule_data): Use quotearg to output the
4865 token strings.
4866
927c1557
PE
48672001-12-13 Paul Eggert <eggert@twinsun.com>
4868
4869 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4870 Do not infringe on the global user namespace when using C++.
4871 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4872 All uses of `fprintf' and `stderr' changed.
4873
4874 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4875
ed8e1f68
AD
48762001-12-13 Akim Demaille <akim@epita.fr>
4877
4878 The computation of nullable is broken: it doesn't handle empty
4879 RHS's properly.
4880
4881 * tests/torture.at (GNU AWK Grammar): New.
4882 * tests/sets.at (Nullable): New.
4883 * src/nullable.c (set_nullable): Instead of blindly looping over
4884 `ritems', loop over the rules, and then over their rhs's.
4885
4886 Work around Autotest bugs.
4887
4888 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4889 frame, because Autotest understand lines starting with a `+' as
4890 traces from the shell. Then, they are not processed properly.
4891 Admittedly an Autotest bug, but we don't have time to wait for
4892 Autotest to catch up.
4893 * tests/regression.at (Broken Closure): Adjust to the new table
4894 frames.
4895 Move to...
4896 * tests/sets.at: here.
4897
cb581495
AD
48982001-12-13 Akim Demaille <akim@epita.fr>
4899
4900 * src/closure.c (closure): Use nrules instead of playing tricks
4901 with BITS_PER_WORD.
4902
2e729273
AD
49032001-12-13 Akim Demaille <akim@epita.fr>
4904
4905 * src/print.c (print_actions): Output the handling of `$' as the
4906 traces do: shifting the token EOF. Before EOF was treated as a
4907 nonterminal.
4908 * tests/regression.at: Adjust some tests.
4909 * src/print_graph.c (print_core): Complete the set of items via
4910 closure. The next-to-final and final states are still unsatisfying,
4911 but that's to be addressed elsewhere.
4912 No longer output the rule numbers, but do output the state number.
4913 A single loop for the shifts + gotos is enough, but picked a
4914 distinct color for each.
4915 (print_graph): Initialize and finalize closure.
4916
107f7dfb
AD
49172001-12-13 Akim Demaille <akim@epita.fr>
4918
4919 * src/reader.c (readgram): Remove dead code, an strip useless
4920 braces.
4921 (get_type): Remove, unused.
4922
9b53a24f
AD
49232001-12-12 Akim Demaille <akim@epita.fr>
4924
4925 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4926 on that of lib/error.c.
4927
dbfb6dcd
AD
49282001-12-12 Akim Demaille <akim@epita.fr>
4929
4930 Some hosts don't like `/' in includes.
4931
4932 * src/system.h: Include libgettext.h without qualifying the path.
4933 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4934 $(top_srcdir).
4935
c25fb648
MA
49362001-12-11 Marc Autret <autret_m@epita.fr>
4937
4938 * src/output.c (output_parser): Remove useless muscle.
4939
710ddc4f
MA
49402001-12-11 Marc Autret <autret_m@epita.fr>
4941
4942 * src/bison.simple: Remove #line just before %%epilogue. It
4943 is now handled in ...
4944 * src/reader.c (read_additionnal_code): Add the output of a
4945 #line for the epilogue.
4946
e83d80b8
MA
49472001-12-10 Marc Autret <autret_m@epita.fr>
4948
927c1557 4949 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
4950 replace precedent remove.
4951 * src/bison.simple: Remove #line before %%prologue because
4952 %%input-line is wrong at this time.
4953
971d5158
MA
49542001-12-10 Marc Autret <autret_m@epita.fr>
4955
4956 * src/reader.c (symbols_output): Clean up.
927c1557 4957 * src/output.c (output_gram, output): Clean up.
971d5158 4958
5edafffd
AD
49592001-12-10 Akim Demaille <akim@epita.fr>
4960
4961 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4962 * src/LR0.c (set_state_table): here.
4963 * src/lalr.c (lalr): Call it.
4964
0279f8e9
AD
49652001-12-10 Akim Demaille <akim@epita.fr>
4966
4967 * src/state.h (shifts): Remove the `number' member: shifts are
4968 attached to state, hence no longer need to be labelled with a
4969 state number.
4970
190c4f5f
AD
49712001-12-10 Akim Demaille <akim@epita.fr>
4972
4973 Now that states have a complete set of members, the linked list of
4974 shifts is useless: just fill directly the state's shifts member.
4975
4976 * src/state.h (shifts): Remove the `next' member.
4977 * src/LR0.c (first_state, last_state): Remove.
4978 Adjust the callers.
4979 (augment_automaton): Don't look for the shifts that must be added
4980 a shift on EOF: it is those of the state we looked for! But now,
4981 since shifts are attached, it is no longer needed to looking
4982 merely by its id: its number.
4983
2a73b93d
AD
49842001-12-10 Akim Demaille <akim@epita.fr>
4985
4986 * src/LR0.c (augment_automaton): Better variable locality.
4987 Remove an impossible branch: if there is a state corresponding to
4988 the start symbol being shifted, then there is shift for the start
4989 symbol from the initial state.
4990
74392f6a
AD
49912001-12-10 Akim Demaille <akim@epita.fr>
4992
4993 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4994 only when appropriate: when insert_start_shifting_state' is not
4995 invoked.
4996 * tests/regression.at (Rule Line Numbers): Adjust.
4997
37c82725
AD
49982001-12-10 Akim Demaille <akim@epita.fr>
4999
5000 * src/LR0.c (augment_automaton): Now that all states have shifts,
5001 merge the two cases addition shifts to the initial state.
5002
6a164e0c
AD
50032001-12-10 Akim Demaille <akim@epita.fr>
5004
5005 * src/lalr.c (set_state_table): Move to...
5006 * src/LR0.c: here.
5007 * src/lalr.c (lalr): Don't call it...
5008 * src/LR0.c (generate_states): do it.
5009 * src/LR0.h (first_state): Remove, only the table is used.
5010
7215de24
AD
50112001-12-10 Akim Demaille <akim@epita.fr>
5012
5013 * src/LR0.h (first_shift, first_reduction): Remove.
5014 * src/lalr.c: Don't use first_shift: find shifts through the
5015 states.
5016
80e25d4d
AD
50172001-12-10 Akim Demaille <akim@epita.fr>
5018
5019 * src/LR0.c: Attach shifts to states as soon as they are
5020 computed.
5021 * src/lalr.c (set_state_table): Instead of assigning shifts to
5022 state, just assert that the mapping was properly done.
5023
0ab3728b
AD
50242001-12-10 Akim Demaille <akim@epita.fr>
5025
5026 * src/LR0.c (insert_start_shift): Rename as...
5027 (insert_start_shifting_state): this.
5028 (insert_eof_shifting_state, insert_accepting_state): New.
5029 (augment_automaton): Adjust.
5030 Better locality of the variables.
5031 When looking if the start_symbol is shifted from the initial
5032 state, using `while (... symbol != start_symbol ...)' sounds
5033 better than `while (... symbol < start_symbol ...)': If fail
5034 to see how the order between symbols could be relevant!
5035
78af9bbc
AD
50362001-12-10 Akim Demaille <akim@epita.fr>
5037
5038 * src/getargs.h: Don't declare `spec_name_prefix' and
5039 `spec_file_prefix', declared by src/files.h.
5040 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
5041 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
5042 * src/output.c (prepare): Adjust.
5043 * src/reader.c (symbols_output): Likewise.
5044 * src/vmsgetargs.c: Vaguely adjust, but who cares?
5045
bdef2a41
AD
50462001-12-10 Akim Demaille <akim@epita.fr>
5047
5048 * src/muscle_tab.c (muscle_init): NULL is a better default than
5049 `"0"'.
5050
3735969c
AD
50512001-12-10 Akim Demaille <akim@epita.fr>
5052
5053 * src/reader.c (reader): Calling symbols_output once is enough.
5054
49701457
AD
50552001-12-10 Akim Demaille <akim@epita.fr>
5056
5057 Now that states have a complete set of members, the linked list of
5058 reductions is useless: just fill directly the state's reductions
5059 member.
5060
5061 * src/state.h (struct reductions): Remove member `number' and
5062 `next'.
5063 * src/LR0.c (first_reduction, last_reduction): Remove.
5064 (save_reductions): Don't link the new reductions, store them in
5065 this_state.
5066 * src/lalr.c (set_state_table): No need to attach reductions to
5067 states, it's already done.
5068 * src/output.c (output_actions): No longer free the shifts, then
5069 the reductions, then the states: free all the states and their
5070 members.
5071
0edad749
AD
50722001-12-10 Akim Demaille <akim@epita.fr>
5073
5074 * src/options.c (OPTN, DRTV, BOTH): New.
5075 (option_table): Use them.
5076
0edad749
AD
5077 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
5078 the job of system.h.
5079 * src/options.c: Don't include stdio.h and xalloc.h for the same
5080 reasons.
5081
5449dd0f
AD
50822001-12-10 Akim Demaille <akim@epita.fr>
5083
5084 * src/output.c (output, prepare): Make sure the values of the
5085 muscles `action' and `prologue' are 0-terminated.
5086
a870c567
AD
50872001-12-10 Akim Demaille <akim@epita.fr>
5088
5089 Clean up GCC warnings.
5090
5091 * src/reader.c (copy_action): `buf' is not used.
5092 (parse_skel_decl): Be static.
5093 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
5094 * src/options.h (create_long_option_table): Have a real prototype.
5095 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
5096 (hash_delete_at): Return const void *.
5097 Adjust casts to preserve the const.
5098
80df8768
AD
50992001-12-10 Akim Demaille <akim@epita.fr>
5100
5101 * configure.in: Require 2.52g.
5102 M4 is not needed, but AUTOM4TE is.
5103 * m4/m4.m4: Remove.
5104 * tests/Makefile.am: Adjust.
5105
f693ad14
AD
51062001-12-10 Akim Demaille <akim@epita.fr>
5107
5108 One structure for states is enough, even though theoretically
5109 there are LR(0) states and LALR(1) states.
5110
5111 * src/lalr.h (state_t): Remove.
5112 (state_table): Be state_t **, not state_t *.
5113 * src/state.h (core, CORE_ALLOC): Rename as...
5114 (state_t, STATE_ALLOC): this.
5115 Add the LALR(1) members: shifts, reductions, errs.
5116 * src/LR0.c (state_table): Rename as...
5117 (state_hash): this, to avoid name clashes with the global
5118 `state_table'.
5119 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
5120 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
5121
74ffbcb6
AD
51222001-12-10 Akim Demaille <akim@epita.fr>
5123
5124 Bison dumps core on bash.y.
5125 Reported by Pascal Bart.
5126
5127 * src/warshall.c (bitmatrix_print): New.
5128 (TC): Use it.
5129 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
5130 j must be the outer loop.
5131 * tests/regression.at (Broken Closure): New.
5132
07708e19
AD
51332001-12-05 Akim Demaille <akim@epita.fr>
5134
5135 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
5136 its argument.
5137