Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(397)

Unified Diff: mojo/shell/public/cpp/interface_registry.h

Issue 1877753003: Move mojo\shell to services\shell (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@62scan
Patch Set: . Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « mojo/shell/public/cpp/interface_factory_impl.h ('k') | mojo/shell/public/cpp/lib/application_runner.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mojo/shell/public/cpp/interface_registry.h
diff --git a/mojo/shell/public/cpp/interface_registry.h b/mojo/shell/public/cpp/interface_registry.h
deleted file mode 100644
index ea0b984471b7b103b1bc084e88209257c39c2581..0000000000000000000000000000000000000000
--- a/mojo/shell/public/cpp/interface_registry.h
+++ /dev/null
@@ -1,109 +0,0 @@
-// Copyright 2016 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 MOJO_SHELL_PUBLIC_CPP_INTERFACE_REGISTRY_H_
-#define MOJO_SHELL_PUBLIC_CPP_INTERFACE_REGISTRY_H_
-
-#include "mojo/public/cpp/bindings/binding.h"
-#include "mojo/shell/public/cpp/lib/interface_factory_binder.h"
-#include "mojo/shell/public/interfaces/interface_provider.mojom.h"
-
-namespace mojo {
-
-class InterfaceBinder;
-
-// An implementation of shell::mojom::InterfaceProvider that allows the user to
-// register services to be exposed to another application.
-//
-// To use, define a class that implements your specific interface. Then
-// implement an InterfaceFactory<Foo> that binds instances of FooImpl to
-// InterfaceRequest<Foo>s and register that on the registry like this:
-//
-// registry.AddInterface(&factory);
-//
-// Or, if you have multiple factories implemented by the same type, explicitly
-// specify the interface to register the factory for:
-//
-// registry.AddInterface<Foo>(&my_foo_and_bar_factory_);
-// registry.AddInterface<Bar>(&my_foo_and_bar_factory_);
-//
-// The InterfaceFactory must outlive the InterfaceRegistry.
-//
-// Additionally you may specify a default InterfaceBinder to handle requests for
-// interfaces unhandled by any registered InterfaceFactory. Just as with
-// InterfaceFactory, the default InterfaceBinder supplied must outlive
-// InterfaceRegistry.
-//
-class InterfaceRegistry : public shell::mojom::InterfaceProvider {
- public:
- class TestApi {
- public:
- explicit TestApi(InterfaceRegistry* registry) : registry_(registry) {}
- ~TestApi() {}
-
- void SetInterfaceBinderForName(InterfaceBinder* binder,
- const std::string& interface_name) {
- registry_->SetInterfaceBinderForName(binder, interface_name);
- }
- void RemoveInterfaceBinderForName(const std::string& interface_name) {
- registry_->RemoveInterfaceBinderForName(interface_name);
- }
-
- private:
- InterfaceRegistry* registry_;
- DISALLOW_COPY_AND_ASSIGN(TestApi);
- };
-
- // Construct with a Connection (which may be null), and create an
- // InterfaceProvider pipe, the client end of which may be obtained by calling
- // TakeClientHandle(). If |connection| is non-null, the Mojo Shell's
- // rules filtering which interfaces are allowed to be exposed to clients are
- // imposed on this registry. If null, they are not.
- explicit InterfaceRegistry(Connection* connection);
- // Construct with an InterfaceProviderRequest and a Connection (which may be
- // null, see note above about filtering).
- InterfaceRegistry(shell::mojom::InterfaceProviderRequest request,
- Connection* connection);
- ~InterfaceRegistry() override;
-
- // Takes the client end of the InterfaceProvider pipe created in the
- // constructor.
- shell::mojom::InterfaceProviderPtr TakeClientHandle();
-
- template <typename Interface>
- bool AddInterface(InterfaceFactory<Interface>* factory) {
- return SetInterfaceBinderForName(
- new internal::InterfaceFactoryBinder<Interface>(factory),
- Interface::Name_);
- }
-
- void set_default_binder(InterfaceBinder* binder) { default_binder_ = binder; }
-
- private:
- using NameToInterfaceBinderMap = std::map<std::string, InterfaceBinder*>;
-
- // shell::mojom::InterfaceProvider:
- void GetInterface(const String& interface_name,
- ScopedMessagePipeHandle handle) override;
-
- // Returns true if the binder was set, false if it was not set (e.g. by
- // some filtering policy preventing this interface from being exposed).
- bool SetInterfaceBinderForName(InterfaceBinder* binder,
- const std::string& name);
-
- void RemoveInterfaceBinderForName(const std::string& interface_name);
-
- shell::mojom::InterfaceProviderPtr client_handle_;
- Binding<shell::mojom::InterfaceProvider> binding_;
- Connection* connection_;
-
- InterfaceBinder* default_binder_;
- NameToInterfaceBinderMap name_to_binder_;
-
- DISALLOW_COPY_AND_ASSIGN(InterfaceRegistry);
-};
-
-} // namespace mojo
-
-#endif // MOJO_SHELL_PUBLIC_CPP_INTERFACE_REGISTRY_H_
« no previous file with comments | « mojo/shell/public/cpp/interface_factory_impl.h ('k') | mojo/shell/public/cpp/lib/application_runner.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698