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