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