[Zodb-checkins] SVN: ZODB/trunk/src/ZEO/zrpc/connection.py Port rev
29092 from 3.3 branch.
Tim Peters
tim.one at comcast.net
Wed Feb 9 16:50:26 EST 2005
Log message for revision 29093:
Port rev 29092 from 3.3 branch.
Forward port from ZODB 3.2.
Connection.__init__(): Python 2.4 added a new gimmick to asyncore (a
._map attribute on asyncore.dispatcher instances) that breaks the
delicate ZEO startup dance. Repaired that.
Changed:
U ZODB/trunk/src/ZEO/zrpc/connection.py
-=-
Modified: ZODB/trunk/src/ZEO/zrpc/connection.py
===================================================================
--- ZODB/trunk/src/ZEO/zrpc/connection.py 2005-02-09 21:42:30 UTC (rev 29092)
+++ ZODB/trunk/src/ZEO/zrpc/connection.py 2005-02-09 21:50:26 UTC (rev 29093)
@@ -265,6 +265,17 @@
# Now it's safe to register with asyncore's socket map; it was not
# safe before message_input was replaced, or before handshake() was
# invoked.
+ # Obscure: in Python 2.4, the base asyncore.dispatcher class grew
+ # a ._map attribute, which is used instead of asyncore's global
+ # socket map when ._map isn't None. Because we passed `ourmap` to
+ # the base class constructor above, in 2.4 asyncore believes we want
+ # to use `ourmap` instead of the global socket map -- but we don't.
+ # So we have to replace our ._map with the global socket map, and
+ # update the global socket map with `ourmap`. Replacing our ._map
+ # isn't necessary before Python 2.4, but doesn't hurt then (it just
+ # gives us an unused attribute in 2.3); updating the global socket
+ # map is necessary regardless of Python version.
+ self._map = asyncore.socket_map
asyncore.socket_map.update(ourmap)
def __repr__(self):
More information about the Zodb-checkins
mailing list