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

Unified Diff: content/browser/mojo/mojo_child_connection.cc

Issue 1776513003: Allow client process information to be passed via Connector::Connect(). (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 9 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 | « content/browser/mojo/mojo_child_connection.h ('k') | content/browser/mojo/mojo_shell_client_host.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/browser/mojo/mojo_child_connection.cc
diff --git a/content/browser/mojo/mojo_shell_client_host.cc b/content/browser/mojo/mojo_child_connection.cc
similarity index 61%
rename from content/browser/mojo/mojo_shell_client_host.cc
rename to content/browser/mojo/mojo_child_connection.cc
index a0e23a99332757475fd1ccb2cc7358a1f3394cd7..e8cfc0e344121e7101700f487f9d1952f58a282a 100644
--- a/content/browser/mojo/mojo_shell_client_host.cc
+++ b/content/browser/mojo/mojo_child_connection.cc
@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "content/browser/mojo/mojo_shell_client_host.h"
+#include "content/browser/mojo/mojo_child_connection.h"
#include <stdint.h>
#include <utility>
@@ -25,26 +25,28 @@
namespace content {
namespace {
-const char kMojoShellInstanceIdentity[] = "mojo_shell_instance_identity";
+const char kMojoRenderProcessHostConnection[] =
+ "mojo_render_process_host_connection";
-class InstanceIdentity : public base::SupportsUserData::Data {
+class RenderProcessHostConnection : public base::SupportsUserData::Data {
public:
- explicit InstanceIdentity(const mojo::Identity& identity)
- : identity_(identity) {}
- ~InstanceIdentity() override {}
+ explicit RenderProcessHostConnection(scoped_ptr<mojo::Connection> connection)
+ : connection_(std::move(connection)) {}
+ ~RenderProcessHostConnection() override {}
- mojo::Identity get() const { return identity_; }
+ mojo::Connection* get() const { return connection_.get(); }
private:
- mojo::Identity identity_;
+ scoped_ptr<mojo::Connection> connection_;
- DISALLOW_COPY_AND_ASSIGN(InstanceIdentity);
+ DISALLOW_COPY_AND_ASSIGN(RenderProcessHostConnection);
};
-void SetMojoIdentity(RenderProcessHost* render_process_host,
- const mojo::Identity& identity) {
- render_process_host->SetUserData(kMojoShellInstanceIdentity,
- new InstanceIdentity(identity));
+void SetMojoConnection(RenderProcessHost* render_process_host,
+ scoped_ptr<mojo::Connection> connection) {
+ render_process_host->SetUserData(
+ kMojoRenderProcessHostConnection,
+ new RenderProcessHostConnection(std::move(connection)));
}
class PIDSender : public RenderProcessHostObserver {
@@ -81,14 +83,11 @@ class PIDSender : public RenderProcessHostObserver {
DISALLOW_COPY_AND_ASSIGN(PIDSender);
};
-void OnConnectionComplete(mojo::shell::mojom::ConnectResult result) {}
-
} // namespace
-std::string RegisterChildWithExternalShell(
- int child_process_id,
- int instance_id,
- RenderProcessHost* render_process_host) {
+std::string MojoConnectToChild(int child_process_id,
+ int instance_id,
+ RenderProcessHost* render_process_host) {
// Generate a token and create a pipe which is bound to it. This pipe is
// passed to the shell if one is available.
std::string pipe_token = mojo::edk::GenerateRandomToken();
@@ -101,38 +100,38 @@ std::string RegisterChildWithExternalShell(
if (!MojoShellConnection::Get())
return pipe_token;
- mojo::shell::mojom::ShellPtr shell;
- MojoShellConnection::Get()->GetConnector()->ConnectToInterface(
- "mojo:shell", &shell);
-
+ mojo::shell::mojom::ShellClientFactoryPtr factory;
+ factory.Bind(mojo::InterfacePtrInfo<mojo::shell::mojom::ShellClientFactory>(
+ std::move(request_pipe), 0u));
mojo::shell::mojom::PIDReceiverPtr pid_receiver;
- mojo::InterfaceRequest<mojo::shell::mojom::PIDReceiver> request =
+ mojo::shell::mojom::PIDReceiverRequest pid_receiver_request =
GetProxy(&pid_receiver);
+ // PIDSender manages its own lifetime.
new PIDSender(render_process_host, std::move(pid_receiver));
- mojo::shell::mojom::ShellClientFactoryPtr factory;
- factory.Bind(mojo::InterfacePtrInfo<mojo::shell::mojom::ShellClientFactory>(
- std::move(request_pipe), 0u));
mojo::Identity target("exe:chrome_renderer",
mojo::shell::mojom::kInheritUserID,
base::StringPrintf("%d_%d", child_process_id,
instance_id));
- shell->CreateInstance(std::move(factory),
- mojo::shell::mojom::Identity::From(target),
- std::move(request), base::Bind(&OnConnectionComplete));
+ mojo::Connector::ConnectParams params(target);
+ params.set_client_process_connection(std::move(factory),
+ std::move(pid_receiver_request));
+ scoped_ptr<mojo::Connection> connection =
+ MojoShellConnection::Get()->GetConnector()->Connect(&params);
- // Store the Identity on the RPH so client code can access it later via
- // GetMojoIdentity().
- SetMojoIdentity(render_process_host, target);
+ // Store the connection on the RPH so client code can access it later via
+ // GetMojoConnection().
+ SetMojoConnection(render_process_host, std::move(connection));
return pipe_token;
}
-mojo::Identity GetMojoIdentity(RenderProcessHost* render_process_host) {
- InstanceIdentity* instance_identity = static_cast<InstanceIdentity*>(
- render_process_host->GetUserData(kMojoShellInstanceIdentity));
- return instance_identity ? instance_identity->get() : mojo::Identity();
+mojo::Connection* GetMojoConnection(RenderProcessHost* render_process_host) {
+ RenderProcessHostConnection* connection =
+ static_cast<RenderProcessHostConnection*>(
+ render_process_host->GetUserData(kMojoRenderProcessHostConnection));
+ return connection ? connection->get() : nullptr;
}
} // namespace content
« no previous file with comments | « content/browser/mojo/mojo_child_connection.h ('k') | content/browser/mojo/mojo_shell_client_host.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698