- short *sp;
- short *sp1;
- int rule;
-
- sp1 = sp = ritem + sitems[i];
-
- while (*sp >= 0)
- sp++;
-
- rule = -(*sp);
-
- if (i)
- obstack_1grow (node_obstack, '\n');
- obstack_fgrow1 (node_obstack, " %s -> ",
- escape (rules[rule].lhs->tag));
-
- for (sp = rules[rule].rhs; sp < sp1; sp++)
- obstack_fgrow1 (node_obstack, "%s ", escape (symbols[*sp]->tag));
-
- obstack_1grow (node_obstack, '.');
-
- for (/* Nothing */; *sp >= 0; ++sp)
- obstack_fgrow1 (node_obstack, " %s", escape (symbols[*sp]->tag));
+ item_number const *sp1 = ritem + sitems[i];
+ item_number const *sp = sp1;
+ rule *r;
+
+ while (0 <= *sp)
+ sp++;
+
+ r = &rules[item_number_as_rule_number (*sp)];
+
+ obstack_printf (oout, "%3d ", r->number);
+ if (previous_lhs && UNIQSTR_EQ (previous_lhs->tag, r->lhs->tag))
+ obstack_printf (oout, "%*s| ",
+ (int) strlen (previous_lhs->tag), "");
+ else
+ obstack_printf (oout, "%s: ", escape (r->lhs->tag));
+ previous_lhs = r->lhs;
+
+ for (sp = r->rhs; sp < sp1; sp++)
+ obstack_printf (oout, "%s ", escape (symbols[*sp]->tag));
+
+ obstack_1grow (oout, '.');
+
+ if (0 <= *r->rhs)
+ for (/* Nothing */; *sp >= 0; ++sp)
+ obstack_printf (oout, " %s", escape (symbols[*sp]->tag));
+ else
+ obstack_printf (oout, " %%empty");
+
+ /* Experimental feature: display the lookahead tokens. */
+ if (report_flag & report_lookahead_tokens
+ && item_number_is_rule_number (*sp1))
+ {
+ /* Find the reduction we are handling. */
+ reductions *reds = s->reductions;
+ int redno = state_reduction_find (s, r);
+
+ /* Print them if there are. */
+ if (reds->lookahead_tokens && redno != -1)
+ {
+ bitset_iterator biter;
+ int k;
+ char const *sep = "";
+ obstack_sgrow (oout, " [");
+ BITSET_FOR_EACH (biter, reds->lookahead_tokens[redno], k, 0)
+ {
+ obstack_sgrow (oout, sep);
+ obstack_sgrow (oout, escape (symbols[k]->tag));
+ sep = ", ";
+ }
+ obstack_1grow (oout, ']');
+ }
+ }
+ obstack_sgrow (oout, "\\l");