Bugfix for ImportProGen, bug #4869

svn: r17361
This commit is contained in:
Kees Bakker 2011-04-30 20:32:19 +00:00
parent db4c8f138a
commit 408580c8c9

View File

@ -2,7 +2,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2008-2008 Kees Bakker # Copyright (C) 2008-2011 Kees Bakker
# Copyright (C) 2008 Brian G. Matherly # Copyright (C) 2008 Brian G. Matherly
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
@ -106,7 +106,11 @@ def _read_mem(bname):
<ESC> <CR> hard return <ESC> <CR> hard return
<ESC> <^Z> end of the memo field <ESC> <^Z> end of the memo field
''' '''
f = open(bname + '.mem') if os.path.exists(bname + '.MEM'):
fname = bname + '.MEM'
else:
fname = bname + '.mem'
f = open(fname)
recfmt = "i28s" recfmt = "i28s"
reclen = struct.calcsize( recfmt ) reclen = struct.calcsize( recfmt )
#print "# reclen = %d" % reclen #print "# reclen = %d" % reclen
@ -123,7 +127,11 @@ def _read_mem(bname):
def _read_recs(table, bname): def _read_recs(table, bname):
'Read records from .PER or .REL file.' 'Read records from .PER or .REL file.'
f = open(bname + table.fileext) if os.path.exists(bname + table.fileext):
fname = bname + table.fileext
else:
fname = bname + table.fileext.lower()
f = open(fname)
recfmt = table.recfmt recfmt = table.recfmt
log.info("# %s - recfmt = %s" % (table['name1'], recfmt)) log.info("# %s - recfmt = %s" % (table['name1'], recfmt))
reclen = struct.calcsize( recfmt ) reclen = struct.calcsize( recfmt )
@ -158,7 +166,7 @@ def _get_defname(fname):
raise ProgenError(_("Not a Pro-Gen file")) raise ProgenError(_("Not a Pro-Gen file"))
return None, '?' return None, '?'
defname = lines[1].lower() defname = lines[1]
defname = defname.strip() defname = defname.strip()
# Strip drive, if any # Strip drive, if any
defname = re.sub( r'^\w:', '', defname ) defname = re.sub( r'^\w:', '', defname )
@ -166,16 +174,18 @@ def _get_defname(fname):
# Strip leading slash, if any. # Strip leading slash, if any.
if defname.startswith(os.sep): if defname.startswith(os.sep):
defname = defname[1:] defname = defname[1:]
#log.warning('_get_defname: fname=%(fname)s => defname=%(defname)s' % vars())
# Using the directory of <fname>, go to the parent directory until # Using the directory of <fname>, go to the parent directory until
# the DEF is found. # the DEF is found.
dir_, f = os.path.split(os.path.abspath(fname)) dir_, f = os.path.split(os.path.abspath(fname))
while dir_: while dir_ and dir_ != os.sep:
#log.warning('_get_defname: dir=%(dir_)s => defname=%(defname)s' % vars())
newdefname = os.path.join(dir_, defname) newdefname = os.path.join(dir_, defname)
if os.path.exists(newdefname): if os.path.exists(newdefname):
return newdefname, defname return newdefname, defname
newdefname = newdefname.upper() newdefname = newdefname.lower()
if os.path.exists(newdefname): if os.path.exists(newdefname):
return newdefname, defname return newdefname, defname
@ -299,8 +309,6 @@ class PG30_Def_Table:
self.parms[m.group(1)] = m.group(2) self.parms[m.group(1)] = m.group(2)
self.fileext = self.parms.get('fileext', None) self.fileext = self.parms.get('fileext', None)
if self.fileext:
self.fileext = self.fileext.lower()
#self.name1 = self.parms.get('name1', None) #self.name1 = self.parms.get('name1', None)
# If there is a n_fields entry then this is a table that # If there is a n_fields entry then this is a table that
@ -318,7 +326,7 @@ class PG30_Def_Table:
self.nam2fld[nam] = f self.nam2fld[nam] = f
if f.size != 0: if f.size != 0:
self.nam2idx[nam] = j self.nam2idx[nam] = j
#print "# %s <= %d" % (f[0], j) #print "# %s <= %d" % (f.fieldname, j)
self.recflds.append(f) self.recflds.append(f)
j = j + 1 j = j + 1
@ -487,10 +495,9 @@ class ProgenParser(object):
self.skeys = {} # Caching source handles self.skeys = {} # Caching source handles
def parse_progen_file(self): def parse_progen_file(self):
self.progress = ProgressMeter(_("Import from Pro-Gen"), '')
self.def_ = PG30_Def(self.fname) self.def_ = PG30_Def(self.fname)
#print self.def_.diag() #print self.def_.diag()
self.progress = ProgressMeter(_("Import from Pro-Gen"), '')
self.mems = _read_mem(self.bname) self.mems = _read_mem(self.bname)
self.pers = _read_recs(self.def_['Table_1'], self.bname) self.pers = _read_recs(self.def_['Table_1'], self.bname)