]> git.saurik.com Git - bison.git/blame_incremental - ChangeLog
(symbol_make_alias): Set type of SYMVAL to be that of SYM's type.
[bison.git] / ChangeLog
... / ...
CommitLineData
12002-12-28 Paul Eggert <eggert@twinsun.com>
2
3 Version 1.75f.
4
5 Switch back to the Yacc style of conflict reports, undoing some
6 of the 2002-07-30 change.
7 * doc/bison.texinfo (Understanding): Use Yacc style for
8 conflict reports. Also, use new way of locating rules.
9 * src/conflicts.c (conflict_report):
10 Renamed from conflict_report_yacc, removing the old
11 'conflict_report'. Translate the entire conflict report at once,
12 so that we don't assume that "," has the same interpretation in
13 all languages.
14 (conflicts_output): Use Yacc-style conflict report for each state,
15 instead of our more-complicated style.
16 (conflicts_print): Use Yacc-style conflict report, except print
17 the input file name when not emulating Yacc.
18 * tests/conflicts.at (Unresolved SR Conflicts, Defaulted
19 Conflicted Reduction, %expect not enough, %expect too much,
20 %expect with reduce conflicts): Switch to Yacc-style conflict reports.
21 * tests/existing.at (GNU Cim Grammar): Likewise.
22 * tests/glr-regr1.at (Badly Collapsed GLR States): Likewise.
23
24 * src/complain.c (warn_at, warn, complain_at, complain, fatal_at,
25 fatal): Don't invoke fflush; it's not needed and it might even be
26 harmful for stdout, as stdout might not be open.
27 * src/reduce.c (reduce_print): Likewise.
28
292002-12-27 Paul Eggert <eggert@twinsun.com>
30
31 Fix a bug where error locations were not being recorded correctly.
32 This problem was originally reported by Paul Hilfinger in
33 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001901.html>.
34
35 * data/yacc.c (yyparse): New local var yylerrsp, to record the
36 top of the location stack's error locations.
37 (yyerrlab): Set it. When discarding a token, push its location
38 onto yylerrsp so that we don't lose track of the error's end.
39 (yyerrlab1): Now is only the target of YYERROR, so that we can
40 properly record the location of the action that failed. For GCC
41 2.93 and later, insert an __attribute__ ((__unused__)) to avoid
42 GCC warning about yyerrlab1 being unused if YYERROR is unused.
43 (yyerrlab2): New label, which yyerrlab now falls through to.
44 Compute the error's location by applying YYLLOC_DEFAULT to
45 the locations of all the symbols that went into the error.
46 * doc/bison.texinfo (Location Default Action): Mention that
47 YYLLOC_DEFAULT is also invoked for syntax errors.
48 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR):
49 Error locations include the locations of all the tokens that were
50 discarded, not just the last token.
51
522002-12-26 Paul Eggert <eggert@twinsun.com>
53
54 * src/files.c: Include quote.h.
55 (compute_output_file_names): Warn if we detect conflicting
56 outputs to the same file. This should catch the misunderstanding
57 exemplified by Debian Bug 165349, reported by Bruce Stephens..
58
59 * src/conflicts.c (conflicts_print): If the user specifies
60 "%expect N", report an error if there are any reduce/reduce
61 conflicts. This is what the manual says should happen.
62 This fixes Debian bug 130890, reported by Anthony DeRobertis.
63 * tests/conflicts.at (%expect with reduce conflicts): New test.
64
65 Don't use m4_include on relative file names, as it doesn't work as
66 desired if there happens to be a file with that name under ".".
67
68 * m4sugar/version.m4: Remove; it was included but it wasn't used.
69 * data/Makefile.am (dist_m4sugar_DATA): Remove m4sugar/version.m4.
70 * data/m4sugar/m4sugar.m4: Don't include m4sugar/version.m4.
71 * data/glr.c, data/lalr1.cc, data/yacc.c: Don't include c.m4.
72 * src/output.c (output_skeleton): Use full path names when
73 specifying a file to include; don't rely on include path, as
74 it's unreliable when the working file contains a file with
75 that name.
76
772002-12-25 Paul Eggert <eggert@twinsun.com>
78
79 Remove obsolete references to bison.simple and bison.hairy.
80 Problem mentioned by Aubin Mahe in
81 <http://mail.gnu.org/pipermail/help-bison/2002-December/001765.html>.
82 * data/glr.c: Comment fix.
83 * doc/bison.1: Remove references. Also, mention "yacc".
84
85 * src/getargs.c (getargs) [MSDOS]: Don't assume optarg != NULL
86 with -g option.
87
88 * src/parse-gram.y (declaration): Use enum "report_states" rather
89 than its numeric value 1.
90
91 * src/scan-skel.l ("@output ".*\n): Close any old yyout before
92 opening a new one. This fixes Debian bug 165349, reported by
93 Bruce Stephens.
94
952002-12-24 Paul Eggert <eggert@twinsun.com>
96
97 Version 1.75e.
98
99 * Makefile.maint (cvs-update): Don't assume that the shell
100 supports $(...), as Solaris sh doesn't.
101
102 * src/parse-gram.y (lloc_default): Remove test for empty
103 nonterminals at the end, since it didn't change the result.
104
1052002-12-24 Paul Eggert <eggert@twinsun.com>
106
107 If the user does not define YYSTYPE as a macro, Bison now declares it
108 using typedef instead of defining it as a macro. POSIX requires this.
109 For consistency, YYLTYPE is also declared instead of defined.
110
111 %union directives can now have a tag before the `{', e.g., the
112 directive `%union foo {...}' now generates the C code
113 `typedef union foo { ... } YYSTYPE;'; this is for Yacc compatibility.
114 The default union tag is `YYSTYPE', for compatibility with Solaris 9
115 Yacc. For consistency, YYLTYPE's struct tag is now `YYLTYPE'
116 instead of `yyltype'.
117
118 `yystype' and `yyltype' are now obsolescent macros instead of being
119 typedefs or tags; they are no longer documented and will be
120 withdrawn in a future release.
121
122 * data/glr.c (b4_location_type): Remove.
123 (YYSTYPE): Renamed from yystype.
124 (YYSTYPE_IS_DECLARED): New macro, used to prevent double-typedef.
125 (struct YYLTYPE): Renamed from struct yyltype.
126 (YYLTYPE): Renamed from yyltype.
127 (yyltype, yystype): New (and obsolescent) macros,
128 for backward compatibility.
129 * data/yacc.c: Likewise.
130
131 * data/yacc.c (YYSTYPE): Declare as union YYSTYPE if the user
132 does not specify a union tag. This is for compatibility with
133 Solaris 9 yacc.
134
135 * src/parse-gram.y (add_param): 2nd arg is now char * not char
136 const *, since it is now modified by stripping surrounding { }.
137 (current_braced_code): Remove.
138 (PERCENT_DESTRUCTOR, PERCENT_PRINTER, PERCENT_UNION,
139 PERCENT_LEX_PARAM, PERCENT_PARSE_PARAM): Change names to include
140 trailing " {...}". Now of type <chars>.
141 (grammar_declaration): Adjust to bundled tokens.
142 (code_content): Remove; stripping is now done by add_param.
143 (print_token_value): Print contents of bundled tokens.
144 (token_name): New function.
145
146 * src/reader.h (braced_code, current_braced_code): Remove.
147 (token_name): New decl.
148
149 * src/scan-gram.l (handle_dollar, handle_at): Now takes int
150 token_type, not braced_code code_kind. All uses changed.
151 (SC_PRE_CODE): New state, for scanning after a keyword that
152 has (or usually has) an immediately-following braced code.
153 (token_type): New local var, to keep track of which token type
154 to return when scanning braced code.
155 (<INITIAL>"%destructor", <INITIAL>"%lex-param",
156 <INITIAL>"%parse-param", <INITIAL>"%printer,
157 <INITIAL>"%union"): Set token type and BEGIN SC_PRE_CODE
158 instead of returning a token type immediately.
159 (<INITIAL>"{"): Set token type.
160 (<SC_BRACED_CODE>"}"): Use it.
161 (handle_action_dollar, handle_action_at): Now returns bool
162 indicating success. Fail if ! current_rule; this prevents a core dump.
163 (handle_symbol_code_dollar, handle_symbol_code_at):
164 Remove; merge body into caller.
165 (handle_dollar, handle_at): Complain in invalid contexts.
166
167 * NEWS, doc/bison.texinfo: Document the above.
168 * NEWS: Fix years and program names in copyright notice.
169
1702002-12-17 Paul Eggert <eggert@twinsun.com>
171
172 * NEWS, doc/bison.texinfo (Parser Function, Pure Calling, Error
173 Reporting, Table of Symbols): Omit mentions of %lex-param and
174 %parse-param from the documentation for now.
175
1762002-12-15 Paul Eggert <eggert@twinsun.com>
177
178 Undo most of the 2002-11-12 yychar -> yytoken patch, as it broke
179 GCC 3.2.1 (which depends on yychar == YYEMPTY when there is no
180 lookahead symbol, and which sets yychar in parser actions) and it
181 disagreed with the Bison documentation. Bug
182 reported by Andrew Walrond.
183
184 * data/yacc.c (YYTRANSLATE): Don't check for negative argument,
185 as the caller now does that.
186 (yyclearin, YYBACKUP, yyparse): Use yychar, not yytoken.
187 (YYEMPTY): Parenthesize right hand side, since others use it.
188 (yyparse): Don't assume that our generated code is the only code
189 that sets yychar.
190
1912002-12-13 Paul Eggert <eggert@twinsun.com>
192
193 Version 1.75d.
194
195 POSIX requires a "yacc" command.
196 * src/Makefile.am (bin_SCRIPTS): New macro, for yacc.
197 (MOSTLYCLEANFILES): Add yacc.
198 (yacc): New rule.
199 * doc/bison.texinfo (Invocation, Bison Options): Mention yacc
200 as an alias for bison y.
201
202 * po/LINGUAS: Add da.
203
204 * src/getargs.c (__GNU_LIBRARY__) [lint]: Define to work around
205 problem with latest <getopt.h>.
206 (HACK_FOR___GNU_LIBRARY___PROTOTYPE): New macro.
207
208 * doc/fdl.texi: Upgrade to 1.2.
209 * lib/alloca.c, lib/error.c, lib/getopt.c, lib/getopt.h
210 lib/getopt1.c, lib/gettext.h, lib/memrchr.c, lib/obstack.c,
211 lib/obstack.h, lib/strnlen.c, lib/unlocked-io.h: Sync with
212 gnulib.
213 * config/install-sh: Sync with autotools.
214
215 Fix a bad interaction with flex 2.5.23 reported by Bruce Lilly in
216 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
217 * data/yacc.c (YYLTYPE, struct yyltype): Do not define unless
218 locations are requested.
219 (union yyalloc): Do not depend on YYLTYPE_IS_TRIVIAL unless
220 locations are requested.
221
2222002-12-12 Paul Eggert <eggert@twinsun.com>
223
224 Remove unportable casts and storage allocation tricks.
225 While we're at it, remove almost all casts, since they
226 usually aren't needed and are a sign of trouble.
227
228 * configure.ac (AC_CHECK_TYPES): Check for uintptr_t.
229
230 * src/derives.c (derives_compute): Do not subtract NTOKENS from
231 the pointer DSET returned by malloc; this isn't portable.
232 Instead, always use DSET[i - NTOKENS] rather than DSET[i].
233 Similarly for DERIVES.
234 * src/lalr.c (set_goto_map): Likewise, for GOTO_MAP and TEMP_MAP.
235 * src/nullable.c (nullable_compute): Likewise, for RSETS and NULLABLE.
236 * src/reduce.c (reduce_grammar_tables): Likewise, for nontermmap
237
238 * src/derives.c (derives_compute): Do not bother invoking
239 int_of_rule_number, since rule numbers are integers.
240
241 * src/files.c (concat2, tr, compute_base_name): Use xmalloc (N)
242 rather than XMALLOC (char, N).
243
244 * src/files.c (filename_split): Rewrite to avoid cast.
245
246 * src/gram.h (symbol_number_as_item_number,
247 item_number_as_symbol_number, rule_number_as_item_number,
248 item_number_as_rule_number):
249 Now inline functions rather than macros, to avoid casts.
250 * src/state.h (state_number_as_int): Likewise.
251 * src/tables.c (state_number_to_vector_number,
252 symbol_number_to_vector_number): Likewise.
253
254 * src/gram.h (int_of_rule_number): Remove; no longer used.
255
256 * src/lalr.c (add_lookback_edge): Use malloc rather than calloc,
257 since the resulting storage is always stored into.
258
259 * src/main.c (alloca) [C_ALLOCA]: Add decl here, the only place
260 where it's needed.
261
262 * src/muscle_tab.c (muscle_m4_output):
263 Now inline. Return bool, not int.
264 * src/state.c (state_compare): Likewise.
265 * src/symtab.c (symbol_check_defined,
266 symbol_check_alias_consistency, symbol_pack, symbol_translation,
267 hash_compare_symbol, hash_symbol):
268 Likewise.
269 * src/uniqstr.c (uniqstr_print): Likewise.
270 * src/muscle_tab.c (muscle_m4_output_processor):
271 New function, to avoid casts.
272 * src/state.c (state_comparator, stage_hasher): Likewise.
273 * src/symtab.c (symbol_check_defined_processor,
274 symbol_check_alias_consistency_processor, symbol_pack_processor,
275 symbol_translation_processor, hash_symbol_comparator,
276 hash_symbol_hasher): Likewise.
277 * src/uniqstr.c (uniqstr_print_processor): Likewise.
278 * src/muscle_tab.c (muscles_m4_output):
279 Use new functions instead of casting old functions unportably.
280 * src/state.c (state_hash_new): Likewise.
281 * src/symtab.c (symbols_new, symbols_do, symbols_check_defined,
282 symbols_token_translations_init):
283 Likewise.
284 * src/uniqstr.c (uniqstrs_new, hash_initialize, uniqstrs_do): Likewise.
285
286 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): Use long local
287 var instead of casting to long, to avoid casts.
288 (prepare_states): Use MALLOC rather than alloca, so that we don't
289 have to worry about alloca.
290 * src/state.c (state_hash_lookup): Likewise.
291
292 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>"'"): Use unsigned char
293 local var instead of casting to unsigned char, to avoid casts.
294
295 * src/state.c (TRANSITIONS_ALLOC, ERRS_ALLOC, REDUCTIONS_ALLOC,
296 STATE_ALLOC): Remove.
297 (transitions_new, errs_new, reductions_new, state_new): Use malloc
298 rather than calloc, and use offsetof to avoid allocating slightly
299 too much storage.
300 (state_new): Initialize all members.
301
302 * src/state.c (state_hash): Use unsigned accumulator, not signed.
303
304 * src/symtab.c (symbol_free): Remove; unused.
305 (symbol_get): Remove cast in lhs of assignment.
306 (symbols_do): Now static. Accept generic arguments, not
307 hashing-related ones.
308
309 * src/symtab.h: (NUMBER_UNDEFINED): Remove unnecessary cast.
310 (symbol_processor): Remove.
311 (symbols_do): Remove decl; now static.
312
313 * src/system.h (alloca): Remove; decl no longer needed.
314 (<stddef.h>): Include, for offsetof.
315 (<inttypes.>, <stdint.h>): Include if available.
316 (uintptr_t): New type, if system lacks it.
317 (CALLOC, MALLOC, REALLOC): New macros.
318 All uses of XCALLOC, XMALLOC, and XREALLOC changed to use these
319 new macros.
320
321 * src/tables.c (table_size): Now int, to pacify GCC.
322 (table_grow, table_ninf_remap): Use signed table size.
323 (save_row): Don't bother initializing locals when not needed.
324 (default_goto, goto_actions, pack_vector): Remove unnecessary casts.
325 * src/uniqstr.c (hash_compare_uniqstr): Likewise.
326
327 * src/vcg.h: Correct misspellings.
328
329 * src/vcg_defaults.h (G_CMAX): Now INT_MAX.
330
331
332 * src/getargs.c (getargs): Don't assume EOF == -1.
333
3342002-12-09 Paul Eggert <eggert@twinsun.com>
335
336 Change identifier spellings to avoid collisions with names
337 that are reserved by POSIX.
338
339 Don't use names ending in _t, since POSIX reserves them.
340 For consistency, remove _e and _s endings -- they're weren't
341 needed to remove ambiguity. All uses changed.
342 * src/uniqstr.h (uniqstr): Renamed from uniqstr_t, which in
343 turn was just renamed from struniq_t.
344 * src/uniqstr.c (uniqstr_processor): Renamed from struniq_processor,
345 which in turn was just renamed from struniq_processor_t.
346 (hash_compare_uniqstr): Renamed from hash_compare_struniq, which
347 in turn was renamed from hash_compare_struniq_t.
348 * src/LR0.c (struct state_list): Renamed from struct state_list_s.
349 (state_list): Renamed from state_list_t.
350 * src/assoc.h (assoc): Renamed from assoc_t.
351 * src/conflicts.c (enum conflict_resolution): Renamed from
352 enum conflict_resolution_e.
353 * src/derives.c (struct rule_list): Renamed from struct rule_list_s.
354 (rule_list): Renamed from rule_list_t.
355 * src/getargs.h (enum trace): Renamed from enum trace_e.
356 (enum report): Renamed from enum report_e.
357 * src/gram.h (item_number): Renamed from item_number_t.
358 (rule_number): Renamed from rule_number_t.
359 (struct rule_s): Remove the "rule_s" part; not used.
360 (rule): Renamed from rule_t.
361 (rule_filter): Renamed from rule_filter_t.
362 * src/lalr.c (struct goto_list): Renamed from struct goto_list_s.
363 (goto_list): Renamed from goto_list_t.
364 * src/lalr.h (goto_number): Renamed from goto_number_t.
365 * src/location.h (location): Renamed from location_t.
366 * src/muscle_tab.c (muscle_entry): Renamed from muscle_entry_t,
367 and moved here from:
368 * src/muscle_tab.h (muscle_entry_t): here.
369 * src/nullable.c (struct rule_list): Renamed from struct rule_list_s.
370 (rule_list): Renamed from rule_list_t.
371 * src/print_graph.c (static_graph): Renamed from graph.
372 * src/reader.h (braced_code): Renamed from braced_code_t.
373 Remove brace_code_e tag.
374 * src/relation.h (relation_node): Renamed from relation_node_t.
375 (relation_nodes): Renamed from relation_nodes_t.
376 (relation): Renamed from relation_t.
377 * src/state.h (state_number): Renamed from state_number_t.
378 (struct state): Renamed from struct state_s.
379 (state): Renamed from state_t.
380 (transitions): Renamed from transitions_t. Unused (and
381 misspelled) transtion_s tag removed.
382 (errs): Renamed from errs_t. Unused errs_s tag removed.
383 (reductions): Renamed from reductions_t. Unused tag
384 reductions_s removed.
385 * src/symlist.h (symbol_list): Renamed from symbol_list_t.
386 (struct symbol_list): Renamed from struct symbol_list_s.
387 * src/symtab.h (symbol_number): Renamed from symbol_number_t.
388 (struct symbol): Renamed from struct symbol_s.
389 (symbol): Renamed from symbol_t.
390 * src/tables.c (vector_number): Renamed from vector_number_t.
391 (action_number): Renamed from action_t.
392 * src/tables.h (base_number): Renamed from base_t.
393 * src/vcg.h (enum color): Renamed from enum color_e.
394 (enum textmode): Renamed from enum textmode_e.
395 (enum shape): Renamed from enum shape_e.
396 (struct colorentry): Renamed from struct colorentry_s.
397 (struct classname): Renamed from struct classname_s.
398 (struct infoname): Renamed from struct infoname_s.
399 (enum layoutalgorithm): Renamed from enum layoutalgorithm_e.
400 (enum decision): Renamed from enum decision_e.
401 (enum orientation): Renamed from enum orientation_e.
402 (enum alignment): Renamed from enum alignment_e.
403 (enum arrow_mode): Renamed from enum arrow_mode_e.
404 (enum crossing_type): Renamed from enum crossing_type_e.
405 (enum view): Renamed from enum view_e.
406 (struct node): Renamed from struct node_s.
407 (node): Renamed from node_t.
408 (enum linestyle): Renamed from enum linestyle_e.
409 (enum arrowstyle): Renamed from enum arrowstyle_e.
410 (struct edge): Renamed from struct edge.
411 (edge): Renamed from edge_t.
412 (struct graph): Renamed from struct graph_s.
413 (graph): Renamed from graph_t.
414 * tests/calc.at (_AT_DATA_CALC_Y, Simple LALR Calculator):
415 Rename value_t -> value.
416 * tests/input.at (Torturing the Scanner): Rename value_t -> value,
417 value_t_as_yystype -> value_as_yystype.
418
419 Don't include <errno.h> in the mainstream code, since it
420 reserves E[A-Z0-9]* and we want to use symbols like 'EQUALS'.
421 * lib/get-errno.c, lib/get-errno.h: New files.
422 * lib/Makefile.am (libbison_a_SOURCES): Add get-errno.h,
423 get-errno.c.
424 * src/files.c (xfopen, xfclose): Use get_errno instead of errno.
425 * src/output.c (output_skeleton): Likewise.
426 * src/scan-gram.l (<INITIAL>{int}): Use set_errno and get_errno
427 instead of errno.
428 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>\\x[0-9abcdefABCDEF]+):
429 Likewise.
430 (handle_action_dollar, handle_action_at): Likewise.
431 * src/system.h: Do not include <errno.h>.
432 (TAB_EXT): Renamed from EXT_TAB.
433 (OUTPUT_EXT): Renamed from EXT_OUTPUT.
434
435 Avoid str[a-z]*, since <string.h> reserves that name space.
436 Change all instances of "struniq" in names to "uniqstr", and
437 likewise for "STRUNIQ" and "UNIQSTR".
438 * src/uniqstr.c: Renamed from src/struniq.c.
439 * src/uniqstr.h: Renamed from src/struniq.h.
440 * src/Makefile.am (bison_SOURCES): Adjust to these renamings.
441 * src/files.c (strsuffix): Remove; unused.
442 (concat2): Renamed from stringappend. Now static.
443 * src/files.h (strsuffix, stringappend): Remove; unused.
444 * src/parse-gram.y (<chars>): Renamed from <string>.
445 (<uniqstr>): Renamed from <struniq>.
446 * src/scan-gram.l (obstack_for_string): Renamed from string_obstack.
447 * src/vcg.h (struct node_s.expand): Renamed from struct node_s.stretch.
448 (struct graph_s.expand): Renamed from struct graph_s.stretch.
449 * src/vcg_defaults.h (G_EXPAND): Renamed from G_STRETCH.
450 (G_LONG_STRAIGHT_PHASE): Renamed from G_STRAIGHT_PHASE.
451 (N_EXPAND): Renamed from N_STRETCH.
452
453 Avoid *_MAX and *_MIN, since <limits.h> reserves that name space.
454 * data/yacc.c (YYSTACK_GAP_MAXIMUM): Renamed from YYSTACK_GAP_MAX.
455 * src/gram.h (ITEM_NUMBER_MAX, ITEM_NUMBER_MIN, RULE_NUMBER_MAX):
456 Remove; unused.
457 * src/lalr.h (GOTO_NUMBER_MAXIMUM): Renamed from GOTO_NUMBER_MAX.
458 * src/state.h (STATE_NUMBER_MAXIMUM): Renamed from STATE_NUMBER_MAX.
459 * src/symtab.h (SYMBOL_NUMBER_MAXIMUM): Renamed from SYMBOL_NUMBER_MAX.
460 * src/tables.c (VECTOR_NUMBER_MAX, VECTOR_NUMBER_MIN): Remove; unused.
461 (BASE_MAXIMUM): Renamed from BASE_MAX.
462 (BASE_MINIMUM): Renamed from BASE_MIN.
463 (ACTION_MAX): Remove; unused.
464 (ACTION_NUMBER_MINIMUM): Renamed from ACTION_MIN.
465 Unnecessary casts removed from above defines.
466
467
468 Fix misspelling in names.
469 * src/vcg.h (enum_alignment_e): Renamed from enum_alignement_e.
470 * src/vcg_defaults.h (G_NODE_ALIGNMENT): Renamed from
471 G_NODE_ALIGNEMENT.
472
473
474 * lib/timevar.c (timevar_report): Renamed from time_report,
475 for consistency with other names.
476 * lib/timevar.h (timevar_report): New decl.
477 * src/system.h (time_report): Remove; decl is now in lib/timevar.h.
478
479
480 Sort include-file uses.
481
482 Reorder all include files under src to be in the order "system.h".
483 then the ../lib include files in angle brackets (alphabetized),
484 then the . include files in double-quotes (alphabetized). Fix
485 dependency breakages encountered in this process, as follows:
486 * src/closure.h, src/derives.h, src/state.h: Include "gram.h".
487 * src/complain.c: Don't include stdlib.h, string.h _LIBC stuff.
488 * src/state.h: Include "symtab.h".
489
4902002-12-08 Paul Eggert <eggert@twinsun.com>
491
492 * data/glr.c, data/lalr1.cc, data/yacc.c: Do not use __file__,
493 since this causes problems when __file__ contains character
494 sequences like "@" that are treated specially by src/scan-skel.l.
495 Instead, just use the file's basename. This fixes the bug
496 reported by Martin Mokrejs in
497 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001945.html>.
498
4992002-12-06 Paul Eggert <eggert@twinsun.com>
500
501 Add support for rules that do not have trailing semicolons, as
502 POSIX requires. Improve the quality of locations in Bison
503 diagnostics.
504
505 * src/location.c: Include <quotearg.h>.
506 (empty_location): Now const.
507 (location_print): New function. Follow the recommendation of the
508 GNU Coding Standards for locations that span file boundaries.
509 * src/location.h: Do not include <quotearg.h>; no longer needed.
510 (boundary): New type.
511 (location_t): Use it. This allows locations to span file boundaries.
512 All member uses changed: file -> start.file or end.file (as needed),
513 first_line -> start.line, first_column -> start.column,
514 last_line -> end.line, last_column -> end.column.
515 (equal_boundaries): New function.
516 (LOCATION_RESET, LOCATION_STEP): Remove.
517 (LOCATION_PRINT): Remove. All callers changed to use location_print.
518 (empty_location): Now const.
519 (location_print): New decl.
520 * src/parse-gram.y (lloc_default): New function, which handles
521 empty locations more accurately.
522 (YYLLOC_DEFAULT): Use it.
523 (%token COLON): Remove.
524 (%token ID_COLON): New token.
525 (rules): Use it.
526 (declarations, rules): Remove trailing semicolon.
527 (declaration, rules_or_grammar_declaration):
528 Allow empty (";") declaration.
529 (symbol_def): Remove empty actions; no longer needed.
530 (rules_or_grammar_declaration): Remove trailing semicolon.
531 (semi_colon.opt): Remove.
532 * src/reader.h: Include location.h.
533 (scanner_cursor): New decl.
534 * src/reduce.c (nonterminals_reduce): Use warn_at rather than
535 rolling our own.
536 * src/scan-gram.l (YY_USER_INIT): Initialize scanner_cursor instead
537 of *loc.
538 (STEP): Remove. No longer needed, now that adjust_location does
539 the work. All uses removed.
540 (scanner_cursor): New var.
541 (adjust_location): Renamed from extend_location. It now sets
542 *loc and adjusts the scanner cursor. All uses changed.
543 Don't bother testing for CR.
544 (handle_syncline): Remove location arg; now updates scanner cursor.
545 All callers changed.
546 (unexpected_end_of_file): Now accepts start boundary of token or
547 comment, not location. All callers changed. Update scanner cursor,
548 not the location.
549 (SC_AFTER_IDENTIFIER): New state.
550 (context_state): Renamed from c_context. All uses changed.
551 (id_loc, code_start, token_start): New local vars.
552 (<INITIAL,SC_AFTER_IDENTIFIER>): New initial context. Move all
553 processing of Yacc white space and equivalents here.
554 (<INITIAL>{id}): Save id_loc. Begin state SC_AFTER_IDENTIFIER
555 instead of returning ID immediately, since we need to search for
556 a subsequent colon.
557 (<INITIAL>"'", "\""): Save token_start.
558 (<INITIAL>"%{", "{", "%%"): Save code_start.
559 (<SC_AFTER_IDENTIFIER>): New state, looking for a colon.
560 (<SC_YACC_COMMENT>, <SC_COMMENT>, <SC_LINE_COMMENT>):
561 BEGIN context_state at end, not INITIAL.
562 (<SC_ESCAPED_STRING>"\"", <SC_ESCAPED_CHARACTER>"'",
563 <SC_BRACED_CODE>"}", <SC_PROLOGUE>"%}", <SC_EPILOGUE><<EOF>>):
564 Return correct token start.
565 (<SC_BRACED_CODE,SC_PROLOGUE,SC_EPILOGUE>): Save start boundary when
566 the start of a character, string or multiline comment is found.
567 * tests/conflicts.at (S/R in initial, Defaulted Conflicted
568 Reduction): Adjust reported locations to match the more-precise
569 results now expected.
570 * tests/input.at (Invalid $n, Invalid @n, Type Clashes): Likewise.
571 * tests/reduce.at (Useless Rules, Reduced Automaton,
572 Underivable Rules): Likewise.
573 * tests/regression.at (Invalid inputs): No longer `expecting ";"
574 or "|"' now that so many other tokens are allowed by the new grammar.
575
576 * src/complain.h (current_file): Remove duplicate decl;
577 current_file is now owned by files.h.
578 * src/complain.c, src/scan-gram.l: Include files.h.
579
5802002-12-06 Paul Eggert <eggert@twinsun.com>
581
582 * data/glr.c (yy_reduce_print): Don't assume that yyrline[yyrule]
583 promotes to int; it might be unsigned int.
584 * data/yacc.c (yy_reduce_print): Likewise.
585
586 * doc/bison.texinfo (Table of Symbols): YYERROR_VERBOSE should
587 be #defined in the prologue, not in the Bison declarations.
588 This fixes Debian Bug 102878, reported by Shaul Karl.
589
5902002-12-02 Paul Eggert <eggert@twinsun.com>
591
592 * configure.ac (AC_REPLACE_FUNCS): Add strtoul.
593 * lib/strtoul.c: New file, from gnulib.
594 This fixes a porting bug reported by Peter Klein in
595 <http://mail.gnu.org/pipermail/bug-bison/2002-December/001944.html>.
596
5972002-11-30 Paul Eggert <eggert@twinsun.com>
598
599 * src/scan-gram.l (no_cr_read, extend_location): Move to epilogue,
600 and put only a forward declaration in the prologue. This is for
601 consistency with the other scanner helper functions.
602
603 Type clashes now generate warnings, not errors, since it
604 appears that POSIX may allow some grammars with type clashes.
605 * src/reader.c (grammar_current_rule_check): Warn about
606 type clashes instead of complaining.
607 * tests/input.at (Type Clashes): Expect warnings, not complaints.
608
609 Add Yacc library, since POSIX requires it.
610 * doc/bison.texinfo (Yacc Library): New node. Regenerate top menu.
611 * lib/Makefile.am (lib_LIBRARIES, liby_a_SOURCES): New macros.
612 * lib/main.c, lib/yyerror.c: New files.
613
614 gram_error can be static; it need not be extern.
615 * src/reader.h (gram_error): Remove decl.
616 * src/parse-gram.y (gram_error): Now static. Add static decl.
617 (print_token_value): Omit parameter names from forward decl,
618 for consistency.
619
6202002-11-29 Paul Eggert <eggert@twinsun.com>
621
622 * doc/bison.texinfo: Emphasize that yylex and yyerror must
623 be declared before being used. E.g., one should typically
624 declare them in the prologue. Use GNU coding style in examples.
625 Put "const" consistently after the type it modifies. Mention
626 that C99 supports "inline". Mention that yyerror traditionally
627 returns "int".
628
629 %parse-param and %lex-param now take just one argument, the
630 declaration; the argument name is deduced from the declaration.
631
632 * doc/bison.texinfo (Parser Function, Pure Calling, Error
633 Reporting, Table of Symbols): Document this.
634 * src/parse-gram.y (add_param): New function.
635 (COMMA): Remove.
636 (declaration): Implement new rule for %parse-param and %lex-param.
637 * src/scan-gram.l: "," now elicits a warning, rather than being
638 a token; this is more compatible with byacc.
639 * tests/calc.at (Simple LALR Calculator): Adopt new convention.
640
6412002-11-27 Paul Eggert <eggert@twinsun.com>
642
643 Rename identifiers to avoid real and potential collisions.
644
645 * data/c.m4 (b4_yysymprint_generate): yyout -> yyoutput,
646 to avoid collision with lex macro described by Bruce Lilly in
647 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001929.html>.
648 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise.
649 * doc/bison.texinfo (Prologue, Tracing): yyprint -> print_token_value.
650 * src/parse-gram.y (print_token_value): Renamed from yyprint.
651 All uses changed.
652 (YYPARSE_PARAM, YYLEX_PARAM, yycontrol): Remove. All uses changed.
653 The name "yycontrol" violates the name space rules, and this stuff
654 wasn't being used anyway.
655 (input): Remove action; this stuff wasn't being used.
656 (gram_error): Rename local variable yylloc -> loc.
657 * src/reader.h (struct gram_control_s, gram_control_t): Remove.
658 (YY_DECL): Don't use "yy" at start of local variables.
659 All uses changed, e.g., yylloc -> loc.
660 * src/scan-gram.l (STEP): Renamed from YY_STEP. All uses changed.
661 (STRING_GROW): Renamed from YY_OBS_GROW. All uses changed.
662 (STRING_FINISH): Renamed from YY_OBS_FINISH. All uses changed.
663 (STRING_FREE): Renamed from YY_OBS_FREE. All uses changed.
664
665 * src/parse-gram.y (gram_error): loc is now const *.
666 * src/reader.h (gram_error): Likewise.
667
6682002-11-24 Paul Eggert <eggert@twinsun.com>
669
670 Version 1.75c.
671
672 * tests/actions.at (Actions after errors): Use an output format
673 more similar to that of the Printers and Destructors test.
674 Test the position of the ';' token too.
675 (Printers and Destructors): Likewise.
676 (Printers and Destructors: %glr-parser): Remove for now, to avoid
677 unnecessarily alarming people when the test fails.
678
679 * data/yacc.c (yyerrlab1): Move this label down, so that the
680 parser does not discard the lookahead token if the user code
681 invokes YYERROR. This change is required for POSIX conformance.
682
683 * lib/error.c: Sync with gnulib.
684
6852002-11-22 Paul Eggert <eggert@twinsun.com>
686
687 * lib/quotearg.c, lib/quotearg.h: Sync with gnulib.
688 * lib/mbswidth.c, lib/mbswidth.h: Likewise.
689 * lib/xmalloc.c: Likewise.
690
6912002-11-20 Paul Eggert <eggert@twinsun.com>
692
693 * lib/argmatch.c, lib/argmatch.h: Sync with gnulib.
694
6952002-11-20 Paul Eggert <eggert@twinsun.com>
696
697 Avoid use of <assert.h>, as the GNU Coding Standards hint that one
698 should use `if (! x) abort ();' rather than `assert (x);', and
699 anyway it's one less thing to worry about configuring.
700
701 * data/glr.c, lib/hash.c, src/system.h: Do not include <assert.h>.
702 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Likewise,
703 and replace all instances of assert with abort.
704 * tests/calc.at (_AT_DATA_CALC_Y): Likewise.
705 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): Likewise.
706
707 * data/glr.c (yydoAction, yyglrReduce, yysplitStack, yyresolveStates,
708 yyresolveAction, yyprocessOneStack): Use abort rather than assert.
709 * lib/hash.c (hash_lookup, hash_get_first, hash_get_next,
710 hash_find_entry, hash_rehash, hash_insert): Likewise.
711 * src/conflicts.c (resolve_sr_conflict): Likewise.
712 * src/lalr.c (set_goto_map, map_goto): Likewise.
713 * src/nullable.c (nullable_compute): Likewise.
714 * src/output.c (prepare_rules, token_definitions_output): Likewise.
715 * src/reader.c (packgram, reader): Likewise.
716 * src/state.c (state_new, state_free, state_transitions_set,
717 state_reduction_find): Likewise.
718 * src/symtab.c (symbol_user_token_number_set, symbol_make_alias,
719 symbol_pack): Likewise.
720 * src/tables.c (conflict_row, pack_vector): Likewise.
721 * src/vcg.c (get_color_str, get_textmode_str, get_shape_str,
722 get_layoutalgorithm_str, get_decision_str, get_orientation_str,
723 get_node_alignement_str, get_arrow_mode_str, get_crossing_type_str,
724 get_view_str, get_linestyle_str, get_arrowstyle_str): Likewise.
725
726 * lib/argmatch.h (ARRAY_CARDINALITY): Do not bother to #undef.
727 (ARGMATCH_CONSTRAINT): New macro.
728 (ARGMATCH_ASSERT): Use it.
729
730 * src/system.h (verify): New macro.
731 * src/getargs.c (trace_argmatch, report_argmatch): Use verify
732 rather than assert.
733 * src/tables.c (tables_generate): Likewise.
734
735 * src/struniq.c (struniq_assert): Now returns void, and aborts
736 if the assertion is false.
737 (struniq_assert_p): Remove.
738 * src/struniq.h: Likewise.
739
7402002-11-18 Paul Eggert <eggert@twinsun.com>
741
742 * data/glr.c (yygetLRActions): Replace `yyindex' with
743 `yytable[yyindex]' to fix typo introduced in my 2002-11-09 patch.
744 This fixes the regression with Sun ONE Studio 7 cc that I reported in
745 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001892.html>.
746
7472002-11-18 Akim Demaille <akim@epita.fr>
748
749 * doc/bison.texinfo (Tracing): `yyprint' shouldn't prepend a
750 space.
751 From Tim Van Holder.
752
7532002-11-17 Paul Eggert <eggert@twinsun.com>
754
755 Pacify Sun ONE Studio 7 lint. Also, rename "ParseError"
756 to "SyntaxError" for consistency with my 2002-11-15 change.
757
758 * data/glr.c (YYDPRINTF, YYDSYMPRINT, YYDSYMPRINTF) [!YYDEBUG]: Do
759 not define to {}, since this breaks the common use of `YYDPRINTF
760 ((...));' if a single statement is desired (e.g. before `else').
761 Work around GCC warnings by surrounding corresponding calls with
762 {} if needed.
763 (yyhasResolvedValue): Remove unused function.
764 (yymergeOptionSets, yyresolvStack): Use `continue;' for empty
765 loop body.
766 (yyreportSyntaxError): Renamed from yyreportParseError.
767 (yyrecoverSyntaxError): Renamed from yyrecoverParseError.
768 All uses changed.
769 * tests/calc.at (_AT_DATA_CALC_Y): Make vars static instead of
770 extern when possible. Remove unused initializations.
771
7722002-11-16 Akim Demaille <akim@epita.fr>
773
774 Augment the similarity between GLR and LALR traces.
775
776 * data/yacc.c (yy_stack_print, YY_STACK_PRINT, yy_reduce_print)
777 (YY_REDUCE_PRINT): New.
778 (yyparse): Use them.
779 * data/glr.c (yy_reduce_print): Use YYFPRINTF, no need for
780 YYDPRINT here.
781 (yyglrReduce, yyrecoverParseError, yyparse): Don't report the
782 state reached after the reduction/recovery, since...
783 (yyparse, yyprocessOneStack): Report the state we are entering in.
784
7852002-11-16 Akim Demaille <akim@epita.fr>
786
787 * src/getargs.h, src/getargs.c (trace_e, trace_args, trace_types):
788 Add support for --trace=skeleton.
789 * src/scan-skel.l: %option debug.
790 Scan strings of non-@ or \n instead of character by character.
791 (scan_skel): Handle trace_skeleton.
792 (QPUTS): New.
793 (@output_parser_name@, @output_header_name@): ``Restore'' their
794 support (used to be M4 macros).
795 * data/yacc.c: Quote larger chunks, a la glr.c.
796 * data/lalr1.cc: Likewise.
797 The header guards are no longer available, so use some other
798 string than `YYLSP_NEEDED'.
799
8002002-11-16 Akim Demaille <akim@epita.fr>
801
802 Make the ``Printers and Destructors'' test more verbose, taking
803 `yacc.c''s behavior as (possibly wrong) reference.
804
805 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Use printf
806 instead of fprint on stdout.
807 Set and report the last_line of the symbols.
808 Consistently display values and locations.
809
8102002-11-16 Paul Eggert <eggert@twinsun.com>
811
812 * data/yacc.c: Avoid over-quoting of __line__ and __file__.
813
8142002-11-15 Paul Eggert <eggert@twinsun.com>
815
816 * tests/actions.at (Actions after errors): New test case.
817
818 * data/glr.c, data/lalr1.cc, data/yacc.cc, doc/bison.texinfo,
819 src/conflicts.c, src/parse-gram.y, src/tables.c, src/tables.h,
820 tests/action.at, tests/calc.at, tests/conflicts.at,
821 tests/cxx-type.at, tests/regression.at:
822 "parse error" -> "syntax error" for POSIX compatibility.
823 "parsing stack overflow..." -> "parser stack overflow" so
824 that code matches Bison documentation.
825
8262002-11-15 Akim Demaille <akim@epita.fr>
827
828 * src/parse-gram.y (declaration): Have %parse-param and %lex-param
829 take two BRACED_CODE, not two string_content.
830 Free the scanner's obstack when we are done.
831 (code_content): New.
832 * tests/calc.at: Adjust.
833 * doc/bison.texinfo: Adjust.
834 Also, make sure to include the `,' for these declarations.
835
8362002-11-15 Tim Van Holder <tim.van.holder@pandora.be>
837
838 * m4/prereq.m4: Removed the commented jm_PREREQ_HASH
839 definition; avoids potential autoreconf problems.
840
8412002-11-15 Akim Demaille <akim@epita.fr>
842
843 Always check the value returned by yyparse.
844
845 * tests/calc.at (_AT_DATA_CALC_Y): Have `main' exit with the value
846 returned by yyparse.
847 (_AT_CHECK_CALC_ERROR): Take the expected exit value as argument.
848 Adjust calls.
849 * tests/glr-regr1.at (glr-regr1.y): Have `main' exit with the value
850 returned by yyparse.
851
8522002-11-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
853
854 * data/glr.c (yyFail): Always set yyerrflag. Corrects regression
855 on input.at test.
856
8572002-11-14 Paul Eggert <eggert@twinsun.com>
858
859 * src/output.c (output_skeleton): Call xfopen instead of
860 duplicating xfopen's body.
861
862 Fix bugs reported by Nelson H. F. Beebe in
863 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
864
865 * tests/headers.at (AT_TEST_CPP_GUARD_H): Don't assume that
866 "$CC -E foo.h" is allowed, as this doesn't work with the Portland
867 Group compiler. Instead, use "$CC -E bar.c". Include the .h
868 file twice in the grammar, as an extra check.
869
870 * tests/input.at (Torturing the Scanner): Surround the
871 backslash-newline tests with "#if 0", to make it less likely that
872 we'll run into compiler bugs. Bring back solitary \ inside
873 comment, but add a closing comment to work around HP C bug. Don't
874 test backslash-newline in C character constant. This should fix
875 the input.at bug reported by Nelson H. F. Beebe in
876 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001893.html>.
877
8782002-11-14 Akim Demaille <akim@epita.fr>
879
880 * tests/synclines.at (AT_SYNCLINES_COMPILE): Ignore the exit
881 status of the compiler.
882 Calling `exit 1' is no longer needed.
883 Reported by Nelson H. F. Beebe.
884
8852002-11-14 Akim Demaille <akim@epita.fr>
886
887 * tests/atlocal.in (CPPFLAGS): We have config.h.
888 * tests/testsuite.at (AT_DATA_GRAMMAR_PROLOGUE, AT_DATA_GRAMMAR):
889 New.
890 * tests/actions.at, tests/calc.at, tests/conflicts.at,
891 * tests/cxx-type.at, tests/glr-regr1.at, tests/headers.at,
892 * tests/regression.at, tests/torture.at: Use them for all the
893 grammars that are to be compiled.
894 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Rename as...
895 * tests/cxx-type.at (_AT_TEST_GLR_CXXTYPES): this.
896 * doc/bison.texinfo (GLR Parsers): Document `inline'.
897
8982002-11-14 Akim Demaille <akim@epita.fr>
899
900 * doc/bison.texinfo: Various formatting changes (alignments in
901 samples, additional @group/@end group, GCS in samples.
902 Use @deffn instead of simple @table to define the directives,
903 macros, variables etc.
904
9052002-11-13 Paul Eggert <eggert@twinsun.com>
906
907 Fix some bugs reported by Albert Chin-A-Young in
908 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001881.html>.
909
910 * tests/input.at (Torturing the Scanner): Don't invoke "cc a.c b.c
911 -o c"; the HP C compiler chatters during compilation.
912 Instead, invoke "cc -c a.c -o a.o; cc -c b.c -o b.o; cc a.o b.o -o c".
913 * tests/headers.at (export YYLTYPE): Likewise.
914
915 * tests/input.at (Torturing the Scanner): Remove lines containing
916 solitary backslashes, as they tickle a bug in the HP C compiler.
917
918 * tests/glr-regr1.at (Badly Collapsed GLR States): Avoid //
919 comments, since they're not portable. Use GNU coding style.
920
9212002-11-13 Akim Demaille <akim@epita.fr>
922
923 * data/yacc.c: Leave bigger chunks of quoted text.
924 (YYDSYMPRINTF): New.
925 Use it to report symbol activities.
926 * data/glr.c (YYDSYMPRINTF): New.
927 Use it.
928
9292002-11-12 Paul Eggert <eggert@twinsun.com>
930
931 Version 1.75b.
932
933 * data/glr.c (yydoAction): Return YYRESULTTAG, not int.
934 (yyglrReduce): Return yyok, not 0.
935 This should avoid the enumerated-type warnings reported
936 by Nelson H.F. Beebe in
937 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001872.html>.
938
939 * lib/bbitset.h (BITSET_INLINE): Remove.
940 * lib/bitset.h [! BITSET_INLINE]: Remove.
941 (bitset_set, bitset_reset, bitset_test): Rename local vars
942 to avoid shadowing warnings by GCC.
943
944 * data/glr.c (inline): Remove #define. It's the user's
945 responsibility to #define it away, just like 'const'.
946 This fixes one of the bugs reported by Nelson H.F. Beebe in
947 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001873.html>.
948
949 * Makefile.maint (po-check): Scan .l and .y files instead of the
950 .c and the .h files that they generate. This fixes the bug
951 reported by Tim Van Holder in:
952 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001352.html>
953 Look for N_ as well as for _. Try to avoid matching #define for
954 N_ and _.
955 * po/POTFILES.in: Remove src/parse-gram.c, src/scan-gram.c,
956 src/system.h. Add src/parse-gram.y, src/scan-gram.l.
957 * src/scan-gram.l: Revamp regular expressions so that " and '
958 do not confuse xgettext.
959
960 * src/struniq.h (struniq_new): Do not declare the return type
961 to be 'const'; this violates the C standard.
962 * src/struniq.c (struniq_new): Likewise.
963
9642002-11-12 Albert Chin-A-Young <china@thewrittenword.com>
965
966 * src/Makefile.am (LDADD): Link $(LIBINTL) last to avoid the
967 duplicate definition of optind on Tru64 UNIX 4.0D with the Compaq
968 linker.
969
9702002-11-12 Akim Demaille <akim@epita.fr>
971
972 * Makefile.maint: Sync with Autoconf:
973 (local_updates): New.
974
9752002-11-12 Akim Demaille <akim@epita.fr>
976
977 * po/POTFILES.in (src/lalr.c, src/state.c): Remove
978
9792002-11-12 Akim Demaille <akim@epita.fr>
980
981 * tests/actions.at (_AT_CHECK_PRINTER_AND_DESTRUCTOR): Display the
982 locations.
983
9842002-11-12 Akim Demaille <akim@epita.fr>
985
986 * data/c.m4 (b4_yysymprint_generate): Pass *yyvaluep to YYPRINT,
987 not yyvalue.
988
9892002-11-12 Akim Demaille <akim@epita.fr>
990
991 * tests/actions.at (AT_CHECK_PRINTER_AND_DESTRUCTOR): New.
992 Use it to test the GLR parser.
993
9942002-11-12 Akim Demaille <akim@epita.fr>
995
996 * tests/regression.at (input.y): s/YYEOF/MYEOF/, as the skeleton
997 defines it.
998 * data/glr.c (yystos): New.
999 (b4_yysymprint_generate, b4_yydestruct_generate): Invoke.
1000 (YYDSYMPRINT): New.
1001 (yyval): Don't define it, it is handled via M4.
1002 (yyrecoverParseError): Free verbosely the discarded symbols.
1003 * data/yacc.c (yysymprint): Remove, rather...
1004 (b4_yysymprint_generate): invoke.
1005 * data/c.m4 (b4_yysymprint_generate): New.
1006 Accept pointers as arguments, as opposed to the version from
1007 yacc.c.
1008 (b4_yydestruct_generate): Likewise.
1009 * tests/cations.at (Printers and Destructors): Use Bison directives
1010 instead of CPP macros.
1011 Don't rely on internal details.
1012
10132002-11-12 Akim Demaille <akim@epita.fr>
1014
1015 * data/c.m4 (b4_yydestruct_generate, b4_symbol_actions): New.
1016 * data/yacc.c: Rename yychar1 as yytoken, as in glr.c.
1017 Don't work on yychar (i.e., do set it to YYEMPTY, don't match
1018 it against YYEMPTY and so forth), work on yytoken (i.e., set
1019 it to YYEMPTY etc.).
1020 (yydestruct): Replace with a b4_yydestruct_generate invocation.
1021 (b4_symbol_actions): Remove.
1022 * data/glr.c (YYTRANSLATE): As for yacc.c, if negative, it stands
1023 for 0, end-of-input.
1024
10252002-11-12 Akim Demaille <akim@epita.fr>
1026
1027 * doc/bison.texinfo (Destructor Decl): New.
1028
10292002-11-12 Akim Demaille <akim@epita.fr>
1030
1031 * src/tables.c (tables_generate): Use free for pointers that
1032 cannot be NULL, not XFREE.
1033 (pack_vector): Use assert, not fatal, for bound violations.
1034 * src/state.c (state_new): Likewise.
1035 * src/reader.c (reader): Likewise.
1036 * src/lalr.c (set_goto_map): Likewise.
1037 * src/location.h (LOCATION_PRINT): If first_line is 0, just issue
1038 the file name.
1039
10402002-11-12 Akim Demaille <akim@epita.fr>
1041
1042 * src/scan-gram.l, src/reader.h (scanner_last_string_free):
1043 Restore.
1044 * src/scan-gram.l (last_string): Is global to the file, not to
1045 yylex.
1046 * src/parse-gram.y (input): Don't append the epilogue here,
1047 (epilogue.opt): do it here, and free the scanner's obstack.
1048 * src/reader.c (epilogue_set): Rename as...
1049 (epilogue_augment): this.
1050 * data/c.m4 (b4_epilogue): Defaults to empty.
1051
10522002-11-12 Akim Demaille <akim@epita.fr>
1053
1054 * src/getargs.c (long_options): Remove duplicates.
1055 * src/vmsgetargs.c, src/build.com, src/bison.cld, src/vmshlp.mar:
1056 Remove.
1057 * doc/bison.rnh: Remove.
1058 * doc/bison.texinfo (VMS Invocation): Remove.
1059
10602002-11-12 Akim Demaille <akim@epita.fr>
1061
1062 * src/struniq.h, src/struniq.c (struniq_t): Is const.
1063 (STRUNIQ_EQ, struniq_assert, struniq_assert_p): New.
1064
1065 Use struniq for symbols.
1066
1067 * src/symtab.h (symbol_t): The tag member is a struniq.
1068 (symbol_type_set): Adjust.
1069 * src/symtab.c (symbol_new): Takes a struniq.
1070 (symbol_free): Don't free the tag member.
1071 (hash_compare_symbol_t, hash_symbol_t): Rename as...
1072 (hash_compare_symbol, hash_symbol): these.
1073 Use the fact that tags as struniqs.
1074 (symbol_get): Use struniq_new.
1075 * src/symlist.h, src/symlist.c (symbol_list_n_type_name_get):
1076 Returns a strniq.
1077 * src/reader.h (merger_list, grammar_currentmerge_set): The name
1078 and type members are struniqs.
1079 * src/reader.c (get_merge_function)
1080 (grammar_current_rule_merge_set): Adjust.
1081 (TYPE, current_type): Are struniq.
1082
1083 Use struniq for file names.
1084
1085 * src/files.h, src/files.c (infile): Split into...
1086 (grammar_file, current_file): these.
1087 * src/scan-gram.c (YY_USER_INIT, handle_syncline): Adjust.
1088 * src/reduce.c (reduce_print): Likewise.
1089 * src/getargs.c (getargs): Likewise.
1090 * src/complain.h, src/complain.c: Likewise.
1091 * src/main.c (main): Call struniqs_new early enough to use it for
1092 file names.
1093 Don't free the input file name.
1094
10952002-11-12 Akim Demaille <akim@epita.fr>
1096
1097 * src/symtab.c (symbol_free): Remove dead deactivated code:
1098 type_name are properly removed.
1099 Don't use XFREE to free items that cannot be NULL.
1100 * src/struniq.h, src/struniq.c: New.
1101 * src/main.c (main): Initialize/free struniqs.
1102 * src/parse-gram.y (%union): Add astruniq member.
1103 (yyprint): Adjust.
1104 * src/scan-gram.l (<{tag}>): Return a struniq.
1105 Free the obstack bit that used to store it.
1106 * src/symtab.h (symbol_t): The 'type_name' member is a struniq.
1107
11082002-11-11 Paul Eggert <eggert@twinsun.com>
1109
1110 Revamp to fix many (but not all) of the C- and M4-related quoting
1111 problems. Among other things, this fixes the Bison bug reported
1112 by Jan Hubicka when processing the Bash grammar; see:
1113 <http://mail.gnu.org/pipermail/bison-patches/2002-November/001329.html>
1114
1115 Use new @ escapes consistently. Represent brackets with @{ and @}
1116 rather than @<:@ and @:>@, since this works a bit better with dumb
1117 editors like vi. Represent @ with @@, since @ is now consistently
1118 an escape. Use @oline@ and @ofile@ rather than __oline__ and
1119 __ofile__, to avoid unexpected expansions. Similarly, use @output
1120 rather than #output.
1121
1122 * data/c.m4 (b4_copyright): Omit file name from comment, since
1123 the file name could contain "*/".
1124 (b4_synclines_flag): Don't quote the 2nd argument; it should already
1125 be quoted. All uses changed.
1126
1127 * data/glr.c: Use new @ escapes consistently.
1128 (b4_input_suffix, b4_output_parser_suffix, b4_output_parser_name,
1129 b4_output_header_suffix, b4_output_header_name, b4_header_guard):
1130 Remove, since they couldn't handle arbitrary characters in file
1131 names.
1132 * data/lalr1.cc: Likewise.
1133 * data/yacc.c: Likewise.
1134
1135 * src/files.c (output_infix): Remove; all uses removed.
1136 * src/files.h: Likewise.
1137
1138 * data/glr.c: Remove use of "#ifdef b4_header_guard", since it
1139 mishandled funny characters in file names, and anyway it isn't
1140 needed any more.
1141 * data/yacc.c: Likewise.
1142 * data/lalr1.cc: Use YYSLP_NEEDED instead of b4_header_guard.
1143
1144 * data/glr.c (YYSTYPE_IS_TRIVIAL): Define when the .h file would.
1145 * data/yacc.c: Likewise.
1146
1147 * src/muscle_tab.c: Include quotearg.h, since we need to quote C
1148 strings now.
1149 (muscle_init): Quote filename as a C string.
1150 * src/muscle_tab.h (MUSCLE_GROW_STRING_PAIR): Remove; unused.
1151 (MUSCLE_OBSTACK_SGROW, MUSCLE_INSERT_C_STRING): New macros.
1152 * src/output.c (escaped_file_name_output): New function.
1153 (prepare_symbols): Quote tokens for M4.
1154 (prepare): Don't insert output_infix, output_prefix,
1155 output_parser_name, output_header_name; this is now down by scan-skel.
1156 Insert skeleton as a C string.
1157
1158 * src/output.c (user_actions_output, symbol_destructors_output,
1159 symbol_printers_output): Quote filenames for C and M4.
1160 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1161
1162 * src/scan-gram.l (<SC_CHARACTER>): Don't worry about any backslash
1163 escapes other than \\ and \'; this simplifies the code.
1164 (<SC_STRING>): Likewise, for \\ and \".
1165 (<SC_COMMENT,SC_LINE_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,
1166 SC_PROLOGUE,SC_EPILOGUE>): Escape $ and @, too.
1167 Use new escapes @{ and @} for [ and ].
1168
1169 * src/scan-skel.l (yylineno, yyoutname): Remove static vars, replacing
1170 them with auto vars.
1171 Switch to new escape scheme, where @ is the escape character uniformly.
1172 Abort if a stray escape character is found. Avoid unbounded input
1173 buffer when parsing non-escaped text.
1174
1175 * tests/input.at (Torturing the Scanner): Add tests that @oline@,
1176 __oline__, #output, $@, and @{ do not have unintended meanings.
1177
11782002-11-09 Paul Eggert <eggert@twinsun.com>
1179
1180 Fix the test failure due to GCC warnings described in
1181 <http://mail.gnu.org/pipermail/bug-bison/2002-November/001815.html>.
1182 * data/glr.c (yyis_pact_ninf, yyis_table_ninf): New macros, which
1183 evaluate to 0 if it's impossible for NINF to be in the respective
1184 table.
1185 (yygetLRActions, yyrecoverParseError): Use them.
1186
1187 * src/scan-gram.l (unexpected_end_of_file): Fix bug: columns were
1188 counted in the token inserted at end of file. Now takes
1189 location_t *, not location_t, so that the location can be
1190 adjusted. All uses changed.
1191
1192 * tests/regression.at (Invalid inputs): Adjust wording in
1193 diagnostic to match the new behavior.
1194
1195 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR,
1196 AT_DATA_HORIZONTAL_GRAMMAR, AT_DATA_LOOKAHEADS_GRAMMAR,
1197 AT_DATA_STACK_TORTURE): Replace `assert (x);' with `if (! (x))
1198 abort ();'. This reduces the runtime of the "Many lookaheads"
1199 test from 27.6 to 2.7 minutes on a 440 MHz Ultrasparc III running
1200 GCC 3.2.
1201
12022002-11-07 Paul Eggert <eggert@twinsun.com>
1203
1204 * src/parse-gram.y (CHARACTER): Remove unused token.
1205 All uses removed.
1206
1207 * src/scan-gram.l: Remove stack option. We no longer use the
1208 stack, since the stack was never deeper than 1; instead, use the
1209 new auto var c_context to record the stacked value.
1210
1211 Remove nounput option. At an unexpected end of file, we now unput
1212 the minimal input necessary to end cleanly; this simplifies the
1213 code.
1214
1215 Avoid unbounded token sizes where this is easy.
1216
1217 (unexpected_end_of_file): New function.
1218 Use it to systematize the error message on unexpected EOF.
1219 (last-string): Now auto, not static.
1220 (YY_OBS_FREE): Remove unnecessary do while (0) wrapper.
1221 (scanner_last_string_free): Remove; not used.
1222 (percent_percent_count): Move decl to just before use.
1223 (SC_ESCAPED_CHARACTER): Return ID at unexpected end of file,
1224 not the (never otherwised-used) CHARACTER.
1225
12262002-11-07 Akim Demaille <akim@epita.fr>
1227
1228 Let yyerror always receive the msg as last argument, so that
1229 yyerror can be variadic.
1230
1231 * data/yacc.c (b4_yyerror_args): New.
1232 Use it when calling yyerror.
1233 * data/glr.c (b4_yyerror_args, b4_lyyerror_args): New.
1234 Use it when calling yyerror.
1235 * doc/bison.texinfo (Error Reporting): Adjust.
1236 * tests/calc.at (_AT_DATA_CALC_Y): Adjust.
1237 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Adjust.
1238
12392002-11-06 Akim Demaille <akim@epita.fr>
1240
1241 #line should have quoted strings.
1242 Ideally, this should be done by m4_quotearg.
1243
1244 * src/scan-skel.l: Include quotearg.h.
1245 Quote __ofile__.
1246 * src/output.c (symbol_printers_output)
1247 (symbol_destructors_output): Quote the file name.
1248
12492002-11-06 Akim Demaille <akim@epita.fr>
1250
1251 * tests/regression.at (Invalid inputs): Adjust to the recent
1252 messages.
1253
12542002-11-06 Akim Demaille <akim@epita.fr>
1255
1256 Restore --no-lines.
1257 Reported by Jim Kent.
1258
1259 * data/c.m4 (b4_syncline): New.
1260 * data/glr.c, data/yacc.c, data/lalr1.cc: Use it.
1261 * src/reader.c (prologue_augment, epilogue_set): Use b4_syncline.
1262 * src/output.c (user_actions_output): Likewise.
1263 (prepare): Define 'b4_synclines_flag'.
1264 * src/muscle_tab.c (muscle_init): Don't define b4_linef.
1265
12662002-11-06 Akim Demaille <akim@epita.fr>
1267
1268 * src/main.c (main): Free `infile'.
1269 * src/scan-gram.l (handle_syncline): New.
1270 Recognize `#line'.
1271 * src/output.c (user_actions_output, symbol_destructors_output)
1272 (symbol_printers_output): Use the location's file name, not
1273 infile.
1274 * src/reader.c (prologue_augment, epilogue_set): Likewise.
1275
12762002-11-05 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1277
1278 * src/tables.c (matching_state): Don't allow states to match if
1279 either has GLR conflict entries.
1280
12812002-11-05 Paul Eggert <eggert@twinsun.com>
1282
1283 * src/scan-gram.l: Use more accurate diagnostics, e.g.
1284 "integer out of range" rather than "invalid value".
1285 * tests/input.at (Invalid $n, Invalid @n): Change expected wording
1286 accordingly.
1287
1288 Scan <% and %> digraphs in C code as POSIX 1003.1-2001 requires.
1289 Also, remove one static variable in the scanner.
1290
1291 * src/scan-gram.l (braces_level): Now auto, not static.
1292 Initialize to zero if the compiler is being picky.
1293 (INITIAL): Clear braces_level instead of incrementing it.
1294 (SC_BRACED_CODE): Treat <% and %> as { and } when inside C code,
1295 as POSIX 1003.1-2001 requires.
1296 * src/system.h (IF_LINT): New macro, taken from coreutils.
1297 * configure.ac: Define "lint" if --enable-gcc-warnings.
1298
12992002-11-05 Akim Demaille <akim@epita.fr>
1300
1301 * src/scan-gram.l: When it starts with `%', complain about the
1302 whole directive, not just that `invalid character: %'.
1303
13042002-11-04 Akim Demaille <akim@epita.fr>
1305
1306 * Makefile.maint: Update from Autoconf.
1307 (update, cvs-update, po-update, do-po-update): New.
1308
13092002-11-04 Akim Demaille <akim@epita.fr>
1310
1311 * tests/glr-regr1.at (Badly Collapsed GLR States): Prototype yylex
1312 and yyerror.
1313 Have yyerror `use' its arguments.
1314 * tests/calc.at (AT_CHECK_PUSHDEFS): AT_YYERROR_SEES_LOC_IF
1315 returns true when location & yacc & pure & parse-param.
1316 (_AT_DATA_CALC_Y): Let yyerror ``use'' its arguments.
1317
13182002-11-04 Akim Demaille <akim@epita.fr>
1319
1320 * src/location.h (LOCATION_PRINT): Use quotearg slot 3 to avoid
1321 clashes.
1322 * src/scan-gram.l: Use [\'] instead of ['] to pacify
1323 font-lock-mode.
1324 Use complain_at.
1325 Use quote, not quote_n since LOCATION_PRINT no longer uses the
1326 slot 0.
1327
13282002-11-03 Paul Eggert <eggert@twinsun.com>
1329
1330 * src/reader.c (get_merge_function, grammar_current_rule_check):
1331 Use consistent diagnostics for reporting type name clashes.
1332 Quote the types with <>, for consistency with Yacc.
1333 * tests/input.at (Type Clashes): Adjust to diagnostic changes.
1334
13352002-11-03 Akim Demaille <akim@epita.fr>
1336
1337 * data/c.m4 (b4_identification, b4_user_args, b4_parse_param):
1338 New.
1339 * data/yacc.m4 (b4_pure_args, b4_Pure_args): New.
1340 (b4_parse_param): Remove.
1341 Use b4_identification.
1342 Propagate b4_pure_args where needed to pass them to yyerror.
1343 * data/glr.m4 (b4_parse_param): Remove.
1344 (b4_user_formals, b4_pure_args, b4_pure_formals, b4_lpure_args)
1345 (b4_lpure_formals): New.
1346 Use b4_identification.
1347 (YY_USER_FORMALS, YY_USER_ARGS): Remove, replaced by
1348 b4_user_formals and b4_user_args.
1349 (yyexpandGLRStack, yyFail, yyaddDeferredAction, yyglrShiftDefer)
1350 (yyreportAmbiguity): When using a pure parser, also need
1351 the location, and the parse-params.
1352 Adjust callers.
1353 (yyuserAction, yyglrShift, yyreportParseError, yyrecoverParseError):
1354 When using a pure parser, also need the parse-params.
1355 Adjust callers.
1356 * tests/calc.at: Test pure (%pure-parser) and absolutely pure
1357 (%pure-parser + %parse-param) LALR and GLR parsers.
1358 (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): New, define AT_PARAM_IF,
1359 AT_LOCATION_IF, AT_PURE_IF, AT_GLR_IF, AAT_PURE_AND_LOC_IF,
1360 AT_GLR_OR_PARAM_IF, AT_YYERROR_ARG_LOC_IF, AT_YYERROR_SEES_LOC_IF.
1361 (_AT_DATA_CALC_Y): Equip for purity of yyerror.
1362 (_AT_CHECK_CALC_ERROR): Use AT_YYERROR_SEES_LOC_IF.
1363 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Equip for yyerror purity.
1364 * doc/bison.texinfo: Untabify the whole file.
1365 (Parser Function): Document %parse-param, deprecate YYPARSE_PARAM.
1366 (Pure Calling): Document %lex-param, deprecate YYLEX_PARAM.
1367 (Error Reporting): Adjust to these new directives.
1368 Document %error-verbose, deprecate YYERROR_VERBOSE.
1369
13702002-11-03 Akim Demaille <akim@epita.fr>
1371
1372 * tests/calc.at: Change all the AT_CHECK_CALC_LALR and
1373 AT_CHECK_CALC_GLR invocations to use % directives, instead of
1374 command line options.
1375 * tests/cxx-type.at: Formatting changes.
1376
13772002-11-03 Paul Eggert <eggert@twinsun.com>
1378
1379 * src/scan-gram.l: Revamp to fix POSIX incompatibilities,
1380 to count columns correctly, and to check for invalid inputs.
1381
1382 Use mbsnwidth to count columns correctly. Account for tabs, too.
1383 Include mbswidth.h.
1384 (YY_USER_ACTION): Invoke extend_location rather than LOCATION_COLUMNS.
1385 (extend_location): New function.
1386 (YY_LINES): Remove.
1387
1388 Handle CRLF in C code rather than in Lex code.
1389 (YY_INPUT): New macro.
1390 (no_cr_read): New function.
1391
1392 Scan UCNs, even though we don't fully handle them yet.
1393 (convert_ucn_to_byte): New function.
1394
1395 Handle backslash-newline correctly in C code.
1396 (SC_LINE_COMMENT, SC_YACC_COMMENT): New states.
1397 (eols, blanks): Remove. YY_USER_ACTION now counts newlines etc.;
1398 all uses changed.
1399 (tag, splice): New EREs. Do not allow NUL or newline in tags.
1400 Use {splice} wherever C allows backslash-newline.
1401 YY_STEP after space, newline, vertical-tab.
1402 ("/*"): BEGIN SC_YACC_COMMENT, not yy_push_state (SC_COMMENT).
1403
1404 (letter, id): Don't assume ASCII; e.g., spell out a-z.
1405
1406 ({int}, handle_action_dollar, handle_action_at): Check for integer
1407 overflow.
1408
1409 (YY_STEP): Omit trailing semicolon, so that it's more like C.
1410
1411 (<SC_ESCAPED_STRING,SC_ESCAPED_CHARACTER>): Allow \0 and \00
1412 as well as \000. Check for UCHAR_MAX, not 255.
1413 Allow \x with an arbitrary positive number of digits, as in C.
1414 Check for overflow here.
1415 Allow \? and UCNs, for compatibility with C.
1416
1417 (handle_symbol_code_dollar): Use quote_n slot 1 to avoid collision
1418 with quote slot used by complain_at.
1419
1420 * tests/input.at: Add tests for backslash-newline, m4 quotes
1421 in symbols, long literals, and funny escapes in strings.
1422
1423 * configure.ac (jm_PREREQ_MBSWIDTH): Add.
1424 * lib/Makefile.am (libbison_a_SOURCES): Add mbswidth.h, mbswidth.c.
1425 * lib/mbswidth.h, lib/mbswidth.c: New files, from GNU gettext.
1426 * m4/Makefile.am (EXTRA_DIST): Add mbswidth.m4.
1427 * m4/mbswidth.m4: New file, from GNU coreutils.
1428
1429 * doc/bison.texinfo (Grammar Outline): Document // comments.
1430 (Symbols): Document that trigraphs have no special meaning in Bison,
1431 nor is backslash-newline allowed.
1432 (Actions): Document that trigraphs have no special meaning.
1433
1434 * src/location.h (LOCATION_COLUMNS, LOCATION_LINES): Remove;
1435 no longer used.
1436
14372002-11-02 Paul Eggert <eggert@twinsun.com>
1438
1439 * src/reader.c: Don't include quote.h; not needed.
1440 (get_merge_function): Reword warning to be consistent with
1441 type clash diagnostic in grammar_current_rule_check.
1442
1443 * lib/quotearg.c (quotearg_buffer_restyled): Fix off-by-two
1444 bug in trigraph handling.
1445
1446 * src/output.c (prepare_symbols): When printing token names,
1447 escape "[" as "@<:@" and likewise for "]".
1448
1449 * src/system.h (errno): Remove declaration, as we are now
1450 assuming C89 or better, and C89 guarantees errno.
1451
14522002-10-30 Paul Eggert <eggert@twinsun.com>
1453
1454 * lib/bitset_stats.c (bitset_stats_read, bitset_stats_write):
1455 Check for close failures.
1456 * src/files.h (xfclose): Return void, not int, since it always
1457 returned zero.
1458 * src/files.c (xfclose): Likewise. Report I/O error if ferror
1459 indicates one.
1460 * src/output.c (output_skeleton): Use xfclose rather than fclose
1461 and ferror. xfclose now checks ferror.
1462
1463 * data/glr.c (YYLEFTMOST_STATE): Remove.
1464 (yyreportTree): Use a stack-based leftmost state. This avoids
1465 our continuing battles with bogus warnings about initializers.
1466
14672002-10-30 Akim Demaille <akim@epita.fr>
1468
1469 * src/system.h: Don't use #ifdef/#ifndef on HAVE_ values, only
1470 #if.
1471
14722002-10-29 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
1473
1474 * tests/glr-regr1.at: New test for reported regressions.
1475 * tests/testsuite.at: Add glr-regr1.at test.
1476 * tests/Makefile.am: Add glr-regr1.at test.
1477
14782002-10-24 Paul Eggert <eggert@twinsun.com>
1479
1480 Version 1.75a.
1481
1482 * tests/calc.at (_AT_DATA_CALC_Y): Remove unused strcat declaration.
1483 * tests/cxx-type.at (_AT_TEST_GLR_CALC): Include stdlib.h, since
1484 we use malloc. Don't assume 'A' through 'Z' are contiguous.
1485 Don't assume strdup exists; POSIX says its an XSI extension.
1486 Check for buffer overflow on input.
1487
14882002-10-24 Akim Demaille <akim@epita.fr>
1489
1490 * src/output.c (output_skeleton): Don't disable M4sugar comments
1491 too soon: it results in comments being expanded.
1492 * data/yacc.c, data/glr.c, data/lalr1.cc: Do it right before the
1493 first output.
1494
14952002-10-24 Akim Demaille <akim@epita.fr>
1496
1497 * data/yacc.c (m4_int_type): New.
1498 * data/c.m4 (m4_int_type): Don't use yysigned_char, but `signed
1499 char' as only yacc.c wants K&R portability.
1500 * data/glr.c (yysigned_char): Remove.
1501 * data/lalr1.cc: Rename the trailing b4_name as b4_parser_class_name.
1502 Reported by Quoc Peyrot.
1503
15042002-10-23 Paul Eggert <eggert@twinsun.com>
1505
1506 * src/main.c (main): With --trace=time, report times even if a
1507 non-fatal error occurs. Formerly, the times were reported in some
1508 such cases but not in others.
1509 * src/reader.c (reader): Just return if a complaint has been issued,
1510 instead of exiting, so that 'main' can report times.
1511
15122002-10-22 Akim Demaille <akim@epita.fr>
1513
1514 * src/system.h: Include sys/types.
1515 Reported by Bert Deknuydt.
1516
15172002-10-23 Paul Eggert <eggert@twinsun.com>
1518
1519 * configure.ac (AC_PROG_LEX): Use instead of AM_PROG_LEX.
1520 Suggested by Art Haas.
1521
15222002-10-22 Paul Eggert <eggert@twinsun.com>
1523
1524 * src/complain.c (exit) [! (STDC_HEADERS || _LIBC)]: Remove exit
1525 decl; not needed any more.
1526 * src/main.c (main): Use return to exit, undoing yesterday's change.
1527 The last OS that we could find where this wouldn't work is
1528 SunOS 3.5, and that's too old to worry about now.
1529
1530 * data/glr.c (struct yyltype): Define members even when not
1531 doing locations. This is more consistent with yacc.c, and it
1532 works around the following bug reports:
1533 http://mail.gnu.org/pipermail/bug-bison/2002-October/001764.html
1534 http://mail.gnu.org/pipermail/bug-bison/2002-October/001769.html
1535 and I hope it also fixes this bug report:
1536 http://mail.gnu.org/pipermail/bug-bison/2002-October/001748.html
1537
1538 * doc/bison.texinfo: Minor spelling and typographical fixes. Use
1539 @acronym consistently. Standardize on "Yacc" instead of "YACC",
1540 "Algol" instead of "ALGOL". Give a bit more history about BNF.
1541
15422002-10-22 Akim Demaille <akim@epita.fr>
1543
1544 * data/README: New.
1545
15462002-10-21 Paul Eggert <eggert@twinsun.com>
1547
1548 Be consistent about 'bool'; the old code used an enum in one
1549 module and an int in another, and this violates the C standard.
1550 * m4/stdbool.m4: New file, from coreutils 4.5.3.
1551 * configure.ac (AC_HEADER_STDBOOL): Add.
1552 * m4/Makefile.am (EXTRA_DIST): Add stdbool.m4.
1553 * src/muscle_tab.c (hash_compare_muscles): (a ? FALSE : TRUE) -> (! a)
1554 * src/symtab.c (hash_compare_symbol_t): Likewise.
1555 * src/system.h (bool, false, true): Use a definition consistent
1556 with ../lib/hash.c. All uses changed.
1557
1558 * src/complain.c (warning_issued): Renamed from warn_message_count,
1559 so that we needn't worry about integer overflow (!).
1560 Now of type bool. All uses changed.
1561 (complaint_issued): Renamed from complain_message_count; likewise.
1562
1563 * src/main.c (main): Use exit to exit with failure.
1564
1565 * src/complain.c (fatal_at, fatal): Use EXIT_FAILURE and EXIT_SUCCESS
1566 rather than 1 and 0.
1567 * src/main.c (main): Likewise.
1568 * src/getargs.c (getargs): Likewise.
1569 * src/reader.c (reader): Likewise.
1570
1571 * src/getarg.c (getargs): Remove duplicate code for
1572 "Try `bison --help'".
1573
1574 * src/files.c (xfopen, xfclose): Use EXIT_FAILURE rather than 2.
1575 What was that "2" for?
1576
1577 * src/complain.h (fatal, fatal_at): Add __attribute__((__noreturn__)).
1578 * src/getargs.c (usage): Likewise.
1579
1580 * src/getargs.c (getargs): When there are too few operands, report
1581 the last one. When there are too many, report the first extra
1582 one. This is how diffutils does it.
1583
15842002-10-20 Paul Eggert <eggert@twinsun.com>
1585
1586 Remove K&R vestiges.
1587 * configure.ac (AC_C_CONST, AM_C_PROTOTYPES): Remove.
1588 * src/complain.c (VA_START): Remove. Assume prototypes.
1589 (vfprintf) [! (HAVE_VPRINTF || defined vfprintf)]: New macro.
1590 (private_strerror, warn_at, warn, complain_at, complain, fatal_at,
1591 fatal): Assume prototypes.
1592 * src/complain.h: Assume prototypes.
1593 * src/system.h (PARAMS): Remove.
1594 Include <limits.h> unconditionally, since it's guaranteeed even
1595 for a freestanding C89 compiler.
1596 (SHRT_MIN, SHRT_MAX): Remove, since C89 guarantees them.
1597 * src/vmsgetargs.c (getargs, cli_present, cli_get_value): Prototype.
1598
15992002-10-20 Akim Demaille <akim@epita.fr>
1600
1601 * src/muscle_tab.c (muscle_grow): Remove trailing debugging code.
1602 * data/glr.c (YY_USER_FORMALS, YY_USER_ARGS): New.
1603 (yyuserAction, yydoAction, yyglrReduce, yyresolveValue)
1604 (yyresolveStates, yyresolveAction, yyresolveStack)
1605 (yyprocessOneStack): Use them.
1606 (yy_reduce_print): New.
1607 * tests/calc.at (_AT_DATA_CALC_Y): Exercise %parse-param.
1608
16092002-10-20 Akim Demaille <akim@epita.fr>
1610
1611 * data/c.m4 (b4_c_ansi_args): Recognize functions with no
1612 arguments and output `void'.
1613 (b4_c_function): Rename as...
1614 (b4_c_function_def): this.
1615 (b4_c_function_decl, b4_c_ansi_function_def)
1616 (b4_c_ansi_function_decl): New.
1617 Change the interpretation of the arguments: before `int, foo', now
1618 `int foo, foo'.
1619 * data/yacc.c (yyparse): Prototype and define thanks to these.
1620 Adjust b4_c_function_def uses.
1621 * data/glr.c (yyparse): Likewise, but ANSI only.
1622
16232002-10-20 Akim Demaille <akim@epita.fr>
1624
1625 * src/output.c (prepare): Move the definition of `tokens_number',
1626 `nterms_number', `undef_token_number', `user_token_number_max'
1627 to...
1628 (prepare_tokens): Here.
1629 (prepare_tokens): Rename as...
1630 (prepare_symbols): this.
1631 (prepare): Move the definition of `rules_number' to...
1632 (prepare_rules): here.
1633 (prepare): Move the definition of `last', `final_state_number',
1634 `states_number' to...
1635 (prepare_states): here.
1636 * data/yacc.c, data/lalr1.cc, data/glr.c: Normalize `>' into `<'.
1637
16382002-10-20 Akim Demaille <akim@epita.fr>
1639
1640 * src/tables.h, src/tables.c, src/output.c: Comment changes.
1641
16422002-10-20 Akim Demaille <akim@epita.fr>
1643
1644 * data/yacc.c, data/yacc.c (b4_location_if, b4_pure_if): Move to...
1645 * data/c.m4: here.
1646
16472002-10-20 Akim Demaille <akim@epita.fr>
1648
1649 * src/output.c (prepare): Use MUSCLE_INSERT_STRING.
1650 * src/muscle_tab.c (muscle_pair_list_grow): Rename `val as
1651 `pair'.
1652 (muscle_init): Move the `b4_ltype', `b4_maxdepth', `b4_initdepth',
1653 `name' to...
1654 * data/glr.c, data/lalr1.cc, data/yacc.c (b4_location_type)
1655 (b4_stack_depth_init, b4_stack_depth_max, b4_parser_class_name):
1656 These.
1657
16582002-10-19 Paul Eggert <eggert@twinsun.com>
1659
1660 Do not create a temporary file, as that involves security and
1661 cleanup headaches. Instead, use a pair of pipes.
1662 Derived from a suggestion by Florian Krohm.
1663 * lib/subpipe.c, lib/subpipe.h, m4/subpipe.m4: New files.
1664 * lib/mkstemp.c, lib/readpipe.c, lib/tempname.c, m4/mkstemp.m4: Remove.
1665 * configure.ac (UTILS_FUNC_MKSTEMP, jm_PREREQ_TEMPNAME): Remove.
1666 (BISON_PREREQ_SUBPIPE): Add.
1667 * lib/Makefile.am (libbison_a_SOURCES): Remove readpipe.c.
1668 Add subpipe.h, subpipe.c.
1669 * m4/Makefile.am (EXTRA_DIST): Remove mkstemp.m4. Add subpipe.m4.
1670 * po/POTFILES.in: Add lib/subpipe.c.
1671 * src/output.c: Include "subpipe.h".
1672 (m4_invoke): Remove decl.
1673 (scan_skel): New decl.
1674 (output_skeleton): Use pipe rather than temporary file for m4 input.
1675 Check that m4sugar.m4 is readable, to avoid deadlock.
1676 Check for pipe I/O error.
1677 * src/scan-skel.l (readpipe): Remove decl.
1678 (scan_skel): New function, to be used in place of m4_invoke.
1679 Read from stream rather than file.
1680
1681 * lib/timevar.c (TICKS_TO_MSEC, CLOCKS_TO_MSEC): Do not cast to
1682 float, as this generates a warning on Solaris 8 + GCC 3.2 with
1683 --enable-gcc-warnings. Instead, divide into 1.0 rather than 1;
1684 this generates a more-accurate value anyway.
1685
1686 * lib/timevar.c (timervar_accumulate): Rename locals to
1687 avoid confusion with similarly-named more-global.
1688 * src/muscle_tab.c (muscle_pair_list_grow): Likewise.
1689
1690 * src/output.c (prepare): Use xstrdup to convert char const *
1691 to char *, to avoid GCC warning.
1692
16932002-10-19 Akim Demaille <akim@epita.fr>
1694
1695 * tests/calc.at (_AT_DATA_CALC_Y): Define VAL, LOC, LEX_FORMALS,
1696 LEX_PRE_FORMALS, LEX_ARGS, LEX_PRE_ARGS, USE_LEX_ARGS.
1697 Use them to have `calc.y' ready for %pure-parser.
1698 * data/yacc.c (YYLEX): Pass a yylex return type to
1699 b4_c_function_call.
1700
17012002-10-19 Akim Demaille <akim@epita.fr>
1702
1703 Prototype support of %lex-param and %parse-param.
1704
1705 * src/parse-gram.y: Add the definition of the %lex-param and
1706 %parse-param tokens, plus their rules.
1707 Drop the `_' version of %glr-parser.
1708 Add the "," token.
1709 * src/scan-gram.l (INITIAL): Scan them.
1710 * src/muscle_tab.c: Comment changes.
1711 (muscle_insert, muscle_find): Rename `pair' as `probe'.
1712 * src/muscle_tab.h (MUSCLE_INSERT_PREFIX): Remove unused.
1713 (muscle_entry_s): The `value' member is no longer const.
1714 Adjust all dependencies.
1715 * src/muscle_tab.c (muscle_init): Adjust: use
1716 MUSCLE_INSERT_STRING.
1717 Initialize the obstack earlier.
1718 * src/muscle_tab.h, src/muscle_tab.c (muscle_grow)
1719 (muscle_pair_list_grow): New.
1720 * data/c.m4 (b4_c_function_call, b4_c_args): New.
1721 * data/yacc.c (YYLEX): Use b4_c_function_call to honor %lex-param.
1722 * tests/calc.at: Use %locations, not --locations.
1723 (AT_CHECK_CALC_GLR): Use %glr-parser, not %glr_parser.
1724
17252002-10-19 Akim Demaille <akim@epita.fr>
1726
1727 * src/getargs.c (usage): Take status as argument and exit
1728 accordingly.
1729 Report the traditional `Try ... --help' message when status != 0.
1730 (usage, version): Don't take a FILE * as arg, it is pointless.
1731 (getargs): When there is an incorrect number of arguments, make it
1732 an error, and report it GNUlically thanks to `usage ()'.
1733
17342002-10-18 Paul Eggert <eggert@twinsun.com>
1735
1736 * data/glr.c (yyreportParseError): Don't assume that sprintf
1737 yields the length of the printed string, as this is not true
1738 on SunOS 4.1.4. Reported by Peter Klein.
1739
1740 * tests/calc.at (_AT_DATA_CALC_Y): #undef memcmp and realloc.
1741 * tests/conflicts.at (%nonassoc and eof): Likewise.
1742 Fixes SunOS 4.1.4 test failure reported by Peter Klein.
1743
17442002-10-17 Akim Demaille <akim@epita.fr>
1745
1746 * src/getargs.h (trace_e): Add trace_scan, and trace_parse.
1747 * src/getargs.c (trace_types, trace_args): Adjust.
1748 * src/reader.c (grammar_current_rule_prec_set)
1749 (grammar_current_rule_dprec_set, grammar_current_rule_merge_set):
1750 Standardize error messages.
1751 And s/@prec/%prec/!
1752 (reader): Use trace_flag to enable scanner/parser debugging,
1753 instead of an adhoc scheme.
1754 * src/scan-gram.l: Remove trailing debugging code.
1755
17562002-10-16 Paul Eggert <eggert@twinsun.com>
1757
1758 * src/muscle_tab.h (MUSCLE_TAB_H_): Was misspelled as
1759 MUSCLE_TAB_H.
1760
1761 * NEWS: Officially drop support for building Bison with K&R C,
1762 since it didn't work anyway and it's not worth worrying about.
1763 * Makefile.maint (wget_files): Remove ansi2knr.c.
1764 (ansi2knr.c-url_prefix): Remove.
1765 * lib/.cvsignore: Remove ansi2knr, ansi2knr.*.
1766 * lib/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1767 * src/Makefile.am (AUTOMAKE_OPTIONS): Remove.
1768
17692002-10-15 Paul Eggert <eggert@twinsun.com>
1770
1771 Stop using the "enum_" trick for K&R-style function definitions;
1772 it confused me, and I was the author! Instead, assume that people
1773 who want to use K&R C compilers (when using these modules in GCC,
1774 perhaps?) will run ansi2knr.
1775
1776 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): Remove.
1777 All uses of "enum_" changed to "enum ".
1778 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
1779 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
1780
1781 * lib/abitset.c (abitset_and, abitset_and_cmp, abitset_and_or,
1782 abitset_and_or_cmp, abitset_andn, abitset_andn_cmp,
1783 abitset_andn_or, abitset_andn_or_cmp, abitset_bytes, abitset_copy,
1784 abitset_copy1, abitset_disjoint_p, abitset_empty_p,
1785 abitset_equal_p, abitset_init, abitset_list, abitset_list_reverse,
1786 abitset_not, abitset_ones, abitset_or, abitset_or_and,
1787 abitset_or_and_cmp, abitset_or_cmp, abitset_reset, abitset_set,
1788 abitset_size, abitset_small_list, abitset_subset_p, abitset_test,
1789 abitset_unused_clear, abitset_xor, abitset_xor_cmp, abitset_zero):
1790 Use function prototypes; this removes the need for declaring
1791 static functions simply to provide their prototypes.
1792 * lib/bitset.c (bitset_alloc, bitset_and_or_, bitset_and_or_cmp_,
1793 bitset_andn_or_, bitset_andn_or_cmp_, bitset_bytes, bitset_copy_,
1794 bitset_count_, bitset_create, bitset_dump, bitset_first,
1795 bitset_free, bitset_init, bitset_last, bitset_next,
1796 bitset_obstack_alloc, bitset_obstack_free, bitset_only_set_p,
1797 bitset_op4_cmp, bitset_or_and_, bitset_or_and_cmp_, bitset_prev,
1798 bitset_print, bitset_release_memory, bitset_toggle_,
1799 bitset_type_choose, bitset_type_get, bitset_type_name_get,
1800 debug_bitset): Likewise.
1801 * lib/bitset.h (bitset_set, bitset_reset, bitset_test): Likewise.
1802 * lib/bitset_stats.c (bitset_log_histogram_print,
1803 bitset_percent_histogram_print, bitset_stats_and,
1804 bitset_stats_and_cmp, bitset_stats_and_or,
1805 bitset_stats_and_or_cmp, bitset_stats_andn, bitset_stats_andn_cmp,
1806 bitset_stats_andn_or, bitset_stats_andn_or_cmp, bitset_stats_copy,
1807 bitset_stats_count, bitset_stats_disable, bitset_stats_disjoint_p,
1808 bitset_stats_dump, bitset_stats_empty_p, bitset_stats_enable,
1809 bitset_stats_equal_p, bitset_stats_free, bitset_stats_init,
1810 bitset_stats_list, bitset_stats_list_reverse, bitset_stats_not,
1811 bitset_stats_ones, bitset_stats_or, bitset_stats_or_and,
1812 bitset_stats_or_and_cmp, bitset_stats_or_cmp, bitset_stats_print,
1813 bitset_stats_print_1, bitset_stats_read, bitset_stats_reset,
1814 bitset_stats_set, bitset_stats_size, bitset_stats_subset_p,
1815 bitset_stats_test, bitset_stats_toggle, bitset_stats_type_get,
1816 bitset_stats_write, bitset_stats_xor, bitset_stats_xor_cmp,
1817 bitset_stats_zero): Likewise.
1818 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
1819 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
1820 bitsetv_dump, debug_bitsetv): Likewise.
1821 * lib/ebitset.c (ebitset_and, ebitset_and_cmp, ebitset_andn,
1822 ebitset_andn_cmp, ebitset_bytes, ebitset_copy, ebitset_copy_,
1823 ebitset_copy_cmp, ebitset_disjoint_p, ebitset_elt_add,
1824 ebitset_elt_alloc, ebitset_elt_calloc, ebitset_elt_find,
1825 ebitset_elt_free, ebitset_elt_last, ebitset_elt_remove,
1826 ebitset_elt_zero_p, ebitset_elts_grow, ebitset_empty_p,
1827 ebitset_equal_p, ebitset_free, ebitset_init, ebitset_list,
1828 ebitset_list_reverse, ebitset_not, ebitset_ones, ebitset_op3_cmp,
1829 ebitset_or, ebitset_or_cmp, ebitset_release_memory, ebitset_reset,
1830 ebitset_set, ebitset_size, ebitset_subset_p, ebitset_test,
1831 ebitset_weed, ebitset_xor, ebitset_xor_cmp, ebitset_zero):
1832 Likewise.
1833 * lib/lbitset.c (debug_lbitset, lbitset_and, lbitset_and_cmp,
1834 lbitset_andn, lbitset_andn_cmp, lbitset_bytes, lbitset_copy,
1835 lbitset_copy_cmp, lbitset_disjoint_p, lbitset_elt_alloc,
1836 lbitset_elt_calloc, lbitset_elt_find, lbitset_elt_free,
1837 lbitset_elt_link, lbitset_elt_unlink, lbitset_elt_zero_p,
1838 lbitset_empty_p, lbitset_equal_p, lbitset_free, lbitset_init,
1839 lbitset_list, lbitset_list_reverse, lbitset_not, lbitset_ones,
1840 lbitset_op3_cmp, lbitset_or, lbitset_or_cmp, lbitset_prune,
1841 lbitset_release_memory, lbitset_reset, lbitset_set, lbitset_size,
1842 lbitset_subset_p, lbitset_test, lbitset_weed, lbitset_xor,
1843 lbitset_xor_cmp, lbitset_zero): Likewise.
1844
18452002-10-14 Akim Demaille <akim@epita.fr>
1846
1847 Version 1.75.
1848
18492002-10-14 Akim Demaille <akim@epita.fr>
1850
1851 * tests/Makefile.am (maintainer-check-posix): New.
1852
18532002-10-14 Akim Demaille <akim@epita.fr>
1854
1855 * data/glr.c [YYDEBUG] (YYLEFTMOST_STATE): Initialize the yyloc
1856 member.
1857
18582002-10-14 Akim Demaille <akim@epita.fr>
1859
1860 * src/tables.c (table_ninf_remap): base -> tab.
1861 Reported by Matt Rosing.
1862
18632002-10-14 Paul Eggert <eggert@twinsun.com>
1864
1865 * tests/action.at, tests/calc.at, tests/conflicts.at,
1866 tests/cxx-type.at, tests/headers.at, tests/input.at,
1867 tests/regression.at, tests/synclines.at, tests/torture.at:
1868 Say "bison -o foo.c foo.y", not "bison foo.y -o foo.c",
1869 so that the tests still work even if POSIXLY_CORRECT is set.
1870 * doc/bison.texinfo (Rpcalc Compile, Invocation): Likewise.
1871
1872 * data/c.m4 (b4_int_type): Use yysigned_char instead of signed char,
1873 for portability to K&R hosts. Fix typo: signed char is guaranteed
1874 only to 127, not to 128.
1875 * data/glr.c (yysigned_char): New type.
1876 * data/yacc.c (yysigned_char): Likewise.
1877 * tests/regression.at (Web2c Actions): signed char -> yysigned_char.
1878
18792002-10-13 Paul Eggert <eggert@twinsun.com>
1880
1881 * data/yacc.c (yyparse): Rewrite to avoid "comparison is always
1882 true due to limited range of data type" warning from GCC.
1883
1884 * data/c.m4 (b4_token_defines): Protect against double-inclusion
1885 by wrapping enum yytokentype's definition inside #ifndef
1886 YYTOKENTYPE. This undoes a bug I introduced on 2002-10-12.
1887
18882002-10-13 Akim Demaille <akim@epita.fr>
1889
1890 * data/glr.c (yyglrShiftDefer, yyaddDeferredAction, yydoAction):
1891 Un yy- yyrhs to avoid the name clash with the global YYRHS.
1892
18932002-10-13 Akim Demaille <akim@epita.fr>
1894
1895 * Makefile.maint: Update from Autoconf 2.54.
1896 * m4/strerror_r.m4 (AC_FUNC_STRERROR_R): Remove, shipped with 2.54.
1897
18982002-10-13 Akim Demaille <akim@epita.fr>
1899
1900 * src/print.c (print_state): Separate the list of solved conflicts
1901 from the other items.
1902 * tests/conflicts.at (Resolved SR Conflicts): Adjust.
1903
19042002-10-13 Akim Demaille <akim@epita.fr>
1905
1906 Let nondeterministic skeletons be usable with deterministic
1907 tables.
1908
1909 With the patch, GAWK compiled by GCC without -O2 passes its test
1910 suite using a GLR parser driven by LALR tables. It fails with -O2
1911 because `struct stat' gives two different answers on my machine:
1912 88 (definition of an auto var) and later 96 (memset on this var).
1913 Hence the stack is badly corrumpted. The headers inclusion is to
1914 blame: if I move the awk.h inclusion before GLR's system header
1915 inclusion, the two struct stat have the same size.
1916
1917 * src/tables.c (pack_table): Always create conflict_table.
1918 (token_actions): Always create conflict_list.
1919 * data/glr.c (YYFLAG): Remove, unused.
1920
19212002-10-13 Akim Demaille <akim@epita.fr>
1922
1923 * configure.ac (AC_GNU_SOURCE): Use it instead of hand written code.
1924 (O0FLAGS): New.
1925 (VALGRIND, GXX): New.
1926 * tests/atlocal.in (CFLAGS): Use O0FLAGS.
1927 * tests/bison.in: Run $PREBISON a pre-command.
1928 * tests/Makefile.am (maintainer-check, maintainer-check-valgrind)
1929 (maintainer-check-g++): New.
1930 * Makefile.am (maintainer-check): New.
1931
19322002-10-13 Akim Demaille <akim@epita.fr>
1933
1934 * data/glr.c: Formatting changes.
1935 Tweak some trace messages to match yacc.c's.
1936
19372002-10-13 Akim Demaille <akim@epita.fr>
1938
1939 GLR parsers sometimes raise parse errors instead of performing the
1940 default reduction.
1941 Reported by Charles-Henry de Boysson.
1942
1943 * tests/calc.at (_AT_CHECK_CALC, _AT_CHECK_CALC_ERROR): Don't
1944 check the length of the traces when %glr.
1945 (_AT_CHECK_CALC_ERROR): Also skip `^Stack' lines, coming from
1946 GLR's traces.
1947 (AT_CHECK_CALC_LALR, AT_CHECK_CALC_GLR): New.
1948 Test GLR parsers.
1949 * data/glr.c (YYLEFTMOST_STATE): Fix its value.
1950 (yyltype): Remove the yy prefix from the member names.
1951 (yytable): Complete its comment.
1952 (yygetLRActions): Map error action number from YYTABLE from
1953 YYTABLE_NINF to 0.
1954 (yyisErrorAction): No longer compare YYACTION to YYPACT_NINF
1955 (which was a bug: it should have been YYTABEL_NINF, and yet it was
1956 not satisfying as we could compare an YYACTION computed from
1957 YYDEFACT to YYTABLE_NINF although they are unrelated): 0 is the
1958 only value for error actions.
1959 (yyreportParseError): In verbose parse error messages, don't issue
1960 `error' in the list of expected tokens.
1961 * data/yacc.c (yyparse) <yybackup>: Rewrite the decoding of the
1962 next action to perform to match glr.c's decoding.
1963 (yytable): Complete its comment.
1964
19652002-10-13 Paul Eggert <eggert@twinsun.com>
1966
1967 Fix problem reported by Henrik Grubbstroem in
1968 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001670.html>:
1969 "nonterm: { $$ = 123; } { $$ = $1; };" was wrongly rejected,
1970 because the Bison parser reads the second action before reducing
1971 the first one.
1972 * src/scan-gram.l (rule_length): New static var.
1973 Use it to keep track of the rule length in the scanner, since
1974 we can't expect the parser to be in lock-step sync with the scanner.
1975 (handle_action_dollar, handle_action_at): Use this var.
1976 * tests/actions.at (Exotic Dollars): Test for the problem.
1977
19782002-10-12 Paul Eggert <eggert@twinsun.com>
1979
1980 * lib/timevar.c [! IN_GCC && HAVE_SYS_TIME_H]: Include <sys/time.h>.
1981 * m4/timevar.m4 (BISON_PREREQ_TIMEVAR): Check for <sys/time.h>.
1982 Include <sys/time.h> when checking for clock_t and struct tms.
1983 Use same include order as source.
1984 This is for the SunOS 4.1.4 porting bug reported by Peter Klein in
1985 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001674.html>.
1986
1987 * lib/timevar.c: Update copyright date and clarify comments.
1988 (get_time) [IN_GCC]: Keep the GCC version for reference.
1989
1990 * lib/timevar.c, lib/timevar.h, lib/timevar.def: Import
1991 GCC version as of today, then merge Bison's changes.
1992 Change "GCC" to "Bison" in copyright notice. timevar.def's
1993 author is Akim, so change that too.
1994
1995 * src/reader.c (grammar_current_rule_check):
1996 Don't worry about the default action if $$ is untyped.
1997 Prevents bogus warnings reported by Jim Gifford in
1998 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001673.html>.
1999
2000 * data/c.m4 (b4_token_enum): Do not define YYTOKENTYPE.
2001 * data/glr.c, data/lalr1.cc, data/yacc.c:
2002 Output token definitions before the first part of user declarations.
2003 Fixes compatibility problem reported by Jim Gifford for kbd in
2004 <http://mail.gnu.org/pipermail/bug-bison/2002-October/001672.html>.
2005
20062002-10-11 Paul Eggert <eggert@twinsun.com>
2007
2008 * data/yacc.c (yyreport_parse_error): Remove, putting its body into...
2009 (yyparse): here. This undoes some of the 2002-07-25 change.
2010 Compatibility problem reported by Ralf S. Engelschall with
2011 OSSP cfg <http://www.ossp.org/pkg/lib/cfg/>.
2012
20132002-10-11 Akim Demaille <akim@epita.fr>
2014
2015 * tests/regression.at Characters Escapes): New.
2016 * src/scan-gram.l (SC_ESCAPED_CHARACTER): Accept \' in strings and
2017 characters.
2018 Reported by Jan Nieuwenhuizen.
2019
20202002-10-11 Akim Demaille <akim@epita.fr>
2021
2022 * po/id.po: New.
2023
20242002-10-10 Paul Eggert <eggert@twinsun.com>
2025
2026 Portability fixes for bitsets; this also avoids several GCC
2027 warnings.
2028
2029 * lib/abitset.c: Include <stddef.h>, for offsetof.
2030 * lib/lbitset.c: Likewise.
2031
2032 * lib/abitset.c (abitset_bytes): Return a size that is aligned
2033 properly for vectors of objects. Do not assume that adding a
2034 header size to a multiple of a word size yields a value that is
2035 properly aligned for the whole union.
2036 * lib/bitsetv.c (bitsetv_alloc): Likewise.
2037
2038 * lib/bitset_stats.c (bitset_stats_bytes): Adjust to new,
2039 unique names for structures.
2040 * lib/ebitset.c (ebitset_bytes): Likewise.
2041 * lib/lbitset.c (lbitset_bytes): Likewise.
2042
2043 * lib/abitset.c (abitset_ones, abitset_zero, abitset_empty_p,
2044 abitset_copy1, abitset_not, abitset_equal_p, abitset_subset_p,
2045 abitset_disjoint_p, abitset_and, abitset_and_cmp, abitset_andn,
2046 abitset_andn_cmp, abitset_or, abitset_or_cmp, abitset_xor,
2047 abitset_xor_cmp, abitset_and_or, abitset_and_or_cmp,
2048 abitset_andn_or, abitset_andn_or_cmp, abitset_or_and,
2049 abitset_or_and_cmp, abitset_copy): Supply prototype decls,
2050 to improve the type-checking that GCC can do.
2051 * lib/bitset.c (bitset_op4_cmp): Likewise.
2052 * lib/bitset_stats.c (bitset_stats_count,
2053 bitset_stats_empty_p, bitset_stats_ones, bitset_stats_zero,
2054 bitset_stats_copy, bitset_stats_disjoint_p,
2055 bitset_stats_equal_p, bitset_stats_not, bitset_stats_subset_p,
2056 bitset_stats_and, bitset_stats_and_cmp, bitset_stats_andn,
2057 bitset_stats_andn_cmp, bitset_stats_or, bitset_stats_or_cmp,
2058 bitset_stats_xor, bitset_stats_xor_cmp, bitset_stats_and_or,
2059 bitset_stats_and_or_cmp, bitset_stats_andn_or,
2060 bitset_stats_andn_or_cmp, bitset_stats_or_and,
2061 bitset_stats_or_and_cmp): Likewise.
2062 * lib/lbitset.c (lbitset_and, lbitset_and_cmp, lbitset_andn,
2063 lbitset_andn_cmp, lbitset_or, lbitset_or_cmp, lbitset_xor,
2064 lbitset_xor_cmp, lbitset_empty_p, lbitset_ones, lbitset_not,
2065 lbitset_subset_p, lbitset_disjoint_p, debug_lbitset): Likewise.
2066
2067 * lib/abitset.h: Include bitset.h, not bbitset.h.
2068 * lib/ebitset.h: Likewise.
2069 * lib/lbitset.h: Likewise.
2070
2071 * lib/bbitset.h: (enum_bitset_ops, enum_bitset_type): New types.
2072 All instances of parameters of type enum bitset_opts are now of
2073 type enum_bitset_opts, to conform to the C Standard, and similarly
2074 for enum_bitset_type.
2075 * lib/ebitset.c (enum_ebitset_find_mode): Likewise.
2076 * lib/lbitset.c (enum_lbitset_find_mode): Likewise.
2077
2078 Do not use "struct bitset_struct" to mean different things in
2079 different modules. Not only is this confusing, it violates
2080 the C Standard, which requires that structure types in different
2081 modules must be compatible if one is to be passed to the other.
2082 * lib/bbitset.h (bitset): Now points to a union, not to a struct.
2083 All instances of "struct bitset_struct *" replaced with "bitset".
2084 * lib/bitset.h (struct bitset_struct): Remove, replacing with....
2085 (union bitset_union, struct abitset_struct, struct ebitset_struct,
2086 struct lbitset_struct, struct bitset_stats_struct): New types.
2087 All uses of struct bitset_struct changed to union bitset_union,
2088 etc.
2089 * lib/abitset.c (struct abitset_struct, abitset,
2090 struct bitset_struct): Remove.
2091 * lib/bitset_stats.c (struct bitset_stats_struct, bitset_stats,
2092 struct bitset_struct): Remove.
2093 * lib/ebitset.c (struct ebitset_struct, ebitset, struct
2094 bitset_struct): Remove.
2095 * lib/lbitset.c (struct lbitset_struct, lbitset, bitset_struct):
2096 Likewise.
2097
2098 Do not call a function of type T using a call that assumes the
2099 function is of a different type U. Standard C requires that a
2100 function must be called with a type that is compatible with its
2101 definition.
2102 * lib/bbitset.h (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2103 New decls.
2104 * lib/bitset.c (bitset_and_or_, bitset_andn_or_, bitset_or_and_):
2105 New functions.
2106 * lib/ebitset.c (PFV): Remove.
2107 * lib/lbitset.c (PFV): Likewise.
2108 * lib/ebitset.c (ebitset_and, ebitset_andn, ebitset_or,
2109 ebitset_xor, ebitset_copy, ebitset_ones, ebitset_empty_p): New
2110 decls.
2111 (ebitset_and, ebitset_andn, ebitset_or, ebitset_xor): New functions.
2112 (ebitset_vtable): Use them.
2113 * lib/lbitset.c (lbitset_and, lbitset_andn, lbitset_or,
2114 lbitset_xor): New functions.
2115 (lbitset_vtable): Use them.
2116
2117 * lib/bitset.h (bitset_next, bitset_prev, bitset_only_set_p):
2118 Declare.
2119
2120 * lib/bitsetv.c (bitsetv_alloc): Add a cast to (void *) to avoid a
2121 GCC warning.
2122 * lib/lbitset.c (LBITSET_CURRENT1): Likewise.
2123 Use offsetof, for simplicity.
2124
21252002-10-06 Paul Eggert <eggert@twinsun.com>
2126
2127 * lib/bitset.h (bitset_reset): Do not assume that bitset_word is
2128 the same width as int. This reapplies a hunk of the 2002-08-12 patch
2129 <http://mail.gnu.org/pipermail/bison-patches/2002-August/001111.html>,
2130 which was inadvertently undone by the 2002-09-30 patch.
2131 * lib/lbitset.c (debug_lbitset): Do not assume that bitset_word is
2132 the same width as int.
2133
21342002-10-04 Paul Eggert <eggert@twinsun.com>
2135
2136 Version 1.50.
2137
2138 * configure.ac (AC_INIT), NEWS: Increment version number.
2139
2140 * doc/bison.texinfo: Minor spelling, grammar, and white space
2141 fixes.
2142 (Symbols): Mention that any negative value returned from yylex
2143 signifies end-of-input. Warn about negative chars. Mention
2144 the portable Standard C character set.
2145
2146 The GNU coding standard says CFLAGS and YFLAGS are reserved
2147 for the installer to set.
2148 * lib/Makefile.am (AM_CFLAGS): Renamed from CFLAGS.
2149 * src/Makefile.am (AM_CFLAGS): Likewise.
2150 (AM_YFLAGS): Renamed from YFLAGS.
2151
2152 Fix some MAX and MIN problems.
2153 * src/gram.h (ITEM_NUMBER_MIN): MIN_MAX -> INT_MIN.
2154 * src/lalr.h (GOTO_NUMBER_MAX): INT_MAX -> SHRT_MAX.
2155 * src/symtab.h (SYMBOL_NUMBER_MAX): New macro.
2156 * src/reader.c (reader): Use it.
2157
2158 * tests/regression.at (Braces parsing): Use grep, not fgrep, as
2159 POSIX 1003.1-2001 has removed fgrep.
2160
21612002-10-04 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
2162
2163 * lib/bbitset.h (BITSET_WINDEX_MAX): Redefine so that it cannot be
2164 interpreted as signed.
2165 * lib/ebitset.c (ebitset_list): Fix bug.
2166
21672002-10-01 Paul Eggert <eggert@twinsun.com>
2168
2169 More fixes for 64-bit hosts and large bitsets.
2170
2171 * lib/abitset.c (struct abitset_struct.n_bits, abitset_small_list,
2172 abitset_size, abitset_list, abitset_list_reverse, abitset_list):
2173 Use bitset_bindex, not int or unsigned int or size_t, to count bits.
2174 * lib/bbitset.h (struct bitset_vtable.size, struct bitset_vtable.count,
2175 struct bitset_vtable.list, struct bitset_vtable.list_reverse,
2176 bitset_count_, bitset_next, bitset_prev, bitset_first, bitset_last,
2177 bitset_count_): Likewise.
2178 * lib/bitset.h (bitset_iterator.num, bitset_iterator.i,
2179 bitset_first, bitset_last): Likewise.
2180 * lib/bitset_stats.c (bitset_stats_size, bitset_stats_list,
2181 bitset_stats_list_reverse, bitset_stats_size,
2182 bitset_stats_count, bitset_stats_list, bitset_stat_list_reverse):
2183 Likewise.
2184 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2185 * lib/bitsetv.c (bitsetv_alloc, bitsetv_create, bitsetv_free,
2186 bitsetv_zero, bitsetv_ones, bitsetv_transitive_closure,
2187 bitsetv_reflexive_transitive_closure): Likewise.
2188 * lib/bitsetv.h (bitsetv_alloc, bitsetv_create): Likewise.
2189 * lib/ebitset.c (ebitset_size, ebitset_list, ebitset_list_reverse):
2190 Likewise.
2191 * lib/lbitset.c (lbitset_size, lbitset_list, lbitset_list_merge):
2192 Likewise.
2193
2194 * lib/abitset.c (abitset_ones, abitset_zero, abitset_bytes):
2195 Use size_t, not unsigned int, to count bytes.
2196 * lib/abitset.h (abitset_bytes): Likewise.
2197 * lib/bitset.c (bitset_bytes, bitset_alloc, bitset_obstack_alloc):
2198 Likewise.
2199 * lib/bitset.h (bitset_bytes): Likewise.
2200 * lib/bitset_stats.c (bitset_stats_bytes, bitset_stats_init): Likewise.
2201 * lib/bitset_stats.h (bitset_stats_bytes): Likewise.
2202 * lib/bitsetv.c (bitsetv_alloc): Likewise.
2203 * lib/ebitset.c (ebitset_bytes): Likewise.
2204 * lib/ebitset.h (ebitset_bytes): Likewise.
2205 * lib/lbitset.c (lbitset_bytes): Likewise.
2206 * lib/lbitset.h (lbitset_bytes): Likewise.
2207
2208 * lib/abitset.c (abitset_empty_p, abitset_not, abitset_equal_p,
2209 abitset_subset_p, abitset_disjoint_p, abitset_and,
2210 abitset_and_cmp, abitset_andn, abitset_andn_cmp, abitset_or,
2211 abitset_or_cmp, abitset_xor, abitset_xor_cmp, abitset_and_or,
2212 abitset_and_or_cmp, abitset_andn_or, abitset_andn_or_cmp,
2213 abitset_or_and, abitset_or_and_cmp):
2214 Use bitset_windex instead of unsigned int.
2215 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2216 * lib/ebitset.c (struct ebitset_struct.size, ebitset_elts_grow,
2217 ebitset_elt_add, ebitset_elt_remove, ebitset_weed,
2218 ebitset_elt_find, ebitset_list_reverse, ebitset_list, ebitset_init):
2219 Likewise.
2220 * lib/lbitset.c (lbitset_ones, lbitset_not): Likewise.
2221
2222 * lib/bitset.c (bitset_print):
2223 Use proper printf formats for widths of integer types.
2224 * lib/bitset_stats.c (bitset_percent_histogram_print,
2225 bitset_log_histogram_print, bitset_stats_print_1): Likewise.
2226 * lib/bitsetv-print.c (bitsetv_matrix_dump): Likewise.
2227 * lib/bitsetv.c (bitsetv_dump, debug_bitsetv): Likewise.
2228 * lib/lbitset.c (lbitset_bytes): Likewise.
2229
2230 * lib/bbitset.h (BITSET_BINDEX_MAX, BITSET_WINDEX_MAX,
2231 BITSET_SIZE_MAX): New macros.
2232 (BITSET_INDEX_MAX): Remove. It wasn't right, since it assumed that
2233 sizeof (bitset_word) == sizeof (bitset_windex). All uses changed
2234 to BITSET_WINDEX_MAX.
2235
2236 * lib/bitset.c (bitset_next, bitset_prev, bitset_first,
2237 bitset_last): Return BITSET_BINDEX_MAX (not -1) for no value,
2238 since we now return the bitset_bindex type (not int).
2239
2240 * lib/bitsetv.c (bitsetv_alloc): Check for arithmetic overflow
2241 when computing sizes.
2242 * lib/ebitset.c (ebitset_elts_grow): Likewise.
2243
2244 * lib/lbitset.c (lbitset_elt_find): Simplify windex calculation
2245 and avoid cast to unsigned.
2246
22472002-09-30 Akim Demaille <akim@epita.fr>
2248
2249 * lib/abitset.c, lib/bbitset.h, lib/bitset.c, lib/bitset.h,
2250 * lib/bitset_stats.c, lib/bitsetv.c, lib/ebitset.c, lib/lbitset.c:
2251 Updates from Michael Hayes.
2252
22532002-09-30 Art Haas <ahaas@neosoft.com>
2254
2255 * configure.ac: Update AC_OUTPUT and AM_CONFIG_HEADER
2256 invocations.
2257 * tests/cxx-type.at (declarator): Don't rely on NDEBUG being not
2258 defined.
2259
22602002-09-27 Akim Demaille <akim@epita.fr>
2261
2262 Version 1.49c.
2263
22642002-09-27 Akim Demaille <akim@epita.fr>
2265
2266 * configure.ac (AM_INIT_AUTOMAKE): We _need_ 1.7.
2267 (Because of AC_LIBSOURCE).
2268
22692002-09-27 Akim Demaille <akim@epita.fr>
2270
2271 Playing with Autoscan.
2272
2273 * configure.ac: Remove the old LIBOBJ tweaks.
2274 (AC_REPLACE_FUNCS): Add strrchr and strtol.
2275 * lib/strrchr.c: New.
2276 * lib/strtol.c: New, from the Coreutils 4.5.1.
2277
22782002-09-27 Akim Demaille <akim@epita.fr>
2279
2280 Playing with Autoscan.
2281
2282 * m4/prereq.m4 (jm_PREREQ_ARGMATCH, jm_FUNC_ARGMATCH): New.
2283 * lib/Makefile.am (libbison_a_SOURCES): No longer include
2284 argmatch.c and argmatch.h, since they are AC_LIBSOURCE'd.
2285 * lib/strcasecmp.c, lib/strncasecmp.c, lib/memcmp.c: New, from the
2286 Coreutils 4.5.1.
2287
22882002-09-24 Akim Demaille <akim@epita.fr>
2289
2290 * doc/bison.texinfo (Stack Overflow): xref to Recursion.
2291 (Frequently Asked Questions, Parser Stack Overflow): New.
2292
22932002-09-13 Akim Demaille <akim@epita.fr>
2294
2295 Playing with autoscan.
2296
2297 * src/reader.c (get_merge_function): Use xstrdup, not strdup.
2298 * src/files.c (skeleton_find): Remove, unused.
2299 * m4/memcmp.m4: New, from the Coreutils 4.5.1.
2300 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): Run jm_FUNC_MEMCMP.
2301
23022002-09-13 Akim Demaille <akim@epita.fr>
2303
2304 * configure.ac (AM_INIT_AUTOMAKE): Require Automake 1.6.3.
2305 * Makefile.am (AUTOMAKE_OPTIONS): Don't.
2306
23072002-09-13 Akim Demaille <akim@epita.fr>
2308
2309 * configure.ac: Require 2.54.
2310 s/jm_FUNC_MALLOC/AC_FUNC_MALLOC/.
2311 s/jm_FUNC_REALLOC/AC_FUNC_REALLOC/.
2312 * m4/c-bs-a.m4, m4/malloc.m4, m4/mbstate_t.m4, m4/realloc.m4:
2313 Remove, provided by Autoconf macros.
2314
23152002-09-12 Akim Demaille <akim@epita.fr>
2316
2317 * m4/prereq.m4: Update, from Coreutils 4.5.1.
2318
23192002-09-12 Akim Demaille <akim@epita.fr>
2320
2321 * m4/prereq.m4: Update, from Fileutils 4.1.5.
2322 * configure.ac (jm_PREREQ_TEMPNAME): Invoke it.
2323 Reported by Martin Mokrejs.
2324
23252002-09-10 Akim Demaille <akim@epita.fr>
2326
2327 * src/parse-gram.y: Associate a human readable string to each
2328 token type.
2329 * tests/regression.at (Invalid inputs): Adjust.
2330
23312002-09-10 Gary V. Vaughan <gary@gnu.org>
2332
2333 * tests/Makefile.am ($(srcdir)/package.m4): Bison now ships
2334 with an Autoconf-2.5x style configure.ac.
2335
23362002-09-06 Paul Eggert <eggert@twinsun.com>
2337
2338 * doc/bison.texinfo (Conditions): Make explicit that the GPL
2339 exception applies only to yacc.c. This is a modification of a
2340 patch originally suggested by Akim Demaille.
2341
23422002-09-06 Akim Demaille <akim@epita.fr>
2343
2344 * data/c.m4 (b4_copyright): Move the GPL exception comment from
2345 here to...
2346 * data/yacc.c: here.
2347
2348 * data/lalr1.cc (struct yyltype): Don't define it, since we use
2349 LocationType.
2350 (b4_ltype): Default to yy::Location from location.hh.
2351
23522002-09-04 Jim Meyering <jim@meyering.net>
2353
2354 * data/yacc.c: Guard the declaration of yytoknum also with
2355 `#ifdef YYPRINT', so it is declared only when used.
2356
23572002-09-04 Akim Demaille <akim@epita.fr>
2358
2359 * configure.in: Rename as...
2360 * configure.ac: this.
2361 Bump to 1.49c.
2362
23632002-09-04 Akim Demaille <akim@epita.fr>
2364
2365 * src/assoc.c, src/closure.c, src/gram.c, src/injections.c,
2366 * src/lalr.c, src/LR0.c, src/relation.c, src/tables.c: Don't
2367 translate maintainer only messages.
2368
23692002-08-12 Paul Eggert <eggert@twinsun.com>
2370
2371 Version 1.49b.
2372
2373 * Makefile.am (SUBDIRS): Remove intl.
2374 (DISTCLEANFILES): Remove.
2375 * NEWS: Mention that GNU M4 is now required. Clarify what is
2376 meant by "larger grammars". Mention the pt_BR translation.
2377 * configure.in (AC_CHECK_DECLS): Add getenv, getopt.
2378 (AM_GNU_GETTEXT_VERSION): New macro, replacing GETTEXT_VERSION var.
2379 Bump version from 0.11.2 to 0.11.5.
2380 (BISON_PREREQ_STAGE): Remove.
2381 (AM_GNU_GETTEXT): Use external gettext.
2382 (AC_OUTPUT): Remove intl/Makefile.
2383
2384 * config/depcomp, config/install-sh: Sync with Automake 1.6.3.
2385
2386 * data/glr.c: Include string.h, for strlen.
2387 (yyreportParseError): Use size_t for yysize.
2388 (yy_yypstack): No longer nested inside yypstates, as nested
2389 functions are not portable. Do not assume size_t is the
2390 same width as int.
2391 (yypstates): Do not assume that ptrdiff_t is the same width
2392 as int, and similarly for yyposn and YYINDEX.
2393
2394 * data/yacc.c: Fix comment about `$$ = $1': it can copy garbage.
2395
2396 * lib/Makefile.am (INCLUDES): Do not include from the intl
2397 directory, which has been removed.
2398 * src/Makefile.am (INCLUDES): Likewise.
2399
2400 * lib/Makefile.am (libbison_a_SOURCES): Add unlocked-io.h.
2401 (bitsets_sources, additional_bitsets_sources, timevars_sources):
2402 New vars.
2403
2404 * lib/Makefile.am (libbison_a_SOURCES): Avoid +=, a GNU make extension.
2405 * tests/Makefile.am (EXTRA_DIST): Likewise.
2406
2407 * lib/abitset.c (abitset_reverse_list, ebitset_reverse_list):
2408 Do not assume that bitset_windex is the same width as unsigned.
2409
2410 * lib/abitset.c (abitset_unused_clear): Do not assume that
2411 bitset_word is the same width as int.
2412 * lib/bbitset.h (BITSET_INDEX_MAX, BITSET_MSB): Likewise.
2413 * lib/bitset.h (bitset_set, bitset_reset): Likewise.
2414 * lib/bitset_stats.c (bitset_stats_set, bitset_stats_reset): Likewise.
2415 * lib/ebitset.c (ebitset_set, ebitset_reset): Likewise.
2416 * lib/lbitset.c (lbitset_set, lbitset_reset): Likewise.
2417
2418 * lib/abitset.c (abitset_op1): Use -1, not ~0, as memset arg (for
2419 portability to one's complement hosts!).
2420 * lib/ebitset.c (ebitset_op1): Likewise.
2421 * lib/lbitset.c (lbitset_op1): Likewise.
2422
2423 * lib/argmatch.c, lib/quotearg.c, quotearg.h: Sync with GNU tar.
2424 * lib/argmatch.h, lib/basename.c, lib/dirname.c, lib/dirname.h,
2425 lib/hash.c, lib/hash.h, lib/strnlen.c, lib/xmalloc.c:
2426 Sync with fileutils.
2427 * lib/error.c, lib/getopt.c, lib/getopt.h, lib/getopt1.c,
2428 lib/gettext.h: Sync with diffutils.
2429
2430 * lib/memrchr.c, lib/mkstemp.c, lib/strchr.c, lib/strnlen.c,
2431 lib/strspn.c, lib/tempname.c: Use GPL, not LGPL.
2432
2433 * lib/obstack.c, lib/obstack.h: Sync with fileutils, except use
2434 PROTOTYPES to check for prototypes, and "defined __STDC__" to
2435 check for void *.
2436
2437 * lib/bbitset.h (BITSET_WORD_BITS): Now of type unsigned, not
2438 size_t; the old version tried to do this but casted improperly.
2439 (bitset_bindex, bitset_windex): Now size_t, not unsigned long.
2440 (bitset_test): Now returns int, not unsigned long.
2441
2442 * lib/bitset_stats.c: Include "gettext.h".
2443 (_): New macro.
2444 (bitset_stats_set, bitset_stats_reset, bitset_stats_test): Don't
2445 name locals "index", as it generates unnecessary warnings on some
2446 hosts that have an "index" function.
2447
2448 * lib/bitset_stats.c (bitset_stats_print_1, bitset_stats_print,
2449 bitset_stats_read, bitset_stats_write): Wrap strings in _() if
2450 they need translation.
2451 * src/LR0.c (state_list_append, new_itemsets, get_state,
2452 append_states, generate_states): Likewise.
2453 * src/assoc.c (assoc_to_string): Likewise.
2454 * src/closure.c (print_closure, set_firsts, closure): Likewise.
2455 * src/gram.c (grammar_dump): Likewise.
2456 * src/injections.c (injections_compute): Likewise.
2457 * src/lalr.c (lookaheads_print): Likewise.
2458 * src/relation.c (relation_transpose): Likewise.
2459 * src/scan-gram.l: Likewise.
2460 * src/tables.c (table_grow, pack_vector): Likewise.
2461
2462 * m4/Makefile.am (EXTRA_DIST): Remove codeset.m4,
2463 glibc21.m4, isc-posix.m4 lcmessage.m4, stage.m4.
2464 * m4/malloc.m4, m4/realloc.m4: Sync with diffutils.
2465 * m4/mbstate_t.m4: Sync with fileutils.
2466 * m4/prereq.m4 (jm_PREREQ_QUOTEARG): AC_MBSTATE_T -> AC_TYPE_MBSTATE_T.
2467
2468 * po/LINGUAS: Add pt_BR.
2469 * po/POTFILES.in: Add src/assoc.c, src/closure.c, src/gram.c,
2470 src/main.c, src/relation.c, src/state.c, lib/bitset_stats.c,
2471 lib/timevar.c.
2472 Use src/parse-gram.y instead of src/parse-gram.c, as the gettext
2473 manual recommends.
2474 Similarly, use src/scan-gram.l instead of src/scan-gram.c.
2475
2476 * src/complain.c (strerror_r): Remove decl; not needed.
2477 (strerror): Use same pattern as ../lib/error.c.
2478
2479 * src/files.c, src/files.h (compute_header_macro): Remove; unused.
2480
2481 * src/gram.c (grammar_dump): Do not assume ptrdiff_t fits in int.
2482
2483 * src/main.c (main): Cast result of bindtextdomain and textdomain
2484 to void, to avoid a GCC warning when --disable-nls is in effect.
2485
2486 * src/scan-gram.l: Use strings rather than escapes when possible,
2487 to minimize the number of warnings from xgettext.
2488 (handle_action_dollar, handle_action_at): Don't use isdigit,
2489 as it mishandles negative chars and it may not work as expected
2490 outside the C locale.
2491
2492 * src/symtab.c (symbol_get): Don't cast LHS of an assignment;
2493 this is a GCC extension and is not portable to other compilers.
2494
2495 * src/system.h (alloca): Use same pattern as ../lib/error.c.
2496 Do not include <ctype.h>; no longer needed.
2497 Do not include <malloc.h>; no longer needed (and generates
2498 warnings on OpenBSD 3.0).
2499
2500 * tests/cxx-type.at (yylex): Do not pass signed char to isupper;
2501 it's not portable.
2502
2503 * tests/regression.at: Do not use 'cc -c input.c -o input';
2504 Sun C rejects this. Instead, use 'cc -c input.c -o input.o'.
2505
2506 * tests/synclines.at (AC_SYNCLINES_COMPILE): Accept any nonzero
2507 exit status as failure, not just exit status 1. Sun C exits
2508 with status 2 sometimes.
2509
2510 * tests/torture.at (AT_INCREASE_DATA_SIZE): New macro.
2511 Use it for the two large tests.
2512
25132002-08-02 Akim Demaille <akim@epita.fr>
2514
2515 * src/conflicts.c (conflicts_output): Don't output rules never
2516 reduced here, since anyway that computation doesn't work.
2517 * src/gram.h, src/gram.h (rule_filter_t, rule_useful_p)
2518 (rule_useless_p, rule_never_reduced_p): New.
2519 (grammar_rules_partial_print): Use a filter instead of a range.
2520 Display the title only if needed.
2521 (grammar_rules_print): Adjust.
2522 (grammar_rules_never_reduced_report): New.
2523 * src/tables.c (action_row): Move the computation of rules never
2524 reduced to...
2525 (token_actions): here.
2526 * src/main.c (main): Make the parser before making the report, so
2527 that rules never reduced are computed.
2528 Call grammar_rules_never_reduced_report.
2529 * src/print.c (print_results): Report rules never reduced.
2530 * tests/conflicts.at, tests/reduce.at: Adjust.
2531
25322002-08-01 Akim Demaille <akim@epita.fr>
2533
2534 Instead of attaching lookaheads and duplicating the rules being
2535 reduced by a state, attach the lookaheads to the reductions.
2536
2537 * src/state.h (state_t): Remove the `lookaheads',
2538 `lookaheads_rule' member.
2539 (reductions_t): Add a `lookaheads' member.
2540 Use a regular array for the `rules'.
2541 * src/state.c (reductions_new): Initialize the lookaheads member
2542 to 0.
2543 (state_rule_lookaheads_print): Adjust.
2544 * src/state.h, src/state.c (state_reductions_find): New.
2545 * src/conflicts.c (resolve_sr_conflict, set_conflicts)
2546 (count_rr_conflicts): Adjust.
2547 * src/lalr.c (LArule): Remove.
2548 (add_lookback_edge): Adjust.
2549 (state_lookaheads_count): New.
2550 (states_lookaheads_initialize): Merge into...
2551 (initialize_LA): this.
2552 (lalr_free): Adjust.
2553 * src/main.c (main): Don't free nullable and derives too early: it
2554 is used by --verbose.
2555 * src/print.c, src/print_graph.c, src/tables.c: Adjust.
2556
25572002-08-01 Akim Demaille <akim@epita.fr>
2558
2559 * src/derives.h, src/derives.c (derives): A `rule_t***' instead of
2560 `rule_number_t**'.
2561 (set_derives, free_derives): Rename as...
2562 (derives_compute, derives_free): this.
2563 Adjust all dependencies.
2564 * src/nullable.c (set_nullable, free_nullable): Rename as...
2565 (nullable_compute, nullable_free): these.
2566 (rule_list_t): Store rule_t *, not rule_number_t.
2567 * src/state.c (state_rule_lookaheads_print): Directly compare rule
2568 pointers, instead of their numbers.
2569 * src/main.c (main): Call nullable_free, and derives_free earlier,
2570 as they were lo longer used.
2571
25722002-08-01 Akim Demaille <akim@epita.fr>
2573
2574 * lib/timevar.c (get_time): Include children time.
2575 * src/lalr.h (LA, LArule): Don't export them: used with the
2576 state_t.
2577 * src/lalr.c (LA, LArule): Static.
2578 * src/lalr.h, src/lalr.c (lalr_free): New.
2579 * src/main.c (main): Call it.
2580 * src/tables.c (pack_vector): Check whether loc is >= to the
2581 table_size, not >.
2582 (pack_tables): Don't free froms, tos, conflict_tos, and pos...
2583 (tables_generate): do it, since that's also it which allocates
2584 them.
2585 Don't free LA and LArule, main does.
2586
25872002-07-31 Akim Demaille <akim@epita.fr>
2588
2589 Separate parser tables computation and output.
2590
2591 * src/output.c (nvectors, base_t, base, base_ninf, conflict_table)
2592 (conflict_list, conflict_list_cnt, table, check, table_ninf)
2593 (yydefgoto, yydefact, high): Move to...
2594 * src/tables.h, src/tables.c: here.
2595 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2596 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2597 (symbol_number_to_vector_number, nvectors, BASE_MAX, BASE_MIN)
2598 (froms, tos, conflict_tos, tally, width, action_t, ACTION_MAX)
2599 (ACTION_MIN, actrow, order, nentries, pos, conflrow)
2600 (conflict_list_free, table_size, lowzero, table_grow, conflict_row)
2601 (action_row, save_row, token_actions, save_column, default_goto)
2602 (goto_actions, sort_actions, matching_state, pack_vector)
2603 (table_ninf_remap, pack_table, prepare_actions): Move to...
2604 * src/tables.c: here.
2605 * src/tables.h, src/tables.c(tables_generate, tables_free): New.
2606 * src/output.c (token_actions, output_base, output_conflicts)
2607 (output_check): Merge into...
2608 (prepare_actions): this.
2609 (actions_output): Rename as...
2610 (user_actions_output): this.
2611 * src/main.c (main): Call tables_generate and tables_free.
2612
26132002-07-31 Akim Demaille <akim@epita.fr>
2614
2615 Steal GCC's --time-report support.
2616
2617 * lib/timevar.c, lib/timevar.h, lib/timevar.def: New,
2618 stolen/adjusted from GCC.
2619 * m4/stage.m4: Remove time related checks.
2620 * m4/timevar.m4: New.
2621 * configure.in: Adjust.
2622 * src/system.h: Adjust to using timevar.h.
2623 * src/getargs.h, src/getargs.c: Support trace_time for
2624 --trace=time.
2625 * src/main.c (stage): Remove.
2626 (main): Replace `stage' invocations with timevar calls.
2627 * src/output.c: Insert pertinent timevar calls.
2628
26292002-07-31 Akim Demaille <akim@epita.fr>
2630
2631 Let --trace have arguments.
2632
2633 * src/getargs.h (enum trace_e): New.
2634 * src/getargs.c (trace_args, trace_types, trace_argmatch): New.
2635 (long_options, short_options): --trace/-T takes an optional
2636 argument.
2637 Change all the uses of trace_flag to reflect the new flags.
2638 * tests/sets.at (Firsts, Nullable, Broken Closure): Use --trace=sets.
2639
2640 Strengthen `stage' portability.
2641
2642 * m4/stage.m4 (BISON_PREREQ_STAGE): New.
2643 * configure.in: Use it.
2644 Don't check for malloc.h and sys/times.h.
2645 * src/system.h: Include them when appropriate.
2646 * src/main.c (stage): Compile only when mallinfo, struct mallinfo,
2647 times and struct tms are available.
2648
26492002-07-30 Akim Demaille <akim@epita.fr>
2650
2651 In verbose parse error message, don't report `error' as an
2652 expected token.
2653 * tests/actions.at (Printers and Destructors): Adjust.
2654 * tests/calc.at (Calculator $1): Adjust.
2655 * data/yacc.c, data/glr.c, data/lalr1.c: When making the verbose
2656 error message, do not report the parser accepts the error token in
2657 that state.
2658
26592002-07-30 Akim Demaille <akim@epita.fr>
2660
2661 Normalize conflict related messages.
2662
2663 * src/complain.h, src/complain.c (warn, complain): New.
2664 * src/conflicts.c (conflicts_print): Use them.
2665 (conflict_report_yacc): New, extracted from...
2666 (conflicts_print): here.
2667 * tests/conflicts.at, tests/existing.at: Adjust.
2668
26692002-07-30 Akim Demaille <akim@epita.fr>
2670
2671 Report rules which are never reduced by the parser: those hidden
2672 by conflicts.
2673
2674 * src/LR0.c (save_reductions): Don't make the final state too
2675 different: save its reduction (accept) instead of having a state
2676 without any action (no shift or goto, no reduce).
2677 Note: the final state is now a ``regular'' state, i.e., the
2678 parsers now contain `reduce 0' as default reduction.
2679 Nevertheless, since they decide to `accept' when yystate =
2680 final_state, they still will not reduce rule 0.
2681 * src/print.c (print_actions, print_reduction): Adjust.
2682 * src/output.c (action_row): Track reduced rules.
2683 (token_actions): Report rules never reduced.
2684 * tests/conflicts.at, tests/regression.at: Adjust.
2685
26862002-07-30 Akim Demaille <akim@epita.fr>
2687
2688 `stage' was accidently included in a previous patch.
2689 Initiate its autoconfiscation.
2690
2691 * configure.in: Look for malloc.h and sys/times.h.
2692 * src/main.c (stage): Adjust.
2693 Report only when trace_flag.
2694
26952002-07-29 Akim Demaille <akim@epita.fr>
2696
2697 * src/state.h, src/state.c (transitions_t): Holds state_t*'s, not
2698 state_number_t.
2699 (errs_t): symbol_t*, not symbol_number_t.
2700 (reductions_t): rule_t*, not rule_number_t.
2701 (FOR_EACH_SHIFT): New.
2702 * src/LR0.c, src/conflicts.c, src/lalr.c, src/output.c
2703 * src/print.c, src/print_graph.c: Adjust.
2704
27052002-07-29 Akim Demaille <akim@epita.fr>
2706
2707 Use $accept and $end, as BYacc and BTYacc do, instead of $axiom and $.
2708
2709 * src/symtab.h, src/symtab.c (eoftoken, axiom): Rename as...
2710 (endtoken, accept): these.
2711 * src/reader.c (reader): Set endtoken's default tag to "$end".
2712 Set undeftoken's tag to "$undefined" instead of "$undefined.".
2713 * doc/bison.texinfo (Table of Symbols): Mention $accept and $end.
2714 Adjust.
2715
27162002-07-29 Akim Demaille <akim@epita.fr>
2717
2718 * src/reduce.c (reduce_grammar): When the language is empty,
2719 complain about the start symbol, not the axiom.
2720 Use its location.
2721 * tests/reduce.at (Empty Language): New.
2722
27232002-07-26 Akim Demaille <akim@epita.fr>
2724
2725 * src/reader.h, src/reader.c (gram_error): ... can't get
2726 yycontrol without making too strong assumptions on the parser
2727 itself.
2728 * src/output.c (prepare_tokens): Use the real 0th value of
2729 token_translations instead of `0'.
2730 * src/parse-gram.y (yyerror): Don't rely on yycontrol being
2731 visible here.
2732 * data/yacc.c (yyreport_parse_error): Rename yylocation as yylloc
2733 for the time being: %locations ought to provide it to yyerror.
2734
27352002-07-25 Akim Demaille <akim@epita.fr>
2736
2737 * src/output.c (prepare_tokens): Go up to ntokens, not ntokens + 1.
2738 * doc/bison.texinfo (Decl Summary): s/$illegal/$undefined./.
2739 * tests/regression.at (Web2c Actions): Adjust.
2740
27412002-07-25 Akim Demaille <akim@epita.fr>
2742
2743 Stop storing rules from 1 to nrules + 1.
2744
2745 * src/LR0.c, src/closure.c, src/derives.c, src/gram.c, src/lalr.c
2746 * src/nullable.c, src/output.c, src/print.c, src/reader.c
2747 * src/reduce.c: Allocate and free from &rules[0], not &rules[1].
2748 Iterate from 0 to nrules.
2749 Use rule_number_as_item_number and item_number_as_rule_number.
2750 Adjust to `derive' now containing possibly 0.
2751 * src/gram.h (rule_number_as_item_number, item_number_as_rule_number):
2752 Handle the `- 1' part in rule numbers from/to item numbers.
2753 * src/conflicts.c (log_resolution): Fix the message which reversed
2754 shift and reduce.
2755 * src/output.c (action_row): Initialize default_rule to -1.
2756 (token_actions): Adjust.
2757 * tests/sets.at (Nullable, Firsts): Fix the previously bogus
2758 expected output.
2759 * tests/conflicts.at (Resolved SR Conflicts): Likewise.
2760
27612002-07-25 Akim Demaille <akim@epita.fr>
2762
2763 * data/c.m4 (b4_c_function, b4_c_ansi_args, b4_c_ansi_arg)
2764 (b4_c_knr_arg_names, b4_c_knr_arg_name, b4_c_knr_arg_decls)
2765 (b4_c_knr_arg_decl): New.
2766 * data/yacc.c: Use it to define yysymprint, yydestruct, and
2767 yyreport_parse_error.
2768
27692002-07-25 Akim Demaille <akim@epita.fr>
2770
2771 * data/yacc.c (yyreport_parse_error): New, extracted from...
2772 (yyparse): here.
2773 (yydestruct, yysymprint): Move above yyparse.
2774 Be K&R compliant.
2775
27762002-07-25 Akim Demaille <akim@epita.fr>
2777
2778 * data/c.m4 (b4_ints_in, b4_int_type, b4_int_type_for): New,
2779 replace...
2780 (b4_sint_type, b4_uint_type): these.
2781 * data/yacc.c, data/glr.c, data/lalr1.cc: Use b4_int_type_for.
2782 * tests/regression.at (Web2c Actions): Adjust.
2783
27842002-07-25 Akim Demaille <akim@epita.fr>
2785
2786 * src/gram.h (TIEM_NUMBER_MAX): New.
2787 (item_number_of_rule_number, rule_number_of_item_number): Rename
2788 as...
2789 (rule_number_as_item_number, item_number_as_rule_number): these.
2790 Adjust dependencies.
2791 * src/output.c (vector_number_t, VECTOR_NUMBER_MAX)
2792 (VECTOR_NUMBER_MIN, state_number_to_vector_number)
2793 (symbol_number_to_vector_number): New.
2794 (order): Of vector_number_t* type.
2795 (base_t, BASE_MAX, BASE_MIN): New.
2796 (froms, tos, width, pos, check): Of base_t type.
2797 (action_number_t, ACTION_MIN, ACTION_MAX): New.
2798 (actrow): Of action_number_t type.
2799 (conflrow): Of unsigned int type.
2800 (table_ninf, base_ninf): New.
2801 (GENERATE_MUSCLE_INSERT_TABLE): Also output the `*_min' value.
2802 (muscle_insert_int_table, muscle_insert_base_table)
2803 (muscle_insert_rule_number_table): New.
2804 (prepare_tokens): Output `toknum' as int_table.
2805 (action_row): Returns a rule_number_t.
2806 Use ACTION_MIN, not SHRT_MIN.
2807 (token_actions): yydefact is rule_number_t*.
2808 (table_ninf_remap): New.
2809 (pack_table): Use it for `base' and `table'.
2810 * data/yacc.c, data/glr.c, data/lalr1.cc (YYFLAG): Remove,
2811 replaced with...
2812 (YYPACT_NINF, YYTABLE_NINF): these.
2813 (yypact, yytable): Compute their types instead of hard-coded
2814 `short'.
2815 * tests/regression.at (Web2c Actions): Adjust.
2816
28172002-07-19 Akim Demaille <akim@epita.fr>
2818
2819 * src/scan-gram.l (id): Can start with an underscore.
2820
28212002-07-16 Akim Demaille <akim@epita.fr>
2822
2823 * src/assoc.c, src/asssoc.h (assoc_t, assoc_to_string): New.
2824 Adjust all former `associativity' dependencies.
2825 * src/symtab.c (symbol_new): Default associativity is `undef', not
2826 `right'.
2827 (symbol_check_alias_consistence): Adjust.
2828
28292002-07-09 Akim Demaille <akim@epita.fr>
2830
2831 * doc/bison.texinfo: Properly set the ``header'' part.
2832 Use @dircategory ``GNU programming tools'' as per Texinfo's
2833 documentation.
2834 Use @copying.
2835
28362002-07-09 Akim Demaille <akim@epita.fr>
2837
2838 * lib/quotearg.h: Protect against multiple inclusions.
2839 * src/location.h (location_t): Add a `file' member.
2840 (LOCATION_RESET, LOCATION_PRINT): Adjust.
2841 * src/complain.c (warn_at, complain_at, fatal_at): Drop
2842 `error_one_per_line' support.
2843
28442002-07-09 Akim Demaille <akim@epita.fr>
2845
2846 * src/complain.h, src/complain.c (warn, complain): Remove, unused.
2847 * src/reader.c (lineno): Remove.
2848 Adjust all dependencies.
2849 (get_merge_function): Take a location and use complain_at.
2850 * src/symtab.h, src/symtab.c (symbol_make_alias): Likewise.
2851 * tests/regression.at (Invalid inputs, Mixing %token styles):
2852 Adjust.
2853
28542002-07-09 Akim Demaille <akim@epita.fr>
2855
2856 * src/parse-gram.y (rules_or_grammar_declaration): Add an error
2857 recovery rule, and forbid extensions when --yacc.
2858 (gram_error): Use complain_at.
2859 * src/reader.c (reader): Exit if there were parse errors.
2860
28612002-07-09 Akim Demaille <akim@epita.fr>
2862
2863 * tests/synclines.at (AT_SYNCLINES_COMPILE): New.
2864 (AT_TEST_SYNCLINE): Adjust to unusual GCC outputs.
2865 Reported by R Blake <blakers@mac.com>.
2866
28672002-07-09 Akim Demaille <akim@epita.fr>
2868
2869 * data/yacc.c: Output the copyright notive in the header.
2870
28712002-07-03 Akim Demaille <akim@epita.fr>
2872
2873 * src/output.c (froms, tos): Are state_number_t.
2874 (save_column): sp, sp1, and sp2 are state_number_t.
2875 (prepare): Rename `final' as `final_state_number', `nnts' as
2876 `nterms_number', `nrules' as `rules_number', `nstates' as
2877 `states_number', and `ntokens' as `tokens_number'. Remove `nsym',
2878 unused.
2879 * data/yacc.c, data/glr.c, data/lalr1.cc: Adjust.
2880 * data/lalr1.cc (nsym_): Remove, unused.
2881
28822002-07-03 Akim Demaille <akim@epita.fr>
2883
2884 * src/lalr.h, src/lalr.c (goto_number_t): New.
2885 * src/lalr.c (goto_list_t): New.
2886 Propagate them.
2887 * src/nullable.c (rule_list_t): New.
2888 Propagate.
2889 * src/types.h: Remove.
2890
28912002-07-03 Akim Demaille <akim@epita.fr>
2892
2893 * src/closure.c (print_fderives): Use rule_rhs_print.
2894 * src/derives.c (print_derives): Use rule_rhs_print.
2895 (rule_list_t): New, replaces `shorts'.
2896 (set_derives): Add comments.
2897 * tests/sets.at (Nullable, Firsts): Adjust.
2898
28992002-07-03 Akim Demaille <akim@epita.fr>
2900
2901 * src/output.c (prepare_actions): Free `tally' and `width'.
2902 (prepare_actions): Allocate and free `order'.
2903 * src/symtab.c (symbols_free): Free `symbols'.
2904 * src/scan-gram.l (scanner_free): Clear Flex's scanners memory.
2905 * src/output.c (m4_invoke): Move to...
2906 * src/scan-skel.l: here.
2907 (<<EOF>>): Close yyout, and free its name.
2908
29092002-07-03 Akim Demaille <akim@epita.fr>
2910
2911 Fix some memory leaks, and fix a bug: state 0 was examined twice.
2912
2913 * src/LR0.c (new_state): Merge into...
2914 (state_list_append): this.
2915 (new_states): Merge into...
2916 (generate_states): here.
2917 (set_states): Don't ensure a proper `errs' state member here, do it...
2918 * src/conflicts.c (conflicts_solve): here.
2919 * src/state.h, src/state.c: Comment changes.
2920 (state_t): Rename member `shifts' as `transitions'.
2921 Adjust all dependencies.
2922 (errs_new): For consistency, also take the values as argument.
2923 (errs_dup): Remove.
2924 (state_errs_set): New.
2925 (state_reductions_set, state_transitions_set): Assert that no
2926 previous value was assigned.
2927 (state_free): New.
2928 (states_free): Use it.
2929 * src/conflicts.c (resolve_sr_conflict): Don't use an `errs_t' as
2930 temporary storage: use `errs' and `nerrs' as elsewhere.
2931 (set_conflicts): Allocate and free this `errs'.
2932
29332002-07-02 Akim Demaille <akim@epita.fr>
2934
2935 * lib/libiberty.h: New.
2936 * lib: Update the bitset implementation from upstream.
2937 * src/closure.c, src/lalr.c, src/output.c, src/print_graph.c,
2938 * src/state.c: Use BITSET_FOR_EACH, not BITSET_EXECUTE.
2939 * src/main.c: Adjust bitset stats calls.
2940
29412002-07-01 Paul Eggert <eggert@twinsun.com>
2942
2943 * src/scan-gram.l (<SC_ESCAPED_CHARACTER>): Convert to unsigned
2944 char, so that negative chars don't collide with $.
2945
29462002-06-30 Akim Demaille <akim@epita.fr>
2947
2948 Have the GLR tests be `warning' checked, and fix the warnings.
2949
2950 * data/glr.c (YYFPRINTF): Always define it, not only when YYDEBUG
2951 (yyuserAction, yyreportAmbiguity): `Use' all the arguments.
2952 (yyremoveDeletes): `yyi' and `yyj' are size_t.
2953 Use YYFPRINTF when under if (YYDEBUG) to avoid empty `if' bodies.
2954 (yyaddDeferredAction): static.
2955 (yyglrReduce): yyi, yyk, amd yyposn are size_t.
2956 (yyreportParseError): yyprefix is const.
2957 yytokenp is used only when verbose.
2958 (yy__GNUC__): Replace with __GNUC__.
2959 (yypdumpstack): yyi is size_t.
2960 (yypreference): Un-yy local variables and arguments, to avoid
2961 clashes with `yyr1'. Anyway, we are not in the user name space.
2962 (yytname_size): be an int, as is compared with ints.
2963 * tests/testsuite.at (AT_COMPILE, AT_PARSER_CHECK): New.
2964 Use them.
2965 * tests/cxx-gram.at: Use quotation to protect $1.
2966 Use AT_COMPILE to enable warnings hunts.
2967 Prototype yylex and yyerror.
2968 `Use' argc.
2969 Include `string.h', not `strings.h'.
2970 Produce and prototype stmtMerge only when used.
2971 yylex takes a location.
2972
29732002-06-30 Akim Demaille <akim@epita.fr>
2974
2975 We spend a lot of time in quotearg, in particular when --verbose.
2976
2977 * src/symtab.c (symbol_get): Store a quoted version of the key.
2978 (symbol_tag_get, symbol_tag_get_n, symbol_tag_print): Remove.
2979 Adjust all callers.
2980
29812002-06-30 Akim Demaille <akim@epita.fr>
2982
2983 * src/state.h (reductions_t): Rename member `nreds' as num.
2984 (errs_t): Rename members `nerrs' and `errs' as `num' and `symbols'.
2985 * src/state.c (ERRS_ALLOC, REDUCTIONS_ALLOC): Use the correct types.
2986
29872002-06-30 Akim Demaille <akim@epita.fr>
2988
2989 * src/state.h, src/state.c (shift_t, SHIFT_SYMBOL, SHIFT_IS_SHIFT)
2990 (SHIFT_IS_GOTO, SHIFT_IS_ERROR, SHIFT_DISABLE, SHIFT_IS_DISABLED)
2991 (shifts_to): Rename as...
2992 (transition_t, TRANSITION_SYMBOL, TRANSITION_IS_TRANSITION)
2993 (TRANSITION_IS_GOTO, TRANSITION_IS_ERROR, TRANSITION_DISABLE)
2994 (TRANSITION_IS_DISABLED, transitions_to): these.
2995
29962002-06-30 Akim Demaille <akim@epita.fr>
2997
2998 * src/print.c (print_shifts, print_gotos): Merge into...
2999 (print_transitions): this.
3000 (print_transitions, print_errs, print_reductions): Align the
3001 lookaheads columns.
3002 (print_core, print_transitions, print_errs, print_state,
3003 print_grammar): Output empty lines separator before, not after.
3004 (state_default_rule_compute): Rename as...
3005 (state_default_rule): this.
3006 * tests/conflicts.at (Defaulted Conflicted Reduction),
3007 (Unresolved SR Conflicts, Resolved SR Conflicts): Adjust.
3008 * tests/regression.at (Rule Line Numbers, Web2c Report): Adjust.
3009
30102002-06-30 Akim Demaille <akim@epita.fr>
3011
3012 Display items as we display rules.
3013
3014 * src/gram.h, src/gram.c (rule_lhs_print): New.
3015 * src/gram.c (grammar_rules_partial_print): Use it.
3016 * src/print.c (print_core): Likewise.
3017 * tests/conflicts.at (Defaulted Conflicted Reduction),
3018 (Unresolved SR Conflicts): Adjust.
3019 (Unresolved SR Conflicts): Adjust and rename as...
3020 (Resolved SR Conflicts): this, as was meant.
3021 * tests/regression.at (Web2c Report): Adjust.
3022
30232002-06-30 Akim Demaille <akim@epita.fr>
3024
3025 * src/print.c (state_default_rule_compute): New, extracted from...
3026 (print_reductions): here.
3027 Pessimize, but clarify the code.
3028 * tests/conflicts.at (Defaulted Conflicted Reduction): New.
3029
30302002-06-30 Akim Demaille <akim@epita.fr>
3031
3032 * src/output.c (action_row): Let default_rule be always a rule
3033 number.
3034
30352002-06-30 Akim Demaille <akim@epita.fr>
3036
3037 * src/closure.c (print_firsts, print_fderives, closure):
3038 Use BITSET_EXECUTE.
3039 * src/lalr.c (lookaheads_print): Likewise.
3040 * src/state.c (state_rule_lookaheads_print): Likewise.
3041 * src/print_graph.c (print_core): Likewise.
3042 * src/print.c (print_reductions): Likewise.
3043 * src/output.c (action_row): Likewise.
3044 Use SHIFT_IS_DISABLED, SHIFT_IS_SHIFT and SHIFT_SYMBOL.
3045
30462002-06-30 Akim Demaille <akim@epita.fr>
3047
3048 * src/print_graph.c: Use report_flag.
3049
30502002-06-30 Akim Demaille <akim@epita.fr>
3051
3052 * src/lalr.c (traverse, digraph, matrix_print, transpose): Move
3053 to...
3054 * src/relation.h, src/relation.c (traverse, relation_digraph)
3055 (relation_print, relation_transpose): New.
3056
30572002-06-30 Akim Demaille <akim@epita.fr>
3058
3059 * src/state.h, src/state.c (shifts_to): New.
3060 * src/lalr.c (build_relations): Use it.
3061
30622002-06-30 Akim Demaille <akim@epita.fr>
3063
3064 * src/gram.h (rule_number_t, RULE_NUMBER_MAX, int_of_rule_number)
3065 (item_number_of_rule_number, rule_number_of_item_number): New.
3066 * src/LR0.c, src/closure.c, src/derives.c, src/derives.h,
3067 * src/gram.c, src/lalr.c, src/nullable.c, src/output.c, src/print.c,
3068 * src/print_graph.c, src/reader.c, src/reduce.c, src/reduce.h:
3069 Propagate their use.
3070 Much remains to be done, in particular wrt `shorts' from types.h.
3071
30722002-06-30 Akim Demaille <akim@epita.fr>
3073
3074 * src/symtab.c (symbol_new): Initialize the `printer' member.
3075
30762002-06-30 Akim Demaille <akim@epita.fr>
3077
3078 * src/LR0.c (save_reductions): Remove, replaced by...
3079 * src/state.h, src/state.c (state_reductions_set): New.
3080 (reductions, errs): Rename as...
3081 (reductions_t, errs_t): these.
3082 Adjust all dependencies.
3083
30842002-06-30 Akim Demaille <akim@epita.fr>
3085
3086 * src/LR0.c (state_list_t, state_list_append): New.
3087 (first_state, last_state): Now symbol_list_t.
3088 (this_state): Remove.
3089 (new_itemsets, append_states, save_reductions): Take a state_t as
3090 argument.
3091 (set_states, generate_states): Adjust.
3092 (save_shifts): Remove, replaced by...
3093 * src/state.h, src/state.c (state_shifts_set): New.
3094 (shifts): Rename as...
3095 (shifts_t): this.
3096 Adjust all dependencies.
3097 * src/state.h (state_t): Remove the `next' member.
3098
30992002-06-30 Akim Demaille <akim@epita.fr>
3100
3101 * src/vcg.c (quote): Use slot 2, since we often pass symbol tag
3102 escaped in slot 0.
3103
31042002-06-30 Akim Demaille <akim@epita.fr>
3105
3106 Use hash.h for the state hash table.
3107
3108 * src/LR0.c (STATE_HASH_SIZE, state_hash): Remove.
3109 (allocate_storage): Use state_hash_new.
3110 (free_storage): Use state_hash_free.
3111 (new_state, get_state): Adjust.
3112 * src/lalr.h, src/lalr.c (states): Move to...
3113 * src/states.h (state_t): Remove the `link' member, no longer
3114 used.
3115 * src/states.h, src/states.c: here.
3116 (state_hash_new, state_hash_free, state_hash_lookup)
3117 (state_hash_insert, states_free): New.
3118 * src/states.c (state_table, state_compare, state_hash): New.
3119 * src/output.c (output_actions): Do not free states now, since we
3120 still need to know the final_state number in `prepare', called
3121 afterwards. Do it...
3122 * src/main.c (main): here: call states_free after `output'.
3123
31242002-06-30 Akim Demaille <akim@epita.fr>
3125
3126 * src/state.h, src/state.c (state_new): New, extracted from...
3127 * src/LR0.c (new_state): here.
3128 * src/state.h (STATE_ALLOC): Move to...
3129 * src/state.c: here.
3130 * src/LR0.h, src/LR0.c (nstates, final_state): Move to...
3131 * src/state.h, src/state.c: here.
3132
31332002-06-30 Akim Demaille <akim@epita.fr>
3134
3135 * src/reader.c (gensym): Rename as...
3136 * src/symtab.h, src/symtab.c (dummy_symbol_get): this.
3137 (getsym): Rename as...
3138 (symbol_get): this.
3139
31402002-06-30 Akim Demaille <akim@epita.fr>
3141
3142 * src/state.h (state_number_t, STATE_NUMBER_MAX): New.
3143 * src/LR0.c, src/LR0.h, src/conflicts.c, src/lalr.c, src/lalr.h,
3144 * src/output.c, src/print.c, src/print_graph.c: Propagate.
3145 * src/LR0.h, src/LR0.h (final_state): Is a state_t*.
3146
31472002-06-30 Akim Demaille <akim@epita.fr>
3148
3149 Make the test suite pass with warnings checked.
3150
3151 * tests/actions.at (Printers and Destructors): Improve.
3152 Avoid unsigned vs. signed issues.
3153 * tests/calc.at: Don't exercise the scanner here, do it...
3154 * tests/input.at (Torturing the Scanner): here.
3155
31562002-06-28 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3157
3158 * data/glr.c: Correct typo in Emacs-mode directive. Slightly
3159 reorganize first lines parallel to yacc.c.
3160
31612002-06-28 Akim Demaille <akim@epita.fr>
3162
3163 * data/c.m4 (b4_copyright, b4_sint_type, b4_uint_type, b4_token_define)
3164 (b4_token_enum, b4_token_defines): New, factored from...
3165 * data/lalr1.cc, data/yacc.c, glr.c: here.
3166
31672002-06-28 Akim Demaille <akim@epita.fr>
3168
3169 * data/yacc.c (yydestruct, yysymprint): Pacify GCC warnings for
3170 unused variables.
3171 * src/output.c (merger_output): static.
3172
31732002-06-28 Akim Demaille <akim@epita.fr>
3174
3175 * src/reader.h: s/grammer_current_rule_merge_set/grammar_.../.
3176 * src/conflicts.c (conflicts_total_count): `i' is unsigned, to
3177 pacify GCC.
3178 * src/output.c (save_row): Initialize all the variables to pacify GCC.
3179
31802002-06-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3181
3182 Accumulated changelog for new GLR parsing features.
3183
3184 * src/conflicts.c (count_total_conflicts): Change name to
3185 conflicts_total_count.
3186 * src/conflicts.h: Ditto.
3187 * src/output.c (token_actions): Use the new name.
3188 (output_conflicts): Change conflp => conflict_list_heads, and
3189 confl => conflict_list for better readability.
3190 * data/glr.c: Use the new names.
3191 * NEWS: Add self to GLR announcement.
3192
3193 * src/reader.c (free_merger_functions): Cleanup: XFREE->free.
3194
3195 * doc/bison.texinfo (GLR Parsers): Make corrections suggested by
3196 Akim Demaille.
3197
3198 * data/bison.glr: Change name to glr.c
3199 * data/glr.c: Renamed from bison.glr.
3200 * data/Makefile.am: Add glr.c
3201
3202 * src/getargs.c:
3203
3204 * src/symlist.h: Add dprec and merger fields to symbol_list_s.
3205 * src/symlist.c (symbol_list_new): Initialize dprec and merger fields.
3206
3207 Originally 2002-06-16 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3208
3209 * data/bison.glr: Be sure to restore the
3210 current #line when returning to the skeleton contents after having
3211 exposed the input file's #line.
3212
3213 Originally 2002-06-13 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3214
3215 * data/bison.glr: Bring up to date with changes to bison.simple.
3216
3217 Originally 2002-06-03 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3218
3219 * data/bison.glr: Correct definitions that use b4_prefix.
3220 Various reformatting.
3221 (GLRStack): Make yychar (in YYPURE case) and yytokenp as part of stack.
3222 (yyreportParseError, yyrecoverParseError, yyprocessOneStack): remove
3223 yytokenp argument; now part of stack.
3224 (yychar): Define to behave as documented.
3225 (yyclearin): Ditto.
3226
3227 Originally 2002-05-14 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3228
3229 * src/reader.h: Add declaration for free_merger_functions.
3230
3231 * src/reader.c (merge_functions): New variable.
3232 (get_merge_function): New function.
3233 (free_merger_functions): New function.
3234 (readgram): Check for %prec that is not followed by a symbol.
3235 Handle %dprec and %merge declarations.
3236 (packgram): Initialize dprec and merger fields in rules array.
3237
3238 * src/output.c (conflict_tos, conflrow, conflict_table, conflict_list,
3239 conflict_list_cnt, conflict_list_free): New variables.
3240 (table_grow): Also grow conflict_table.
3241 (prepare_rules): Output dprec and merger tables.
3242 (conflict_row): New function.
3243 (action_row): Output conflict lists for GLR parser. Don't use
3244 default reduction in conflicted states for GLR parser so that there
3245 are spaces for the conflict lists.
3246 (save_row): Also save conflict information.
3247 (token_actions): Allocate conflict list.
3248 (merger_output): New function.
3249 (pack_vector): Pack conflict table, too.
3250 (output_conflicts): New function to output yyconflp and yyconfl.
3251 (output_check): Allocate conflict_tos.
3252 (output_actions): Output conflict tables, also.
3253 (output_skeleton): Output b4_mergers definition.
3254 (prepare): Output b4_max_rhs_length definition.
3255 Use 'bison.glr' as default skeleton for GLR parsers.
3256
3257 * src/gram.c (glr_parser): New flag.
3258 (grammar_free): Call free_merger_functions.
3259
3260 * src/conflicts.c (count_rr_conflicts): Augment to optionally count
3261 all pairs of conflicting reductions, rather than just all tokens
3262 causing conflicts. Needed to size conflict tables.
3263 (conflicts_output): Modify call to count_rr_conflicts for new
3264 interface.
3265 (conflicts_print): Ditto.
3266 (count_total_conflicts): New function.
3267
3268 * src/reader.h (merger_list): New type.
3269 (merge_functions): New variable.
3270
3271 * src/lex.h (tok_dprec, tok_merge): New token types.
3272
3273 * src/gram.h (rule_s): Add dprec and merger fields.
3274 (glr_parser): New flag.
3275
3276 * src/conflicts.h (count_total_conflicts): New function.
3277
3278 * src/options.c (option_table): Add %dprec, %merge, and %glr-parser.
3279
3280 * doc/bison.texinfo (Generalized LR Parsing): New section.
3281 (GLR Parsers): New section.
3282 (Language and Grammar): Mention GLR parsing.
3283 (Table of Symbols): Add %dprec, %glr-parser, %merge, GLR
3284 Correct typo ("tge" -> "the").
3285
3286 * data/bison.glr: New skeleton for GLR parsing.
3287
3288 * tests/cxx-gram.at: New tests for GLR parsing.
3289
3290 * tests/testsuite.at: Include cxx-gram.at.
3291
3292 * tests/Makefile.am: Add cxx-gram.at.
3293
3294 * src/parse-gram.y:
3295
3296 * src/scan-gram.l: Add %dprec, %glr-parser, %merge.
3297
3298 * src/parse-gram.y: Grammar for %dprec, %merge, %glr-parser.
3299
33002002-06-27 Akim Demaille <akim@epita.fr>
3301
3302 * src/options.h, src/options.c: Remove.
3303 * src/getargs.c (short_options, long_options): New.
3304
33052002-06-27 Akim Demaille <akim@epita.fr>
3306
3307 * data/bison.simple, data/bison.c++: Rename as...
3308 * data/yacc.c, data/lalr1.cc: these.
3309 * doc/bison.texinfo (Environment Variables): Remove.
3310
33112002-06-25 Raja R Harinath <harinath@cs.umn.edu>
3312
3313 * src/getargs.c (report_argmatch): Initialize strtok().
3314
33152002-06-20 Akim Demaille <akim@epita.fr>
3316
3317 * data/bison.simple (b4_symbol_actions): New, replaces...
3318 (b4_symbol_destructor, b4_symbol_printer): these.
3319 (yysymprint): Be sure to call YYPRINT only for tokens, and using
3320 user token numbers.
3321
33222002-06-20 Akim Demaille <akim@epita.fr>
3323
3324 * data/bison.simple (yydestructor): Rename as...
3325 (yydestruct): this.
3326
33272002-06-20 Akim Demaille <akim@epita.fr>
3328
3329 * src/symtab.h, src/symtab.c (symbol_type_set)
3330 (symbol_destructor_set, symbol_precedence_set): The location is
3331 the last argument.
3332 Adjust all callers.
3333
33342002-06-20 Akim Demaille <akim@epita.fr>
3335
3336 * src/parse-gram.y (YYPRINT, yyprint): Don't mess with the parser
3337 internals.
3338 * src/reader.h, src/reader.c (grammar_current_rule_prec_set):
3339 Takes a location.
3340 * src/symtab.h, src/symtab.c (symbol_class_set)
3341 (symbol_user_token_number_set): Likewise.
3342 Adjust all callers.
3343 Promote complain_at.
3344 * tests/input.at (Type Clashes): Adjust.
3345
33462002-06-20 Akim Demaille <akim@epita.fr>
3347
3348 * data/bison.simple (YYLEX): Fix the declaration when
3349 %pure-parser.
3350
33512002-06-20 Akim Demaille <akim@epita.fr>
3352
3353 * data/bison.simple (yysymprint): Don't print the token number,
3354 just its name.
3355 * tests/actions.at (Destructors): Rename as...
3356 (Printers and Destructors): this.
3357 Also exercise %printer.
3358
33592002-06-20 Akim Demaille <akim@epita.fr>
3360
3361 * data/bison.simple (YYDSYMPRINT): New.
3362 Use it to remove many of the #if YYDEBUG/if (yydebug).
3363
33642002-06-20 Akim Demaille <akim@epita.fr>
3365
3366 * src/symtab.h, src/symtab.c (symbol_t): printer and
3367 printer_location are new members.
3368 (symbol_printer_set): New.
3369 * src/parse-gram.y (PERCENT_PRINTER): New token.
3370 Handle its associated rule.
3371 * src/scan-gram.l: Adjust.
3372 (handle_destructor_at, handle_destructor_dollar): Rename as...
3373 (handle_symbol_code_at, handle_symbol_code_dollar): these.
3374 * src/output.c (symbol_printers_output): New.
3375 (output_skeleton): Call it.
3376 * data/bison.simple (yysymprint): New. Cannot be named yyprint
3377 since there are already many grammar files with a user `yyprint'.
3378 Replace the calls to YYPRINT to calls to yysymprint.
3379 * tests/calc.at: Adjust.
3380 * tests/torture.at (AT_DATA_STACK_TORTURE): Remove YYPRINT: it was
3381 taking advantage of parser very internal details (stack size!).
3382
33832002-06-20 Akim Demaille <akim@epita.fr>
3384
3385 * src/scan-gram.l: Complete the scanner with the missing patterns
3386 to pacify Flex.
3387 Use `quote' and `symbol_tag_get' where appropriate.
3388
33892002-06-19 Akim Demaille <akim@epita.fr>
3390
3391 * tests/actions.at (Destructors): Augment to test locations.
3392 * data/bison.simple (yydestructor): Pass it the current location
3393 if locations are enabled.
3394 Prototype only when __STDC__ or C++.
3395 Change the argument names to move into the yy name space: there is
3396 user code here.
3397
33982002-06-19 Akim Demaille <akim@epita.fr>
3399
3400 * data/bison.simple (b4_pure_if): New.
3401 Use it instead of #ifdef YYPURE.
3402
34032002-06-19 Akim Demaille <akim@epita.fr>
3404
3405 * data/bison.simple (b4_location_if): New.
3406 Use it instead of #ifdef YYLSP_NEEDED.
3407
34082002-06-19 Akim Demaille <akim@epita.fr>
3409
3410 Prepare @$ in %destructor, but currently don't bind it in the
3411 skeleton, as %location use is not cleaned up yet.
3412
3413 * src/scan-gram.l (handle_dollar, handle_destructor_at)
3414 (handle_action_at): New.
3415 (handle_at, handle_action_dollar, handle_destructor_dollar): Take
3416 a braced_code_t and a location as additional arguments.
3417 (handle_destructor_dollar): Instead of requiring `b4_eval', just
3418 unquote one when outputting `b4_dollar_dollar'.
3419 Adjust callers.
3420 * data/bison.simple (b4_eval): Remove.
3421 (b4_symbol_destructor): Adjust.
3422 * tests/input.at (Invalid @n): Adjust.
3423
34242002-06-19 Zack Weinberg <zack@codesourcery.com>
3425
3426 * doc/bison.texinfo: Document ability to have multiple
3427 prologue sections.
3428
34292002-06-18 Akim Demaille <akim@epita.fr>
3430
3431 * src/files.c (compute_base_names): When computing the output file
3432 names from the input file name, strip the directory part.
3433
34342002-06-18 Akim Demaille <akim@epita.fr>
3435
3436 * data/bison.simple.new: Comment changes.
3437 Reported by Andreas Schwab.
3438
34392002-06-18 Matt Kraai <kraai@alumni.cmu.edu>
3440
3441 * data/bison.simple (yyoverflowlab): #ifndef yyoverflow, so that
3442 there are no `label `yyoverflowlab' defined but not used' warnings
3443 when yyoverflow is defined.
3444
34452002-06-18 Akim Demaille <akim@epita.fr>
3446
3447 * src/symtab.h, src/symtab.c (symbol_t): destructor_location is a
3448 new member.
3449 (symbol_destructor_set): Adjust.
3450 * src/output.c (symbol_destructors_output): Output the destructor
3451 locations.
3452 Output the symbol name.
3453 * data/bison.simple (b4_symbol_destructor): Adjust.
3454
34552002-06-18 Cris Bailiff <c.bailiff@awayweb.com>
3456 and Akim Demaille <akim@epita.fr>
3457
3458 * data/bison.simple.new (yyerrlab1): Be sure to pop and destroy
3459 what's left on the stack when the error recovery hits EOF.
3460 * tests/actions.at (Destructors): Complete to exercise this case.
3461
34622002-06-17 Akim Demaille <akim@epita.fr>
3463
3464 * data/m4sugar/m4sugar.m4 (m4_map): Recognize when the list of
3465 arguments is really empty, not only equal to `[]'.
3466 * src/symtab.h, src/symtab.c (symbol_t): `destructor' is a new
3467 member.
3468 (symbol_destructor_set): New.
3469 * src/output.c (symbol_destructors_output): New.
3470 * src/reader.h (brace_code_t, current_braced_code): New.
3471 * src/scan-gram.l (BRACED_CODE): Use it to branch on...
3472 (handle_dollar): Rename as...
3473 (handle_action_dollar): this.
3474 (handle_destructor_dollar): New.
3475 * src/parse-gram.y (PERCENT_DESTRUCTOR): New.
3476 (grammar_declaration): Use it.
3477 * data/bison.simple (yystos): Is always defined.
3478 (yydestructor): New.
3479 * tests/actions.at (Destructors): New.
3480 * tests/calc.at (_AT_CHECK_CALC_ERROR): Don't rely on egrep.
3481
34822002-06-17 Akim Demaille <akim@epita.fr>
3483
3484 * src/symlist.h, src/symlist.c (symbol_list_length): New.
3485 * src/scan-gram.l (handle_dollar, handle_at): Compute the
3486 rule_length only when needed.
3487 * src/output.c (actions_output, token_definitions_output): Output
3488 the full M4 block.
3489 * src/symtab.c: Don't access directly to the symbol tag, use
3490 symbol_tag_get.
3491 * src/parse-gram.y: Use symbol_list_free.
3492
34932002-06-17 Akim Demaille <akim@epita.fr>
3494
3495 * src/reader.h, src/reader.c (symbol_list, symbol_list_new)
3496 (symbol_list_prepend, get_type_name): Move to...
3497 * src/symlist.h, src/symlist.c (symbol_list_t, symbol_list_new)
3498 (symbol_list_prepend, symbol_list_n_type_name_get): here.
3499 Adjust all callers.
3500 (symbol_list_free): New.
3501 * src/scan-gram.l (handle_dollar): Takes a location.
3502 * tests/input.at (Invalid $n): Adjust.
3503
35042002-06-17 Akim Demaille <akim@epita.fr>
3505
3506 * src/reader.h, src/reader.c (symbol_list_new): Export it.
3507 (symbol_list_prepend): New.
3508 * src/parse-gram.y (%union): `list' is a new member.
3509 (symbols.1): New, replaces...
3510 (terms_to_prec.1, nterms_to_type.1): these.
3511 * src/symtab.h, src/symtab.c (symbol_type_set, symbol_precedence_set)
3512 Take a location as additional argument.
3513 Adjust all callers.
3514
35152002-06-15 Akim Demaille <akim@epita.fr>
3516
3517 * src/parse-gram.y: Move %token in the declaration section so that
3518 we don't depend upon CVS Bison.
3519
35202002-06-15 Akim Demaille <akim@epita.fr>
3521
3522 * src/state.h, src/state.c (state_rule_lookaheads_print): New.
3523 * src/print.c (print_core): Use it.
3524
35252002-06-15 Akim Demaille <akim@epita.fr>
3526
3527 * src/conflicts.c (log_resolution): Accept the rule involved in
3528 the sr conflicts instead of the lookahead number that points to
3529 that rule.
3530 (flush_reduce): Accept the current lookahead vector as argument,
3531 instead of the index in LA.
3532 (resolve_sr_conflict): Accept the current number of lookahead
3533 bitset to consider for the STATE, instead of the index in LA.
3534 (set_conflicts): Adjust.
3535 * src/lalr.c, src/lalr.h, src/state.h: Comment changes.
3536
35372002-06-15 Akim Demaille <akim@epita.fr>
3538
3539 * src/state.h (state_t): Replace the `lookaheadsp' member, a
3540 short, with `lookaheads' (bitsetv), `lookaheads_rule' (rule_t**).
3541 Adjust all dependencies.
3542 * src/lalr.c (initialize_lookaheads): Split into...
3543 (states_lookaheads_count, states_lookaheads_initialize): these.
3544 (lalr): Adjust.
3545
35462002-06-15 Akim Demaille <akim@epita.fr>
3547
3548 * src/gram.h, src/gram.c (grammar_rules_partial_print): New, eved
3549 out of...
3550 (grammar_rules_print): here.
3551 * src/reduce.c (reduce_output): Use it.
3552 * tests/reduce.at (Useless Rules, Reduced Automaton)
3553 (Underivable Rules): Adjust.
3554
35552002-06-15 Akim Demaille <akim@epita.fr>
3556
3557 Copy BYacc's nice way to report the grammar.
3558
3559 * src/gram.h, src/gram.c (grammar_rhs_print, grammar_rules_print):
3560 New.
3561 Don't print the rules' location, it is confusing and useless.
3562 (rule_print): Use grammar_rhs_print.
3563 * src/print.c (print_grammar): Use grammar_rules_print.
3564
35652002-06-15 Akim Demaille <akim@epita.fr>
3566
3567 Complete and rationalize `useless thing' warnings.
3568
3569 * src/symtab.h, src/symtab.c (symbol_tag_get, symbol_tag_get_n)
3570 (symbol_tag_print): New.
3571 Use them everywhere in place of accessing directly the tag member.
3572 * src/gram.h, src/gram.c (rule_print): New.
3573 Use it where a rule used to be printed `by hand'.
3574 * src/reduce.c (nonterminals_reduce): Report the use nonterminals.
3575 (reduce_grammar_tables): Report the useless rules.
3576 (reduce_print): Useless things are a warning, not an error.
3577 Report it as such.
3578 * tests/reduce.at (Useless Nonterminals, Useless Rules):
3579 (Reduced Automaton, Underivable Rules): Adjust.
3580 * tests/regression.at (Web2c Report, Web2c Report): Adjust.
3581 * tests/conflicts.at (Unresolved SR Conflicts)
3582 (Solved SR Conflicts): Adjust.
3583
35842002-06-15 Akim Demaille <akim@epita.fr>
3585
3586 Let symbols have a location.
3587
3588 * src/symtab.h, src/symtab.c (symbol_t): Location is a new member.
3589 (getsym): Adjust.
3590 Adjust all callers.
3591 * src/complain.h, src/complain.c (complain_at, fatal_at, warn_at):
3592 Use location_t, not int.
3593 * src/symtab.c (symbol_check_defined): Take advantage of the
3594 location.
3595 * tests/regression.at (Invalid inputs): Adjust.
3596
35972002-06-15 Akim Demaille <akim@epita.fr>
3598
3599 * src/parse-gram.y (YYLLOC_DEFAULT, current_lhs_location): New.
3600 (input): Don't try to initialize yylloc here, do it in the
3601 scanner.
3602 * src/scan-gram.l (YY_USER_INIT): Initialize yylloc.
3603 * src/gram.h (rule_t): Change line and action_line into location
3604 and action_location, of location_t type.
3605 Adjust all dependencies.
3606 * src/location.h, src/location.c (empty_location): New.
3607 * src/reader.h, src/reader.c (grammar_start_symbol_set)
3608 (grammar_symbol_append, grammar_rule_begin, grammar_rule_end)
3609 (grammar_current_rule_symbol_append)
3610 (grammar_current_rule_action_append): Expect a location as argument.
3611 * src/reader.c (grammar_midrule_action): Adjust to attach an
3612 action's location as dummy symbol location.
3613 * src/symtab.h, src/symtab.c (startsymbol_location): New.
3614 * tests/regression.at (Web2c Report, Rule Line Numbers): Adjust
3615 the line numbers.
3616
36172002-06-14 Akim Demaille <akim@epita.fr>
3618
3619 Grammar declarations may be found in the grammar section.
3620
3621 * src/parse-gram.y (rules_or_grammar_declaration): New.
3622 (declarations): Each declaration may end with a semicolon, not
3623 just...
3624 (grammar_declaration): `"%union"'.
3625 (grammar): Branch to rules_or_grammar_declaration.
3626
36272002-06-14 Akim Demaille <akim@epita.fr>
3628
3629 * src/main.c (main): Invoke scanner_free.
3630
36312002-06-14 Akim Demaille <akim@epita.fr>
3632
3633 * src/output.c (m4_invoke): Extracted from...
3634 (output_skeleton): here.
3635 Free tempfile.
3636
36372002-06-14 Akim Demaille <akim@epita.fr>
3638
3639 * src/parse-gram.y (directives, directive, gram)
3640 (grammar_directives, precedence_directives, precedence_directive):
3641 Rename as...
3642 (declarations, declaration, grammar, grammar_declaration)
3643 (precedence_declaration, precedence_declarator): these.
3644 (symbol_declaration): New.
3645
36462002-06-14 Akim Demaille <akim@epita.fr>
3647
3648 * src/files.c (action_obstack): Remove, unused.
3649 (output_obstack): Remove it, and all its dependencies, as it is no
3650 longer needed.
3651 * src/reader.c (epilogue_set): Build the epilogue in the
3652 muscle_obstack.
3653 * src/output.h, src/output.c (muscle_obstack): Move to...
3654 * src/muscle_tab.h, src/muscle_tab.h: here.
3655 (muscle_init): Initialize muscle_obstack.
3656 (muscle_free): New.
3657 * src/main.c (main): Call it.
3658
36592002-06-14 Akim Demaille <akim@epita.fr>
3660
3661 * src/location.h: New, extracted from...
3662 * src/reader.h: here.
3663 * src/Makefile.am (noinst_HEADERS): Merge into
3664 (bison_SOURCES): this.
3665 Add location.h.
3666 * src/parse-gram.y: Use location_t instead of Bison's.
3667 * src/reader.h, src/reader.c (prologue_augment, epilogue_set):
3668 Use location_t instead of ints.
3669
36702002-06-14 Akim Demaille <akim@epita.fr>
3671
3672 * data/bison.simple, data/bison.c++: Be sure to restore the
3673 current #line when returning to the skeleton contents after having
3674 exposed the input file's #line.
3675
36762002-06-12 Akim Demaille <akim@epita.fr>
3677
3678 * src/scan-gram.l (SC_BRACED_CODE): Don't use `<.*>', it is too
3679 eager.
3680 * tests/actions.at (Exotic Dollars): New.
3681
36822002-06-12 Akim Demaille <akim@epita.fr>
3683
3684 * src/scan-gram.l (SC_PROLOGUE): Don't eat characters amongst
3685 ['"/] too eagerly.
3686 * tests/input.at (Torturing the Scanner): New.
3687
36882002-06-11 Akim Demaille <akim@epita.fr>
3689
3690 * src/scan-gram.l (YY_OBS_INIT): Remove, replace with...
3691 [SC_COMMENT,SC_STRING,SC_CHARACTER,SC_BRACED_CODE,SC_PROLOGUE]
3692 [SC_EPILOGUE]: Output the quadrigraphs only when not in a comment.
3693 * src/reader.h, src/scan-gram.l (scanner_initialize): this.
3694 * src/reader.c (reader): Use it.
3695
36962002-06-11 Akim Demaille <akim@epita.fr>
3697
3698 * src/scan-gram.l (YY_OBS_FINISH): Don't set yylval.
3699 Adjust all callers.
3700 (scanner_last_string_free): New.
3701
37022002-06-11 Akim Demaille <akim@epita.fr>
3703
3704 * src/scan-gram.l (YY_INIT, YY_GROW, YY_FINISH): Rename as...
3705 (YY_OBS_INIT, YY_OBS_GROW, YY_OBS_FINISH): these.
3706 (last_string, YY_OBS_FREE): New.
3707 Use them when returning an ID.
3708
37092002-06-11 Akim Demaille <akim@epita.fr>
3710
3711 Have Bison grammars parsed by a Bison grammar.
3712
3713 * src/reader.c, src/reader.h (prologue_augment): New.
3714 * src/reader.c (copy_definition): Remove.
3715
3716 * src/reader.h, src/reader.c (gram_start_symbol_set, prologue_augment)
3717 (grammar_symbol_append, grammar_rule_begin, grammar_midrule_action)
3718 (grammar_current_rule_prec_set, grammar_current_rule_check)
3719 (grammar_current_rule_symbol_append)
3720 (grammar_current_rule_action_append): Export.
3721 * src/parse-gram.y (symbol_list_new, symbol_list_symbol_append_
3722 (symbol_list_action_append): Remove.
3723 Hook the routines from reader.
3724 * src/scan-gram.l: In INITIAL, characters and strings are tokens.
3725 * src/system.h (ATTRIBUTE_NORETURN, ATTRIBUTE_UNUSED): Now.
3726
3727 * src/reader.c (read_declarations): Remove, unused.
3728
3729 * src/parse-gram.y: Handle the epilogue.
3730 * src/reader.h, src/reader.c (gram_start_symbol_set): Rename as...
3731 (grammar_start_symbol_set): this.
3732 * src/scan-gram.l: Be sure to ``use'' yycontrol to keep GCC quiet.
3733 * src/reader.c (readgram): Remove, unused.
3734 (reader): Adjust to insert eoftoken and axiom where appropriate.
3735
3736 * src/reader.c (copy_dollar): Replace with...
3737 * src/scan-gram.h (handle_dollar): this.
3738 * src/parse-gram.y: Remove `%thong'.
3739
3740 * src/reader.c (copy_at): Replace with...
3741 * src/scan-gram.h (handle_at): this.
3742
3743 * src/complain.h, src/complain.c (warn_at, complain_at, fatal_at):
3744 New.
3745
3746 * src/scan-gram.l (YY_LINES): Keep lineno synchronized for the
3747 time being.
3748
3749 * src/reader.h, src/reader.c (grammar_rule_end): New.
3750
3751 * src/parse.y (current_type, current_class): New.
3752 Implement `%nterm', `%token' support.
3753 Merge `%term' into `%token'.
3754 (string_as_id): New.
3755 * src/symtab.h, src/symtab.c (symbol_make_alias): Don't pass the
3756 type name.
3757
3758 * src/parse-gram.y: Be sure to handle properly the beginning of
3759 rules.
3760
3761 * src/parse-gram.y: Handle %type.
3762 * src/reader.c (grammar_rule_end): Call grammar_current_rule_check.
3763
3764 * src/parse-gram.y: More directives support.
3765 * src/options.c: No longer handle source directives.
3766
3767 * src/parse-gram.y: Fix %output.
3768
3769 * src/parse-gram.y: Handle %union.
3770 Use the prologue locations.
3771 * src/reader.c (parse_union_decl): Remove.
3772
3773 * src/reader.h, src/reader.c (epilogue_set): New.
3774 * src/parse-gram.y: Use it.
3775
3776 * data/bison.simple, data/bison.c++: b4_stype is now either not
3777 defined, then default to int, or to the contents of %union,
3778 without `union' itself.
3779 Adjust.
3780 * src/muscle_tab.c (muscle_init): Don't predefine `stype'.
3781
3782 * src/output.c (actions_output): Don't output braces, as they are
3783 already handled by the scanner.
3784
3785 * src/scan-gram.l (SC_CHARACTER): Set the user_token_number of
3786 characters to themselves.
3787
3788 * tests/reduce.at (Reduced Automaton): End the grammars with %% so
3789 that the epilogue has a proper #line.
3790
3791 * src/parse-gram.y: Handle precedence/associativity.
3792
3793 * src/symtab.c (symbol_precedence_set): Requires the symbol to be
3794 a terminal.
3795 * src/scan-gram.l (SC_BRACED_CODE): Catch strings and characters.
3796 * tests/calc.at: Do not use `%token "foo"' as it makes not sense
3797 at all to define terminals that cannot be emitted.
3798
3799 * src/scan-gram.l: Escape M4 characters.
3800
3801 * src/scan-gram.l: Working properly with escapes in user
3802 strings/characters.
3803
3804 * tests/torture.at (AT_DATA_TRIANGULAR_GRAMMAR)
3805 (AT_DATA_HORIZONTAL_GRAMMAR): Respect the `%token ID NUM STRING'
3806 grammar.
3807 Use more modest sizes, as for the time being the parser does not
3808 release memory, and therefore the process swallows a huge amount
3809 of memory.
3810
3811 * tests/torture.at (AT_DATA_LOOKAHEADS_GRAMMAR): Adjust to the
3812 stricter %token grammar.
3813
3814 * src/symtab.h (associativity): Add `undef_assoc'.
3815 (symbol_precedence_set): Do nothing when passed an undef_assoc.
3816 * src/symtab.c (symbol_check_alias_consistence): Adjust.
3817
3818 * tests/regression.at (Invalid %directive): Remove, as it is now
3819 meaningless.
3820 (Invalid inputs): Adjust to the new error messages.
3821 (Token definitions): The new grammar doesn't allow too many
3822 eccentricities.
3823
3824 * src/lex.h, src/lex.c: Remove.
3825 * src/reader.c (lastprec, skip_to_char, read_signed_integer)
3826 (copy_character, copy_string2, copy_string, copy_identifier)
3827 (copy_comment, parse_token_decl, parse_type_decl, parse_assoc_decl)
3828 (parse_muscle_decl, parse_dquoted_param, parse_skel_decl)
3829 (parse_action): Remove.
3830 * po/POTFILES.in: Adjust.
3831
38322002-06-11 Akim Demaille <akim@epita.fr>
3833
3834 * src/reader.c (parse_action): Don't store directly into the
3835 rule's action member: return the action as a string.
3836 Don't require `rule_length' as an argument: compute it.
3837 (grammar_current_rule_symbol_append)
3838 (grammar_current_rule_action_append): New, eved out from
3839 (readgram): here.
3840 Remove `action_flag', `rulelength', unused now.
3841
38422002-06-11 Akim Demaille <akim@epita.fr>
3843
3844 * src/reader.c (grammar_current_rule_prec_set).
3845 (grammar_current_rule_check): New, eved out from...
3846 (readgram): here.
3847 Remove `xaction', `first_rhs': useless.
3848 * tests/input.at (Type clashes): New.
3849 * tests/existing.at (GNU Cim Grammar): Adjust.
3850
38512002-06-11 Akim Demaille <akim@epita.fr>
3852
3853 * src/reader.c (grammar_midrule_action): New, Eved out from
3854 (readgram): here.
3855
38562002-06-11 Akim Demaille <akim@epita.fr>
3857
3858 * src/reader.c (grammar_rule_begin, previous_rule, current_rule):
3859 New.
3860 (readgram): Use them as replacement of inlined code, crule and
3861 crule1.
3862
38632002-06-11 Akim Demaille <akim@epita.fr>
3864
3865 * src/reader.c (grammar_end, grammar_symbol_append): New.
3866 (readgram): Use them.
3867 Make the use of `p' as local as possible.
3868
38692002-06-10 Akim Demaille <akim@epita.fr>
3870
3871 GCJ's parser requires the tokens to be defined before the prologue.
3872
3873 * data/bison.simple: Output the token definition before the user's
3874 prologue.
3875 * tests/regression.at (Braces parsing, Duplicate string)
3876 (Mixing %token styles): Check the output from bison.
3877 (Early token definitions): New.
3878
38792002-06-10 Akim Demaille <akim@epita.fr>
3880
3881 * src/symtab.c (symbol_user_token_number_set): Don't complain when
3882 assigning twice the same user number to a token, so that we can
3883 use it in...
3884 * src/lex.c (lex): here.
3885 Also use `symbol_class_set' instead of hand written code.
3886 * src/reader.c (parse_assoc_decl): Likewise.
3887
38882002-06-10 Akim Demaille <akim@epita.fr>
3889
3890 * src/symtab.c, src/symtab.c (symbol_class_set)
3891 (symbol_user_token_number_set): New.
3892 * src/reader.c (parse_token_decl): Use them.
3893 Use a switch instead of ifs.
3894 Use a single argument.
3895
38962002-06-10 Akim Demaille <akim@epita.fr>
3897
3898 Remove `%thong' support as it is undocumented, unused, duplicates
3899 `%token's job, and creates useless e-mail traffic with people who
3900 want to know what it is, why it is undocumented, unused, and
3901 duplicates `%token's job.
3902
3903 * src/reader.c (parse_thong_decl): Remove.
3904 * src/options.c (option_table): Remove "thong".
3905 * src/lex.h (tok_thong): Remove.
3906
39072002-06-10 Akim Demaille <akim@epita.fr>
3908
3909 * src/symtab.c, src/symtab.c (symbol_type_set)
3910 (symbol_precedence_set): New.
3911 * src/reader.c (parse_type_decl, parse_assoc_decl): Use them.
3912 (value_components_used): Remove, unused.
3913
39142002-06-09 Akim Demaille <akim@epita.fr>
3915
3916 Move symbols handling code out of the reader.
3917
3918 * src/reader.h, src/reader.c (errtoken, undeftoken, eoftoken)
3919 (axiom): Move to...
3920 * src/symtab.h, src/symtab.c: here.
3921
3922 * src/gram.c (start_symbol): Remove: use startsymbol->number.
3923 * src/reader.c (startval): Rename as...
3924 * src/symtab.h, src/symtab.c (startsymbol): this.
3925 * src/reader.c: Adjust.
3926
3927 * src/reader.c (symbol_check_defined, symbol_make_alias)
3928 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
3929 (token_translations_init)
3930 Move to...
3931 * src/symtab.c: here.
3932 * src/reader.c (packsymbols): Move to...
3933 * src/symtab.h, src/symtab.c (symbols_pack): here.
3934 * src/symtab.h, src/symtab.c (symbol_make_alias): Takes SYMVAL as
3935 argument.
3936
39372002-06-03 Akim Demaille <akim@epita.fr>
3938
3939 * src/muscle_tab.c (muscle_insert, muscle_find): Declarations,
3940 then statements.
3941
39422002-06-03 Akim Demaille <akim@epita.fr>
3943
3944 * src/muscle_tab.c (muscle_find, muscle_insert): Don't initialize
3945 structs with non literals.
3946 * src/scan-skel.l: never-interactive.
3947 * src/conflicts.c (enum conflict_resolution_e): No trailing
3948 comma.
3949 * src/getargs.c (usage): Split long literal strings.
3950 Reported by Hans Aberg.
3951
39522002-05-28 Akim Demaille <akim@epita.fr>
3953
3954 * data/bison.c++: Use C++ ostreams.
3955 (cdebug_): New member.
3956
39572002-05-28 Akim Demaille <akim@epita.fr>
3958
3959 * src/output.c (output_skeleton): Be sure to allocate enough room
3960 for `/' _and_ for `\0' in full_skeleton.
3961
39622002-05-28 Akim Demaille <akim@epita.fr>
3963
3964 * data/bison.c++: Catch up with bison.simple:
3965 2002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3966 and Paul Eggert <eggert@twinsun.com>: `error' handing.
3967 2002-05-26 Akim Demaille <akim@epita.fr>: stos_, token_number_,
3968 and popping traces.
3969
39702002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3971
3972 * src/output.c (output_skeleton): Put an explicit path in front of
3973 the skeleton file name, rather than relying on the -I directory,
3974 to partially alleviate effects of having a skeleton file lying around
3975 in the current directory.
3976
39772002-05-27 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
3978
3979 * src/conflicts.c (log_resolution): Correct typo:
3980 obstack_printf should be obstack_fgrow1.
3981
39822002-05-26 Akim Demaille <akim@epita.fr>
3983
3984 * src/state.h (state_t): `solved_conflicts' is a new member.
3985 * src/LR0.c (new_state): Set it to 0.
3986 * src/conflicts.h, src/conflicts.c (print_conflicts)
3987 (free_conflicts, solve_conflicts): Rename as...
3988 (conflicts_print, conflicts_free, conflicts_solve): these.
3989 Adjust callers.
3990 * src/conflicts.c (enum conflict_resolution_e)
3991 (solved_conflicts_obstack): New, used by...
3992 (log_resolution): this.
3993 Adjust to attach the conflict resolution to each state.
3994 Complete the description with the precedence/associativity
3995 information.
3996 (resolve_sr_conflict): Adjust.
3997 * src/print.c (print_state): Output its solved_conflicts.
3998 * tests/conflicts.at (Unresolved SR Conflicts)
3999 (Solved SR Conflicts): Exercise --report=all.
4000
40012002-05-26 Akim Demaille <akim@epita.fr>
4002
4003 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4004 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4005 * src/reader.c, src/reduce.c, src/state.h, src/symtab.h
4006 (token_number_t, item_number_as_token_number)
4007 (token_number_as_item_number, muscle_insert_token_number_table):
4008 Rename as...
4009 (symbol_number_t, item_number_as_symbol_number)
4010 (symbol_number_as_item_number, muscle_insert_symbol_number_table):
4011 these, since it is more appropriate.
4012
40132002-05-26 Akim Demaille <akim@epita.fr>
4014
4015 * tests/calc.at (AT_CHECK_CALC): Adjust: there are now additional
4016 `Error:' lines.
4017 * data/bison.simple (yystos) [YYDEBUG]: New.
4018 (yyparse) [YYDEBUG]: Display the symbols which are popped during
4019 error recovery.
4020 * tests/regression.at (Web2c Actions): Adjust: yystos is output now.
4021
40222002-05-25 Akim Demaille <akim@epita.fr>
4023
4024 * doc/bison.texinfo (Debugging): Split into...
4025 (Tracing): this new section, its former contents, and...
4026 (Understanding): this new section.
4027 * src/getargs.h, src/getargs.c (verbose_flag): Remove, replaced
4028 by...
4029 (report_flag): this.
4030 Adjust all dependencies.
4031 (report_args, report_types, report_argmatch): New.
4032 (usage, getargs): Report/support -r, --report.
4033 * src/options.h
4034 (struct option_table_struct): Rename as..,
4035 (struct option_table_s): this.
4036 Rename the `set_flag' member to `flag' to match with getopt_long's
4037 struct.
4038 * src/options.c (option_table): Split verbose into an entry for
4039 %verbose, and another for --verbose.
4040 Support --report/-r, so remove -r from the obsolete --raw.
4041 * src/print.c: Attach full item sets and lookaheads reports to
4042 report_flag instead of trace_flag.
4043 * lib/argmatch.h, lib/argmatch.c: New, from Fileutils 4.1.
4044
40452002-05-24 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4046 and Paul Eggert <eggert@twinsun.com>
4047
4048 * data/bison.simple (yyparse): Correct error handling to conform to
4049 POSIX and yacc. Specifically, after syntax error is discovered,
4050 do not reduce further before shifting the error token.
4051 Clean up the code a bit by removing the labels yyerrdefault,
4052 yyerrhandle, yyerrpop.
4053 * NEWS: Document the above.
4054
40552002-05-20 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4056
4057 * data/bison.simple (yyr1): Don't use yy_token_number_type as element
4058 type; it isn't always big enough, since it doesn't necessarily
4059 include non-terminals.
4060 (yytranslate): Expand definition of yy_token_number_type, so that
4061 the latter can be removed.
4062 (yy_token_number_type): Remove, only one use.
4063 * data/bison.c++ (r1_): Parallel change to yyr1 in bison.simple---
4064 don't use TokenNumberType as element type.
4065
4066 * tests/regression.at: Modify expected output to agree with change
4067 to yyr1 and yytranslate.
4068
40692002-05-13 Florian Krohm <florian@edamail.fishkill.ibm.com>
4070
4071 * src/reader.c (parse_action): Use copy_character instead of
4072 obstack_1grow.
4073
40742002-05-13 Akim Demaille <akim@epita.fr>
4075
4076 * tests/regression.at (Token definitions): Prototype yylex and
4077 yyerror.
4078
40792002-05-12 Paul Hilfinger <Hilfinger@CS.Berkeley.EDU>
4080
4081 * src/scan-skel.l: Correct off-by-one error in handling of __oline__.
4082 * data/bison.simple (b4_sint_type, b4_uint_type): Correct to reflect
4083 32-bit arithmetic.
4084 * data/bison.c++ (b4_sint_type, b4_uint_type): Ditto.
4085
40862002-05-07 Akim Demaille <akim@epita.fr>
4087
4088 * tests/synclines.at: Be sure to prototype yylex and yyerror to
4089 avoid GCC warnings.
4090
40912002-05-07 Akim Demaille <akim@epita.fr>
4092
4093 Kill GCC warnings.
4094
4095 * src/reduce.c (nonterminals_reduce): Don't loop over RITEM: loop
4096 over the RHS of each rule.
4097 * src/gram.h, src/gram.c (nritems): Is `unsigned int', not int.
4098 * src/state.h (state_t): Member `nitems' is unsigned short.
4099 * src/LR0.c (get_state): Adjust.
4100 * src/reader.c (packgram): Likewise.
4101 * src/output.c (GENERATE_MUSCLE_INSERT_TABLE): `max' is of type
4102 `Type'.
4103 (muscle_insert_int_table): Remove, unused.
4104 (prepare_rules): Remove `max'.
4105
41062002-05-06 Akim Demaille <akim@epita.fr>
4107
4108 * src/closure.c (print_firsts): Display of the symbol tags.
4109 (bitmatrix_print): Move to...
4110 * lib/bitsetv-print.h, lib/bitsetv-print.c (bitsetv_matrix_dump):
4111 here.
4112 * tests/sets.at (Nullable, Broken Closure, Firsts): Adjust.
4113
41142002-05-06 Akim Demaille <akim@epita.fr>
4115
4116 * src/muscle_tab.c (muscle_m4_output): Must return TRUE for
4117 hash_do_for_each.
4118
41192002-05-06 Akim Demaille <akim@epita.fr>
4120
4121 * src/LR0.c (new_state, get_state): Instead of using the global
4122 `kernel_size' and `kernel_base', have two new arguments:
4123 `core_size' and `core'.
4124 Adjust callers.
4125
41262002-05-06 Akim Demaille <akim@epita.fr>
4127
4128 * src/reader.c (packgram): No longer end `ritem' with a 0
4129 sentinel: it is not used.
4130
41312002-05-05 Akim Demaille <akim@epita.fr>
4132
4133 New experimental feature: display the lookaheads in the report and
4134 graph.
4135
4136 * src/print (print_core): When --trace-flag, display the rules
4137 lookaheads.
4138 * src/print_graph.c (print_core): Likewise.
4139 Swap the arguments.
4140 Adjust caller.
4141
41422002-05-05 Akim Demaille <akim@epita.fr>
4143
4144 * tests/torture.at (Many lookaheads): New test.
4145
41462002-05-05 Akim Demaille <akim@epita.fr>
4147
4148 * src/output.c (GENERATE_OUTPUT_TABLE): Replace with...
4149 (GENERATE_MUSCLE_INSERT_TABLE): this.
4150 (output_int_table, output_unsigned_int_table, output_short_table)
4151 (output_token_number_table, output_item_number_table): Replace with...
4152 (muscle_insert_int_table, muscle_insert_unsigned_int_table)
4153 (muscle_insert_short_table, muscle_insert_token_number_table)
4154 (muscle_insert_item_number_table): these.
4155 Adjust all callers.
4156 (prepare_tokens): Don't free `translations', since...
4157 * src/reader.h, src/reader.c (grammar_free): do it.
4158 Move to...
4159 * src/gram.h, src/gram.c (grammar_free): here.
4160 * data/bison.simple, data/bison.c++: b4_token_number_max is now
4161 b4_translate_max.
4162
41632002-05-05 Akim Demaille <akim@epita.fr>
4164
4165 * src/output.c (output_unsigned_int_table): New.
4166 (prepare_rules): `i' is unsigned.
4167 `prhs', `rline', `r2' are unsigned int.
4168 Rename muscle `rhs_number_max' as `rhs_max'.
4169 Output muscles `prhs_max', `rline_max', and `r2_max'.
4170 Free rline and r1.
4171 * data/bison.simple, data/bison.c++: Adjust to use these muscles
4172 to compute types instead of constant types.
4173 * tests/regression.at (Web2c Actions): Adjust.
4174
41752002-05-04 Akim Demaille <akim@epita.fr>
4176
4177 * src/symtab.h (SALIAS, SUNDEF): Rename as...
4178 (USER_NUMBER_ALIAS, USER_NUMBER_UNDEFINED): these.
4179 Adjust dependencies.
4180 * src/output.c (token_definitions_output): Be sure not to output a
4181 `#define 'a'' when fed with `%token 'a' "a"'.
4182 * tests/regression.at (Token definitions): New.
4183
41842002-05-03 Paul Eggert <eggert@twinsun.com>
4185
4186 * data/bison.simple (b4_token_defines): Also define YYTOKENTYPE
4187 for K&R C.
4188
41892002-05-03 gettextize <bug-gnu-gettext@gnu.org>
4190
4191 * Makefile.am (SUBDIRS): Remove intl.
4192 (EXTRA_DIST): Add config/config.rpath.
4193
41942002-05-03 Akim Demaille <akim@epita.fr>
4195
4196 * data/bison.simple (m4_if): Don't output empty enums.
4197 And actually, output valid enum definitions :(.
4198
41992002-05-03 Akim Demaille <akim@epita.fr>
4200
4201 * configure.bat: Remove, completely obsolete.
4202 * Makefile.am (EXTRA_DIST): Adjust.
4203 Don't distribute config.rpath...
4204 * config/Makefile.am (EXTRA_DIST): Do it.
4205
42062002-05-03 Akim Demaille <akim@epita.fr>
4207
4208 * configure.in (GETTEXT_VERSION): New.
4209 Suggested by Bruno Haible for the forthcoming Gettext 0.10.3.
4210
42112002-05-03 Akim Demaille <akim@epita.fr>
4212
4213 * data/bison.simple (b4_token_enum): New.
4214 (b4_token_defines): Use it to output tokens both as #define and
4215 enums.
4216 Suggested by Paul Eggert.
4217 * src/output.c (token_definitions_output): Don't output spurious
4218 white spaces.
4219
42202002-05-03 Akim Demaille <akim@epita.fr>
4221
4222 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4223
42242002-05-02 Robert Anisko <robert@lrde.epita.fr>
4225
4226 * data/bison.c++: Adapt expansion of $s and @s to the C++ parser.
4227 Update the stack class, give a try to deque as the default container.
4228
42292002-05-02 Akim Demaille <akim@epita.fr>
4230
4231 * data/bison.simple (yyparse): Do not implement @$ = @1.
4232 (YYLLOC_DEFAULT): Adjust to do it.
4233 * doc/bison.texinfo (Location Default Action): Fix.
4234
42352002-05-02 Akim Demaille <akim@epita.fr>
4236
4237 * src/reader.c (parse_braces): Merge into...
4238 (parse_action): this.
4239
42402002-05-02 Akim Demaille <akim@epita.fr>
4241
4242 * configure.in (ALL_LINGUAS): Remove.
4243 * po/LINGUAS, hr.po: New.
4244
42452002-05-02 Akim Demaille <akim@epita.fr>
4246
4247 Remove the so called hairy (semantic) parsers.
4248
4249 * src/system.h (EXT_GUARD_C, EXT_STYPE_H): Remove.
4250 * src/gram.h, src/gram.c (semantic_parser): Remove.
4251 (rule_t): Remove the guard and guard_line members.
4252 * src/lex.h (token_t): remove tok_guard.
4253 * src/options.c (option_table): Remove %guard and %semantic_parser
4254 support.
4255 * src/output.c, src/output.h (guards_output): Remove.
4256 (prepare): Adjust.
4257 (token_definitions_output): Don't output the `T'
4258 tokens (???).
4259 (output_skeleton): Don't output the guards.
4260 * src/files.c, src/files.c (attrsfile): Remove.
4261 * src/reader.c (symbol_list): Remove the guard and guard_line
4262 members.
4263 Adjust dependencies.
4264 (parse_guard): Remove.
4265 * data/bison.hairy: Remove.
4266 * doc/bison.texinfo (Environment Variables): Remove occurrences of
4267 BISON_HAIRY.
4268
42692002-05-02 Akim Demaille <akim@epita.fr>
4270
4271 * src/reader.c (copy_at, copy_dollarm parse_braces, parse_action)
4272 (parse_guard): Rename the formal argument `stack_offset' as
4273 `rule_length', which is more readable.
4274 Adjust callers.
4275 (copy_at, copy_dollar): Instead of outputting the hard coded
4276 values of $$, $n and so forth, output invocation to b4_lhs_value,
4277 b4_lhs_location, b4_rhs_value, and b4_rhs_location.
4278 Note: this patch partially drops `semantic-parser' support: it
4279 always does `rule_length - n', where semantic parsers ought to
4280 always use `-n'.
4281 * data/bison.simple, data/bison.c++ (b4_lhs_value)
4282 (b4_lhs_location, b4_rhs_value, and b4_rhs_location: New.
4283
42842002-05-02 Akim Demaille <akim@epita.fr>
4285
4286 * configure.in (AC_INIT): Bump to 1.49b.
4287 (AM_INIT_AUTOMAKE): Short invocation.
4288
42892002-05-02 Akim Demaille <akim@epita.fr>
4290
4291 Version 1.49a.
4292
42932002-05-01 Akim Demaille <akim@epita.fr>
4294
4295 * src/skeleton.h: Remove.
4296
42972002-05-01 Akim Demaille <akim@epita.fr>
4298
4299 * src/skeleton.h: Fix the #endif.
4300 Reported by Magnus Fromreide.
4301
43022002-04-26 Paul Eggert <eggert@twinsun.com>
4303
4304 * data/bison.simple (YYSTYPE_IS_TRIVIAL, YYLTYPE_IS_TRIVIAL):
4305 Define if we define YYSTYPE and YYLTYPE, respectively.
4306 (YYCOPY): Fix [] quoting problem in the non-GCC case.
4307
43082002-04-25 Robert Anisko <robert@lrde.epita.fr>
4309
4310 * src/scan-skel.l: Postprocess quadrigraphs.
4311
4312 * src/reader.c (copy_character): New function, used to output
4313 single characters while replacing `[' and `]' with quadrigraphs, to
4314 avoid troubles with M4 quotes.
4315 (copy_comment): Output characters with copy_character.
4316 (read_additionnal_code): Likewise.
4317 (copy_string2): Likewise.
4318 (copy_definition): Likewise.
4319
4320 * tests/calc.at: Exercise M4 quoting.
4321
43222002-04-25 Akim Demaille <akim@epita.fr>
4323
4324 * tests/sets.at (AT_EXTRACT_SETS): Sed portability issue: no space
4325 between `!' and the command.
4326 Reported by Paul Eggert.
4327
43282002-04-24 Robert Anisko <robert@lrde.epita.fr>
4329
4330 * tests/calc.at: Exercise prologue splitting.
4331
4332 * data/bison.simple, data/bison.c++: Use `b4_pre_prologue' and
4333 `b4_post_prologue' instead of `b4_prologue'.
4334
4335 * src/output.c (prepare): Add the `pre_prologue' and `post_prologue'
4336 muscles.
4337 (output): Free pre_prologue_obstack and post_prologue_obstack.
4338 * src/files.h, src/files.c (attrs_obstack): Remove.
4339 (pre_prologue_obstack, post_prologue_obstack): New.
4340 * src/reader.c (copy_definition): Add a parameter to specify the
4341 obstack to fill, instead of using attrs_obstack unconditionally.
4342 (read_declarations): Pass pre_prologue_obstack to copy_definition if
4343 `%union' has not yet been seen, pass post_prologue_obstack otherwise.
4344
43452002-04-23 Paul Eggert <eggert@twinsun.com>
4346
4347 * data/bison.simple: Remove unnecessary commentary and white
4348 space differences from 1_29-branch.
4349 Depend on YYERROR_VERBOSE, not defined (YYERROR_VERBOSE).
4350
4351 (union yyalloc, YYSTACK_GAP_MAX, YYSTACK_BYTES, YYCOPY,
4352 YYSTACK_RELOCATE): Do not define if yyoverflow is defined, or
4353 if this is a C++ parser and YYSTYPE or YYLTYPE has nontrivial
4354 constructors or destructors.
4355
4356 (yyparse) [! defined YYSTACK_RELOCATE]: Do not relocate the stack.
4357
43582002-04-23 Akim Demaille <akim@epita.fr>
4359
4360 * tests/sets.at (AT_EXTRACT_SETS): Don't use 8 char long sed labels.
4361 * tests/synclines.at (AT_TEST_SYNCLINE): Be robust to GCC's
4362 location with columns.
4363 * tests/conflicts.at (%nonassoc and eof): Don't use `error.h'.
4364 All reported by Paul Eggert.
4365
43662002-04-22 Akim Demaille <akim@epita.fr>
4367
4368 * src/reduce.c (dump_grammar): Move to...
4369 * src/gram.h, src/gram.c (grammar_dump): here.
4370 Be sure to separate long item numbers.
4371 Don't read the members of a rule's prec if its nil.
4372
43732002-04-22 Akim Demaille <akim@epita.fr>
4374
4375 * src/output.c (table_size, table_grow): New.
4376 (MAXTABLE): Remove, replace uses with table_size.
4377 (pack_vector): Instead of dying when the table is too big, grow it.
4378
43792002-04-22 Akim Demaille <akim@epita.fr>
4380
4381 * data/bison.simple (yyr1): Its type is that of a token number.
4382 * data/bison.c++ (r1_): Likewise.
4383 * tests/regression.at (Web2c Actions): Adjust.
4384
43852002-04-22 Akim Demaille <akim@epita.fr>
4386
4387 * src/reader.c (token_translations_init): 256 is now the default
4388 value for the error token, i.e., it will be assigned another
4389 number if the user assigned 256 to one of her tokens.
4390 (reader): Don't force 256 to error.
4391 * doc/bison.texinfo (Symbols): Adjust.
4392 * tests/torture.at (AT_DATA_HORIZONTAL_GRAMMAR)
4393 (AT_DATA_TRIANGULAR_GRAMMAR): Number the tokens as 1, 2, 3
4394 etc. instead of 10, 20, 30 (which was used to `jump' over error
4395 (256) and undefined (2)).
4396
43972002-04-22 Akim Demaille <akim@epita.fr>
4398
4399 Propagate more token_number_t.
4400
4401 * src/gram.h (token_number_as_item_number)
4402 (item_number_as_token_number): New.
4403 * src/output.c (GENERATE_OUTPUT_TABLE): New.
4404 Use it to create output_item_number_table and
4405 output_token_number_table.
4406 * src/LR0.c, src/derives.c, src/gram.c, src/gram.h, src/lalr.c,
4407 * src/lex.c, src/nullable.c, src/output.c, src/print.c,
4408 * src/print_graph.c, src/reader.c, src/reduce.c, src/state.h,
4409 * src/symtab.c, src/symtab.h: Use token_number_t instead of shorts.
4410
44112002-04-22 Akim Demaille <akim@epita.fr>
4412
4413 * src/output.h, src/output.c (get_lines_number): Remove.
4414
44152002-04-19 Akim Demaille <akim@epita.fr>
4416
4417 * doc/bison.texinfo (Actions): Make clear that `|' is not the same
4418 as Lex/Flex'.
4419 (Debugging): More details about enabling the debugging features.
4420 (Table of Symbols): Describe $$, $n, @$, and @n.
4421 Suggested by Tim Josling.
4422
44232002-04-19 Akim Demaille <akim@epita.fr>
4424
4425 * doc/bison.texinfo: Remove the uses of the obsolete @refill.
4426
44272002-04-10 Akim Demaille <akim@epita.fr>
4428
4429 * src/system.h: Rely on HAVE_LIMITS_H.
4430 Suggested by Paul Eggert.
4431
44322002-04-09 Akim Demaille <akim@epita.fr>
4433
4434 * tests/calc.at (_AT_CHECK_CALC_ERROR): Receive as argument the
4435 full stderr, and strip it according to the bison options, instead
4436 of composing the error message from different bits.
4437 This makes it easier to check for several error messages.
4438 Adjust all the invocations.
4439 Add an invocation exercising the error token.
4440 Add an invocation demonstrating a stupid error message.
4441 (_AT_DATA_CALC_Y): Follow the GCS: initial column is 1, not 0.
4442 Adjust the tests.
4443 Error message are for stderr, not stdout.
4444
44452002-04-09 Akim Demaille <akim@epita.fr>
4446
4447 * src/gram.h, src/gram.c (error_token_number): Remove, use
4448 errtoken->number.
4449 * src/reader.c (reader): Don't specify the user token number (2)
4450 for $undefined, as it uselessly prevents using it.
4451 * src/gram.h (token_number_t): Move to...
4452 * src/symtab.h: here.
4453 (state_t.number): Is a token_number_t.
4454 * src/print.c, src/reader.c: Use undeftoken->number instead of
4455 hard coded 2.
4456 (Even though this 2 is not the same as above: the number of the
4457 undeftoken remains being 2, it is its user token number which
4458 might not be 2).
4459 * src/output.c (prepare_tokens): Rename the `maxtok' muscle with
4460 `user_token_number_max'.
4461 Output `undef_token_number'.
4462 * data/bison.simple, data/bison.c++: Use them.
4463 Be sure to map invalid yylex return values to
4464 `undef_token_number'. This saves us from gratuitous SEGV.
4465
4466 * tests/conflicts.at (Solved SR Conflicts)
4467 (Unresolved SR Conflicts): Adjust.
4468 * tests/regression.at (Web2c Actions): Adjust.
4469
44702002-04-08 Akim Demaille <akim@epita.fr>
4471
4472 * data/bison.c++: s/b4_item_number_max/b4_rhs_number_max/.
4473 Adding #line.
4474 Remove the duplicate `typedefs'.
4475 (RhsNumberType): Fix the declaration and various other typos.
4476 Use __ofile__.
4477 * data/bison.simple: Use __ofile__.
4478 * src/scan-skel.l: Handle __ofile__.
4479
44802002-04-08 Akim Demaille <akim@epita.fr>
4481
4482 * src/gram.h (item_number_t): New, the type of item numbers in
4483 RITEM. Note that it must be able to code symbol numbers as
4484 positive number, and the negation of rule numbers as negative
4485 numbers.
4486 Adjust all dependencies (pretty many).
4487 * src/reduce.c (rule): Remove this `short *' pointer: use
4488 item_number_t.
4489 * src/system.h (MINSHORT, MAXSHORT): Remove.
4490 Include `limits.h'.
4491 Adjust dependencies to using SHRT_MAX and SHRT_MIN.
4492 (shortcpy): Remove.
4493 (MAXTABLE): Move to...
4494 * src/output.c (MAXTABLE): here.
4495 (prepare_rules): Use output_int_table to output rhs.
4496 * data/bison.simple, data/bison.c++: Adjust.
4497 * tests/torture.at (Big triangle): Move the limit from 254 to
4498 500.
4499 * tests/regression.at (Web2c Actions): Ajust.
4500
4501 Trying with bigger grammars shows various phenomena: at 3000 (28Mb
4502 of grammar file) bison is killed by my system, at 2000 (12Mb) bison
4503 passes, but produces negative #line number, once fixed, GCC is
4504 killed while compiling 14Mb, at 1500 (6.7 Mb of grammar, 8.2Mb of
4505 C), it passes.
4506 * src/state.h (state_h): Code input lines on ints, not shorts.
4507
45082002-04-08 Akim Demaille <akim@epita.fr>
4509
4510 * src/reduce.c (reduce_grammar): First reduce the nonterminals,
4511 and then the grammar.
4512
45132002-04-08 Akim Demaille <akim@epita.fr>
4514
4515 * src/system.h: No longer using strndup.
4516
45172002-04-07 Akim Demaille <akim@epita.fr>
4518
4519 * src/muscle_tab.h (MUSCLE_INSERT_LONG_INT): New.
4520 * src/output.c (output_table_data): Return the longest number.
4521 (prepare_tokens): Output `token_number_max').
4522 * data/bison.simple, data/bison.c++ (b4_sint_type, b4_uint_type):
4523 New.
4524 Use them to define yy_token_number_type/TokenNumberType.
4525 Use this type for yytranslate.
4526 * tests/torture.at (Big triangle): Push the limit from 124 to
4527 253.
4528 * tests/regression.at (Web2c Actions): Adjust.
4529
45302002-04-07 Akim Demaille <akim@epita.fr>
4531
4532 * tests/torture.at (Big triangle): New.
4533 (GNU AWK Grammar, GNU Cim Grammar): Move to...
4534 * tests/existing.at: here.
4535
45362002-04-07 Akim Demaille <akim@epita.fr>
4537
4538 * src/gram.h, src/gram.c (nitems): Remove, it is an alias of
4539 nritems.
4540 Adjust dependencies.
4541
45422002-04-07 Akim Demaille <akim@epita.fr>
4543
4544 * src/reader.c: Normalize increments to prefix form.
4545
45462002-04-07 Akim Demaille <akim@epita.fr>
4547
4548 * src/reader.c, symtab.c: Remove debugging code.
4549
45502002-04-07 Akim Demaille <akim@epita.fr>
4551
4552 Rename all the `bucket's as `symbol_t'.
4553
4554 * src/gram.c, src/gram.h, src/lex.c, src/lex.h, src/output.c,
4555 * src/reader.c, src/reader.h, src/reduce.c, src/state.h,
4556 * src/symtab.c, src/symtab.h (bucket): Rename as...
4557 (symbol_t): this.
4558 (symbol_list_new, bucket_check_defined, bucket_make_alias)
4559 (bucket_check_alias_consistence, bucket_pack, bucket_translation)
4560 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4561 (buckets_new, buckets_free, buckets_do): Rename as...
4562 (symbol_list_new, symbol_check_defined, symbol_make_alias)
4563 (symbol_check_alias_consistence, symbol_pack, symbol_translation)
4564 (symbol_new, symbol_free, hash_compare_symbol_t, hash_symbol_t)
4565 (symbols_new, symbols_free, symbols_do): these.
4566
45672002-04-07 Akim Demaille <akim@epita.fr>
4568
4569 Use lib/hash for the symbol table.
4570
4571 * src/gram.c (ntokens): Initialize to 1, to reserve a slot for
4572 EOF.
4573 * src/lex.c (lex): Set the `number' member of new terminals.
4574 * src/reader.c (bucket_check_defined, bucket_make_alias)
4575 (bucket_check_alias_consistence, bucket_translation): New.
4576 (reader, grammar_free, readgram, token_translations_init)
4577 (packsymbols): Adjust.
4578 (reader): Number the predefined tokens.
4579 * src/reduce.c (inaccessable_symbols): Just use hard coded numbers
4580 for predefined tokens.
4581 * src/symtab.h (bucket): Remove all the hash table related
4582 members.
4583 * src/symtab.c (symtab): Replace by...
4584 (bucket_table): this.
4585 (bucket_new, bucket_free, hash_compare_bucket, hash_bucket)
4586 (buckets_new, buckets_do): New.
4587
45882002-04-07 Akim Demaille <akim@epita.fr>
4589
4590 * src/gram.c (nitems, nrules, nsyms, ntokens, nvars, nritems)
4591 (start_symbol, max_user_token_number, semantic_parser)
4592 (error_token_number): Initialize.
4593 * src/reader.c (grammar, start_flag, startval, typed, lastprec):
4594 Initialize.
4595 (reader): Don't.
4596 (errtoken, eoftoken, undeftoken, axiom): Extern.
4597
45982002-04-07 Akim Demaille <akim@epita.fr>
4599
4600 * src/gram.h (rule_s): prec and precsym are now pointers
4601 to the bucket giving the priority/associativity.
4602 Member `associativity' removed: useless.
4603 * src/reduce.c, src/conflicts.c: Adjust.
4604
46052002-04-07 Akim Demaille <akim@epita.fr>
4606
4607 * src/lalr.c, src/LR0.c, src/closure.c, src/gram.c, src/reduce.c:
4608 Properly escape the symbols' TAG when outputting them.
4609
46102002-04-07 Akim Demaille <akim@epita.fr>
4611
4612 * src/lalr.h (LA): Is a bitsetv, not bitset*.
4613
46142002-04-07 Akim Demaille <akim@epita.fr>
4615
4616 * src/lalr.h, src/lalr.c (LAruleno): Replace with...
4617 (LArule): this, which is an array to rule_t*.
4618 * src/print.c, src/conflicts.c: Adjust.
4619
46202002-04-07 Akim Demaille <akim@epita.fr>
4621
4622 * src/gram.h (rule_t): Rename `number' as `user_number'.
4623 `number' is a new member.
4624 Adjust dependencies.
4625 * src/reduce.c (reduce_grammar_tables): Renumber rule_t.number.
4626
46272002-04-07 Akim Demaille <akim@epita.fr>
4628
4629 As a result of the previous patch, it is no longer needed
4630 to reorder ritem itself.
4631
4632 * src/reduce.c (reduce_grammar_tables): Don't sort RITEM.
4633
46342002-04-07 Akim Demaille <akim@epita.fr>
4635
4636 Be sure never to walk through RITEMS, but use only data related to
4637 the rules themselves. RITEMS should be banished.
4638
4639 * src/output.c (output_token_translations): Rename as...
4640 (prepare_tokens): this.
4641 In addition to `translate', prepare the muscles `tname' and
4642 `toknum', which were handled by...
4643 (output_rule_data): this.
4644 Remove, and move the remainder of its outputs into...
4645 (prepare_rules): this new routines, which also merges content from
4646 (output_gram): this.
4647 (prepare_rules): Be sure never to walk through RITEMS.
4648 (output_stos): Rename as...
4649 (prepare_stos): this.
4650 (output): Always invoke prepare_states, after all, just don't use it
4651 in the output if you don't need it.
4652
46532002-04-07 Akim Demaille <akim@epita.fr>
4654
4655 * src/LR0.c (new_state): Display `nstates' as the name of the
4656 newly created state.
4657 Adjust to initialize first_state and last_state if needed.
4658 Be sure to distinguish the initial from the final state.
4659 (new_states): Create the itemset of the initial state, and use
4660 new_state.
4661 * src/closure.c (closure): Now that the initial state has its
4662 items properly set, there is no need for a special case when
4663 creating `ruleset'.
4664
4665 As a result, now the rule 0, reducing to $axiom, is visible in the
4666 outputs. Adjust the test suite.
4667
4668 * tests/conflicts.at (Solved SR Conflicts)
4669 (Unresolved SR Conflicts): Adjust.
4670 * tests/regression.at (Web2c Report, Rule Line Numbers): Idem.
4671 * tests/conflicts.at (S/R in initial): New.
4672
46732002-04-07 Akim Demaille <akim@epita.fr>
4674
4675 * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
4676 the RHS of the rules.
4677 * src/output.c (output_gram): Likewise.
4678
46792002-04-07 Akim Demaille <akim@epita.fr>
4680
4681 * src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
4682 bucket.
4683 Adjust all dependencies.
4684 * src/reduce.c (nonterminals_reduce): Don't forget to renumber the
4685 `number' of the buckets too.
4686 * src/gram.h: Include `symtab.h'.
4687 (associativity): Move to...
4688 * src/symtab.h: here.
4689 No longer include `gram.h'.
4690
46912002-04-07 Akim Demaille <akim@epita.fr>
4692
4693 * src/gram.h, src/gram.c (rules_rhs_length): New.
4694 (ritem_longest_rhs): Use it.
4695 * src/gram.h (rule_t): `number' is a new member.
4696 * src/reader.c (packgram): Set it.
4697 * src/reduce.c (reduce_grammar_tables): Move the useless rules at
4698 the end of `rules', and count them out of `nrules'.
4699 (reduce_output, dump_grammar): Adjust.
4700 * src/print.c (print_grammar): It is no longer needed to check for
4701 the usefulness of a rule, as useless rules are beyond `nrules + 1'.
4702 * tests/reduce.at (Reduced Automaton): New test.
4703
47042002-04-07 Akim Demaille <akim@epita.fr>
4705
4706 * src/reduce.c (inaccessable_symbols): Fix a buglet: because of a
4707 lacking `+ 1' to nrules, Bison reported as useless a token if it
4708 was used solely to set the precedence of the last rule...
4709
47102002-04-07 Akim Demaille <akim@epita.fr>
4711
4712 * data/bison.c++, data/bison.simple: Don't output the current file
4713 name in #line, to avoid useless diffs between two identical
4714 outputs under different names.
4715
47162002-04-07 Akim Demaille <akim@epita.fr>
4717
4718 * src/closure.c, src/print.c, src/reader.c, src/reduce.c:
4719 Normalize loops to using `< nrules + 1', not `<= nrules'.
4720
47212002-04-07 Akim Demaille <akim@epita.fr>
4722
4723 * TODO: Update.
4724
47252002-04-07 Akim Demaille <akim@epita.fr>
4726
4727 * src/output.c, src/reader.c, src/symtab.c, src/symtab.h: Rename
4728 bucket.value as bucket.number.
4729
47302002-04-07 Akim Demaille <akim@epita.fr>
4731
4732 * src/closure.c, src/derives.c, src/gram.h, src/lalr.c,
4733 * src/nullable.c, src/output.c, src/print.c, src/print_graph.c,
4734 * src/reader.c, src/reduce.c: Let rule_t.rhs point directly to the
4735 RHS, instead of being an index in RITEMS.
4736
47372002-04-04 Paul Eggert <eggert@twinsun.com>
4738
4739 * doc/bison.texinfo: Update copyright date.
4740 (Rpcalc Lexer, Symbols, Token Decl): Don't assume ASCII.
4741 (Symbols): Warn about running Bison in one character set,
4742 but compiling and/or running in an incompatible one.
4743 Warn about character code 256, too.
4744
47452002-04-03 Paul Eggert <eggert@twinsun.com>
4746
4747 * src/bison.data (YYSTACK_ALLOC): Depend on whether
4748 YYERROR_VERBOSE is nonzero, not whether it is defined.
4749
4750 Merge changes from bison-1_29-branch.
4751
47522002-03-20 Paul Eggert <eggert@twinsun.com>
4753
4754 Merge fixes from Debian bison_1.34-1.diff.
4755
4756 * configure.in (AC_PREREQ): 2.53.
4757
47582002-03-20 Akim Demaille <akim@epita.fr>
4759
4760 * src/conflicts.c (log_resolution): Argument `resolution' is const.
4761
47622002-03-19 Paul Eggert <eggert@twinsun.com>
4763
4764 * src/bison.simple (YYCOPY): New macro.
4765 (YYSTACK_RELOCATE): Use it.
4766 Remove Type arg; no longer needed. All callers changed.
4767 (yymemcpy): Remove; no longer needed.
4768
4769 * Makefile.am (AUTOMAKE_OPTIONS): 1.6.
4770 * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
4771
47722002-03-19 Akim Demaille <akim@epita.fr>
4773
4774 Test and fix the #line outputs.
4775
4776 * tests/atlocal.at (GCC): New.
4777 * tests/synclines.at (AT_TEST_SYNCLINE): New macro.
4778 (Prologue synch line, ,%union synch line, Postprologue synch line)
4779 (Action synch line, Epilogue synch line): New tests.
4780 * src/reader.c (parse_union_decl): Define the muscle stype_line.
4781 * data/bison.simple, data/bison.c++: Use it.
4782
47832002-03-19 Akim Demaille <akim@epita.fr>
4784
4785 * tests/regression.at (%nonassoc and eof, Unresolved SR Conflicts)
4786 (Solved SR Conflicts, %expect not enough, %expect right)
4787 (%expect too much): Move to...
4788 * tests/conflicts.at: this new file.
4789
47902002-03-19 Akim Demaille <akim@epita.fr>
4791
4792 * data/m4sugar/m4sugar.m4: Update from CVS Autoconf.
4793 * data/bison.simple, data/bison.c++: Handle the `#define' part, so
4794 that we can move to enums for instance.
4795 * src/output.c (token_definitions_output): Output a list of
4796 `token-name, token-number' instead of the #define.
4797 (output_skeleton): Name this list `b4_tokens', not `b4_tokendefs'.
4798
47992002-03-14 Akim Demaille <akim@epita.fr>
4800
4801 Use Gettext 0.11.1.
4802
48032002-03-09 Robert Anisko <robert@lrde.epita.fr>
4804
4805 * data/bison.c++: Make the user able to add members to the generated
4806 parser by subclassing.
4807
48082002-03-05 Robert Anisko <robert@lrde.epita.fr>
4809
4810 * src/reader.c (read_additionnal_code): `c' should be an integer, not
4811 a character.
4812 Reported by Nicolas Tisserand and Nicolas Burrus.
4813
48142002-03-04 Robert Anisko <robert@lrde.epita.fr>
4815
4816 * src/reader.c: Warn about lacking semi-colons, do not complain.
4817
48182002-03-04 Robert Anisko <robert@lrde.epita.fr>
4819
4820 * data/bison.c++: Remove a debug line.
4821
48222002-03-04 Robert Anisko <robert@lrde.epita.fr>
4823
4824 * data/bison.c++: Unmerge value as yylval and value as yyval. Unmerge
4825 location as yylloc and location as yyloc. Use YYLLOC_DEFAULT, and
4826 provide a default implementation.
4827
48282002-03-04 Akim Demaille <akim@epita.fr>
4829
4830 * tests/input.at (Invalid $n, Invalid @n): Add the ending `;'.
4831 * tests/output.at (AT_CHECK_OUTPUT): Likewise.
4832 * tests/headers.at (AT_TEST_CPP_GUARD_H): Ditto.
4833 * tests/semantic.at (Parsing Guards): Similarly.
4834 * src/reader.at (readgram): Complain if the last rule is not ended
4835 with a semi-colon.
4836
48372002-03-04 Akim Demaille <akim@epita.fr>
4838
4839 * src/warshall.h, src/warshall.c (bitmatrix_print): Move to...
4840 * src/closure.c: here.
4841 (set_firsts): Use bitsetv_reflexive_transitive_closure instead of
4842 RTC.
4843 * src/warshall.h, src/warshall.c: Remove.
4844 * tests/sets.at (Broken Closure): Adjust.
4845
48462002-03-04 Akim Demaille <akim@epita.fr>
4847
4848 * src/output.c (output_skeleton): tempdir is const.
4849 bytes_read is unused.
4850
48512002-03-04 Akim Demaille <akim@epita.fr>
4852
4853 * lib/bbitset.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4854 * lib/bitsetv.h, lib/ebitset.c, lib/lbitset.c, lib/sbitset.c:
4855 Update.
4856 From Michael Hayes.
4857
48582002-03-04 Akim Demaille <akim@epita.fr>
4859
4860 * src/closure.c (closure): `r' is unused.
4861
48622002-03-04 Akim Demaille <akim@epita.fr>
4863
4864 * tests/sets.at (Broken Closure): Add the ending `;'.
4865 * src/reader.at (readgram): Complain if a rule is not ended with a
4866 semi-colon.
4867
48682002-03-04 Akim Demaille <akim@epita.fr>
4869
4870 * src/conflicts.c (set_conflicts): Use bitset_disjoint_p.
4871 (count_sr_conflicts): Use bitset_count.
4872 * src/reduce.c (inaccessable_symbols): Ditto.
4873 (bits_size): Remove.
4874 * src/warshall.h, src/warshall.c: Convert to bitsetv.
4875
48762002-03-04 Akim Demaille <akim@epita.fr>
4877
4878 * src/closure.c, src/conflicts.c, src/lalr.c, src/print.c,
4879 * src/reduce.c: Remove the `bitset_zero's following the
4880 `bitset_create's, as now it is performed by the latter.
4881
48822002-03-04 Akim Demaille <akim@epita.fr>
4883
4884 * lib/bitset.c, lib/bitset.h, lib/bitsetv.c, lib/bitsetv.h,
4885 * lib/ebitset.c, lib/ebitset.h, lib/lbitset.c, lib/lbitset.h,
4886 * lib/sbitset.c, lib/sbitset.h, lib/bbitset.h: Update from the
4887 latest sources from Michael.
4888
48892002-03-04 Akim Demaille <akim@epita.fr>
4890
4891 * src/output.c (output): Don't free the grammar.
4892 * src/reader.c (grammar_free): New.
4893 * src/main.c (main): Call it and don't free symtab here.
4894
48952002-03-04 Akim Demaille <akim@epita.fr>
4896
4897 * src/lex.c (parse_percent_token): Be sure to 0-end token_buffer
4898 before returning.
4899 Reported by Benoit Perrot.
4900
49012002-03-04 Akim Demaille <akim@epita.fr>
4902
4903 Use bitset operations when possible, not loops over bits.
4904
4905 * src/conflicts.c (set_conflicts, count_sr_conflicts): Use
4906 bitset_or.
4907 * src/print.c (print_reductions): Use bitset_and, bitset_andn.
4908 * src/reduce.c (useless_nonterminals): Formatting changes.
4909 * src/warshall.c (TC): Use bitset_or.
4910
49112002-03-04 Akim Demaille <akim@epita.fr>
4912
4913 * src/lalr.h, src/lalr.c (tokensetsize): Remove, unused.
4914 * src/system.h (BITS_PER_WORD, WORDSIZE, SETBIT, RESETBIT, BITISSET):
4915 Ditto.
4916
49172002-03-04 Akim Demaille <akim@epita.fr>
4918
4919 * src/lalr.c (F): Now a bitset*.
4920 Adjust all dependencies.
4921
49222002-03-04 Akim Demaille <akim@epita.fr>
4923
4924 * src/conflicts.c (shiftset, lookaheadset): Now bitset.
4925 Adjust all dependencies.
4926
49272002-03-04 Akim Demaille <akim@epita.fr>
4928
4929 * src/L0.c, src/LR0.h (nstates): Be size_t.
4930 Adjust comparisons (signed vs unsigned).
4931 * src/conflics.c, src/lalr.c, src/lalr.h, src/output.c (LA): Now a
4932 bitset*.
4933 Adjust all dependencies.
4934
49352002-03-04 Akim Demaille <akim@epita.fr>
4936
4937 * src/closure.c (firsts): Now, also a bitset.
4938 Adjust all dependencies.
4939 (varsetsize): Remove, now unused.
4940 * src/warshall.h, src/warshall.c: Now work on arrays of bitsets.
4941
49422002-03-04 Akim Demaille <akim@epita.fr>
4943
4944 * src/print.c: Convert to use bitset.h, not hand coded iterations
4945 over ints.
4946
49472002-03-04 Akim Demaille <akim@epita.fr>
4948
4949 * src/reduce.c: Convert to use bitset.h, not hand coded BSet.
4950
49512002-03-04 Akim Demaille <akim@epita.fr>
4952
4953 * src/closure.c (ruleset): Be a bitset.
4954 (rulesetsize): Remove.
4955
49562002-03-04 Akim Demaille <akim@epita.fr>
4957
4958 * lib/bitset-int.h, lib/bitset.c, lib/bitset.h, lib/bitsetv.c,
4959 * lib/bitsetv.h, lib/ebitset.c, lib/ebitset.h, lib/lbitset.c,
4960 * lib/lbitset.h, lib/sbitset.c, lib/sbitset.h: New.
4961 * src/closure.c (fderives): Be an array of bitsets.
4962
49632002-02-28 Robert Anisko <robert@lrde.epita.fr>
4964
4965 * data/bison.c++: Merge the two generated headers. Insert a copyright
4966 notice in each output file.
4967
49682002-02-28 Akim Demaille <akim@epita.fr>
4969
4970 * data/bison.c++: Copy the prologue of bison.simple to fetch
4971 useful M4 definitions, such as b4_header_guard.
4972
49732002-02-25 Akim Demaille <akim@epita.fr>
4974
4975 * src/getargs.c (version): Give the name of the authors, and use a
4976 translator friendly scheme for the bgr
4977 copyright notice.
4978
49792002-02-25 Akim Demaille <akim@epita.fr>
4980
4981 * src/output.c (header_output): Remove, now handled completely via
4982 M4.
4983
49842002-02-25 Akim Demaille <akim@epita.fr>
4985
4986 * m4/m4.m4: New, from CVS Autoconf.
4987 * configure.in: Invoke it.
4988 * src/output.c (output_skeleton): Use its result instead of the
4989 hard coded name.
4990
49912002-02-25 Akim Demaille <akim@epita.fr>
4992
4993 * lib/tempname.c, lib/mkstemp.c, m4/mkstemp.m4: New, stolen from
4994 Fileutils 4.1.5.
4995 * configure.in: Invoke UTILS_FUNC_MKSTEMP.
4996 * src/output.c (output_skeleton): Use mkstemp to create a real
4997 temporary file.
4998 Move the filling of `skeleton' and its muscle to...
4999 (prepare): here.
5000 (output): Move the definition of the prologue muscle to...
5001 (prepare): here.
5002 * src/system.h (DEFAULT_TMPDIR): New.
5003
50042002-02-14 Paul Eggert <eggert@twinsun.com>
5005
5006 Remove the support for C++ namespace cleanliness; it was
5007 causing more problems than it was curing, since it didn't work
5008 properly on some nonstandard C++ compilers. This can wait
5009 for a proper C++ parser.
5010
5011 * NEWS: Document this.
5012 * doc/bison.texinfo (Bison Parser, Debugging): Remove special mention
5013 of C++, as it's treated like C now.
5014 * src/bison.simple (YYSTD): Remove.
5015 (YYSIZE_T, YYFPRINTF, YYPARSE_PARAM_ARG, YYPARSE_PARAM_DECL):
5016 Treat C++ just like Standard C instead of trying to support
5017 namespace cleanliness.
5018
50192002-02-14 Akim Demaille <akim@epita.fr>
5020
5021 * tests/regression.at (else): Adjust to Andreas' change.
5022
50232002-02-14 Akim Demaille <akim@epita.fr>
5024
5025 * lib/Makefile.am (EXTRA_DIST): Ship strnlen.c.
5026
50272002-02-13 Andreas Schwab <schwab@suse.de>
5028
5029 * src/output.c (output_rule_data): Don't output NULL, it might
5030 not be defined yet.
5031
50322002-02-11 Robert Anisko <robert@lrde.epita.fr>
5033
5034 * data/bison.c++ (YYDEBUG, YYERROR_VERBOSE): After the prologue.
5035 (Copyright notice): Update.
5036
50372002-02-11 Akim Demaille <akim@epita.fr>
5038
5039 * tests/regression.at (%nonassoc and eof): Don't include
5040 nonportable headers.
5041
50422002-02-08 Robert Anisko <robert@lrde.epita.fr>
5043
5044 * data/bison.c++: Correct error recovery. Make the user able to
5045 initialize the starting location.
5046
50472002-02-07 Akim Demaille <akim@epita.fr>
5048
5049 * tests/input.at: New.
5050
50512002-02-07 Robert Anisko <robert@lrde.epita.fr>
5052
5053 * data/bison.c++: Replace some direct m4 expansions by constants. Be
5054 more consistent when naming methods and variables. Put preprocessor
5055 directives around tables only needed for debugging.
5056
50572002-02-07 Robert Anisko <robert@lrde.epita.fr>
5058
5059 * data/bison.c++ (yy::b4_name::print_): New method, replaces yyprint in
5060 C++ parsers.
5061 (yy::b4_name::parse): Use print_.
5062
50632002-02-07 Robert Anisko <robert@lrde.epita.fr>
5064
5065 * data/bison.c++ (yy::b4_name::parse): Error recovery is back.
5066
50672002-02-07 Robert Anisko <robert@lrde.epita.fr>
5068
5069 * data/bison.c++ (yy::b4_name::error_): New method, replaces yyerror in
5070 C++ parsers.
5071 (yy::b4_name::parse): Build verbose error messages, and use error_.
5072
50732002-02-06 Robert Anisko <robert@lrde.epita.fr>
5074
5075 * data/bison.c++: Fix m4 quoting in comments.
5076
50772002-02-06 Robert Anisko <robert@lrde.epita.fr>
5078
5079 * data/bison.c++: Adjust the parser code. Fix some muscles that were
5080 not expanded by m4.
5081
50822002-02-05 Akim Demaille <akim@epita.fr>
5083
5084 * data/bison.c++: Adjust to the M4 back end.
5085 More is certainly needed.
5086
50872002-02-05 Akim Demaille <akim@epita.fr>
5088
5089 Give a try to M4 as a back end.
5090
5091 * lib/readpipe.c: New, from wdiff.
5092 * src/Makefile.am (DEFS): Define PKGDATADIR, not BISON_SIMPLE and
5093 BISON_HAIRY.
5094 * src/system.h (BISON_HAIRY, BISON_SIMPLE): Remove the DOS and VMS
5095 specific values. Now it is m4 that performs the lookup.
5096 * src/parse-skel.y: Remove.
5097 * src/muscle_tab.c, src/muscle_tab.h (muscles_m4_output): New.
5098 * src/output.c (actions_output, guards_output)
5099 (token_definitions_output): No longer keeps track of the output
5100 line number, hence remove the second argument.
5101 (guards_output): Check against the guard member of a rule, not the
5102 action member.
5103 Adjust callers.
5104 (output_skeleton): Don't look for the skeleton location, let m4 do
5105 that.
5106 Create `/tmp/muscles.m4'. This is temporary, a proper temporary
5107 file will be used.
5108 Invoke `m4' on m4sugar.m4, muscles.m4, and the skeleton.
5109 (prepare): Given that for the time being changesyntax is not
5110 usable in M4, rename the muscles using `-' to `_'.
5111 Define `defines_flag', `output_parser_name' and `output_header_name'.
5112 * src/output.h (actions_output, guards_output)
5113 (token_definitions_output): Adjust prototypes.
5114 * src/scan-skel.l: Instead of scanning the skeletons, it now
5115 processes the output of m4: `__oline__' and `#output'.
5116 * data/bison.simple: Adjust to be used by M4(sugar).
5117 * tests/Makefile.am: Use check_SCRIPTS to make sure `bison' is up
5118 to date.
5119 * tests/bison.in: Use the secrete envvar `BISON_PKGDATADIR'
5120 instead of the dead `BISON_SIMPLE' and `BISON_HAIRY'.
5121 * data/m4sugar/m4sugar.m4, data/m4sugar/version.m4: New,
5122 shamelessly stolen from CVS Autoconf.
5123
51242002-02-05 Akim Demaille <akim@epita.fr>
5125
5126 * lib/hash.c, lib/hash.h: Replace with Fileutils 4.1's version.
5127 * configure.in: Check for the declarations of free and malloc.
5128 * src/muscle_tab.c: Adjust.
5129
51302002-02-05 Akim Demaille <akim@epita.fr>
5131
5132 * src/muscle_tab.c (muscle_init): Don't default to NULL muscle
5133 which have no values.
5134
51352002-02-05 Akim Demaille <akim@epita.fr>
5136
5137 * src/bison.simple, src/bison.hairy, src/bison.c++: Move to...
5138 * data/: here.
5139
51402002-01-29 Paul Eggert <eggert@twinsun.com>
5141
5142 * src/bison.simple (YYSIZE_T): Do not define merely because
5143 YYSTACK_USE_ALLOCA is nonzero or alloca or _ALLOCA_H are defined.
5144 On some platforms, <alloca.h> does not declare YYSTD (size_t).
5145
51462002-01-27 Akim Demaille <akim@epita.fr>
5147
5148 Fix `%nonassoc and eof'.
5149
5150 * src/state.c (errs_dup): Aaaah! The failure was due to bytes
5151 which were not properly copied! Replace
5152 memcpy (res->errs, src->errs, src->nerrs);
5153 with
5154 memcpy (res->errs, src->errs, src->nerrs * sizeof (src->errs[0]));
5155 !!!
5156 * tests/regression.at (%nonassoc and eof): Adjust to newest
5157 Autotest: `.' is not in the PATH.
5158
51592002-01-27 Akim Demaille <akim@epita.fr>
5160
5161 * tests/sets.at (AT_EXTRACT_SETS): New.
5162 (Nullable): Use it.
5163 (Firsts): New.
5164
51652002-01-26 Akim Demaille <akim@epita.fr>
5166
5167 * tests/actions.at, tests/calc.at, tests/headers.at,
5168 * tests/torture.at: Adjust to the newest Autotest which no longer
5169 forces `.' in the PATH.
5170
51712002-01-25 Akim Demaille <akim@epita.fr>
5172
5173 * tests/regression.at (%nonassoc and eof): New.
5174 Suggested by Robert Anisko.
5175
51762002-01-24 Akim Demaille <akim@epita.fr>
5177
5178 Bison dumps core when trying to complain about broken input files.
5179 Reported by Cris van Pelt.
5180
5181 * src/lex.c (parse_percent_token): Be sure to set token_buffer.
5182 * tests/regression.at (Invalid input: 1, Invalid input: 2): Merge
5183 into...
5184 (Invalid inputs): Strengthen: exercise parse_percent_token.
5185
51862002-01-24 Robert Anisko <robert.anisko@epita.fr>
5187
5188 * src/Makefile.am: Add bison.c++.
5189 * src/bison.c++: New skeleton.
5190
51912002-01-21 Paolo Bonzini <bonzini@gnu.org>
5192
5193 * po/it.po: New.
5194
51952002-01-21 Kees Zeelenberg <kzlg@users.sourceforge.net>
5196
5197 * src/files.c (skeleton_find) [MSDOS]: Fix cp definition.
5198
51992002-01-20 Marc Autret <marc@gnu.org>
5200
5201 * src/files.c (compute_output_file_names): Fix
5202
52032002-01-20 Marc Autret <marc@gnu.org>
5204
5205 * tests/output.at: New test.
5206 * src/files.c (compute_base_names): Don't map extensions when
5207 the YACC flag is set, use defaults.
5208 Reported by Evgeny Stambulchik.
5209
52102002-01-20 Marc Autret <marc@gnu.org>
5211
5212 * src/system.h: Need to define __attribute__ away for non-GCC
5213 compilers as well (i.e. the vendor C compiler).
5214 Suggested by Albert Chin-A-Young.
5215
52162002-01-11 Tim Van Holder <tim.van.holder@pandora.be>
5217
5218 * lib/hash.h, lib/hash.c: Renamed __P to PARAMS and used the
5219 canonical definition.
5220 * src/system.h: Use the canonical definition for PARAMS (avoids
5221 a conflict with the macro from lib/hash.h).
5222
52232002-01-11 Akim Demaille <akim@epita.fr>
5224
5225 * configure.in: Use AC_FUNC_STRNLEN.
5226 Fixes the failures observed on AIX 4.3 by H.Merijn Brand.
5227
52282002-01-09 Akim Demaille <akim@epita.fr>
5229
5230 * src/files.c, src/files.h (output_infix): New.
5231 (tab_extension): Remove.
5232 (compute_base_names): Compute the former, drop the latter.
5233 * src/output.c (prepare): Insert the muscles `output-infix', and
5234 `output-suffix'.
5235 * src/parse-skel.y (string, string.1): New.
5236 (section.header): Use it.
5237 (section.yacc): Remove.
5238 (prefix): Remove too.
5239 * src/scan-skel.l: Adjust.
5240 * src/bison.simple, src/bison.hairy: Adjust.
5241
52422002-01-09 Akim Demaille <akim@epita.fr>
5243
5244 * configure.in (WERROR_CFLAGS): Compute it.
5245 * src/Makefile.am (CFLAGS): Pass it.
5246 * tests/atlocal.in (CFLAGS): Idem.
5247 * src/files.c: Fix a few warnings.
5248 (get_extension_index): Remove, unused.
5249
52502002-01-08 Akim Demaille <akim@epita.fr>
5251
5252 * src/getargs.c (AS_FILE_NAME): New.
5253 (getargs): Use it to convert DOSish file names.
5254 * src/files.c (base_name): Rename as full_base_name to avoid
5255 clashes with `base_name ()'.
5256 (filename_split): New.
5257 (compute_base_names): N-th rewrite, using filename_split.
5258
52592002-01-08 Akim Demaille <akim@epita.fr>
5260
5261 * lib/basename.c, lib/dirname.h, lib/dirname.c, lib/memrchr.c:
5262 New, stolen from the Fileutils 4.1.
5263 * lib/Makefile.am (libbison_a_SOURCES): Adjust.
5264 * configure.in: Check for the presence of memrchr, and of its
5265 prototype.
5266
52672002-01-07 Tim Van Holder <tim.van.holder@pandora.be>
5268
5269 * lib/hash.h (__P): Added definition for this macro.
5270 * src/Makefile.am: Add parse-skel.c and scan-skel.c to
5271 BUILT_SOURCES, to ensure they are generated first.
5272 * src/parse-skel.y: Use YYERROR_VERBOSE instead of
5273 %error-verbose to allow bootstrapping with bison 1.30x.
5274
52752002-01-06 Akim Demaille <akim@epita.fr>
5276
5277 * src/reader.c (parse_braces): Don't fetch the next char, the
5278 convention is to fetch on entry.
5279 * tests/torture.at (GNU Cim Grammar): Reintroduce their weird
5280 'switch' without a following semicolon.
5281 * tests/regression.at (braces parsing): New.
5282
52832002-01-06 Akim Demaille <akim@epita.fr>
5284
5285 Bison is dead wrong in its RR conflict reports.
5286
5287 * tests/torture.at (GNU Cim Grammar): New.
5288 * src/conflicts.c (count_rr_conflicts): Fix.
5289
52902002-01-06 Akim Demaille <akim@epita.fr>
5291
5292 Creating package.m4 from configure.ac causes too many problems.
5293
5294 * tests/Makefile.am (package.m4): Create it by hand,
5295 AC_CONFIG_TESTDIR no longer does in the most recent CVS Autoconf.
5296
52972002-01-06 Akim Demaille <akim@epita.fr>
5298
5299 * src/Makefile.am (bison_SOURCES): Add parse-skel.h and
5300 skeleton.h.
5301
53022002-01-04 Paul Eggert <eggert@twinsun.com>
5303
5304 * doc/bison.texinfo (Debugging):
5305 Remove YYSTDERR; it's no longer defined or used.
5306 Also, s/cstdio.h/cstdio/.
5307
53082002-01-03 Akim Demaille <akim@epita.fr>
5309
5310 * tests/bison.in, tests/atlocal.in: Adjust to CVS Autoconf.
5311
53122002-01-03 Akim Demaille <akim@epita.fr>
5313
5314 * src/parse-skel.y (process_skeleton): Don't bind the parser's
5315 tracing code to --trace, wait for a better --trace option, with
5316 args.
5317
53182002-01-03 Akim Demaille <akim@epita.fr>
5319
5320 * src/bison.simple (YYSTDERR): Remove, replace `stderr'.
5321 The ISO C++ standard is extremely clear about it: stderr is
5322 considered a macro, not a regular symbol (see table 94 `Header
5323 <cstdio> synopsis', [lib.c.files] 27.8.2 C Library files).
5324 Therefore std:: does not apply to it. It still does with fprintf.
5325 Also, s/cstdio.h/cstdio/.
5326
53272002-01-03 Akim Demaille <akim@epita.fr>
5328
5329 * lib/quotearg.c: Use `#include "..."' instead of `#include <...>'
5330 for non system headers.
5331
53322002-01-02 Akim Demaille <akim@epita.fr>
5333
5334 Equip the skeleton chain with location tracking, runtime trace,
5335 pure parser and scanner.
5336
5337 * src/parse-skel.y: Request a pure parser, locations, and prefix
5338 renaming.
5339 (%union): Having several members with the same type does not help
5340 type mismatches, simplify.
5341 (YYPRINT, yyprint): New.
5342 (yyerror): ``Rename'' (there is a #define yyerror skel_error) as...
5343 (skel_error): this.
5344 Handle locations.
5345 * src/scan-skel.l: Adjust to these changes.
5346 * src/skeleton.h (LOCATION_RESET, LOCATION_LINES, LOCATION_STEP)
5347 (LOCATION_PRINT, skel_control_t): New.
5348
53492001-12-30 Akim Demaille <akim@epita.fr>
5350
5351 * src/parse-skel.y: Get rid of the shift/reduce conflict:
5352 replace `gb' with BLANKS.
5353 * src/scan-skel.l: Adjust.
5354
53552001-12-30 Akim Demaille <akim@epita.fr>
5356
5357 * src/system.h: We don't need nor want bcopy.
5358 Throw away MS-DOS crap: we don't need getpid.
5359 * configure.in: We don't need strndup. It was even causing
5360 problems: because Flex includes the headers *before* us,
5361 _GNU_SOURCE is not defined by config.h, and therefore strndup was
5362 not visible.
5363 * lib/xstrndup.c: New.
5364 * src/scan-skel.l: Use it.
5365 Be sure to initialize yylval.muscle member when scanning a MUSCLE.
5366 * src/parse-skel.y: Use %directives instead of #defines.
5367
53682001-12-30 Akim Demaille <akim@epita.fr>
5369
5370 * src/skeleton.h: New.
5371 * src/output.c (output_parser, output_master_parser): Remove, dead
5372 code.
5373 * src/output.h (get_lines_number, actions_output, guards_output)
5374 (token_definitions_output): Prototype them.
5375 * src/parse-skel.y: Add the license notice.
5376 Include output.h and skeleton.h.
5377 (process_skeleton): Returns void, and takes a single parameter.
5378 * src/scan-skel.l: Add the license notice.
5379 Include skeleton.h.
5380 Don't use %option yylineno: it seems that then Flex imagines
5381 REJECT has been used, and therefore it won't reallocate its
5382 buffers (which makes no other sense to me than a bug). It results
5383 in warnings for `unused: yy_flex_realloc'.
5384
53852001-12-30 Robert Anisko <robert.anisko@epita.fr>
5386
5387 * src/muscle_tab.h (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5388 (MUSCLE_INSERT_PREFIX): ...to there.
5389 * src/output.c (MUSCLE_INSERT_INT, MUSCLE_INSERT_STRING)
5390 (MUSCLE_INSERT_PREFIX): Move from here...
5391
5392 * src/bison.hairy: Add a section directive. Put braces around muscle
5393 names. This parser skeleton is still broken, but Bison should not
5394 choke on a bad muscle 'syntax'.
5395 * src/bison.simple: Add a section directive. Put braces around muscle
5396 names.
5397
5398 * src/files.h (strsuffix, stringappend): Add declarations.
5399 (tab_extension): Add declaration.
5400 (short_base_name): Add declaration.
5401
5402 * src/files.c (strsuffix, stringappend): No longer static. These
5403 functions are used in the skeleton parser.
5404 (tab_extension): New.
5405 (compute_base_names): Use the computations done in this function
5406 to guess if the generated parsers should have '.tab' in their
5407 names.
5408 (short_base_name): No longer static.
5409
5410 * src/output.c (output_skeleton): New.
5411 (output): Disable call to output_master_parser, and give a try to
5412 a new skeleton handling system.
5413 (guards_output, actions_output): No longer static.
5414 (token_definitions_output, get_lines_number): No longer static.
5415
5416 * configure.in: Use AM_PROG_LEX and AC_PROG_YACC.
5417
5418 * src/Makefile.am (bison_SOURCES): Add scan-skel.l and
5419 parse-skel.y.
5420
5421 * src/parse-skel.y: New file.
5422 * src/scan-skel.l: New file.
5423
54242001-12-29 Akim Demaille <akim@epita.fr>
5425
5426 %name-prefix is broken.
5427
5428 * src/files.c (spec_name_prefix): Initialize to NULL, not to "yy".
5429 Adjust all dependencies.
5430 * tests/headers.at (export YYLTYPE): Strengthen this test: use
5431 %name-prefix.
5432
5433 Renaming yylval but not yylloc is not consistent. Now we do.
5434
5435 * src/bison.simple: Prefix yylloc if used.
5436 * doc/bison.texinfo (Decl Summary): Document that.
5437
54382001-12-29 Akim Demaille <akim@epita.fr>
5439
5440 * doc/bison.texinfo: Promote `%long-directive' over
5441 `%long_directive'.
5442 Remove all references to fixed-output-files, yacc is enough.
5443
54442001-12-29 Akim Demaille <akim@epita.fr>
5445
5446 * src/bison.simple: Define YYDEBUG and YYERROR_VERBOSE *after* the
5447 user prologue. These are defaults.
5448 * tests/actions.at (Mid-rule actions): Make sure the user can
5449 define YYDEBUG and YYERROR_VERBOSE.
5450
54512001-12-29 Akim Demaille <akim@epita.fr>
5452
5453 * src/output.c (header_output): Don't forget to export YYLTYPE and
5454 yylloc.
5455 * tests/headers.at (export YYLTYPE): New, make sure it does.
5456 * tests/regression.at (%union and --defines, Invalid CPP headers):
5457 Move to...
5458 * tests/headers.at: here.
5459
54602001-12-29 Akim Demaille <akim@epita.fr>
5461
5462 * src/gram.h (rule_s): Member `assoc' is of type `associativity'.
5463
54642001-12-29 Akim Demaille <akim@epita.fr>
5465
5466 * tests/actions.at (Mid-rule actions): Output on a single line
5467 instead of several.
5468
54692001-12-29 Akim Demaille <akim@epita.fr>
5470
5471 * doc/bison.texinfo: Formatting changes.
5472
54732001-12-29 Akim Demaille <akim@epita.fr>
5474
5475 Don't store the token defs in a muscle, just be ready to output it
5476 on command. Now possible via `symbols'. Fixes a memory leak.
5477
5478 * src/output.c (token_definitions_output): New.
5479 (output_parser, header_output): Use it.
5480 * src/reader.c (symbols_save): Remove.
5481
54822001-12-29 Akim Demaille <akim@epita.fr>
5483
5484 * src/bison.simple: Do not provide a default for YYSTYPE and
5485 YYLTYPE before the user's prologue. Otherwise it's hardly... a
5486 default.
5487
54882001-12-29 Akim Demaille <akim@epita.fr>
5489
5490 Mid-rule actions are simply... ignored!
5491
5492 * src/reader.c (readgram): Be sure to attach mid-rule actions to
5493 the empty-rule associated to the dummy symbol, not to the host
5494 rule.
5495 * tests/actions.at (Mid-rule actions): New.
5496
54972001-12-29 Akim Demaille <akim@epita.fr>
5498
5499 Memory leak.
5500
5501 * src/reader.c (reader): Free grammar.
5502
55032001-12-29 Akim Demaille <akim@epita.fr>
5504
5505 Memory leak.
5506
5507 * src/LR0.c (new_itemsets): Don't allocate `shift_symbol' here,
5508 since it allocates it for each state, although only one is needed.
5509 (allocate_storage): Do it here.
5510
55112001-12-29 Akim Demaille <akim@epita.fr>
5512
5513 * src/options.h, src/options.c (create_long_option_table): Rename
5514 as...
5515 (long_option_table_new): this, with a clearer prototype.
5516 (percent_table): Remove, unused,
5517 * src/getargs.c (getargs): Adjust.
5518
55192001-12-29 Akim Demaille <akim@epita.fr>
5520
5521 * src/LR0.c, src/conflicts.c, src/lalr.c, src/lalr.h, src/output.c
5522 * src/print.c, src/print_graph.c, src/state.h: Rename state_table
5523 as states.
5524
55252001-12-29 Akim Demaille <akim@epita.fr>
5526
5527 * src/lalr.c (build_relations): Rename `states' as `states1'.
5528 Sorry, I don't understand exactly what it is, no better name...
5529
55302001-12-29 Akim Demaille <akim@epita.fr>
5531
5532 * src/closure.c, src/conflicts.c, src/derives.c, src/gram.c
5533 * src/gram.h, src/lalr.c, src/nullable.c, src/output.c, src/print.c
5534 * src/print_graph.c, src/reader.c, src/reduce.c: Rename rule_table
5535 as rules.
5536
55372001-12-29 Akim Demaille <akim@epita.fr>
5538
5539 * src/gram.c (rprec, rprecsym, rassoc): Remove, unused since long
5540 ago.
5541
55422001-12-29 Akim Demaille <akim@epita.fr>
5543
5544 * src/reader.c, src/reader.h (user_toknums): Remove.
5545 Adjust all users to use symbols[i]->user_token_number.
5546
55472001-12-29 Akim Demaille <akim@epita.fr>
5548
5549 * src/gram.c, src/gram.h (sprec, sassoc): Remove.
5550 Adjust all users to use symbols[i]->prec or ->assoc.
5551
55522001-12-29 Akim Demaille <akim@epita.fr>
5553
5554 * src/reader.c, src/reader.h (tags): Remove.
5555 Adjust all users to use symbols[i]->tag.
5556
55572001-12-29 Akim Demaille <akim@epita.fr>
5558
5559 * src/gram.h, src/gram.c (symbols): New, similar to state_table
5560 and rule_table.
5561 * src/reader.c (packsymbols): Fill this table.
5562 Drop sprec.
5563 * src/conflicts.c (resolve_sr_conflict): Adjust.
5564 * src/reduce.c (reduce_grammar): Adjust: just sort symbols, a
5565 single table.
5566 Use symbols[i]->tag instead of tags[i].
5567
55682001-12-29 Akim Demaille <akim@epita.fr>
5569
5570 * tests/calc.at (_AT_DATA_CALC_Y): Also use %union.
5571 In addition, put a comment in there, to replace...
5572 * tests/regression.at (%union and C comments): Remove.
5573
55742001-12-29 Akim Demaille <akim@epita.fr>
5575
5576 * tests/regression.at (Web2c Actions): Blindly move the actual
5577 output as expected output. The contents *seem* right to me, but I
5578 can't pretend reading perfectly parser tables... Nonetheless, all
5579 the other tests pass correctly, the table look OK, even though the
5580 presence of `$axiom' is to be noted: AFAICS it is useless (but
5581 harmless).
5582
55832001-12-29 Akim Demaille <akim@epita.fr>
5584
5585 * src/reader.c (readgram): Don't add the rule 0 if there were no
5586 rules read. In other words, add it _after_ having performed
5587 grammar sanity checks.
5588 Fixes the `tests/regression.at (Invalid input: 1)' Failure.
5589
55902001-12-29 Akim Demaille <akim@epita.fr>
5591
5592 * tests/regression.at (Web2c Report): Catch up: the rule 0 is now
5593 visible, and some states have now a different number.
5594
55952001-12-29 Akim Demaille <akim@epita.fr>
5596
5597 * src/reader.c (readgram): Bind the initial rule's lineno to that
5598 of the first rule.
5599 * tests/regression.at (Rule Line Numbers, Unresolved SR Conflicts):
5600 (Solved SR Conflicts): Adjust rule 0's line number.
5601
56022001-12-29 Akim Demaille <akim@epita.fr>
5603
5604 Fix the `GAWK Grammar' failure.
5605
5606 * src/LR0.c (final_state): Initialize to -1 so that we do compute
5607 the reductions of the first state which was mistakenly confused
5608 with the final state because precisely final_state was initialized
5609 to 0.
5610 * tests/sets.at (Nullable): Adjust: state 0 does have lookaheads,
5611 now noticed by Bison.
5612 * tests/regression.at (Rule Line Numbers): Adjust: state 0 does
5613 have a reduction on $default.
5614
56152001-12-29 Akim Demaille <akim@epita.fr>
5616
5617 * src/gram.c (ritem_print): Be sure to subtract 1 when displaying
5618 rule line numbers.
5619 * src/closure.c (print_closure): Likewise.
5620 * src/derives.c (print_derives): Likewise.
5621 * tests/sets.at (Nullable): Adjust: the rule numbers are correct
5622 now.
5623
56242001-12-29 Akim Demaille <akim@epita.fr>
5625
5626 * src/lalr.c (lookaheads_print): New.
5627 (lalr): Call it when --trace-flag.
5628 * tests/sets.at (Nullable): Adjust: when tracing, the lookaheads
5629 are dumped.
5630
56312001-12-29 Akim Demaille <akim@epita.fr>
5632
5633 * src/derives.c (print_derives): Be sure to use `>= 0', not `> 0',
5634 when walking through ritem, even via rule->rhs.
5635 * src/reduce.c (dump_grammar, useful_production, reduce_output)
5636 (useful_production, useless_nonterminals): Likewise.
5637 (reduce_grammar_tables): Likewise, plus update nritems.
5638 * src/nullable.c (set_nullable): Likewise.
5639 * src/lalr.c (build_relations): Likewise.
5640 * tests/sets.at (Nullable): Adjust.
5641 Fortunately, now, the $axiom is no longer nullable.
5642
56432001-12-29 Akim Demaille <akim@epita.fr>
5644
5645 * src/LR0.c (generate_states): Use nritems, not nitems, nor using
5646 the 0-sentinel.
5647 * src/gram.c (ritem_longest_rhs): Likewise.
5648 * src/reduce.c (nonterminals_reduce): Likewise.
5649 * src/print_graph.c (print_graph): Likewise.
5650 * src/output.c (output_rule_data): Likewise.
5651 * src/nullable.c (set_nullable): Likewise.
5652
56532001-12-29 Akim Demaille <akim@epita.fr>
5654
5655 * src/output.c: Comment changes.
5656
56572001-12-27 Paul Eggert <eggert@twinsun.com>
5658
5659 * src/bison.simple (YYSTACK_ALLOC, YYSIZE_T): Remove special
5660 cases for non-GNU systems like AIX, HP-UX, SGI, Sun, and
5661 Sparc, as they were causing more porting problems than the
5662 (minor) performance improvement was worth.
5663
5664 Also, catch up with 1.31's YYSTD.
5665
56662001-12-27 Akim Demaille <akim@epita.fr>
5667
5668 * src/output.c (output_gram): Rely on nritems, not the
5669 0-sentinel. See below.
5670 Use -1 as separator, not 0.
5671 * src/bison.simple (yyparse): Subtract 1 to the rule numbers.
5672 Rely on -1 as separator in yyrhs, instead of 0.
5673 * tests/calc.at (AT_CHECK_CALC): Now, the parsers no longer issue
5674 twice `Now at end of input', therefore there are two lines less to
5675 expect.
5676
56772001-12-27 Akim Demaille <akim@epita.fr>
5678
5679 * tests/regression.at (Unresolved SR Conflicts):
5680 (Solved SR Conflicts, Rule Line Numbers): Adjust to the changes
5681 below.
5682
56832001-12-27 Akim Demaille <akim@epita.fr>
5684
5685 * src/LR0.c (new_state): Recognize the final state by the fact it
5686 is reached by eoftoken.
5687 (insert_start_shifting_state, insert_eof_shifting_state)
5688 (insert_accepting_state, augment_automaton): Remove, since now
5689 these states are automatically computed from the initial state.
5690 (generate_states): Adjust.
5691 * src/print.c: When reporting a rule number to the user, substract
5692 1, so that the axiom rule is rule 0, and the first user rule is 1.
5693 * src/reduce.c: Likewise.
5694 * src/print_graph.c (print_core): For the time being, just as for
5695 the report, depend upon --trace-flags to dump the full set of
5696 items.
5697 * src/reader.c (readgram): Once the grammar read, insert the rule
5698 0: `$axiom: START-SYMBOL $'.
5699 * tests/set.at: Adjust: rule 0 is now displayed, and since the
5700 number of the states has changed (the final state is no longer
5701 necessarily the last), catch up.
5702
57032001-12-27 Akim Demaille <akim@epita.fr>
5704
5705 Try to make the use of the eoftoken valid. Given that its value
5706 is 0 which was also used as a sentinel in ritem, (i) make sure >= 0
5707 is used instead of > 0 where appropriate, (ii), depend upon nritems
5708 instead of the 0-sentinel.
5709
5710 * src/gram.h, src/gram.c (nritems): New.
5711 Expected to be duplication of nitems, but for the time being...
5712 * src/reader.c (packgram): Assert nritems and nitems are equal.
5713 * src/LR0.c (allocate_itemsets, new_itemsets): Adjust.
5714 * src/closure.c (print_closure, print_fderives): Likewise.
5715 * src/gram.c (ritem_print): Likewise.
5716 * src/print.c (print_core, print_grammar): Likewise.
5717 * src/print_graph.c: Likewise.
5718
57192001-12-27 Akim Demaille <akim@epita.fr>
5720
5721 * src/main.c (main): If there are complains after grammar
5722 reductions, then output the report anyway if requested, then die.
5723 * src/symtab.c (bucket_new): Initialize `value' to -1, not 0.
5724 * src/reader.c (eoftoken): New.
5725 (parse_token_decl): If the token being defined has value `0', it
5726 is the eoftoken.
5727 (packsymbols): No longer hack `tags' to insert `$' by hand.
5728 Be sure to preserve the value of the eoftoken.
5729 (reader): Make sure eoftoken is defined.
5730 Initialize nsyms to 0: now eoftoken is created just like the others.
5731 * src/print.c (print_grammar): Don't special case the eof token.
5732 * src/regression.at: Adjust: `$' has value 0, not -1, which was a
5733 lie anyway, albeit pleasant.
5734 * tests/calc.at: Exercise error messages with eoftoken.
5735 Change the grammar so that empty input is invalid.
5736 Adjust expectations.
5737 When yyungeting, be sure to use a valid yylloc: use last_yylloc.
5738
57392001-12-27 Akim Demaille <akim@epita.fr>
5740
5741 * configure.in: Check the protos of strchr ans strspn.
5742 Replace strchr if needed.
5743 * src/system.h: Provide the protos of strchr, strspn and memchr if
5744 missing.
5745 * lib/strchr.c: New.
5746 * src/reader.c (symbols_save): Use strchr.
5747
57482001-12-27 Akim Demaille <akim@epita.fr>
5749
5750 * src/print.c, src/print_graph.c (escape): New.
5751 Use it to quote the TAGS outputs.
5752 * src/print_graph.c (print_state): Now errors are in red, and
5753 reductions in green.
5754 Prefer high to wide: output the state number on a line of its own.
5755
57562001-12-27 Akim Demaille <akim@epita.fr>
5757
5758 * src/state.h, src/state.c (reductions_new): New.
5759 * src/LR0.c (set_state_table): Let all the states have a
5760 `reductions', even if reduced to 0.
5761 (save_reductions): Adjust.
5762 * src/lalr.c (initialize_LA, initialize_lookaheads): Adjust.
5763 * src/print.c (print_reductions, print_actions): Adjust.
5764 * src/output.c (action_row): Adjust.
5765
57662001-12-27 Akim Demaille <akim@epita.fr>
5767
5768 * src/state.h, src/state.c (errs_new, errs_dup): New.
5769 * src/LR0.c (set_state_table): Let all the states have an errs,
5770 even if reduced to 0.
5771 * src/print.c (print_errs, print_reductions): Adjust.
5772 * src/output.c (output_actions, action_row): Adjust.
5773 * src/conflicts.c (resolve_sr_conflict): Adjust.
5774
57752001-12-27 Akim Demaille <akim@epita.fr>
5776
5777 * src/lalr.c (set_goto_map, initialize_F): Use SHIFT_SYMBOL.
5778
57792001-12-27 Akim Demaille <akim@epita.fr>
5780
5781 * src/conflicts.c, src/conflicts.h (print_reductions): Move to...
5782 * src/print.c: here.
5783 (lookaheadset, shiftset): New, used as additional storage by
5784 print_reductions.
5785 (print_results): Adjust.
5786 (print_shifts, print_gotos, print_errs): New, extracted from...
5787 (print_actions): here.
5788 * src/print_graph.c (print_actions): Remove dead code.
5789
57902001-12-27 Akim Demaille <akim@epita.fr>
5791
5792 * src/reader.c (copy_dollar, copy_at): Better checking of `n' in
5793 `$n' and `@n'.
5794
57952001-12-27 Akim Demaille <akim@epita.fr>
5796
5797 * src/lalr.c (add_lookback_edge): Use state_t instead of ints.
5798 (build_relations): Adjust.
5799
58002001-12-27 Akim Demaille <akim@epita.fr>
5801
5802 * src/lalr.c (set_goto_map): Remove a wrong but benign loop
5803 duplication.
5804
58052001-12-27 Akim Demaille <akim@epita.fr>
5806
5807 * src/reader.c (packgram): Catch nitems overflows.
5808
58092001-12-27 Akim Demaille <akim@epita.fr>
5810
5811 * src/files.c, src/files.h (guard_obstack): Remove.
5812 * src/output.c (output): Adjust.
5813 * src/reader.c (parse_braces): New, factoring...
5814 (copy_action, copy_guard): these two which are renamed as...
5815 (parse_action, parse_guard): these.
5816 As a voluntary consequence, using braces around guards is now
5817 mandatory.
5818
58192001-12-27 Akim Demaille <akim@epita.fr>
5820
5821 * src/gram.h (rule_t): `guard' and `guard_line' are new members.
5822 * src/reader.c (symbol_list): `guard' and `guard_line' are new
5823 members.
5824 (symbol_list_new): Adjust.
5825 (copy_action): action_line is the first line, not the last.
5826 (copy_guard): Just as for actions, store the `action' only, not
5827 the switch/case/break flesh.
5828 Don't parse the user action that might follow the guard, let...
5829 (readgram): do it, i.e., now, there can be an action after a
5830 guard.
5831 In other words the guard is just explicitly optional.
5832 (packgram): Adjust.
5833 * src/output.c (guards_output): New.
5834 (output_parser): Call it when needed.
5835 (output): Also free the guard and attrs obstacks.
5836 * src/files.c, src/files.h (obstack_save): Remove.
5837 (output_files): Remove.
5838 As a result, if one needs the former `.act' file, using an
5839 appropriate skeleton which requires actions and guards is now
5840 required.
5841 * src/main.c (main): Adjust.
5842 * tests/semantic.at: New.
5843 * tests/regression.at: Use `input.y' as input file name.
5844 Avoid 8+3 problems by requiring input.c when the test needs the
5845 parser.
5846
58472001-12-27 Akim Demaille <akim@epita.fr>
5848
5849 * src/reader.c (symbol_list_new): Be sure to initialize all the
5850 fields.
5851
58522001-12-27 Akim Demaille <akim@epita.fr>
5853
5854 All the hacks using a final pseudo state are now useless.
5855
5856 * src/LR0.c (set_state_table): state_table holds exactly nstates.
5857 * src/lalr.c (nLA): New.
5858 (initialize_LA, compute_lookaheads, initialize_lookaheads): Use it
5859 instead of lookaheadsp from the pseudo state (nstate + 1).
5860
58612001-12-27 Akim Demaille <akim@epita.fr>
5862
5863 * src/output.c (action_row, token_actions): Use a state_t instead
5864 of a integer, and nlookaheads instead of the following state's
5865 lookaheadsp.
5866
58672001-12-27 Akim Demaille <akim@epita.fr>
5868
5869 * src/conflicts.c (log_resolution, flush_shift)
5870 (resolve_sr_conflict, set_conflicts, solve_conflicts)
5871 (count_sr_conflicts, count_rr_conflicts, conflicts_output)
5872 (conflicts_print, print_reductions): Use a state_t instead of an
5873 integer when referring to a state.
5874 As much as possible, depend upon nlookaheads, instead of the
5875 `lookaheadsp' member of the following state (since lookaheads of
5876 successive states are successive, the difference between state n + 1
5877 and n served as the number of lookaheads for state n).
5878 * src/lalr.c (add_lookback_edge): Likewise.
5879 * src/print.c (print_core, print_actions, print_state)
5880 (print_results): Likewise.
5881 * src/print_graph.c (print_core, print_actions, print_state)
5882 (print_graph): Likewise.
5883 * src/conflicts.h: Adjust.
5884
58852001-12-27 Akim Demaille <akim@epita.fr>
5886
5887 * src/bison.hairy: Formatting/comment changes.
5888 ANSIfy.
5889 Remove `register' indications.
5890 Add plenty of `static'.
5891
58922001-12-27 Akim Demaille <akim@epita.fr>
5893
5894 * src/output.c (prepare): Drop the muscle `ntbase' which
5895 duplicates ntokens.
5896 * src/bison.simple: Formatting/comment changes.
5897 Use YYNTOKENS only, which is documented, but not YYNTBASE, which
5898 is an undocumented synonym.
5899
59002001-12-22 Akim Demaille <akim@epita.fr>
5901
5902 * src/output.c (output_table_data): Change the prototype to use
5903 `int' for array ranges: some invocations do pass an int, not a
5904 short.
5905 Reported by Wayne Green.
5906
59072001-12-22 Akim Demaille <akim@epita.fr>
5908
5909 Some actions of web2c.y are improperly triggered.
5910 Reported by Mike Castle.
5911
5912 * src/lalr.c (traverse): s/F (i)[k] = F (j)[k]/F (j)[k] = F (i)[k]/.
5913 * tests/regression.at (Web2c): Rename as...
5914 (Web2c Report): this.
5915 (Web2c Actions): New.
5916
59172001-12-22 Akim Demaille <akim@epita.fr>
5918
5919 Reductions in web2c.y are improperly reported.
5920 Reported by Mike Castle.
5921
5922 * src/conflicts.c (print_reductions): Fix.
5923 * tests/regression.at (Web2c): New.
5924
59252001-12-18 Akim Demaille <akim@epita.fr>
5926
5927 Some host fail on `assert (!"foo")', which expands to
5928 ((!"foo") ? (void)0 : __assert("!"foo."", __FILE__, __LINE__))
5929 Reported by Nelson Beebee.
5930
5931 * src/output.c, src/vcg.c: Replace `assert (!"it succeeded")' with
5932 `#define it_succeeded 0' and `assert (it_succeeded)'.
5933
59342001-12-17 Marc Autret <autret_m@epita.fr>
5935
5936 * src/bison.simple: Don't hard code the skeleton line and filename.
5937 * src/output.c (output_parser): Rename 'line' as 'output_line'.
5938 New line counter 'skeleton_line' (skeleton-line muscle).
5939
59402001-12-17 Paul Eggert <eggert@twinsun.com>
5941
5942 * NEWS, doc/bison.texinfo, doc/bison.1, doc/bison.rnh: Document that
5943 YYDEBUG must be defined to a nonzero value.
5944
5945 * src/bison.simple (yytname): Do not assume that the user defines
5946 YYDEBUG to a properly parenthesized expression.
5947
59482001-12-17 Akim Demaille <akim@epita.fr>
5949
5950 * src/state.h (state_t): Rename lookaheads as lookaheadsp.
5951 nlookaheads is a new member.
5952 Adjust all users.
5953 * src/lalr.h (nlookaheads): Remove this orphan declaration.
5954 * src/lalr.c (initialize_lookaheads): Set nlookaheads for each
5955 state.
5956
59572001-12-17 Akim Demaille <akim@epita.fr>
5958
5959 * src/files.h, src/files.c (open_files, close_files): Remove.
5960 * src/main.c (main): Don't open/close files, nor invoke lex_free,
5961 let...
5962 * src/reader.c (reader): Do it.
5963
59642001-12-17 Akim Demaille <akim@epita.fr>
5965
5966 * src/conflicts.c (print_reductions): Formatting changes.
5967
59682001-12-17 Akim Demaille <akim@epita.fr>
5969
5970 * src/conflicts.c (flush_shift): Also adjust lookaheadset.
5971 (flush_reduce): New.
5972 (resolve_sr_conflict): Adjust.
5973
59742001-12-17 Akim Demaille <akim@epita.fr>
5975
5976 * src/output.c (output_obstack): Be static and rename as...
5977 (format_obstack): this, to avoid any confusion with files.c's
5978 output_obstack.
5979 * src/reader.h (muscle_obstack): Move to...
5980 * src/output.h: here, since it's defined in output.c.
5981
59822001-12-17 Akim Demaille <akim@epita.fr>
5983
5984 * src/output.c (action_row, save_column, default_goto)
5985 (sort_actions, matching_state, pack_vector): Better variable
5986 locality.
5987
59882001-12-17 Akim Demaille <akim@epita.fr>
5989
5990 * src/output.c: Various formatting changes.
5991
59922001-12-17 Akim Demaille <akim@epita.fr>
5993
5994 * src/files.c (output_files): Free the output_obstack.
5995 * src/main.c (main): Call print and print_graph conditionally.
5996 * src/print.c (print): Work unconditionally.
5997 * src/print_graph.c (print_graph): Work unconditionally.
5998 * src/conflicts.c (log_resolution): Output only if verbose_flag.
5999
60002001-12-16 Marc Autret <autret_m@epita.fr>
6001
6002 * src/output.c (actions_output): Fix. When we use %no-lines,
6003 there is one less line per action.
6004
60052001-12-16 Marc Autret <autret_m@epita.fr>
6006
6007 * src/bison.simple: Remove a useless #line directive.
6008 s/#line %%line %%skeleton/#line %%line "%%parser-file-name"/'.
6009 * src/output.c (get_lines_number): New.
6010 (output_parser): Adjust, now takes care about the lines of a
6011 output muscles.
6012 Fix line numbering.
6013 (actions_output): Computes the number of lines taken by actions.
6014 (output_master_parser): Insert new skeleton which is the name of
6015 the output parser file name.
6016
60172001-12-15 Marc Autret <autret_m@epita.fr>
6018
6019 * src/bison.simple [YYERROR_VERBOSE]: Restore backward compatibility.
6020
60212001-12-15 Marc Autret <autret_m@epita.fr>
6022
6023 * src/output.c (output_gram): Keep track of the hairy one.
6024
60252001-12-15 Akim Demaille <akim@epita.fr>
6026
6027 Make `make distcheck' work.
6028
6029 * lib/Makefile.am (INCLUDES): Add top_srcdir/intl, since hash uses
6030 system.h which uses libgettext.h.
6031
60322001-12-15 Akim Demaille <akim@epita.fr>
6033
6034 * src/nullable.c (set_nullable): Useless rules must be skipped,
6035 otherwise, since we range over their symbols, we might look at a
6036 nonterminal which no longer ``exists'', i.e., it is not counted in
6037 `nvars', hence we overflow our arrays.
6038
60392001-12-15 Akim Demaille <akim@epita.fr>
6040
6041 The header can also be produced directly, without any obstack!
6042 Yahoo!
6043
6044 * src/files.c, src/files.h (defines_obstack): Remove.
6045 (compute_header_macro): Global.
6046 (defines_obstack_save): Remove.
6047 * src/reader.c (parse_union_decl): No longer output to
6048 defines_obstack: its content can be found in the `stype' muscle
6049 anyway.
6050 (output_token_translations): Merge into...
6051 (symbols_output): this.
6052 Rename as...
6053 (symbols_save): this.
6054 (reader): Adjust.
6055 * src/output.c (header_output): New.
6056 (output): Call it.
6057
60582001-12-15 Akim Demaille <akim@epita.fr>
6059
6060 * src/reader.c (parse_union_decl): Instead of handling two obstack
6061 simultaneously, use one to define the `stype' muscle, and use the
6062 value of the latter to fill defines_obstack.
6063 (copy_comment): Remove.
6064 (copy_comment2): Work for a single obstack.
6065 Rename as...
6066 (copy_comment): this.
6067
60682001-12-15 Akim Demaille <akim@epita.fr>
6069
6070 * src/lex.c, src/lex.h (xgetc): No longer static.
6071 * src/reader.c (parse_union_decl): Revamp.
6072
60732001-12-15 Akim Demaille <akim@epita.fr>
6074
6075 Still making progress in separating Bison into (i) input, (ii)
6076 process, (iii) output: now we can directly output the parser file
6077 without using table_obstack at all.
6078
6079 * src/files.c, src/files.h (table_obstack): Bye bye.
6080 (parser_file_name): New.
6081 * src/files.c (compute_output_file_names): Compute it.
6082 * src/output.c (actions_output, output_parser)
6083 (output_master_parser): To a file instead of an obstack.
6084
60852001-12-15 Akim Demaille <akim@epita.fr>
6086
6087 Attach actions to rules, instead of pre-outputting them to
6088 actions_obstack.
6089
6090 * src/gram.h (rule_t): action and action_line are new members.
6091 * src/reader.c (symbol_list): Likewise.
6092 (copy_action): Save the actions within the rule.
6093 (packgram): Save them in rule_table.
6094 * src/output.c (actions_output): New.
6095 (output_parser): Use it on `%%actions'.
6096 (output_rule_data): Don't free rule_table.
6097 (output): Do it.
6098 (prepare): Don't save the `action' muscle.
6099 * src/bison.simple: s/%%action/%%actions/.
6100
61012001-12-15 Akim Demaille <akim@epita.fr>
6102
6103 * src/reader.c (copy_action): When --yacc, don't append a `;'
6104 to the user action: let it fail if lacking.
6105 Suggested by Arnold Robbins and Tom Tromey.
6106
61072001-12-14 Akim Demaille <akim@epita.fr>
6108
6109 * src/lex.c (literalchar): Simply return the char you decoded, non
6110 longer mess around with obstacks and int pointers.
6111 Adjust all callers.
6112
61132001-12-14 Akim Demaille <akim@epita.fr>
6114
6115 * src/lex.c (literalchar): Don't escape the special characters,
6116 just decode them, and keep them as char (before, eol was output as
6117 the 2 char string `\n' etc.).
6118 * src/output.c (output_rule_data): Use quotearg to output the
6119 token strings.
6120
61212001-12-13 Paul Eggert <eggert@twinsun.com>
6122
6123 * src/bison.simple (YYSIZE_T, YYSTACK_ALLOC, YYSTACK_FREE):
6124 Do not infringe on the global user namespace when using C++.
6125 (YYFPRINTF, YYSTDERR): New macros, needed for the above.
6126 All uses of `fprintf' and `stderr' changed.
6127
6128 * doc/bison.texinfo: Document YYFPRINTF, YYSTDERR.
6129
61302001-12-13 Akim Demaille <akim@epita.fr>
6131
6132 The computation of nullable is broken: it doesn't handle empty
6133 RHS's properly.
6134
6135 * tests/torture.at (GNU AWK Grammar): New.
6136 * tests/sets.at (Nullable): New.
6137 * src/nullable.c (set_nullable): Instead of blindly looping over
6138 `ritems', loop over the rules, and then over their rhs's.
6139
6140 Work around Autotest bugs.
6141
6142 * src/warshall.c (bitmatrix_print): Don't use `+--+' as table
6143 frame, because Autotest understand lines starting with a `+' as
6144 traces from the shell. Then, they are not processed properly.
6145 Admittedly an Autotest bug, but we don't have time to wait for
6146 Autotest to catch up.
6147 * tests/regression.at (Broken Closure): Adjust to the new table
6148 frames.
6149 Move to...
6150 * tests/sets.at: here.
6151
61522001-12-13 Akim Demaille <akim@epita.fr>
6153
6154 * src/closure.c (closure): Use nrules instead of playing tricks
6155 with BITS_PER_WORD.
6156
61572001-12-13 Akim Demaille <akim@epita.fr>
6158
6159 * src/print.c (print_actions): Output the handling of `$' as the
6160 traces do: shifting the token EOF. Before EOF was treated as a
6161 nonterminal.
6162 * tests/regression.at: Adjust some tests.
6163 * src/print_graph.c (print_core): Complete the set of items via
6164 closure. The next-to-final and final states are still unsatisfying,
6165 but that's to be addressed elsewhere.
6166 No longer output the rule numbers, but do output the state number.
6167 A single loop for the shifts + gotos is enough, but picked a
6168 distinct color for each.
6169 (print_graph): Initialize and finalize closure.
6170
61712001-12-13 Akim Demaille <akim@epita.fr>
6172
6173 * src/reader.c (readgram): Remove dead code, an strip useless
6174 braces.
6175 (get_type): Remove, unused.
6176
61772001-12-12 Akim Demaille <akim@epita.fr>
6178
6179 * src/complain.h, src/complain.c: Remove error_one_per_line, rely
6180 on that of lib/error.c.
6181
61822001-12-12 Akim Demaille <akim@epita.fr>
6183
6184 Some hosts don't like `/' in includes.
6185
6186 * src/system.h: Include libgettext.h without qualifying the path.
6187 * src/Makefile.am (INCLUDES): Add $(top_srcdir)/intl, remove
6188 $(top_srcdir).
6189
61902001-12-11 Marc Autret <autret_m@epita.fr>
6191
6192 * src/output.c (output_parser): Remove useless muscle.
6193
61942001-12-11 Marc Autret <autret_m@epita.fr>
6195
6196 * src/bison.simple: Remove #line just before %%epilogue. It
6197 is now handled in ...
6198 * src/reader.c (read_additionnal_code): Add the output of a
6199 #line for the epilogue.
6200
62012001-12-10 Marc Autret <autret_m@epita.fr>
6202
6203 * src/reader.c (copy_definition): Re-use CPP-outed code which
6204 replace precedent remove.
6205 * src/bison.simple: Remove #line before %%prologue because
6206 %%input-line is wrong at this time.
6207
62082001-12-10 Marc Autret <autret_m@epita.fr>
6209
6210 * src/reader.c (symbols_output): Clean up.
6211 * src/output.c (output_gram, output): Clean up.
6212
62132001-12-10 Akim Demaille <akim@epita.fr>
6214
6215 * src/lalr.c (initialize_lookaheads): New. Extracted from...
6216 * src/LR0.c (set_state_table): here.
6217 * src/lalr.c (lalr): Call it.
6218
62192001-12-10 Akim Demaille <akim@epita.fr>
6220
6221 * src/state.h (shifts): Remove the `number' member: shifts are
6222 attached to state, hence no longer need to be labelled with a
6223 state number.
6224
62252001-12-10 Akim Demaille <akim@epita.fr>
6226
6227 Now that states have a complete set of members, the linked list of
6228 shifts is useless: just fill directly the state's shifts member.
6229
6230 * src/state.h (shifts): Remove the `next' member.
6231 * src/LR0.c (first_state, last_state): Remove.
6232 Adjust the callers.
6233 (augment_automaton): Don't look for the shifts that must be added
6234 a shift on EOF: it is those of the state we looked for! But now,
6235 since shifts are attached, it is no longer needed to looking
6236 merely by its id: its number.
6237
62382001-12-10 Akim Demaille <akim@epita.fr>
6239
6240 * src/LR0.c (augment_automaton): Better variable locality.
6241 Remove an impossible branch: if there is a state corresponding to
6242 the start symbol being shifted, then there is shift for the start
6243 symbol from the initial state.
6244
62452001-12-10 Akim Demaille <akim@epita.fr>
6246
6247 * src/LR0.c (augment_automaton): Call `insert_eof_shifting_state'
6248 only when appropriate: when insert_start_shifting_state' is not
6249 invoked.
6250 * tests/regression.at (Rule Line Numbers): Adjust.
6251
62522001-12-10 Akim Demaille <akim@epita.fr>
6253
6254 * src/LR0.c (augment_automaton): Now that all states have shifts,
6255 merge the two cases addition shifts to the initial state.
6256
62572001-12-10 Akim Demaille <akim@epita.fr>
6258
6259 * src/lalr.c (set_state_table): Move to...
6260 * src/LR0.c: here.
6261 * src/lalr.c (lalr): Don't call it...
6262 * src/LR0.c (generate_states): do it.
6263 * src/LR0.h (first_state): Remove, only the table is used.
6264
62652001-12-10 Akim Demaille <akim@epita.fr>
6266
6267 * src/LR0.h (first_shift, first_reduction): Remove.
6268 * src/lalr.c: Don't use first_shift: find shifts through the
6269 states.
6270
62712001-12-10 Akim Demaille <akim@epita.fr>
6272
6273 * src/LR0.c: Attach shifts to states as soon as they are
6274 computed.
6275 * src/lalr.c (set_state_table): Instead of assigning shifts to
6276 state, just assert that the mapping was properly done.
6277
62782001-12-10 Akim Demaille <akim@epita.fr>
6279
6280 * src/LR0.c (insert_start_shift): Rename as...
6281 (insert_start_shifting_state): this.
6282 (insert_eof_shifting_state, insert_accepting_state): New.
6283 (augment_automaton): Adjust.
6284 Better locality of the variables.
6285 When looking if the start_symbol is shifted from the initial
6286 state, using `while (... symbol != start_symbol ...)' sounds
6287 better than `while (... symbol < start_symbol ...)': If fail
6288 to see how the order between symbols could be relevant!
6289
62902001-12-10 Akim Demaille <akim@epita.fr>
6291
6292 * src/getargs.h: Don't declare `spec_name_prefix' and
6293 `spec_file_prefix', declared by src/files.h.
6294 * src/files.c, src/files.h: Default for spec_name_prefix is "yy".
6295 * src/muscle_tab.c (muscle_init): Default prefix to NULL.
6296 * src/output.c (prepare): Adjust.
6297 * src/reader.c (symbols_output): Likewise.
6298 * src/vmsgetargs.c: Vaguely adjust, but who cares?
6299
63002001-12-10 Akim Demaille <akim@epita.fr>
6301
6302 * src/muscle_tab.c (muscle_init): NULL is a better default than
6303 `"0"'.
6304
63052001-12-10 Akim Demaille <akim@epita.fr>
6306
6307 * src/reader.c (reader): Calling symbols_output once is enough.
6308
63092001-12-10 Akim Demaille <akim@epita.fr>
6310
6311 Now that states have a complete set of members, the linked list of
6312 reductions is useless: just fill directly the state's reductions
6313 member.
6314
6315 * src/state.h (struct reductions): Remove member `number' and
6316 `next'.
6317 * src/LR0.c (first_reduction, last_reduction): Remove.
6318 (save_reductions): Don't link the new reductions, store them in
6319 this_state.
6320 * src/lalr.c (set_state_table): No need to attach reductions to
6321 states, it's already done.
6322 * src/output.c (output_actions): No longer free the shifts, then
6323 the reductions, then the states: free all the states and their
6324 members.
6325
63262001-12-10 Akim Demaille <akim@epita.fr>
6327
6328 * src/options.c (OPTN, DRTV, BOTH): New.
6329 (option_table): Use them.
6330
6331 * src/muscle_tab.c: Don't include xalloc.h and string.h: that's
6332 the job of system.h.
6333 * src/options.c: Don't include stdio.h and xalloc.h for the same
6334 reasons.
6335
63362001-12-10 Akim Demaille <akim@epita.fr>
6337
6338 * src/output.c (output, prepare): Make sure the values of the
6339 muscles `action' and `prologue' are 0-terminated.
6340
63412001-12-10 Akim Demaille <akim@epita.fr>
6342
6343 Clean up GCC warnings.
6344
6345 * src/reader.c (copy_action): `buf' is not used.
6346 (parse_skel_decl): Be static.
6347 * src/muscle_tab.c (mhash1, mhash2, muscle_insert): Preserve `const'.
6348 * src/options.h (create_long_option_table): Have a real prototype.
6349 * lib/hash.c, lib/hash.h (hash_insert, hash_insert_at, hash_delete)
6350 (hash_delete_at): Return const void *.
6351 Adjust casts to preserve the const.
6352
63532001-12-10 Akim Demaille <akim@epita.fr>
6354
6355 * configure.in: Require 2.52g.
6356 M4 is not needed, but AUTOM4TE is.
6357 * m4/m4.m4: Remove.
6358 * tests/Makefile.am: Adjust.
6359
63602001-12-10 Akim Demaille <akim@epita.fr>
6361
6362 One structure for states is enough, even though theoretically
6363 there are LR(0) states and LALR(1) states.
6364
6365 * src/lalr.h (state_t): Remove.
6366 (state_table): Be state_t **, not state_t *.
6367 * src/state.h (core, CORE_ALLOC): Rename as...
6368 (state_t, STATE_ALLOC): this.
6369 Add the LALR(1) members: shifts, reductions, errs.
6370 * src/LR0.c (state_table): Rename as...
6371 (state_hash): this, to avoid name clashes with the global
6372 `state_table'.
6373 * src/print_graph.c, src/LR0.c, src/LR0.h, src/conflicts.c
6374 * src/lalr.c, src/lalr.h, src/output.c, src/print.c: Adjust.
6375
63762001-12-10 Akim Demaille <akim@epita.fr>
6377
6378 Bison dumps core on bash.y.
6379 Reported by Pascal Bart.
6380
6381 * src/warshall.c (bitmatrix_print): New.
6382 (TC): Use it.
6383 When performing a transitive closure R(i, j) && R(j, k) => R(i, k),
6384 j must be the outer loop.
6385 * tests/regression.at (Broken Closure): New.
6386
63872001-12-05 Akim Demaille <akim@epita.fr>
6388
6389 * tests/atlocal.in (CPPFLAGS): Do not leave a space between -I and
6390 its argument.
6391