Skip to content
This repository has been archived by the owner on May 4, 2018. It is now read-only.

Commit

Permalink
unix: back out new idle watcher for now
Browse files Browse the repository at this point in the history
Its semantics don't quite match what node.js expects. This breaks the
stdio_over_pipes and shutdown_close_pipe tests but that can't be helped.
  • Loading branch information
bnoordhuis committed May 17, 2012
1 parent 60af28a commit 073a48d
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 2 deletions.
1 change: 1 addition & 0 deletions include/uv-private/uv-unix.h
Expand Up @@ -198,6 +198,7 @@ typedef struct {

/* UV_IDLE */
#define UV_IDLE_PRIVATE_FIELDS \
ev_idle idle_watcher; \
uv_idle_cb idle_cb; \
ngx_queue_t queue;

Expand Down
4 changes: 3 additions & 1 deletion src/unix/core.c
Expand Up @@ -204,14 +204,16 @@ static void uv__poll(uv_loop_t* loop, int block) {


static int uv__run(uv_loop_t* loop) {
/*
if (!uv__has_pending_handles(loop) && !uv__has_active_reqs(loop))
uv__run_idle(loop);
*/

uv__run_pending(loop);
uv__run_prepare(loop);

if (uv__has_active_handles(loop) || uv__has_active_reqs(loop))
uv__poll(loop, 0);
uv__poll(loop, 1);

uv__run_check(loop);

Expand Down
42 changes: 41 additions & 1 deletion src/unix/loop.c
Expand Up @@ -109,7 +109,47 @@ void uv__loop_delete(uv_loop_t* loop) {
void uv__##name##_close(uv_##name##_t* handle) { \
uv_##name##_stop(handle); \
}
X(idle, UV_IDLE)
/*X(idle, UV_IDLE)*/
X(check, UV_CHECK)
X(prepare, UV_PREPARE)
#undef X


static void uv__idle(EV_P_ ev_idle* w, int revents) {
uv_idle_t* handle = container_of(w, uv_idle_t, idle_watcher);
handle->idle_cb(handle, 0);
}


int uv_idle_init(uv_loop_t* loop, uv_idle_t* handle) {
uv__handle_init(loop, (uv_handle_t*)handle, UV_IDLE);
ev_idle_init(&handle->idle_watcher, uv__idle);
loop->counters.idle_init++;
handle->idle_cb = NULL;
return 0;
}


int uv_idle_start(uv_idle_t* handle, uv_idle_cb cb) {
if (uv__is_active(handle)) return 0;
ngx_queue_insert_head(&handle->loop->idle_handles, &handle->queue);
ev_idle_start(handle->loop->ev, &handle->idle_watcher);
uv__handle_start(handle);
handle->idle_cb = cb;
return 0;
}


int uv_idle_stop(uv_idle_t* handle) {
if (!uv__is_active(handle)) return 0;
ngx_queue_remove(&handle->queue);
ev_idle_stop(handle->loop->ev, &handle->idle_watcher);
uv__handle_stop(handle);
handle->idle_cb = NULL;
return 0;
}


void uv__idle_close(uv_idle_t* handle) {
uv_idle_stop(handle);
}

0 comments on commit 073a48d

Please sign in to comment.