X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FScheduler.cci;h=f88a979631f266a555974a885dda9bac8249b569;hb=ae06fe86f16fdabb7ffb219d255444d2eb4f4f79;hp=230870545751b338c3239c29586063026f841d34;hpb=145f6a7d0f3a6aaa77b3625351c952d24cb0b8a1;p=senf.git diff --git a/Scheduler/Scheduler.cci b/Scheduler/Scheduler.cci index 2308705..f88a979 100644 --- a/Scheduler/Scheduler.cci +++ b/Scheduler/Scheduler.cci @@ -31,16 +31,52 @@ #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// +prefix_ senf::Scheduler::Scheduler & senf::Scheduler::instance() +{ + static Scheduler instance; + return instance; +} + +prefix_ unsigned senf::Scheduler::timeout(ClockService::clock_type timeout, + TimerCallback const & cb) +{ + ++ timerIdCounter_; + TimerMap::iterator i ( + timerMap_.insert(std::make_pair(timerIdCounter_, + TimerSpec(timeout,cb,timerIdCounter_))).first); + timerQueue_.push(i); + return timerIdCounter_; +} + +prefix_ void senf::Scheduler::cancelTimeout(unsigned id) +{ + TimerMap::iterator i (timerMap_.find(id)); + if (i != timerMap_.end()) + i->second.canceled = true; +} + prefix_ void senf::Scheduler::terminate() { terminate_ = true; } +prefix_ senf::ClockService::clock_type senf::Scheduler::eventTime() + const +{ + return eventTime_; +} + prefix_ int senf::retrieve_filehandle(int fd) { return fd; } +prefix_ senf::Scheduler::TimerSpecCompare::result_type +senf::Scheduler::TimerSpecCompare::operator()(first_argument_type a, second_argument_type b) +{ + return a->second < b->second; +} + ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_