[Zodb-checkins] CVS: ZEO/ZEO/zrpc - client.py:1.1.2.7

Tim Peters tim.one@home.com
Sat, 26 Jan 2002 13:37:30 -0500


Update of /cvs-repository/ZEO/ZEO/zrpc
In directory cvs.zope.org:/tmp/cvs-serv4531/zrpc

Modified Files:
      Tag: Standby-branch
	client.py 
Log Message:
ConnectThread.connect():  add enough errno smarts so that checkWriteClient
passes on Windows too.


=== ZEO/ZEO/zrpc/client.py 1.1.2.6 => 1.1.2.7 ===
         self.sock = sock
 
+# When trying to do a connect on a non-blocking socket, some outcomes
+# are expected.  Set _CONNECT_IN_PROGRESS to the errno value(s) expected
+# when an initial connect can't complete immediately.  Set _CONNECT_OK
+# to the errno value(s) expected if the connect succeeds *or* if it's
+# already connected (our code can attempt redundant connects).
+if hasattr(errno, "WSAEWOULDBLOCK"):    # Windows
+    _CONNECT_IN_PROGRESS = (errno.WSAEWOULDBLOCK,)
+    _CONNECT_OK          = (0, errno.WSAEISCONN)
+else:                                   # Unix
+    _CONNECT_IN_PROGRESS = (errno.EINPROGRESS,)
+    _CONNECT_OK          = (0, errno.EISCONN)
+
 class ConnectThread(threading.Thread):
     """Thread that tries to connect to server given one or more addresses.
 
@@ -213,8 +225,6 @@
                 s.setblocking(0)
                 self.sockets[s] = addr
                 # XXX can still block for a while if addr requires DNS
-                # YYY What is that XXX comment trying to say?  self.connect
-                # YYY explicitly tolerates EINPROGRESS.
                 e = self.connect(s)
 
             # next wait until they actually connect
@@ -254,9 +264,9 @@
         """
         addr = self.sockets[s]
         e = s.connect_ex(addr)
-        if e == errno.EINPROGRESS:
+        if e in _CONNECT_IN_PROGRESS:
             return 1
-        elif e == 0 or e == errno.EISCONN:
+        elif e in _CONNECT_OK:
             c = self.test_connection(s, addr)
             log("connected to %s" % repr(addr), level=zLOG.DEBUG)
             if c: