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

Side by Side Diff: content/common/mojo/mojo_shell_connection_impl.h

Issue 2138263002: Revert of Move content's shell connections to the IO thread (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 5 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 unified diff | Download patch
« no previous file with comments | « content/child/child_thread_impl.cc ('k') | content/common/mojo/mojo_shell_connection_impl.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #ifndef CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_ 5 #ifndef CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_
6 #define CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_ 6 #define CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <vector>
9 10
10 #include "base/macros.h" 11 #include "base/macros.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/weak_ptr.h"
13 #include "base/sequenced_task_runner.h"
14 #include "content/public/common/mojo_shell_connection.h" 12 #include "content/public/common/mojo_shell_connection.h"
15 #include "mojo/public/cpp/bindings/string.h" 13 #include "mojo/public/cpp/bindings/binding_set.h"
16 #include "mojo/public/cpp/system/message_pipe.h" 14 #include "mojo/public/cpp/system/message_pipe.h"
17 #include "services/shell/public/cpp/identity.h" 15 #include "services/shell/public/cpp/service.h"
18 #include "services/shell/public/interfaces/service.mojom.h" 16 #include "services/shell/public/cpp/service_context.h"
19 17 #include "services/shell/public/interfaces/service_factory.mojom.h"
20 namespace shell {
21 class Connector;
22 }
23 18
24 namespace content { 19 namespace content {
25 20
26 class EmbeddedApplicationRunner; 21 class EmbeddedApplicationRunner;
27 22
28 class MojoShellConnectionImpl : public MojoShellConnection { 23 class MojoShellConnectionImpl
24 : public MojoShellConnection,
25 public shell::Service,
26 public shell::InterfaceFactory<shell::mojom::ServiceFactory>,
27 public shell::mojom::ServiceFactory {
28
29 public: 29 public:
30 explicit MojoShellConnectionImpl( 30 explicit MojoShellConnectionImpl(shell::mojom::ServiceRequest request);
31 shell::mojom::ServiceRequest request,
32 scoped_refptr<base::SequencedTaskRunner> io_task_runner);
33 ~MojoShellConnectionImpl() override; 31 ~MojoShellConnectionImpl() override;
34 32
35 private: 33 private:
36 class IOThreadContext;
37
38 // MojoShellConnection: 34 // MojoShellConnection:
39 void Start() override; 35 shell::ServiceContext* GetShellConnection() override;
40 void SetInitializeHandler(const base::Closure& handler) override;
41 shell::Connector* GetConnector() override; 36 shell::Connector* GetConnector() override;
42 const shell::Identity& GetIdentity() const override; 37 const shell::Identity& GetIdentity() const override;
43 void SetConnectionLostClosure(const base::Closure& closure) override; 38 void SetConnectionLostClosure(const base::Closure& closure) override;
44 void SetupInterfaceRequestProxies( 39 void MergeService(std::unique_ptr<shell::Service> service) override;
45 shell::InterfaceRegistry* registry, 40 void MergeService(shell::Service* service) override;
46 shell::InterfaceProvider* provider) override;
47 void AddConnectionFilter(std::unique_ptr<ConnectionFilter> filter) override;
48 void AddEmbeddedService(const std::string& name, 41 void AddEmbeddedService(const std::string& name,
49 const MojoApplicationInfo& info) override; 42 const MojoApplicationInfo& info) override;
50 void AddServiceRequestHandler( 43 void AddServiceRequestHandler(
51 const std::string& name, 44 const std::string& name,
52 const ServiceRequestHandler& handler) override; 45 const ServiceRequestHandler& handler) override;
53 46
54 void OnContextInitialized(const shell::Identity& identity); 47 // shell::Service:
55 void OnConnectionLost(); 48 void OnStart(shell::Connector* connector,
49 const shell::Identity& identity,
50 uint32_t id) override;
51 bool OnConnect(shell::Connection* connection) override;
52 shell::InterfaceRegistry* GetInterfaceRegistryForConnection() override;
53 shell::InterfaceProvider* GetInterfaceProviderForConnection() override;
54
55 // shell::InterfaceFactory<shell::mojom::ServiceFactory>:
56 void Create(shell::Connection* connection,
57 shell::mojom::ServiceFactoryRequest request) override;
58
59 // shell::mojom::ServiceFactory:
56 void CreateService(shell::mojom::ServiceRequest request, 60 void CreateService(shell::mojom::ServiceRequest request,
57 const mojo::String& name); 61 const mojo::String& name) override;
58 void GetInterface(shell::mojom::InterfaceProvider* provider,
59 const mojo::String& interface_name,
60 mojo::ScopedMessagePipeHandle request_handle);
61 62
62 shell::Identity identity_; 63 std::unique_ptr<shell::ServiceContext> shell_connection_;
63 64 mojo::BindingSet<shell::mojom::ServiceFactory> factory_bindings_;
64 std::unique_ptr<shell::Connector> connector_; 65 std::vector<shell::Service*> embedded_services_;
65 scoped_refptr<IOThreadContext> context_; 66 std::vector<std::unique_ptr<shell::Service>> owned_services_;
66
67 base::Closure initialize_handler_;
68 base::Closure connection_lost_handler_;
69
70 std::unordered_map<std::string, std::unique_ptr<EmbeddedApplicationRunner>> 67 std::unordered_map<std::string, std::unique_ptr<EmbeddedApplicationRunner>>
71 embedded_apps_; 68 embedded_apps_;
72 std::unordered_map<std::string, ServiceRequestHandler> request_handlers_; 69 std::unordered_map<std::string, ServiceRequestHandler> request_handlers_;
73 70
74 base::WeakPtrFactory<MojoShellConnectionImpl> weak_factory_;
75
76 DISALLOW_COPY_AND_ASSIGN(MojoShellConnectionImpl); 71 DISALLOW_COPY_AND_ASSIGN(MojoShellConnectionImpl);
77 }; 72 };
78 73
79 } // namespace content 74 } // namespace content
80 75
81 #endif // CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_ 76 #endif // CONTENT_COMMON_MOJO_SHELL_CONNECTION_IMPL_H_
OLDNEW
« no previous file with comments | « content/child/child_thread_impl.cc ('k') | content/common/mojo/mojo_shell_connection_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698