From: Akim Demaille Date: Fri, 28 Dec 2012 09:04:49 +0000 (+0100) Subject: graph: minor simplification X-Git-Tag: v2.7.90~205 X-Git-Url: https://git.saurik.com/bison.git/commitdiff_plain/fd7f0289bcfa2e830439e37395fd91f0d7587a39 graph: minor simplification * src/gram.c (print_lhs): Use %*s to indent. * src/print_graph.c (print_lhs): Use obstack_printf. Became simple enough to be inlined in... (print_core): here. Use a "rule*" instead of an index in "rules[]". --- diff --git a/src/gram.c b/src/gram.c index 20aefe19..4ee56867 100644 --- a/src/gram.c +++ b/src/gram.c @@ -69,16 +69,9 @@ rule_lhs_print (rule const *r, symbol const *previous_lhs, FILE *out) { fprintf (out, " %3d ", r->number); if (previous_lhs != r->lhs) - { - fprintf (out, "%s:", r->lhs->tag); - } + fprintf (out, "%s:", r->lhs->tag); else - { - int n; - for (n = strlen (previous_lhs->tag); n > 0; --n) - fputc (' ', out); - fputc ('|', out); - } + fprintf (out, "%*s|", (int) strlen (previous_lhs->tag), ""); } void diff --git a/src/print_graph.c b/src/print_graph.c index 31e0e382..6ca44c05 100644 --- a/src/print_graph.c +++ b/src/print_graph.c @@ -42,33 +42,15 @@ /* Print the lhs of a rule in such a manner that there is no vertical repetition, like in *.output files. */ -static void -print_lhs (struct obstack *oout, rule *previous_rule, rule *r) -{ - if (previous_rule && STREQ (previous_rule->lhs->tag, r->lhs->tag)) - { - int i; - for (i = 0; i < strlen (r->lhs->tag); ++i) - obstack_1grow (oout, ' '); - obstack_1grow (oout, '|'); - } - else - { - obstack_sgrow (oout, escape (r->lhs->tag)); - obstack_1grow (oout, ':'); - } - obstack_1grow (oout, ' '); -} - static void print_core (struct obstack *oout, state *s) { - item_number *sitems = s->items; - rule *previous_rule = NULL; + item_number const *sitems = s->items; + symbol *previous_lhs = NULL; size_t i; size_t snritems = s->nitems; - /* Output all the items of a state, not only its kernel. */ + /* Output all the items of a state, not just its kernel. */ if (report_flag & report_itemsets) { closure (sitems, snritems); @@ -80,22 +62,24 @@ print_core (struct obstack *oout, state *s) obstack_sgrow (oout, "\\n\\l"); for (i = 0; i < snritems; i++) { - item_number *sp; - item_number *sp1; - rule_number r; - - sp1 = sp = ritem + sitems[i]; + item_number const *sp1 = ritem + sitems[i]; + item_number const *sp = sp1; + rule *r; - while (*sp >= 0) + while (0 <= *sp) sp++; - r = item_number_as_rule_number (*sp); + r = &rules[item_number_as_rule_number (*sp)]; - obstack_printf (oout, "%3d ", r); - print_lhs (oout, previous_rule, &rules[r]); - previous_rule = &rules[r]; + 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 = rules[r].rhs; sp < sp1; sp++) + for (sp = r->rhs; sp < sp1; sp++) obstack_printf (oout, "%s ", escape (symbols[*sp]->tag)); obstack_1grow (oout, '.'); @@ -109,7 +93,7 @@ print_core (struct obstack *oout, state *s) { /* Find the reduction we are handling. */ reductions *reds = s->reductions; - int redno = state_reduction_find (s, &rules[r]); + int redno = state_reduction_find (s, r); /* Print them if there are. */ if (reds->lookahead_tokens && redno != -1)