| Index: mojo/bindings/js/waiting_callback.cc
|
| diff --git a/mojo/bindings/js/waiting_callback.cc b/mojo/bindings/js/waiting_callback.cc
|
| index 692551bb0e7d309db93b8b9c4933adbfc863411c..5533d94f89f551a22cb44993cdc667d55db633b6 100644
|
| --- a/mojo/bindings/js/waiting_callback.cc
|
| +++ b/mojo/bindings/js/waiting_callback.cc
|
| @@ -24,12 +24,12 @@ gin::WrapperInfo WaitingCallback::kWrapperInfo = { gin::kEmbedderNativeGin };
|
| gin::Handle<WaitingCallback> WaitingCallback::Create(
|
| v8::Isolate* isolate,
|
| v8::Handle<v8::Function> callback,
|
| - mojo::Handle handle,
|
| + gin::Handle<gin::HandleWrapper> handle_wrapper,
|
| MojoHandleSignals signals) {
|
| - gin::Handle<WaitingCallback> waiting_callback =
|
| - gin::CreateHandle(isolate, new WaitingCallback(isolate, callback));
|
| + gin::Handle<WaitingCallback> waiting_callback = gin::CreateHandle(
|
| + isolate, new WaitingCallback(isolate, callback, handle_wrapper));
|
| waiting_callback->wait_id_ = Environment::GetDefaultAsyncWaiter()->AsyncWait(
|
| - handle.value(),
|
| + handle_wrapper->get().value(),
|
| signals,
|
| MOJO_DEADLINE_INDEFINITE,
|
| &WaitingCallback::CallOnHandleReady,
|
| @@ -41,13 +41,16 @@ void WaitingCallback::Cancel() {
|
| if (!wait_id_)
|
| return;
|
|
|
| + handle_wrapper_->RemoveCloseObserver(this);
|
| Environment::GetDefaultAsyncWaiter()->CancelWait(wait_id_);
|
| wait_id_ = 0;
|
| }
|
|
|
| WaitingCallback::WaitingCallback(v8::Isolate* isolate,
|
| - v8::Handle<v8::Function> callback)
|
| - : wait_id_() {
|
| + v8::Handle<v8::Function> callback,
|
| + gin::Handle<gin::HandleWrapper> handle_wrapper)
|
| + : wait_id_(), handle_wrapper_(handle_wrapper.get()) {
|
| + handle_wrapper_->AddCloseObserver(this);
|
| v8::Handle<v8::Context> context = isolate->GetCurrentContext();
|
| runner_ = gin::PerContextData::From(context)->runner()->GetWeakPtr();
|
| GetWrapper(isolate)->SetHiddenValue(GetHiddenPropertyName(isolate), callback);
|
| @@ -64,6 +67,7 @@ void WaitingCallback::CallOnHandleReady(void* closure, MojoResult result) {
|
|
|
| void WaitingCallback::OnHandleReady(MojoResult result) {
|
| wait_id_ = 0;
|
| + handle_wrapper_->RemoveCloseObserver(this);
|
|
|
| if (!runner_)
|
| return;
|
| @@ -80,5 +84,11 @@ void WaitingCallback::OnHandleReady(MojoResult result) {
|
| runner_->Call(callback, runner_->global(), 1, args);
|
| }
|
|
|
| +void WaitingCallback::OnHandleClosed() {
|
| + Environment::GetDefaultAsyncWaiter()->CancelWait(wait_id_);
|
| + OnHandleReady(MOJO_RESULT_INVALID_ARGUMENT);
|
| + handle_wrapper_ = NULL;
|
| +}
|
| +
|
| } // namespace js
|
| } // namespace mojo
|
|
|