Index: ipc/ipc_channel_proxy.h |
diff --git a/ipc/ipc_channel_proxy.h b/ipc/ipc_channel_proxy.h |
index 0a3a5d2fb05b480d356c8a66e731045295f554ba..d1f270dd5b18c97a61dea48d2ec1ab130eb4ec21 100644 |
--- a/ipc/ipc_channel_proxy.h |
+++ b/ipc/ipc_channel_proxy.h |
@@ -64,10 +64,31 @@ class IPC_EXPORT ChannelProxy : public Sender, public base::NonThreadSafe { |
// on the background thread. Any message not handled by the filter will be |
// dispatched to the listener. The given task runner correspond to a thread |
// on which IPC::Channel is created and used (e.g. IO thread). |
- ChannelProxy(const IPC::ChannelHandle& channel_handle, |
- Channel::Mode mode, |
- Listener* listener, |
- base::SingleThreadTaskRunner* ipc_task_runner); |
+ // The naming pattern follows IPC::Channel. The Create() does not create |
+ // underlying channel and let Init*() do it. |
+ static scoped_ptr<ChannelProxy> Create( |
+ Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
+ |
+ static scoped_ptr<ChannelProxy> CreateClient( |
+ const IPC::ChannelHandle& channel_handle, |
+ Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
+ |
+ static scoped_ptr<ChannelProxy> CreateServer( |
+ const IPC::ChannelHandle& channel_handle, |
+ Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
+ |
+ static scoped_ptr<ChannelProxy> CreateNamedClient( |
+ const IPC::ChannelHandle& channel_handle, |
+ Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
+ |
+ static scoped_ptr<ChannelProxy> CreateNamedServer( |
+ const IPC::ChannelHandle& channel_handle, |
+ Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
virtual ~ChannelProxy(); |
@@ -75,8 +96,17 @@ class IPC_EXPORT ChannelProxy : public Sender, public base::NonThreadSafe { |
// proxy that was not initialized in its constructor. If create_pipe_now is |
// true, the pipe is created synchronously. Otherwise it's created on the IO |
// thread. |
- void Init(const IPC::ChannelHandle& channel_handle, Channel::Mode mode, |
- bool create_pipe_now); |
+ // The naming pattern follows IPC::Channel::Create*(). |
+ void InitByMode(const IPC::ChannelHandle& channel_handle, Channel::Mode mode, |
+ bool create_pipe_now); |
+ void InitClient(const IPC::ChannelHandle& channel_handle, |
+ bool create_pipe_now); |
+ void InitServer(const IPC::ChannelHandle& channel_handle, |
+ bool create_pipe_now); |
+ void InitNamedClient(const IPC::ChannelHandle& channel_handle, |
+ bool create_pipe_now); |
+ void InitNamedServer(const IPC::ChannelHandle& channel_handle, |
+ bool create_pipe_now); |
// Close the IPC::Channel. This operation completes asynchronously, once the |
// background thread processes the command to close the channel. It is ok to |
@@ -124,6 +154,10 @@ class IPC_EXPORT ChannelProxy : public Sender, public base::NonThreadSafe { |
// to the internal state. |
ChannelProxy(Context* context); |
+ ChannelProxy(Listener* listener, |
+ base::SingleThreadTaskRunner* ipc_task_runner); |
+ |
+ |
// Used internally to hold state that is referenced on the IPC thread. |
class Context : public base::RefCountedThreadSafe<Context>, |
public Listener { |