* of synchronisation with the action file
*/
while (p->n_count--) getaction(1);
+ if (g_gettype(p->n_rule) == EORULE &&
+ getntparams(p) == 0) {
+ continue;
+ }
fprintf(fpars,"L%d_%s (\n",s->o_index,p->n_name);
if (p->n_flags & PARAMS) {
controlline();
getntsafe(n) <= SAFESCANDONE)) {
genpop(findindex(n->n_contains));
}
- if (g_gettype(n->n_rule) == EORULE &&
- safety <= getntout(n) &&
- ! g_getnpar(p)) {
- safety = getntout(n);
- break;
- }
fprintf(f,"L%d_%s(\n",g_getcont(p), n->n_name);
if (g_getnpar(p)) {
controlline();
case TERM :
reachwalk(g_getterm(p)->t_rule);
break;
- case NONTERM :
- reachable(&nonterms[g_getcont(p)]);
+ case NONTERM : {
+ register p_nont n = &nonterms[g_getcont(p)];
+
+ reachable(n);
+ if (g_gettype(n->n_rule) == EORULE &&
+ ! g_getnpar(p) && (getntparams(n) == 0)) {
+ register p_gram np = p;
+ do {
+ *np = *(np + 1);
+ np++;
+ } while (g_gettype(np) != EORULE);
+ continue;
+ }
break;
+ }
case EORULE :
return;
}