Introduce a destroy() method on states, and use it instead of delete.
Right now, destroy() just executes "delete this". But in a later version, we will rewrite tgba_explicit so that it does not allocate new states (and the destroy() method for explicit state will do nothing). * src/tgba/state.hh (state::destroy): New method, to replace state::~state() in the future. (shared_state_deleter): New function. * src/evtgba/product.cc, src/evtgbaalgos/reachiter.cc, src/evtgbaalgos/save.cc, src/evtgbaalgos/tgba2evtgba.cc, src/tgba/tgba.cc, src/tgba/tgbaproduct.cc, src/tgba/tgbareduc.cc, src/tgba/tgbasafracomplement.cc, src/tgba/tgbasgba.cc, src/tgba/tgbatba.cc, src/tgba/tgbaunion.cc, src/tgba/wdbacomp.cc, src/tgbaalgos/cutscc.cc, src/tgbaalgos/emptiness.cc, src/tgbaalgos/gtec/ce.cc, src/tgbaalgos/gtec/explscc.cc, src/tgbaalgos/gtec/gtec.cc, src/tgbaalgos/gtec/nsheap.cc, src/tgbaalgos/gv04.cc, src/tgbaalgos/magic.cc, src/tgbaalgos/minimize.cc, src/tgbaalgos/ndfs_result.hxx, src/tgbaalgos/neverclaim.cc, src/tgbaalgos/powerset.hh, src/tgbaalgos/reachiter.cc, src/tgbaalgos/reducerun.cc, src/tgbaalgos/reductgba_sim.cc, src/tgbaalgos/reductgba_sim_del.cc, src/tgbaalgos/replayrun.cc, src/tgbaalgos/safety.cc, src/tgbaalgos/save.cc, src/tgbaalgos/scc.cc, src/tgbaalgos/se05.cc, src/tgbaalgos/tau03.cc, src/tgbaalgos/tau03opt.cc: Adjust to call "s->destroy()" instead of "delete s". * src/saba/sabacomplementtgba.cc, src/tgba/tgbakvcomplement.cc: Pass shared_state_deleter to the shared_ptr constructor, so that it calls destroy() instead of delete.
This commit is contained in:
parent
60930d7a12
commit
574a228583
39 changed files with 259 additions and 167 deletions
38
ChangeLog
38
ChangeLog
|
|
@ -1,6 +1,40 @@
|
||||||
|
2011-01-25 Alexandre Duret-Lutz <adl@lrde.epita.fr>
|
||||||
|
|
||||||
|
Introduce a destroy() method on states, and use it instead of delete.
|
||||||
|
|
||||||
|
Right now, destroy() just executes "delete this". But in a later
|
||||||
|
version, we will rewrite tgba_explicit so that it does not
|
||||||
|
allocate new states (and the destroy() method for explicit state
|
||||||
|
will do nothing).
|
||||||
|
|
||||||
|
* src/tgba/state.hh (state::destroy): New method, to replace
|
||||||
|
state::~state() in the future.
|
||||||
|
(shared_state_deleter): New function.
|
||||||
|
* src/evtgba/product.cc, src/evtgbaalgos/reachiter.cc,
|
||||||
|
src/evtgbaalgos/save.cc, src/evtgbaalgos/tgba2evtgba.cc,
|
||||||
|
src/tgba/tgba.cc, src/tgba/tgbaproduct.cc, src/tgba/tgbareduc.cc,
|
||||||
|
src/tgba/tgbasafracomplement.cc, src/tgba/tgbasgba.cc,
|
||||||
|
src/tgba/tgbatba.cc, src/tgba/tgbaunion.cc, src/tgba/wdbacomp.cc,
|
||||||
|
src/tgbaalgos/cutscc.cc, src/tgbaalgos/emptiness.cc,
|
||||||
|
src/tgbaalgos/gtec/ce.cc, src/tgbaalgos/gtec/explscc.cc,
|
||||||
|
src/tgbaalgos/gtec/gtec.cc, src/tgbaalgos/gtec/nsheap.cc,
|
||||||
|
src/tgbaalgos/gv04.cc, src/tgbaalgos/magic.cc,
|
||||||
|
src/tgbaalgos/minimize.cc, src/tgbaalgos/ndfs_result.hxx,
|
||||||
|
src/tgbaalgos/neverclaim.cc, src/tgbaalgos/powerset.hh,
|
||||||
|
src/tgbaalgos/reachiter.cc, src/tgbaalgos/reducerun.cc,
|
||||||
|
src/tgbaalgos/reductgba_sim.cc,
|
||||||
|
src/tgbaalgos/reductgba_sim_del.cc, src/tgbaalgos/replayrun.cc,
|
||||||
|
src/tgbaalgos/safety.cc, src/tgbaalgos/save.cc,
|
||||||
|
src/tgbaalgos/scc.cc, src/tgbaalgos/se05.cc,
|
||||||
|
src/tgbaalgos/tau03.cc, src/tgbaalgos/tau03opt.cc: Adjust to call
|
||||||
|
"s->destroy()" instead of "delete s".
|
||||||
|
* src/saba/sabacomplementtgba.cc, src/tgba/tgbakvcomplement.cc:
|
||||||
|
Pass shared_state_deleter to the shared_ptr constructor, so that
|
||||||
|
it calls destroy() instead of delete.
|
||||||
|
|
||||||
2011-01-26 Alexandre Duret-Lutz <adl@lrde.epita.fr>
|
2011-01-26 Alexandre Duret-Lutz <adl@lrde.epita.fr>
|
||||||
|
|
||||||
* wrap/python/ajax/ltl2tgba.html: Display the Spot version in
|
* wrap/python/ajax/ltl2tgba.html: Display the Spot version in
|
||||||
the tooltip over the Spot logo.
|
the tooltip over the Spot logo.
|
||||||
|
|
||||||
2011-01-26 Alexandre Duret-Lutz <adl@lrde.epita.fr>
|
2011-01-26 Alexandre Duret-Lutz <adl@lrde.epita.fr>
|
||||||
|
|
@ -17,7 +51,7 @@
|
||||||
|
|
||||||
* wrap/python/ajax/ltl2tgba.html: Remove the auto-update button, and
|
* wrap/python/ajax/ltl2tgba.html: Remove the auto-update button, and
|
||||||
enable auto-update automatically after the first submission. Add
|
enable auto-update automatically after the first submission. Add
|
||||||
tools tips for the "Desired Output" tabs, and the Spot logo.
|
tools tips for the "Desired Output" tabs, and the Spot logo.
|
||||||
Add a email icon to encourage feedback.
|
Add a email icon to encourage feedback.
|
||||||
* wrap/python/ajax/ltl2tgba.css: fix sizes of formula field and
|
* wrap/python/ajax/ltl2tgba.css: fix sizes of formula field and
|
||||||
send button. Set position of mail icon.
|
send button. Set position of mail icon.
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2008 Laboratoire de Recherche et Développement
|
// Copyright (C) 2008, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -43,7 +43,7 @@ namespace spot
|
||||||
~evtgba_product_state()
|
~evtgba_product_state()
|
||||||
{
|
{
|
||||||
for (int j = 0; j < n_; ++j)
|
for (int j = 0; j < n_; ++j)
|
||||||
delete s_[j];
|
s_[j]->destroy();
|
||||||
delete[] s_;
|
delete[] s_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -40,7 +42,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -79,7 +81,7 @@ namespace spot
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
process_link(tn, s->second, si);
|
process_link(tn, s->second, si);
|
||||||
delete current;
|
current->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -48,7 +50,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* s = i->current_state();
|
const state* s = i->current_state();
|
||||||
os_ << " " << quote_unless_bare_word(automata_->format_state(s));
|
os_ << " " << quote_unless_bare_word(automata_->format_state(s));
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
os_ << ";" << std::endl;
|
os_ << ";" << std::endl;
|
||||||
delete i;
|
delete i;
|
||||||
|
|
@ -69,7 +71,7 @@ namespace spot
|
||||||
<< ",";
|
<< ",";
|
||||||
output_acc_set(si->current_acceptance_conditions());
|
output_acc_set(si->current_acceptance_conditions());
|
||||||
os_ << ";" << std::endl;
|
os_ << ";" << std::endl;
|
||||||
delete dest;
|
dest->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Developpement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -72,7 +72,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* s = si->current_state();
|
const state* s = si->current_state();
|
||||||
process_state(s, out, 0);
|
process_state(s, out, 0);
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
rsymbol_set ss = acc_to_symbol_set(si->current_acceptance_conditions());
|
rsymbol_set ss = acc_to_symbol_set(si->current_acceptance_conditions());
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009, 2010 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2010, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -220,7 +220,8 @@ namespace spot
|
||||||
{
|
{
|
||||||
bdd c = iterator->current_condition();
|
bdd c = iterator->current_condition();
|
||||||
if ((c & condition) != bddfalse)
|
if ((c & condition) != bddfalse)
|
||||||
state_list.push_back(shared_state(iterator->current_state()));
|
state_list.push_back(shared_state(iterator->current_state(),
|
||||||
|
shared_state_deleter));
|
||||||
}
|
}
|
||||||
delete iterator;
|
delete iterator;
|
||||||
|
|
||||||
|
|
@ -399,12 +400,14 @@ namespace spot
|
||||||
saba_state_complement_tgba* new_init;
|
saba_state_complement_tgba* new_init;
|
||||||
if (automaton_->state_is_accepting(original_init_state))
|
if (automaton_->state_is_accepting(original_init_state))
|
||||||
new_init =
|
new_init =
|
||||||
new saba_state_complement_tgba(shared_state(original_init_state),
|
new saba_state_complement_tgba(shared_state(original_init_state,
|
||||||
|
shared_state_deleter),
|
||||||
2 * nb_states_,
|
2 * nb_states_,
|
||||||
the_acceptance_cond_);
|
the_acceptance_cond_);
|
||||||
else
|
else
|
||||||
new_init =
|
new_init =
|
||||||
new saba_state_complement_tgba(shared_state(original_init_state),
|
new saba_state_complement_tgba(shared_state(original_init_state,
|
||||||
|
shared_state_deleter),
|
||||||
2 * nb_states_,
|
2 * nb_states_,
|
||||||
bddfalse);
|
bddfalse);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6
|
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6
|
||||||
// (LIP6), département Systèmes Répartis Coopératifs (SRC), Université
|
// (LIP6), département Systèmes Répartis Coopératifs (SRC), Université
|
||||||
|
|
@ -74,6 +74,27 @@ namespace spot
|
||||||
/// Duplicate a state.
|
/// Duplicate a state.
|
||||||
virtual state* clone() const = 0;
|
virtual state* clone() const = 0;
|
||||||
|
|
||||||
|
/// \brief Release a state.
|
||||||
|
///
|
||||||
|
/// Methods from the tgba or tgba_succ_iterator always return a
|
||||||
|
/// new state that you should deallocate with this function.
|
||||||
|
/// Before Spot 0.7, you had to "delete" your state directly.
|
||||||
|
/// Starting with Spot 0.7, you update your code to this function
|
||||||
|
/// instead (which simply calls "delete"). In a future version,
|
||||||
|
/// some subclasses will redefine destroy() to allow better memory
|
||||||
|
/// management (e.g. no memory allocation for explicit automata).
|
||||||
|
virtual void destroy() const
|
||||||
|
{
|
||||||
|
delete this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FIXME: Make the destructor protected after Spot 0.7.
|
||||||
|
//protected:
|
||||||
|
|
||||||
|
/// \brief Destructor.
|
||||||
|
///
|
||||||
|
/// \deprecated Client code should now call
|
||||||
|
/// <code>s->destroy();</code> instead of <code>delete s;</code>.
|
||||||
virtual ~state()
|
virtual ~state()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
@ -156,6 +177,8 @@ namespace spot
|
||||||
|
|
||||||
typedef boost::shared_ptr<const state> shared_state;
|
typedef boost::shared_ptr<const state> shared_state;
|
||||||
|
|
||||||
|
inline void shared_state_deleter(state* s) { s->destroy(); }
|
||||||
|
|
||||||
/// \brief Strict Weak Ordering for \c shared_state
|
/// \brief Strict Weak Ordering for \c shared_state
|
||||||
/// (shared_ptr<const state*>).
|
/// (shared_ptr<const state*>).
|
||||||
/// \ingroup tgba_essentials
|
/// \ingroup tgba_essentials
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'EPITA (LRDE).
|
||||||
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -32,8 +34,10 @@ namespace spot
|
||||||
|
|
||||||
tgba::~tgba()
|
tgba::~tgba()
|
||||||
{
|
{
|
||||||
delete last_support_conditions_input_;
|
if (last_support_conditions_input_)
|
||||||
delete last_support_variables_input_;
|
last_support_conditions_input_->destroy();
|
||||||
|
if (last_support_variables_input_)
|
||||||
|
last_support_variables_input_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
bdd
|
bdd
|
||||||
|
|
@ -43,7 +47,8 @@ namespace spot
|
||||||
|| last_support_conditions_input_->compare(state) != 0)
|
|| last_support_conditions_input_->compare(state) != 0)
|
||||||
{
|
{
|
||||||
last_support_conditions_output_ = compute_support_conditions(state);
|
last_support_conditions_output_ = compute_support_conditions(state);
|
||||||
delete last_support_conditions_input_;
|
if (last_support_conditions_input_)
|
||||||
|
last_support_conditions_input_->destroy();
|
||||||
last_support_conditions_input_ = state->clone();
|
last_support_conditions_input_ = state->clone();
|
||||||
}
|
}
|
||||||
return last_support_conditions_output_;
|
return last_support_conditions_output_;
|
||||||
|
|
@ -56,7 +61,8 @@ namespace spot
|
||||||
|| last_support_variables_input_->compare(state) != 0)
|
|| last_support_variables_input_->compare(state) != 0)
|
||||||
{
|
{
|
||||||
last_support_variables_output_ = compute_support_variables(state);
|
last_support_variables_output_ = compute_support_variables(state);
|
||||||
delete last_support_variables_input_;
|
if (last_support_variables_input_)
|
||||||
|
last_support_variables_input_->destroy();
|
||||||
last_support_variables_input_ = state->clone();
|
last_support_variables_input_ = state->clone();
|
||||||
}
|
}
|
||||||
return last_support_variables_output_;
|
return last_support_variables_output_;
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009, 2010 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2010, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -443,7 +443,7 @@ namespace spot
|
||||||
bdd c = iterator->current_condition();
|
bdd c = iterator->current_condition();
|
||||||
if ((c & condition) != bddfalse)
|
if ((c & condition) != bddfalse)
|
||||||
{
|
{
|
||||||
shared_state s(iterator->current_state());
|
shared_state s(iterator->current_state(), shared_state_deleter);
|
||||||
if (highest_current_ranks_.find(s) != highest_current_ranks_.end())
|
if (highest_current_ranks_.find(s) != highest_current_ranks_.end())
|
||||||
{
|
{
|
||||||
if (i->second < highest_current_ranks_[s])
|
if (i->second < highest_current_ranks_[s])
|
||||||
|
|
@ -470,7 +470,7 @@ namespace spot
|
||||||
bdd c = iterator->current_condition();
|
bdd c = iterator->current_condition();
|
||||||
if ((c & condition) != bddfalse)
|
if ((c & condition) != bddfalse)
|
||||||
{
|
{
|
||||||
shared_state s(iterator->current_state());
|
shared_state s(iterator->current_state(), shared_state_deleter);
|
||||||
highest_state_set_.insert(s);
|
highest_state_set_.insert(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -621,7 +621,8 @@ namespace spot
|
||||||
{
|
{
|
||||||
state_kv_complement* init = new state_kv_complement();
|
state_kv_complement* init = new state_kv_complement();
|
||||||
rank_t r = {2 * nb_states_, bdd_ordered()};
|
rank_t r = {2 * nb_states_, bdd_ordered()};
|
||||||
init->add(shared_state(automaton_->get_init_state()), r);
|
init->add(shared_state(automaton_->get_init_state(), shared_state_deleter),
|
||||||
|
r);
|
||||||
return init;
|
return init;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -41,8 +41,8 @@ namespace spot
|
||||||
|
|
||||||
state_product::~state_product()
|
state_product::~state_product()
|
||||||
{
|
{
|
||||||
delete left_;
|
left_->destroy();
|
||||||
delete right_;
|
right_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
// Copyright (C) 2008, 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2008, 2009, 2011 Laboratoire de Recherche et
|
||||||
// de l'Epita (LRDE).
|
// Developpement de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris
|
||||||
// 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
// 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
||||||
// Université Pierre et Marie Curie.
|
// Université Pierre et Marie Curie.
|
||||||
|
|
@ -156,7 +156,7 @@ namespace spot
|
||||||
spot::state* init = automata_->get_init_state();
|
spot::state* init = automata_->get_init_state();
|
||||||
if (init->compare(s) == 0)
|
if (init->compare(s) == 0)
|
||||||
this->set_init_state(automata_->format_state(s));
|
this->set_init_state(automata_->format_state(s));
|
||||||
delete init;
|
init->destroy();
|
||||||
|
|
||||||
transition* t;
|
transition* t;
|
||||||
for (si->first(); !si->done(); si->next())
|
for (si->first(); !si->done(); si->next())
|
||||||
|
|
@ -165,7 +165,7 @@ namespace spot
|
||||||
t = this->create_transition(s, init);
|
t = this->create_transition(s, init);
|
||||||
this->add_conditions(t, si->current_condition());
|
this->add_conditions(t, si->current_condition());
|
||||||
this->add_acceptance_conditions(t, si->current_acceptance_conditions());
|
this->add_acceptance_conditions(t, si->current_acceptance_conditions());
|
||||||
delete init;
|
init->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -361,7 +361,7 @@ namespace spot
|
||||||
sim1 = sim2;
|
sim1 = sim2;
|
||||||
sim2 = simtmp;
|
sim2 = simtmp;
|
||||||
}
|
}
|
||||||
delete init;
|
init->destroy();
|
||||||
|
|
||||||
sp_map::iterator i = state_predecessor_map_.find(s1);
|
sp_map::iterator i = state_predecessor_map_.find(s1);
|
||||||
if (i == state_predecessor_map_.end()) // 0 predecessor
|
if (i == state_predecessor_map_.end()) // 0 predecessor
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009, 2010 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2010, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -170,7 +170,7 @@ namespace spot
|
||||||
delete *i;
|
delete *i;
|
||||||
|
|
||||||
for (subset_t::iterator i = nodes.begin(); i != nodes.end(); ++i)
|
for (subset_t::iterator i = nodes.begin(); i != nodes.end(); ++i)
|
||||||
delete *i;
|
(*i)->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
const safra_tree&
|
const safra_tree&
|
||||||
|
|
@ -403,7 +403,7 @@ namespace spot
|
||||||
const state* s = *node_it;
|
const state* s = *node_it;
|
||||||
(*child_it)->remove_node_from_children(*node_it);
|
(*child_it)->remove_node_from_children(*node_it);
|
||||||
(*child_it)->nodes.erase(node_it++);
|
(*child_it)->nodes.erase(node_it++);
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
@ -431,7 +431,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const spot::state* s = *it;
|
const spot::state* s = *it;
|
||||||
(*child_it)->nodes.erase(it);
|
(*child_it)->nodes.erase(it);
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
(*child_it)->remove_node_from_children(state);
|
(*child_it)->remove_node_from_children(state);
|
||||||
}
|
}
|
||||||
|
|
@ -679,7 +679,7 @@ namespace spot
|
||||||
for (safra_tree::tr_cache_t::iterator j = i->second.begin();
|
for (safra_tree::tr_cache_t::iterator j = i->second.begin();
|
||||||
j != i->second.end();
|
j != i->second.end();
|
||||||
++j)
|
++j)
|
||||||
delete j->second;
|
j->second->destroy();
|
||||||
// delete node;
|
// delete node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -48,7 +48,7 @@ namespace spot
|
||||||
virtual
|
virtual
|
||||||
~state_sgba_proxy()
|
~state_sgba_proxy()
|
||||||
{
|
{
|
||||||
delete s_;
|
s_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
state*
|
state*
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2010 Laboratoire de Recherche et Développement de
|
// Copyright (C) 2010, 2011 Laboratoire de Recherche et Développement de
|
||||||
// l'Epita.
|
// l'Epita.
|
||||||
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris
|
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris
|
||||||
// 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
// 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
||||||
|
|
@ -56,7 +56,7 @@ namespace spot
|
||||||
virtual
|
virtual
|
||||||
~state_tba_proxy()
|
~state_tba_proxy()
|
||||||
{
|
{
|
||||||
delete s_;
|
s_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
state*
|
state*
|
||||||
|
|
@ -204,7 +204,7 @@ namespace spot
|
||||||
else // Yes, combine labels.
|
else // Yes, combine labels.
|
||||||
{
|
{
|
||||||
id->second |= it->current_condition();
|
id->second |= it->current_condition();
|
||||||
delete dest;
|
dest->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete it;
|
delete it;
|
||||||
|
|
@ -219,7 +219,7 @@ namespace spot
|
||||||
const state* d = i->first.first;
|
const state* d = i->first.first;
|
||||||
// Advance i before deleting d.
|
// Advance i before deleting d.
|
||||||
++i;
|
++i;
|
||||||
delete d;
|
d->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -318,7 +318,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the key.
|
// Advance the iterator before deleting the key.
|
||||||
const state* s = i->first;
|
const state* s = i->first;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -452,15 +452,15 @@ namespace spot
|
||||||
// duplication of the initial state.
|
// duplication of the initial state.
|
||||||
// The cycle_start_ points to the right starting
|
// The cycle_start_ points to the right starting
|
||||||
// point already, so just return.
|
// point already, so just return.
|
||||||
delete dest;
|
dest->destroy();
|
||||||
delete it;
|
delete it;
|
||||||
delete init;
|
init->destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
delete dest;
|
dest->destroy();
|
||||||
}
|
}
|
||||||
delete it;
|
delete it;
|
||||||
delete init;
|
init->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we arrive here either because the number of acceptance
|
// If we arrive here either because the number of acceptance
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -38,8 +38,8 @@ namespace spot
|
||||||
|
|
||||||
state_union::~state_union()
|
state_union::~state_union()
|
||||||
{
|
{
|
||||||
delete left_;
|
left_->destroy();
|
||||||
delete right_;
|
right_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|
@ -293,8 +293,8 @@ namespace spot
|
||||||
right_acc_missing_,
|
right_acc_missing_,
|
||||||
left_var_missing_,
|
left_var_missing_,
|
||||||
right_var_missing_);
|
right_var_missing_);
|
||||||
delete left_init;
|
left_init->destroy();
|
||||||
delete right_init;
|
right_init->destroy();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -44,7 +44,8 @@ namespace spot
|
||||||
virtual
|
virtual
|
||||||
~state_wdba_comp_proxy()
|
~state_wdba_comp_proxy()
|
||||||
{
|
{
|
||||||
delete s_;
|
if (s_)
|
||||||
|
s_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
state*
|
state*
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Developpement de
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Developpement
|
||||||
// l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
//
|
//
|
||||||
|
|
@ -72,7 +72,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
delete dst;
|
dst->destroy();
|
||||||
}
|
}
|
||||||
tgba_explicit::transition* t =
|
tgba_explicit::transition* t =
|
||||||
sub_a->create_transition(cur_format, dst_format);
|
sub_a->create_transition(cur_format, dst_format);
|
||||||
|
|
@ -83,7 +83,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
delete dst;
|
dst->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete sit;
|
delete sit;
|
||||||
|
|
@ -93,7 +93,7 @@ namespace spot
|
||||||
// Free visited states.
|
// Free visited states.
|
||||||
for (it2 = seen.begin(); it2 != seen.end(); it2++)
|
for (it2 = seen.begin(); it2 != seen.end(); it2++)
|
||||||
{
|
{
|
||||||
delete *it2;
|
(*it2)->destroy();
|
||||||
}
|
}
|
||||||
return sub_a;
|
return sub_a;
|
||||||
}
|
}
|
||||||
|
|
@ -255,7 +255,7 @@ namespace spot
|
||||||
scc_sizes[i] = m.states_of(i).size();
|
scc_sizes[i] = m.states_of(i).size();
|
||||||
state* initial_state = a->get_init_state();
|
state* initial_state = a->get_init_state();
|
||||||
unsigned init = m.scc_of_state(initial_state);
|
unsigned init = m.scc_of_state(initial_state);
|
||||||
delete initial_state;
|
initial_state->destroy();
|
||||||
// Find all interesting pathes in our automaton.
|
// Find all interesting pathes in our automaton.
|
||||||
find_paths_sub(init, m, d, scc_sizes);
|
find_paths_sub(init, m, d, scc_sizes);
|
||||||
|
|
||||||
|
|
@ -272,7 +272,7 @@ namespace spot
|
||||||
std::vector<std::vector<sccs_set* > >* rec_paths = find_paths(a, m);
|
std::vector<std::vector<sccs_set* > >* rec_paths = find_paths(a, m);
|
||||||
state* initial_state = a->get_init_state();
|
state* initial_state = a->get_init_state();
|
||||||
unsigned init = m.scc_of_state(initial_state);
|
unsigned init = m.scc_of_state(initial_state);
|
||||||
delete initial_state;
|
initial_state->destroy();
|
||||||
std::vector<sccs_set*>* final_sets =&(*rec_paths)[init];
|
std::vector<sccs_set*>* final_sets =&(*rec_paths)[init];
|
||||||
if (rec_paths->empty())
|
if (rec_paths->empty())
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -42,9 +42,9 @@ namespace spot
|
||||||
tgba_run::~tgba_run()
|
tgba_run::~tgba_run()
|
||||||
{
|
{
|
||||||
for (steps::const_iterator i = prefix.begin(); i != prefix.end(); ++i)
|
for (steps::const_iterator i = prefix.begin(); i != prefix.end(); ++i)
|
||||||
delete i->s;
|
i->s->destroy();
|
||||||
for (steps::const_iterator i = cycle.begin(); i != cycle.end(); ++i)
|
for (steps::const_iterator i = cycle.begin(); i != cycle.end(); ++i)
|
||||||
delete i->s;
|
i->s->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
tgba_run::tgba_run(const tgba_run& run)
|
tgba_run::tgba_run(const tgba_run& run)
|
||||||
|
|
@ -345,7 +345,7 @@ namespace spot
|
||||||
|
|
||||||
// browse the actual outgoing transitions
|
// browse the actual outgoing transitions
|
||||||
tgba_succ_iterator* j = a->succ_iter(s);
|
tgba_succ_iterator* j = a->succ_iter(s);
|
||||||
delete s;
|
s->destroy(); // FIXME: is it always legitimate to destroy s before j?
|
||||||
for (j->first(); !j->done(); j->next())
|
for (j->first(); !j->done(); j->next())
|
||||||
{
|
{
|
||||||
if (j->current_condition() != label
|
if (j->current_condition() != label
|
||||||
|
|
@ -355,7 +355,7 @@ namespace spot
|
||||||
const state* s2 = j->current_state();
|
const state* s2 = j->current_state();
|
||||||
if (s2->compare(next) != 0)
|
if (s2->compare(next) != 0)
|
||||||
{
|
{
|
||||||
delete s2;
|
s2->destroy();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -386,7 +386,7 @@ namespace spot
|
||||||
if (l == &run->cycle && i != l->begin())
|
if (l == &run->cycle && i != l->begin())
|
||||||
seen_acc |= acc;
|
seen_acc |= acc;
|
||||||
}
|
}
|
||||||
delete s;
|
s->destroy();
|
||||||
|
|
||||||
assert(seen_acc == a->all_acceptance_conditions());
|
assert(seen_acc == a->all_acceptance_conditions());
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,8 @@
|
||||||
|
// Copyright (C) 2010, 2011 Laboratoire de Recherche et Développement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
// Copyright (C) 2010 Laboratoire de Recherche et Développement de
|
|
||||||
// l'Epita (LRDE).
|
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
//
|
//
|
||||||
|
|
@ -55,7 +55,7 @@ namespace spot
|
||||||
// Ignore unknown states ...
|
// Ignore unknown states ...
|
||||||
if (!sip.first)
|
if (!sip.first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// ... as well as dead states.
|
// ... as well as dead states.
|
||||||
|
|
@ -129,7 +129,7 @@ namespace spot
|
||||||
if (ps != ss.end())
|
if (ps != ss.end())
|
||||||
{
|
{
|
||||||
// The initial state is on the cycle.
|
// The initial state is on the cycle.
|
||||||
delete prefix_start;
|
prefix_start->destroy();
|
||||||
cycle_entry_point = *ps;
|
cycle_entry_point = *ps;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -198,7 +198,7 @@ namespace spot
|
||||||
// Ignore unknown states.
|
// Ignore unknown states.
|
||||||
if (!sip.first)
|
if (!sip.first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// Stay in the final SCC.
|
// Stay in the final SCC.
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -30,7 +32,7 @@ namespace spot
|
||||||
if (it != states.end())
|
if (it != states.end())
|
||||||
{
|
{
|
||||||
if (s != *it)
|
if (s != *it)
|
||||||
delete s;
|
s->destroy();
|
||||||
return *it;
|
return *it;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2008 Laboratoire de Recherche et Développement
|
// Copyright (C) 2008, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2003, 2004, 2005, 2006 Laboratoire d'Informatique de
|
// Copyright (C) 2003, 2004, 2005, 2006 Laboratoire d'Informatique de
|
||||||
// Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
// Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
||||||
|
|
@ -376,7 +376,7 @@ namespace spot
|
||||||
numbered_state_heap::state_index_p spi = ecs_->h->index(q->s);
|
numbered_state_heap::state_index_p spi = ecs_->h->index(q->s);
|
||||||
// ... or if it is an unknown state.
|
// ... or if it is an unknown state.
|
||||||
if (spi.first == 0)
|
if (spi.first == 0)
|
||||||
delete q->s;
|
q->s->destroy();
|
||||||
}
|
}
|
||||||
dec_depth(todo.back().q.size() + 1);
|
dec_depth(todo.back().q.size() + 1);
|
||||||
todo.pop_back();
|
todo.pop_back();
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Développement
|
||||||
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2006 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2006 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -84,7 +86,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the key.
|
// Advance the iterator before deleting the key.
|
||||||
const state* s = i->first;
|
const state* s = i->first;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -105,7 +107,7 @@ namespace spot
|
||||||
res.second = i->second;
|
res.second = i->second;
|
||||||
|
|
||||||
if (s != i->first)
|
if (s != i->first)
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
@ -127,7 +129,7 @@ namespace spot
|
||||||
res.second = &i->second;
|
res.second = &i->second;
|
||||||
|
|
||||||
if (s != i->first)
|
if (s != i->first)
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,8 @@
|
||||||
|
// Copyright (C) 2008, 2010, 2011 Laboratoire de recherche et
|
||||||
|
// développement de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6
|
||||||
// (LIP6), département Systèmes Répartis Coopératifs (SRC), Université
|
// (LIP6), département Systèmes Répartis Coopératifs (SRC), Université
|
||||||
// Pierre et Marie Curie.
|
// Pierre et Marie Curie.
|
||||||
// Copyright (C) 2008, 2010 Laboratoire de recherche et développement
|
|
||||||
// de l'Epita (LRDE).
|
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
//
|
//
|
||||||
|
|
@ -88,7 +88,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -156,7 +156,7 @@ namespace spot
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
set_states(h.size());
|
set_states(h.size());
|
||||||
|
|
@ -355,11 +355,11 @@ namespace spot
|
||||||
// Or it is still on the stack but not in the SCC
|
// Or it is still on the stack but not in the SCC
|
||||||
|| data.stack[j->second].lowlink < scc_root)
|
|| data.stack[j->second].lowlink < scc_root)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
r->inc_ars_cycle_states();
|
r->inc_ars_cycle_states();
|
||||||
delete s;
|
s->destroy();
|
||||||
return j->first;
|
return j->first;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de recherche et développement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -292,7 +294,7 @@ namespace spot
|
||||||
// to visit white states either if a cycle can be missed
|
// to visit white states either if a cycle can be missed
|
||||||
// with bit-state hashing search.
|
// with bit-state hashing search.
|
||||||
trace << " It is white, pop it" << std::endl;
|
trace << " It is white, pop it" << std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
else if (c.get_color() == BLUE)
|
else if (c.get_color() == BLUE)
|
||||||
{
|
{
|
||||||
|
|
@ -463,7 +465,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -474,7 +476,7 @@ namespace spot
|
||||||
return color_ref(0);
|
return color_ref(0);
|
||||||
if (s!=it->first)
|
if (s!=it->first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = it->first;
|
s = it->first;
|
||||||
}
|
}
|
||||||
return color_ref(&(it->second));
|
return color_ref(&(it->second));
|
||||||
|
|
@ -564,7 +566,7 @@ namespace spot
|
||||||
|
|
||||||
void pop_notify(const state* s) const
|
void pop_notify(const state* s) const
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool has_been_visited(const state* s) const
|
bool has_been_visited(const state* s) const
|
||||||
|
|
|
||||||
|
|
@ -105,7 +105,7 @@ namespace spot
|
||||||
seen->insert(dst);
|
seen->insert(dst);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
delete dst;
|
dst->destroy();
|
||||||
}
|
}
|
||||||
delete sit;
|
delete sit;
|
||||||
}
|
}
|
||||||
|
|
@ -151,7 +151,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* dst = succit->current_state();
|
const state* dst = succit->current_state();
|
||||||
unsigned dst_num = state_num[dst];
|
unsigned dst_num = state_num[dst];
|
||||||
delete dst;
|
dst->destroy();
|
||||||
trs* t = res->create_transition(src_num, dst_num);
|
trs* t = res->create_transition(src_num, dst_num);
|
||||||
res->add_conditions(t, succit->current_condition());
|
res->add_conditions(t, succit->current_condition());
|
||||||
if (accepting)
|
if (accepting)
|
||||||
|
|
@ -163,7 +163,7 @@ namespace spot
|
||||||
res->merge_transitions();
|
res->merge_transitions();
|
||||||
const state* init_state = a->get_init_state();
|
const state* init_state = a->get_init_state();
|
||||||
unsigned init_num = state_num[init_state];
|
unsigned init_num = state_num[init_state];
|
||||||
delete init_state;
|
init_state->destroy();
|
||||||
res->set_init_state(init_num);
|
res->set_init_state(init_num);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
@ -190,7 +190,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
hash_set::const_iterator old = i;
|
hash_set::const_iterator old = i;
|
||||||
++i;
|
++i;
|
||||||
delete *old;
|
(*old)->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -205,7 +205,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = *i;
|
s = *i;
|
||||||
}
|
}
|
||||||
// Ignore states outside SCC #n.
|
// Ignore states outside SCC #n.
|
||||||
|
|
@ -250,11 +250,11 @@ namespace spot
|
||||||
for (n = 1, i = loop.begin(); n < loop_size; ++n, ++i)
|
for (n = 1, i = loop.begin(); n < loop_size; ++n, ++i)
|
||||||
{
|
{
|
||||||
loop_a.create_transition(n - 1, n)->condition = i->label;
|
loop_a.create_transition(n - 1, n)->condition = i->label;
|
||||||
delete i->s;
|
i->s->destroy();
|
||||||
}
|
}
|
||||||
assert(i != loop.end());
|
assert(i != loop.end());
|
||||||
loop_a.create_transition(n - 1, 0)->condition = i->label;
|
loop_a.create_transition(n - 1, 0)->condition = i->label;
|
||||||
delete i->s;
|
i->s->destroy();
|
||||||
assert(++i == loop.end());
|
assert(++i == loop.end());
|
||||||
|
|
||||||
const state* loop_a_init = loop_a.get_init_state();
|
const state* loop_a_init = loop_a.get_init_state();
|
||||||
|
|
@ -284,7 +284,7 @@ namespace spot
|
||||||
delete p;
|
delete p;
|
||||||
}
|
}
|
||||||
|
|
||||||
delete loop_a_init;
|
loop_a_init->destroy();
|
||||||
return accepting;
|
return accepting;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -383,7 +383,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* dst = si->current_state();
|
const state* dst = si->current_state();
|
||||||
unsigned dst_set = state_set_map[dst];
|
unsigned dst_set = state_set_map[dst];
|
||||||
delete dst;
|
dst->destroy();
|
||||||
f |= (bdd_ithvar(dst_set) & si->current_condition());
|
f |= (bdd_ithvar(dst_set) & si->current_condition());
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
|
|
@ -480,7 +480,7 @@ namespace spot
|
||||||
for (hit = state_set_map.begin(); hit != state_set_map.end();)
|
for (hit = state_set_map.begin(); hit != state_set_map.end();)
|
||||||
{
|
{
|
||||||
hash_map::iterator old = hit++;
|
hash_map::iterator old = hit++;
|
||||||
delete old->first;
|
old->first->destroy();
|
||||||
}
|
}
|
||||||
std::list<hash_set*>::iterator it;
|
std::list<hash_set*>::iterator it;
|
||||||
for (it = done.begin(); it != done.end(); ++it)
|
for (it = done.begin(); it != done.end(); ++it)
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de recherche et développement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005, 2006 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005, 2006 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -190,7 +192,7 @@ namespace spot
|
||||||
(void) b;
|
(void) b;
|
||||||
}
|
}
|
||||||
|
|
||||||
delete start;
|
start->destroy();
|
||||||
|
|
||||||
assert(!acc_trans.empty());
|
assert(!acc_trans.empty());
|
||||||
|
|
||||||
|
|
@ -205,8 +207,8 @@ namespace spot
|
||||||
for (typename accepting_transitions_list::const_iterator i =
|
for (typename accepting_transitions_list::const_iterator i =
|
||||||
acc_trans.begin(); i != acc_trans.end(); ++i)
|
acc_trans.begin(); i != acc_trans.end(); ++i)
|
||||||
{
|
{
|
||||||
delete i->source;
|
i->source->destroy();
|
||||||
delete i->dest;
|
i->dest->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
return run;
|
return run;
|
||||||
|
|
@ -240,13 +242,13 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* s = *i;
|
const state* s = *i;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
for (state_set::iterator i = dead.begin(); i != dead.end();)
|
for (state_set::iterator i = dead.begin(); i != dead.end();)
|
||||||
{
|
{
|
||||||
const state* s = *i;
|
const state* s = *i;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -282,7 +284,7 @@ namespace spot
|
||||||
if (dead.find(s_prime) != dead.end())
|
if (dead.find(s_prime) != dead.end())
|
||||||
{
|
{
|
||||||
ndfsr_trace << " it is dead, pop it" << std::endl;
|
ndfsr_trace << " it is dead, pop it" << std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
else if (seen.find(s_prime) == seen.end())
|
else if (seen.find(s_prime) == seen.end())
|
||||||
{
|
{
|
||||||
|
|
@ -309,23 +311,23 @@ namespace spot
|
||||||
if (covered_acc == a_->all_acceptance_conditions())
|
if (covered_acc == a_->all_acceptance_conditions())
|
||||||
{
|
{
|
||||||
clean(st1, seen, dead);
|
clean(st1, seen, dead);
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ndfsr_trace << " already seen, pop it" << std::endl;
|
ndfsr_trace << " already seen, pop it" << std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ndfsr_trace << " not seen during the search, pop it"
|
ndfsr_trace << " not seen during the search, pop it"
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -384,7 +386,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = *i;
|
const state* ptr = *i;
|
||||||
++i;
|
++i;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -403,7 +405,7 @@ namespace spot
|
||||||
|| seen.find(s) != seen.end()
|
|| seen.find(s) != seen.end()
|
||||||
|| dead.find(s) != dead.end())
|
|| dead.find(s) != dead.end())
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
ars->inc_ars_cycle_states();
|
ars->inc_ars_cycle_states();
|
||||||
|
|
@ -477,7 +479,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = *i;
|
const state* ptr = *i;
|
||||||
++i;
|
++i;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -499,7 +501,7 @@ namespace spot
|
||||||
ndfsr_trace << " not visited" << std::endl;
|
ndfsr_trace << " not visited" << std::endl;
|
||||||
else
|
else
|
||||||
ndfsr_trace << " already seen" << std::endl;
|
ndfsr_trace << " already seen" << std::endl;
|
||||||
delete s;
|
s->destroy();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
ndfsr_trace << " OK" << std::endl;
|
ndfsr_trace << " OK" << std::endl;
|
||||||
|
|
@ -634,7 +636,7 @@ namespace spot
|
||||||
if (ps != target.end())
|
if (ps != target.end())
|
||||||
{
|
{
|
||||||
// The initial state is on the cycle.
|
// The initial state is on the cycle.
|
||||||
delete prefix_start;
|
prefix_start->destroy();
|
||||||
cycle_entry_point = ps->first->clone();
|
cycle_entry_point = ps->first->clone();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -653,7 +655,7 @@ namespace spot
|
||||||
&& cycle_entry_point->compare(cycle_ep_it->s); ++cycle_ep_it)
|
&& cycle_entry_point->compare(cycle_ep_it->s); ++cycle_ep_it)
|
||||||
continue;
|
continue;
|
||||||
assert(cycle_ep_it != run->cycle.end());
|
assert(cycle_ep_it != run->cycle.end());
|
||||||
delete cycle_entry_point;
|
cycle_entry_point->destroy();
|
||||||
|
|
||||||
// Now shift the cycle so it starts on cycle_entry_point.
|
// Now shift the cycle so it starts on cycle_entry_point.
|
||||||
run->cycle.splice(run->cycle.end(), run->cycle,
|
run->cycle.splice(run->cycle.end(), run->cycle,
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -71,7 +71,7 @@ namespace spot
|
||||||
os_ << " skip" << std::endl;
|
os_ << " skip" << std::endl;
|
||||||
}
|
}
|
||||||
os_ << "}" << std::endl;
|
os_ << "}" << std::endl;
|
||||||
delete init_;
|
init_->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
|
@ -110,7 +110,7 @@ namespace spot
|
||||||
label = "accept_S" + ns;
|
label = "accept_S" + ns;
|
||||||
else
|
else
|
||||||
label = "accept_all";
|
label = "accept_all";
|
||||||
delete current;
|
current->destroy();
|
||||||
}
|
}
|
||||||
delete it;
|
delete it;
|
||||||
}
|
}
|
||||||
|
|
@ -156,7 +156,7 @@ namespace spot
|
||||||
os_ << " if" << std::endl;
|
os_ << " if" << std::endl;
|
||||||
fi_needed_ = true;
|
fi_needed_ = true;
|
||||||
}
|
}
|
||||||
delete current;
|
current->destroy();
|
||||||
}
|
}
|
||||||
delete it;
|
delete it;
|
||||||
}
|
}
|
||||||
|
|
@ -174,7 +174,7 @@ namespace spot
|
||||||
f->destroy();
|
f->destroy();
|
||||||
state* current = si->current_state();
|
state* current = si->current_state();
|
||||||
os_ << ") -> goto " << get_state_label(current, out) << std::endl;
|
os_ << ") -> goto " << get_state_label(current, out) << std::endl;
|
||||||
delete current;
|
current->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -47,7 +47,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the key.
|
// Advance the iterator before deleting the key.
|
||||||
const state* s = *i;
|
const state* s = *i;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -63,7 +63,7 @@ namespace spot
|
||||||
state_set::const_iterator i = states.find(s);
|
state_set::const_iterator i = states.find(s);
|
||||||
if (i != states.end())
|
if (i != states.end())
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = *i;
|
s = *i;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2003, 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -42,7 +42,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -80,7 +80,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
if (ws)
|
if (ws)
|
||||||
process_link(t, tn, s->first, s->second, si);
|
process_link(t, tn, s->first, s->second, si);
|
||||||
delete current;
|
current->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Développement
|
||||||
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -46,7 +48,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = *i;
|
const state* ptr = *i;
|
||||||
++i;
|
++i;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -70,7 +72,7 @@ namespace spot
|
||||||
seen.insert(s);
|
seen.insert(s);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = *i;
|
s = *i;
|
||||||
}
|
}
|
||||||
return s;
|
return s;
|
||||||
|
|
@ -162,7 +164,7 @@ namespace spot
|
||||||
if (ps != ss.end())
|
if (ps != ss.end())
|
||||||
{
|
{
|
||||||
// The initial state is on the cycle.
|
// The initial state is on the cycle.
|
||||||
delete prefix_start;
|
prefix_start->destroy();
|
||||||
cycle_entry_point = *ps;
|
cycle_entry_point = *ps;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2009 Laboratoire de Recherche et Développement
|
// Copyright (C) 2009, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005, 2007 Laboratoire d'Informatique de
|
// Copyright (C) 2004, 2005, 2007 Laboratoire d'Informatique de
|
||||||
// Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
// Paris 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
||||||
|
|
@ -469,7 +469,7 @@ namespace spot
|
||||||
else
|
else
|
||||||
delete p;
|
delete p;
|
||||||
}
|
}
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
}
|
}
|
||||||
|
|
@ -513,7 +513,7 @@ namespace spot
|
||||||
(*j)->add_succ(*i);
|
(*j)->add_succ(*i);
|
||||||
++nb_ds;
|
++nb_ds;
|
||||||
}
|
}
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
}
|
}
|
||||||
|
|
@ -534,7 +534,7 @@ namespace spot
|
||||||
(*i)->add_succ(*j);
|
(*i)->add_succ(*j);
|
||||||
++nb_sd;
|
++nb_sd;
|
||||||
}
|
}
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
delete si;
|
delete si;
|
||||||
}
|
}
|
||||||
|
|
@ -656,7 +656,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = j->first;
|
const state* ptr = j->first;
|
||||||
++j;
|
++j;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2008 Laboratoire de Recherche et Développement
|
// Copyright (C) 2008, 2011 Laboratoire de Recherche et Développement
|
||||||
// de l'Epita (LRDE).
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
|
|
@ -410,7 +410,7 @@ namespace spot
|
||||||
s = si->current_state();
|
s = si->current_state();
|
||||||
if (s->compare(*i1) == 0)
|
if (s->compare(*i1) == 0)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
duplicator_node_delayed* dn
|
duplicator_node_delayed* dn
|
||||||
= add_duplicator_node_delayed(*i1,
|
= add_duplicator_node_delayed(*i1,
|
||||||
sn->get_duplicator_node(),
|
sn->get_duplicator_node(),
|
||||||
|
|
@ -426,7 +426,7 @@ namespace spot
|
||||||
build_recurse_successor_duplicator(dn, sn, os2);
|
build_recurse_successor_duplicator(dn, sn, os2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -463,7 +463,7 @@ namespace spot
|
||||||
|
|
||||||
if (s->compare(*i1) == 0)
|
if (s->compare(*i1) == 0)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
spoiler_node_delayed* sn_n
|
spoiler_node_delayed* sn_n
|
||||||
= add_spoiler_node_delayed(dn->get_spoiler_node(),
|
= add_spoiler_node_delayed(dn->get_spoiler_node(),
|
||||||
*i1,
|
*i1,
|
||||||
|
|
@ -478,7 +478,7 @@ namespace spot
|
||||||
build_recurse_successor_spoiler(sn_n, os2);
|
build_recurse_successor_spoiler(sn_n, os2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -668,7 +668,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = j->first;
|
const state* ptr = j->first;
|
||||||
++j;
|
++j;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Développement
|
||||||
|
// de l'Epita (LRDE).
|
||||||
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -80,7 +82,7 @@ namespace spot
|
||||||
<< a->format_state(i->s) << std::endl
|
<< a->format_state(i->s) << std::endl
|
||||||
<< "does not match initial state of automata: "
|
<< "does not match initial state of automata: "
|
||||||
<< a->format_state(s) << std::endl;
|
<< a->format_state(s) << std::endl;
|
||||||
delete s;
|
s->destroy();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -98,7 +100,7 @@ namespace spot
|
||||||
for (d = o->second.begin(); d != o->second.end(); ++d)
|
for (d = o->second.begin(); d != o->second.end(); ++d)
|
||||||
msg << " == " << *d;
|
msg << " == " << *d;
|
||||||
o->second.insert(serial);
|
o->second.insert(serial);
|
||||||
delete s;
|
s->destroy();
|
||||||
s = o->first;
|
s = o->first;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -142,7 +144,7 @@ namespace spot
|
||||||
// When not debugging, S is not used as key in SEEN, so we can
|
// When not debugging, S is not used as key in SEEN, so we can
|
||||||
// delete it right now.
|
// delete it right now.
|
||||||
if (!debug)
|
if (!debug)
|
||||||
delete s;
|
s->destroy();
|
||||||
for (j->first(); !j->done(); j->next())
|
for (j->first(); !j->done(); j->next())
|
||||||
{
|
{
|
||||||
if (j->current_condition() != label
|
if (j->current_condition() != label
|
||||||
|
|
@ -152,7 +154,7 @@ namespace spot
|
||||||
const state* s2 = j->current_state();
|
const state* s2 = j->current_state();
|
||||||
if (s2->compare(next))
|
if (s2->compare(next))
|
||||||
{
|
{
|
||||||
delete s2;
|
s2->destroy();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -185,11 +187,11 @@ namespace spot
|
||||||
<< bdd_format_accset(a->get_dict(),
|
<< bdd_format_accset(a->get_dict(),
|
||||||
j->current_acceptance_conditions())
|
j->current_acceptance_conditions())
|
||||||
<< " going to " << a->format_state(s2) << std::endl;
|
<< " going to " << a->format_state(s2) << std::endl;
|
||||||
delete s2;
|
s2->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete j;
|
delete j;
|
||||||
delete s;
|
s->destroy();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (debug)
|
if (debug)
|
||||||
|
|
@ -232,7 +234,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete s;
|
s->destroy();
|
||||||
if (all_acc != expected_all_acc)
|
if (all_acc != expected_all_acc)
|
||||||
{
|
{
|
||||||
if (debug)
|
if (debug)
|
||||||
|
|
@ -251,7 +253,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = o->first;
|
const state* ptr = o->first;
|
||||||
++o;
|
++o;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (C) 2010 Laboratoire de Recherche et Développement de
|
// Copyright (C) 2010, 2011 Laboratoire de Recherche et Développement de
|
||||||
// l'Epita (LRDE)
|
// l'Epita (LRDE)
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
|
|
@ -58,7 +58,7 @@ namespace spot
|
||||||
bdd cond = it->current_condition();
|
bdd cond = it->current_condition();
|
||||||
it->next();
|
it->next();
|
||||||
result = (!dest->compare(s)) && it->done() && (cond == bddtrue);
|
result = (!dest->compare(s)) && it->done() && (cond == bddtrue);
|
||||||
delete dest;
|
dest->destroy();
|
||||||
delete it;
|
delete it;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,8 @@
|
||||||
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2011 Laboratoire de Recherche et Développement de
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// l'Epita (LRDE)
|
||||||
// et Marie Curie.
|
// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris
|
||||||
|
// 6 (LIP6), département Systèmes Répartis Coopératifs (SRC),
|
||||||
|
// Université Pierre et Marie Curie.
|
||||||
//
|
//
|
||||||
// This file is part of Spot, a model checking library.
|
// This file is part of Spot, a model checking library.
|
||||||
//
|
//
|
||||||
|
|
@ -59,7 +61,7 @@ namespace spot
|
||||||
escape_str(os_, bdd_format_formula(d, si->current_condition()));
|
escape_str(os_, bdd_format_formula(d, si->current_condition()));
|
||||||
os_ << "\",";
|
os_ << "\",";
|
||||||
print_acc(si->current_acceptance_conditions()) << ";" << std::endl;
|
print_acc(si->current_acceptance_conditions()) << ";" << std::endl;
|
||||||
delete dest;
|
dest->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -54,7 +54,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the key.
|
// Advance the iterator before deleting the key.
|
||||||
const state* s = i->first;
|
const state* s = i->first;
|
||||||
++i;
|
++i;
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -63,7 +63,7 @@ namespace spot
|
||||||
{
|
{
|
||||||
state* in = aut_->get_init_state();
|
state* in = aut_->get_init_state();
|
||||||
int val = scc_of_state(in);
|
int val = scc_of_state(in);
|
||||||
delete in;
|
in->destroy();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -231,7 +231,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we know the state, reuse the previous object.
|
// If we know the state, reuse the previous object.
|
||||||
delete dest;
|
dest->destroy();
|
||||||
dest = spi->first;
|
dest = spi->first;
|
||||||
|
|
||||||
// Have we reached a maximal SCC?
|
// Have we reached a maximal SCC?
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -292,7 +294,7 @@ namespace spot
|
||||||
// collision, this property does not hold.
|
// collision, this property does not hold.
|
||||||
trace << " It is white (due to collision), pop it"
|
trace << " It is white (due to collision), pop it"
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
else if (c.get_color() == RED)
|
else if (c.get_color() == RED)
|
||||||
{
|
{
|
||||||
|
|
@ -499,14 +501,14 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = *sc;
|
const state* ptr = *sc;
|
||||||
++sc;
|
++sc;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
hash_type::const_iterator s = h.begin();
|
hash_type::const_iterator s = h.begin();
|
||||||
while (s != h.end())
|
while (s != h.end())
|
||||||
{
|
{
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -520,14 +522,14 @@ namespace spot
|
||||||
return color_ref(0); // white state
|
return color_ref(0); // white state
|
||||||
if (s!=it->first)
|
if (s!=it->first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = it->first;
|
s = it->first;
|
||||||
}
|
}
|
||||||
return color_ref(&(it->second)); // blue or red state
|
return color_ref(&(it->second)); // blue or red state
|
||||||
}
|
}
|
||||||
if (s!=*ic)
|
if (s!=*ic)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = *ic;
|
s = *ic;
|
||||||
}
|
}
|
||||||
return color_ref(&h, &hc, *ic); // cyan state
|
return color_ref(&h, &hc, *ic); // cyan state
|
||||||
|
|
@ -651,7 +653,7 @@ namespace spot
|
||||||
|
|
||||||
void pop_notify(const state* s) const
|
void pop_notify(const state* s) const
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool has_been_visited(const state* s) const
|
bool has_been_visited(const state* s) const
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -251,7 +253,7 @@ namespace spot
|
||||||
if (c_prime.is_white())
|
if (c_prime.is_white())
|
||||||
{
|
{
|
||||||
trace << " It is white, pop it" << std::endl;
|
trace << " It is white, pop it" << std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
}
|
}
|
||||||
else if ((c_prime.get_acc() & acu) != acu)
|
else if ((c_prime.get_acc() & acu) != acu)
|
||||||
{
|
{
|
||||||
|
|
@ -328,7 +330,7 @@ namespace spot
|
||||||
// Advance the iterator before deleting the "key" pointer.
|
// Advance the iterator before deleting the "key" pointer.
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -339,7 +341,7 @@ namespace spot
|
||||||
return color_ref(0, 0);
|
return color_ref(0, 0);
|
||||||
if (s!=it->first)
|
if (s!=it->first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = it->first;
|
s = it->first;
|
||||||
}
|
}
|
||||||
return color_ref(&(it->second.first), &(it->second.second));
|
return color_ref(&(it->second.first), &(it->second.second));
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
// Copyright (C) 2011 Laboratoire de Recherche et Developpement de
|
||||||
|
// l'Epita (LRDE).
|
||||||
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
// Copyright (C) 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6),
|
||||||
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
// département Systèmes Répartis Coopératifs (SRC), Université Pierre
|
||||||
// et Marie Curie.
|
// et Marie Curie.
|
||||||
|
|
@ -340,7 +342,7 @@ namespace spot
|
||||||
if (c_prime.is_white())
|
if (c_prime.is_white())
|
||||||
{
|
{
|
||||||
trace << " It is white, pop it" << std::endl;
|
trace << " It is white, pop it" << std::endl;
|
||||||
delete s_prime;
|
s_prime->destroy();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (c_prime.get_color() == CYAN &&
|
else if (c_prime.get_color() == CYAN &&
|
||||||
|
|
@ -492,14 +494,14 @@ namespace spot
|
||||||
{
|
{
|
||||||
const state* ptr = sc->first;
|
const state* ptr = sc->first;
|
||||||
++sc;
|
++sc;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
hash_type::const_iterator s = h.begin();
|
hash_type::const_iterator s = h.begin();
|
||||||
while (s != h.end())
|
while (s != h.end())
|
||||||
{
|
{
|
||||||
const state* ptr = s->first;
|
const state* ptr = s->first;
|
||||||
++s;
|
++s;
|
||||||
delete ptr;
|
ptr->destroy();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -514,7 +516,7 @@ namespace spot
|
||||||
return color_ref(0, 0);
|
return color_ref(0, 0);
|
||||||
if (s!=it->first)
|
if (s!=it->first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = it->first;
|
s = it->first;
|
||||||
}
|
}
|
||||||
// blue or red state
|
// blue or red state
|
||||||
|
|
@ -522,7 +524,7 @@ namespace spot
|
||||||
}
|
}
|
||||||
if (s!=ic->first)
|
if (s!=ic->first)
|
||||||
{
|
{
|
||||||
delete s;
|
s->destroy();
|
||||||
s = ic->first;
|
s = ic->first;
|
||||||
}
|
}
|
||||||
// cyan state
|
// cyan state
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue