mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-10 12:53:03 +00:00
Make xml2dot.xsl and --graph produce the same output.
* data/xslt/xml2dot.xsl (xsl:template match="rule"): Use a ` ' instead of a `\n'. That is, don't add escapes yet or they'll be doubly escaped later. (xsl:template name="output-node"): Use the new escape template instead of the string-replace template directly. (xsl:template name="output-edge"): Likewise. (xsl:template name="escape"): New, escapes backslashes and newlines in addition to quotation marks. * src/graphviz.c (start_graph, output_node, output_edge): Add whitespace to output for legibility. Make xml2text.xsl and --report produce the same output, and remove the XML "conflicts" element since a conflict summary is easily extracted from the automaton. * data/xslt/bison.xsl: New. (xsl:template match="state" mode="bison:count-conflicts): New. * data/xslt/xml2text.xsl: Import bison.xsl. (xsl:template match="bison-xml-report"): Instead of styling the "conflicts" element, style the "automaton" element with mode "conflicts". Unlike the former, the latter lists S/R and R/R conflicts for a state on the same line. (xsl:template match="conflicts"): Remove. (xsl:template match="conflict"): Remove. (xsl:template match="terminal"): Line-wrap the list of rules in which the terminal is used. (xsl:template match="nonterminal"): Likewise for nonterminals. (xsl:template match="automaton" mode="conflicts"): New. (xsl:template match="state" mode="conflicts"): New. (xsl:template name="line-wrap"): New. (xsl:template name="ws-search"): New. * data/xslt/xml2xhtml.xsl: Import bison.xsl. (xsl:template match="bison-xml-report"): Instead of styling the "conflicts" element, style the "automaton" element with mode "conflicts." (xsl:template match="conflicts"): Remove. (xsl:template match="conflict"): Remove. (xsl:template match="automaton" mode="conflicts"): New. (xsl:template match="state" mode="conflicts): New. * src/conflicts.c (conflicts_output_xml): Remove. * src/conflicts.h (conflicts_output_xml): Remove prototype. * src/print-xml.c (print_xml): Don't invoke conflicts_output_xml. * src/print.c (print_grammar): Consistently wrap at the 66th column so the corresponding XSLT is easier. Also, never wrap between a word and the comma that follows it.
This commit is contained in:
@@ -522,47 +522,6 @@ conflicts_output (FILE *out)
|
||||
fputs ("\n\n", out);
|
||||
}
|
||||
|
||||
void
|
||||
conflicts_output_xml (FILE *out, int level)
|
||||
{
|
||||
bool printed_sth = false;
|
||||
state_number i;
|
||||
int src_num;
|
||||
int rrc_num;
|
||||
|
||||
for (i = 0; i < nstates; i++)
|
||||
{
|
||||
state *s = states[i];
|
||||
if (conflicts[i])
|
||||
{
|
||||
if (!printed_sth) {
|
||||
fputc ('\n', out);
|
||||
xml_puts (out, level, "<conflicts>");
|
||||
}
|
||||
|
||||
src_num = count_sr_conflicts (s);
|
||||
rrc_num = count_rr_conflicts (s, true);
|
||||
|
||||
if (src_num)
|
||||
xml_printf (out, level + 1,
|
||||
"<conflict state=\"%d\" num=\"%d\""
|
||||
" type=\"shift/reduce\"/>",
|
||||
i, src_num);
|
||||
if (rrc_num)
|
||||
xml_printf (out, level + 1,
|
||||
"<conflict state=\"%d\" num=\"%d\""
|
||||
" type=\"reduce/reduce\"/>",
|
||||
i, rrc_num);
|
||||
|
||||
printed_sth = true;
|
||||
}
|
||||
}
|
||||
if (printed_sth)
|
||||
xml_puts (out, level, "</conflicts>");
|
||||
else
|
||||
xml_puts (out, level, "<conflicts/>");
|
||||
}
|
||||
|
||||
/*--------------------------------------------------------.
|
||||
| Total the number of S/R and R/R conflicts. Unlike the |
|
||||
| code in conflicts_output, however, count EACH pair of |
|
||||
|
||||
@@ -37,7 +37,6 @@ void conflicts_update_state_numbers (state_number old_to_new[],
|
||||
void conflicts_print (void);
|
||||
int conflicts_total_count (void);
|
||||
void conflicts_output (FILE *out);
|
||||
void conflicts_output_xml (FILE *out, int level);
|
||||
void conflicts_free (void);
|
||||
|
||||
/* Were there conflicts? */
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
/* Output Graphviz specification of a state machine generated by Bison.
|
||||
|
||||
Copyright (C) 2006 Free Software Foundation, Inc.
|
||||
Copyright (C) 2006, 2007 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of Bison, the GNU Compiler Compiler.
|
||||
|
||||
@@ -38,20 +38,20 @@ quote (char const *name)
|
||||
void
|
||||
start_graph (FILE *fout)
|
||||
{
|
||||
fputs ("digraph Automaton{\n", fout);
|
||||
fputs ("digraph Automaton {\n", fout);
|
||||
}
|
||||
|
||||
void
|
||||
output_node (int id, char const *label, FILE *fout)
|
||||
{
|
||||
fprintf (fout, "%d[label=%s]\n", id, quote (label));
|
||||
fprintf (fout, " %d [label=%s]\n", id, quote (label));
|
||||
}
|
||||
|
||||
void
|
||||
output_edge (int source, int destination, char const *label,
|
||||
char const *style, FILE *fout)
|
||||
{
|
||||
fprintf (fout, "%d->%d[style=%s", source, destination, style);
|
||||
fprintf (fout, " %d -> %d [style=%s", source, destination, style);
|
||||
if (label)
|
||||
fprintf (fout, " label=%s", quote (label));
|
||||
fputs ("]\n", fout);
|
||||
|
||||
@@ -584,9 +584,6 @@ print_xml (void)
|
||||
/* print rules never reduced */
|
||||
print_rules_never_reduced (out, level + 1);
|
||||
|
||||
/* print conflicts */
|
||||
conflicts_output_xml (out, level + 1);
|
||||
|
||||
/* print grammar */
|
||||
print_grammar (out, level + 1);
|
||||
|
||||
|
||||
12
src/print.c
12
src/print.c
@@ -401,7 +401,7 @@ print_grammar (FILE *out)
|
||||
buffer[0] = 0;
|
||||
column = strlen (tag);
|
||||
fputs (tag, out);
|
||||
END_TEST (50);
|
||||
END_TEST (65);
|
||||
sprintf (buffer, " (%d)", i);
|
||||
|
||||
for (r = 0; r < nrules; r++)
|
||||
@@ -445,14 +445,16 @@ print_grammar (FILE *out)
|
||||
|
||||
if (left_count > 0)
|
||||
{
|
||||
END_TEST (50);
|
||||
END_TEST (65);
|
||||
sprintf (buffer + strlen (buffer), _(" on left:"));
|
||||
|
||||
for (r = 0; r < nrules; r++)
|
||||
{
|
||||
END_TEST (65);
|
||||
if (rules[r].lhs->number == i)
|
||||
sprintf (buffer + strlen (buffer), " %d", r);
|
||||
{
|
||||
END_TEST (65);
|
||||
sprintf (buffer + strlen (buffer), " %d", r);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -460,7 +462,7 @@ print_grammar (FILE *out)
|
||||
{
|
||||
if (left_count > 0)
|
||||
sprintf (buffer + strlen (buffer), ",");
|
||||
END_TEST (50);
|
||||
END_TEST (65);
|
||||
sprintf (buffer + strlen (buffer), _(" on right:"));
|
||||
for (r = 0; r < nrules; r++)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user