Mercurial > gnulib
changeset 39858:f1a9693c37be
dfa: prune states as we go
* lib/dfa.c (prune): Remove.
(merge_nfa_state): Prune as we go instead of at the end.
Prefer ptrdiff_t for indexes, as this helps the compiler a bit.
Simplify constraint checking a bit.
author | Paul Eggert <eggert@cs.ucla.edu> |
---|---|
date | Tue, 18 Sep 2018 18:24:27 -0700 |
parents | b0bc3272b80e |
children | 1f2a63e46815 |
files | ChangeLog lib/dfa.c |
diffstat | 2 files changed, 24 insertions(+), 36 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog Tue Sep 18 15:25:51 2018 -0700 +++ b/ChangeLog Tue Sep 18 18:24:27 2018 -0700 @@ -1,6 +1,11 @@ 2018-09-18 Paul Eggert <eggert@cs.ucla.edu> + dfa: prune states as we go + * lib/dfa.c (prune): Remove. dfa: reorder enum for efficiency + (merge_nfa_state): Prune as we go instead of at the end. + Prefer ptrdiff_t for indexes, as this helps the compiler a bit. + * lib/dfa.c (END): Now -1 again. Reorder other elements of the enumeration to make it easier for GCC to generate efficient code by using fewer comparisons to check for
--- a/lib/dfa.c Tue Sep 18 15:25:51 2018 -0700 +++ b/lib/dfa.c Tue Sep 18 18:24:27 2018 -0700 @@ -2129,22 +2129,6 @@ return 0; } -static void -prune (position_set *s) -{ - size_t d = 0; - - for (size_t i = 0; i < s->nelem; i++) - { - if (s->elems[i].constraint == 0) - continue; - - s->elems[d++] = s->elems[i]; - } - - s->nelem = d; -} - /* Replace a position with the followed set. */ static void replace (position_set *dst, size_t del, position_set *add, @@ -2362,17 +2346,20 @@ merge_nfa_state (struct dfa *d, size_t *queue, size_t nqueue, size_t tindex, int *flags, position_set *merged) { - size_t sindex; - size_t dindex; - - for (size_t i = 0; i < d->follows[tindex].nelem; i++) + position_set *follows = d->follows; + ptrdiff_t nelem = 0; + + for (ptrdiff_t i = 0; i < follows[tindex].nelem; i++) { - dindex = d->follows[tindex].elems[i].index; + size_t dindex = follows[tindex].elems[i].index; /* Skip the node as pruned in future. */ - if (d->follows[tindex].elems[i].constraint == 0) + unsigned int iconstraint = follows[tindex].elems[i].constraint; + if (iconstraint == 0) continue; + follows[tindex].elems[nelem++] = follows[tindex].elems[i]; + if (tindex < dindex && !(flags[dindex] & OPT_QUEUED)) { queue[nqueue++] = dindex; @@ -2382,11 +2369,11 @@ if (flags[dindex] & (OPT_LPAREN | OPT_RPAREN)) continue; - for (size_t j = i + 1; j < d->follows[tindex].nelem; j++) + for (size_t j = i + 1; j < follows[tindex].nelem; j++) { - sindex = d->follows[tindex].elems[j].index; - - if (d->follows[tindex].elems[j].constraint == 0) + size_t sindex = follows[tindex].elems[j].index; + + if (follows[tindex].elems[j].constraint != iconstraint) continue; if (flags[sindex] & (OPT_LPAREN | OPT_RPAREN)) @@ -2395,25 +2382,21 @@ if (d->tokens[sindex] != d->tokens[dindex]) continue; - if (d->follows[tindex].elems[i].constraint != - d->follows[tindex].elems[j].constraint) - continue; - if ((flags[sindex] ^ flags[dindex]) & OPT_REPEAT) continue; if (flags[sindex] & OPT_REPEAT) - delete (sindex, &d->follows[sindex]); - - merge (&d->follows[dindex], &d->follows[sindex], merged); - copy (merged, &d->follows[dindex]); + delete (sindex, &follows[sindex]); + + merge (&follows[dindex], &follows[sindex], merged); + copy (merged, &follows[dindex]); /* Mark it as pruned in future. */ - d->follows[tindex].elems[j].constraint = 0; + follows[tindex].elems[j].constraint = 0; } } - prune (&d->follows[tindex]); + follows[tindex].nelem = nelem; return nqueue; }