]>
git.saurik.com Git - bison.git/blob - src/print.c
1 /* Print information on generated parser, for bison,
3 Copyright (C) 1984, 1986, 1989, 2000-2005, 2007, 2009-2014 Free
4 Software Foundation, Inc.
6 This file is part of Bison, the GNU Compiler Compiler.
8 This program is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
28 #include "conflicts.h"
33 #include "muscle-tab.h"
41 static bitset no_reduce_set
;
45 print_token (int extnum
, int token
)
47 fprintf (out
, _(" type %d is %s\n"), extnum
, tags
[token
]);
53 /*---------------------------------------.
54 | *WIDTH := max (*WIDTH, strlen (STR)). |
55 `---------------------------------------*/
58 max_length (size_t *width
, const char *str
)
60 size_t len
= strlen (str
);
65 /*--------------------------------.
66 | Report information on a state. |
67 `--------------------------------*/
70 print_core (FILE *out
, state
*s
)
73 item_number
*sitems
= s
->items
;
74 size_t snritems
= s
->nitems
;
75 symbol
*previous_lhs
= NULL
;
77 /* Output all the items of a state, not only its kernel. */
78 if (report_flag
& report_itemsets
)
80 closure (sitems
, snritems
);
90 for (i
= 0; i
< snritems
; i
++)
96 sp1
= sp
= ritem
+ sitems
[i
];
101 r
= item_number_as_rule_number (*sp
);
103 rule_lhs_print (&rules
[r
], previous_lhs
, out
);
104 previous_lhs
= rules
[r
].lhs
;
106 for (sp
= rules
[r
].rhs
; sp
< sp1
; sp
++)
107 fprintf (out
, " %s", symbols
[*sp
]->tag
);
109 if (0 <= *rules
[r
].rhs
)
110 for (/* Nothing */; 0 <= *sp
; ++sp
)
111 fprintf (out
, " %s", symbols
[*sp
]->tag
);
113 fprintf (out
, " %%empty");
115 /* Display the lookahead tokens? */
116 if (report_flag
& report_lookahead_tokens
117 && item_number_is_rule_number (*sp1
))
118 state_rule_lookahead_tokens_print (s
, &rules
[r
], out
);
125 /*------------------------------------------------------------.
126 | Report the shifts iff DISPLAY_SHIFTS_P or the gotos of S on |
128 `------------------------------------------------------------*/
131 print_transitions (state
*s
, FILE *out
, bool display_transitions_p
)
133 transitions
*trans
= s
->transitions
;
137 /* Compute the width of the lookahead token column. */
138 for (i
= 0; i
< trans
->num
; i
++)
139 if (!TRANSITION_IS_DISABLED (trans
, i
)
140 && TRANSITION_IS_SHIFT (trans
, i
) == display_transitions_p
)
142 symbol
*sym
= symbols
[TRANSITION_SYMBOL (trans
, i
)];
143 max_length (&width
, sym
->tag
);
146 /* Nothing to report. */
153 /* Report lookahead tokens and shifts. */
154 for (i
= 0; i
< trans
->num
; i
++)
155 if (!TRANSITION_IS_DISABLED (trans
, i
)
156 && TRANSITION_IS_SHIFT (trans
, i
) == display_transitions_p
)
158 symbol
*sym
= symbols
[TRANSITION_SYMBOL (trans
, i
)];
159 const char *tag
= sym
->tag
;
160 state
*s1
= trans
->states
[i
];
163 fprintf (out
, " %s", tag
);
164 for (j
= width
- strlen (tag
); j
> 0; --j
)
166 if (display_transitions_p
)
167 fprintf (out
, _("shift, and go to state %d\n"), s1
->number
);
169 fprintf (out
, _("go to state %d\n"), s1
->number
);
174 /*--------------------------------------------------------.
175 | Report the explicit errors of S raised from %nonassoc. |
176 `--------------------------------------------------------*/
179 print_errs (FILE *out
, state
*s
)
181 errs
*errp
= s
->errs
;
185 /* Compute the width of the lookahead token column. */
186 for (i
= 0; i
< errp
->num
; ++i
)
187 if (errp
->symbols
[i
])
188 max_length (&width
, errp
->symbols
[i
]->tag
);
190 /* Nothing to report. */
197 /* Report lookahead tokens and errors. */
198 for (i
= 0; i
< errp
->num
; ++i
)
199 if (errp
->symbols
[i
])
201 const char *tag
= errp
->symbols
[i
]->tag
;
203 fprintf (out
, " %s", tag
);
204 for (j
= width
- strlen (tag
); j
> 0; --j
)
206 fputs (_("error (nonassociative)\n"), out
);
211 /*-------------------------------------------------------------------------.
212 | Report a reduction of RULE on LOOKAHEAD_TOKEN (which can be 'default'). |
213 | If not ENABLED, the rule is masked by a shift or a reduce (S/R and |
215 `-------------------------------------------------------------------------*/
218 print_reduction (FILE *out
, size_t width
,
219 const char *lookahead_token
,
220 rule
*r
, bool enabled
)
223 fprintf (out
, " %s", lookahead_token
);
224 for (j
= width
- strlen (lookahead_token
); j
> 0; --j
)
229 fprintf (out
, _("reduce using rule %d (%s)"), r
->number
, r
->lhs
->tag
);
231 fprintf (out
, _("accept"));
238 /*-------------------------------------------.
239 | Report on OUT the reduction actions of S. |
240 `-------------------------------------------*/
243 print_reductions (FILE *out
, state
*s
)
245 transitions
*trans
= s
->transitions
;
246 reductions
*reds
= s
->reductions
;
247 rule
*default_reduction
= NULL
;
250 bool default_reduction_only
= true;
255 if (yydefact
[s
->number
] != 0)
256 default_reduction
= &rules
[yydefact
[s
->number
] - 1];
258 bitset_zero (no_reduce_set
);
259 FOR_EACH_SHIFT (trans
, i
)
260 bitset_set (no_reduce_set
, TRANSITION_SYMBOL (trans
, i
));
261 for (i
= 0; i
< s
->errs
->num
; ++i
)
262 if (s
->errs
->symbols
[i
])
263 bitset_set (no_reduce_set
, s
->errs
->symbols
[i
]->number
);
265 /* Compute the width of the lookahead token column. */
266 if (default_reduction
)
267 width
= strlen (_("$default"));
269 if (reds
->lookahead_tokens
)
270 for (i
= 0; i
< ntokens
; i
++)
272 bool count
= bitset_test (no_reduce_set
, i
);
274 for (j
= 0; j
< reds
->num
; ++j
)
275 if (bitset_test (reds
->lookahead_tokens
[j
], i
))
279 if (reds
->rules
[j
] != default_reduction
)
280 max_length (&width
, symbols
[i
]->tag
);
285 max_length (&width
, symbols
[i
]->tag
);
290 /* Nothing to report. */
297 /* Report lookahead tokens (or $default) and reductions. */
298 if (reds
->lookahead_tokens
)
299 for (i
= 0; i
< ntokens
; i
++)
301 bool defaulted
= false;
302 bool count
= bitset_test (no_reduce_set
, i
);
304 default_reduction_only
= false;
306 for (j
= 0; j
< reds
->num
; ++j
)
307 if (bitset_test (reds
->lookahead_tokens
[j
], i
))
311 if (reds
->rules
[j
] != default_reduction
)
313 default_reduction_only
= false;
314 print_reduction (out
, width
,
316 reds
->rules
[j
], true);
324 default_reduction_only
= false;
326 print_reduction (out
, width
,
328 default_reduction
, true);
330 print_reduction (out
, width
,
332 reds
->rules
[j
], false);
337 if (default_reduction
)
339 char *default_reductions
=
340 muscle_percent_define_get ("lr.default-reduction");
341 print_reduction (out
, width
, _("$default"), default_reduction
, true);
342 aver (STREQ (default_reductions
, "most")
343 || (STREQ (default_reductions
, "consistent")
344 && default_reduction_only
)
345 || (reds
->num
== 1 && reds
->rules
[0]->number
== 0));
346 free (default_reductions
);
351 /*--------------------------------------------------------------.
352 | Report on OUT all the actions (shifts, gotos, reductions, and |
353 | explicit erros from %nonassoc) of S. |
354 `--------------------------------------------------------------*/
357 print_actions (FILE *out
, state
*s
)
360 print_transitions (s
, out
, true);
362 print_reductions (out
, s
);
364 print_transitions (s
, out
, false);
368 /*----------------------------------.
369 | Report all the data on S on OUT. |
370 `----------------------------------*/
373 print_state (FILE *out
, state
*s
)
376 fprintf (out
, _("State %d"), s
->number
);
379 print_actions (out
, s
);
380 if ((report_flag
& report_solved_conflicts
) && s
->solved_conflicts
)
383 fputs (s
->solved_conflicts
, out
);
387 /*-----------------------------------------.
388 | Print information on the whole grammar. |
389 `-----------------------------------------*/
391 #define END_TEST(End) \
393 if (column + strlen (buffer) > (End)) \
395 fprintf (out, "%s\n ", buffer); \
403 print_grammar (FILE *out
)
409 grammar_rules_print (out
);
411 /* TERMINAL (type #) : rule #s terminal is on RHS */
412 fprintf (out
, "%s\n\n", _("Terminals, with rules where they appear"));
413 for (i
= 0; i
< max_user_token_number
+ 1; i
++)
414 if (token_translations
[i
] != undeftoken
->number
)
416 const char *tag
= symbols
[token_translations
[i
]]->tag
;
421 column
= strlen (tag
);
424 sprintf (buffer
, " (%d)", i
);
426 for (r
= 0; r
< nrules
; r
++)
427 for (rhsp
= rules
[r
].rhs
; *rhsp
>= 0; rhsp
++)
428 if (item_number_as_symbol_number (*rhsp
) == token_translations
[i
])
431 sprintf (buffer
+ strlen (buffer
), " %d", r
);
434 fprintf (out
, "%s\n", buffer
);
439 fprintf (out
, "%s\n\n", _("Nonterminals, with rules where they appear"));
440 for (i
= ntokens
; i
< nsyms
; i
++)
442 int left_count
= 0, right_count
= 0;
444 const char *tag
= symbols
[i
]->tag
;
446 for (r
= 0; r
< nrules
; r
++)
449 if (rules
[r
].lhs
->number
== i
)
451 for (rhsp
= rules
[r
].rhs
; *rhsp
>= 0; rhsp
++)
452 if (item_number_as_symbol_number (*rhsp
) == i
)
461 column
= strlen (tag
);
462 sprintf (buffer
, " (%d)", i
);
468 sprintf (buffer
+ strlen (buffer
), _(" on left:"));
470 for (r
= 0; r
< nrules
; r
++)
472 if (rules
[r
].lhs
->number
== i
)
475 sprintf (buffer
+ strlen (buffer
), " %d", r
);
483 sprintf (buffer
+ strlen (buffer
), ",");
485 sprintf (buffer
+ strlen (buffer
), _(" on right:"));
486 for (r
= 0; r
< nrules
; r
++)
489 for (rhsp
= rules
[r
].rhs
; *rhsp
>= 0; rhsp
++)
490 if (item_number_as_symbol_number (*rhsp
) == i
)
493 sprintf (buffer
+ strlen (buffer
), " %d", r
);
498 fprintf (out
, "%s\n", buffer
);
507 /* We used to use just .out if SPEC_NAME_PREFIX (-p) was used, but
508 that conflicts with Posix. */
509 FILE *out
= xfopen (spec_verbose_file
, "w");
512 grammar_rules_partial_print (out
,
513 _("Rules useless in parser due to conflicts"),
514 rule_useless_in_parser_p
);
515 conflicts_output (out
);
519 /* If the whole state item sets, not only the kernels, are wanted,
520 'closure' will be run, which needs memory allocation/deallocation. */
521 if (report_flag
& report_itemsets
)
522 new_closure (nritems
);
523 /* Storage for print_reductions. */
524 no_reduce_set
= bitset_create (ntokens
, BITSET_FIXED
);
525 for (i
= 0; i
< nstates
; i
++)
526 print_state (out
, states
[i
]);
527 bitset_free (no_reduce_set
);
528 if (report_flag
& report_itemsets
)