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