forked from izaya/LuPPC
Fixed timeout issues
This commit is contained in:
parent
6b5bbba8bd
commit
170ce567ce
@ -40,7 +40,11 @@ static void handleStdin(evutil_socket_t fd, short what, void *ptr) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void event_prepare() {
|
void event_prepare() {
|
||||||
base = event_base_new();
|
struct event_config* cfg = event_config_new();
|
||||||
|
event_config_set_flag(cfg, EVENT_BASE_FLAG_NO_CACHE_TIME);
|
||||||
|
|
||||||
|
base = event_base_new_with_config(cfg);
|
||||||
|
evutil_make_socket_nonblocking(STDIN_FILENO);
|
||||||
event_assign(&stdinEvent, base, STDIN_FILENO, EV_READ, handleStdin, NULL);
|
event_assign(&stdinEvent, base, STDIN_FILENO, EV_READ, handleStdin, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,18 +52,17 @@ static void add_events(struct timeval* timeout) {
|
|||||||
event_add(&stdinEvent, timeout);
|
event_add(&stdinEvent, timeout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int event_pull(int _timeout) {
|
int event_pull(int _timeout) {
|
||||||
if(_timeout > 0) { /* wait max this much time for event */
|
if(_timeout > 0) { /* wait max this much time for event */
|
||||||
struct timeval timeout = {_timeout / 1000, (_timeout % 1000) * 1000000};
|
struct timeval timeout = {_timeout / 1000, (_timeout % 1000) * 1000};
|
||||||
add_events(&timeout);
|
add_events(&timeout);
|
||||||
/* event_base_loopexit(base, &timeout); */
|
|
||||||
event_base_loop(base, EVLOOP_ONCE);
|
event_base_loop(base, EVLOOP_ONCE);
|
||||||
} else if(_timeout == 0) { /* Get event without blocking */
|
} else if(_timeout == 0) { /* Get event without blocking */
|
||||||
add_events(NULL);
|
add_events(NULL);
|
||||||
event_base_loop(base, EVLOOP_ONCE | EVLOOP_NONBLOCK);
|
event_base_loop(base, EVLOOP_ONCE | EVLOOP_NONBLOCK);
|
||||||
} else { /* wait for event to appear */
|
} else { /* wait for event to appear */
|
||||||
add_events(NULL);
|
add_events(NULL);
|
||||||
event_base_loopexit(base, NULL);
|
|
||||||
event_base_loop(base, EVLOOP_ONCE);
|
event_base_loop(base, EVLOOP_ONCE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user