]> git.saurik.com Git - bison.git/blame - ChangeLog
* data/README: New.
[bison.git] / ChangeLog
CommitLineData
8b76775a
AD
12002-10-22 Akim Demaille <akim@epita.fr>
2
3 * data/README: New.
4
92a060fd
PE
52002-10-20 Paul Eggert <eggert@twinsun.com>
6
7 Remove K&R vestiges.
8 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
9 * src/complain.c (VA_START): Remove. Assume prototypes.
10 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
11 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
12 fatal): Assume prototypes.
13 * src/complain.h: Assume prototypes.
14 * src/system.h (PARAMS): Remove.
15 Include <limits.h> unconditionally, since it's guaranteeed even
16 for a freestanding C89 compiler.
17 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
18 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
8b76775a 19
e7cb57c0
AD
202002-10-20 Akim Demaille <akim@epita.fr>
21
22 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
23 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
24 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
25 (yyresolveStates, yyresolveAction, yyresolveStack)
26 (yyprocessOneStack): Use them.
27 (yy_reduce_print): New.
28 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
29
0245f82d
AD
302002-10-20 Akim Demaille <akim@epita.fr>
31
32 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
33 arguments and output `void'.
34 (b4_c_function): Rename as...
35 (b4_c_function_def): this.
36 (b4_c_function_decl, b4_c_ansi_function_def)
37 (b4_c_ansi_function_decl): New.
38 Change the interpretation of the arguments: before `int, foo', now
39 `int foo, foo'.
40 * data/yacc.c (yyparse): Prototype and define thanks to these.
41 Adjust b4_c_function_def uses.
42 * data/glr.c (yyparse): Likewise, but ANSI only.
43
39912f52
AD
442002-10-20 Akim Demaille <akim@epita.fr>
45
46 * src/output.c (prepare): Move the definition of `tokens_number',
47 `nterms_number', `undef_token_number', `user_token_number_max'
48 to...
49 (prepare_tokens): Here.
50 (prepare_tokens): Rename as...
51 (prepare_symbols): this.
52 (prepare): Move the definition of `rules_number' to...
53 (prepare_rules): here.
54 (prepare): Move the definition of `last', `final_state_number',
55 `states_number' to...
56 (prepare_states): here.
57 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
58
20c1e2ad
AD
592002-10-20 Akim Demaille <akim@epita.fr>
60
61 * src/tables.h, src/tables.c, src/output.c: Comment changes.
62
21964f43
AD
632002-10-20 Akim Demaille <akim@epita.fr>
64
65 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
66 * data/c.m4: here.
67
66d30cd4
AD
682002-10-20 Akim Demaille <akim@epita.fr>
69
70 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
71 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
72 `pair'.
73 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
74 `name' to...
75 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
76 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
77 These.
78
95f2c9fe
PE
792002-10-19 Paul Eggert <eggert@twinsun.com>
80
81 Do not create a temporary file, as that involves security and
82 cleanup headaches. Instead, use a pair of pipes.
83 Derived from a suggestion by Florian Krohm.
84 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
85 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
86 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
87 (BISON_PREREQ_SUBPIPE): Add.
88 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
89 Add subpipe.h, subpipe.c.
90 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
91 * po/POTFILES.in: Add lib/subpipe.c.
92 * src/output.c: Include "subpipe.h".
93 (m4_invoke): Remove decl.
94 (scan_skel): New decl.
95 (output_skeleton): Use pipe rather than temporary file for m4 input.
96 Check that m4sugar.m4 is readable, to avoid deadlock.
97 Check for pipe I/O error.
98 * src/scan-skel.l (readpipe): Remove decl.
99 (scan_skel): New function, to be used in place of m4_invoke.
100 Read from stream rather than file.
66d30cd4 101
95f2c9fe
PE
102 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
103 float, as this generates a warning on Solaris 8 + GCC 3.2 with
104 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
105 this generates a more-accurate value anyway.
106
107 * lib/timevar.c (timervar_accumulate): Rename locals to
108 avoid confusion with similarly-named more-global.
109 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
110
111 * src/output.c (prepare): Use xstrdup to convert char const *
112 to char *, to avoid GCC warning.
113
c19988b7
AD
1142002-10-19 Akim Demaille <akim@epita.fr>
115
116 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
117 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
118 Use them to have `calc.y' ready for %pure-parser.
119 * data/yacc.c (YYLEX): Pass a yylex return type to
120 b4_c_function_call.
121
ae7453f2
AD
1222002-10-19 Akim Demaille <akim@epita.fr>
123
124 Prototype support of %lex-param and %parse-param.
125
126 * src/parse-gram.y: Add the definition of the %lex-param and
127 %parse-param tokens, plus their rules.
128 Drop the `_' version of %glr-parser.
129 Add the "," token.
130 * src/scan-gram.l (INITIAL): Scan them.
131 * src/muscle_tab.c: Comment changes.
132 (muscle_insert, muscle_find): Rename `pair' as `probe'.
133 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
134 (muscle_entry_s): The `value' member is no longer const.
135 Adjust all dependencies.
136 * src/muscle_tab.c (muscle_init): Adjust: use
137 MUSCLE_INSERT_STRING.
138 Initialize the obstack earlier.
139 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
140 (muscle_pair_list_grow): New.
141 * data/c.m4 (b4_c_function_call, b4_c_args): New.
142 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
143 * tests/calc.at: Use %locations, not --locations.
144 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
145
0e575721
AD
1462002-10-19 Akim Demaille <akim@epita.fr>
147
148 * src/getargs.c (usage): Take status as argument and exit
149 accordingly.
150 Report the traditional `Try ... --help' message when status != 0.
151 (usage, version): Don't take a FILE * as arg, it is pointless.
152 (getargs): When there is an incorrect number of arguments, make it
153 an error, and report it GNUlically thanks to `usage ()'.
154
724ce7f5
PE
1552002-10-18 Paul Eggert <eggert@twinsun.com>
156
3a781eb2
PE
157 * data/glr.c (yyreportParseError): Don't assume that sprintf
158 yields the length of the printed string, as this is not true
159 on SunOS 4.1.4. Reported by Peter Klein.
160
724ce7f5
PE
161 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
162 * tests/conflicts.at (%nonassoc and eof): Likewise.
163 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
164
473d0a75
AD
1652002-10-17 Akim Demaille <akim@epita.fr>
166
167 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
168 * src/getargs.c (trace_types, trace_args): Adjust.
169 * src/reader.c (grammar_current_rule_prec_set)
170 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
171 Standardize error messages.
172 And s/@prec/%prec/!
173 (reader): Use trace_flag to enable scanner/parser debugging,
174 instead of an adhoc scheme.
175 * src/scan-gram.l: Remove trailing debugging code.
176
e76d2469
PE
1772002-10-16 Paul Eggert <eggert@twinsun.com>
178
93e2236a
PE
179 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
180 MUSCLE_TAB_H.
181
e76d2469
PE
182 * NEWS: Officially drop support for building Bison with K&R C,
183 since it didn't work anyway and it's not worth worrying about.
184 * Makefile.maint (wget_files): Remove ansi2knr.c.
185 (ansi2knr.c-url_prefix): Remove.
186 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
187 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
188 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
189
5bd1c419
PE
1902002-10-15 Paul Eggert <eggert@twinsun.com>
191
192 Stop using the "enum_" trick for K&R-style function definitions;
193 it confused me, and I was the author! Instead, assume that people
194 who want to use K&R C compilers (when using these modules in GCC,
195 perhaps?) will run ansi2knr.
196
197 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
198 All uses of "enum_" changed to "enum ".
199 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
200 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
e76d2469 201
5bd1c419
PE
202 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
203 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
204 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
205 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
206 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
207 abitset_not, abitset_ones, abitset_or, abitset_or_and,
208 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
209 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
210 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
211 Use function prototypes; this removes the need for declaring
212 static functions simply to provide their prototypes.
213 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
214 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
215 bitset_count_, bitset_create, bitset_dump, bitset_first,
216 bitset_free, bitset_init, bitset_last, bitset_next,
217 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
218 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
219 bitset_print, bitset_release_memory, bitset_toggle_,
220 bitset_type_choose, bitset_type_get, bitset_type_name_get,
221 debug_bitset): Likewise.
222 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
223 * lib/bitset_stats.c (bitset_log_histogram_print,
224 bitset_percent_histogram_print, bitset_stats_and,
225 bitset_stats_and_cmp, bitset_stats_and_or,
226 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
227 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
228 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
229 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
230 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
231 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
232 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
233 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
234 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
235 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
236 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
237 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
238 bitset_stats_zero): Likewise.
239 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
240 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
241 bitsetv_dump, debug_bitsetv): Likewise.
242 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
243 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
244 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
245 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
246 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
247 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
248 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
249 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
250 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
251 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
252 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
253 Likewise.
254 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
255 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
256 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
257 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
258 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
259 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
260 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
261 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
262 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
263 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
264 lbitset_xor_cmp, lbitset_zero): Likewise.
e76d2469 265
ae26e1f0
AD
2662002-10-14 Akim Demaille <akim@epita.fr>
267
268 Version 1.75.
269
d43baf71
AD
2702002-10-14 Akim Demaille <akim@epita.fr>
271
272 * tests/Makefile.am (maintainer-check-posix): New.
273
7ebc83e3
AD
2742002-10-14 Akim Demaille <akim@epita.fr>
275
276 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
277 member.
278
05846dae
AD
2792002-10-14 Akim Demaille <akim@epita.fr>
280
281 * src/tables.c (table_ninf_remap): base -> tab.
282 Reported by Matt Rosing.
283
1318e37d
PE
2842002-10-14 Paul Eggert <eggert@twinsun.com>
285
447fbb17
PE
286 * tests/action.at, tests/calc.at, tests/conflicts.at,
287 tests/cxx-type.at, tests/headers.at, tests/input.at,
288 tests/regression.at, tests/synclines.at, tests/torture.at:
289 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
290 so that the tests still work even if POSIXLY_CORRECT is set.
291 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
05846dae 292
1318e37d
PE
293 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
294 for portability to K&R hosts. Fix typo: signed char is guaranteed
295 only to 127, not to 128.
296 * data/glr.c (yysigned_char): New type.
297 * data/yacc.c (yysigned_char): Likewise.
298 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
299
cc0f0794
PE
3002002-10-13 Paul Eggert <eggert@twinsun.com>
301
5038f418
PE
302 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
303 true due to limited range of data type" warning from GCC.
304
cc0f0794
PE
305 * data/c.m4 (b4_token_defines): Protect against double-inclusion
306 by wrapping enum yytokentype's definition inside #ifndef
307 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
308
6fed0802
AD
3092002-10-13 Akim Demaille <akim@epita.fr>
310
311 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
312 Un yy- yyrhs to avoid the name clash with the global YYRHS.
313
32f0598d
AD
3142002-10-13 Akim Demaille <akim@epita.fr>
315
316 * Makefile.maint: Update from Autoconf 2.54.
317 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
318
7ea9a33f
AD
3192002-10-13 Akim Demaille <akim@epita.fr>
320
321 * src/print.c (print_state): Separate the list of solved conflicts
322 from the other items.
323 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
324
ea99527d
AD
3252002-10-13 Akim Demaille <akim@epita.fr>
326
327 Let nondeterministic skeletons be usable with deterministic
328 tables.
329
330 With the patch, GAWK compiled by GCC without -O2 passes its test
331 suite using a GLR parser driven by LALR tables. It fails with -O2
332 because `struct stat' gives two different answers on my machine:
333 88 (definition of an auto var) and later 96 (memset on this var).
334 Hence the stack is badly corrumpted. The headers inclusion is to
335 blame: if I move the awk.h inclusion before GLR's system header
336 inclusion, the two struct stat have the same size.
337
338 * src/tables.c (pack_table): Always create conflict_table.
339 (token_actions): Always create conflict_list.
340 * data/glr.c (YYFLAG): Remove, unused.
341
f377f69f
AD
3422002-10-13 Akim Demaille <akim@epita.fr>
343
344 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
345 (O0FLAGS): New.
346 (VALGRIND, GXX): New.
347 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
348 * tests/bison.in: Run $PREBISON a pre-command.
349 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
350 (maintainer-check-g++): New.
351 * Makefile.am (maintainer-check): New.
352
2a1fe6ed
AD
3532002-10-13 Akim Demaille <akim@epita.fr>
354
355 * data/glr.c: Formatting changes.
356 Tweak some trace messages to match yacc.c's.
357
f50adbbd
AD
3582002-10-13 Akim Demaille <akim@epita.fr>
359
360 GLR parsers sometimes raise parse errors instead of performing the
361 default reduction.
362 Reported by Charles-Henry de Boysson.
363
364 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
365 check the length of the traces when %glr.
366 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
367 GLR's traces.
368 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
369 Test GLR parsers.
370 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
371 (yyltype): Remove the yy prefix from the member names.
372 (yytable): Complete its comment.
373 (yygetLRActions): Map error action number from YYTABLE from
374 YYTABLE_NINF to 0.
375 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
376 (which was a bug: it should have been YYTABEL_NINF, and yet it was
377 not satisfying as we could compare an YYACTION computed from
378 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
379 only value for error actions.
380 (yyreportParseError): In verbose parse error messages, don't issue
381 `error' in the list of expected tokens.
382 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
383 next action to perform to match glr.c's decoding.
384 (yytable): Complete its comment.
385
bcbad5b9
PE
3862002-10-13 Paul Eggert <eggert@twinsun.com>
387
388 Fix problem reported by Henrik Grubbstroem in
389 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
390 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
391 because the Bison parser reads the second action before reducing
392 the first one.
393 * src/scan-gram.l (rule_length): New static var.
394 Use it to keep track of the rule length in the scanner, since
395 we can't expect the parser to be in lock-step sync with the scanner.
396 (handle_action_dollar, handle_action_at): Use this var.
397 * tests/actions.at (Exotic Dollars): Test for the problem.
05846dae 398
14904b89
PE
3992002-10-12 Paul Eggert <eggert@twinsun.com>
400
1fe611e5
PE
401 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
402 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
403 Include <sys/time.h> when checking for clock_t and struct tms.
404 Use same include order as source.
405 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
406 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
05846dae 407
1fe611e5
PE
408 * lib/timevar.c: Update copyright date and clarify comments.
409 (get_time) [IN_GCC]: Keep the GCC version for reference.
05846dae 410
1fe611e5
PE
411 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
412 GCC version as of today, then merge Bison's changes.
413 Change "GCC" to "Bison" in copyright notice. timevar.def's
414 author is Akim, so change that too.
415
98194095
PE
416 * src/reader.c (grammar_current_rule_check):
417 Don't worry about the default action if $$ is untyped.
418 Prevents bogus warnings reported by Jim Gifford in
419 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
420
14904b89
PE
421 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
422 * data/glr.c, data/lalr1.cc, data/yacc.c:
423 Output token definitions before the first part of user declarations.
424 Fixes compatibility problem reported by Jim Gifford for kbd in
425 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
426
ff6dca18
PE
4272002-10-11 Paul Eggert <eggert@twinsun.com>
428
429 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
430 (yyparse): here. This undoes some of the 2002-07-25 change.
431 Compatibility problem reported by Ralf S. Engelschall with
432 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
433
eb714592
AD
4342002-10-11 Akim Demaille <akim@epita.fr>
435
436 * tests/regression.at Characters Escapes): New.
437 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
438 characters.
439 Reported by Jan Nieuwenhuizen.
440
b7195100
AD
4412002-10-11 Akim Demaille <akim@epita.fr>
442
443 * po/id.po: New.
444
f28a0f2d
PE
4452002-10-10 Paul Eggert <eggert@twinsun.com>
446
447 Portability fixes for bitsets; this also avoids several GCC
448 warnings.
449
450 * lib/abitset.c: Include <stddef.h>, for offsetof.
451 * lib/lbitset.c: Likewise.
452
453 * lib/abitset.c (abitset_bytes): Return a size that is aligned
454 properly for vectors of objects. Do not assume that adding a
455 header size to a multiple of a word size yields a value that is
456 properly aligned for the whole union.
457 * lib/bitsetv.c (bitsetv_alloc): Likewise.
458
459 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
460 unique names for structures.
461 * lib/ebitset.c (ebitset_bytes): Likewise.
462 * lib/lbitset.c (lbitset_bytes): Likewise.
463
464 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
465 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
466 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
467 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
468 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
469 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
470 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
471 to improve the type-checking that GCC can do.
472 * lib/bitset.c (bitset_op4_cmp): Likewise.
473 * lib/bitset_stats.c (bitset_stats_count,
474 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
475 bitset_stats_copy, bitset_stats_disjoint_p,
476 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
477 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
478 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
479 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
480 bitset_stats_and_or_cmp, bitset_stats_andn_or,
481 bitset_stats_andn_or_cmp, bitset_stats_or_and,
482 bitset_stats_or_and_cmp): Likewise.
483 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
484 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
485 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
486 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
487
488 * lib/abitset.h: Include bitset.h, not bbitset.h.
489 * lib/ebitset.h: Likewise.
490 * lib/lbitset.h: Likewise.
491
492 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
493 All instances of parameters of type enum bitset_opts are now of
494 type enum_bitset_opts, to conform to the C Standard, and similarly
495 for enum_bitset_type.
496 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
497 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
498
499 Do not use "struct bitset_struct" to mean different things in
500 different modules. Not only is this confusing, it violates
501 the C Standard, which requires that structure types in different
502 modules must be compatible if one is to be passed to the other.
503 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
504 All instances of "struct bitset_struct *" replaced with "bitset".
505 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
506 (union bitset_union, struct abitset_struct, struct ebitset_struct,
507 struct lbitset_struct, struct bitset_stats_struct): New types.
508 All uses of struct bitset_struct changed to union bitset_union,
509 etc.
510 * lib/abitset.c (struct abitset_struct, abitset,
511 struct bitset_struct): Remove.
512 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
513 struct bitset_struct): Remove.
514 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
515 bitset_struct): Remove.
516 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
517 Likewise.
518
519 Do not call a function of type T using a call that assumes the
520 function is of a different type U. Standard C requires that a
521 function must be called with a type that is compatible with its
522 definition.
523 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
524 New decls.
525 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
526 New functions.
527 * lib/ebitset.c (PFV): Remove.
528 * lib/lbitset.c (PFV): Likewise.
529 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
530 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
531 decls.
532 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
533 (ebitset_vtable): Use them.
534 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
535 lbitset_xor): New functions.
536 (lbitset_vtable): Use them.
537
538 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
539 Declare.
540
541 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
542 GCC warning.
543 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
544 Use offsetof, for simplicity.
545
6fbe4984
PE
5462002-10-06 Paul Eggert <eggert@twinsun.com>
547
548 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
549 the same width as int. This reapplies a hunk of the 2002-08-12 patch
550 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
551 which was inadvertently undone by the 2002-09-30 patch.
552 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
553 the same width as int.
554
420f93c8
PE
5552002-10-04 Paul Eggert <eggert@twinsun.com>
556
557 Version 1.50.
558
559 * configure.ac (AC_INIT), NEWS: Increment version number.
560
561 * doc/bison.texinfo: Minor spelling, grammar, and white space
562 fixes.
563 (Symbols): Mention that any negative value returned from yylex
564 signifies end-of-input. Warn about negative chars. Mention
565 the portable Standard C character set.
566
567 The GNU coding standard says CFLAGS and YFLAGS are reserved
568 for the installer to set.
569 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
570 * src/Makefile.am (AM_CFLAGS): Likewise.
571 (AM_YFLAGS): Renamed from YFLAGS.
572
573 Fix some MAX and MIN problems.
574 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
575 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
576 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
577 * src/reader.c (reader): Use it.
578
579 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
580 POSIX 1003.1-2001 has removed fgrep.
581
5822002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
583
584 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
585 interpreted as signed.
586 * lib/ebitset.c (ebitset_list): Fix bug.
587
ff68026d
PE
5882002-10-01 Paul Eggert <eggert@twinsun.com>
589
590 More fixes for 64-bit hosts and large bitsets.
591
592 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
593 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
594 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
595 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
596 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
597 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
598 bitset_count_): Likewise.
599 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
600 bitset_first, bitset_last): Likewise.
601 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
602 bitset_stats_list_reverse, bitset_stats_size,
603 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
604 Likewise.
605 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
606 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
607 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
608 bitsetv_reflexive_transitive_closure): Likewise.
609 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
610 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
611 Likewise.
612 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
613 Likewise.
420f93c8 614
ff68026d
PE
615 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
616 Use size_t, not unsigned int, to count bytes.
617 * lib/abitset.h (abitset_bytes): Likewise.
618 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
619 Likewise.
620 * lib/bitset.h (bitset_bytes): Likewise.
621 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
622 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
623 * lib/bitsetv.c (bitsetv_alloc): Likewise.
624 * lib/ebitset.c (ebitset_bytes): Likewise.
625 * lib/ebitset.h (ebitset_bytes): Likewise.
626 * lib/lbitset.c (lbitset_bytes): Likewise.
627 * lib/lbitset.h (lbitset_bytes): Likewise.
420f93c8 628
ff68026d
PE
629 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
630 abitset_subset_p, abitset_disjoint_p, abitset_and,
631 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
632 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
633 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
634 abitset_or_and, abitset_or_and_cmp):
635 Use bitset_windex instead of unsigned int.
636 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
637 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
638 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
639 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
640 Likewise.
641 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
420f93c8 642
ff68026d
PE
643 * lib/bitset.c (bitset_print):
644 Use proper printf formats for widths of integer types.
645 * lib/bitset_stats.c (bitset_percent_histogram_print,
646 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
647 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
648 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
649 * lib/lbitset.c (lbitset_bytes): Likewise.
420f93c8 650
ff68026d
PE
651 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
652 BITSET_SIZE_MAX): New macros.
653 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
654 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
655 to BITSET_WINDEX_MAX.
656
657 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
658 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
659 since we now return the bitset_bindex type (not int).
660
661 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
662 when computing sizes.
663 * lib/ebitset.c (ebitset_elts_grow): Likewise.
664
665 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
666 and avoid cast to unsigned.
667
6aa452a6
AD
6682002-09-30 Akim Demaille <akim@epita.fr>
669
670 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
671 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
672 Updates from Michael Hayes.
673
927f7817
AD
6742002-09-30 Art Haas <ahaas@neosoft.com>
675
676 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
677 invocations.
678 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
679 defined.
680
9738f41e
AD
6812002-09-27 Akim Demaille <akim@epita.fr>
682
683 Version 1.49c.
684
a5c75d7f
AD
6852002-09-27 Akim Demaille <akim@epita.fr>
686
687 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
688 (Because of AC_LIBSOURCE).
689
8280e179
AD
6902002-09-27 Akim Demaille <akim@epita.fr>
691
692 Playing with Autoscan.
693
694 * configure.ac: Remove the old LIBOBJ tweaks.
695 (AC_REPLACE_FUNCS): Add strrchr and strtol.
696 * lib/strrchr.c: New.
697 * lib/strtol.c: New, from the Coreutils 4.5.1.
698
ae64af35
AD
6992002-09-27 Akim Demaille <akim@epita.fr>
700
701 Playing with Autoscan.
702
703 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
704 * lib/Makefile.am (libbison_a_SOURCES): No longer include
705 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
706 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
707 Coreutils 4.5.1.
708
d1a1114f
AD
7092002-09-24 Akim Demaille <akim@epita.fr>
710
711 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
712 (Frequently Asked Questions, Parser Stack Overflow): New.
713
b906441c
AD
7142002-09-13 Akim Demaille <akim@epita.fr>
715
716 Playing with autoscan.
717
718 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
719 * src/files.c (skeleton_find): Remove, unused.
720 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
721 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
722
bd701811
AD
7232002-09-13 Akim Demaille <akim@epita.fr>
724
725 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
726 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
727
e0a13e7b
AD
7282002-09-13 Akim Demaille <akim@epita.fr>
729
730 * configure.ac: Require 2.54.
731 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
732 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
733 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
734 Remove, provided by Autoconf macros.
735
c97011bf
AD
7362002-09-12 Akim Demaille <akim@epita.fr>
737
738 * m4/prereq.m4: Update, from Coreutils 4.5.1.
739
d862b1be
AD
7402002-09-12 Akim Demaille <akim@epita.fr>
741
742 * m4/prereq.m4: Update, from Fileutils 4.1.5.
743 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
744 Reported by Martin Mokrejs.
745
3d38c03a
AD
7462002-09-10 Akim Demaille <akim@epita.fr>
747
748 * src/parse-gram.y: Associate a human readable string to each
749 token type.
750 * tests/regression.at (Invalid inputs): Adjust.
751
b6347355
AD
7522002-09-10 Gary V. Vaughan <gary@gnu.org>
753
754 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
755 with an Autoconf-2.5x style configure.ac.
756
09ba4ab2
PE
7572002-09-06 Paul Eggert <eggert@twinsun.com>
758
759 * doc/bison.texinfo (Conditions): Make explicit that the GPL
760 exception applies only to yacc.c. This is a modification of a
761 patch originally suggested by Akim Demaille.
762
21846f69
AD
7632002-09-06 Akim Demaille <akim@epita.fr>
764
09ba4ab2
PE
765 * data/c.m4 (b4_copyright): Move the GPL exception comment from
766 here to...
767 * data/yacc.c: here.
768
21846f69
AD
769 * data/lalr1.cc (struct yyltype): Don't define it, since we use
770 LocationType.
771 (b4_ltype): Default to yy::Location from location.hh.
772
c0ad8bf3
AD
7732002-09-04 Jim Meyering <jim@meyering.net>
774
775 * data/yacc.c: Guard the declaration of yytoknum also with
776 `#ifdef YYPRINT', so it is declared only when used.
777
3a93251e
AD
7782002-09-04 Akim Demaille <akim@epita.fr>
779
780 * configure.in: Rename as...
781 * configure.ac: this.
782 Bump to 1.49c.
783
427c0dda
AD
7842002-09-04 Akim Demaille <akim@epita.fr>
785
786 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
787 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
788 translate maintainer only messages.
789
6a254321
PE
7902002-08-12 Paul Eggert <eggert@twinsun.com>
791
645e30d1
PE
792 Version 1.49b.
793
6a254321
PE
794 * Makefile.am (SUBDIRS): Remove intl.
795 (DISTCLEANFILES): Remove.
796 * NEWS: Mention that GNU M4 is now required. Clarify what is
797 meant by "larger grammars". Mention the pt_BR translation.
798 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
799 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
800 Bump version from 0.11.2 to 0.11.5.
801 (BISON_PREREQ_STAGE): Remove.
802 (AM_GNU_GETTEXT): Use external gettext.
803 (AC_OUTPUT): Remove intl/Makefile.
804
805 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
806
807 * data/glr.c: Include string.h, for strlen.
808 (yyreportParseError): Use size_t for yysize.
809 (yy_yypstack): No longer nested inside yypstates, as nested
810 functions are not portable. Do not assume size_t is the
811 same width as int.
812 (yypstates): Do not assume that ptrdiff_t is the same width
813 as int, and similarly for yyposn and YYINDEX.
814
815 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
816
817 * lib/Makefile.am (INCLUDES): Do not include from the intl
818 directory, which has been removed.
819 * src/Makefile.am (INCLUDES): Likewise.
820
821 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
822 (bitsets_sources, additional_bitsets_sources, timevars_sources):
823 New vars.
824
825 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
826 * tests/Makefile.am (EXTRA_DIST): Likewise.
827
828 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
829 Do not assume that bitset_windex is the same width as unsigned.
830
831 * lib/abitset.c (abitset_unused_clear): Do not assume that
832 bitset_word is the same width as int.
833 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
834 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
835 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
836 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
837 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
838
839 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
840 portability to one's complement hosts!).
841 * lib/ebitset.c (ebitset_op1): Likewise.
842 * lib/lbitset.c (lbitset_op1): Likewise.
843
844 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
845 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
846 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
847 Sync with fileutils.
848 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
849 lib/gettext.h: Sync with diffutils.
850
851 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
852 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
853
854 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
855 PROTOTYPES to check for prototypes, and "defined __STDC__" to
856 check for void *.
857
858 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
859 size_t; the old version tried to do this but casted improperly.
860 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
861 (bitset_test): Now returns int, not unsigned long.
862
863 * lib/bitset_stats.c: Include "gettext.h".
864 (_): New macro.
865 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
866 name locals "index", as it generates unnecessary warnings on some
867 hosts that have an "index" function.
868
869 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
870 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
871 they need translation.
872 * src/LR0.c (state_list_append, new_itemsets, get_state,
873 append_states, generate_states): Likewise.
874 * src/assoc.c (assoc_to_string): Likewise.
875 * src/closure.c (print_closure, set_firsts, closure): Likewise.
876 * src/gram.c (grammar_dump): Likewise.
877 * src/injections.c (injections_compute): Likewise.
878 * src/lalr.c (lookaheads_print): Likewise.
879 * src/relation.c (relation_transpose): Likewise.
880 * src/scan-gram.l: Likewise.
881 * src/tables.c (table_grow, pack_vector): Likewise.
882
883 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
884 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
885 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
886 * m4/mbstate_t.m4: Sync with fileutils.
887 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
888
889 * po/LINGUAS: Add pt_BR.
890 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
891 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
892 lib/timevar.c.
893 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
894 manual recommends.
895 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
896
897 * src/complain.c (strerror_r): Remove decl; not needed.
898 (strerror): Use same pattern as ../lib/error.c.
899
900 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
901
902 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
903
904 * src/main.c (main): Cast result of bindtextdomain and textdomain
905 to void, to avoid a GCC warning when --disable-nls is in effect.
906
907 * src/scan-gram.l: Use strings rather than escapes when possible,
908 to minimize the number of warnings from xgettext.
909 (handle_action_dollar, handle_action_at): Don't use isdigit,
910 as it mishandles negative chars and it may not work as expected
911 outside the C locale.
912
913 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
914 this is a GCC extension and is not portable to other compilers.
915
916 * src/system.h (alloca): Use same pattern as ../lib/error.c.
917 Do not include <ctype.h>; no longer needed.
918 Do not include <malloc.h>; no longer needed (and generates
919 warnings on OpenBSD 3.0).
920
921 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
922 it's not portable.
923
924 * tests/regression.at: Do not use 'cc -c input.c -o input';
925 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
926
927 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
928 exit status as failure, not just exit status 1. Sun C exits
929 with status 2 sometimes.
930
931 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
932 Use it for the two large tests.
933
c8f002c7
AD
9342002-08-02 Akim Demaille <akim@epita.fr>
935
936 * src/conflicts.c (conflicts_output): Don't output rules never
937 reduced here, since anyway that computation doesn't work.
938 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
939 (rule_useless_p, rule_never_reduced_p): New.
940 (grammar_rules_partial_print): Use a filter instead of a range.
941 Display the title only if needed.
942 (grammar_rules_print): Adjust.
943 (grammar_rules_never_reduced_report): New.
944 * src/tables.c (action_row): Move the computation of rules never
945 reduced to...
946 (token_actions): here.
947 * src/main.c (main): Make the parser before making the report, so
948 that rules never reduced are computed.
949 Call grammar_rules_never_reduced_report.
950 * src/print.c (print_results): Report rules never reduced.
951 * tests/conflicts.at, tests/reduce.at: Adjust.
952
cd08e51e
AD
9532002-08-01 Akim Demaille <akim@epita.fr>
954
955 Instead of attaching lookaheads and duplicating the rules being
956 reduced by a state, attach the lookaheads to the reductions.
957
958 * src/state.h (state_t): Remove the `lookaheads',
959 `lookaheads_rule' member.
960 (reductions_t): Add a `lookaheads' member.
961 Use a regular array for the `rules'.
962 * src/state.c (reductions_new): Initialize the lookaheads member
963 to 0.
964 (state_rule_lookaheads_print): Adjust.
965 * src/state.h, src/state.c (state_reductions_find): New.
966 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
967 (count_rr_conflicts): Adjust.
968 * src/lalr.c (LArule): Remove.
969 (add_lookback_edge): Adjust.
970 (state_lookaheads_count): New.
971 (states_lookaheads_initialize): Merge into...
972 (initialize_LA): this.
973 (lalr_free): Adjust.
974 * src/main.c (main): Don't free nullable and derives too early: it
975 is used by --verbose.
976 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
977
bb0027a9
AD
9782002-08-01 Akim Demaille <akim@epita.fr>
979
980 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
981 `rule_number_t**'.
982 (set_derives, free_derives): Rename as...
983 (derives_compute, derives_free): this.
984 Adjust all dependencies.
985 * src/nullable.c (set_nullable, free_nullable): Rename as...
986 (nullable_compute, nullable_free): these.
987 (rule_list_t): Store rule_t *, not rule_number_t.
988 * src/state.c (state_rule_lookaheads_print): Directly compare rule
989 pointers, instead of their numbers.
990 * src/main.c (main): Call nullable_free, and derives_free earlier,
991 as they were lo longer used.
992
3325ddc4
AD
9932002-08-01 Akim Demaille <akim@epita.fr>
994
995 * lib/timevar.c (get_time): Include children time.
996 * src/lalr.h (LA, LArule): Don't export them: used with the
997 state_t.
998 * src/lalr.c (LA, LArule): Static.
999 * src/lalr.h, src/lalr.c (lalr_free): New.
1000 * src/main.c (main): Call it.
1001 * src/tables.c (pack_vector): Check whether loc is >= to the
1002 table_size, not >.
1003 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
1004 (tables_generate): do it, since that's also it which allocates
1005 them.
1006 Don't free LA and LArule, main does.
1007
c6f1a33c
AD
10082002-07-31 Akim Demaille <akim@epita.fr>
1009
1010 Separate parser tables computation and output.
1011
1012 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
1013 (conflict_list, conflict_list_cnt, table, check, table_ninf)
1014 (yydefgoto, yydefact, high): Move to...
1015 * src/tables.h, src/tables.c: here.
1016 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1017 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1018 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
1019 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
1020 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
1021 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
1022 (action_row, save_row, token_actions, save_column, default_goto)
1023 (goto_actions, sort_actions, matching_state, pack_vector)
1024 (table_ninf_remap, pack_table, prepare_actions): Move to...
1025 * src/tables.c: here.
1026 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
1027 * src/output.c (token_actions, output_base, output_conflicts)
1028 (output_check): Merge into...
1029 (prepare_actions): this.
1030 (actions_output): Rename as...
1031 (user_actions_output): this.
1032 * src/main.c (main): Call tables_generate and tables_free.
1033
1509d42f
AD
10342002-07-31 Akim Demaille <akim@epita.fr>
1035
1036 Steal GCC's --time-report support.
1037
1038 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
1039 stolen/adjusted from GCC.
1040 * m4/stage.m4: Remove time related checks.
1041 * m4/timevar.m4: New.
1042 * configure.in: Adjust.
1043 * src/system.h: Adjust to using timevar.h.
1044 * src/getargs.h, src/getargs.c: Support trace_time for
1045 --trace=time.
1046 * src/main.c (stage): Remove.
1047 (main): Replace `stage' invocations with timevar calls.
1048 * src/output.c: Insert pertinent timevar calls.
1049
273a74fa
AD
10502002-07-31 Akim Demaille <akim@epita.fr>
1051
1052 Let --trace have arguments.
1053
1054 * src/getargs.h (enum trace_e): New.
1055 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
1056 (long_options, short_options): --trace/-T takes an optional
1057 argument.
1058 Change all the uses of trace_flag to reflect the new flags.
1059 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
1060
1061 Strengthen `stage' portability.
1062
1063 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
1064 * configure.in: Use it.
1065 Don't check for malloc.h and sys/times.h.
1066 * src/system.h: Include them when appropriate.
1067 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
1068 times and struct tms are available.
1069
217598da
AD
10702002-07-30 Akim Demaille <akim@epita.fr>
1071
1072 In verbose parse error message, don't report `error' as an
1073 expected token.
1074 * tests/actions.at (Printers and Destructors): Adjust.
1075 * tests/calc.at (Calculator $1): Adjust.
1076 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
1077 error message, do not report the parser accepts the error token in
1078 that state.
1079
52489d44
AD
10802002-07-30 Akim Demaille <akim@epita.fr>
1081
1082 Normalize conflict related messages.
1083
1084 * src/complain.h, src/complain.c (warn, complain): New.
1085 * src/conflicts.c (conflicts_print): Use them.
1086 (conflict_report_yacc): New, extracted from...
1087 (conflicts_print): here.
1088 * tests/conflicts.at, tests/existing.at: Adjust.
1089
e8832397
AD
10902002-07-30 Akim Demaille <akim@epita.fr>
1091
1092 Report rules which are never reduced by the parser: those hidden
1093 by conflicts.
1094
1095 * src/LR0.c (save_reductions): Don't make the final state too
1096 different: save its reduction (accept) instead of having a state
1097 without any action (no shift or goto, no reduce).
1098 Note: the final state is now a ``regular'' state, i.e., the
1099 parsers now contain `reduce 0' as default reduction.
1100 Nevertheless, since they decide to `accept' when yystate =
1101 final_state, they still will not reduce rule 0.
1102 * src/print.c (print_actions, print_reduction): Adjust.
1103 * src/output.c (action_row): Track reduced rules.
1104 (token_actions): Report rules never reduced.
1105 * tests/conflicts.at, tests/regression.at: Adjust.
1106
caf23d24
AD
11072002-07-30 Akim Demaille <akim@epita.fr>
1108
1109 `stage' was accidently included in a previous patch.
1110 Initiate its autoconfiscation.
1111
1112 * configure.in: Look for malloc.h and sys/times.h.
1113 * src/main.c (stage): Adjust.
1114 Report only when trace_flag.
1115
640748ee
AD
11162002-07-29 Akim Demaille <akim@epita.fr>
1117
1118 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
1119 state_number_t.
1120 (errs_t): symbol_t*, not symbol_number_t.
1121 (reductions_t): rule_t*, not rule_number_t.
1122 (FOR_EACH_SHIFT): New.
1123 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
1124 * src/print.c, src/print_graph.c: Adjust.
1125
88bce5a2
AD
11262002-07-29 Akim Demaille <akim@epita.fr>
1127
1128 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
1129
1130 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
1131 (endtoken, accept): these.
1132 * src/reader.c (reader): Set endtoken's default tag to "$end".
1133 Set undeftoken's tag to "$undefined" instead of "$undefined.".
1134 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
1135 Adjust.
1136
1bfb97db
AD
11372002-07-29 Akim Demaille <akim@epita.fr>
1138
1139 * src/reduce.c (reduce_grammar): When the language is empty,
1140 complain about the start symbol, not the axiom.
1141 Use its location.
1142 * tests/reduce.at (Empty Language): New.
1143
fc5734fe
AD
11442002-07-26 Akim Demaille <akim@epita.fr>
1145
1146 * src/reader.h, src/reader.c (gram_error): ... can't get
1147 yycontrol without making too strong assumptions on the parser
1148 itself.
1149 * src/output.c (prepare_tokens): Use the real 0th value of
1150 token_translations instead of `0'.
1151 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
1152 visible here.
1153 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
1154 for the time being: %locations ought to provide it to yyerror.
1155
3650b4b8
AD
11562002-07-25 Akim Demaille <akim@epita.fr>
1157
1158 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
1159 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
1160 * tests/regression.at (Web2c Actions): Adjust.
1161
4b3d3a8e
AD
11622002-07-25 Akim Demaille <akim@epita.fr>
1163
1164 Stop storing rules from 1 to nrules + 1.
1165
1166 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
1167 * src/nullable.c, src/output.c, src/print.c, src/reader.c
1168 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
1169 Iterate from 0 to nrules.
1170 Use rule_number_as_item_number and item_number_as_rule_number.
1171 Adjust to `derive' now containing possibly 0.
1172 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
1173 Handle the `- 1' part in rule numbers from/to item numbers.
1174 * src/conflicts.c (log_resolution): Fix the message which reversed
1175 shift and reduce.
1176 * src/output.c (action_row): Initialize default_rule to -1.
1177 (token_actions): Adjust.
1178 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
1179 expected output.
1180 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
1181
4a2a22f4
AD
11822002-07-25 Akim Demaille <akim@epita.fr>
1183
1184 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
1185 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
1186 (b4_c_knr_arg_decl): New.
1187 * data/yacc.c: Use it to define yysymprint, yydestruct, and
1188 yyreport_parse_error.
1189
b8df3223
AD
11902002-07-25 Akim Demaille <akim@epita.fr>
1191
1192 * data/yacc.c (yyreport_parse_error): New, extracted from...
1193 (yyparse): here.
1194 (yydestruct, yysymprint): Move above yyparse.
1195 Be K&R compliant.
1196
a762e609
AD
11972002-07-25 Akim Demaille <akim@epita.fr>
1198
1199 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
1200 replace...
1201 (b4_sint_type, b4_uint_type): these.
1202 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
1203 * tests/regression.at (Web2c Actions): Adjust.
1204
12b0043a
AD
12052002-07-25 Akim Demaille <akim@epita.fr>
1206
1207 * src/gram.h (TIEM_NUMBER_MAX): New.
1208 (item_number_of_rule_number, rule_number_of_item_number): Rename
1209 as...
1210 (rule_number_as_item_number, item_number_as_rule_number): these.
1211 Adjust dependencies.
1212 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
1213 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
1214 (symbol_number_to_vector_number): New.
1215 (order): Of vector_number_t* type.
1216 (base_t, BASE_MAX, BASE_MIN): New.
1217 (froms, tos, width, pos, check): Of base_t type.
1218 (action_number_t, ACTION_MIN, ACTION_MAX): New.
1219 (actrow): Of action_number_t type.
1220 (conflrow): Of unsigned int type.
1221 (table_ninf, base_ninf): New.
1222 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
1223 (muscle_insert_int_table, muscle_insert_base_table)
1224 (muscle_insert_rule_number_table): New.
1225 (prepare_tokens): Output `toknum' as int_table.
1226 (action_row): Returns a rule_number_t.
1227 Use ACTION_MIN, not SHRT_MIN.
1228 (token_actions): yydefact is rule_number_t*.
1229 (table_ninf_remap): New.
1230 (pack_table): Use it for `base' and `table'.
1231 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
1232 replaced with...
1233 (YYPACT_NINF, YYTABLE_NINF): these.
1234 (yypact, yytable): Compute their types instead of hard-coded
1235 `short'.
1236 * tests/regression.at (Web2c Actions): Adjust.
1237
5dde258a
AD
12382002-07-19 Akim Demaille <akim@epita.fr>
1239
1240 * src/scan-gram.l (id): Can start with an underscore.
1241
a945ec39
AD
12422002-07-16 Akim Demaille <akim@epita.fr>
1243
1244 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
1245 Adjust all former `associativity' dependencies.
1246 * src/symtab.c (symbol_new): Default associativity is `undef', not
1247 `right'.
1248 (symbol_check_alias_consistence): Adjust.
1249
fae437e8
AD
12502002-07-09 Akim Demaille <akim@epita.fr>
1251
1252 * doc/bison.texinfo: Properly set the ``header'' part.
1253 Use @dircategory ``GNU programming tools'' as per Texinfo's
1254 documentation.
1255 Use @copying.
1256
1a715ef2
AD
12572002-07-09 Akim Demaille <akim@epita.fr>
1258
1259 * lib/quotearg.h: Protect against multiple inclusions.
1260 * src/location.h (location_t): Add a `file' member.
1261 (LOCATION_RESET, LOCATION_PRINT): Adjust.
1262 * src/complain.c (warn_at, complain_at, fatal_at): Drop
1263 `error_one_per_line' support.
1264
a5d50994
AD
12652002-07-09 Akim Demaille <akim@epita.fr>
1266
1267 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
1268 * src/reader.c (lineno): Remove.
1269 Adjust all dependencies.
1270 (get_merge_function): Take a location and use complain_at.
1271 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
1272 * tests/regression.at (Invalid inputs, Mixing %token styles):
1273 Adjust.
1274
b275314e
AD
12752002-07-09 Akim Demaille <akim@epita.fr>
1276
1277 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
1278 recovery rule, and forbid extensions when --yacc.
1279 (gram_error): Use complain_at.
1280 * src/reader.c (reader): Exit if there were parse errors.
1281
865b9df1
AD
12822002-07-09 Akim Demaille <akim@epita.fr>
1283
1284 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
1285 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
1286 Reported by R Blake <blakers@mac.com>.
1287
c76e14da
AD
12882002-07-09 Akim Demaille <akim@epita.fr>
1289
1290 * data/yacc.c: Output the copyright notive in the header.
1291
7db2ed2d
AD
12922002-07-03 Akim Demaille <akim@epita.fr>
1293
1294 * src/output.c (froms, tos): Are state_number_t.
1295 (save_column): sp, sp1, and sp2 are state_number_t.
1296 (prepare): Rename `final' as `final_state_number', `nnts' as
1297 `nterms_number', `nrules' as `rules_number', `nstates' as
1298 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
1299 unused.
1300 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
1301 * data/lalr1.cc (nsym_): Remove, unused.
1302
e68e0410
AD
13032002-07-03 Akim Demaille <akim@epita.fr>
1304
1305 * src/lalr.h, src/lalr.c (goto_number_t): New.
1306 * src/lalr.c (goto_list_t): New.
1307 Propagate them.
1308 * src/nullable.c (rule_list_t): New.
1309 Propagate.
1310 * src/types.h: Remove.
1311
e1a4f3a4
AD
13122002-07-03 Akim Demaille <akim@epita.fr>
1313
1314 * src/closure.c (print_fderives): Use rule_rhs_print.
1315 * src/derives.c (print_derives): Use rule_rhs_print.
1316 (rule_list_t): New, replaces `shorts'.
1317 (set_derives): Add comments.
1318 * tests/sets.at (Nullable, Firsts): Adjust.
1319
536545f3
AD
13202002-07-03 Akim Demaille <akim@epita.fr>
1321
1322 * src/output.c (prepare_actions): Free `tally' and `width'.
1323 (prepare_actions): Allocate and free `order'.
1324 * src/symtab.c (symbols_free): Free `symbols'.
1325 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
1326 * src/output.c (m4_invoke): Move to...
1327 * src/scan-skel.l: here.
1328 (<<EOF>>): Close yyout, and free its name.
1329
8b752b00
AD
13302002-07-03 Akim Demaille <akim@epita.fr>
1331
1332 Fix some memory leaks, and fix a bug: state 0 was examined twice.
1333
1334 * src/LR0.c (new_state): Merge into...
1335 (state_list_append): this.
1336 (new_states): Merge into...
1337 (generate_states): here.
1338 (set_states): Don't ensure a proper `errs' state member here, do it...
1339 * src/conflicts.c (conflicts_solve): here.
1340 * src/state.h, src/state.c: Comment changes.
1341 (state_t): Rename member `shifts' as `transitions'.
1342 Adjust all dependencies.
1343 (errs_new): For consistency, also take the values as argument.
1344 (errs_dup): Remove.
1345 (state_errs_set): New.
1346 (state_reductions_set, state_transitions_set): Assert that no
1347 previous value was assigned.
1348 (state_free): New.
1349 (states_free): Use it.
1350 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
1351 temporary storage: use `errs' and `nerrs' as elsewhere.
1352 (set_conflicts): Allocate and free this `errs'.
1353
613f5e1a
AD
13542002-07-02 Akim Demaille <akim@epita.fr>
1355
1356 * lib/libiberty.h: New.
1357 * lib: Update the bitset implementation from upstream.
1358 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
1359 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
1360 * src/main.c: Adjust bitset stats calls.
1361
26e0cadc
PE
13622002-07-01 Paul Eggert <eggert@twinsun.com>
1363
1364 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
1365 char, so that negative chars don't collide with $.
1366
1154cced
AD
13672002-06-30 Akim Demaille <akim@epita.fr>
1368
1369 Have the GLR tests be `warning' checked, and fix the warnings.
1370
1371 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
1372 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
1373 (yyremoveDeletes): `yyi' and `yyj' are size_t.
1374 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
1375 (yyaddDeferredAction): static.
1376 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
1377 (yyreportParseError): yyprefix is const.
1378 yytokenp is used only when verbose.
1379 (yy__GNUC__): Replace with __GNUC__.
1380 (yypdumpstack): yyi is size_t.
1381 (yypreference): Un-yy local variables and arguments, to avoid
1382 clashes with `yyr1'. Anyway, we are not in the user name space.
1383 (yytname_size): be an int, as is compared with ints.
1384 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
1385 Use them.
1386 * tests/cxx-gram.at: Use quotation to protect $1.
1387 Use AT_COMPILE to enable warnings hunts.
1388 Prototype yylex and yyerror.
1389 `Use' argc.
1390 Include `string.h', not `strings.h'.
1391 Produce and prototype stmtMerge only when used.
1392 yylex takes a location.
1393
97650f4e
AD
13942002-06-30 Akim Demaille <akim@epita.fr>
1395
1396 We spend a lot of time in quotearg, in particular when --verbose.
1397
1398 * src/symtab.c (symbol_get): Store a quoted version of the key.
1399 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
1400 Adjust all callers.
1401
d2576365
AD
14022002-06-30 Akim Demaille <akim@epita.fr>
1403
1404 * src/state.h (reductions_t): Rename member `nreds' as num.
1405 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
1406 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
1407
ccaf65bc
AD
14082002-06-30 Akim Demaille <akim@epita.fr>
1409
1410 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
1411 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
1412 (shifts_to): Rename as...
1413 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
1414 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
1415 (TRANSITION_IS_DISABLED, transitions_to): these.
1416
87675353
AD
14172002-06-30 Akim Demaille <akim@epita.fr>
1418
1419 * src/print.c (print_shifts, print_gotos): Merge into...
1420 (print_transitions): this.
1421 (print_transitions, print_errs, print_reductions): Align the
1422 lookaheads columns.
1423 (print_core, print_transitions, print_errs, print_state,
1424 print_grammar): Output empty lines separator before, not after.
1425 (state_default_rule_compute): Rename as...
1426 (state_default_rule): this.
1427 * tests/conflicts.at (Defaulted Conflicted Reduction),
1428 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
1429 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
1430
ce4ccb4b
AD
14312002-06-30 Akim Demaille <akim@epita.fr>
1432
1433 Display items as we display rules.
1434
1435 * src/gram.h, src/gram.c (rule_lhs_print): New.
1436 * src/gram.c (grammar_rules_partial_print): Use it.
1437 * src/print.c (print_core): Likewise.
1438 * tests/conflicts.at (Defaulted Conflicted Reduction),
1439 (Unresolved SR Conflicts): Adjust.
1440 (Unresolved SR Conflicts): Adjust and rename as...
1441 (Resolved SR Conflicts): this, as was meant.
1442 * tests/regression.at (Web2c Report): Adjust.
1443
bc933ef1
AD
14442002-06-30 Akim Demaille <akim@epita.fr>
1445
1446 * src/print.c (state_default_rule_compute): New, extracted from...
1447 (print_reductions): here.
1448 Pessimize, but clarify the code.
1449 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
1450
53d4308d
AD
14512002-06-30 Akim Demaille <akim@epita.fr>
1452
1453 * src/output.c (action_row): Let default_rule be always a rule
1454 number.
1455
574fb2d5
AD
14562002-06-30 Akim Demaille <akim@epita.fr>
1457
1458 * src/closure.c (print_firsts, print_fderives, closure):
1459 Use BITSET_EXECUTE.
1460 * src/lalr.c (lookaheads_print): Likewise.
1461 * src/state.c (state_rule_lookaheads_print): Likewise.
1462 * src/print_graph.c (print_core): Likewise.
1463 * src/print.c (print_reductions): Likewise.
1464 * src/output.c (action_row): Likewise.
1465 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
1466
05811fd7
AD
14672002-06-30 Akim Demaille <akim@epita.fr>
1468
1469 * src/print_graph.c: Use report_flag.
1470
0e4d5753
AD
14712002-06-30 Akim Demaille <akim@epita.fr>
1472
1473 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
1474 to...
1475 * src/relation.h, src/relation.c (traverse, relation_digraph)
1476 (relation_print, relation_transpose): New.
1477
24c7d800
AD
14782002-06-30 Akim Demaille <akim@epita.fr>
1479
1480 * src/state.h, src/state.c (shifts_to): New.
1481 * src/lalr.c (build_relations): Use it.
1482
9222837b
AD
14832002-06-30 Akim Demaille <akim@epita.fr>
1484
1485 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
1486 (item_number_of_rule_number, rule_number_of_item_number): New.
1487 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
1488 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
1489 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
1490 Propagate their use.
1491 Much remains to be done, in particular wrt `shorts' from types.h.
1492
260008e5
AD
14932002-06-30 Akim Demaille <akim@epita.fr>
1494
1495 * src/symtab.c (symbol_new): Initialize the `printer' member.
1496
8a731ca8
AD
14972002-06-30 Akim Demaille <akim@epita.fr>
1498
1499 * src/LR0.c (save_reductions): Remove, replaced by...
1500 * src/state.h, src/state.c (state_reductions_set): New.
1501 (reductions, errs): Rename as...
1502 (reductions_t, errs_t): these.
1503 Adjust all dependencies.
1504
32e1e0a4
AD
15052002-06-30 Akim Demaille <akim@epita.fr>
1506
1507 * src/LR0.c (state_list_t, state_list_append): New.
1508 (first_state, last_state): Now symbol_list_t.
1509 (this_state): Remove.
1510 (new_itemsets, append_states, save_reductions): Take a state_t as
1511 argument.
1512 (set_states, generate_states): Adjust.
1513 (save_shifts): Remove, replaced by...
1514 * src/state.h, src/state.c (state_shifts_set): New.
1515 (shifts): Rename as...
1516 (shifts_t): this.
1517 Adjust all dependencies.
1518 * src/state.h (state_t): Remove the `next' member.
1519
e5fb6710
AD
15202002-06-30 Akim Demaille <akim@epita.fr>
1521
1522 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
1523 escaped in slot 0.
1524
c7ca99d4
AD
15252002-06-30 Akim Demaille <akim@epita.fr>
1526
1527 Use hash.h for the state hash table.
1528
1529 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
1530 (allocate_storage): Use state_hash_new.
1531 (free_storage): Use state_hash_free.
1532 (new_state, get_state): Adjust.
1533 * src/lalr.h, src/lalr.c (states): Move to...
1534 * src/states.h (state_t): Remove the `link' member, no longer
1535 used.
1536 * src/states.h, src/states.c: here.
1537 (state_hash_new, state_hash_free, state_hash_lookup)
1538 (state_hash_insert, states_free): New.
1539 * src/states.c (state_table, state_compare, state_hash): New.
1540 * src/output.c (output_actions): Do not free states now, since we
1541 still need to know the final_state number in `prepare', called
1542 afterwards. Do it...
1543 * src/main.c (main): here: call states_free after `output'.
1544
df0e7316
AD
15452002-06-30 Akim Demaille <akim@epita.fr>
1546
1547 * src/state.h, src/state.c (state_new): New, extracted from...
1548 * src/LR0.c (new_state): here.
1549 * src/state.h (STATE_ALLOC): Move to...
1550 * src/state.c: here.
1551 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
1552 * src/state.h, src/state.c: here.
1553
39f41916
AD
15542002-06-30 Akim Demaille <akim@epita.fr>
1555
1556 * src/reader.c (gensym): Rename as...
1557 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
1558 (getsym): Rename as...
1559 (symbol_get): this.
1560
d57650a5
AD
15612002-06-30 Akim Demaille <akim@epita.fr>
1562
1563 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
1564 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
1565 * src/output.c, src/print.c, src/print_graph.c: Propagate.
1566 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
1567
5a08f1ce
AD
15682002-06-30 Akim Demaille <akim@epita.fr>
1569
1570 Make the test suite pass with warnings checked.
1571
1572 * tests/actions.at (Printers and Destructors): Improve.
1573 Avoid unsigned vs. signed issues.
1574 * tests/calc.at: Don't exercise the scanner here, do it...
1575 * tests/input.at (Torturing the Scanner): here.
1576
720623af
PH
15772002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1578
88e7e941 1579 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
720623af
PH
1580 reorganize first lines parallel to yacc.c.
1581
fb8135fa
AD
15822002-06-28 Akim Demaille <akim@epita.fr>
1583
1584 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
1585 (b4_token_enum, b4_token_defines): New, factored from...
1586 * data/lalr1.cc, data/yacc.c, glr.c: here.
1587
41442480
AD
15882002-06-28 Akim Demaille <akim@epita.fr>
1589
1590 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
1591 unused variables.
1592 * src/output.c (merger_output): static.
1593
e0e5bf84
AD
15942002-06-28 Akim Demaille <akim@epita.fr>
1595
1596 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
1597 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
1598 pacify GCC.
1599 * src/output.c (save_row): Initialize all the variables to pacify GCC.
e0e5bf84 1600
676385e2
PH
16012002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1602
1603 Accumulated changelog for new GLR parsing features.
1604
6a254321 1605 * src/conflicts.c (count_total_conflicts): Change name to
676385e2
PH
1606 conflicts_total_count.
1607 * src/conflicts.h: Ditto.
1608 * src/output.c (token_actions): Use the new name.
1609 (output_conflicts): Change conflp => conflict_list_heads, and
1610 confl => conflict_list for better readability.
1611 * data/glr.c: Use the new names.
1612 * NEWS: Add self to GLR announcement.
e0e5bf84 1613
676385e2
PH
1614 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
1615
1616 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
1617 Akim Demaille.
1618
1619 * data/bison.glr: Change name to glr.c
1620 * data/glr.c: Renamed from bison.glr.
1621 * data/Makefile.am: Add glr.c
e0e5bf84
AD
1622
1623 * src/getargs.c:
1624
676385e2
PH
1625 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
1626 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
e0e5bf84 1627
676385e2
PH
1628 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1629
1630 * data/bison.glr: Be sure to restore the
1631 current #line when returning to the skeleton contents after having
1632 exposed the input file's #line.
1633
1634 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1635
1636 * data/bison.glr: Bring up to date with changes to bison.simple.
1637
1638 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1639
1640 * data/bison.glr: Correct definitions that use b4_prefix.
1641 Various reformatting.
1642 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
1643 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
1644 yytokenp argument; now part of stack.
1645 (yychar): Define to behave as documented.
1646 (yyclearin): Ditto.
e0e5bf84 1647
676385e2
PH
1648 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1649
1650 * src/reader.h: Add declaration for free_merger_functions.
1651
1652 * src/reader.c (merge_functions): New variable.
1653 (get_merge_function): New function.
1654 (free_merger_functions): New function.
1655 (readgram): Check for %prec that is not followed by a symbol.
1656 Handle %dprec and %merge declarations.
1657 (packgram): Initialize dprec and merger fields in rules array.
1658
1659 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
1660 conflict_list_cnt, conflict_list_free): New variables.
1661 (table_grow): Also grow conflict_table.
e0e5bf84 1662 (prepare_rules): Output dprec and merger tables.
676385e2 1663 (conflict_row): New function.
e0e5bf84 1664 (action_row): Output conflict lists for GLR parser. Don't use
676385e2
PH
1665 default reduction in conflicted states for GLR parser so that there
1666 are spaces for the conflict lists.
1667 (save_row): Also save conflict information.
1668 (token_actions): Allocate conflict list.
1669 (merger_output): New function.
1670 (pack_vector): Pack conflict table, too.
1671 (output_conflicts): New function to output yyconflp and yyconfl.
1672 (output_check): Allocate conflict_tos.
1673 (output_actions): Output conflict tables, also.
1674 (output_skeleton): Output b4_mergers definition.
1675 (prepare): Output b4_max_rhs_length definition.
1676 Use 'bison.glr' as default skeleton for GLR parsers.
1677
1678 * src/gram.c (glr_parser): New flag.
1679 (grammar_free): Call free_merger_functions.
1680
1681 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
1682 all pairs of conflicting reductions, rather than just all tokens
1683 causing conflicts. Needed to size conflict tables.
e0e5bf84 1684 (conflicts_output): Modify call to count_rr_conflicts for new
676385e2
PH
1685 interface.
1686 (conflicts_print): Ditto.
1687 (count_total_conflicts): New function.
1688
1689 * src/reader.h (merger_list): New type.
1690 (merge_functions): New variable.
1691
1692 * src/lex.h (tok_dprec, tok_merge): New token types.
1693
1694 * src/gram.h (rule_s): Add dprec and merger fields.
1695 (glr_parser): New flag.
1696
1697 * src/conflicts.h (count_total_conflicts): New function.
1698
1699 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
1700
1701 * doc/bison.texinfo (Generalized LR Parsing): New section.
1702 (GLR Parsers): New section.
1703 (Language and Grammar): Mention GLR parsing.
1704 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
1705 Correct typo ("tge" -> "the").
1706
1707 * data/bison.glr: New skeleton for GLR parsing.
1708
1709 * tests/cxx-gram.at: New tests for GLR parsing.
1710
1711 * tests/testsuite.at: Include cxx-gram.at.
1712
1713 * tests/Makefile.am: Add cxx-gram.at.
e0e5bf84 1714
676385e2
PH
1715 * src/parse-gram.y:
1716
1717 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
1718
1719 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
e0e5bf84 1720
b5480d74 17212002-06-27 Akim Demaille <akim@epita.fr>
e2aaf4c4
AD
1722
1723 * src/options.h, src/options.c: Remove.
1724 * src/getargs.c (short_options, long_options): New.
1725
60491a94
AD
17262002-06-27 Akim Demaille <akim@epita.fr>
1727
1728 * data/bison.simple, data/bison.c++: Rename as...
1729 * data/yacc.c, data/lalr1.cc: these.
1730 * doc/bison.texinfo (Environment Variables): Remove.
1731
9be0c25b
AD
17322002-06-25 Raja R Harinath <harinath@cs.umn.edu>
1733
1734 * src/getargs.c (report_argmatch): Initialize strtok().
1735
1ae72863
AD
17362002-06-20 Akim Demaille <akim@epita.fr>
1737
1738 * data/bison.simple (b4_symbol_actions): New, replaces...
1739 (b4_symbol_destructor, b4_symbol_printer): these.
1740 (yysymprint): Be sure to call YYPRINT only for tokens, and using
1741 user token numbers.
1742
87542d29
AD
17432002-06-20 Akim Demaille <akim@epita.fr>
1744
1745 * data/bison.simple (yydestructor): Rename as...
1746 (yydestruct): this.
1747
1a31ed21
AD
17482002-06-20 Akim Demaille <akim@epita.fr>
1749
1750 * src/symtab.h, src/symtab.c (symbol_type_set)
1751 (symbol_destructor_set, symbol_precedence_set): The location is
1752 the last argument.
1753 Adjust all callers.
1754
e776192e
AD
17552002-06-20 Akim Demaille <akim@epita.fr>
1756
1757 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
1758 internals.
1759 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
1760 Takes a location.
1761 * src/symtab.h, src/symtab.c (symbol_class_set)
1762 (symbol_user_token_number_set): Likewise.
1763 Adjust all callers.
1764 Promote complain_at.
1765 * tests/input.at (Type Clashes): Adjust.
1766
5c1180b3
AD
17672002-06-20 Akim Demaille <akim@epita.fr>
1768
1769 * data/bison.simple (YYLEX): Fix the declaration when
1770 %pure-parser.
1771
e3170060
AD
17722002-06-20 Akim Demaille <akim@epita.fr>
1773
1774 * data/bison.simple (yysymprint): Don't print the token number,
1775 just its name.
1776 * tests/actions.at (Destructors): Rename as...
1777 (Printers and Destructors): this.
1778 Also exercise %printer.
1779
253862fd
AD
17802002-06-20 Akim Demaille <akim@epita.fr>
1781
1782 * data/bison.simple (YYDSYMPRINT): New.
1783 Use it to remove many of the #if YYDEBUG/if (yydebug).
1784
366eea36
AD
17852002-06-20 Akim Demaille <akim@epita.fr>
1786
1787 * src/symtab.h, src/symtab.c (symbol_t): printer and
1788 printer_location are new members.
1789 (symbol_printer_set): New.
1790 * src/parse-gram.y (PERCENT_PRINTER): New token.
1791 Handle its associated rule.
1792 * src/scan-gram.l: Adjust.
1793 (handle_destructor_at, handle_destructor_dollar): Rename as...
1794 (handle_symbol_code_at, handle_symbol_code_dollar): these.
1795 * src/output.c (symbol_printers_output): New.
1796 (output_skeleton): Call it.
1797 * data/bison.simple (yysymprint): New. Cannot be named yyprint
1798 since there are already many grammar files with a user `yyprint'.
1799 Replace the calls to YYPRINT to calls to yysymprint.
1800 * tests/calc.at: Adjust.
1801 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
1802 taking advantage of parser very internal details (stack size!).
1803
4f25ebb0
AD
18042002-06-20 Akim Demaille <akim@epita.fr>
1805
1806 * src/scan-gram.l: Complete the scanner with the missing patterns
1807 to pacify Flex.
1808 Use `quote' and `symbol_tag_get' where appropriate.
1809
93b68a0e
AD
18102002-06-19 Akim Demaille <akim@epita.fr>
1811
1812 * tests/actions.at (Destructors): Augment to test locations.
1813 * data/bison.simple (yydestructor): Pass it the current location
1814 if locations are enabled.
1815 Prototype only when __STDC__ or C++.
1816 Change the argument names to move into the yy name space: there is
1817 user code here.
1818
58612f1d
AD
18192002-06-19 Akim Demaille <akim@epita.fr>
1820
74310291
AD
1821 * data/bison.simple (b4_pure_if): New.
1822 Use it instead of #ifdef YYPURE.
1823
18242002-06-19 Akim Demaille <akim@epita.fr>
1825
1826 * data/bison.simple (b4_location_if): New.
58612f1d
AD
1827 Use it instead of #ifdef YYLSP_NEEDED.
1828
f25bfb75
AD
18292002-06-19 Akim Demaille <akim@epita.fr>
1830
1831 Prepare @$ in %destructor, but currently don't bind it in the
1832 skeleton, as %location use is not cleaned up yet.
1833
1834 * src/scan-gram.l (handle_dollar, handle_destructor_at)
1835 (handle_action_at): New.
1836 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
1837 a braced_code_t and a location as additional arguments.
1838 (handle_destructor_dollar): Instead of requiring `b4_eval', just
1839 unquote one when outputting `b4_dollar_dollar'.
1840 Adjust callers.
1841 * data/bison.simple (b4_eval): Remove.
1842 (b4_symbol_destructor): Adjust.
1843 * tests/input.at (Invalid @n): Adjust.
1844
c732d2c6
AD
18452002-06-19 Zack Weinberg <zack@codesourcery.com>
1846
1847 * doc/bison.texinfo: Document ability to have multiple
1848 prologue sections.
1849
8c165d89
AD
18502002-06-18 Akim Demaille <akim@epita.fr>
1851
1852 * src/files.c (compute_base_names): When computing the output file
1853 names from the input file name, strip the directory part.
1854
ca98bf57
AD
18552002-06-18 Akim Demaille <akim@epita.fr>
1856
1857 * data/bison.simple.new: Comment changes.
1858 Reported by Andreas Schwab.
1859
0bfb02ff
AD
18602002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
1861
1862 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
1863 there are no `label `yyoverflowlab' defined but not used' warnings
1864 when yyoverflow is defined.
1865
24c0aad7
AD
18662002-06-18 Akim Demaille <akim@epita.fr>
1867
1868 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
1869 new member.
1870 (symbol_destructor_set): Adjust.
1871 * src/output.c (symbol_destructors_output): Output the destructor
1872 locations.
1873 Output the symbol name.
1874 * data/bison.simple (b4_symbol_destructor): Adjust.
1875
5719c109
AD
18762002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
1877 and Akim Demaille <akim@epita.fr>
1878
1879 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
1880 what's left on the stack when the error recovery hits EOF.
1881 * tests/actions.at (Destructors): Complete to exercise this case.
1882
9280d3ef
AD
18832002-06-17 Akim Demaille <akim@epita.fr>
1884
1885 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
1886 arguments is really empty, not only equal to `[]'.
1887 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
1888 member.
1889 (symbol_destructor_set): New.
1890 * src/output.c (symbol_destructors_output): New.
1891 * src/reader.h (brace_code_t, current_braced_code): New.
1892 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
1893 (handle_dollar): Rename as...
1894 (handle_action_dollar): this.
1895 (handle_destructor_dollar): New.
1896 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
1897 (grammar_declaration): Use it.
1898 * data/bison.simple (yystos): Is always defined.
1899 (yydestructor): New.
1900 * tests/actions.at (Destructors): New.
1901 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
1902
dafdc66f
AD
19032002-06-17 Akim Demaille <akim@epita.fr>
1904
1905 * src/symlist.h, src/symlist.c (symbol_list_length): New.
1906 * src/scan-gram.l (handle_dollar, handle_at): Compute the
1907 rule_length only when needed.
1908 * src/output.c (actions_output, token_definitions_output): Output
1909 the full M4 block.
1910 * src/symtab.c: Don't access directly to the symbol tag, use
1911 symbol_tag_get.
1912 * src/parse-gram.y: Use symbol_list_free.
1913
56c47203
AD
19142002-06-17 Akim Demaille <akim@epita.fr>
1915
1916 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
1917 (symbol_list_prepend, get_type_name): Move to...
1918 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
1919 (symbol_list_prepend, symbol_list_n_type_name_get): here.
1920 Adjust all callers.
1921 (symbol_list_free): New.
1922 * src/scan-gram.l (handle_dollar): Takes a location.
1923 * tests/input.at (Invalid $n): Adjust.
1924
1e0bab92
AD
19252002-06-17 Akim Demaille <akim@epita.fr>
1926
1927 * src/reader.h, src/reader.c (symbol_list_new): Export it.
1928 (symbol_list_prepend): New.
1929 * src/parse-gram.y (%union): `list' is a new member.
1930 (symbols.1): New, replaces...
1931 (terms_to_prec.1, nterms_to_type.1): these.
1932 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
1933 Take a location as additional argument.
1934 Adjust all callers.
1935
04e60654
AD
19362002-06-15 Akim Demaille <akim@epita.fr>
1937
1938 * src/parse-gram.y: Move %token in the declaration section so that
1939 we don't depend upon CVS Bison.
1940
10e5b8bd
AD
19412002-06-15 Akim Demaille <akim@epita.fr>
1942
1943 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
1944 * src/print.c (print_core): Use it.
1945
9801d40c
AD
19462002-06-15 Akim Demaille <akim@epita.fr>
1947
1948 * src/conflicts.c (log_resolution): Accept the rule involved in
1949 the sr conflicts instead of the lookahead number that points to
1950 that rule.
1951 (flush_reduce): Accept the current lookahead vector as argument,
1952 instead of the index in LA.
1953 (resolve_sr_conflict): Accept the current number of lookahead
1954 bitset to consider for the STATE, instead of the index in LA.
1955 (set_conflicts): Adjust.
1956 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
1957
c0263492
AD
19582002-06-15 Akim Demaille <akim@epita.fr>
1959
1960 * src/state.h (state_t): Replace the `lookaheadsp' member, a
1961 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
1962 Adjust all dependencies.
1963 * src/lalr.c (initialize_lookaheads): Split into...
1964 (states_lookaheads_count, states_lookaheads_initialize): these.
1965 (lalr): Adjust.
1966
9757c359
AD
19672002-06-15 Akim Demaille <akim@epita.fr>
1968
1969 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
1970 out of...
1971 (grammar_rules_print): here.
1972 * src/reduce.c (reduce_output): Use it.
1973 * tests/reduce.at (Useless Rules, Reduced Automaton)
1974 (Underivable Rules): Adjust.
1975
6b98e4b5
AD
19762002-06-15 Akim Demaille <akim@epita.fr>
1977
1978 Copy BYacc's nice way to report the grammar.
1979
1980 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
1981 New.
1982 Don't print the rules' location, it is confusing and useless.
1983 (rule_print): Use grammar_rhs_print.
1984 * src/print.c (print_grammar): Use grammar_rules_print.
1985
6b98e4b5
AD
19862002-06-15 Akim Demaille <akim@epita.fr>
1987
1988 Complete and rationalize `useless thing' warnings.
1989
1990 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
1991 (symbol_tag_print): New.
1992 Use them everywhere in place of accessing directly the tag member.
1993 * src/gram.h, src/gram.c (rule_print): New.
1994 Use it where a rule used to be printed `by hand'.
1995 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
1996 (reduce_grammar_tables): Report the useless rules.
1997 (reduce_print): Useless things are a warning, not an error.
1998 Report it as such.
1999 * tests/reduce.at (Useless Nonterminals, Useless Rules):
2000 (Reduced Automaton, Underivable Rules): Adjust.
2001 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
2002 * tests/conflicts.at (Unresolved SR Conflicts)
2003 (Solved SR Conflicts): Adjust.
2004
ee000ba4
AD
20052002-06-15 Akim Demaille <akim@epita.fr>
2006
2007 Let symbols have a location.
2008
2009 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
2010 (getsym): Adjust.
2011 Adjust all callers.
2012 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
2013 Use location_t, not int.
2014 * src/symtab.c (symbol_check_defined): Take advantage of the
2015 location.
2016 * tests/regression.at (Invalid inputs): Adjust.
2017
8efe435c
AD
20182002-06-15 Akim Demaille <akim@epita.fr>
2019
2020 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
2021 (input): Don't try to initialize yylloc here, do it in the
2022 scanner.
2023 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
2024 * src/gram.h (rule_t): Change line and action_line into location
2025 and action_location, of location_t type.
2026 Adjust all dependencies.
2027 * src/location.h, src/location.c (empty_location): New.
2028 * src/reader.h, src/reader.c (grammar_start_symbol_set)
2029 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
2030 (grammar_current_rule_symbol_append)
2031 (grammar_current_rule_action_append): Expect a location as argument.
2032 * src/reader.c (grammar_midrule_action): Adjust to attach an
2033 action's location as dummy symbol location.
2034 * src/symtab.h, src/symtab.c (startsymbol_location): New.
2035 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
2036 the line numbers.
2037
1921f1d7
AD
20382002-06-14 Akim Demaille <akim@epita.fr>
2039
2040 Grammar declarations may be found in the grammar section.
2041
2042 * src/parse-gram.y (rules_or_grammar_declaration): New.
2043 (declarations): Each declaration may end with a semicolon, not
2044 just...
2045 (grammar_declaration): `"%union"'.
2046 (grammar): Branch to rules_or_grammar_declaration.
2047
4515534c
AD
20482002-06-14 Akim Demaille <akim@epita.fr>
2049
2050 * src/main.c (main): Invoke scanner_free.
2051
f958596b
AD
20522002-06-14 Akim Demaille <akim@epita.fr>
2053
2054 * src/output.c (m4_invoke): Extracted from...
2055 (output_skeleton): here.
2056 Free tempfile.
2057
2c569025
AD
20582002-06-14 Akim Demaille <akim@epita.fr>
2059
2060 * src/parse-gram.y (directives, directive, gram)
2061 (grammar_directives, precedence_directives, precedence_directive):
2062 Rename as...
2063 (declarations, declaration, grammar, grammar_declaration)
2064 (precedence_declaration, precedence_declarator): these.
2065 (symbol_declaration): New.
2066
592e8d4d
AD
20672002-06-14 Akim Demaille <akim@epita.fr>
2068
2069 * src/files.c (action_obstack): Remove, unused.
2070 (output_obstack): Remove it, and all its dependencies, as it is no
2071 longer needed.
2072 * src/reader.c (epilogue_set): Build the epilogue in the
2073 muscle_obstack.
2074 * src/output.h, src/output.c (muscle_obstack): Move to...
2075 * src/muscle_tab.h, src/muscle_tab.h: here.
2076 (muscle_init): Initialize muscle_obstack.
2077 (muscle_free): New.
2078 * src/main.c (main): Call it.
2079
0c15323d
AD
20802002-06-14 Akim Demaille <akim@epita.fr>
2081
2082 * src/location.h: New, extracted from...
2083 * src/reader.h: here.
2084 * src/Makefile.am (noinst_HEADERS): Merge into
2085 (bison_SOURCES): this.
2086 Add location.h.
2087 * src/parse-gram.y: Use location_t instead of Bison's.
2088 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
2089 Use location_t instead of ints.
2090
e96c9728
AD
20912002-06-14 Akim Demaille <akim@epita.fr>
2092
2093 * data/bison.simple, data/bison.c++: Be sure to restore the
2094 current #line when returning to the skeleton contents after having
2095 exposed the input file's #line.
2096
75d1fe16
AD
20972002-06-12 Akim Demaille <akim@epita.fr>
2098
2099 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
2100 eager.
2101 * tests/actions.at (Exotic Dollars): New.
2102
6c35d22c
AD
21032002-06-12 Akim Demaille <akim@epita.fr>
2104
2105 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
2106 ['"/] too eagerly.
2107 * tests/input.at (Torturing the Scanner): New.
2108
1d6412ad
AD
21092002-06-11 Akim Demaille <akim@epita.fr>
2110
2111 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
2112 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
2113 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
2114 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
2115 * src/reader.c (reader): Use it.
2116
4cdb01db
AD
21172002-06-11 Akim Demaille <akim@epita.fr>
2118
2119 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
2120 Adjust all callers.
2121 (scanner_last_string_free): New.
2122
44995b2e
AD
21232002-06-11 Akim Demaille <akim@epita.fr>
2124
2125 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
2126 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
2127 (last_string, YY_OBS_FREE): New.
2128 Use them when returning an ID.
2129
e9955c83
AD
21302002-06-11 Akim Demaille <akim@epita.fr>
2131
2132 Have Bison grammars parsed by a Bison grammar.
2133
2134 * src/reader.c, src/reader.h (prologue_augment): New.
2135 * src/reader.c (copy_definition): Remove.
2136
2137 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
2138 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
2139 (grammar_current_rule_prec_set, grammar_current_rule_check)
2140 (grammar_current_rule_symbol_append)
2141 (grammar_current_rule_action_append): Export.
2142 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
2143 (symbol_list_action_append): Remove.
2144 Hook the routines from reader.
2145 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
2146 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
2147
2148 * src/reader.c (read_declarations): Remove, unused.
2149
2150 * src/parse-gram.y: Handle the epilogue.
2151 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
2152 (grammar_start_symbol_set): this.
2153 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
2154 * src/reader.c (readgram): Remove, unused.
2155 (reader): Adjust to insert eoftoken and axiom where appropriate.
2156
2157 * src/reader.c (copy_dollar): Replace with...
2158 * src/scan-gram.h (handle_dollar): this.
2159 * src/parse-gram.y: Remove `%thong'.
2160
2161 * src/reader.c (copy_at): Replace with...
2162 * src/scan-gram.h (handle_at): this.
2163
2164 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
2165 New.
2166
2167 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
2168 time being.
2169
2170 * src/reader.h, src/reader.c (grammar_rule_end): New.
2171
2172 * src/parse.y (current_type, current_class): New.
2173 Implement `%nterm', `%token' support.
2174 Merge `%term' into `%token'.
2175 (string_as_id): New.
2176 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
2177 type name.
2178
2179 * src/parse-gram.y: Be sure to handle properly the beginning of
2180 rules.
2181
2182 * src/parse-gram.y: Handle %type.
2183 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
2184
2185 * src/parse-gram.y: More directives support.
2186 * src/options.c: No longer handle source directives.
2187
2188 * src/parse-gram.y: Fix %output.
2189
2190 * src/parse-gram.y: Handle %union.
2191 Use the prologue locations.
2192 * src/reader.c (parse_union_decl): Remove.
2193
2194 * src/reader.h, src/reader.c (epilogue_set): New.
2195 * src/parse-gram.y: Use it.
2196
2197 * data/bison.simple, data/bison.c++: b4_stype is now either not
2198 defined, then default to int, or to the contents of %union,
2199 without `union' itself.
2200 Adjust.
2201 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
2202
2203 * src/output.c (actions_output): Don't output braces, as they are
2204 already handled by the scanner.
2205
2206 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
2207 characters to themselves.
2208
2209 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
2210 that the epilogue has a proper #line.
2211
2212 * src/parse-gram.y: Handle precedence/associativity.
2213
2214 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
2215 a terminal.
2216 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
2217 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
2218 at all to define terminals that cannot be emitted.
2219
2220 * src/scan-gram.l: Escape M4 characters.
2221
2222 * src/scan-gram.l: Working properly with escapes in user
2223 strings/characters.
2224
2225 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
2226 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
2227 grammar.
2228 Use more modest sizes, as for the time being the parser does not
2229 release memory, and therefore the process swallows a huge amount
2230 of memory.
2231
2232 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
2233 stricter %token grammar.
2234
2235 * src/symtab.h (associativity): Add `undef_assoc'.
2236 (symbol_precedence_set): Do nothing when passed an undef_assoc.
2237 * src/symtab.c (symbol_check_alias_consistence): Adjust.
2238
2239 * tests/regression.at (Invalid %directive): Remove, as it is now
2240 meaningless.
2241 (Invalid inputs): Adjust to the new error messages.
2242 (Token definitions): The new grammar doesn't allow too many
2243 eccentricities.
2244
2245 * src/lex.h, src/lex.c: Remove.
2246 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
2247 (copy_character, copy_string2, copy_string, copy_identifier)
2248 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
2249 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
2250 (parse_action): Remove.
2251 * po/POTFILES.in: Adjust.
2252
2e047461
AD
22532002-06-11 Akim Demaille <akim@epita.fr>
2254
2255 * src/reader.c (parse_action): Don't store directly into the
2256 rule's action member: return the action as a string.
2257 Don't require `rule_length' as an argument: compute it.
2258 (grammar_current_rule_symbol_append)
2259 (grammar_current_rule_action_append): New, eved out from
2260 (readgram): here.
2261 Remove `action_flag', `rulelength', unused now.
2262
9af3fbce
AD
22632002-06-11 Akim Demaille <akim@epita.fr>
2264
2265 * src/reader.c (grammar_current_rule_prec_set).
2266 (grammar_current_rule_check): New, eved out from...
2267 (readgram): here.
2268 Remove `xaction', `first_rhs': useless.
2269 * tests/input.at (Type clashes): New.
2270 * tests/existing.at (GNU Cim Grammar): Adjust.
2271
1485e106
AD
22722002-06-11 Akim Demaille <akim@epita.fr>
2273
2274 * src/reader.c (grammar_midrule_action): New, Eved out from
2275 (readgram): here.
2276
da4160c3
AD
22772002-06-11 Akim Demaille <akim@epita.fr>
2278
2279 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
2280 New.
2281 (readgram): Use them as replacement of inlined code, crule and
2282 crule1.
2283
f6d0f937
AD
22842002-06-11 Akim Demaille <akim@epita.fr>
2285
2286 * src/reader.c (grammar_end, grammar_symbol_append): New.
2287 (readgram): Use them.
2288 Make the use of `p' as local as possible.
2289
69078d4b
AD
22902002-06-10 Akim Demaille <akim@epita.fr>
2291
2292 GCJ's parser requires the tokens to be defined before the prologue.
2293
2294 * data/bison.simple: Output the token definition before the user's
2295 prologue.
2296 * tests/regression.at (Braces parsing, Duplicate string)
2297 (Mixing %token styles): Check the output from bison.
2298 (Early token definitions): New.
2299
5e424082
AD
23002002-06-10 Akim Demaille <akim@epita.fr>
2301
2302 * src/symtab.c (symbol_user_token_number_set): Don't complain when
2303 assigning twice the same user number to a token, so that we can
2304 use it in...
2305 * src/lex.c (lex): here.
2306 Also use `symbol_class_set' instead of hand written code.
2307 * src/reader.c (parse_assoc_decl): Likewise.
2308
44536b35
AD
23092002-06-10 Akim Demaille <akim@epita.fr>
2310
2311 * src/symtab.c, src/symtab.c (symbol_class_set)
2312 (symbol_user_token_number_set): New.
2313 * src/reader.c (parse_token_decl): Use them.
2314 Use a switch instead of ifs.
2315 Use a single argument.
2316
8b9f2372
AD
23172002-06-10 Akim Demaille <akim@epita.fr>
2318
2319 Remove `%thong' support as it is undocumented, unused, duplicates
2320 `%token's job, and creates useless e-mail traffic with people who
2321 want to know what it is, why it is undocumented, unused, and
2322 duplicates `%token's job.
2323
2324 * src/reader.c (parse_thong_decl): Remove.
2325 * src/options.c (option_table): Remove "thong".
2326 * src/lex.h (tok_thong): Remove.
2327
3ae2b51f
AD
23282002-06-10 Akim Demaille <akim@epita.fr>
2329
2330 * src/symtab.c, src/symtab.c (symbol_type_set)
2331 (symbol_precedence_set): New.
2332 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
2333 (value_components_used): Remove, unused.
2334
2f1afb73
AD
23352002-06-09 Akim Demaille <akim@epita.fr>
2336
2337 Move symbols handling code out of the reader.
2338
2339 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
2340 (axiom): Move to...
2341 * src/symtab.h, src/symtab.c: here.
2342
2343 * src/gram.c (start_symbol): Remove: use startsymbol->number.
2344 * src/reader.c (startval): Rename as...
2345 * src/symtab.h, src/symtab.c (startsymbol): this.
2346 * src/reader.c: Adjust.
2347
2348 * src/reader.c (symbol_check_defined, symbol_make_alias)
2349 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2350 (token_translations_init)
2351 Move to...
2352 * src/symtab.c: here.
2353 * src/reader.c (packsymbols): Move to...
2354 * src/symtab.h, src/symtab.c (symbols_pack): here.
2355 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
2356 argument.
2357
e9bca3ad
AD
23582002-06-03 Akim Demaille <akim@epita.fr>
2359
2360 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
2361 then statements.
2362
86eff183
AD
23632002-06-03 Akim Demaille <akim@epita.fr>
2364
2365 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
2366 structs with non literals.
2367 * src/scan-skel.l: never-interactive.
2368 * src/conflicts.c (enum conflict_resolution_e): No trailing
2369 comma.
2370 * src/getargs.c (usage): Split long literal strings.
2371 Reported by Hans Aberg.
2372
717be197
AD
23732002-05-28 Akim Demaille <akim@epita.fr>
2374
2375 * data/bison.c++: Use C++ ostreams.
2376 (cdebug_): New member.
2377
670ddffd
AD
23782002-05-28 Akim Demaille <akim@epita.fr>
2379
2380 * src/output.c (output_skeleton): Be sure to allocate enough room
2381 for `/' _and_ for `\0' in full_skeleton.
2382
769b430f
AD
23832002-05-28 Akim Demaille <akim@epita.fr>
2384
2385 * data/bison.c++: Catch up with bison.simple:
2386 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2387 and Paul Eggert <eggert@twinsun.com>: `error' handing.
2388 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
2389 and popping traces.
2390
7067cb36
PH
23912002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2392
2393 * src/output.c (output_skeleton): Put an explicit path in front of
2394 the skeleton file name, rather than relying on the -I directory,
2395 to partially alleviate effects of having a skeleton file lying around
2396 in the current directory.
769b430f 2397
4a713ec2
PH
23982002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2399
769b430f 2400 * src/conflicts.c (log_resolution): Correct typo:
4a713ec2
PH
2401 obstack_printf should be obstack_fgrow1.
2402
b408954b
AD
24032002-05-26 Akim Demaille <akim@epita.fr>
2404
2405 * src/state.h (state_t): `solved_conflicts' is a new member.
2406 * src/LR0.c (new_state): Set it to 0.
2407 * src/conflicts.h, src/conflicts.c (print_conflicts)
2408 (free_conflicts, solve_conflicts): Rename as...
2409 (conflicts_print, conflicts_free, conflicts_solve): these.
2410 Adjust callers.
2411 * src/conflicts.c (enum conflict_resolution_e)
2412 (solved_conflicts_obstack): New, used by...
2413 (log_resolution): this.
2414 Adjust to attach the conflict resolution to each state.
2415 Complete the description with the precedence/associativity
2416 information.
2417 (resolve_sr_conflict): Adjust.
2418 * src/print.c (print_state): Output its solved_conflicts.
2419 * tests/conflicts.at (Unresolved SR Conflicts)
2420 (Solved SR Conflicts): Exercise --report=all.
2421
a49aecd5
AD
24222002-05-26 Akim Demaille <akim@epita.fr>
2423
2424 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2425 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
2426 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
2427 (token_number_t, item_number_as_token_number)
2428 (token_number_as_item_number, muscle_insert_token_number_table):
2429 Rename as...
2430 (symbol_number_t, item_number_as_symbol_number)
2431 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
2432 these, since it is more appropriate.
2433
5504898e
AD
24342002-05-26 Akim Demaille <akim@epita.fr>
2435
2436 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
2437 `Error:' lines.
2438 * data/bison.simple (yystos) [YYDEBUG]: New.
2439 (yyparse) [YYDEBUG]: Display the symbols which are popped during
2440 error recovery.
2441 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
2442
ec3bc396
AD
24432002-05-25 Akim Demaille <akim@epita.fr>
2444
2445 * doc/bison.texinfo (Debugging): Split into...
2446 (Tracing): this new section, its former contents, and...
2447 (Understanding): this new section.
2448 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
2449 by...
2450 (report_flag): this.
2451 Adjust all dependencies.
2452 (report_args, report_types, report_argmatch): New.
2453 (usage, getargs): Report/support -r, --report.
2454 * src/options.h
2455 (struct option_table_struct): Rename as..,
2456 (struct option_table_s): this.
2457 Rename the `set_flag' member to `flag' to match with getopt_long's
2458 struct.
2459 * src/options.c (option_table): Split verbose into an entry for
2460 %verbose, and another for --verbose.
2461 Support --report/-r, so remove -r from the obsolete --raw.
2462 * src/print.c: Attach full item sets and lookaheads reports to
2463 report_flag instead of trace_flag.
2464 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
2465
78df8250
PE
24662002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2467 and Paul Eggert <eggert@twinsun.com>
769b430f 2468
78df8250
PE
2469 * data/bison.simple (yyparse): Correct error handling to conform to
2470 POSIX and yacc. Specifically, after syntax error is discovered,
2471 do not reduce further before shifting the error token.
2472 Clean up the code a bit by removing the labels yyerrdefault,
2473 yyerrhandle, yyerrpop.
2474 * NEWS: Document the above.
2475
c0c9ea05
PH
24762002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2477
2478 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
2479 type; it isn't always big enough, since it doesn't necessarily
2480 include non-terminals.
769b430f 2481 (yytranslate): Expand definition of yy_token_number_type, so that
c0c9ea05
PH
2482 the latter can be removed.
2483 (yy_token_number_type): Remove, only one use.
2484 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
2485 don't use TokenNumberType as element type.
769b430f 2486
c0c9ea05
PH
2487 * tests/regression.at: Modify expected output to agree with change
2488 to yyr1 and yytranslate.
769b430f 2489
6390a83f
FK
24902002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
2491
2492 * src/reader.c (parse_action): Use copy_character instead of
2493 obstack_1grow.
2494
db7c8e9a
AD
24952002-05-13 Akim Demaille <akim@epita.fr>
2496
2497 * tests/regression.at (Token definitions): Prototype yylex and
2498 yyerror.
2499
fcc61800
PH
25002002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
2501
158c687b 2502 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
fcc61800
PH
2503 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
2504 32-bit arithmetic.
2505 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
2506
5683e9b2
AD
25072002-05-07 Akim Demaille <akim@epita.fr>
2508
2509 * tests/synclines.at: Be sure to prototype yylex and yyerror to
2510 avoid GCC warnings.
2511
0c2d3f4c
AD
25122002-05-07 Akim Demaille <akim@epita.fr>
2513
2514 Kill GCC warnings.
2515
2516 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
2517 over the RHS of each rule.
2518 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
2519 * src/state.h (state_t): Member `nitems' is unsigned short.
2520 * src/LR0.c (get_state): Adjust.
2521 * src/reader.c (packgram): Likewise.
2522 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
2523 `Type'.
2524 (muscle_insert_int_table): Remove, unused.
2525 (prepare_rules): Remove `max'.
2526
1565b720
AD
25272002-05-06 Akim Demaille <akim@epita.fr>
2528
2529 * src/closure.c (print_firsts): Display of the symbol tags.
2530 (bitmatrix_print): Move to...
2531 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
2532 here.
2533 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
2534
cfaee611
AD
25352002-05-06 Akim Demaille <akim@epita.fr>
2536
2537 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
2538 hash_do_for_each.
2539
458be8e0
AD
25402002-05-06 Akim Demaille <akim@epita.fr>
2541
2542 * src/LR0.c (new_state, get_state): Instead of using the global
2543 `kernel_size' and `kernel_base', have two new arguments:
2544 `core_size' and `core'.
2545 Adjust callers.
2546
a900a624
AD
25472002-05-06 Akim Demaille <akim@epita.fr>
2548
2549 * src/reader.c (packgram): No longer end `ritem' with a 0
2550 sentinel: it is not used.
2551
d4e7d3a1
AD
25522002-05-05 Akim Demaille <akim@epita.fr>
2553
2554 New experimental feature: display the lookaheads in the report and
2555 graph.
2556
2557 * src/print (print_core): When --trace-flag, display the rules
2558 lookaheads.
2559 * src/print_graph.c (print_core): Likewise.
2560 Swap the arguments.
2561 Adjust caller.
2562
39ceb25b
AD
25632002-05-05 Akim Demaille <akim@epita.fr>
2564
2565 * tests/torture.at (Many lookaheads): New test.
2566
5372019f
AD
25672002-05-05 Akim Demaille <akim@epita.fr>
2568
2569 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
2570 (GENERATE_MUSCLE_INSERT_TABLE): this.
2571 (output_int_table, output_unsigned_int_table, output_short_table)
2572 (output_token_number_table, output_item_number_table): Replace with...
2573 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
2574 (muscle_insert_short_table, muscle_insert_token_number_table)
2575 (muscle_insert_item_number_table): these.
2576 Adjust all callers.
2577 (prepare_tokens): Don't free `translations', since...
2578 * src/reader.h, src/reader.c (grammar_free): do it.
2579 Move to...
2580 * src/gram.h, src/gram.c (grammar_free): here.
2581 * data/bison.simple, data/bison.c++: b4_token_number_max is now
2582 b4_translate_max.
2583
5df5f6d5
AD
25842002-05-05 Akim Demaille <akim@epita.fr>
2585
2586 * src/output.c (output_unsigned_int_table): New.
2587 (prepare_rules): `i' is unsigned.
2588 `prhs', `rline', `r2' are unsigned int.
2589 Rename muscle `rhs_number_max' as `rhs_max'.
2590 Output muscles `prhs_max', `rline_max', and `r2_max'.
2591 Free rline and r1.
2592 * data/bison.simple, data/bison.c++: Adjust to use these muscles
2593 to compute types instead of constant types.
2594 * tests/regression.at (Web2c Actions): Adjust.
2595
b87f8b21
AD
25962002-05-04 Akim Demaille <akim@epita.fr>
2597
2598 * src/symtab.h (SALIAS, SUNDEF): Rename as...
2599 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
2600 Adjust dependencies.
2601 * src/output.c (token_definitions_output): Be sure not to output a
2602 `#define 'a'' when fed with `%token 'a' "a"'.
2603 * tests/regression.at (Token definitions): New.
2604
8bb936e4
PE
26052002-05-03 Paul Eggert <eggert@twinsun.com>
2606
2607 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
2608 for K&R C.
2609
26102002-05-03 gettextize <bug-gnu-gettext@gnu.org>
2611
2612 * Makefile.am (SUBDIRS): Remove intl.
2613 (EXTRA_DIST): Add config/config.rpath.
2614
53c71a12
AD
26152002-05-03 Akim Demaille <akim@epita.fr>
2616
2617 * data/bison.simple (m4_if): Don't output empty enums.
2618 And actually, output valid enum definitions :(.
2619
289dd0cf
AD
26202002-05-03 Akim Demaille <akim@epita.fr>
2621
2622 * configure.bat: Remove, completely obsolete.
2623 * Makefile.am (EXTRA_DIST): Adjust.
2624 Don't distribute config.rpath...
2625 * config/Makefile.am (EXTRA_DIST): Do it.
2626
db85e524
AD
26272002-05-03 Akim Demaille <akim@epita.fr>
2628
2629 * configure.in (GETTEXT_VERSION): New.
2630 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
2631
83ccf991
AD
26322002-05-03 Akim Demaille <akim@epita.fr>
2633
2634 * data/bison.simple (b4_token_enum): New.
2635 (b4_token_defines): Use it to output tokens both as #define and
2636 enums.
2637 Suggested by Paul Eggert.
2638 * src/output.c (token_definitions_output): Don't output spurious
2639 white spaces.
2640
1f418995
AD
26412002-05-03 Akim Demaille <akim@epita.fr>
2642
2643 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
2644
45119f04
RA
26452002-05-02 Robert Anisko <robert@lrde.epita.fr>
2646
2647 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
2648 Update the stack class, give a try to deque as the default container.
2649
b2d52318
AD
26502002-05-02 Akim Demaille <akim@epita.fr>
2651
2652 * data/bison.simple (yyparse): Do not implement @$ = @1.
2653 (YYLLOC_DEFAULT): Adjust to do it.
2654 * doc/bison.texinfo (Location Default Action): Fix.
2655
3a8b4109
AD
26562002-05-02 Akim Demaille <akim@epita.fr>
2657
2658 * src/reader.c (parse_braces): Merge into...
2659 (parse_action): this.
2660
84614e13
AD
26612002-05-02 Akim Demaille <akim@epita.fr>
2662
2663 * configure.in (ALL_LINGUAS): Remove.
2664 * po/LINGUAS, hr.po: New.
2665
fdbcd8e2
AD
26662002-05-02 Akim Demaille <akim@epita.fr>
2667
2668 Remove the so called hairy (semantic) parsers.
2669
2670 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
2671 * src/gram.h, src/gram.c (semantic_parser): Remove.
2672 (rule_t): Remove the guard and guard_line members.
2673 * src/lex.h (token_t): remove tok_guard.
2674 * src/options.c (option_table): Remove %guard and %semantic_parser
2675 support.
2676 * src/output.c, src/output.h (guards_output): Remove.
2677 (prepare): Adjust.
2678 (token_definitions_output): Don't output the `T'
2679 tokens (???).
2680 (output_skeleton): Don't output the guards.
2681 * src/files.c, src/files.c (attrsfile): Remove.
2682 * src/reader.c (symbol_list): Remove the guard and guard_line
2683 members.
2684 Adjust dependencies.
2685 (parse_guard): Remove.
2686 * data/bison.hairy: Remove.
2687 * doc/bison.texinfo (Environment Variables): Remove occurrences of
2688 BISON_HAIRY.
2689
82b6cb3f
AD
26902002-05-02 Akim Demaille <akim@epita.fr>
2691
2692 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
2693 (parse_guard): Rename the formal argument `stack_offset' as
2694 `rule_length', which is more readable.
2695 Adjust callers.
2696 (copy_at, copy_dollar): Instead of outputting the hard coded
2697 values of $$, $n and so forth, output invocation to b4_lhs_value,
2698 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
900c877b
AD
2699 Note: this patch partially drops `semantic-parser' support: it
2700 always does `rule_length - n', where semantic parsers ought to
2701 always use `-n'.
82b6cb3f
AD
2702 * data/bison.simple, data/bison.c++ (b4_lhs_value)
2703 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
2704
6cbfbcc5
AD
27052002-05-02 Akim Demaille <akim@epita.fr>
2706
2707 * configure.in (AC_INIT): Bump to 1.49b.
2708 (AM_INIT_AUTOMAKE): Short invocation.
2709
b8548114
AD
27102002-05-02 Akim Demaille <akim@epita.fr>
2711
2712 Version 1.49a.
2713
c20cd1fa
AD
27142002-05-01 Akim Demaille <akim@epita.fr>
2715
2716 * src/skeleton.h: Remove.
2717
8a9566d4
AD
27182002-05-01 Akim Demaille <akim@epita.fr>
2719
2720 * src/skeleton.h: Fix the #endif.
2721 Reported by Magnus Fromreide.
2722
8c6d399a
PE
27232002-04-26 Paul Eggert <eggert@twinsun.com>
2724
2725 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
2726 Define if we define YYSTYPE and YYLTYPE, respectively.
b756bb75 2727 (YYCOPY): Fix [] quoting problem in the non-GCC case.
8a9566d4 2728
2b7ed18a
RA
27292002-04-25 Robert Anisko <robert@lrde.epita.fr>
2730
2731 * src/scan-skel.l: Postprocess quadrigraphs.
2732
2733 * src/reader.c (copy_character): New function, used to output
2734 single characters while replacing `[' and `]' with quadrigraphs, to
2735 avoid troubles with M4 quotes.
2736 (copy_comment): Output characters with copy_character.
2737 (read_additionnal_code): Likewise.
2738 (copy_string2): Likewise.
2739 (copy_definition): Likewise.
2740
2741 * tests/calc.at: Exercise M4 quoting.
2742
34a89c50
AD
27432002-04-25 Akim Demaille <akim@epita.fr>
2744
2745 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
2746 between `!' and the command.
2747 Reported by Paul Eggert.
2748
0dd1580a
RA
27492002-04-24 Robert Anisko <robert@lrde.epita.fr>
2750
2751 * tests/calc.at: Exercise prologue splitting.
2752
2753 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
2754 `b4_post_prologue' instead of `b4_prologue'.
2755
2756 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
2757 muscles.
2758 (output): Free pre_prologue_obstack and post_prologue_obstack.
2759 * src/files.h, src/files.c (attrs_obstack): Remove.
2760 (pre_prologue_obstack, post_prologue_obstack): New.
2761 * src/reader.c (copy_definition): Add a parameter to specify the
2762 obstack to fill, instead of using attrs_obstack unconditionally.
2763 (read_declarations): Pass pre_prologue_obstack to copy_definition if
2764 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
2765
83c1796f
PE
27662002-04-23 Paul Eggert <eggert@twinsun.com>
2767
2768 * data/bison.simple: Remove unnecessary commentary and white
2769 space differences from 1_29-branch.
2770 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
2771
2772 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
2773 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
2774 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
2775 constructors or destructors.
2776
2777 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
2778
1207eeac
AD
27792002-04-23 Akim Demaille <akim@epita.fr>
2780
2781 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
2782 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
2783 location with columns.
2784 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
2785 All reported by Paul Eggert.
2786
78ab8f67
AD
27872002-04-22 Akim Demaille <akim@epita.fr>
2788
2789 * src/reduce.c (dump_grammar): Move to...
2790 * src/gram.h, src/gram.c (grammar_dump): here.
2791 Be sure to separate long item numbers.
2792 Don't read the members of a rule's prec if its nil.
2793
133c20e2
AD
27942002-04-22 Akim Demaille <akim@epita.fr>
2795
2796 * src/output.c (table_size, table_grow): New.
2797 (MAXTABLE): Remove, replace uses with table_size.
2798 (pack_vector): Instead of dying when the table is too big, grow it.
2799
9515e8a7
AD
28002002-04-22 Akim Demaille <akim@epita.fr>
2801
2802 * data/bison.simple (yyr1): Its type is that of a token number.
2803 * data/bison.c++ (r1_): Likewise.
2804 * tests/regression.at (Web2c Actions): Adjust.
2805
23c5a174
AD
28062002-04-22 Akim Demaille <akim@epita.fr>
2807
2808 * src/reader.c (token_translations_init): 256 is now the default
2809 value for the error token, i.e., it will be assigned another
2810 number if the user assigned 256 to one of her tokens.
2811 (reader): Don't force 256 to error.
2812 * doc/bison.texinfo (Symbols): Adjust.
2813 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
2814 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
2815 etc. instead of 10, 20, 30 (which was used to `jump' over error
2816 (256) and undefined (2)).
2817
5fbb0954
AD
28182002-04-22 Akim Demaille <akim@epita.fr>
2819
2820 Propagate more token_number_t.
2821
2822 * src/gram.h (token_number_as_item_number)
2823 (item_number_as_token_number): New.
2824 * src/output.c (GENERATE_OUTPUT_TABLE): New.
2825 Use it to create output_item_number_table and
2826 output_token_number_table.
2827 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
2828 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
2829 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
2830 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
2831
4f940944
AD
28322002-04-22 Akim Demaille <akim@epita.fr>
2833
2834 * src/output.h, src/output.c (get_lines_number): Remove.
2835
3ded9a63
AD
28362002-04-19 Akim Demaille <akim@epita.fr>
2837
2838 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
2839 as Lex/Flex'.
2840 (Debugging): More details about enabling the debugging features.
2841 (Table of Symbols): Describe $$, $n, @$, and @n.
2842 Suggested by Tim Josling.
2843
e0c471a9
AD
28442002-04-19 Akim Demaille <akim@epita.fr>
2845
2846 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
2847
fecc10cd
AD
28482002-04-10 Akim Demaille <akim@epita.fr>
2849
2850 * src/system.h: Rely on HAVE_LIMITS_H.
2851 Suggested by Paul Eggert.
2852
51dec47b
AD
28532002-04-09 Akim Demaille <akim@epita.fr>
2854
2855 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
2856 full stderr, and strip it according to the bison options, instead
2857 of composing the error message from different bits.
2858 This makes it easier to check for several error messages.
2859 Adjust all the invocations.
2860 Add an invocation exercising the error token.
2861 Add an invocation demonstrating a stupid error message.
2862 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
2863 Adjust the tests.
2864 Error message are for stderr, not stdout.
2865
007a50a4
AD
28662002-04-09 Akim Demaille <akim@epita.fr>
2867
2868 * src/gram.h, src/gram.c (error_token_number): Remove, use
2869 errtoken->number.
2870 * src/reader.c (reader): Don't specify the user token number (2)
2871 for $undefined, as it uselessly prevents using it.
2872 * src/gram.h (token_number_t): Move to...
2873 * src/symtab.h: here.
2874 (state_t.number): Is a token_number_t.
2875 * src/print.c, src/reader.c: Use undeftoken->number instead of
2876 hard coded 2.
2877 (Even though this 2 is not the same as above: the number of the
2878 undeftoken remains being 2, it is its user token number which
2879 might not be 2).
2880 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
2881 `user_token_number_max'.
2882 Output `undef_token_number'.
2883 * data/bison.simple, data/bison.c++: Use them.
2884 Be sure to map invalid yylex return values to
2885 `undef_token_number'. This saves us from gratuitous SEGV.
2886
2887 * tests/conflicts.at (Solved SR Conflicts)
2888 (Unresolved SR Conflicts): Adjust.
2889 * tests/regression.at (Web2c Actions): Adjust.
2890
06446ccf
AD
28912002-04-08 Akim Demaille <akim@epita.fr>
2892
2893 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
2894 Adding #line.
2895 Remove the duplicate `typedefs'.
2896 (RhsNumberType): Fix the declaration and various other typos.
2897 Use __ofile__.
2898 * data/bison.simple: Use __ofile__.
2899 * src/scan-skel.l: Handle __ofile__.
2900
62a3e4f0
AD
29012002-04-08 Akim Demaille <akim@epita.fr>
2902
2903 * src/gram.h (item_number_t): New, the type of item numbers in
2904 RITEM. Note that it must be able to code symbol numbers as
2905 positive number, and the negation of rule numbers as negative
2906 numbers.
2907 Adjust all dependencies (pretty many).
2908 * src/reduce.c (rule): Remove this `short *' pointer: use
2909 item_number_t.
2910 * src/system.h (MINSHORT, MAXSHORT): Remove.
2911 Include `limits.h'.
2912 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
2913 (shortcpy): Remove.
2914 (MAXTABLE): Move to...
2915 * src/output.c (MAXTABLE): here.
2916 (prepare_rules): Use output_int_table to output rhs.
2917 * data/bison.simple, data/bison.c++: Adjust.
2918 * tests/torture.at (Big triangle): Move the limit from 254 to
2919 500.
2920 * tests/regression.at (Web2c Actions): Ajust.
2921
2922 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
2923 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
2924 passes, but produces negative #line number, once fixed, GCC is
2925 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
2926 C), it passes.
2927 * src/state.h (state_h): Code input lines on ints, not shorts.
2928
bb88b0fc
AD
29292002-04-08 Akim Demaille <akim@epita.fr>
2930
2931 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
2932 and then the grammar.
2933
9a636f47
AD
29342002-04-08 Akim Demaille <akim@epita.fr>
2935
2936 * src/system.h: No longer using strndup.
2937
680e8701
AD
29382002-04-07 Akim Demaille <akim@epita.fr>
2939
2940 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
2941 * src/output.c (output_table_data): Return the longest number.
2942 (prepare_tokens): Output `token_number_max').
2943 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
2944 New.
2945 Use them to define yy_token_number_type/TokenNumberType.
2946 Use this type for yytranslate.
2947 * tests/torture.at (Big triangle): Push the limit from 124 to
2948 253.
2949 * tests/regression.at (Web2c Actions): Adjust.
2950
817e9f41
AD
29512002-04-07 Akim Demaille <akim@epita.fr>
2952
2953 * tests/torture.at (Big triangle): New.
2954 (GNU AWK Grammar, GNU Cim Grammar): Move to...
2955 * tests/existing.at: here.
2956
5123689b
AD
29572002-04-07 Akim Demaille <akim@epita.fr>
2958
2959 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
2960 nritems.
2961 Adjust dependencies.
2962
f3849179
AD
29632002-04-07 Akim Demaille <akim@epita.fr>
2964
2965 * src/reader.c: Normalize increments to prefix form.
2966
bd02036a
AD
29672002-04-07 Akim Demaille <akim@epita.fr>
2968
2969 * src/reader.c, symtab.c: Remove debugging code.
2970
db8837cb
AD
29712002-04-07 Akim Demaille <akim@epita.fr>
2972
2973 Rename all the `bucket's as `symbol_t'.
2974
2975 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
2976 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
2977 * src/symtab.c, src/symtab.h (bucket): Rename as...
2978 (symbol_t): this.
2979 (symbol_list_new, bucket_check_defined, bucket_make_alias)
2980 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
2981 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
2982 (buckets_new, buckets_free, buckets_do): Rename as...
2983 (symbol_list_new, symbol_check_defined, symbol_make_alias)
2984 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
2985 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
2986 (symbols_new, symbols_free, symbols_do): these.
2987
72a23c97
AD
29882002-04-07 Akim Demaille <akim@epita.fr>
2989
2990 Use lib/hash for the symbol table.
2991
2992 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
2993 EOF.
2994 * src/lex.c (lex): Set the `number' member of new terminals.
2995 * src/reader.c (bucket_check_defined, bucket_make_alias)
2996 (bucket_check_alias_consistence, bucket_translation): New.
2997 (reader, grammar_free, readgram, token_translations_init)
2998 (packsymbols): Adjust.
2999 (reader): Number the predefined tokens.
3000 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
3001 for predefined tokens.
3002 * src/symtab.h (bucket): Remove all the hash table related
3003 members.
3004 * src/symtab.c (symtab): Replace by...
3005 (bucket_table): this.
3006 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
3007 (buckets_new, buckets_do): New.
3008
280a38c3
AD
30092002-04-07 Akim Demaille <akim@epita.fr>
3010
3011 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
3012 (start_symbol, max_user_token_number, semantic_parser)
3013 (error_token_number): Initialize.
3014 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
3015 Initialize.
3016 (reader): Don't.
3017 (errtoken, eoftoken, undeftoken, axiom): Extern.
3018
03b31c0c
AD
30192002-04-07 Akim Demaille <akim@epita.fr>
3020
3021 * src/gram.h (rule_s): prec and precsym are now pointers
3022 to the bucket giving the priority/associativity.
3023 Member `associativity' removed: useless.
3024 * src/reduce.c, src/conflicts.c: Adjust.
3025
8b3df748
AD
30262002-04-07 Akim Demaille <akim@epita.fr>
3027
3028 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
3029 Properly escape the symbols' TAG when outputting them.
3030
e601aa1d
AD
30312002-04-07 Akim Demaille <akim@epita.fr>
3032
3033 * src/lalr.h (LA): Is a bitsetv, not bitset*.
3034
b0299a2e
AD
30352002-04-07 Akim Demaille <akim@epita.fr>
3036
3037 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
3038 (LArule): this, which is an array to rule_t*.
3039 * src/print.c, src/conflicts.c: Adjust.
3040
d7e1f00c
AD
30412002-04-07 Akim Demaille <akim@epita.fr>
3042
3043 * src/gram.h (rule_t): Rename `number' as `user_number'.
3044 `number' is a new member.
3045 Adjust dependencies.
3046 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
3047
cc9305dd
AD
30482002-04-07 Akim Demaille <akim@epita.fr>
3049
3050 As a result of the previous patch, it is no longer needed
3051 to reorder ritem itself.
3052
3053 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
3054
b0940840
AD
30552002-04-07 Akim Demaille <akim@epita.fr>
3056
3057 Be sure never to walk through RITEMS, but use only data related to
3058 the rules themselves. RITEMS should be banished.
3059
3060 * src/output.c (output_token_translations): Rename as...
3061 (prepare_tokens): this.
3062 In addition to `translate', prepare the muscles `tname' and
3063 `toknum', which were handled by...
3064 (output_rule_data): this.
3065 Remove, and move the remainder of its outputs into...
3066 (prepare_rules): this new routines, which also merges content from
3067 (output_gram): this.
3068 (prepare_rules): Be sure never to walk through RITEMS.
3069 (output_stos): Rename as...
3070 (prepare_stos): this.
3071 (output): Always invoke prepare_states, after all, just don't use it
3072 in the output if you don't need it.
3073
643a5994
AD
30742002-04-07 Akim Demaille <akim@epita.fr>
3075
3076 * src/LR0.c (new_state): Display `nstates' as the name of the
3077 newly created state.
3078 Adjust to initialize first_state and last_state if needed.
3079 Be sure to distinguish the initial from the final state.
3080 (new_states): Create the itemset of the initial state, and use
3081 new_state.
3082 * src/closure.c (closure): Now that the initial state has its
3083 items properly set, there is no need for a special case when
3084 creating `ruleset'.
3085
3086 As a result, now the rule 0, reducing to $axiom, is visible in the
3087 outputs. Adjust the test suite.
3088
3089 * tests/conflicts.at (Solved SR Conflicts)
3090 (Unresolved SR Conflicts): Adjust.
3091 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
3092 * tests/conflicts.at (S/R in initial): New.
3093
b4c4ccc2
AD
30942002-04-07 Akim Demaille <akim@epita.fr>
3095
3096 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
3097 the RHS of the rules.
3098 * src/output.c (output_gram): Likewise.
3099
bba97eb2
AD
31002002-04-07 Akim Demaille <akim@epita.fr>
3101
3102 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
3103 bucket.
3104 Adjust all dependencies.
3105 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
3106 `number' of the buckets too.
3107 * src/gram.h: Include `symtab.h'.
3108 (associativity): Move to...
3109 * src/symtab.h: here.
3110 No longer include `gram.h'.
3111
c3b407f4
AD
31122002-04-07 Akim Demaille <akim@epita.fr>
3113
3114 * src/gram.h, src/gram.c (rules_rhs_length): New.
3115 (ritem_longest_rhs): Use it.
3116 * src/gram.h (rule_t): `number' is a new member.
3117 * src/reader.c (packgram): Set it.
3118 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
3119 the end of `rules', and count them out of `nrules'.
3120 (reduce_output, dump_grammar): Adjust.
3121 * src/print.c (print_grammar): It is no longer needed to check for
3122 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
3123 * tests/reduce.at (Reduced Automaton): New test.
3124
11652ab3
AD
31252002-04-07 Akim Demaille <akim@epita.fr>
3126
3127 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
3128 lacking `+ 1' to nrules, Bison reported as useless a token if it
3129 was used solely to set the precedence of the last rule...
3130
26b23c1a
AD
31312002-04-07 Akim Demaille <akim@epita.fr>
3132
3133 * data/bison.c++, data/bison.simple: Don't output the current file
3134 name in #line, to avoid useless diffs between two identical
3135 outputs under different names.
3136
18bcecb0
AD
31372002-04-07 Akim Demaille <akim@epita.fr>
3138
3139 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
3140 Normalize loops to using `< nrules + 1', not `<= nrules'.
3141
fa770c86
AD
31422002-04-07 Akim Demaille <akim@epita.fr>
3143
3144 * TODO: Update.
3145
d9b739c3
AD
31462002-04-07 Akim Demaille <akim@epita.fr>
3147
3148 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
3149 bucket.value as bucket.number.
3150
99013900
AD
31512002-04-07 Akim Demaille <akim@epita.fr>
3152
3153 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
3154 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
3155 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
3156 RHS, instead of being an index in RITEMS.
3157
e966383b
PE
31582002-04-04 Paul Eggert <eggert@twinsun.com>
3159
3160 * doc/bison.texinfo: Update copyright date.
3161 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
3162 (Symbols): Warn about running Bison in one character set,
3163 but compiling and/or running in an incompatible one.
3164 Warn about character code 256, too.
3165
31662002-04-03 Paul Eggert <eggert@twinsun.com>
3167
3168 * src/bison.data (YYSTACK_ALLOC): Depend on whether
3169 YYERROR_VERBOSE is nonzero, not whether it is defined.
3170
3171 Merge changes from bison-1_29-branch.
c307773e 3172
8d6c48b9
PE
31732002-03-20 Paul Eggert <eggert@twinsun.com>
3174
3175 Merge fixes from Debian bison_1.34-1.diff.
3176
3177 * configure.in (AC_PREREQ): 2.53.
3178
e53c6322
AD
31792002-03-20 Akim Demaille <akim@epita.fr>
3180
3181 * src/conflicts.c (log_resolution): Argument `resolution' is const.
3182
9ffbeca7
PE
31832002-03-19 Paul Eggert <eggert@twinsun.com>
3184
21db0b2a
PE
3185 * src/bison.simple (YYCOPY): New macro.
3186 (YYSTACK_RELOCATE): Use it.
3187 Remove Type arg; no longer needed. All callers changed.
3188 (yymemcpy): Remove; no longer needed.
3189
9ffbeca7
PE
3190 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
3191 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
3192
642cb8f8
AD
31932002-03-19 Akim Demaille <akim@epita.fr>
3194
3195 Test and fix the #line outputs.
3196
3197 * tests/atlocal.at (GCC): New.
3198 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
3199 (Prologue synch line, ,%union synch line, Postprologue synch line)
3200 (Action synch line, Epilogue synch line): New tests.
3201 * src/reader.c (parse_union_decl): Define the muscle stype_line.
3202 * data/bison.simple, data/bison.c++: Use it.
3203
3c31a486
AD
32042002-03-19 Akim Demaille <akim@epita.fr>
3205
3206 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
3207 (Solved SR Conflicts, %expect not enough, %expect right)
3208 (%expect too much): Move to...
3209 * tests/conflicts.at: this new file.
3210
0d8bed56
AD
32112002-03-19 Akim Demaille <akim@epita.fr>
3212
3213 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
3214 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
3215 that we can move to enums for instance.
3216 * src/output.c (token_definitions_output): Output a list of
3217 `token-name, token-number' instead of the #define.
3218 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
3219
9208d17f
AD
32202002-03-14 Akim Demaille <akim@epita.fr>
3221
3222 Use Gettext 0.11.1.
3223
af27eacb
RA
32242002-03-09 Robert Anisko <robert@lrde.epita.fr>
3225
3226 * data/bison.c++: Make the user able to add members to the generated
3227 parser by subclassing.
3228
9101a310
RA
32292002-03-05 Robert Anisko <robert@lrde.epita.fr>
3230
3231 * src/reader.c (read_additionnal_code): `c' should be an integer, not
3232 a character.
3233 Reported by Nicolas Tisserand and Nicolas Burrus.
3234
fff9bf0b
RA
32352002-03-04 Robert Anisko <robert@lrde.epita.fr>
3236
3237 * src/reader.c: Warn about lacking semi-colons, do not complain.
3238
64dba31e
RA
32392002-03-04 Robert Anisko <robert@lrde.epita.fr>
3240
3241 * data/bison.c++: Remove a debug line.
3242
374f5a14
RA
32432002-03-04 Robert Anisko <robert@lrde.epita.fr>
3244
3245 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
3246 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
3247 provide a default implementation.
3248
bfcf1f3a
AD
32492002-03-04 Akim Demaille <akim@epita.fr>
3250
3251 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
3252 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
3253 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
3254 * tests/semantic.at (Parsing Guards): Similarly.
3255 * src/reader.at (readgram): Complain if the last rule is not ended
3256 with a semi-colon.
3257
65ccf9fc
AD
32582002-03-04 Akim Demaille <akim@epita.fr>
3259
3260 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
3261 * src/closure.c: here.
3262 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
3263 RTC.
3264 * src/warshall.h, src/warshall.c: Remove.
3265 * tests/sets.at (Broken Closure): Adjust.
3266
d0039cbc
AD
32672002-03-04 Akim Demaille <akim@epita.fr>
3268
3269 * src/output.c (output_skeleton): tempdir is const.
3270 bytes_read is unused.
3271
345cea78
AD
32722002-03-04 Akim Demaille <akim@epita.fr>
3273
3274 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3275 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
3276 Update.
3277 From Michael Hayes.
3278
564801f7
AD
32792002-03-04 Akim Demaille <akim@epita.fr>
3280
3281 * src/closure.c (closure): `r' is unused.
3282
e5352bc7
AD
32832002-03-04 Akim Demaille <akim@epita.fr>
3284
3285 * tests/sets.at (Broken Closure): Add the ending `;'.
3286 * src/reader.at (readgram): Complain if a rule is not ended with a
3287 semi-colon.
3288
914feea9
AD
32892002-03-04 Akim Demaille <akim@epita.fr>
3290
3291 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
3292 (count_sr_conflicts): Use bitset_count.
3293 * src/reduce.c (inaccessable_symbols): Ditto.
3294 (bits_size): Remove.
3295 * src/warshall.h, src/warshall.c: Convert to bitsetv.
3296
f0250de6
AD
32972002-03-04 Akim Demaille <akim@epita.fr>
3298
3299 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
3300 * src/reduce.c: Remove the `bitset_zero's following the
3301 `bitset_create's, as now it is performed by the latter.
3302
ef017502
AD
33032002-03-04 Akim Demaille <akim@epita.fr>
3304
3305 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
3306 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
3307 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
3308 latest sources from Michael.
3309
76514394
AD
33102002-03-04 Akim Demaille <akim@epita.fr>
3311
3312 * src/output.c (output): Don't free the grammar.
3313 * src/reader.c (grammar_free): New.
3314 * src/main.c (main): Call it and don't free symtab here.
3315
55024580
AD
33162002-03-04 Akim Demaille <akim@epita.fr>
3317
3318 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
3319 before returning.
3320 Reported by Benoit Perrot.
3321
f9abaa2c
AD
33222002-03-04 Akim Demaille <akim@epita.fr>
3323
3324 Use bitset operations when possible, not loops over bits.
3325
3326 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
3327 bitset_or.
3328 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
3329 * src/reduce.c (useless_nonterminals): Formatting changes.
3330 * src/warshall.c (TC): Use bitset_or.
3331
0e721e75
AD
33322002-03-04 Akim Demaille <akim@epita.fr>
3333
3334 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
3335 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
3336 Ditto.
3337
0fb1ffb1
AD
33382002-03-04 Akim Demaille <akim@epita.fr>
3339
3340 * src/lalr.c (F): Now a bitset*.
3341 Adjust all dependencies.
3342
b86796bf
AD
33432002-03-04 Akim Demaille <akim@epita.fr>
3344
3345 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
3346 Adjust all dependencies.
3347
602bbf31
AD
33482002-03-04 Akim Demaille <akim@epita.fr>
3349
3350 * src/L0.c, src/LR0.h (nstates): Be size_t.
3351 Adjust comparisons (signed vs unsigned).
3352 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
3353 bitset*.
3354 Adjust all dependencies.
3355
d8a0245c
AD
33562002-03-04 Akim Demaille <akim@epita.fr>
3357
3358 * src/closure.c (firsts): Now, also a bitset.
3359 Adjust all dependencies.
3360 (varsetsize): Remove, now unused.
3361 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
3362
34ba9743
AD
33632002-03-04 Akim Demaille <akim@epita.fr>
3364
3365 * src/print.c: Convert to use bitset.h, not hand coded iterations
3366 over ints.
3367
ed86e78c
AD
33682002-03-04 Akim Demaille <akim@epita.fr>
3369
3370 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
3371
dfdb1797
AD
33722002-03-04 Akim Demaille <akim@epita.fr>
3373
3374 * src/closure.c (ruleset): Be a bitset.
3375 (rulesetsize): Remove.
3376
7086e707
AD
33772002-03-04 Akim Demaille <akim@epita.fr>
3378
3379 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
3380 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
3381 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
3382 * src/closure.c (fderives): Be an array of bitsets.
3383
98254360
RA
33842002-02-28 Robert Anisko <robert@lrde.epita.fr>
3385
3386 * data/bison.c++: Merge the two generated headers. Insert a copyright
3387 notice in each output file.
3388
a75c057f
AD
33892002-02-28 Akim Demaille <akim@epita.fr>
3390
3391 * data/bison.c++: Copy the prologue of bison.simple to fetch
3392 useful M4 definitions, such as b4_header_guard.
3393
06b00abc
AD
33942002-02-25 Akim Demaille <akim@epita.fr>
3395
3396 * src/getargs.c (version): Give the name of the authors, and use a
a75c057f
AD
3397 translator friendly scheme for the bgr
3398 copyright notice.
06b00abc 3399
70e7d534
AD
34002002-02-25 Akim Demaille <akim@epita.fr>
3401
3402 * src/output.c (header_output): Remove, now handled completely via
3403 M4.
3404
abe017f6
AD
34052002-02-25 Akim Demaille <akim@epita.fr>
3406
3407 * m4/m4.m4: New, from CVS Autoconf.
3408 * configure.in: Invoke it.
3409 * src/output.c (output_skeleton): Use its result instead of the
3410 hard coded name.
3411
381fb12e
AD
34122002-02-25 Akim Demaille <akim@epita.fr>
3413
3414 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
3415 Fileutils 4.1.5.
3416 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
3417 * src/output.c (output_skeleton): Use mkstemp to create a real
3418 temporary file.
3419 Move the filling of `skeleton' and its muscle to...
3420 (prepare): here.
3421 (output): Move the definition of the prologue muscle to...
3422 (prepare): here.
3423 * src/system.h (DEFAULT_TMPDIR): New.
3424
6f38107f
PE
34252002-02-14 Paul Eggert <eggert@twinsun.com>
3426
3427 Remove the support for C++ namespace cleanliness; it was
3428 causing more problems than it was curing, since it didn't work
3429 properly on some nonstandard C++ compilers. This can wait
3430 for a proper C++ parser.
3431
3432 * NEWS: Document this.
3433 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
3434 of C++, as it's treated like C now.
3435 * src/bison.simple (YYSTD): Remove.
3436 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
3437 Treat C++ just like Standard C instead of trying to support
3438 namespace cleanliness.
3439
80cce3da
AD
34402002-02-14 Akim Demaille <akim@epita.fr>
3441
3442 * tests/regression.at (else): Adjust to Andreas' change.
3443
842e8679
AD
34442002-02-14 Akim Demaille <akim@epita.fr>
3445
3446 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
3447
4bda3f10
AD
34482002-02-13 Andreas Schwab <schwab@suse.de>
3449
3450 * src/output.c (output_rule_data): Don't output NULL, it might
3451 not be defined yet.
3452
4162fa07 34532002-02-11 Robert Anisko <robert@lrde.epita.fr>
b418ecd8 3454
4162fa07
RA
3455 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
3456 (Copyright notice): Update.
b418ecd8 3457
bd16a5dc
AD
34582002-02-11 Akim Demaille <akim@epita.fr>
3459
3460 * tests/regression.at (%nonassoc and eof): Don't include
3461 nonportable headers.
3462
8d69a1a3
RA
34632002-02-08 Robert Anisko <robert@lrde.epita.fr>
3464
3465 * data/bison.c++: Correct error recovery. Make the user able to
3466 initialize the starting location.
3467
9b2d0677
AD
34682002-02-07 Akim Demaille <akim@epita.fr>
3469
3470 * tests/input.at: New.
3471
69e2658b
RA
34722002-02-07 Robert Anisko <robert@lrde.epita.fr>
3473
3474 * data/bison.c++: Replace some direct m4 expansions by constants. Be
9b2d0677 3475 more consistent when naming methods and variables. Put preprocessor
69e2658b
RA
3476 directives around tables only needed for debugging.
3477
4aacc3a7
RA
34782002-02-07 Robert Anisko <robert@lrde.epita.fr>
3479
3480 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
3481 C++ parsers.
3482 (yy::b4_name::parse): Use print_.
3483
762a801e
RA
34842002-02-07 Robert Anisko <robert@lrde.epita.fr>
3485
3486 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
3487
4bb2bc3f
RA
34882002-02-07 Robert Anisko <robert@lrde.epita.fr>
3489
3490 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
3491 C++ parsers.
3492 (yy::b4_name::parse): Build verbose error messages, and use error_.
3493
6b45a3ca
RA
34942002-02-06 Robert Anisko <robert@lrde.epita.fr>
3495
3496 * data/bison.c++: Fix m4 quoting in comments.
3497
50997c6e
RA
34982002-02-06 Robert Anisko <robert@lrde.epita.fr>
3499
3500 * data/bison.c++: Adjust the parser code. Fix some muscles that were
3501 not expanded by m4.
3502
3f3eed27
AD
35032002-02-05 Akim Demaille <akim@epita.fr>
3504
3505 * data/bison.c++: Adjust to the M4 back end.
3506 More is certainly needed.
3507
be2a1a68
AD
35082002-02-05 Akim Demaille <akim@epita.fr>
3509
3510 Give a try to M4 as a back end.
3511
3512 * lib/readpipe.c: New, from wdiff.
3513 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
3514 BISON_HAIRY.
3515 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
3516 specific values. Now it is m4 that performs the lookup.
3517 * src/parse-skel.y: Remove.
3518 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
3519 * src/output.c (actions_output, guards_output)
3520 (token_definitions_output): No longer keeps track of the output
3521 line number, hence remove the second argument.
3522 (guards_output): Check against the guard member of a rule, not the
3523 action member.
3524 Adjust callers.
3525 (output_skeleton): Don't look for the skeleton location, let m4 do
3526 that.
3527 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
3528 file will be used.
3529 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
3530 (prepare): Given that for the time being changesyntax is not
3531 usable in M4, rename the muscles using `-' to `_'.
3532 Define `defines_flag', `output_parser_name' and `output_header_name'.
3533 * src/output.h (actions_output, guards_output)
3534 (token_definitions_output): Adjust prototypes.
3535 * src/scan-skel.l: Instead of scanning the skeletons, it now
3536 processes the output of m4: `__oline__' and `#output'.
3537 * data/bison.simple: Adjust to be used by M4(sugar).
3538 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
3539 to date.
3540 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
3541 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
3542 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
3543 shamelessly stolen from CVS Autoconf.
3544
beda758b
AD
35452002-02-05 Akim Demaille <akim@epita.fr>
3546
3547 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
3548 * configure.in: Check for the declarations of free and malloc.
3549 * src/muscle_tab.c: Adjust.
3550
5ece6d43
AD
35512002-02-05 Akim Demaille <akim@epita.fr>
3552
3553 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
3554 which have no values.
3555
5bb18f9a
AD
35562002-02-05 Akim Demaille <akim@epita.fr>
3557
3558 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
3559 * data/: here.
3560
894dd62e
PE
35612002-01-29 Paul Eggert <eggert@twinsun.com>
3562
3563 * src/bison.simple (YYSIZE_T): Do not define merely because
3564 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
3565 On some platforms, <alloca.h> does not declare YYSTD (size_t).
3566
82841af7
AD
35672002-01-27 Akim Demaille <akim@epita.fr>
3568
3569 Fix `%nonassoc and eof'.
3570
3571 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
3572 which were not properly copied! Replace
3573 memcpy (res->errs, src->errs, src->nerrs);
3574 with
3575 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
3576 !!!
3577 * tests/regression.at (%nonassoc and eof): Adjust to newest
3578 Autotest: `.' is not in the PATH.
3579
318b76e9
AD
35802002-01-27 Akim Demaille <akim@epita.fr>
3581
3582 * tests/sets.at (AT_EXTRACT_SETS): New.
3583 (Nullable): Use it.
3584 (Firsts): New.
3585
30d2f3d5
AD
35862002-01-26 Akim Demaille <akim@epita.fr>
3587
3588 * tests/actions.at, tests/calc.at, tests/headers.at,
3589 * tests/torture.at: Adjust to the newest Autotest which no longer
3590 forces `.' in the PATH.
3591
30f8c395
AD
35922002-01-25 Akim Demaille <akim@epita.fr>
3593
3594 * tests/regression.at (%nonassoc and eof): New.
3595 Suggested by Robert Anisko.
3596
29ae55f1
AD
35972002-01-24 Akim Demaille <akim@epita.fr>
3598
3599 Bison dumps core when trying to complain about broken input files.
3600 Reported by Cris van Pelt.
3601
3602 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
3603 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
3604 into...
3605 (Invalid inputs): Strengthen: exercise parse_percent_token.
3606
2b548aa6
RA
36072002-01-24 Robert Anisko <robert.anisko@epita.fr>
3608
3609 * src/Makefile.am: Add bison.c++.
3610 * src/bison.c++: New skeleton.
3611
bb0146c2
AD
36122002-01-21 Paolo Bonzini <bonzini@gnu.org>
3613
3614 * po/it.po: New.
3615
bec30531
AD
36162002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
3617
3618 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
3619
fc6edc45
MA
36202002-01-20 Marc Autret <marc@gnu.org>
3621
3622 * src/files.c (compute_output_file_names): Fix
3623
5e5d5415
MA
36242002-01-20 Marc Autret <marc@gnu.org>
3625
3626 * tests/output.at: New test.
3627 * src/files.c (compute_base_names): Don't map extensions when
3628 the YACC flag is set, use defaults.
3629 Reported by Evgeny Stambulchik.
3630
44ea3fbd
MA
36312002-01-20 Marc Autret <marc@gnu.org>
3632
bb0146c2 3633 * src/system.h: Need to define __attribute__ away for non-GCC
44ea3fbd
MA
3634 compilers as well (i.e. the vendor C compiler).
3635 Suggested by Albert Chin-A-Young.
3636
338963d1
TVH
36372002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
3638
3639 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
3640 canonical definition.
3641 * src/system.h: Use the canonical definition for PARAMS (avoids
3642 a conflict with the macro from lib/hash.h).
3643
c57b2479
AD
36442002-01-11 Akim Demaille <akim@epita.fr>
3645
3646 * configure.in: Use AC_FUNC_STRNLEN.
d9e9746c 3647 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
c57b2479 3648
b85810ae
AD
36492002-01-09 Akim Demaille <akim@epita.fr>
3650
3651 * src/files.c, src/files.h (output_infix): New.
3652 (tab_extension): Remove.
3653 (compute_base_names): Compute the former, drop the latter.
3654 * src/output.c (prepare): Insert the muscles `output-infix', and
3655 `output-suffix'.
3656 * src/parse-skel.y (string, string.1): New.
3657 (section.header): Use it.
3658 (section.yacc): Remove.
3659 (prefix): Remove too.
3660 * src/scan-skel.l: Adjust.
3661 * src/bison.simple, src/bison.hairy: Adjust.
3662
cae60122
AD
36632002-01-09 Akim Demaille <akim@epita.fr>
3664
3665 * configure.in (WERROR_CFLAGS): Compute it.
3666 * src/Makefile.am (CFLAGS): Pass it.
3667 * tests/atlocal.in (CFLAGS): Idem.
3668 * src/files.c: Fix a few warnings.
3669 (get_extension_index): Remove, unused.
3670
ae404801
AD
36712002-01-08 Akim Demaille <akim@epita.fr>
3672
3673 * src/getargs.c (AS_FILE_NAME): New.
3674 (getargs): Use it to convert DOSish file names.
3675 * src/files.c (base_name): Rename as full_base_name to avoid
3676 clashes with `base_name ()'.
3677 (filename_split): New.
3678 (compute_base_names): N-th rewrite, using filename_split.
3679
22312b71
AD
36802002-01-08 Akim Demaille <akim@epita.fr>
3681
3682 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
3683 New, stolen from the Fileutils 4.1.
3684 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
3685 * configure.in: Check for the presence of memrchr, and of its
3686 prototype.
3687
a67cef01
TVH
36882002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
3689
3690 * lib/hash.h (__P): Added definition for this macro.
3691 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
3692 BUILT_SOURCES, to ensure they are generated first.
3693 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
3694 %error-verbose to allow bootstrapping with bison 1.30x.
3695
2b25d624
AD
36962002-01-06 Akim Demaille <akim@epita.fr>
3697
3698 * src/reader.c (parse_braces): Don't fetch the next char, the
3699 convention is to fetch on entry.
3700 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
3701 'switch' without a following semicolon.
3702 * tests/regression.at (braces parsing): New.
3703
3460813b
AD
37042002-01-06 Akim Demaille <akim@epita.fr>
3705
3706 Bison is dead wrong in its RR conflict reports.
3707
3708 * tests/torture.at (GNU Cim Grammar): New.
3709 * src/conflicts.c (count_rr_conflicts): Fix.
3710
73784c64
AD
37112002-01-06 Akim Demaille <akim@epita.fr>
3712
3713 Creating package.m4 from configure.ac causes too many problems.
3714
3715 * tests/Makefile.am (package.m4): Create it by hand,
3716 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
3717
25d81090
AD
37182002-01-06 Akim Demaille <akim@epita.fr>
3719
3720 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
3721 skeleton.h.
3722
a9b8959e
PE
37232002-01-04 Paul Eggert <eggert@twinsun.com>
3724
3725 * doc/bison.texinfo (Debugging):
3726 Remove YYSTDERR; it's no longer defined or used.
3727 Also, s/cstdio.h/cstdio/.
3728
25d81090
AD
37292002-01-03 Akim Demaille <akim@epita.fr>
3730
3731 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
3732
1109455c
AD
37332002-01-03 Akim Demaille <akim@epita.fr>
3734
3735 * src/parse-skel.y (process_skeleton): Don't bind the parser's
3736 tracing code to --trace, wait for a better --trace option, with
3737 args.
3738
7ea5e977
AD
37392002-01-03 Akim Demaille <akim@epita.fr>
3740
3741 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
3742 The ISO C++ standard is extremely clear about it: stderr is
3743 considered a macro, not a regular symbol (see table 94 `Header
3744 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
3745 Therefore std:: does not apply to it. It still does with fprintf.
3746 Also, s/cstdio.h/cstdio/.
3747
fab5b110
AD
37482002-01-03 Akim Demaille <akim@epita.fr>
3749
3750 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
3751 for non system headers.
3752
aed7fd9b
AD
37532002-01-02 Akim Demaille <akim@epita.fr>
3754
3755 Equip the skeleton chain with location tracking, runtime trace,
3756 pure parser and scanner.
3757
3758 * src/parse-skel.y: Request a pure parser, locations, and prefix
3759 renaming.
3760 (%union): Having several members with the same type does not help
3761 type mismatches, simplify.
3762 (YYPRINT, yyprint): New.
3763 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
3764 (skel_error): this.
3765 Handle locations.
3766 * src/scan-skel.l: Adjust to these changes.
3767 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
3768 (LOCATION_PRINT, skel_control_t): New.
3769
24fad99e
AD
37702001-12-30 Akim Demaille <akim@epita.fr>
3771
3772 * src/parse-skel.y: Get rid of the shift/reduce conflict:
3773 replace `gb' with BLANKS.
3774 * src/scan-skel.l: Adjust.
3775
a4b36db4
AD
37762001-12-30 Akim Demaille <akim@epita.fr>
3777
3778 * src/system.h: We don't need nor want bcopy.
3779 Throw away MS-DOS crap: we don't need getpid.
3780 * configure.in: We don't need strndup. It was even causing
3781 problems: because Flex includes the headers *before* us,
3782 _GNU_SOURCE is not defined by config.h, and therefore strndup was
3783 not visible.
3784 * lib/xstrndup.c: New.
3785 * src/scan-skel.l: Use it.
3786 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
3787 * src/parse-skel.y: Use %directives instead of #defines.
3788
1239777d
AD
37892001-12-30 Akim Demaille <akim@epita.fr>
3790
3791 * src/skeleton.h: New.
3792 * src/output.c (output_parser, output_master_parser): Remove, dead
3793 code.
3794 * src/output.h (get_lines_number, actions_output, guards_output)
3795 (token_definitions_output): Prototype them.
3796 * src/parse-skel.y: Add the license notice.
3797 Include output.h and skeleton.h.
3798 (process_skeleton): Returns void, and takes a single parameter.
3799 * src/scan-skel.l: Add the license notice.
3800 Include skeleton.h.
3801 Don't use %option yylineno: it seems that then Flex imagines
3802 REJECT has been used, and therefore it won't reallocate its
3803 buffers (which makes no other sense to me than a bug). It results
3804 in warnings for `unused: yy_flex_realloc'.
3805
9b3add5b
RA
38062001-12-30 Robert Anisko <robert.anisko@epita.fr>
3807
3808 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3809 (MUSCLE_INSERT_PREFIX): ...to there.
3810 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
3811 (MUSCLE_INSERT_PREFIX): Move from here...
3812
3813 * src/bison.hairy: Add a section directive. Put braces around muscle
3814 names. This parser skeleton is still broken, but Bison should not
3815 choke on a bad muscle 'syntax'.
3816 * src/bison.simple: Add a section directive. Put braces around muscle
3817 names.
3818
3819 * src/files.h (strsuffix, stringappend): Add declarations.
3820 (tab_extension): Add declaration.
3821 (short_base_name): Add declaration.
3822
3823 * src/files.c (strsuffix, stringappend): No longer static. These
3824 functions are used in the skeleton parser.
3825 (tab_extension): New.
3826 (compute_base_names): Use the computations done in this function
fab5b110 3827 to guess if the generated parsers should have '.tab' in their
9b3add5b
RA
3828 names.
3829 (short_base_name): No longer static.
3830
3831 * src/output.c (output_skeleton): New.
3832 (output): Disable call to output_master_parser, and give a try to
3833 a new skeleton handling system.
3834 (guards_output, actions_output): No longer static.
3835 (token_definitions_output, get_lines_number): No longer static.
3836
3837 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
3838
fab5b110 3839 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
9b3add5b
RA
3840 parse-skel.y.
3841
3842 * src/parse-skel.y: New file.
3843 * src/scan-skel.l: New file.
3844
b5b61c61
AD
38452001-12-29 Akim Demaille <akim@epita.fr>
3846
3847 %name-prefix is broken.
3848
3849 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
3850 Adjust all dependencies.
3851 * tests/headers.at (export YYLTYPE): Strengthen this test: use
3852 %name-prefix.
3853
3854 Renaming yylval but not yylloc is not consistent. Now we do.
3855
3856 * src/bison.simple: Prefix yylloc if used.
3857 * doc/bison.texinfo (Decl Summary): Document that.
3858
8c9a50be
AD
38592001-12-29 Akim Demaille <akim@epita.fr>
3860
3861 * doc/bison.texinfo: Promote `%long-directive' over
3862 `%long_directive'.
3863 Remove all references to fixed-output-files, yacc is enough.
3864
d99361e6
AD
38652001-12-29 Akim Demaille <akim@epita.fr>
3866
3867 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
3868 user prologue. These are defaults.
3869 * tests/actions.at (Mid-rule actions): Make sure the user can
3870 define YYDEBUG and YYERROR_VERBOSE.
3871
b9cecb91
AD
38722001-12-29 Akim Demaille <akim@epita.fr>
3873
3874 * src/output.c (header_output): Don't forget to export YYLTYPE and
3875 yylloc.
3876 * tests/headers.at (export YYLTYPE): New, make sure it does.
3877 * tests/regression.at (%union and --defines, Invalid CPP headers):
3878 Move to...
3879 * tests/headers.at: here.
3880
aea13e97
AD
38812001-12-29 Akim Demaille <akim@epita.fr>
3882
3883 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
3884
931394cb
AD
38852001-12-29 Akim Demaille <akim@epita.fr>
3886
3887 * tests/actions.at (Mid-rule actions): Output on a single line
3888 instead of several.
3889
704a47c4
AD
38902001-12-29 Akim Demaille <akim@epita.fr>
3891
3892 * doc/bison.texinfo: Formatting changes.
3893
091e20bb
AD
38942001-12-29 Akim Demaille <akim@epita.fr>
3895
3896 Don't store the token defs in a muscle, just be ready to output it
3897 on command. Now possible via `symbols'. Fixes a memory leak.
3898
3899 * src/output.c (token_definitions_output): New.
3900 (output_parser, header_output): Use it.
3901 * src/reader.c (symbols_save): Remove.
3902
cce71710
AD
39032001-12-29 Akim Demaille <akim@epita.fr>
3904
3905 * src/bison.simple: Do not provide a default for YYSTYPE and
3906 YYLTYPE before the user's prologue. Otherwise it's hardly... a
3907 default.
3908
82c035a8
AD
39092001-12-29 Akim Demaille <akim@epita.fr>
3910
3911 Mid-rule actions are simply... ignored!
3912
3913 * src/reader.c (readgram): Be sure to attach mid-rule actions to
3914 the empty-rule associated to the dummy symbol, not to the host
3915 rule.
3916 * tests/actions.at (Mid-rule actions): New.
3917
8419d367
AD
39182001-12-29 Akim Demaille <akim@epita.fr>
3919
3920 Memory leak.
3921
3922 * src/reader.c (reader): Free grammar.
3923
375d5806
AD
39242001-12-29 Akim Demaille <akim@epita.fr>
3925
3926 Memory leak.
3927
3928 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
3929 since it allocates it for each state, although only one is needed.
3930 (allocate_storage): Do it here.
3931
f51cb8ff
AD
39322001-12-29 Akim Demaille <akim@epita.fr>
3933
3934 * src/options.h, src/options.c (create_long_option_table): Rename
3935 as...
3936 (long_option_table_new): this, with a clearer prototype.
3937 (percent_table): Remove, unused,
3938 * src/getargs.c (getargs): Adjust.
3939
29e88316
AD
39402001-12-29 Akim Demaille <akim@epita.fr>
3941
3942 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
3943 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
3944 as states.
3945
b9f71f19
AD
39462001-12-29 Akim Demaille <akim@epita.fr>
3947
3948 * src/lalr.c (build_relations): Rename `states' as `states1'.
3949 Sorry, I don't understand exactly what it is, no better name...
3950
1a2b5d37
AD
39512001-12-29 Akim Demaille <akim@epita.fr>
3952
3953 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
3954 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
3955 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
3956 as rules.
3957
1cca533e
AD
39582001-12-29 Akim Demaille <akim@epita.fr>
3959
3960 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
3961 ago.
3962
c03ae966
AD
39632001-12-29 Akim Demaille <akim@epita.fr>
3964
3965 * src/reader.c, src/reader.h (user_toknums): Remove.
3966 Adjust all users to use symbols[i]->user_token_number.
3967
5a670b1e
AD
39682001-12-29 Akim Demaille <akim@epita.fr>
3969
3970 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
3971 Adjust all users to use symbols[i]->prec or ->assoc.
3972
ad949da9
AD
39732001-12-29 Akim Demaille <akim@epita.fr>
3974
3975 * src/reader.c, src/reader.h (tags): Remove.
3976 Adjust all users to use symbols[i]->tag.
3977
0e78e603
AD
39782001-12-29 Akim Demaille <akim@epita.fr>
3979
3980 * src/gram.h, src/gram.c (symbols): New, similar to state_table
3981 and rule_table.
3982 * src/reader.c (packsymbols): Fill this table.
3983 Drop sprec.
3984 * src/conflicts.c (resolve_sr_conflict): Adjust.
3985 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
3986 single table.
3987 Use symbols[i]->tag instead of tags[i].
3988
213e640e
AD
39892001-12-29 Akim Demaille <akim@epita.fr>
3990
3991 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
3992 In addition, put a comment in there, to replace...
3993 * tests/regression.at (%union and C comments): Remove.
3994
e7b8bef1
AD
39952001-12-29 Akim Demaille <akim@epita.fr>
3996
3997 * tests/regression.at (Web2c Actions): Blindly move the actual
3998 output as expected output. The contents *seem* right to me, but I
3999 can't pretend reading perfectly parser tables... Nonetheless, all
4000 the other tests pass correctly, the table look OK, even though the
4001 presence of `$axiom' is to be noted: AFAICS it is useless (but
4002 harmless).
4003
b68e7744
AD
40042001-12-29 Akim Demaille <akim@epita.fr>
4005
4006 * src/reader.c (readgram): Don't add the rule 0 if there were no
4007 rules read. In other words, add it _after_ having performed
4008 grammar sanity checks.
4009 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
4010
78d5bae9
AD
40112001-12-29 Akim Demaille <akim@epita.fr>
4012
4013 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
4014 visible, and some states have now a different number.
4015
ff442794
AD
40162001-12-29 Akim Demaille <akim@epita.fr>
4017
4018 * src/reader.c (readgram): Bind the initial rule's lineno to that
4019 of the first rule.
4020 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
4021 (Solved SR Conflicts): Adjust rule 0's line number.
4022
610ab194
AD
40232001-12-29 Akim Demaille <akim@epita.fr>
4024
4025 Fix the `GAWK Grammar' failure.
4026
4027 * src/LR0.c (final_state): Initialize to -1 so that we do compute
4028 the reductions of the first state which was mistakenly confused
4029 with the final state because precisely final_state was initialized
4030 to 0.
4031 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
4032 now noticed by Bison.
4033 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
4034 have a reduction on $default.
4035
29d29c8f
AD
40362001-12-29 Akim Demaille <akim@epita.fr>
4037
4038 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
4039 rule line numbers.
4040 * src/closure.c (print_closure): Likewise.
4041 * src/derives.c (print_derives): Likewise.
4042 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
4043 now.
4044
7c6b64d0
AD
40452001-12-29 Akim Demaille <akim@epita.fr>
4046
4047 * src/lalr.c (lookaheads_print): New.
4048 (lalr): Call it when --trace-flag.
4049 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
4050 are dumped.
4051
3d4daee3
AD
40522001-12-29 Akim Demaille <akim@epita.fr>
4053
4054 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
4055 when walking through ritem, even via rule->rhs.
4056 * src/reduce.c (dump_grammar, useful_production, reduce_output)
4057 (useful_production, useless_nonterminals): Likewise.
4058 (reduce_grammar_tables): Likewise, plus update nritems.
4059 * src/nullable.c (set_nullable): Likewise.
4060 * src/lalr.c (build_relations): Likewise.
4061 * tests/sets.at (Nullable): Adjust.
4062 Fortunately, now, the $axiom is no longer nullable.
4063
9e7f6bbd
AD
40642001-12-29 Akim Demaille <akim@epita.fr>
4065
4066 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
4067 the 0-sentinel.
4068 * src/gram.c (ritem_longest_rhs): Likewise.
4069 * src/reduce.c (nonterminals_reduce): Likewise.
4070 * src/print_graph.c (print_graph): Likewise.
4071 * src/output.c (output_rule_data): Likewise.
4072 * src/nullable.c (set_nullable): Likewise.
4073
255ef638
AD
40742001-12-29 Akim Demaille <akim@epita.fr>
4075
4076 * src/output.c: Comment changes.
4077
0d8a7363
AD
40782001-12-27 Paul Eggert <eggert@twinsun.com>
4079
4080 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
4081 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
4082 Sparc, as they were causing more porting problems than the
4083 (minor) performance improvement was worth.
4084
4085 Also, catch up with 1.31's YYSTD.
4086
3db472b9
AD
40872001-12-27 Akim Demaille <akim@epita.fr>
4088
4089 * src/output.c (output_gram): Rely on nritems, not the
4090 0-sentinel. See below.
4091 Use -1 as separator, not 0.
4092 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
4093 Rely on -1 as separator in yyrhs, instead of 0.
4094 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
4095 twice `Now at end of input', therefore there are two lines less to
4096 expect.
4097
b365aa05
AD
40982001-12-27 Akim Demaille <akim@epita.fr>
4099
4100 * tests/regression.at (Unresolved SR Conflicts):
4101 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
4102 below.
4103
30171f79
AD
41042001-12-27 Akim Demaille <akim@epita.fr>
4105
4106 * src/LR0.c (new_state): Recognize the final state by the fact it
4107 is reached by eoftoken.
4108 (insert_start_shifting_state, insert_eof_shifting_state)
4109 (insert_accepting_state, augment_automaton): Remove, since now
4110 these states are automatically computed from the initial state.
4111 (generate_states): Adjust.
4112 * src/print.c: When reporting a rule number to the user, substract
4113 1, so that the axiom rule is rule 0, and the first user rule is 1.
4114 * src/reduce.c: Likewise.
4115 * src/print_graph.c (print_core): For the time being, just as for
4116 the report, depend upon --trace-flags to dump the full set of
4117 items.
4118 * src/reader.c (readgram): Once the grammar read, insert the rule
4119 0: `$axiom: START-SYMBOL $'.
4120 * tests/set.at: Adjust: rule 0 is now displayed, and since the
4121 number of the states has changed (the final state is no longer
4122 necessarily the last), catch up.
4123
75142d45
AD
41242001-12-27 Akim Demaille <akim@epita.fr>
4125
4126 Try to make the use of the eoftoken valid. Given that its value
4127 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
4128 is used instead of > 0 where appropriate, (ii), depend upon nritems
4129 instead of the 0-sentinel.
4130
4131 * src/gram.h, src/gram.c (nritems): New.
4132 Expected to be duplication of nitems, but for the time being...
4133 * src/reader.c (packgram): Assert nritems and nitems are equal.
4134 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
4135 * src/closure.c (print_closure, print_fderives): Likewise.
4136 * src/gram.c (ritem_print): Likewise.
4137 * src/print.c (print_core, print_grammar): Likewise.
4138 * src/print_graph.c: Likewise.
4139
b7c49edf
AD
41402001-12-27 Akim Demaille <akim@epita.fr>
4141
4142 * src/main.c (main): If there are complains after grammar
4143 reductions, then output the report anyway if requested, then die.
4144 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
4145 * src/reader.c (eoftoken): New.
4146 (parse_token_decl): If the token being defined has value `0', it
4147 is the eoftoken.
4148 (packsymbols): No longer hack `tags' to insert `$' by hand.
4149 Be sure to preserve the value of the eoftoken.
4150 (reader): Make sure eoftoken is defined.
4151 Initialize nsyms to 0: now eoftoken is created just like the others.
4152 * src/print.c (print_grammar): Don't special case the eof token.
4153 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
4154 lie anyway, albeit pleasant.
4155 * tests/calc.at: Exercise error messages with eoftoken.
4156 Change the grammar so that empty input is invalid.
4157 Adjust expectations.
4158 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
4159
ec2da99f
AD
41602001-12-27 Akim Demaille <akim@epita.fr>
4161
4162 * configure.in: Check the protos of strchr ans strspn.
4163 Replace strchr if needed.
4164 * src/system.h: Provide the protos of strchr, strspn and memchr if
4165 missing.
4166 * lib/strchr.c: New.
4167 * src/reader.c (symbols_save): Use strchr.
4168
8adfa272
AD
41692001-12-27 Akim Demaille <akim@epita.fr>
4170
4171 * src/print.c, src/print_graph.c (escape): New.
4172 Use it to quote the TAGS outputs.
4173 * src/print_graph.c (print_state): Now errors are in red, and
4174 reductions in green.
4175 Prefer high to wide: output the state number on a line of its own.
4176
80dac38c
AD
41772001-12-27 Akim Demaille <akim@epita.fr>
4178
4179 * src/state.h, src/state.c (reductions_new): New.
4180 * src/LR0.c (set_state_table): Let all the states have a
4181 `reductions', even if reduced to 0.
4182 (save_reductions): Adjust.
4183 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
4184 * src/print.c (print_reductions, print_actions): Adjust.
4185 * src/output.c (action_row): Adjust.
4186
2cec70b9
AD
41872001-12-27 Akim Demaille <akim@epita.fr>
4188
4189 * src/state.h, src/state.c (errs_new, errs_dup): New.
4190 * src/LR0.c (set_state_table): Let all the states have an errs,
4191 even if reduced to 0.
4192 * src/print.c (print_errs, print_reductions): Adjust.
4193 * src/output.c (output_actions, action_row): Adjust.
4194 * src/conflicts.c (resolve_sr_conflict): Adjust.
4195
13ca549a
AD
41962001-12-27 Akim Demaille <akim@epita.fr>
4197
4198 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
4199
5092aba5
AD
42002001-12-27 Akim Demaille <akim@epita.fr>
4201
4202 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
4203 * src/print.c: here.
4204 (lookaheadset, shiftset): New, used as additional storage by
4205 print_reductions.
4206 (print_results): Adjust.
4207 (print_shifts, print_gotos, print_errs): New, extracted from...
4208 (print_actions): here.
4209 * src/print_graph.c (print_actions): Remove dead code.
4210
11e2beca
AD
42112001-12-27 Akim Demaille <akim@epita.fr>
4212
4213 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
4214 `$n' and `@n'.
4215
dac3c910
AD
42162001-12-27 Akim Demaille <akim@epita.fr>
4217
4218 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
4219 (build_relations): Adjust.
4220
d0b0fefa
AD
42212001-12-27 Akim Demaille <akim@epita.fr>
4222
4223 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
4224 duplication.
4225
adc8c848
AD
42262001-12-27 Akim Demaille <akim@epita.fr>
4227
4228 * src/reader.c (packgram): Catch nitems overflows.
4229
14d293ac
AD
42302001-12-27 Akim Demaille <akim@epita.fr>
4231
4232 * src/files.c, src/files.h (guard_obstack): Remove.
4233 * src/output.c (output): Adjust.
4234 * src/reader.c (parse_braces): New, factoring...
4235 (copy_action, copy_guard): these two which are renamed as...
4236 (parse_action, parse_guard): these.
4237 As a voluntary consequence, using braces around guards is now
4238 mandatory.
4239
f499b062
AD
42402001-12-27 Akim Demaille <akim@epita.fr>
4241
4242 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
4243 * src/reader.c (symbol_list): `guard' and `guard_line' are new
4244 members.
4245 (symbol_list_new): Adjust.
4246 (copy_action): action_line is the first line, not the last.
4247 (copy_guard): Just as for actions, store the `action' only, not
4248 the switch/case/break flesh.
4249 Don't parse the user action that might follow the guard, let...
4250 (readgram): do it, i.e., now, there can be an action after a
4251 guard.
4252 In other words the guard is just explicitly optional.
4253 (packgram): Adjust.
4254 * src/output.c (guards_output): New.
4255 (output_parser): Call it when needed.
4256 (output): Also free the guard and attrs obstacks.
4257 * src/files.c, src/files.h (obstack_save): Remove.
4258 (output_files): Remove.
4259 As a result, if one needs the former `.act' file, using an
4260 appropriate skeleton which requires actions and guards is now
4261 required.
4262 * src/main.c (main): Adjust.
4263 * tests/semantic.at: New.
4264 * tests/regression.at: Use `input.y' as input file name.
4265 Avoid 8+3 problems by requiring input.c when the test needs the
4266 parser.
4267
d945f5cd
AD
42682001-12-27 Akim Demaille <akim@epita.fr>
4269
4270 * src/reader.c (symbol_list_new): Be sure to initialize all the
4271 fields.
4272
d200e455
AD
42732001-12-27 Akim Demaille <akim@epita.fr>
4274
4275 All the hacks using a final pseudo state are now useless.
4276
4277 * src/LR0.c (set_state_table): state_table holds exactly nstates.
4278 * src/lalr.c (nLA): New.
4279 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
4280 instead of lookaheadsp from the pseudo state (nstate + 1).
4281
f9507c28
AD
42822001-12-27 Akim Demaille <akim@epita.fr>
4283
4284 * src/output.c (action_row, token_actions): Use a state_t instead
4285 of a integer, and nlookaheads instead of the following state's
4286 lookaheadsp.
4287
065fbd27
AD
42882001-12-27 Akim Demaille <akim@epita.fr>
4289
4290 * src/conflicts.c (log_resolution, flush_shift)
4291 (resolve_sr_conflict, set_conflicts, solve_conflicts)
4292 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
4293 (conflicts_print, print_reductions): Use a state_t instead of an
4294 integer when referring to a state.
4295 As much as possible, depend upon nlookaheads, instead of the
4296 `lookaheadsp' member of the following state (since lookaheads of
4297 successive states are successive, the difference between state n + 1
4298 and n served as the number of lookaheads for state n).
4299 * src/lalr.c (add_lookback_edge): Likewise.
4300 * src/print.c (print_core, print_actions, print_state)
4301 (print_results): Likewise.
4302 * src/print_graph.c (print_core, print_actions, print_state)
4303 (print_graph): Likewise.
4304 * src/conflicts.h: Adjust.
4305
1b177bd7
AD
43062001-12-27 Akim Demaille <akim@epita.fr>
4307
4308 * src/bison.hairy: Formatting/comment changes.
4309 ANSIfy.
4310 Remove `register' indications.
4311 Add plenty of `static'.
4312
7742ddeb
AD
43132001-12-27 Akim Demaille <akim@epita.fr>
4314
4315 * src/output.c (prepare): Drop the muscle `ntbase' which
4316 duplicates ntokens.
4317 * src/bison.simple: Formatting/comment changes.
4318 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
4319 is an undocumented synonym.
4320
1fa14068
AD
43212001-12-22 Akim Demaille <akim@epita.fr>
4322
4323 * src/output.c (output_table_data): Change the prototype to use
4324 `int' for array ranges: some invocations do pass an int, not a
4325 short.
4326 Reported by Wayne Green.
4327
b9752825
AD
43282001-12-22 Akim Demaille <akim@epita.fr>
4329
4330 Some actions of web2c.y are improperly triggered.
4331 Reported by Mike Castle.
4332
4333 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
4334 * tests/regression.at (Web2c): Rename as...
4335 (Web2c Report): this.
4336 (Web2c Actions): New.
4337
776209d6
AD
43382001-12-22 Akim Demaille <akim@epita.fr>
4339
4340 Reductions in web2c.y are improperly reported.
4341 Reported by Mike Castle.
4342
4343 * src/conflicts.c (print_reductions): Fix.
4344 * tests/regression.at (Web2c): New.
4345
275fc3ad
AD
43462001-12-18 Akim Demaille <akim@epita.fr>
4347
4348 Some host fail on `assert (!"foo")', which expands to
4349 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
4350 Reported by Nelson Beebee.
4351
4352 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
4353 `#define it_succeeded 0' and `assert (it_succeeded)'.
4354
897668ee
MA
43552001-12-17 Marc Autret <autret_m@epita.fr>
4356
4357 * src/bison.simple: Don't hard code the skeleton line and filename.
4358 * src/output.c (output_parser): Rename 'line' as 'output_line'.
4359 New line counter 'skeleton_line' (skeleton-line muscle).
4360
ab3399e0
PE
43612001-12-17 Paul Eggert <eggert@twinsun.com>
4362
4363 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
4364 YYDEBUG must be defined to a nonzero value.
4365
4366 * src/bison.simple (yytname): Do not assume that the user defines
4367 YYDEBUG to a properly parenthesized expression.
4368
3877f72b
AD
43692001-12-17 Akim Demaille <akim@epita.fr>
4370
4371 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
4372 nlookaheads is a new member.
4373 Adjust all users.
4374 * src/lalr.h (nlookaheads): Remove this orphan declaration.
4375 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
4376 state.
776209d6 4377
331dbc1b
AD
43782001-12-17 Akim Demaille <akim@epita.fr>
4379
4380 * src/files.h, src/files.c (open_files, close_files): Remove.
4381 * src/main.c (main): Don't open/close files, nor invoke lex_free,
4382 let...
4383 * src/reader.c (reader): Do it.
776209d6 4384
be750e4c
AD
43852001-12-17 Akim Demaille <akim@epita.fr>
4386
4387 * src/conflicts.c (print_reductions): Formatting changes.
776209d6 4388
709ae8c6
AD
43892001-12-17 Akim Demaille <akim@epita.fr>
4390
4391 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
4392 (flush_reduce): New.
4393 (resolve_sr_conflict): Adjust.
776209d6 4394
f87685c3
AD
43952001-12-17 Akim Demaille <akim@epita.fr>
4396
4397 * src/output.c (output_obstack): Be static and rename as...
4398 (format_obstack): this, to avoid any confusion with files.c's
4399 output_obstack.
4400 * src/reader.h (muscle_obstack): Move to...
4401 * src/output.h: here, since it's defined in output.c.
4402
837491d8
AD
44032001-12-17 Akim Demaille <akim@epita.fr>
4404
4405 * src/output.c (action_row, save_column, default_goto)
4406 (sort_actions, matching_state, pack_vector): Better variable
4407 locality.
4408
796d61fb
AD
44092001-12-17 Akim Demaille <akim@epita.fr>
4410
4411 * src/output.c: Various formatting changes.
776209d6 4412
64d15509
AD
44132001-12-17 Akim Demaille <akim@epita.fr>
4414
4415 * src/files.c (output_files): Free the output_obstack.
4416 * src/main.c (main): Call print and print_graph conditionally.
4417 * src/print.c (print): Work unconditionally.
4418 * src/print_graph.c (print_graph): Work unconditionally.
4419 * src/conflicts.c (log_resolution): Output only if verbose_flag.
4420
fbc8ecb7
MA
44212001-12-16 Marc Autret <autret_m@epita.fr>
4422
4423 * src/output.c (actions_output): Fix. When we use %no-lines,
4424 there is one less line per action.
4425
f0440388
MA
44262001-12-16 Marc Autret <autret_m@epita.fr>
4427
4428 * src/bison.simple: Remove a useless #line directive.
4429 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
4430 * src/output.c (get_lines_number): New.
776209d6 4431 (output_parser): Adjust, now takes care about the lines of a
f0440388
MA
4432 output muscles.
4433 Fix line numbering.
4434 (actions_output): Computes the number of lines taken by actions.
4435 (output_master_parser): Insert new skeleton which is the name of
4436 the output parser file name.
4437
a79986b8
MA
44382001-12-15 Marc Autret <autret_m@epita.fr>
4439
4440 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
4441
4ec8e00f
MA
44422001-12-15 Marc Autret <autret_m@epita.fr>
4443
4444 * src/output.c (output_gram): Keep track of the hairy one.
4445
1a4648ff
AD
44462001-12-15 Akim Demaille <akim@epita.fr>
4447
4448 Make `make distcheck' work.
4449
4450 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
4451 system.h which uses libgettext.h.
4452
9c2c67e6
AD
44532001-12-15 Akim Demaille <akim@epita.fr>
4454
4455 * src/nullable.c (set_nullable): Useless rules must be skipped,
4456 otherwise, since we range over their symbols, we might look at a
4457 nonterminal which no longer ``exists'', i.e., it is not counted in
4458 `nvars', hence we overflow our arrays.
4459
93ede233
AD
44602001-12-15 Akim Demaille <akim@epita.fr>
4461
4462 The header can also be produced directly, without any obstack!
4463 Yahoo!
4464
4465 * src/files.c, src/files.h (defines_obstack): Remove.
4466 (compute_header_macro): Global.
4467 (defines_obstack_save): Remove.
4468 * src/reader.c (parse_union_decl): No longer output to
4469 defines_obstack: its content can be found in the `stype' muscle
4470 anyway.
4471 (output_token_translations): Merge into...
4472 (symbols_output): this.
4473 Rename as...
4474 (symbols_save): this.
4475 (reader): Adjust.
4476 * src/output.c (header_output): New.
4477 (output): Call it.
4478
2666f928
AD
44792001-12-15 Akim Demaille <akim@epita.fr>
4480
4481 * src/reader.c (parse_union_decl): Instead of handling two obstack
4482 simultaneously, use one to define the `stype' muscle, and use the
4483 value of the latter to fill defines_obstack.
4484 (copy_comment): Remove.
4485 (copy_comment2): Work for a single obstack.
4486 Rename as...
4487 (copy_comment): this.
4488
428046f8
AD
44892001-12-15 Akim Demaille <akim@epita.fr>
4490
4491 * src/lex.c, src/lex.h (xgetc): No longer static.
4492 * src/reader.c (parse_union_decl): Revamp.
4493
ea52d706
AD
44942001-12-15 Akim Demaille <akim@epita.fr>
4495
4496 Still making progress in separating Bison into (i) input, (ii)
4497 process, (iii) output: now we can directly output the parser file
4498 without using table_obstack at all.
4499
4500 * src/files.c, src/files.h (table_obstack): Bye bye.
4501 (parser_file_name): New.
4502 * src/files.c (compute_output_file_names): Compute it.
4503 * src/output.c (actions_output, output_parser)
4504 (output_master_parser): To a file instead of an obstack.
4505
3f96f4dc
AD
45062001-12-15 Akim Demaille <akim@epita.fr>
4507
4508 Attach actions to rules, instead of pre-outputting them to
4509 actions_obstack.
4510
4511 * src/gram.h (rule_t): action and action_line are new members.
4512 * src/reader.c (symbol_list): Likewise.
4513 (copy_action): Save the actions within the rule.
4514 (packgram): Save them in rule_table.
4515 * src/output.c (actions_output): New.
4516 (output_parser): Use it on `%%actions'.
4517 (output_rule_data): Don't free rule_table.
4518 (output): Do it.
4519 (prepare): Don't save the `action' muscle.
4520 * src/bison.simple: s/%%action/%%actions/.
4521
51576fb3
AD
45222001-12-15 Akim Demaille <akim@epita.fr>
4523
4524 * src/reader.c (copy_action): When --yacc, don't append a `;'
4525 to the user action: let it fail if lacking.
dee049eb 4526 Suggested by Arnold Robbins and Tom Tromey.
51576fb3 4527
2648a72d
AD
45282001-12-14 Akim Demaille <akim@epita.fr>
4529
4530 * src/lex.c (literalchar): Simply return the char you decoded, non
4531 longer mess around with obstacks and int pointers.
4532 Adjust all callers.
4533
92790e5b
AD
45342001-12-14 Akim Demaille <akim@epita.fr>
4535
4536 * src/lex.c (literalchar): Don't escape the special characters,
4537 just decode them, and keep them as char (before, eol was output as
4538 the 2 char string `\n' etc.).
4539 * src/output.c (output_rule_data): Use quotearg to output the
4540 token strings.
4541
927c1557
PE
45422001-12-13 Paul Eggert <eggert@twinsun.com>
4543
4544 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
4545 Do not infringe on the global user namespace when using C++.
4546 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
4547 All uses of `fprintf' and `stderr' changed.
4548
4549 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
4550
ed8e1f68
AD
45512001-12-13 Akim Demaille <akim@epita.fr>
4552
4553 The computation of nullable is broken: it doesn't handle empty
4554 RHS's properly.
4555
4556 * tests/torture.at (GNU AWK Grammar): New.
4557 * tests/sets.at (Nullable): New.
4558 * src/nullable.c (set_nullable): Instead of blindly looping over
4559 `ritems', loop over the rules, and then over their rhs's.
4560
4561 Work around Autotest bugs.
4562
4563 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
4564 frame, because Autotest understand lines starting with a `+' as
4565 traces from the shell. Then, they are not processed properly.
4566 Admittedly an Autotest bug, but we don't have time to wait for
4567 Autotest to catch up.
4568 * tests/regression.at (Broken Closure): Adjust to the new table
4569 frames.
4570 Move to...
4571 * tests/sets.at: here.
4572
cb581495
AD
45732001-12-13 Akim Demaille <akim@epita.fr>
4574
4575 * src/closure.c (closure): Use nrules instead of playing tricks
4576 with BITS_PER_WORD.
4577
2e729273
AD
45782001-12-13 Akim Demaille <akim@epita.fr>
4579
4580 * src/print.c (print_actions): Output the handling of `$' as the
4581 traces do: shifting the token EOF. Before EOF was treated as a
4582 nonterminal.
4583 * tests/regression.at: Adjust some tests.
4584 * src/print_graph.c (print_core): Complete the set of items via
4585 closure. The next-to-final and final states are still unsatisfying,
4586 but that's to be addressed elsewhere.
4587 No longer output the rule numbers, but do output the state number.
4588 A single loop for the shifts + gotos is enough, but picked a
4589 distinct color for each.
4590 (print_graph): Initialize and finalize closure.
4591
107f7dfb
AD
45922001-12-13 Akim Demaille <akim@epita.fr>
4593
4594 * src/reader.c (readgram): Remove dead code, an strip useless
4595 braces.
4596 (get_type): Remove, unused.
4597
9b53a24f
AD
45982001-12-12 Akim Demaille <akim@epita.fr>
4599
4600 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
4601 on that of lib/error.c.
4602
dbfb6dcd
AD
46032001-12-12 Akim Demaille <akim@epita.fr>
4604
4605 Some hosts don't like `/' in includes.
4606
4607 * src/system.h: Include libgettext.h without qualifying the path.
4608 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
4609 $(top_srcdir).
4610
c25fb648
MA
46112001-12-11 Marc Autret <autret_m@epita.fr>
4612
4613 * src/output.c (output_parser): Remove useless muscle.
4614
710ddc4f
MA
46152001-12-11 Marc Autret <autret_m@epita.fr>
4616
4617 * src/bison.simple: Remove #line just before %%epilogue. It
4618 is now handled in ...
4619 * src/reader.c (read_additionnal_code): Add the output of a
4620 #line for the epilogue.
4621
e83d80b8
MA
46222001-12-10 Marc Autret <autret_m@epita.fr>
4623
927c1557 4624 * src/reader.c (copy_definition): Re-use CPP-outed code which
e83d80b8
MA
4625 replace precedent remove.
4626 * src/bison.simple: Remove #line before %%prologue because
4627 %%input-line is wrong at this time.
4628
971d5158
MA
46292001-12-10 Marc Autret <autret_m@epita.fr>
4630
4631 * src/reader.c (symbols_output): Clean up.
927c1557 4632 * src/output.c (output_gram, output): Clean up.
971d5158 4633
5edafffd
AD
46342001-12-10 Akim Demaille <akim@epita.fr>
4635
4636 * src/lalr.c (initialize_lookaheads): New. Extracted from...
4637 * src/LR0.c (set_state_table): here.
4638 * src/lalr.c (lalr): Call it.
4639
0279f8e9
AD
46402001-12-10 Akim Demaille <akim@epita.fr>
4641
4642 * src/state.h (shifts): Remove the `number' member: shifts are
4643 attached to state, hence no longer need to be labelled with a
4644 state number.
4645
190c4f5f
AD
46462001-12-10 Akim Demaille <akim@epita.fr>
4647
4648 Now that states have a complete set of members, the linked list of
4649 shifts is useless: just fill directly the state's shifts member.
4650
4651 * src/state.h (shifts): Remove the `next' member.
4652 * src/LR0.c (first_state, last_state): Remove.
4653 Adjust the callers.
4654 (augment_automaton): Don't look for the shifts that must be added
4655 a shift on EOF: it is those of the state we looked for! But now,
4656 since shifts are attached, it is no longer needed to looking
4657 merely by its id: its number.
4658
2a73b93d
AD
46592001-12-10 Akim Demaille <akim@epita.fr>
4660
4661 * src/LR0.c (augment_automaton): Better variable locality.
4662 Remove an impossible branch: if there is a state corresponding to
4663 the start symbol being shifted, then there is shift for the start
4664 symbol from the initial state.
4665
74392f6a
AD
46662001-12-10 Akim Demaille <akim@epita.fr>
4667
4668 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
4669 only when appropriate: when insert_start_shifting_state' is not
4670 invoked.
4671 * tests/regression.at (Rule Line Numbers): Adjust.
4672
37c82725
AD
46732001-12-10 Akim Demaille <akim@epita.fr>
4674
4675 * src/LR0.c (augment_automaton): Now that all states have shifts,
4676 merge the two cases addition shifts to the initial state.
4677
6a164e0c
AD
46782001-12-10 Akim Demaille <akim@epita.fr>
4679
4680 * src/lalr.c (set_state_table): Move to...
4681 * src/LR0.c: here.
4682 * src/lalr.c (lalr): Don't call it...
4683 * src/LR0.c (generate_states): do it.
4684 * src/LR0.h (first_state): Remove, only the table is used.
4685
7215de24
AD
46862001-12-10 Akim Demaille <akim@epita.fr>
4687
4688 * src/LR0.h (first_shift, first_reduction): Remove.
4689 * src/lalr.c: Don't use first_shift: find shifts through the
4690 states.
4691
80e25d4d
AD
46922001-12-10 Akim Demaille <akim@epita.fr>
4693
4694 * src/LR0.c: Attach shifts to states as soon as they are
4695 computed.
4696 * src/lalr.c (set_state_table): Instead of assigning shifts to
4697 state, just assert that the mapping was properly done.
4698
0ab3728b
AD
46992001-12-10 Akim Demaille <akim@epita.fr>
4700
4701 * src/LR0.c (insert_start_shift): Rename as...
4702 (insert_start_shifting_state): this.
4703 (insert_eof_shifting_state, insert_accepting_state): New.
4704 (augment_automaton): Adjust.
4705 Better locality of the variables.
4706 When looking if the start_symbol is shifted from the initial
4707 state, using `while (... symbol != start_symbol ...)' sounds
4708 better than `while (... symbol < start_symbol ...)': If fail
4709 to see how the order between symbols could be relevant!
4710
78af9bbc
AD
47112001-12-10 Akim Demaille <akim@epita.fr>
4712
4713 * src/getargs.h: Don't declare `spec_name_prefix' and
4714 `spec_file_prefix', declared by src/files.h.
4715 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
4716 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
4717 * src/output.c (prepare): Adjust.
4718 * src/reader.c (symbols_output): Likewise.
4719 * src/vmsgetargs.c: Vaguely adjust, but who cares?
4720
bdef2a41
AD
47212001-12-10 Akim Demaille <akim@epita.fr>
4722
4723 * src/muscle_tab.c (muscle_init): NULL is a better default than
4724 `"0"'.
4725
3735969c
AD
47262001-12-10 Akim Demaille <akim@epita.fr>
4727
4728 * src/reader.c (reader): Calling symbols_output once is enough.
4729
49701457
AD
47302001-12-10 Akim Demaille <akim@epita.fr>
4731
4732 Now that states have a complete set of members, the linked list of
4733 reductions is useless: just fill directly the state's reductions
4734 member.
4735
4736 * src/state.h (struct reductions): Remove member `number' and
4737 `next'.
4738 * src/LR0.c (first_reduction, last_reduction): Remove.
4739 (save_reductions): Don't link the new reductions, store them in
4740 this_state.
4741 * src/lalr.c (set_state_table): No need to attach reductions to
4742 states, it's already done.
4743 * src/output.c (output_actions): No longer free the shifts, then
4744 the reductions, then the states: free all the states and their
4745 members.
4746
0edad749
AD
47472001-12-10 Akim Demaille <akim@epita.fr>
4748
4749 * src/options.c (OPTN, DRTV, BOTH): New.
4750 (option_table): Use them.
4751
0edad749
AD
4752 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
4753 the job of system.h.
4754 * src/options.c: Don't include stdio.h and xalloc.h for the same
4755 reasons.
4756
5449dd0f
AD
47572001-12-10 Akim Demaille <akim@epita.fr>
4758
4759 * src/output.c (output, prepare): Make sure the values of the
4760 muscles `action' and `prologue' are 0-terminated.
4761
a870c567
AD
47622001-12-10 Akim Demaille <akim@epita.fr>
4763
4764 Clean up GCC warnings.
4765
4766 * src/reader.c (copy_action): `buf' is not used.
4767 (parse_skel_decl): Be static.
4768 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
4769 * src/options.h (create_long_option_table): Have a real prototype.
4770 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
4771 (hash_delete_at): Return const void *.
4772 Adjust casts to preserve the const.
4773
80df8768
AD
47742001-12-10 Akim Demaille <akim@epita.fr>
4775
4776 * configure.in: Require 2.52g.
4777 M4 is not needed, but AUTOM4TE is.
4778 * m4/m4.m4: Remove.
4779 * tests/Makefile.am: Adjust.
4780
f693ad14
AD
47812001-12-10 Akim Demaille <akim@epita.fr>
4782
4783 One structure for states is enough, even though theoretically
4784 there are LR(0) states and LALR(1) states.
4785
4786 * src/lalr.h (state_t): Remove.
4787 (state_table): Be state_t **, not state_t *.
4788 * src/state.h (core, CORE_ALLOC): Rename as...
4789 (state_t, STATE_ALLOC): this.
4790 Add the LALR(1) members: shifts, reductions, errs.
4791 * src/LR0.c (state_table): Rename as...
4792 (state_hash): this, to avoid name clashes with the global
4793 `state_table'.
4794 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
4795 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
4796
74ffbcb6
AD
47972001-12-10 Akim Demaille <akim@epita.fr>
4798
4799 Bison dumps core on bash.y.
4800 Reported by Pascal Bart.
4801
4802 * src/warshall.c (bitmatrix_print): New.
4803 (TC): Use it.
4804 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
4805 j must be the outer loop.
4806 * tests/regression.at (Broken Closure): New.
4807
07708e19
AD
48082001-12-05 Akim Demaille <akim@epita.fr>
4809
4810 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
4811 its argument.
4812