From: Ulya Trofimovich Date: Sat, 30 Apr 2016 16:10:31 +0000 (+0100) Subject: Simplified rule tracking during DFA construction. X-Git-Tag: 1.0~39^2~323 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6548b2e0450e3ba93e5d67e2ed34f760b5b80c5d;p=re2c Simplified rule tracking during DFA construction. --- diff --git a/re2c/src/ir/dfa/determinization.cc b/re2c/src/ir/dfa/determinization.cc index cad20b0c..1b80cd2f 100644 --- a/re2c/src/ir/dfa/determinization.cc +++ b/re2c/src/ir/dfa/determinization.cc @@ -97,10 +97,12 @@ dfa_t::dfa_t( , rules(nfa.rules) , contexts(nfa.contexts) { - std::map > s2rules; + const size_t nrules = rules.size(); + ord_hash_set_t kernels; nfa_state_t **const buffer = new nfa_state_t*[nfa.size]; std::vector > arcs(nchars); + bool *fin = new bool[nrules]; find_state(buffer, closure(buffer, nfa.root), kernels); for (size_t i = 0; i < kernels.size(); ++i) @@ -108,6 +110,8 @@ dfa_t::dfa_t( dfa_state_t *s = new dfa_state_t; states.push_back(s); + memset(fin, 0, nrules * sizeof(bool)); + nfa_state_t **kernel; const size_t kernel_size = kernels.deref(i, kernel); for (size_t j = 0; j < kernel_size; ++j) @@ -133,7 +137,7 @@ dfa_t::dfa_t( s->ctxs.insert(n->value.ctx.info); break; case nfa_state_t::FIN: - s2rules[i].insert(n->value.fin.rule); + fin[n->value.fin.rule] = true; break; default: break; @@ -151,32 +155,28 @@ dfa_t::dfa_t( s->arcs[c] = find_state(buffer, end, kernels); } + // choose the first rule (the one with smallest rank) + size_t r; + for (r = 0; r < nrules; ++r) { + if (fin[r]) { + s->rule = r; + break; + } + } + // mark other rules as shadowed by this one + for (++r; r < nrules; ++r) { + if (fin[r]) { + rules[r].shadow.insert(rules[s->rule].info->loc.line); + } + } + for(size_t c = 0; c < nchars; ++c) { arcs[c].clear(); } } delete[] buffer; - - const size_t count = states.size(); - for (size_t i = 0; i < count; ++i) { - dfa_state_t *s = states[i]; - std::set &rs = s2rules[i]; - // for each final state: choose the rule with the smallest rank - for (std::set::const_iterator j = rs.begin(); j != rs.end(); ++j) { - const size_t rule = *j; - if (s->rule == Rule::NONE || rule < s->rule) { - s->rule = rule; - } - } - // other rules are shadowed by the chosen rule - for (std::set::const_iterator j = rs.begin(); j != rs.end(); ++j) { - const size_t rule = *j; - if (s->rule != rule) { - rules[rule].shadow.insert(rules[s->rule].info->loc.line); - } - } - } + delete[] fin; check_context_selfoverlap(kernels, contexts, line, cond); }