From 831aa9acb642f280927d10382baa05ca451d0f4a Mon Sep 17 00:00:00 2001 From: Gireesh Punathil Date: Mon, 18 Feb 2019 09:07:19 -0500 Subject: [PATCH] src: make `node::SignalWrap::OnSignal` into lambda PR-URL: /~https://github.com/nodejs/node/pull/26184 Reviewed-By: James M Snell Reviewed-By: Anna Henningsen Reviewed-By: Colin Ihrig --- src/signal_wrap.cc | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/signal_wrap.cc b/src/signal_wrap.cc index ca08342ec63bb1..ba5ceb95025fd0 100644 --- a/src/signal_wrap.cc +++ b/src/signal_wrap.cc @@ -101,7 +101,17 @@ class SignalWrap : public HandleWrap { } } #endif - int err = uv_signal_start(&wrap->handle_, OnSignal, signum); + int err = uv_signal_start( + &wrap->handle_, + [](uv_signal_t* handle, int signum) { + SignalWrap* wrap = ContainerOf(&SignalWrap::handle_, handle); + Environment* env = wrap->env(); + HandleScope handle_scope(env->isolate()); + Context::Scope context_scope(env->context()); + Local arg = Integer::New(env->isolate(), signum); + wrap->MakeCallback(env->onsignal_string(), 1, &arg); + }, + signum); args.GetReturnValue().Set(err); } @@ -112,16 +122,6 @@ class SignalWrap : public HandleWrap { args.GetReturnValue().Set(err); } - static void OnSignal(uv_signal_t* handle, int signum) { - SignalWrap* wrap = ContainerOf(&SignalWrap::handle_, handle); - Environment* env = wrap->env(); - HandleScope handle_scope(env->isolate()); - Context::Scope context_scope(env->context()); - - Local arg = Integer::New(env->isolate(), signum); - wrap->MakeCallback(env->onsignal_string(), 1, &arg); - } - uv_signal_t handle_; };