X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/8be96606a051358ca1b0e8269f5150a7e3d53cab..a57327d86b9fb16acacc71a3359817acd2a2816b:/src/kernel/resource/Action.cpp diff --git a/src/kernel/resource/Action.cpp b/src/kernel/resource/Action.cpp index 7f6fa06dd4..ee1c70a087 100644 --- a/src/kernel/resource/Action.cpp +++ b/src/kernel/resource/Action.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2004-2018. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2004-2019. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -47,8 +47,8 @@ Action::~Action() void Action::finish(Action::State state) { finish_time_ = surf_get_clock(); - set_state(state); set_remains(0); + set_state(state); } Action::State Action::get_state() const @@ -155,7 +155,7 @@ bool Action::unref() void Action::suspend() { XBT_IN("(%p)", this); - if (suspended_ != SuspendStates::sleeping) { + 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) { get_model()->get_action_heap().remove(this); @@ -164,7 +164,7 @@ void Action::suspend() update_remains_lazy(surf_get_clock()); } } - suspended_ = SuspendStates::suspended; + suspended_ = SuspendStates::SUSPENDED; } XBT_OUT(); } @@ -172,20 +172,15 @@ void Action::suspend() void Action::resume() { XBT_IN("(%p)", this); - if (suspended_ != SuspendStates::sleeping) { + if (suspended_ != SuspendStates::SLEEPING) { get_model()->get_maxmin_system()->update_variable_weight(get_variable(), get_priority()); - suspended_ = SuspendStates::not_suspended; + suspended_ = SuspendStates::RUNNING; if (get_model()->get_update_algorithm() == Model::UpdateAlgo::LAZY) get_model()->get_action_heap().remove(this); } XBT_OUT(); } -bool Action::is_suspended() -{ - return suspended_ == SuspendStates::suspended; -} - double Action::get_remains() { XBT_IN("(%p)", this); @@ -198,7 +193,8 @@ double Action::get_remains() void Action::update_max_duration(double delta) { - double_update(&max_duration_, delta, sg_surf_precision); + if (max_duration_ != NO_MAX_DURATION) + double_update(&max_duration_, delta, sg_surf_precision); } void Action::update_remains(double delta) { @@ -245,5 +241,5 @@ Action* ActionHeap::pop() } } // namespace surf -} // namespace simgrid +} // namespace kernel } // namespace simgrid