mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-17 16:23:04 +00:00
New experimental feature: display the lookaheads in the report and
graph. * src/print (print_core): When --trace-flag, display the rules lookaheads. * src/print_graph.c (print_core): Likewise. Swap the arguments. Adjust caller.
This commit is contained in:
11
ChangeLog
11
ChangeLog
@@ -1,3 +1,14 @@
|
|||||||
|
2002-05-05 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
|
New experimental feature: display the lookaheads in the report and
|
||||||
|
graph.
|
||||||
|
|
||||||
|
* src/print (print_core): When --trace-flag, display the rules
|
||||||
|
lookaheads.
|
||||||
|
* src/print_graph.c (print_core): Likewise.
|
||||||
|
Swap the arguments.
|
||||||
|
Adjust caller.
|
||||||
|
|
||||||
2002-05-05 Akim Demaille <akim@epita.fr>
|
2002-05-05 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
* tests/torture.at (Many lookaheads): New test.
|
* tests/torture.at (Many lookaheads): New test.
|
||||||
|
|||||||
104
TODO
104
TODO
@@ -21,6 +21,110 @@ When implementing multiple-%union support, bare the following in mind:
|
|||||||
char *sval;
|
char *sval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
* Experimental report features
|
||||||
|
Decide whether they should be enabled, or optional. For instance, on:
|
||||||
|
|
||||||
|
input:
|
||||||
|
exp
|
||||||
|
| input exp
|
||||||
|
;
|
||||||
|
|
||||||
|
exp:
|
||||||
|
token1 "1"
|
||||||
|
| token2 "2"
|
||||||
|
| token3 "3"
|
||||||
|
;
|
||||||
|
|
||||||
|
token1: token;
|
||||||
|
token2: token;
|
||||||
|
token3: token;
|
||||||
|
|
||||||
|
the traditional Bison reports:
|
||||||
|
|
||||||
|
state 0
|
||||||
|
|
||||||
|
$axiom -> . input $ (rule 0)
|
||||||
|
|
||||||
|
token shift, and go to state 1
|
||||||
|
|
||||||
|
input go to state 2
|
||||||
|
exp go to state 3
|
||||||
|
token1 go to state 4
|
||||||
|
token2 go to state 5
|
||||||
|
token3 go to state 6
|
||||||
|
|
||||||
|
state 1
|
||||||
|
|
||||||
|
token1 -> token . (rule 6)
|
||||||
|
token2 -> token . (rule 7)
|
||||||
|
token3 -> token . (rule 8)
|
||||||
|
|
||||||
|
"2" reduce using rule 7 (token2)
|
||||||
|
"3" reduce using rule 8 (token3)
|
||||||
|
$default reduce using rule 6 (token1)
|
||||||
|
|
||||||
|
while with --trace, i.e., when enabling both the display of non-core
|
||||||
|
item sets and the display of lookaheads, Bison now displays:
|
||||||
|
|
||||||
|
state 0
|
||||||
|
|
||||||
|
$axiom -> . input $ (rule 0)
|
||||||
|
input -> . exp (rule 1)
|
||||||
|
input -> . input exp (rule 2)
|
||||||
|
exp -> . token1 "1" (rule 3)
|
||||||
|
exp -> . token2 "2" (rule 4)
|
||||||
|
exp -> . token3 "3" (rule 5)
|
||||||
|
token1 -> . token (rule 6)
|
||||||
|
token2 -> . token (rule 7)
|
||||||
|
token3 -> . token (rule 8)
|
||||||
|
|
||||||
|
token shift, and go to state 1
|
||||||
|
|
||||||
|
input go to state 2
|
||||||
|
exp go to state 3
|
||||||
|
token1 go to state 4
|
||||||
|
token2 go to state 5
|
||||||
|
token3 go to state 6
|
||||||
|
|
||||||
|
state 1
|
||||||
|
|
||||||
|
token1 -> token . ["1"] (rule 6)
|
||||||
|
token2 -> token . ["2"] (rule 7)
|
||||||
|
token3 -> token . ["3"] (rule 8)
|
||||||
|
|
||||||
|
"2" reduce using rule 7 (token2)
|
||||||
|
"3" reduce using rule 8 (token3)
|
||||||
|
$default reduce using rule 6 (token1)
|
||||||
|
|
||||||
|
so decide whether this should be an option, or always enabled. I'm in
|
||||||
|
favor of making it the default, but maybe we should tune the output to
|
||||||
|
distinguish core item sets from non core:
|
||||||
|
|
||||||
|
state 0
|
||||||
|
Core:
|
||||||
|
$axiom -> . input $ (rule 0)
|
||||||
|
|
||||||
|
Derived:
|
||||||
|
input -> . exp (rule 1)
|
||||||
|
input -> . input exp (rule 2)
|
||||||
|
exp -> . token1 "1" (rule 3)
|
||||||
|
exp -> . token2 "2" (rule 4)
|
||||||
|
exp -> . token3 "3" (rule 5)
|
||||||
|
token1 -> . token (rule 6)
|
||||||
|
token2 -> . token (rule 7)
|
||||||
|
token3 -> . token (rule 8)
|
||||||
|
|
||||||
|
token shift, and go to state 1
|
||||||
|
|
||||||
|
input go to state 2
|
||||||
|
exp go to state 3
|
||||||
|
token1 go to state 4
|
||||||
|
token2 go to state 5
|
||||||
|
token3 go to state 6
|
||||||
|
|
||||||
|
|
||||||
|
Note that the same questions applies to --graph.
|
||||||
|
|
||||||
* Coding system independence
|
* Coding system independence
|
||||||
Paul notes:
|
Paul notes:
|
||||||
|
|
||||||
|
|||||||
26
src/print.c
26
src/print.c
@@ -105,6 +105,32 @@ print_core (FILE *out, state_t *state)
|
|||||||
for (/* Nothing */; *sp >= 0; ++sp)
|
for (/* Nothing */; *sp >= 0; ++sp)
|
||||||
fprintf (out, " %s", escape (symbols[*sp]->tag));
|
fprintf (out, " %s", escape (symbols[*sp]->tag));
|
||||||
|
|
||||||
|
/* Experimental feature: display the lookaheads. */
|
||||||
|
if (trace_flag && state->nlookaheads)
|
||||||
|
{
|
||||||
|
int j, k;
|
||||||
|
int nlookaheads = 0;
|
||||||
|
/* Look for lookaheads corresponding to this rule. */
|
||||||
|
for (j = 0; j < state->nlookaheads; ++j)
|
||||||
|
for (k = 0; k < ntokens; ++k)
|
||||||
|
if (bitset_test (LA[state->lookaheadsp + j], k)
|
||||||
|
&& LArule[state->lookaheadsp + j]->number == rule)
|
||||||
|
nlookaheads++;
|
||||||
|
if (nlookaheads)
|
||||||
|
{
|
||||||
|
fprintf (out, " [");
|
||||||
|
for (j = 0; j < state->nlookaheads; ++j)
|
||||||
|
for (k = 0; k < ntokens; ++k)
|
||||||
|
if (bitset_test (LA[state->lookaheadsp + j], k)
|
||||||
|
&& LArule[state->lookaheadsp + j]->number == rule)
|
||||||
|
fprintf (out, "%s%s",
|
||||||
|
quotearg_style (escape_quoting_style,
|
||||||
|
symbols[k]->tag),
|
||||||
|
--nlookaheads ? ", " : "");
|
||||||
|
fprintf (out, "]");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fprintf (out, _(" (rule %d)"), rule - 1);
|
fprintf (out, _(" (rule %d)"), rule - 1);
|
||||||
fputc ('\n', out);
|
fputc ('\n', out);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ escape (const char *s)
|
|||||||
|
|
||||||
/* This part will construct the label of nodes. */
|
/* This part will construct the label of nodes. */
|
||||||
static void
|
static void
|
||||||
print_core (state_t *state, struct obstack *node_obstack)
|
print_core (struct obstack *oout, state_t *state)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
item_number_t *sitems = state->items;
|
item_number_t *sitems = state->items;
|
||||||
@@ -61,7 +61,7 @@ print_core (state_t *state, struct obstack *node_obstack)
|
|||||||
snritems = nritemset;
|
snritems = nritemset;
|
||||||
}
|
}
|
||||||
|
|
||||||
obstack_fgrow1 (node_obstack, "state %2d\n", state->number);
|
obstack_fgrow1 (oout, "state %2d\n", state->number);
|
||||||
for (i = 0; i < snritems; i++)
|
for (i = 0; i < snritems; i++)
|
||||||
{
|
{
|
||||||
item_number_t *sp;
|
item_number_t *sp;
|
||||||
@@ -76,17 +76,43 @@ print_core (state_t *state, struct obstack *node_obstack)
|
|||||||
rule = -(*sp);
|
rule = -(*sp);
|
||||||
|
|
||||||
if (i)
|
if (i)
|
||||||
obstack_1grow (node_obstack, '\n');
|
obstack_1grow (oout, '\n');
|
||||||
obstack_fgrow1 (node_obstack, " %s -> ",
|
obstack_fgrow1 (oout, " %s -> ",
|
||||||
escape (rules[rule].lhs->tag));
|
escape (rules[rule].lhs->tag));
|
||||||
|
|
||||||
for (sp = rules[rule].rhs; sp < sp1; sp++)
|
for (sp = rules[rule].rhs; sp < sp1; sp++)
|
||||||
obstack_fgrow1 (node_obstack, "%s ", escape (symbols[*sp]->tag));
|
obstack_fgrow1 (oout, "%s ", escape (symbols[*sp]->tag));
|
||||||
|
|
||||||
obstack_1grow (node_obstack, '.');
|
obstack_1grow (oout, '.');
|
||||||
|
|
||||||
for (/* Nothing */; *sp >= 0; ++sp)
|
for (/* Nothing */; *sp >= 0; ++sp)
|
||||||
obstack_fgrow1 (node_obstack, " %s", escape (symbols[*sp]->tag));
|
obstack_fgrow1 (oout, " %s", escape (symbols[*sp]->tag));
|
||||||
|
|
||||||
|
/* Experimental feature: display the lookaheads. */
|
||||||
|
if (trace_flag && state->nlookaheads)
|
||||||
|
{
|
||||||
|
int j, k;
|
||||||
|
int nlookaheads = 0;
|
||||||
|
/* Look for lookaheads corresponding to this rule. */
|
||||||
|
for (j = 0; j < state->nlookaheads; ++j)
|
||||||
|
for (k = 0; k < ntokens; ++k)
|
||||||
|
if (bitset_test (LA[state->lookaheadsp + j], k)
|
||||||
|
&& LArule[state->lookaheadsp + j]->number == rule)
|
||||||
|
nlookaheads++;
|
||||||
|
if (nlookaheads)
|
||||||
|
{
|
||||||
|
obstack_sgrow (oout, " [");
|
||||||
|
for (j = 0; j < state->nlookaheads; ++j)
|
||||||
|
for (k = 0; k < ntokens; ++k)
|
||||||
|
if (bitset_test (LA[state->lookaheadsp + j], k)
|
||||||
|
&& LArule[state->lookaheadsp + j]->number == rule)
|
||||||
|
obstack_fgrow2 (oout, "%s%s",
|
||||||
|
quotearg_style (escape_quoting_style,
|
||||||
|
symbols[k]->tag),
|
||||||
|
--nlookaheads ? ", " : "");
|
||||||
|
obstack_sgrow (oout, "]");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -154,7 +180,7 @@ print_state (state_t *state)
|
|||||||
new_node (&node);
|
new_node (&node);
|
||||||
sprintf (name, "%d", state->number);
|
sprintf (name, "%d", state->number);
|
||||||
node.title = name;
|
node.title = name;
|
||||||
print_core (state, &node_obstack);
|
print_core (&node_obstack, state);
|
||||||
obstack_1grow (&node_obstack, '\0');
|
obstack_1grow (&node_obstack, '\0');
|
||||||
node.label = obstack_finish (&node_obstack);
|
node.label = obstack_finish (&node_obstack);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user