Chromium Code Reviews| Index: content/renderer/service_registry_js_wrapper.cc |
| diff --git a/content/renderer/service_registry_js_wrapper.cc b/content/renderer/service_registry_js_wrapper.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c26f3d130ebdc30d441da0bc2e78fe6f159d59b7 |
| --- /dev/null |
| +++ b/content/renderer/service_registry_js_wrapper.cc |
| @@ -0,0 +1,54 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "content/renderer/service_registry_js_wrapper.h" |
| + |
| +#include "content/public/common/service_registry.h" |
| +#include "content/public/renderer/service_registry_js.h" |
| +#include "mojo/bindings/js/handle.h" |
| + |
| +namespace content { |
| + |
| +gin::WrapperInfo ServiceRegistryJsWrapper::kWrapperInfo = { |
| + gin::kEmbedderNativeGin}; |
| +const char kServiceRegistryModuleName[] = |
| + "content/public/renderer/service_registry"; |
| + |
| +v8::Handle<v8::Value> WrapServiceRegistry(v8::Isolate* isolate, |
| + ServiceRegistry* service_registry) { |
| + return ServiceRegistryJsWrapper::Create(isolate, |
| + service_registry->AsWeakPtr()).ToV8(); |
| +} |
| + |
| +ServiceRegistryJsWrapper::~ServiceRegistryJsWrapper() { |
| +} |
| + |
| +// static |
| +gin::Handle<ServiceRegistryJsWrapper> ServiceRegistryJsWrapper::Create( |
| + v8::Isolate* isolate, |
| + base::WeakPtr<ServiceRegistry> service_registry) { |
| + return gin::CreateHandle(isolate, |
| + new ServiceRegistryJsWrapper(service_registry)); |
| +} |
| + |
| +gin::ObjectTemplateBuilder ServiceRegistryJsWrapper::GetObjectTemplateBuilder( |
| + v8::Isolate* isolate) { |
| + return Wrappable<ServiceRegistryJsWrapper>::GetObjectTemplateBuilder(isolate) |
| + .SetMethod("getInterface", &ServiceRegistryJsWrapper::GetInterface); |
|
darin (slow to review)
2014/06/21 04:44:16
nit: "." operator on the previous line
Sam McNally
2014/06/24 08:45:01
Done.
|
| +} |
| + |
| +mojo::Handle ServiceRegistryJsWrapper::GetInterface( |
| + const std::string& service_name) { |
| + mojo::MessagePipe pipe; |
| + if (service_registry_) |
| + service_registry_->GetInterface(service_name, pipe.handle0.Pass()); |
| + return pipe.handle1.release(); |
| +} |
| + |
| +ServiceRegistryJsWrapper::ServiceRegistryJsWrapper( |
| + base::WeakPtr<ServiceRegistry> service_registry) |
| + : service_registry_(service_registry) { |
| +} |
| + |
| +} // namespace content |