X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FScheduler.cci;h=f88a979631f266a555974a885dda9bac8249b569;hb=54fe6b70dd2c783a37f4bbd62a166160adae0e0f;hp=cda14cab57738bdf2cc180890dff42df7b13bea8;hpb=85ab07d100a382467a42e19d741d403a7a96c951;p=senf.git diff --git a/Scheduler/Scheduler.cci b/Scheduler/Scheduler.cci index cda14ca..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_ @@ -51,4 +87,6 @@ prefix_ int senf::retrieve_filehandle(int fd) // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: