… | |
… | |
1237 | assert (("ev_periodic reschedule callback returned time in the past", ((WT)w)->at > ev_rt_now)); |
1237 | assert (("ev_periodic reschedule callback returned time in the past", ((WT)w)->at > ev_rt_now)); |
1238 | downheap ((WT *)periodics, periodiccnt, 0); |
1238 | downheap ((WT *)periodics, periodiccnt, 0); |
1239 | } |
1239 | } |
1240 | else if (w->interval) |
1240 | else if (w->interval) |
1241 | { |
1241 | { |
1242 | ((WT)w)->at += floor ((ev_rt_now - ((WT)w)->at) / w->interval + 1.) * w->interval; |
1242 | ((WT)w)->at = w->offset + floor ((ev_rt_now - w->offset) / w->interval + 1.) * w->interval; |
1243 | assert (("ev_periodic timeout in the past detected while processing timers, negative interval?", ((WT)w)->at > ev_rt_now)); |
1243 | assert (("ev_periodic timeout in the past detected while processing timers, negative interval?", ((WT)w)->at > ev_rt_now)); |
1244 | downheap ((WT *)periodics, periodiccnt, 0); |
1244 | downheap ((WT *)periodics, periodiccnt, 0); |
1245 | } |
1245 | } |
1246 | else |
1246 | else |
1247 | ev_periodic_stop (EV_A_ w); /* nonrepeating: stop timer */ |
1247 | ev_periodic_stop (EV_A_ w); /* nonrepeating: stop timer */ |
… | |
… | |
1261 | ev_periodic *w = periodics [i]; |
1261 | ev_periodic *w = periodics [i]; |
1262 | |
1262 | |
1263 | if (w->reschedule_cb) |
1263 | if (w->reschedule_cb) |
1264 | ((WT)w)->at = w->reschedule_cb (w, ev_rt_now); |
1264 | ((WT)w)->at = w->reschedule_cb (w, ev_rt_now); |
1265 | else if (w->interval) |
1265 | else if (w->interval) |
1266 | ((WT)w)->at += ceil ((ev_rt_now - ((WT)w)->at) / w->interval) * w->interval; |
1266 | ((WT)w)->at = w->offset + ceil ((ev_rt_now - w->offset) / w->interval) * w->interval; |
1267 | } |
1267 | } |
1268 | |
1268 | |
1269 | /* now rebuild the heap */ |
1269 | /* now rebuild the heap */ |
1270 | for (i = periodiccnt >> 1; i--; ) |
1270 | for (i = periodiccnt >> 1; i--; ) |
1271 | downheap ((WT *)periodics, periodiccnt, i); |
1271 | downheap ((WT *)periodics, periodiccnt, i); |
… | |
… | |
1690 | ((WT)w)->at = w->reschedule_cb (w, ev_rt_now); |
1690 | ((WT)w)->at = w->reschedule_cb (w, ev_rt_now); |
1691 | else if (w->interval) |
1691 | else if (w->interval) |
1692 | { |
1692 | { |
1693 | assert (("ev_periodic_start called with negative interval value", w->interval >= 0.)); |
1693 | assert (("ev_periodic_start called with negative interval value", w->interval >= 0.)); |
1694 | /* this formula differs from the one in periodic_reify because we do not always round up */ |
1694 | /* this formula differs from the one in periodic_reify because we do not always round up */ |
1695 | ((WT)w)->at += ceil ((ev_rt_now - ((WT)w)->at) / w->interval) * w->interval; |
1695 | ((WT)w)->at = w->offset + ceil ((ev_rt_now - w->offset) / w->interval) * w->interval; |
1696 | } |
1696 | } |
|
|
1697 | else |
|
|
1698 | ((WT)w)->at = w->offset; |
1697 | |
1699 | |
1698 | ev_start (EV_A_ (W)w, ++periodiccnt); |
1700 | ev_start (EV_A_ (W)w, ++periodiccnt); |
1699 | array_needsize (ev_periodic *, periodics, periodicmax, periodiccnt, EMPTY2); |
1701 | array_needsize (ev_periodic *, periodics, periodicmax, periodiccnt, EMPTY2); |
1700 | periodics [periodiccnt - 1] = w; |
1702 | periodics [periodiccnt - 1] = w; |
1701 | upheap ((WT *)periodics, periodiccnt - 1); |
1703 | upheap ((WT *)periodics, periodiccnt - 1); |