[Zope-Checkins] CVS: Zope3/src/ZODB/zodb4 - conversion.py:1.5
Jim Fulton
jim at zope.com
Mon Feb 23 07:31:35 EST 2004
Update of /cvs-repository/Zope3/src/ZODB/zodb4
In directory cvs.zope.org:/tmp/cvs-serv5003
Modified Files:
conversion.py
Log Message:
Relaxed the prickling error detection to handle all errors.
If an error occurs while unpickling records, a message will be logged
and the affected records are skipped.
=== Zope3/src/ZODB/zodb4/conversion.py 1.4 => 1.5 ===
--- Zope3/src/ZODB/zodb4/conversion.py:1.4 Mon Feb 23 06:54:44 2004
+++ Zope3/src/ZODB/zodb4/conversion.py Mon Feb 23 07:31:35 2004
@@ -73,12 +73,12 @@
try:
classmeta = up.load()
state = up.load()
- except ImportError, v:
+ except Exception, v:
v = str(v)
if v not in errors:
if not errors:
- sys.stderr.write("Pickling import errors:\n")
- sys.stderr.write('\t'+v+'\n')
+ sys.stderr.write("Pickling errors:\n\n")
+ sys.stderr.write('\t'+v+'\n\n')
errors[v] = True
skipped += 1
@@ -94,15 +94,30 @@
error_explanation = """
-There were import errors while copying data records.
+There were errors while copying data records.
-This is because modules referenced by the database couldn't be found.
-You might be able to fix this by getting the necessary modules.
-It's possible that the affected objects aren't used any more,
-in which case, it doesn't matter whether they were copied.
+If the errors were import errors, then this is because modules
+referenced by the database couldn't be found. You might be able to
+fix this by getting the necessary modules. It's possible that the
+affected objects aren't used any more, in which case, it doesn't
+matter whether they were copied. (We apologise for the lame import
+errors that don't show full dotted module names.)
-(We apologise for the lame import errors that don't show full dotted
- module names.)
+If errors looked something like:
+
+ "('object.__new__(SomeClass) is not safe, use
+ persistent.Persistent.__new__()', <function _reconstructor at
+ 0x4015ccdc>, (<class 'somemodule.SomeClass'>, <type 'object'>,
+ None))",
+
+then the error arises from data records for objects whos classes
+changed from being non-persistent to being persistent.
+
+If other errors were reported, it would be a good idea to ask about
+them on zope3-dev.
+
+In any case, keep your original data file in case you decide to rerun
+the conversion.
"""
More information about the Zope-Checkins
mailing list