X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/640e6f6494f5e1151f6436aea0e0c515da2c144b..93ae3804979dbbefc774e5a70acc32a4407dd7e8:/src/kernel/activity/IoImpl.hpp diff --git a/src/kernel/activity/IoImpl.hpp b/src/kernel/activity/IoImpl.hpp index 52d0aa793b..5e50b88178 100644 --- a/src/kernel/activity/IoImpl.hpp +++ b/src/kernel/activity/IoImpl.hpp @@ -15,19 +15,28 @@ namespace kernel { namespace activity { class XBT_PUBLIC IoImpl : public ActivityImpl { + resource::StorageImpl* storage_ = nullptr; + sg_size_t size_ = 0; + s4u::Io::OpType type_ = s4u::Io::OpType::READ; + sg_size_t performed_ioops_ = 0; + public: ~IoImpl() override; - explicit IoImpl(const std::string& name, resource::StorageImpl* storage); + IoImpl() = default; + + IoImplPtr set_name(const std::string& name); + IoImplPtr set_size(sg_size_t size); + IoImplPtr set_type(s4u::Io::OpType type); + IoImplPtr set_storage(resource::StorageImpl* storage); - IoImpl* start(sg_size_t size, s4u::Io::OpType type); + sg_size_t get_performed_ioops() { return performed_ioops_; } + + IoImpl* start(); void post() override; void finish() override; void cancel(); double get_remaining(); - sg_size_t get_performed_ioops() { return performed_ioops_; } - resource::StorageImpl* storage_ = nullptr; - sg_size_t performed_ioops_ = 0; static xbt::signal on_start; static xbt::signal on_completion; };