From 09ac99f1f4be6dc4d90152c79a4ab7e0f9068550 Mon Sep 17 00:00:00 2001 From: Bert Belder Date: Wed, 8 Jun 2011 03:46:29 +0200 Subject: [PATCH] Avoid tick spinner spinning forever --- src/node.cc | 45 +++++++++++++++++++++++---------------------- 1 file changed, 23 insertions(+), 22 deletions(-) diff --git a/src/node.cc b/src/node.cc index 7fb7da8e893..8698828d763 100644 --- a/src/node.cc +++ b/src/node.cc @@ -200,28 +200,6 @@ static void Check(uv_handle_t* watcher, int status) { } -static void Spin(uv_handle_t* handle, int status) { - assert((uv_idle_t*) handle == &tick_spinner); - assert(status == 0); -} - - -static Handle NeedTickCallback(const Arguments& args) { - HandleScope scope; - need_tick_cb = true; - // TODO: this tick_spinner shouldn't be necessary. An ev_prepare should be - // sufficent, the problem is only in the case of the very last "tick" - - // there is nothing left to do in the event loop and libev will exit. The - // ev_prepare callback isn't called before exiting. Thus we start this - // tick_spinner to keep the event loop alive long enough to handle it. - if (!uv_is_active((uv_handle_t*) &tick_spinner)) { - uv_idle_start(&tick_spinner, Spin); - uv_ref(); - } - return Undefined(); -} - - static void Tick(void) { // Avoid entering a V8 scope. if (!need_tick_cb) return; @@ -254,6 +232,29 @@ static void Tick(void) { } +static void Spin(uv_handle_t* handle, int status) { + assert((uv_idle_t*) handle == &tick_spinner); + assert(status == 0); + Tick(); +} + + +static Handle NeedTickCallback(const Arguments& args) { + HandleScope scope; + need_tick_cb = true; + // TODO: this tick_spinner shouldn't be necessary. An ev_prepare should be + // sufficent, the problem is only in the case of the very last "tick" - + // there is nothing left to do in the event loop and libev will exit. The + // ev_prepare callback isn't called before exiting. Thus we start this + // tick_spinner to keep the event loop alive long enough to handle it. + if (!uv_is_active((uv_handle_t*) &tick_spinner)) { + uv_idle_start(&tick_spinner, Spin); + uv_ref(); + } + return Undefined(); +} + + static void PrepareTick(uv_handle_t* handle, int status) { assert((uv_prepare_t*) handle == &prepare_tick_watcher); assert(status == 0);