[Zope-Checkins] CVS: ZODB3/BDBStorage - BDBFullStorage.py:1.67

Barry Warsaw barry@wooz.org
Mon, 27 Jan 2003 16:09:33 -0500


Update of /cvs-repository/ZODB3/BDBStorage
In directory cvs.zope.org:/tmp/cvs-serv18289

Modified Files:
	BDBFullStorage.py 
Log Message:
_version_check(): Backport the setting up and checking of the storage
version string.


=== ZODB3/BDBStorage/BDBFullStorage.py 1.66 => 1.67 ===
--- ZODB3/BDBStorage/BDBFullStorage.py:1.66	Tue Jan 21 14:25:59 2003
+++ ZODB3/BDBStorage/BDBFullStorage.py	Mon Jan 27 16:09:31 2003
@@ -53,6 +53,8 @@
     True = 1
     False = 0
 
+BDBFULL_SCHEMA_VERSION = 'BF01'
+
 
 
 class BDBFullStorage(BerkeleyBase, ConflictResolvingStorage):
@@ -185,7 +187,10 @@
         #         packtime - time of the last pack.  It is illegal to undo to
         #         before the last pack time.
         #
-        #         version - the version of the database (reserved for ZODB4)
+        #         dbversion - the version of the database serialization
+        #         protocol (reserved for ZODB4)
+        #
+        #         version - the underlying Berkeley database schema version
         #
         # objrevs -- {newserial+oid -> oldserial}
         #     This table collects object revision information for packing
@@ -234,6 +239,13 @@
         self._delqueue = self._setupDB('delqueue', 0, db.DB_QUEUE, 8)
         # Do recovery and consistency checks
         self._withlock(self._dorecovery)
+
+    def _version_check(self, txn):
+        version = self._info.get('version')
+        if version is None:
+            self._info.put('version', BDBFULL_SCHEMA_VERSION, txn=txn)
+        elif version <> BDBFULL_SCHEMA_VERSION:
+            raise StorageSystemError, 'incompatible storage version'
 
     def _make_autopacker(self, event):
         config = self._config