[Zope-Checkins] CVS: Zope2 - FileStorage.py:1.54
Jim Fulton
jim@digicool.com
Thu, 12 Apr 2001 19:38:25 -0400 (EDT)
Update of /cvs-repository/Zope2/lib/python/ZODB
In directory korak:/tmp/cvs-serv10215
Modified Files:
FileStorage.py
Log Message:
Added checks for empty strings in commit/abortVersion and
versionEmpty.
--- Updated File FileStorage.py in package Zope2/lib/python/ZODB --
--- FileStorage.py 2001/04/12 20:50:23 1.53
+++ FileStorage.py 2001/04/12 23:38:25 1.54
@@ -203,6 +203,8 @@
try: from posix import fsync
except: fsync=None
+StringType=type('')
+
z64='\0'*8
def warn(message, *data):
@@ -450,6 +452,11 @@
def commitVersion(self, src, dest, transaction, abort=None):
# We are going to commit by simply storing back pointers.
+ if (not src or
+ type(src) is not StringType or type(dest) is not StringType
+ ):
+ raise POSException.VersionCommitError('Invalid source version')
+
if dest and abort:
raise 'VersionCommitError', (
'Internal error, can\'t abort to a version')
@@ -1074,6 +1081,13 @@
finally: self._lock_release()
def versionEmpty(self, version):
+ if not version:
+ # The interface is silent on this case. I think that this should
+ # be an error, but Barry thinks this should return 1 if we have
+ # any non-version data. This would be excruciatingly painful to
+ # test, so I must be right. ;)
+ raise POSException.VersionError(
+ 'The version must be an non-empty string')
self._lock_acquire()
try:
index=self._index
--- Updated File FileStorage.py in package Zope2 --
--- FileStorage.py 2001/04/12 20:50:23 1.53
+++ FileStorage.py 2001/04/12 23:38:25 1.54
@@ -203,6 +203,8 @@
try: from posix import fsync
except: fsync=None
+StringType=type('')
+
z64='\0'*8
def warn(message, *data):
@@ -450,6 +452,11 @@
def commitVersion(self, src, dest, transaction, abort=None):
# We are going to commit by simply storing back pointers.
+ if (not src or
+ type(src) is not StringType or type(dest) is not StringType
+ ):
+ raise POSException.VersionCommitError('Invalid source version')
+
if dest and abort:
raise 'VersionCommitError', (
'Internal error, can\'t abort to a version')
@@ -1074,6 +1081,13 @@
finally: self._lock_release()
def versionEmpty(self, version):
+ if not version:
+ # The interface is silent on this case. I think that this should
+ # be an error, but Barry thinks this should return 1 if we have
+ # any non-version data. This would be excruciatingly painful to
+ # test, so I must be right. ;)
+ raise POSException.VersionError(
+ 'The version must be an non-empty string')
self._lock_acquire()
try:
index=self._index