1 | /* |
1 | /* |
2 | * libevent compatibility layer |
2 | * libevent compatibility layer |
3 | * |
3 | * |
4 | * Copyright (c) 2007,2008 Marc Alexander Lehmann <libev@schmorp.de> |
4 | * Copyright (c) 2007,2008,2009,2010 Marc Alexander Lehmann <libev@schmorp.de> |
5 | * All rights reserved. |
5 | * All rights reserved. |
6 | * |
6 | * |
7 | * Redistribution and use in source and binary forms, with or without modifica- |
7 | * Redistribution and use in source and binary forms, with or without modifica- |
8 | * tion, are permitted provided that the following conditions are met: |
8 | * tion, are permitted provided that the following conditions are met: |
9 | * |
9 | * |
… | |
… | |
61 | int dummy; |
61 | int dummy; |
62 | }; |
62 | }; |
63 | |
63 | |
64 | static struct event_base *ev_x_cur; |
64 | static struct event_base *ev_x_cur; |
65 | |
65 | |
66 | static void |
|
|
67 | ev_tv_set (struct timeval *tv, ev_tstamp at) |
|
|
68 | { |
|
|
69 | tv->tv_sec = (long)at; |
|
|
70 | tv->tv_usec = (long)((at - (ev_tstamp)tv->tv_sec) * 1e6); |
|
|
71 | } |
|
|
72 | |
|
|
73 | static ev_tstamp |
66 | static ev_tstamp |
74 | ev_tv_get (struct timeval *tv) |
67 | ev_tv_get (struct timeval *tv) |
75 | { |
68 | { |
76 | if (tv) |
69 | if (tv) |
|
|
70 | { |
77 | return tv->tv_sec + tv->tv_usec * 1e-6; |
71 | ev_tstamp after = tv->tv_sec + tv->tv_usec * 1e-6; |
|
|
72 | return after ? after : 1e-6; |
|
|
73 | } |
78 | else |
74 | else |
79 | return -1.; |
75 | return -1.; |
80 | } |
76 | } |
81 | |
77 | |
82 | #define EVENT_STRINGIFY(s) # s |
78 | #define EVENT_STRINGIFY(s) # s |
… | |
… | |
142 | } |
138 | } |
143 | |
139 | |
144 | static void |
140 | static void |
145 | ev_x_cb (struct event *ev, int revents) |
141 | ev_x_cb (struct event *ev, int revents) |
146 | { |
142 | { |
147 | revents &= EV_READ | EV_WRITE | EV_TIMEOUT | EV_SIGNAL; |
143 | revents &= EV_READ | EV_WRITE | EV_TIMER | EV_SIGNAL; |
148 | |
144 | |
149 | ev->ev_res = revents; |
145 | ev->ev_res = revents; |
150 | ev->ev_callback (ev->ev_fd, (short)revents, ev->ev_arg); |
146 | ev->ev_callback (ev->ev_fd, (short)revents, ev->ev_arg); |
151 | } |
147 | } |
152 | |
148 | |
… | |
… | |
300 | if (ev->ev_events & EV_TIMEOUT || ev_is_active (&ev->to) || ev_is_pending (&ev->to)) |
296 | if (ev->ev_events & EV_TIMEOUT || ev_is_active (&ev->to) || ev_is_pending (&ev->to)) |
301 | { |
297 | { |
302 | revents |= EV_TIMEOUT; |
298 | revents |= EV_TIMEOUT; |
303 | |
299 | |
304 | if (tv) |
300 | if (tv) |
305 | ev_tv_set (tv, ev_now (EV_A)); /* not sure if this is right :) */ |
301 | EV_TV_SET (tv, ev_now (EV_A)); /* not sure if this is right :) */ |
306 | } |
302 | } |
307 | |
303 | |
308 | return events & revents; |
304 | return events & revents; |
309 | } |
305 | } |
310 | |
306 | |
… | |
… | |
329 | |
325 | |
330 | int event_base_loop (struct event_base *base, int flags) |
326 | int event_base_loop (struct event_base *base, int flags) |
331 | { |
327 | { |
332 | dLOOPbase; |
328 | dLOOPbase; |
333 | |
329 | |
334 | ev_loop (EV_A_ flags); |
330 | ev_run (EV_A_ flags); |
335 | |
331 | |
336 | return 0; |
332 | return 0; |
337 | } |
333 | } |
338 | |
334 | |
339 | int event_base_dispatch (struct event_base *base) |
335 | int event_base_dispatch (struct event_base *base) |
… | |
… | |
344 | static void |
340 | static void |
345 | ev_x_loopexit_cb (int revents, void *base) |
341 | ev_x_loopexit_cb (int revents, void *base) |
346 | { |
342 | { |
347 | dLOOPbase; |
343 | dLOOPbase; |
348 | |
344 | |
349 | ev_unloop (EV_A_ EVUNLOOP_ONE); |
345 | ev_break (EV_A_ EVBREAK_ONE); |
350 | } |
346 | } |
351 | |
347 | |
352 | int event_base_loopexit (struct event_base *base, struct timeval *tv) |
348 | int event_base_loopexit (struct event_base *base, struct timeval *tv) |
353 | { |
349 | { |
354 | ev_tstamp after = ev_tv_get (tv); |
350 | ev_tstamp after = ev_tv_get (tv); |