[Zope-Checkins] CVS: ZODB3/ZODB - DB.py:1.43.24.2 Connection.py:1.76.4.1.2.3
Jeremy Hylton
jeremy@zope.com
Fri, 1 Nov 2002 16:15:21 -0500
Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv330
Modified Files:
Tag: ZODB3-deadlock-debug-branch
DB.py Connection.py
Log Message:
Add id() to each jar's sortKey().
It's not sufficient to just use the storage key, because two different
connections could use the same storage in the same transaction.
=== ZODB3/ZODB/DB.py 1.43.24.1 => 1.43.24.2 ===
--- ZODB3/ZODB/DB.py:1.43.24.1 Fri Nov 1 14:22:33 2002
+++ ZODB3/ZODB/DB.py Fri Nov 1 16:15:21 2002
@@ -577,8 +577,11 @@
self.tpc_begin=s.tpc_begin
self.tpc_vote=s.tpc_vote
self.tpc_finish=s.tpc_finish
- self.sortKey=s.sortKey
+ self._sortKey=s.sortKey
get_transaction().register(self)
+
+ def sortKey(self):
+ return "%s:%s" % (self._sortKey(), id(self))
def abort(self, reallyme, t): pass
=== ZODB3/ZODB/Connection.py 1.76.4.1.2.2 => 1.76.4.1.2.3 ===
--- ZODB3/ZODB/Connection.py:1.76.4.1.2.2 Fri Nov 1 14:42:15 2002
+++ ZODB3/ZODB/Connection.py Fri Nov 1 16:15:21 2002
@@ -193,7 +193,11 @@
def sortKey(self):
# XXX will raise an exception if the DB hasn't been set
- return self._sortKey()
+ storage_key = self._sortKey()
+ # If two connections use the same storage, give them a
+ # consistent order using id(). This is unique for the
+ # lifetime of a connection, which is good enough.
+ return "%s:%s" % (storage_key, id(self))
def _setDB(self, odb):
"""Begin a new transaction.