[Zope-Checkins] CVS: ZODB3/ZEO/zrpc - trigger.py:1.12 smac.py:1.36 connection.py:1.39

Jeremy Hylton jeremy@zope.com
Mon, 18 Nov 2002 18:18:11 -0500


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

Modified Files:
	trigger.py smac.py connection.py 
Log Message:
Merge ZODB 3.1 changes to the trunk.
XXX Not sure if berkeley still works.


=== ZODB3/ZEO/zrpc/trigger.py 1.11 => 1.12 ===
--- ZODB3/ZEO/zrpc/trigger.py:1.11	Tue Nov 12 08:36:11 2002
+++ ZODB3/ZEO/zrpc/trigger.py	Mon Nov 18 18:17:40 2002
@@ -16,6 +16,7 @@
 import os
 import socket
 import thread
+import errno
 
 if os.name == 'posix':
 
@@ -71,6 +72,7 @@
                 self.del_channel()
                 for fd in self._fds:
                     os.close(fd)
+                self._fds = []
 
         def __repr__(self):
             return '<select-trigger (pipe) at %x>' % id(self)
@@ -83,6 +85,9 @@
 
         def handle_connect(self):
             pass
+
+        def handle_close(self):
+            self.close()
 
         def pull_trigger(self, thunk=None):
             if thunk:


=== ZODB3/ZEO/zrpc/smac.py 1.35 => 1.36 ===
--- ZODB3/ZEO/zrpc/smac.py:1.35	Mon Oct  7 17:16:53 2002
+++ ZODB3/ZEO/zrpc/smac.py	Mon Nov 18 18:17:40 2002
@@ -77,6 +77,9 @@
         self.__closed = 0
         self.__super_init(sock, map)
 
+    def get_addr(self):
+        return self.addr
+
     # XXX avoid expensive getattr calls?  Can't remember exactly what
     # this comment was supposed to mean, but it has something to do
     # with the way asyncore uses getattr and uses if sock:


=== ZODB3/ZEO/zrpc/connection.py 1.38 => 1.39 ===
--- ZODB3/ZEO/zrpc/connection.py:1.38	Sat Sep 28 23:24:17 2002
+++ ZODB3/ZEO/zrpc/connection.py	Mon Nov 18 18:17:40 2002
@@ -348,13 +348,22 @@
         else:
             return 0
 
+    def _pull_trigger(self, tryagain=10):
+        try:
+            self.trigger.pull_trigger()
+        except OSError, e:
+            self.trigger.close()
+            self.trigger = trigger()
+            if tryagain > 0:
+                self._pull_trigger(tryagain=tryagain-1)
+
     def wait(self, msgid):
         """Invoke asyncore mainloop and wait for reply."""
         if __debug__:
             log("wait(%d), async=%d" % (msgid, self.is_async()),
                 level=zLOG.TRACE)
         if self.is_async():
-            self.trigger.pull_trigger()
+            self._pull_trigger()
 
         # Delay used when we call asyncore.poll() directly.
         # Start with a 1 msec delay, double until 1 sec.
@@ -398,7 +407,7 @@
         if __debug__:
             log("poll(), async=%d" % self.is_async(), level=zLOG.TRACE)
         if self.is_async():
-            self.trigger.pull_trigger()
+            self._pull_trigger()
         else:
             asyncore.poll(0.0, self._map)