X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FReadHelper.ct;h=ca4397a90a6dc3350e983ae99af6a1464e50d1e2;hb=fd3a0e8ac95d1158e9ea661ddf9187b67c70169f;hp=42d068add8674825ef4ba97190001194dfafdef3;hpb=40fa3e3f1e0f639c68bd15bf469e35045f94abee;p=senf.git diff --git a/Scheduler/ReadHelper.ct b/Scheduler/ReadHelper.ct index 42d068a..ca4397a 100644 --- a/Scheduler/ReadHelper.ct +++ b/Scheduler/ReadHelper.ct @@ -35,24 +35,23 @@ template prefix_ senf::ReadHelper::ReadHelper(Handle handle, std::string::size_type maxSize, InternalPredicate * predicate, Callback cb) - : handle_(handle), maxSize_(maxSize), predicate_(predicate), callback_(cb), - errno_(0), complete_(false) + : handle_(handle), + fde_("senf::ReadHelper", boost::bind(&ReadHelper::dispatchProcess,ptr(this), handle, _1), + handle, senf::scheduler::FdEvent::EV_READ), + maxSize_(maxSize), predicate_(predicate), callback_(cb), errno_(0), complete_(false) { // Here we add a *static* member taking a *smart* pointer as first // argumnet instead of a simple bound-member as callback to the // scheduler. This ensures, that the refcount is at least 1 as // long as the helper is registered with the scheduler. - senf::Scheduler::instance() - .add(handle,boost::bind(&ReadHelper::dispatchProcess,ptr(this), handle, _1), - senf::Scheduler::EV_READ); } template prefix_ void senf::ReadHelper::revoke() { ptr guard (this); // To ensure, 'this' is deleted only after this method terminates ... - senf::Scheduler::instance() - .remove(handle_,senf::Scheduler::EV_READ); + fde_.disable(); + fde_.action(0); // Remove smart pointer reference to this } template @@ -68,7 +67,7 @@ template prefix_ void senf::ReadHelper::process(Handle handle,int event) { try { - if (event != senf::Scheduler::EV_READ) + if (event != senf::scheduler::FdEvent::EV_READ) throw SystemException(EPIPE SENF_EXC_DEBUGINFO); std::string rcv; handle.read(rcv, maxSize_ - data_.size());