X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1fd762bbcbc15aa4ffafe2d15df5cb650d1fa1ff..76f5257ad1d80be9046790e7df5a1b5f6d9584ba:/src/kernel/activity/ActivityImpl.cpp diff --git a/src/kernel/activity/ActivityImpl.cpp b/src/kernel/activity/ActivityImpl.cpp index 757667bb15..c5f3524539 100644 --- a/src/kernel/activity/ActivityImpl.cpp +++ b/src/kernel/activity/ActivityImpl.cpp @@ -4,6 +4,7 @@ * under the terms of the license (GNU LGPL) which comes with this package. */ #include "src/kernel/activity/ActivityImpl.hpp" +#include "src/simix/smx_private.hpp" XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(simix_process); @@ -12,21 +13,37 @@ namespace kernel { namespace activity { ActivityImpl::~ActivityImpl() +{ + clean_action(); + XBT_DEBUG("Destroy activity %p", this); +} + +void ActivityImpl::register_simcall(smx_simcall_t simcall) +{ + simcalls_.push_back(simcall); + simcall->issuer->waiting_synchro = this; +} + +void ActivityImpl::clean_action() { if (surf_action_) { surf_action_->unref(); - XBT_DEBUG("Destroy activity %p", this); surf_action_ = nullptr; } } +double ActivityImpl::get_remaining() const +{ + return surf_action_ ? surf_action_->get_remains() : 0; +} + void ActivityImpl::suspend() { if (surf_action_ == nullptr) return; XBT_VERB("This activity is suspended (remain: %f)", surf_action_->get_remains()); surf_action_->suspend(); - on_suspended(this); + on_suspended(*this); } void ActivityImpl::resume() @@ -35,13 +52,15 @@ void ActivityImpl::resume() return; XBT_VERB("This activity is resumed (remain: %f)", surf_action_->get_remains()); surf_action_->resume(); - on_resumed(this); + on_resumed(*this); } -void ActivityImpl::set_category(const std::string& category) +void ActivityImpl::cancel() { - if (surf_action_) - surf_action_->set_category(category); + XBT_VERB("Activity %p is canceled", this); + if (surf_action_ != nullptr) + surf_action_->cancel(); + state_ = SIMIX_CANCELED; } // boost::intrusive_ptr support: @@ -57,8 +76,8 @@ void intrusive_ptr_release(simgrid::kernel::activity::ActivityImpl* activity) delete activity; } } -xbt::signal ActivityImpl::on_resumed; -xbt::signal ActivityImpl::on_suspended; +xbt::signal ActivityImpl::on_resumed; +xbt::signal ActivityImpl::on_suspended; } } } // namespace simgrid::kernel::activity::