| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/shell/renderer/layout_test/interface_registry_js_wrapper.h" | 5 #include "content/shell/renderer/layout_test/interface_registry_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_registry.h" | 11 #include "services/service_manager/public/cpp/interface_registry.h" |
| 12 | 12 |
| 13 namespace content { | 13 namespace content { |
| 14 | 14 |
| 15 gin::WrapperInfo InterfaceRegistryJsWrapper::kWrapperInfo = { | 15 gin::WrapperInfo InterfaceRegistryJsWrapper::kWrapperInfo = { |
| 16 gin::kEmbedderNativeGin}; | 16 gin::kEmbedderNativeGin}; |
| 17 const char InterfaceRegistryJsWrapper::kPerFrameModuleName[] = | 17 const char InterfaceRegistryJsWrapper::kPerFrameModuleName[] = |
| 18 "content/shell/renderer/layout_test/frame_interface_registry"; | 18 "content/shell/renderer/layout_test/frame_interface_registry"; |
| 19 const char InterfaceRegistryJsWrapper::kPerProcessModuleName[] = | 19 const char InterfaceRegistryJsWrapper::kPerProcessModuleName[] = |
| 20 "content/shell/renderer/layout_test/interface_registry"; | 20 "content/shell/renderer/layout_test/interface_registry"; |
| 21 | 21 |
| 22 InterfaceRegistryJsWrapper::~InterfaceRegistryJsWrapper() = default; | 22 InterfaceRegistryJsWrapper::~InterfaceRegistryJsWrapper() = default; |
| 23 | 23 |
| 24 // static | 24 // static |
| 25 gin::Handle<InterfaceRegistryJsWrapper> InterfaceRegistryJsWrapper::Create( | 25 gin::Handle<InterfaceRegistryJsWrapper> InterfaceRegistryJsWrapper::Create( |
| 26 v8::Isolate* isolate, | 26 v8::Isolate* isolate, |
| 27 v8::Handle<v8::Context> context, | 27 v8::Handle<v8::Context> context, |
| 28 shell::InterfaceRegistry* interface_registry) { | 28 service_manager::InterfaceRegistry* interface_registry) { |
| 29 return gin::CreateHandle( | 29 return gin::CreateHandle( |
| 30 isolate, new InterfaceRegistryJsWrapper( | 30 isolate, new InterfaceRegistryJsWrapper( |
| 31 isolate, context, interface_registry->GetWeakPtr())); | 31 isolate, context, interface_registry->GetWeakPtr())); |
| 32 } | 32 } |
| 33 | 33 |
| 34 gin::ObjectTemplateBuilder InterfaceRegistryJsWrapper::GetObjectTemplateBuilder( | 34 gin::ObjectTemplateBuilder InterfaceRegistryJsWrapper::GetObjectTemplateBuilder( |
| 35 v8::Isolate* isolate) { | 35 v8::Isolate* isolate) { |
| 36 return Wrappable<InterfaceRegistryJsWrapper>::GetObjectTemplateBuilder( | 36 return Wrappable<InterfaceRegistryJsWrapper>::GetObjectTemplateBuilder( |
| 37 isolate) | 37 isolate) |
| 38 .SetMethod("getLocalInterfaceForTesting", | 38 .SetMethod("getLocalInterfaceForTesting", |
| 39 &InterfaceRegistryJsWrapper::GetLocalInterfaceForTesting); | 39 &InterfaceRegistryJsWrapper::GetLocalInterfaceForTesting); |
| 40 } | 40 } |
| 41 | 41 |
| 42 mojo::Handle InterfaceRegistryJsWrapper::GetLocalInterfaceForTesting( | 42 mojo::Handle InterfaceRegistryJsWrapper::GetLocalInterfaceForTesting( |
| 43 const std::string& interface_name) { | 43 const std::string& interface_name) { |
| 44 mojo::MessagePipe pipe; | 44 mojo::MessagePipe pipe; |
| 45 if (interface_registry_) { | 45 if (interface_registry_) { |
| 46 shell::InterfaceRegistry::TestApi test_api(interface_registry_.get()); | 46 service_manager::InterfaceRegistry::TestApi test_api( |
| 47 interface_registry_.get()); |
| 47 test_api.GetLocalInterface(interface_name, std::move(pipe.handle0)); | 48 test_api.GetLocalInterface(interface_name, std::move(pipe.handle0)); |
| 48 } | 49 } |
| 49 return pipe.handle1.release(); | 50 return pipe.handle1.release(); |
| 50 } | 51 } |
| 51 | 52 |
| 52 InterfaceRegistryJsWrapper::InterfaceRegistryJsWrapper( | 53 InterfaceRegistryJsWrapper::InterfaceRegistryJsWrapper( |
| 53 v8::Isolate* isolate, | 54 v8::Isolate* isolate, |
| 54 v8::Handle<v8::Context> context, | 55 v8::Handle<v8::Context> context, |
| 55 base::WeakPtr<shell::InterfaceRegistry> interface_registry) | 56 base::WeakPtr<service_manager::InterfaceRegistry> interface_registry) |
| 56 : isolate_(isolate), | 57 : isolate_(isolate), |
| 57 context_(isolate, context), | 58 context_(isolate, context), |
| 58 interface_registry_(interface_registry), | 59 interface_registry_(interface_registry), |
| 59 weak_factory_(this) { | 60 weak_factory_(this) { |
| 60 context_.SetWeak(this, &InterfaceRegistryJsWrapper::ClearContext, | 61 context_.SetWeak(this, &InterfaceRegistryJsWrapper::ClearContext, |
| 61 v8::WeakCallbackType::kParameter); | 62 v8::WeakCallbackType::kParameter); |
| 62 } | 63 } |
| 63 | 64 |
| 64 // static | 65 // static |
| 65 void InterfaceRegistryJsWrapper::ClearContext( | 66 void InterfaceRegistryJsWrapper::ClearContext( |
| 66 const v8::WeakCallbackInfo<InterfaceRegistryJsWrapper>& data) { | 67 const v8::WeakCallbackInfo<InterfaceRegistryJsWrapper>& data) { |
| 67 InterfaceRegistryJsWrapper* registry = data.GetParameter(); | 68 InterfaceRegistryJsWrapper* registry = data.GetParameter(); |
| 68 registry->context_.Reset(); | 69 registry->context_.Reset(); |
| 69 } | 70 } |
| 70 | 71 |
| 71 } // namespace content | 72 } // namespace content |
| OLD | NEW |