From a78ea510a2f7a8f86ad00f7bf7c6202cd5aecc9f Mon Sep 17 00:00:00 2001 From: Ryan Date: Sun, 21 Jun 2009 13:18:00 +0200 Subject: [PATCH] Add onExit callback --- src/process.cc | 17 ++++++++++++++--- src/process.h | 2 +- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/src/process.cc b/src/process.cc index 7e7495477cd..bba44ddf2f2 100644 --- a/src/process.cc +++ b/src/process.cc @@ -164,7 +164,7 @@ Process::Process (Handle handle) ev_init(&stdin_watcher_, Process::OnWritable); stdin_watcher_.data = this; - ev_init(&child_watcher_, Process::OnCHLD); + ev_init(&child_watcher_, Process::OnExit); child_watcher_.data = this; stdout_pipe_[0] = -1; @@ -402,7 +402,7 @@ Process::OnWritable (EV_P_ ev_io *watcher, int revents) } void -Process::OnCHLD (EV_P_ ev_child *watcher, int revents) +Process::OnExit (EV_P_ ev_child *watcher, int revents) { ev_child_stop(EV_A_ watcher); Process *process = static_cast(watcher->data); @@ -412,7 +412,18 @@ Process::OnCHLD (EV_P_ ev_child *watcher, int revents) assert(&process->child_watcher_ == watcher); // Call onExit ( watcher->rstatus ) - printf("OnCHLD with status %d\n", watcher->rstatus); + HandleScope scope; + Handle callback_v = process->handle_->Get(ON_EXIT_SYMBOL); + + if (callback_v->IsFunction()) { + Handle callback = Handle::Cast(callback_v); + TryCatch try_catch; + Handle argv[1] = { Integer::New(watcher->rstatus) }; + callback->Call(process->handle_, 1, argv); + if (try_catch.HasCaught()) FatalException(try_catch); + } + process->Shutdown(); + process->Detach(); } int diff --git a/src/process.h b/src/process.h index 8cbb444b538..faee88e1b13 100644 --- a/src/process.h +++ b/src/process.h @@ -31,7 +31,7 @@ class Process : ObjectWrap { static void OnOutput (EV_P_ ev_io *watcher, int revents); static void OnError (EV_P_ ev_io *watcher, int revents); static void OnWritable (EV_P_ ev_io *watcher, int revents); - static void OnCHLD (EV_P_ ev_child *watcher, int revents); + static void OnExit (EV_P_ ev_child *watcher, int revents); ev_io stdout_watcher_; ev_io stderr_watcher_;