summaryrefslogtreecommitdiff
path: root/ev.c
diff options
context:
space:
mode:
authorroot <root>2007-10-31 11:52:12 +0000
committerroot <root>2007-10-31 11:52:12 +0000
commit19d6e7a1f1a0ef5dcde45cc8c0d175129c73cfe1 (patch)
tree8fb237ed1f57d56c11e6ddebcd90ccc28b491686 /ev.c
parent487c8aa2bb79f45c17a479dd48d8dc45948d2527 (diff)
*** empty log message ***
Diffstat (limited to 'ev.c')
-rw-r--r--ev.c21
1 files changed, 20 insertions, 1 deletions
diff --git a/ev.c b/ev.c
index a038613..96380ac 100644
--- a/ev.c
+++ b/ev.c
@@ -540,7 +540,7 @@ void ev_loop (int flags)
if (timercnt)
{
- ev_tstamp to = timers [0]->at - get_clock () + method_fudge;
+ ev_tstamp to = timers [0]->at - (have_monotonic ? get_clock () : ev_now) + method_fudge;
if (block > to) block = to;
}
@@ -679,10 +679,29 @@ evtimer_stop (struct ev_timer *w)
downheap ((WT *)timers, timercnt, w->active - 1);
}
+ w->at = w->repeat;
+
ev_stop ((W)w);
}
void
+evtimer_again (struct ev_timer *w)
+{
+ if (ev_is_active (w))
+ {
+ if (w->repeat)
+ {
+ w->at = now + w->repeat;
+ downheap ((WT *)timers, timercnt, w->active - 1);
+ }
+ else
+ evtimer_stop (w);
+ }
+ else if (w->repeat)
+ evtimer_start (w);
+}
+
+void
evperiodic_start (struct ev_periodic *w)
{
if (ev_is_active (w))