Homogenize passing of automata as pointers, not references.
Disallow copy for security. * src/tgba/tgbabddconcrete.hh (tgba_bdd_concrete): Disallow copy. * src/tgba/tgbaexplicit.hh (tgba_explicit): Likewise. * src/tgba/tgbaexplicit.cc (tgba_explicit::operator=, tgba_explicit::tgba_explicit(tgba_explicit)): Remove. * src/tgba/tgbabddconcreteproduct.cc (tgba_bdd_concrete_product_factory::tgba_bdd_concrete_product_factory, product): Take operand automata as pointers. * src/tgba/tgbabddconcreteproduct.hh (product): Likewise. * src/tgba/tgbaproduct.cc, src/tgba/tgbaproduct.hh: (tgba_product): Disallow copy. (tgba_product::tgba_product): Take operand automata as pointers. * src/tgbaalgos/dotty.cc (dotty_state, dotty_rec, dotty_reachable): Take tgba arguments as pointer. * src/tgbaalgos/dotty.hh (dotty_reachable): Likewise. * src/tgbaalgos/lbtt.cc (fill_todo, lbtt_reachable): Likewise. * src/tgbaalgos/lbtt.hh (lbtt_reachable): Likewise. * src/tgbaalgos/ltl2tgba.cc, src/tgbaalgos/ltl2tgba.hh (ltl_to_tgba): Likewise. * src/tgbaalgos/save.cc (save_rec, tgba_save_reachable): Likewise. * src/tgbaalgos/save.hh (save): Likewise. * src/tgbatest/explicit.cc, src/tgbatest/explprod.cc, src/tgbatest/ltl2tgba.cc, src/tgbatest/ltlprod.cc, src/tgbatest/mixprod.cc, src/tgbatest/readsave.cc, src/tgbatest/spotlbtt.cc, src/tgbatest/tgbaread.cc, src/tgbatest/tripprod.cc: Likewise.
This commit is contained in:
parent
cab3be9795
commit
66b1630c31
25 changed files with 123 additions and 104 deletions
|
|
@ -10,18 +10,18 @@ namespace spot
|
|||
|
||||
/// Process successors.
|
||||
static void
|
||||
save_rec(std::ostream& os, const tgba& g, state* st, seen_set& m)
|
||||
save_rec(std::ostream& os, const tgba* g, state* st, seen_set& m)
|
||||
{
|
||||
m.insert(st);
|
||||
std::string cur = g.format_state(st);
|
||||
tgba_succ_iterator* si = g.succ_iter(st);
|
||||
std::string cur = g->format_state(st);
|
||||
tgba_succ_iterator* si = g->succ_iter(st);
|
||||
for (si->first(); !si->done(); si->next())
|
||||
{
|
||||
state* s = si->current_state();
|
||||
os << "\"" << cur << "\", \"" << g.format_state(s) << "\", ";
|
||||
os << "\"" << cur << "\", \"" << g->format_state(s) << "\", ";
|
||||
|
||||
bdd_print_sat(os, g.get_dict(), si->current_condition()) << ",";
|
||||
bdd_print_acc(os, g.get_dict(), si->current_accepting_conditions())
|
||||
bdd_print_sat(os, g->get_dict(), si->current_condition()) << ",";
|
||||
bdd_print_acc(os, g->get_dict(), si->current_accepting_conditions())
|
||||
<< ";" << std::endl;
|
||||
|
||||
// Destination already explored?
|
||||
|
|
@ -40,9 +40,9 @@ namespace spot
|
|||
}
|
||||
|
||||
std::ostream&
|
||||
tgba_save_reachable(std::ostream& os, const tgba& g)
|
||||
tgba_save_reachable(std::ostream& os, const tgba* g)
|
||||
{
|
||||
const bdd_dict* d = g.get_dict();
|
||||
const bdd_dict* d = g->get_dict();
|
||||
os << "acc =";
|
||||
for (bdd_dict::fv_map::const_iterator ai = d->acc_map.begin();
|
||||
ai != d->acc_map.end(); ++ai)
|
||||
|
|
@ -53,7 +53,7 @@ namespace spot
|
|||
os << ";" << std::endl;
|
||||
|
||||
seen_set m;
|
||||
state* state = g.get_init_state();
|
||||
state* state = g->get_init_state();
|
||||
save_rec(os, g, state, m);
|
||||
// Finally delete all states used as keys in m:
|
||||
for (seen_set::iterator i = m.begin(); i != m.end(); ++i)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue