summaryrefslogtreecommitdiffstats
path: root/ipc/ipc_sync_channel.h
diff options
context:
space:
mode:
authorkkania@chromium.org <kkania@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-11-16 01:06:46 +0000
committerkkania@chromium.org <kkania@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-11-16 01:06:46 +0000
commit952394afc0a0dc5e3e6a1f3c2e1c0fa99b7b681f (patch)
tree85d8246efdada076c5dda1b0a561d6c3322f37d1 /ipc/ipc_sync_channel.h
parent8bbba87862f0ce45234380cebf60e3ded5d88147 (diff)
downloadchromium_src-952394afc0a0dc5e3e6a1f3c2e1c0fa99b7b681f.zip
chromium_src-952394afc0a0dc5e3e6a1f3c2e1c0fa99b7b681f.tar.gz
chromium_src-952394afc0a0dc5e3e6a1f3c2e1c0fa99b7b681f.tar.bz2
Allow proxy channels to be created without initializing the underlying channel.
This fixes a bug where a client needed to guarantee a message filter was in place before any messages were received. It also follows the style of not having constructors that do complex initialization. BUG=102894 TEST=none Review URL: http://codereview.chromium.org/8417054 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@110229 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ipc/ipc_sync_channel.h')
-rw-r--r--ipc/ipc_sync_channel.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/ipc/ipc_sync_channel.h b/ipc/ipc_sync_channel.h
index e43933e..ae9a765 100644
--- a/ipc/ipc_sync_channel.h
+++ b/ipc/ipc_sync_channel.h
@@ -62,12 +62,22 @@ class SyncMessage;
class IPC_EXPORT SyncChannel : public ChannelProxy,
public base::WaitableEventWatcher::Delegate {
public:
+ // Creates and initializes a sync channel. If create_pipe_now is specified,
+ // the channel will be initialized synchronously.
SyncChannel(const IPC::ChannelHandle& channel_handle,
Channel::Mode mode,
Channel::Listener* listener,
base::MessageLoopProxy* ipc_message_loop,
bool create_pipe_now,
base::WaitableEvent* shutdown_event);
+
+ // Creates an uninitialized sync channel. Call ChannelProxy::Init to
+ // initialize the channel. This two-step setup allows message filters to be
+ // added before any messages are sent or received.
+ SyncChannel(Channel::Listener* listener,
+ base::MessageLoopProxy* ipc_message_loop,
+ base::WaitableEvent* shutdown_event);
+
virtual ~SyncChannel();
virtual bool Send(Message* message);
@@ -186,6 +196,9 @@ class IPC_EXPORT SyncChannel : public ChannelProxy,
// shuts down.
static void WaitForReplyWithNestedMessageLoop(SyncContext* context);
+ // Starts the dispatch watcher.
+ void StartWatching();
+
bool sync_messages_with_no_timeout_allowed_;
// Used to signal events between the IPC and listener threads.