namespace kernel {
namespace activity {
-IoImpl::IoImpl(std::string name, surf::StorageImpl* storage) : ActivityImpl(std::move(name)), storage_(storage)
+IoImpl& IoImpl::set_name(const std::string& name)
{
- this->state_ = SIMIX_RUNNING;
+ ActivityImpl::set_name(name);
+ return *this;
+}
- XBT_DEBUG("Create io impl %p", this);
+IoImpl& IoImpl::set_type(s4u::Io::OpType type)
+{
+ type_ = type;
+ return *this;
}
-IoImpl::~IoImpl()
+IoImpl& IoImpl::set_size(sg_size_t size)
{
- if (surf_action_ != nullptr)
- surf_action_->unref();
- XBT_DEBUG("Destroy io %p", this);
+ size_ = size;
+ return *this;
}
-IoImpl* IoImpl::start(sg_size_t size, simgrid::s4u::Io::OpType type)
+IoImpl& IoImpl::set_storage(resource::StorageImpl* storage)
{
- surf_action_ = storage_->io_start(size, type);
+ storage_ = storage;
+ return *this;
+}
+
+IoImpl* IoImpl::start()
+{
+ state_ = SIMIX_RUNNING;
+ surf_action_ = storage_->io_start(size_, type_);
surf_action_->set_data(this);
XBT_DEBUG("Create IO synchro %p %s", this, get_cname());
- simgrid::kernel::activity::IoImpl::on_start(this);
+ IoImpl::on_start(*this);
return this;
}
{
performed_ioops_ = surf_action_->get_cost();
switch (surf_action_->get_state()) {
- case simgrid::kernel::resource::Action::State::FAILED:
+ case resource::Action::State::FAILED:
state_ = SIMIX_FAILED;
break;
- case simgrid::kernel::resource::Action::State::FINISHED:
+ case resource::Action::State::FINISHED:
state_ = SIMIX_DONE;
break;
default:
THROW_IMPOSSIBLE;
- break;
}
- on_completion(this);
+ on_completion(*this);
finish();
}
/*************
* Callbacks *
*************/
-xbt::signal<void(IoImplPtr)> IoImpl::on_start;
-xbt::signal<void(IoImplPtr)> IoImpl::on_completion;
+xbt::signal<void(IoImpl const&)> IoImpl::on_start;
+xbt::signal<void(IoImpl const&)> IoImpl::on_completion;
} // namespace activity
} // namespace kernel