diff options
author | morrita@chromium.org <morrita@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-08-04 23:44:17 +0000 |
---|---|---|
committer | morrita@chromium.org <morrita@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-08-04 23:44:17 +0000 |
commit | 6486088e8bb6dc810157503edfa3c75a58e9e49d (patch) | |
tree | eda9fabacac5b6796c142ec4cc402b47bdf97dd8 /ipc/ipc_sync_channel.cc | |
parent | d93dbd1248f4e556c9c1c1005f5d051e3fe1efc8 (diff) | |
download | chromium_src-6486088e8bb6dc810157503edfa3c75a58e9e49d.zip chromium_src-6486088e8bb6dc810157503edfa3c75a58e9e49d.tar.gz chromium_src-6486088e8bb6dc810157503edfa3c75a58e9e49d.tar.bz2 |
Introduce ChannelMojo
This CL introduces ChannelMojo IPC::Channel implementation
and optionally applies it for renderer-browser IPC channel.
Current stability is like 5-seconds browser and There are rough edges.
It often closes the channel so needs to be more robust.
Even though the level of stability, having it in the tree will helps
team to try and improve it.
BUG=377980
R=darin@chromium.org,jam@chromium.org,viettrungluu@chromium.org
TEST=ipc_channel_mojo_unittest.cc
Review URL: https://codereview.chromium.org/382333002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@287402 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ipc/ipc_sync_channel.cc')
-rw-r--r-- | ipc/ipc_sync_channel.cc | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/ipc/ipc_sync_channel.cc b/ipc/ipc_sync_channel.cc index a7ed230..0c4702c 100644 --- a/ipc/ipc_sync_channel.cc +++ b/ipc/ipc_sync_channel.cc @@ -13,6 +13,7 @@ #include "base/synchronization/waitable_event_watcher.h" #include "base/thread_task_runner_handle.h" #include "base/threading/thread_local.h" +#include "ipc/ipc_channel_factory.h" #include "ipc/ipc_logging.h" #include "ipc/ipc_message_macros.h" #include "ipc/ipc_sync_message.h" @@ -420,6 +421,19 @@ scoped_ptr<SyncChannel> SyncChannel::Create( // static scoped_ptr<SyncChannel> SyncChannel::Create( + scoped_ptr<ChannelFactory> factory, + Listener* listener, + base::SingleThreadTaskRunner* ipc_task_runner, + bool create_pipe_now, + base::WaitableEvent* shutdown_event) { + scoped_ptr<SyncChannel> channel = + Create(listener, ipc_task_runner, shutdown_event); + channel->Init(factory.Pass(), create_pipe_now); + return channel.Pass(); +} + +// static +scoped_ptr<SyncChannel> SyncChannel::Create( Listener* listener, base::SingleThreadTaskRunner* ipc_task_runner, WaitableEvent* shutdown_event) { |