[Zope3-checkins] CVS: Zope3/src/transaction - manager.py:1.8 interfaces.py:1.5

Jeremy Hylton jeremy@zope.com
Thu, 20 Mar 2003 12:25:55 -0500


Update of /cvs-repository/Zope3/src/transaction
In directory cvs.zope.org:/tmp/cvs-serv14445

Modified Files:
	manager.py interfaces.py 
Log Message:
Change prepare() signature in IDataManager.

The manager should raise an exception in its prepare() method rather
than returning a boolean to indicate failure.  Rationale: The txn
manager can't raise a reasonable exception, because it doesn't know
what the data manager couldn't prepare.


=== Zope3/src/transaction/manager.py 1.7 => 1.8 ===
--- Zope3/src/transaction/manager.py:1.7	Thu Mar 13 13:48:55 2003
+++ Zope3/src/transaction/manager.py	Thu Mar 20 12:25:54 2003
@@ -23,18 +23,14 @@
         # commit calls _finishCommit() or abort()
         assert txn._status is Status.ACTIVE
         txn._status = Status.PREPARING
-        prepare_ok = True
         self.logger.debug("%s: prepare", txn)
         try:
             for r in txn._resources:
-                if prepare_ok and not r.prepare(txn):
-                    raise AbortError(r)
+                r.prepare(txn)
         except:
             txn._status = Status.FAILED
             raise
         txn._status = Status.PREPARED
-        # XXX An error below is intolerable.  What state to use?
-        # Need code to handle this case.
         self._finishCommit(txn)
 
     def _finishCommit(self, txn):


=== Zope3/src/transaction/interfaces.py 1.4 => 1.5 ===
--- Zope3/src/transaction/interfaces.py:1.4	Thu Mar  6 19:15:26 2003
+++ Zope3/src/transaction/interfaces.py	Thu Mar 20 12:25:54 2003
@@ -57,7 +57,8 @@
     def prepare(transaction):
         """Begin two-phase commit of a transaction.
 
-        DataManager should return True or False.
+        The data manager must raise an exception if it is not prepared
+        to commit the transaction after executing prepare().
         """
 
     def abort(transaction):