X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Ftime%2Ftimer.cpp;h=e0af57cc78fcc41363632e169e33a8219653e9f1;hp=f26900b8d4a589769c707b59513de6aa2d8dc129;hb=be8ea216d23bf36bdfb2d3e302638782575fc136;hpb=aad3371b3d1831dd0525a51e40f637f00be6ff87 diff --git a/source/time/timer.cpp b/source/time/timer.cpp index f26900b..e0af57c 100644 --- a/source/time/timer.cpp +++ b/source/time/timer.cpp @@ -1,4 +1,5 @@ #include +#include #include "timer.h" #include "utils.h" @@ -55,35 +56,59 @@ void Timer::cancel(Slot &slot) void Timer::tick(bool block) { + if(block) + tick(); + else + tick(zero); +} + +void Timer::tick() +{ + do_tick(-sec); +} + +void Timer::tick(const TimeDelta &timeout) +{ + if(timeout=zero) + deadline = now()+timeout; + Slot *next = 0; { MutexLock l(mutex); while(1) { - if(slots.empty()) + TimeStamp stamp; + TimeStamp t = now(); + if(!slots.empty()) { - if(block) - { - blocking = true; - mutex.unlock(); - sem.wait(); - mutex.lock(); - } - else - return; + next = slots.begin()->slot; + stamp = next->get_timeout(); + if(stamp<=t) + break; } - next = slots.begin()->slot; - const TimeStamp &stamp = next->get_timeout(); - const TimeStamp t = now(); - if(stamp<=t) - break; - else if(block) + if(timeout && (!deadline || t