OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "content/renderer/mojo/interface_provider_js_wrapper.h" | 5 #include "content/renderer/mojo/interface_provider_js_wrapper.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "mojo/edk/js/handle.h" | 10 #include "mojo/edk/js/handle.h" |
11 #include "services/service_manager/public/cpp/interface_provider.h" | 11 #include "services/service_manager/public/cpp/interface_provider.h" |
12 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 12 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
13 | 13 |
14 namespace content { | 14 namespace content { |
15 | 15 |
16 gin::WrapperInfo InterfaceProviderJsWrapper::kWrapperInfo = { | 16 gin::WrapperInfo InterfaceProviderJsWrapper::kWrapperInfo = { |
17 gin::kEmbedderNativeGin}; | 17 gin::kEmbedderNativeGin}; |
18 const char InterfaceProviderJsWrapper::kPerFrameModuleName[] = | 18 const char InterfaceProviderJsWrapper::kPerFrameModuleName[] = |
19 "content/public/renderer/frame_interfaces"; | 19 "content/public/renderer/frame_interfaces"; |
20 const char InterfaceProviderJsWrapper::kPerProcessModuleName[] = | 20 const char InterfaceProviderJsWrapper::kPerProcessModuleName[] = |
21 "content/public/renderer/interfaces"; | 21 "content/public/renderer/interfaces"; |
22 | 22 |
23 InterfaceProviderJsWrapper::~InterfaceProviderJsWrapper() { | 23 InterfaceProviderJsWrapper::~InterfaceProviderJsWrapper() { |
24 } | 24 } |
25 | 25 |
26 // static | 26 // static |
27 gin::Handle<InterfaceProviderJsWrapper> | 27 gin::Handle<InterfaceProviderJsWrapper> InterfaceProviderJsWrapper::Create( |
28 InterfaceProviderJsWrapper::Create( | |
29 v8::Isolate* isolate, | 28 v8::Isolate* isolate, |
30 v8::Handle<v8::Context> context, | 29 v8::Handle<v8::Context> context, |
31 shell::InterfaceProvider* remote_interfaces) { | 30 service_manager::InterfaceProvider* remote_interfaces) { |
32 return gin::CreateHandle( | 31 return gin::CreateHandle( |
33 isolate, | 32 isolate, |
34 new InterfaceProviderJsWrapper( | 33 new InterfaceProviderJsWrapper( |
35 isolate, context, | 34 isolate, context, |
36 remote_interfaces->GetWeakPtr())); | 35 remote_interfaces->GetWeakPtr())); |
37 } | 36 } |
38 | 37 |
39 gin::ObjectTemplateBuilder | 38 gin::ObjectTemplateBuilder |
40 InterfaceProviderJsWrapper::GetObjectTemplateBuilder(v8::Isolate* isolate) { | 39 InterfaceProviderJsWrapper::GetObjectTemplateBuilder(v8::Isolate* isolate) { |
41 return Wrappable<InterfaceProviderJsWrapper>::GetObjectTemplateBuilder( | 40 return Wrappable<InterfaceProviderJsWrapper>::GetObjectTemplateBuilder( |
(...skipping 13 matching lines...) Expand all Loading... |
55 remote_interfaces_->GetInterface( | 54 remote_interfaces_->GetInterface( |
56 interface_name, std::move(pipe.handle0)); | 55 interface_name, std::move(pipe.handle0)); |
57 } | 56 } |
58 return pipe.handle1.release(); | 57 return pipe.handle1.release(); |
59 } | 58 } |
60 | 59 |
61 void InterfaceProviderJsWrapper::AddOverrideForTesting( | 60 void InterfaceProviderJsWrapper::AddOverrideForTesting( |
62 const std::string& interface_name, | 61 const std::string& interface_name, |
63 v8::Local<v8::Function> service_factory) { | 62 v8::Local<v8::Function> service_factory) { |
64 ScopedJsFactory factory(v8::Isolate::GetCurrent(), service_factory); | 63 ScopedJsFactory factory(v8::Isolate::GetCurrent(), service_factory); |
65 shell::InterfaceProvider::TestApi test_api(remote_interfaces_.get()); | 64 service_manager::InterfaceProvider::TestApi test_api( |
| 65 remote_interfaces_.get()); |
66 test_api.SetBinderForName( | 66 test_api.SetBinderForName( |
67 interface_name, | 67 interface_name, |
68 base::Bind(&InterfaceProviderJsWrapper::CallJsFactory, | 68 base::Bind(&InterfaceProviderJsWrapper::CallJsFactory, |
69 weak_factory_.GetWeakPtr(), factory)); | 69 weak_factory_.GetWeakPtr(), factory)); |
70 } | 70 } |
71 | 71 |
72 void InterfaceProviderJsWrapper::ClearOverridesForTesting() { | 72 void InterfaceProviderJsWrapper::ClearOverridesForTesting() { |
73 shell::InterfaceProvider::TestApi test_api(remote_interfaces_.get()); | 73 service_manager::InterfaceProvider::TestApi test_api( |
| 74 remote_interfaces_.get()); |
74 test_api.ClearBinders(); | 75 test_api.ClearBinders(); |
75 } | 76 } |
76 | 77 |
77 InterfaceProviderJsWrapper::InterfaceProviderJsWrapper( | 78 InterfaceProviderJsWrapper::InterfaceProviderJsWrapper( |
78 v8::Isolate* isolate, | 79 v8::Isolate* isolate, |
79 v8::Handle<v8::Context> context, | 80 v8::Handle<v8::Context> context, |
80 base::WeakPtr<shell::InterfaceProvider> remote_interfaces) | 81 base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces) |
81 : isolate_(isolate), | 82 : isolate_(isolate), |
82 context_(isolate, context), | 83 context_(isolate, context), |
83 remote_interfaces_(remote_interfaces), | 84 remote_interfaces_(remote_interfaces), |
84 weak_factory_(this) { | 85 weak_factory_(this) { |
85 context_.SetWeak(this, &InterfaceProviderJsWrapper::ClearContext, | 86 context_.SetWeak(this, &InterfaceProviderJsWrapper::ClearContext, |
86 v8::WeakCallbackType::kParameter); | 87 v8::WeakCallbackType::kParameter); |
87 } | 88 } |
88 | 89 |
89 void InterfaceProviderJsWrapper::CallJsFactory( | 90 void InterfaceProviderJsWrapper::CallJsFactory( |
90 const ScopedJsFactory& factory, | 91 const ScopedJsFactory& factory, |
(...skipping 12 matching lines...) Expand all Loading... |
103 } | 104 } |
104 | 105 |
105 // static | 106 // static |
106 void InterfaceProviderJsWrapper::ClearContext( | 107 void InterfaceProviderJsWrapper::ClearContext( |
107 const v8::WeakCallbackInfo<InterfaceProviderJsWrapper>& data) { | 108 const v8::WeakCallbackInfo<InterfaceProviderJsWrapper>& data) { |
108 InterfaceProviderJsWrapper* registry = data.GetParameter(); | 109 InterfaceProviderJsWrapper* registry = data.GetParameter(); |
109 registry->context_.Reset(); | 110 registry->context_.Reset(); |
110 } | 111 } |
111 | 112 |
112 } // namespace content | 113 } // namespace content |
OLD | NEW |