summaryrefslogtreecommitdiffstats
path: root/ipc/ipc_channel_win.cc
diff options
context:
space:
mode:
authordmaclach@chromium.org <dmaclach@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-12-18 23:31:52 +0000
committerdmaclach@chromium.org <dmaclach@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-12-18 23:31:52 +0000
commit3ca1235de00024d82644d6162467d71ba1c1bdcb (patch)
tree2b5dad701054ee3cdbbc37a8fde61b648dd5d2ef /ipc/ipc_channel_win.cc
parent5581541cc09adfed95fbf478f6d8991e87164778 (diff)
downloadchromium_src-3ca1235de00024d82644d6162467d71ba1c1bdcb.zip
chromium_src-3ca1235de00024d82644d6162467d71ba1c1bdcb.tar.gz
chromium_src-3ca1235de00024d82644d6162467d71ba1c1bdcb.tar.bz2
Add support for sockets that can listen and accept a connection.
These sockets allow one connection at a time, however clients can connect and disconnect repeatedly. These are going to be used by Cloud Print, Remoting and Automation. BUG=NONE TEST=BUILD Review URL: http://codereview.chromium.org/5749001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@69660 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ipc/ipc_channel_win.cc')
-rw-r--r--ipc/ipc_channel_win.cc16
1 files changed, 16 insertions, 0 deletions
diff --git a/ipc/ipc_channel_win.cc b/ipc/ipc_channel_win.cc
index e12c521..0e7ba1b 100644
--- a/ipc/ipc_channel_win.cc
+++ b/ipc/ipc_channel_win.cc
@@ -106,6 +106,22 @@ Channel::ChannelImpl::ChannelImpl(const IPC::ChannelHandle &channel_handle,
waiting_connect_(mode == MODE_SERVER),
processing_incoming_(false),
ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) {
+ switch(mode) {
+ case MODE_NONE:
+ LOG(FATAL) << "Bad mode for " << channel_handle.name;
+ break;
+ case MODE_SERVER:
+ case MODE_CLIENT:
+ break;
+ case MODE_NAMED_SERVER:
+ mode = MODE_SERVER;
+ break;
+ case MODE_NAMED_CLIENT:
+ mode = MODE_CLIENT;
+ break;
+ // Intentionally no default case here so that the compiler
+ // will check that we handle all the cases in the enum.
+ }
if (!CreatePipe(channel_handle, mode)) {
// The pipe may have been closed already.
LOG(WARNING) << "Unable to create pipe named \"" << channel_handle.name <<