the RHS of the rules.
* src/output.c (output_gram): Likewise.
+2002-04-07 Akim Demaille <akim@epita.fr>
+
+ * src/LR0.c (allocate_itemsets): Don't loop over ritem: loop over
+ the RHS of the rules.
+ * src/output.c (output_gram): Likewise.
+
2002-04-07 Akim Demaille <akim@epita.fr>
* src/gram.h (rule_t): `lhs' is now a pointer to the symbol's
static void
allocate_itemsets (void)
{
- int i;
+ int i, r;
+ short *rhsp;
/* Count the number of occurrences of all the symbols in RITEMS.
Note that useless productions (hence useless nonterminals) are
int count = 0;
short *symbol_count = XCALLOC (short, nsyms + nuseless_nonterminals);
- for (i = 0; i < nritems; ++i)
- if (ritem[i] >= 0)
+ for (r = 1; r < nrules + 1; ++r)
+ for (rhsp = rules[r].rhs; *rhsp >= 0; ++rhsp)
{
count++;
- symbol_count[ritem[i]]++;
+ symbol_count[*rhsp]++;
}
/* See comments before new_itemsets. All the vectors of items
muscle_insert ("prhs", obstack_finish (&format_obstack));
{
- short *yyrhs;
- int i;
-
- yyrhs = XMALLOC (short, nritems);
-
- for (i = 1; i < nritems; ++i)
- yyrhs[i] = ritem[i] >= 0 ? ritem[i] : -1;
+ short *rhsp;
+ int r;
+ int i = 0;
+ short *yyrhs = XMALLOC (short, nritems);
+ for (r = 1; r < nrules + 1; ++r)
+ {
+ for (rhsp = rules[r].rhs; *rhsp >= 0; ++rhsp)
+ yyrhs[i++] = *rhsp;
+ yyrhs[i++] = -1;
+ }
+ assert (i == nritems);
output_table_data (&format_obstack, yyrhs,
ritem[0], 1, nritems);
muscle_insert ("rhs", obstack_finish (&format_obstack));