OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "mojo/apps/js/bindings/waiting_callback.h" | 5 #include "mojo/apps/js/bindings/waiting_callback.h" |
6 | 6 |
7 #include "gin/per_context_data.h" | 7 #include "gin/per_context_data.h" |
8 | 8 |
9 namespace mojo { | 9 namespace mojo { |
10 namespace js { | 10 namespace js { |
(...skipping 18 matching lines...) Expand all Loading... |
29 | 29 |
30 WaitingCallback::~WaitingCallback() { | 30 WaitingCallback::~WaitingCallback() { |
31 DCHECK(!wait_id_) << "Waiting callback was destroyed before being cancelled."; | 31 DCHECK(!wait_id_) << "Waiting callback was destroyed before being cancelled."; |
32 } | 32 } |
33 | 33 |
34 gin::Handle<WaitingCallback> WaitingCallback::Create( | 34 gin::Handle<WaitingCallback> WaitingCallback::Create( |
35 v8::Isolate* isolate, v8::Handle<v8::Function> callback) { | 35 v8::Isolate* isolate, v8::Handle<v8::Function> callback) { |
36 return gin::CreateHandle(isolate, new WaitingCallback(isolate, callback)); | 36 return gin::CreateHandle(isolate, new WaitingCallback(isolate, callback)); |
37 } | 37 } |
38 | 38 |
| 39 // static |
| 40 void WaitingCallback::CallOnHandleReady(void* closure, MojoResult result) { |
| 41 static_cast<WaitingCallback*>(closure)->OnHandleReady(result); |
| 42 } |
| 43 |
39 void WaitingCallback::OnHandleReady(MojoResult result) { | 44 void WaitingCallback::OnHandleReady(MojoResult result) { |
40 wait_id_ = NULL; | 45 wait_id_ = 0; |
41 | 46 |
42 if (!runner_) | 47 if (!runner_) |
43 return; | 48 return; |
44 | 49 |
45 gin::Runner::Scope scope(runner_.get()); | 50 gin::Runner::Scope scope(runner_.get()); |
46 v8::Isolate* isolate = runner_->isolate(); | 51 v8::Isolate* isolate = runner_->isolate(); |
47 | 52 |
48 v8::Handle<v8::Value> hidden_value = | 53 v8::Handle<v8::Value> hidden_value = |
49 GetWrapper(isolate)->GetHiddenValue(GetHiddenPropertyName(isolate)); | 54 GetWrapper(isolate)->GetHiddenValue(GetHiddenPropertyName(isolate)); |
50 v8::Handle<v8::Function> callback; | 55 v8::Handle<v8::Function> callback; |
51 CHECK(gin::ConvertFromV8(isolate, hidden_value, &callback)); | 56 CHECK(gin::ConvertFromV8(isolate, hidden_value, &callback)); |
52 | 57 |
53 v8::Handle<v8::Value> args[] = { gin::ConvertToV8(isolate, result) }; | 58 v8::Handle<v8::Value> args[] = { gin::ConvertToV8(isolate, result) }; |
54 runner_->Call(callback, runner_->global(), 1, args); | 59 runner_->Call(callback, runner_->global(), 1, args); |
55 } | 60 } |
56 | 61 |
57 } // namespace js | 62 } // namespace js |
58 } // namespace mojo | 63 } // namespace mojo |
OLD | NEW |