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

Unified Diff: mojo/system/embedder.cc

Issue 140403002: Mojo: Add the ability to hook up a channel to the embedder API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: win Created 6 years, 11 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/system/embedder.h ('k') | mojo/system/embedder_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: mojo/system/embedder.cc
diff --git a/mojo/system/embedder.cc b/mojo/system/embedder.cc
index b66fb2b61239e31efcdf850ebf0e2d0c2443eeda..4136f7cde53706bacc62852787d4da98764c85ce 100644
--- a/mojo/system/embedder.cc
+++ b/mojo/system/embedder.cc
@@ -4,14 +4,106 @@
#include "mojo/system/embedder.h"
+#include "base/bind.h"
+#include "base/location.h"
+#include "base/logging.h"
+#include "base/memory/scoped_ptr.h"
+#include "mojo/system/channel.h"
#include "mojo/system/core_impl.h"
+#include "mojo/system/local_message_pipe_endpoint.h"
+#include "mojo/system/message_pipe.h"
+#include "mojo/system/message_pipe_dispatcher.h"
+#include "mojo/system/proxy_message_pipe_endpoint.h"
namespace mojo {
+
+namespace embedder {
+
+struct ChannelInfo {
+ scoped_refptr<system::Channel> channel;
+};
+
+} // namespace embedder
+
+// Have helpers in the |system| namespace, to avoid saying "system::" all over
+// the place.
+namespace system {
+namespace {
+
+void CreateChannelOnIOThread(
+ ScopedPlatformHandle platform_handle,
+ scoped_refptr<MessagePipe> message_pipe,
+ embedder::DidCreateChannelOnIOThreadCallback callback) {
+ CHECK(platform_handle.is_valid());
+
+ scoped_ptr<embedder::ChannelInfo> channel_info(new embedder::ChannelInfo);
+
+ // Create and initialize |Channel|.
+ channel_info->channel = new Channel();
+ bool success = channel_info->channel->Init(platform_handle.Pass());
+ DCHECK(success);
+
+ // Attach the message pipe endpoint.
+ MessageInTransit::EndpointId endpoint_id =
+ channel_info->channel->AttachMessagePipeEndpoint(message_pipe, 1);
+ DCHECK_EQ(endpoint_id, Channel::kBootstrapEndpointId);
+ channel_info->channel->RunMessagePipeEndpoint(Channel::kBootstrapEndpointId,
+ Channel::kBootstrapEndpointId);
+
+ // Hand the channel back to the embedder.
+ callback.Run(channel_info.release());
+}
+
+MojoHandle CreateChannelHelper(
+ ScopedPlatformHandle platform_handle,
+ scoped_refptr<base::TaskRunner> io_thread_task_runner,
+ embedder::DidCreateChannelOnIOThreadCallback callback) {
+ DCHECK(platform_handle.is_valid());
+
+ scoped_refptr<MessagePipe> message_pipe(new MessagePipe(
+ scoped_ptr<MessagePipeEndpoint>(new LocalMessagePipeEndpoint()),
+ scoped_ptr<MessagePipeEndpoint>(new ProxyMessagePipeEndpoint())));
+ scoped_refptr<MessagePipeDispatcher> dispatcher(new MessagePipeDispatcher());
+ dispatcher->Init(message_pipe, 0);
+
+ CoreImpl* core_impl = static_cast<CoreImpl*>(Core::Get());
+ DCHECK(core_impl);
+ MojoHandle rv = core_impl->AddDispatcher(dispatcher);
+ // TODO(vtl): Do we properly handle the failure case here?
+ if (rv != MOJO_HANDLE_INVALID) {
+ io_thread_task_runner->PostTask(FROM_HERE,
+ base::Bind(&CreateChannelOnIOThread,
+ base::Passed(&platform_handle),
+ message_pipe,
+ callback));
+ }
+ return rv;
+}
+
+} // namespace
+} // namespace system
+
namespace embedder {
void Init() {
Core::Init(new system::CoreImpl());
}
+MojoHandle CreateChannel(
+ system::ScopedPlatformHandle platform_handle,
+ scoped_refptr<base::TaskRunner> io_thread_task_runner,
+ DidCreateChannelOnIOThreadCallback callback) {
+ return system::CreateChannelHelper(platform_handle.Pass(),
+ io_thread_task_runner,
+ callback);
+}
+
+void DestroyChannelOnIOThread(ChannelInfo* channel_info) {
+ DCHECK(channel_info);
+ DCHECK(channel_info->channel.get());
+ channel_info->channel->Shutdown();
+ delete channel_info;
+}
+
} // namespace embedder
} // namespace mojo
« no previous file with comments | « mojo/system/embedder.h ('k') | mojo/system/embedder_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698