X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/d9966aa66acc63c0417fbeae8e3ff12bccb0cdb0..40e0bf5686dc6da940c2dfe33c2e8b4824fefb8f:/src/kernel/activity/ExecImpl.hpp diff --git a/src/kernel/activity/ExecImpl.hpp b/src/kernel/activity/ExecImpl.hpp index 4b114476be..d37b98745b 100644 --- a/src/kernel/activity/ExecImpl.hpp +++ b/src/kernel/activity/ExecImpl.hpp @@ -13,24 +13,29 @@ namespace simgrid { namespace kernel { namespace activity { -XBT_PUBLIC_CLASS ExecImpl : public ActivityImpl -{ +class XBT_PUBLIC ExecImpl : public ActivityImpl { ~ExecImpl() override; public: - explicit ExecImpl(const char* name, sg_host_t host); + explicit ExecImpl(const char* name, resource::Action* surf_action, resource::Action* timeout_detector, + s4u::Host* host); void suspend() override; void resume() override; + void cancel(); void post() override; - double remains(); - double remainingRatio(); - void setBound(double bound); + double get_remaining(); + double get_remaining_ratio(); + void set_bound(double bound); + void set_priority(double priority); virtual ActivityImpl* migrate(s4u::Host* to); /* The host where the execution takes place. nullptr means this is a parallel exec (and only surf knows the hosts) */ - sg_host_t host_ = nullptr; - kernel::resource::Action* surfAction_ = nullptr; /* The Surf execution action encapsulated */ - kernel::resource::Action* timeoutDetector = nullptr; + s4u::Host* host_ = nullptr; + resource::Action* surf_action_; /* The Surf execution action encapsulated */ +private: + resource::Action* timeout_detector_ = nullptr; + +public: static simgrid::xbt::signal onCreation; static simgrid::xbt::signal onCompletion; static simgrid::xbt::signal onMigration;