Partial fix for 0001722: add dialog that on import gives a warning if the xml is made with an older version

svn: r10113
This commit is contained in:
Brian Matherly 2008-02-25 04:32:11 +00:00
parent af21e396d9
commit e801786edb
3 changed files with 123 additions and 33 deletions

View File

@ -1,3 +1,9 @@
2008-02-24 Brian Matherly <brian@gramps-project.org>
* src/GrampsDbUtils/_ReadXML.py:
* src/GrampsDbUtils/_GrmapsDbWriteXML.py:
Partial fix for 0001722: add dialog that on import gives a warning if the
xml is made with an older version
2008-02-24 Brian Matherly <brian@gramps-project.org> 2008-02-24 Brian Matherly <brian@gramps-project.org>
* src/docgen/AsciiDoc.py: * src/docgen/AsciiDoc.py:
Fix page_break() Fix page_break()

View File

@ -68,7 +68,7 @@ try:
except: except:
_gzip_ok = 0 _gzip_ok = 0
_xml_version = "1.2.0" XML_VERSION = "1.2.0"
# table for skipping control chars from XML # table for skipping control chars from XML
strip_dict = dict.fromkeys(range(9)+range(12,20)) strip_dict = dict.fromkeys(range(9)+range(12,20))
@ -205,9 +205,9 @@ class GrampsDbXmlWriter(UpdateCallback):
self.g.write('<!DOCTYPE database ' self.g.write('<!DOCTYPE database '
'PUBLIC "-//GRAMPS//DTD GRAMPS XML %s//EN"\n' 'PUBLIC "-//GRAMPS//DTD GRAMPS XML %s//EN"\n'
'"http://gramps-project.org/xml/%s/grampsxml.dtd">\n' '"http://gramps-project.org/xml/%s/grampsxml.dtd">\n'
% (_xml_version,_xml_version)) % (XML_VERSION, XML_VERSION))
self.g.write('<database xmlns="http://gramps-project.org/xml/%s/">\n' self.g.write('<database xmlns="http://gramps-project.org/xml/%s/">\n'
% _xml_version) % XML_VERSION)
self.g.write(" <header>\n") self.g.write(" <header>\n")
self.g.write(' <created date="%04d-%02d-%02d\"' % self.g.write(' <created date="%04d-%02d-%02d\"' %
(date[0],date[1],date[2]) ) (date[0],date[1],date[2]) )

View File

@ -37,7 +37,7 @@ import re
# Gramps Modules # Gramps Modules
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
from QuestionDialog import ErrorDialog from QuestionDialog import ErrorDialog, QuestionDialog2
import Mime import Mime
import gen.lib import gen.lib
import Utils import Utils
@ -46,6 +46,8 @@ from BasicUtils import name_displayer
from gen.db.dbconst import (PERSON_KEY, FAMILY_KEY, SOURCE_KEY, EVENT_KEY, from gen.db.dbconst import (PERSON_KEY, FAMILY_KEY, SOURCE_KEY, EVENT_KEY,
MEDIA_KEY, PLACE_KEY, REPOSITORY_KEY, NOTE_KEY) MEDIA_KEY, PLACE_KEY, REPOSITORY_KEY, NOTE_KEY)
from BasicUtils import UpdateCallback from BasicUtils import UpdateCallback
import _GrampsDbWriteXML
import const
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -96,40 +98,17 @@ def importData(database, filename, callback=None, cl=0, use_trans=False):
read_only = database.readonly read_only = database.readonly
database.readonly = False database.readonly = False
if GZIP_OK: xml_file = open_file(filename, cl)
use_gzip = True
try: if xml_file is None or \
ofile = gzip.open(filename, "r") version_is_valid(xml_file, cl) is False:
ofile.read(1) if cl:
ofile.close() sys.exit(1)
except IOError, msg:
use_gzip = False
except ValueError, msg:
use_gzip = True
else: else:
use_gzip = False return
try: try:
if use_gzip: xml_file.seek(0)
xml_file = gzip.open(filename, "rb")
else:
xml_file = open(filename, "r")
except IOError, msg:
if cl:
print "Error: %s could not be opened Exiting." % filename
print msg
sys.exit(1)
else:
ErrorDialog(_("%s could not be opened") % filename, str(msg))
return
except:
if cl:
print "Error: %s could not be opened. Exiting." % filename
sys.exit(1)
else:
ErrorDialog(_("%s could not be opened") % filename)
return
try:
parser.parse(xml_file, use_trans, line_cnt, person_cnt) parser.parse(xml_file, use_trans, line_cnt, person_cnt)
except IOError, msg: except IOError, msg:
if cl: if cl:
@ -2140,3 +2119,108 @@ def build_place_title(loc):
if loc.country: if loc.country:
value = append_value(value, loc.country) value = append_value(value, loc.country)
return value return value
#-------------------------------------------------------------------------
#
# VersionParser
#
#-------------------------------------------------------------------------
class VersionParser:
"""
Utility class to quickly get the versions from an XML file.
"""
def __init__(self, xml_file):
"""
xml_file must be a file object that is already open.
"""
self.__p = ParserCreate()
self.__p.StartElementHandler = self.__element_handler
self.__gramps_version = 'unknown'
self.__xml_version = '1.0.0'
xml_file.seek(0)
self.__p.ParseFile(xml_file)
def __element_handler(self, tag, attrs):
" Handle XML elements "
if tag == "database" and attrs.has_key('xmlns'):
xmlns = attrs.get('xmlns')
self.__xml_version = xmlns.split('/')[4]
elif tag == "created" and attrs.has_key('version'):
self.__gramps_version = attrs.get('version')
def get_xmlns_version(self):
" Get the namespace version of the file "
return self.__xml_version
def get_gramps_version(self):
" Get the version of Gramps that created the file "
return self.__gramps_version
def open_file(filename, cli):
"""
Open the xml file.
Return a valid file handle if the file opened sucessfully.
Return None if the file was not able to be opened.
"""
if GZIP_OK:
use_gzip = True
try:
ofile = gzip.open(filename, "r")
ofile.read(1)
ofile.close()
except IOError, msg:
use_gzip = False
except ValueError, msg:
use_gzip = True
else:
use_gzip = False
try:
if use_gzip:
xml_file = gzip.open(filename, "rb")
else:
xml_file = open(filename, "r")
except IOError, msg:
if cli:
print "Error: %s could not be opened Exiting." % filename
print msg
else:
ErrorDialog(_("%s could not be opened") % filename, str(msg))
xml_file = None
except:
if cli:
print "Error: %s could not be opened. Exiting." % filename
else:
ErrorDialog(_("%s could not be opened") % filename)
xml_file = None
return xml_file
def version_is_valid(filename, cli):
"""
Validate the xml version.
"""
parser = VersionParser(filename)
if parser.get_xmlns_version() > _GrampsDbWriteXML.XML_VERSION:
msg = _("The .gramps file you are importing was made by version %s of "
"GRAMPS, while you are running an older version %s. "
"The file might include parts which cannot be understood by "
"this version of GRAMPS and will be discarded upon import."
) % (parser.get_gramps_version(), const.VERSION)
if cli:
print msg
print _('Enter "Yes" to continue with import.')
response = sys.stdin.read()
if response not in ["Yes", "yes"]:
return False
else:
prompt = QuestionDialog2( _("Import Newer File?"), msg,
_("Continue with import"),
_("Do not import newer file") )
response = prompt.run()
if response is False:
return False
return True