Chromium Code Reviews| Index: content/public/common/service_registry.h |
| diff --git a/content/public/common/service_registry.h b/content/public/common/service_registry.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..bbad59efad8e0266b1857f86181bf335431b5a77 |
| --- /dev/null |
| +++ b/content/public/common/service_registry.h |
| @@ -0,0 +1,73 @@ |
| +// 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. |
| + |
| +#ifndef CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_ |
| +#define CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_ |
| + |
| +#include <string> |
| + |
| +#include "base/bind.h" |
| +#include "base/callback.h" |
| +#include "base/strings/string_piece.h" |
| +#include "content/common/content_export.h" |
| +#include "mojo/public/cpp/bindings/interface_ptr.h" |
| +#include "mojo/public/cpp/bindings/interface_request.h" |
| +#include "mojo/public/cpp/system/core.h" |
| + |
| +namespace content { |
| + |
| +// A ServiceRegistry exposes local services that have been added using |
| +// AddService to a paired remote ServiceRegistry and provides local access to |
| +// services exposed by the remote ServiceRegistry through GetInterface. |
| +class CONTENT_EXPORT ServiceRegistry { |
| + public: |
| + virtual ~ServiceRegistry() {} |
| + |
| + // Make the service created by |service_factory| available to the remote |
| + // InterfaceProvider. In response to each request for a service, |
| + // |service_factory| will be run with an InterfaceRequest<Interface> |
| + // representing that request. |
| + template <typename Interface> |
| + void AddService(const base::Callback<void(mojo::InterfaceRequest<Interface>)> |
| + service_factory) { |
| + AddService(Interface::Name_, |
| + base::Bind(&ServiceRegistry::ForwardToServiceFactory<Interface>, |
| + service_factory)); |
| + } |
| + virtual void AddService( |
| + const std::string& service_name, |
| + const base::Callback<void(mojo::ScopedMessagePipeHandle)> |
| + service_factory) = 0; |
| + |
| + // Remove future access to the service implementing Interface. Existing |
| + // connections to the service are unaffected. |
| + template <typename Interface> |
| + void RemoveService() { |
| + RemoveService(Interface::Name_); |
| + } |
| + virtual void RemoveService(const std::string& service_name) = 0; |
| + |
| + // Connect to an interface provided by the remote interface provider. |
| + template <typename Interface> |
| + void GetInterface(mojo::InterfacePtr<Interface>* ptr) { |
|
darin (slow to review)
2014/06/18 00:09:29
nit: You might call this GetRemoteInterface for cl
Sam McNally
2014/06/18 01:31:40
Done.
|
| + mojo::MessagePipe pipe; |
| + ptr->Bind(pipe.handle0.Pass()); |
| + GetInterface(Interface::Name_, pipe.handle1.Pass()); |
| + } |
| + virtual void GetInterface(const base::StringPiece& name, |
| + mojo::ScopedMessagePipeHandle handle) = 0; |
| + |
| + private: |
| + template <typename Interface> |
| + static void ForwardToServiceFactory( |
| + const base::Callback<void(mojo::InterfaceRequest<Interface>)> |
| + service_factory, |
| + mojo::ScopedMessagePipeHandle handle) { |
| + service_factory.Run(mojo::MakeRequest<Interface>(handle.Pass())); |
| + } |
| +}; |
| + |
| +} // namespace content |
| + |
| +#endif // CONTENT_PUBLIC_COMMON_SERVICE_REGISTRY_H_ |