From fbf464146241036598ddbe8141c09f12c06f9b95 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miroslav=20Bajto=C5=A1?= Date: Thu, 2 May 2013 16:42:49 +0200 Subject: [PATCH] src: initialize debug-related uv_async_t handles uv_async_t handles for dispatching of debug messages and emitting NODE_DEBUG_ENABLED used to be initialized every time node::EnableDebug() was called, which happened every time user sends a SIGUSR1. Now they are initialized only once from node::Init() during application start. --- src/node.cc | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/src/node.cc b/src/node.cc index 2b3d06009b6..3cd26694835 100644 --- a/src/node.cc +++ b/src/node.cc @@ -2746,12 +2746,8 @@ static void EmitDebugEnabledAsyncCallback(uv_async_t* handle, int status) { } -// Called from the signal handler (unix) or off-thread (windows) +// Called from the signal watcher callback static void EmitDebugEnabled() { - uv_async_init(uv_default_loop(), - &emit_debug_enabled_async, - EmitDebugEnabledAsyncCallback); - uv_unref((uv_handle_t*) &emit_debug_enabled_async); uv_async_send(&emit_debug_enabled_async); } @@ -2764,11 +2760,6 @@ static void EnableDebug(bool wait_connect) { v8::Debug::SetDebugMessageDispatchHandler(DispatchMessagesDebugAgentCallback, false); - uv_async_init(uv_default_loop(), - &dispatch_debug_messages_async, - DispatchDebugMessagesAsyncCallback); - uv_unref((uv_handle_t*) &dispatch_debug_messages_async); - // Start the debug thread and it's associated TCP server on port 5858. bool r = v8::Debug::EnableAgent("node " NODE_VERSION, debug_port, @@ -2783,7 +2774,7 @@ static void EnableDebug(bool wait_connect) { debugger_running = true; - // Do not emit _debug_enabled when debugger is enabled before starting + // Do not emit NODE_DEBUG_ENABLED when debugger is enabled before starting // the main process (i.e. when called via `node --debug`) if (!process.IsEmpty()) EmitDebugEnabled(); @@ -3016,6 +3007,18 @@ char** Init(int argc, char *argv[]) { // Make inherited handles noninheritable. uv_disable_stdio_inheritance(); + // init async debug messages dispatching + uv_async_init(uv_default_loop(), + &dispatch_debug_messages_async, + DispatchDebugMessagesAsyncCallback); + uv_unref(reinterpret_cast(&dispatch_debug_messages_async)); + + // init async NODE_DEBUG_ENABLED emitter + uv_async_init(uv_default_loop(), + &emit_debug_enabled_async, + EmitDebugEnabledAsyncCallback); + uv_unref(reinterpret_cast(&emit_debug_enabled_async)); + // Parse a few arguments which are specific to Node. node::ParseArgs(argc, argv); // Parse the rest of the args (up to the 'option_end_index' (where '--' was