X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c0f3756528127131a1947179f56871657a084259..4a8bc21517c2e7759a0036d879338f84ed6bf56e:/src/kernel/resource/Action.cpp diff --git a/src/kernel/resource/Action.cpp b/src/kernel/resource/Action.cpp index 4fb398fbd8..7f6fa06dd4 100644 --- a/src/kernel/resource/Action.cpp +++ b/src/kernel/resource/Action.cpp @@ -42,8 +42,6 @@ Action::~Action() get_model()->get_action_heap().remove(this); if (modified_set_hook_.is_linked()) simgrid::xbt::intrusive_erase(*get_model()->get_modified_set(), *this); - - xbt_free(category_); } void Action::finish(Action::State state) @@ -63,7 +61,9 @@ Action::State Action::get_state() const return Action::State::FAILED; if (state_set_ == model_->get_finished_action_set()) return Action::State::FINISHED; - return Action::State::IGNORED; + if (state_set_ == model_->get_ignored_action_set()) + return Action::State::IGNORED; + THROW_IMPOSSIBLE; } void Action::set_state(Action::State state) @@ -82,6 +82,9 @@ void Action::set_state(Action::State state) case Action::State::FINISHED: state_set_ = model_->get_finished_action_set(); break; + case Action::State::IGNORED: + state_set_ = model_->get_ignored_action_set(); + break; default: state_set_ = nullptr; break; @@ -101,16 +104,11 @@ void Action::set_bound(double bound) if (variable_) get_model()->get_maxmin_system()->update_variable_bound(variable_, bound); - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy && get_last_update() != surf_get_clock()) + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY && get_last_update() != surf_get_clock()) get_model()->get_action_heap().remove(this); XBT_OUT(); } -void Action::set_category(const char* category) -{ - category_ = xbt_strdup(category); -} - void Action::ref() { refcount_++; @@ -119,7 +117,7 @@ void Action::ref() void Action::set_max_duration(double duration) { max_duration_ = duration; - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) // remove action from the heap + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) // remove action from the heap get_model()->get_action_heap().remove(this); } @@ -129,7 +127,7 @@ void Action::set_priority(double weight) sharing_priority_ = weight; get_model()->get_maxmin_system()->update_variable_weight(get_variable(), weight); - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) get_model()->get_action_heap().remove(this); XBT_OUT(); } @@ -137,21 +135,21 @@ void Action::set_priority(double weight) void Action::cancel() { set_state(Action::State::FAILED); - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) { + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) { if (modified_set_hook_.is_linked()) simgrid::xbt::intrusive_erase(*get_model()->get_modified_set(), *this); get_model()->get_action_heap().remove(this); } } -int Action::unref() +bool Action::unref() { refcount_--; if (not refcount_) { delete this; - return 1; + return true; } - return 0; + return false; } void Action::suspend() @@ -159,7 +157,7 @@ void Action::suspend() XBT_IN("(%p)", this); if (suspended_ != SuspendStates::sleeping) { get_model()->get_maxmin_system()->update_variable_weight(get_variable(), 0.0); - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) { + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) { get_model()->get_action_heap().remove(this); if (state_set_ == get_model()->get_started_action_set() && sharing_priority_ > 0) { // If we have a lazy model, we need to update the remaining value accordingly @@ -177,7 +175,7 @@ void Action::resume() if (suspended_ != SuspendStates::sleeping) { get_model()->get_maxmin_system()->update_variable_weight(get_variable(), get_priority()); suspended_ = SuspendStates::not_suspended; - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) get_model()->get_action_heap().remove(this); } XBT_OUT(); @@ -191,8 +189,8 @@ bool Action::is_suspended() double Action::get_remains() { XBT_IN("(%p)", this); - /* update remains before return it */ - if (get_model()->get_update_algorithm() == Model::UpdateAlgo::Lazy) /* update remains before return it */ + /* update remains before returning it */ + if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) /* update remains before return it */ update_remains_lazy(surf_get_clock()); XBT_OUT(); return remains_;