[Zodb-checkins] CVS: Zope3/src/transaction - interfaces.py:1.5.50.4

Jim Fulton jim at zope.com
Thu Jan 22 14:42:54 EST 2004


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

Modified Files:
      Tag: zope3-zodb3-devel-branch
	interfaces.py 
Log Message:
Added some additional details.


=== Zope3/src/transaction/interfaces.py 1.5.50.3 => 1.5.50.4 ===
--- Zope3/src/transaction/interfaces.py:1.5.50.3	Thu Jan 22 14:32:09 2004
+++ Zope3/src/transaction/interfaces.py	Thu Jan 22 14:42:53 2004
@@ -29,7 +29,7 @@
     - Probably want separate abort methods for use in and out of
       two-phase commit.
 
-    - The savepoint api needs some more thought.
+    - The savepoint api may need some more thought.
     
     """
 
@@ -42,6 +42,9 @@
 
         The data manager must raise an exception if it is not prepared
         to commit the transaction after executing prepare().
+
+        The transaction must match that used for preceeding
+        savepoints, if any.
         """
         
         # This is equivalent to zodb3's tpc_begin, commit, and
@@ -50,14 +53,23 @@
     def abort(transaction):
         """Abort changes made by transaction
 
-        Call's to this method may or may not be preceeded by prepare calls.
+        This may be called before two-phase commit or in the second
+        phase of two-phase commit.
+
+        The transaction must match that used for preceeding
+        savepoints, if any.
+
         """
 
         # This is equivalent to *both* zodb3's abort and tpc_abort
         # calls. This should probably be split into 2 methods.
 
     def commit(transaction):
-        """Commit changes made by transaction.
+        """Finish two-phase commit
+
+        The prepare method must be called, with the same transaction,
+        before calling commit.
+        
         """
 
         # This is equivalent to zodb3's tpc_finish
@@ -68,13 +80,21 @@
         Should return an object implementing IRollback that can be used
         to rollback to the savepoint.
         
+        Note that (unlike zodb3) this doesn't use a 2-phase commit
+        protocol.  If this call fails, or if a rollback call on the
+        result fails, the (containing) transaction should be
+        aborted.  Aborting the containing transaction is *not* the
+        responsibility of the data manager, however.
+
+        An implementation that doesn't support savepoints should
+        implement this method by returning a rollback implementation
+        that always raises an error when it's rollback method is
+        called. The savepoing method shouldn't raise an error. This
+        way, transactions that create savepoints can proceed as long
+        as an attempt is never made to roll back a savepoint.
+
         """
 
-        # Note that (unlike zodb3)this doesn't use a 2-phase commit
-        # protocol.  If this call fails, or if a rollback call on the
-        # result fails, the (containing) transaction should be
-        # aborted.  Aborting the containing transaction is *not* the
-        # responsibility of the data manager, however.
 
 class IRollback(Interface):
 




More information about the Zodb-checkins mailing list