X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FScheduler%2FTimerEventProxy.ct;h=0caaf20417a3d9365e11c19a5be18a2f635d2110;hb=e3179a2123ad51d0d9eb63834a581145c4f77c92;hp=666f30ae234195b96168eb7ce7219678170712a2;hpb=7661548b20e6c7627f54bff87e0758396fd523ef;p=senf.git diff --git a/senf/Scheduler/TimerEventProxy.ct b/senf/Scheduler/TimerEventProxy.ct index 666f30a..0caaf20 100644 --- a/senf/Scheduler/TimerEventProxy.ct +++ b/senf/Scheduler/TimerEventProxy.ct @@ -59,8 +59,15 @@ template prefix_ void senf::scheduler::TimerEventProxy::add( ClockService::clock_type timeout, IdType const & id, Callback cb) { - // insert new entry - entrySetByTimeout.insert( Entry(timeout, id, cb)); + // insert new entry or replace the timeout of an entry already indexed + typename EntrySetById_t::iterator i = entrySetById.find(id); + if(i == entrySetById.end()) + entrySetByTimeout.insert( Entry(timeout, id, cb)); + else{ + Entry tmp = *i; + tmp.timeout = timeout; + entrySetById.replace(i,tmp); + } // the scheduler time to the first earliest timeout (ordered index) timer.timeout( entrySetByTimeout.begin()->timeout); } @@ -98,6 +105,19 @@ prefix_ std::vector > senf::sc return tmp; } +template +prefix_ unsigned senf::scheduler::TimerEventProxy::numEvents() + const +{ + return entrySetByTimeout.size(); +} + +template +prefix_ void senf::scheduler::TimerEventProxy::clear() +{ + entrySetByTimeout.clear(); +} + //-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_