00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00026 #include "TimerEvent.hh"
00027 #include "TimerEvent.ih"
00028
00029
00030 #include <sstream>
00031
00032
00033 #define prefix_
00034
00035
00036 prefix_ senf::scheduler::detail::TimerDispatcher::TimerDispatcher()
00037 : source_ (new PollTimerSource())
00038 {}
00039
00040 prefix_ senf::scheduler::detail::TimerDispatcher::~TimerDispatcher()
00041 {
00042 TimerSet::iterator i (timers_.begin());
00043 TimerSet::iterator const i_end (timers_.end());
00044 for (; i != i_end; ++i)
00045 FIFORunner::instance().dequeue(&(*i));
00046 }
00047
00048 void senf::scheduler::detail::TimerDispatcher::add(TimerEvent & event)
00049 {
00050 TimerSet::iterator i (timers_.insert(event));
00051 FIFORunner::instance().enqueue(&(*i));
00052 }
00053
00054 prefix_ void senf::scheduler::detail::TimerDispatcher::remove(TimerEvent & event)
00055 {
00056 TimerSet::iterator i (TimerSet::current(event));
00057 if (i == timers_.end())
00058 return;
00059 FIFORunner::instance().dequeue(&(*i));
00060 timers_.erase(i);
00061 }
00062
00063 prefix_ void senf::scheduler::detail::TimerDispatcher::prepareRun()
00064 {
00065 TimerSet::iterator i (timers_.begin());
00066 TimerSet::iterator const i_end (timers_.end());
00067 ClockService::clock_type now (FdManager::instance().eventTime());
00068 for (; i != i_end && i->timeout_ <= now ; ++i)
00069 i->setRunnable();
00070 }
00071
00072 prefix_ void senf::scheduler::detail::TimerDispatcher::reschedule()
00073 {
00074 if (timers_.empty())
00075 source_->notimeout();
00076 else
00077 source_->timeout(timers_.begin()->timeout_);
00078 }
00079
00080
00081
00082
00083 prefix_ void senf::scheduler::TimerEvent::v_run()
00084 {
00085 disable();
00086 cb_();
00087 }
00088
00089 prefix_ char const * senf::scheduler::TimerEvent::v_type()
00090 const
00091 {
00092 return "tm";
00093 }
00094
00095 prefix_ std::string senf::scheduler::TimerEvent::v_info()
00096 const
00097 {
00098 std::stringstream ss;
00099 ss.imbue( std::locale(ss.getloc(),
00100 new boost::posix_time::time_facet("%Y-%m-%d %H:%M:%S.%f-0000")) );
00101 ss << "expire " << ClockService::abstime(timeout_);
00102 return ss.str();
00103 }
00104
00105
00106 #undef prefix_
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118