regex_automata::util::determinize

Function epsilon_closure

source
pub(crate) fn epsilon_closure(
    nfa: &NFA,
    start_nfa_id: StateID,
    look_have: LookSet,
    stack: &mut Vec<StateID>,
    set: &mut SparseSet,
)
Expand description

Compute the epsilon closure for the given NFA state. The epsilon closure consists of all NFA state IDs, including start_nfa_id, that can be reached from start_nfa_id without consuming any input. These state IDs are written to set in the order they are visited, but only if they are not already in set. start_nfa_id must be a valid state ID for the NFA given.

look_have consists of the satisfied assertions at the current position. For conditional look-around epsilon transitions, these are only followed if they are satisfied by look_have.

stack must have length 0. It is used as scratch space for depth first traversal. After returning, it is guaranteed that stack will have length 0.