spot 2.13
|
Iterate over all states of an automaton using a DFS. More...
#include <spot/twaalgos/reachiter.hh>
Classes | |
struct | stack_item |
Public Member Functions | |
twa_reachable_iterator_depth_first (const const_twa_ptr &a) | |
virtual void | run () |
Iterate over all reachable states of a spot::tgba. More... | |
virtual bool | want_state (const state *s) const |
virtual void | start () |
Called by run() before starting its iteration. More... | |
virtual void | end () |
Called by run() once all states have been explored. More... | |
virtual void | process_state (const state *s, int n, twa_succ_iterator *si) |
virtual void | process_link (const state *in_s, int in, const state *out_s, int out, const twa_succ_iterator *si) |
Protected Member Functions | |
virtual void | push (const state *s, int sn) |
Push a new state in todo. More... | |
virtual void | pop () |
Pop the DFS stack. More... | |
Protected Attributes | |
const_twa_ptr | aut_ |
The spot::tgba to explore. More... | |
state_map< int > | seen |
States already seen. More... | |
std::deque< stack_item > | todo |
the DFS stack More... | |
Iterate over all states of an automaton using a DFS.
|
virtual |
Called by run() once all states have been explored.
|
protectedvirtual |
Pop the DFS stack.
Reimplemented in spot::twa_reachable_iterator_depth_first_stack.
|
virtual |
Called by run() to process a transition.
in_s | The source state |
in | The source state number. |
out_s | The destination state |
out | The destination state number. |
si | The spot::twa_succ_iterator positioned on the current transition. |
The in_s and out_s states are owned by the spot::twa_reachable_iterator instance and destroyed when the instance is destroyed.
|
virtual |
Called by run() to process a state.
s | The current state. |
n | A unique number assigned to s. |
si | The spot::twa_succ_iterator for s. |
|
protectedvirtual |
Push a new state in todo.
Reimplemented in spot::twa_reachable_iterator_depth_first_stack.
|
virtual |
Iterate over all reachable states of a spot::tgba.
This is a template method that will call start(), end(), want_state(), process_state(), and process_link(), while it iterates over states.
|
virtual |
Called by run() before starting its iteration.
|
virtual |
Called by add_state or next_states implementations to filter states. Default implementation always return true.
|
protected |
The spot::tgba to explore.
|
protected |
States already seen.
|
protected |
the DFS stack