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