pylint on Gedcom importer and exporter
This commit is contained in:
parent
436509edf6
commit
ac4ba4cb0b
@ -44,12 +44,10 @@ from gramps.gen.const import GRAMPS_LOCALE as glocale
|
|||||||
_ = glocale.translation.gettext
|
_ = glocale.translation.gettext
|
||||||
from gramps.gen.lib import (AttributeType, ChildRefType, Citation, Date,
|
from gramps.gen.lib import (AttributeType, ChildRefType, Citation, Date,
|
||||||
EventRoleType, EventType, LdsOrd, NameType,
|
EventRoleType, EventType, LdsOrd, NameType,
|
||||||
PlaceType, NoteType, Person, UrlType,
|
PlaceType, NoteType, Person, UrlType)
|
||||||
SrcAttributeType)
|
|
||||||
from gramps.version import VERSION
|
from gramps.version import VERSION
|
||||||
import gramps.plugins.lib.libgedcom as libgedcom
|
import gramps.plugins.lib.libgedcom as libgedcom
|
||||||
from gramps.gen.errors import DatabaseError
|
from gramps.gen.errors import DatabaseError
|
||||||
from gramps.gui.plug.export import WriterOptionBox
|
|
||||||
from gramps.gen.updatecallback import UpdateCallback
|
from gramps.gen.updatecallback import UpdateCallback
|
||||||
from gramps.gen.utils.file import media_path_full
|
from gramps.gen.utils.file import media_path_full
|
||||||
from gramps.gen.utils.place import conv_lat_lon
|
from gramps.gen.utils.place import conv_lat_lon
|
||||||
@ -64,7 +62,7 @@ from gramps.gen.display.place import displayer as _pd
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
NEEDS_PARAMETER = set(
|
NEEDS_PARAMETER = set(
|
||||||
["CAST", "DSCR", "EDUC", "IDNO", "NATI", "NCHI",
|
["CAST", "DSCR", "EDUC", "IDNO", "NATI", "NCHI",
|
||||||
"NMR", "OCCU", "PROP", "RELI", "SSN", "TITL"])
|
"NMR", "OCCU", "PROP", "RELI", "SSN", "TITL"])
|
||||||
|
|
||||||
LDS_ORD_NAME = {
|
LDS_ORD_NAME = {
|
||||||
LdsOrd.BAPTISM : 'BAPL',
|
LdsOrd.BAPTISM : 'BAPL',
|
||||||
@ -72,7 +70,7 @@ LDS_ORD_NAME = {
|
|||||||
LdsOrd.SEAL_TO_PARENTS : 'SLGC',
|
LdsOrd.SEAL_TO_PARENTS : 'SLGC',
|
||||||
LdsOrd.SEAL_TO_SPOUSE : 'SLGS',
|
LdsOrd.SEAL_TO_SPOUSE : 'SLGS',
|
||||||
LdsOrd.CONFIRMATION : 'CONL',
|
LdsOrd.CONFIRMATION : 'CONL',
|
||||||
}
|
}
|
||||||
|
|
||||||
LDS_STATUS = {
|
LDS_STATUS = {
|
||||||
LdsOrd.STATUS_BIC : "BIC",
|
LdsOrd.STATUS_BIC : "BIC",
|
||||||
@ -86,19 +84,17 @@ LDS_STATUS = {
|
|||||||
LdsOrd.STATUS_QUALIFIED : "QUALIFIED",
|
LdsOrd.STATUS_QUALIFIED : "QUALIFIED",
|
||||||
LdsOrd.STATUS_DNS_CAN : "DNS/CAN",
|
LdsOrd.STATUS_DNS_CAN : "DNS/CAN",
|
||||||
LdsOrd.STATUS_STILLBORN : "STILLBORN",
|
LdsOrd.STATUS_STILLBORN : "STILLBORN",
|
||||||
LdsOrd.STATUS_SUBMITTED : "SUBMITTED" ,
|
LdsOrd.STATUS_SUBMITTED : "SUBMITTED",
|
||||||
LdsOrd.STATUS_UNCLEARED : "UNCLEARED",
|
LdsOrd.STATUS_UNCLEARED : "UNCLEARED",
|
||||||
}
|
}
|
||||||
|
|
||||||
LANGUAGES = {
|
LANGUAGES = {
|
||||||
'cs' : 'Czech', 'da' : 'Danish', 'nl' : 'Dutch',
|
'cs' : 'Czech', 'da' : 'Danish', 'nl' : 'Dutch', 'en' : 'English',
|
||||||
'en' : 'English', 'eo' : 'Esperanto', 'fi' : 'Finnish',
|
'eo' : 'Esperanto', 'fi' : 'Finnish', 'fr' : 'French', 'de' : 'German',
|
||||||
'fr' : 'French', 'de' : 'German', 'hu' : 'Hungarian',
|
'hu' : 'Hungarian', 'it' : 'Italian', 'lt' : 'Latvian',
|
||||||
'it' : 'Italian', 'lt' : 'Latvian', 'lv' : 'Lithuanian',
|
'lv' : 'Lithuanian', 'no' : 'Norwegian', 'po' : 'Polish',
|
||||||
'no' : 'Norwegian', 'po' : 'Polish', 'pt' : 'Portuguese',
|
'pt' : 'Portuguese', 'ro' : 'Romanian', 'sk' : 'Slovak',
|
||||||
'ro' : 'Romanian', 'sk' : 'Slovak', 'es' : 'Spanish',
|
'es' : 'Spanish', 'sv' : 'Swedish', 'ru' : 'Russian', }
|
||||||
'sv' : 'Swedish', 'ru' : 'Russian',
|
|
||||||
}
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -113,23 +109,25 @@ MIME2GED = {
|
|||||||
"image/x-pcx" : "pcx",
|
"image/x-pcx" : "pcx",
|
||||||
"image/tiff" : "tiff",
|
"image/tiff" : "tiff",
|
||||||
"audio/x-wav" : "wav"
|
"audio/x-wav" : "wav"
|
||||||
}
|
}
|
||||||
|
|
||||||
QUALITY_MAP = {
|
QUALITY_MAP = {
|
||||||
Citation.CONF_VERY_HIGH : "3",
|
Citation.CONF_VERY_HIGH : "3",
|
||||||
Citation.CONF_HIGH : "2",
|
Citation.CONF_HIGH : "2",
|
||||||
Citation.CONF_LOW : "1",
|
Citation.CONF_LOW : "1",
|
||||||
Citation.CONF_VERY_LOW : "0",
|
Citation.CONF_VERY_LOW : "0",
|
||||||
}
|
}
|
||||||
|
|
||||||
PEDIGREE_TYPES = {
|
PEDIGREE_TYPES = {
|
||||||
ChildRefType.BIRTH: 'birth',
|
ChildRefType.BIRTH : 'birth',
|
||||||
ChildRefType.STEPCHILD: 'Step',
|
ChildRefType.STEPCHILD: 'Step',
|
||||||
ChildRefType.ADOPTED: 'Adopted',
|
ChildRefType.ADOPTED : 'Adopted',
|
||||||
ChildRefType.FOSTER: 'Foster',
|
ChildRefType.FOSTER : 'Foster',
|
||||||
}
|
}
|
||||||
|
|
||||||
NOTES_PER_PERSON = 104 # fudge factor to make progress meter a bit smoother
|
NOTES_PER_PERSON = 104 # fudge factor to make progress meter a bit smoother
|
||||||
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# sort_handles_by_id
|
# sort_handles_by_id
|
||||||
@ -148,10 +146,11 @@ def sort_handles_by_id(handle_list, handle_to_object):
|
|||||||
obj = handle_to_object(handle)
|
obj = handle_to_object(handle)
|
||||||
if obj:
|
if obj:
|
||||||
data = (obj.get_gramps_id(), handle)
|
data = (obj.get_gramps_id(), handle)
|
||||||
sorted_list.append (data)
|
sorted_list.append(data)
|
||||||
sorted_list.sort()
|
sorted_list.sort()
|
||||||
return sorted_list
|
return sorted_list
|
||||||
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# breakup
|
# breakup
|
||||||
@ -170,8 +169,8 @@ def breakup(txt, limit):
|
|||||||
# look for non-space pair to break between
|
# look for non-space pair to break between
|
||||||
# do not break within a UTF-8 byte sequence, i. e. first char >127
|
# do not break within a UTF-8 byte sequence, i. e. first char >127
|
||||||
idx = limit
|
idx = limit
|
||||||
while (idx>0 and (txt[idx-1].isspace() or txt[idx].isspace()
|
while (idx > 0 and (txt[idx - 1].isspace() or txt[idx].isspace() or
|
||||||
or ord(txt[idx-1]) > 127)):
|
ord(txt[idx - 1]) > 127)):
|
||||||
idx -= 1
|
idx -= 1
|
||||||
if idx == 0:
|
if idx == 0:
|
||||||
#no words to break on, just break at limit anyway
|
#no words to break on, just break at limit anyway
|
||||||
@ -191,6 +190,7 @@ def breakup(txt, limit):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def event_has_subordinate_data(event, event_ref):
|
def event_has_subordinate_data(event, event_ref):
|
||||||
|
""" determine if event is empty or not """
|
||||||
if event and event_ref:
|
if event and event_ref:
|
||||||
return (event.get_description().strip() or
|
return (event.get_description().strip() or
|
||||||
not event.get_date_object().is_empty() or
|
not event.get_date_object().is_empty() or
|
||||||
@ -239,7 +239,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
Write the actual GEDCOM file to the specified filename.
|
Write the actual GEDCOM file to the specified filename.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
self.dirname = os.path.dirname (filename)
|
self.dirname = os.path.dirname(filename)
|
||||||
with open(filename, "w", encoding='utf-8') as self.gedcom_file:
|
with open(filename, "w", encoding='utf-8') as self.gedcom_file:
|
||||||
person_len = self.dbase.get_number_of_people()
|
person_len = self.dbase.get_number_of_people()
|
||||||
family_len = self.dbase.get_number_of_families()
|
family_len = self.dbase.get_number_of_families()
|
||||||
@ -273,7 +273,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
into multiple lines using CONC.
|
into multiple lines using CONC.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
assert(token)
|
assert token
|
||||||
if textlines:
|
if textlines:
|
||||||
# break the line into multiple lines if a newline is found
|
# break the line into multiple lines if a newline is found
|
||||||
textlines = textlines.replace('\n\r', '\n')
|
textlines = textlines.replace('\n\r', '\n')
|
||||||
@ -288,7 +288,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
txt = prefix.join(breakup(text, limit))
|
txt = prefix.join(breakup(text, limit))
|
||||||
else:
|
else:
|
||||||
txt = text
|
txt = text
|
||||||
self.gedcom_file.write("%d %s %s\n" % (token_level, token, txt))
|
self.gedcom_file.write("%d %s %s\n" %
|
||||||
|
(token_level, token, txt))
|
||||||
token_level = level + 1
|
token_level = level + 1
|
||||||
token = "CONT"
|
token = "CONT"
|
||||||
else:
|
else:
|
||||||
@ -335,7 +336,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
|
|
||||||
self._writeln(0, "HEAD")
|
self._writeln(0, "HEAD")
|
||||||
self._writeln(1, "SOUR", "Gramps")
|
self._writeln(1, "SOUR", "Gramps")
|
||||||
self._writeln(2, "VERS", VERSION)
|
self._writeln(2, "VERS", VERSION)
|
||||||
self._writeln(2, "NAME", "Gramps")
|
self._writeln(2, "NAME", "Gramps")
|
||||||
self._writeln(1, "DATE", date_str)
|
self._writeln(1, "DATE", date_str)
|
||||||
self._writeln(2, "TIME", time_str)
|
self._writeln(2, "TIME", time_str)
|
||||||
@ -441,7 +442,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
if person is None:
|
if person is None:
|
||||||
return
|
return
|
||||||
self._writeln(0, "@%s@" % person.get_gramps_id(), "INDI")
|
self._writeln(0, "@%s@" % person.get_gramps_id(), "INDI")
|
||||||
|
|
||||||
self._names(person)
|
self._names(person)
|
||||||
self._gender(person)
|
self._gender(person)
|
||||||
@ -471,9 +472,9 @@ class GedcomWriter(UpdateCallback):
|
|||||||
person = self.dbase.get_person_from_handle(ref.ref)
|
person = self.dbase.get_person_from_handle(ref.ref)
|
||||||
if person:
|
if person:
|
||||||
self._writeln(level, "ASSO", "@%s@" % person.get_gramps_id())
|
self._writeln(level, "ASSO", "@%s@" % person.get_gramps_id())
|
||||||
self._writeln(level+1, "RELA", ref.get_relation())
|
self._writeln(level + 1, "RELA", ref.get_relation())
|
||||||
self._note_references(ref.get_note_list(), level+1)
|
self._note_references(ref.get_note_list(), level + 1)
|
||||||
self._source_references(ref.get_citation_list(), level+1)
|
self._source_references(ref.get_citation_list(), level + 1)
|
||||||
|
|
||||||
def _note_references(self, notelist, level):
|
def _note_references(self, notelist, level):
|
||||||
"""
|
"""
|
||||||
@ -498,8 +499,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
If a nickname is present in the name structure, it has precedence
|
If a nickname is present in the name structure, it has precedence
|
||||||
|
|
||||||
"""
|
"""
|
||||||
nicknames = [ attr.get_value() for attr in person.get_attribute_list()
|
nicknames = [attr.get_value() for attr in person.get_attribute_list()
|
||||||
if int(attr.get_type()) == AttributeType.NICKNAME ]
|
if int(attr.get_type()) == AttributeType.NICKNAME]
|
||||||
if len(nicknames) > 0:
|
if len(nicknames) > 0:
|
||||||
nickname = nicknames[0]
|
nickname = nicknames[0]
|
||||||
else:
|
else:
|
||||||
@ -551,7 +552,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
adop_written = False
|
adop_written = False
|
||||||
for event_ref in person.get_event_ref_list():
|
for event_ref in person.get_event_ref_list():
|
||||||
event = self.dbase.get_event_from_handle(event_ref.ref)
|
event = self.dbase.get_event_from_handle(event_ref.ref)
|
||||||
if not event: continue
|
if not event:
|
||||||
|
continue
|
||||||
self._process_person_event(person, event, event_ref)
|
self._process_person_event(person, event, event_ref)
|
||||||
if not adop_written:
|
if not adop_written:
|
||||||
self._adoption_records(person, adop_written)
|
self._adoption_records(person, adop_written)
|
||||||
@ -615,12 +617,12 @@ class GedcomWriter(UpdateCallback):
|
|||||||
|
|
||||||
adoptions = []
|
adoptions = []
|
||||||
|
|
||||||
for family in [ self.dbase.get_family_from_handle(fh)
|
for family in [self.dbase.get_family_from_handle(fh)
|
||||||
for fh in person.get_parent_family_handle_list() ]:
|
for fh in person.get_parent_family_handle_list()]:
|
||||||
if family is None:
|
if family is None:
|
||||||
continue
|
continue
|
||||||
for child_ref in [ ref for ref in family.get_child_ref_list()
|
for child_ref in [ref for ref in family.get_child_ref_list()
|
||||||
if ref.ref == person.handle ]:
|
if ref.ref == person.handle]:
|
||||||
if child_ref.mrel == ChildRefType.ADOPTED \
|
if child_ref.mrel == ChildRefType.ADOPTED \
|
||||||
or child_ref.frel == ChildRefType.ADOPTED:
|
or child_ref.frel == ChildRefType.ADOPTED:
|
||||||
adoptions.append((family, child_ref.frel, child_ref.mrel))
|
adoptions.append((family, child_ref.frel, child_ref.mrel))
|
||||||
@ -649,8 +651,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# filter out the nicknames
|
# filter out the nicknames
|
||||||
attr_list = [ attr for attr in person.get_attribute_list()
|
attr_list = [attr for attr in person.get_attribute_list()
|
||||||
if attr.get_type() != AttributeType.NICKNAME ]
|
if attr.get_type() != AttributeType.NICKNAME]
|
||||||
|
|
||||||
for attr in attr_list:
|
for attr in attr_list:
|
||||||
|
|
||||||
@ -714,8 +716,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# get the list of familes from the handle list
|
# get the list of familes from the handle list
|
||||||
family_list = [ self.dbase.get_family_from_handle(hndl)
|
family_list = [self.dbase.get_family_from_handle(hndl)
|
||||||
for hndl in person.get_parent_family_handle_list() ]
|
for hndl in person.get_parent_family_handle_list()]
|
||||||
|
|
||||||
for family in family_list:
|
for family in family_list:
|
||||||
if family:
|
if family:
|
||||||
@ -751,8 +753,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# get the list of familes from the handle list
|
# get the list of familes from the handle list
|
||||||
family_list = [ self.dbase.get_family_from_handle(hndl)
|
family_list = [self.dbase.get_family_from_handle(hndl)
|
||||||
for hndl in person.get_family_handle_list() ]
|
for hndl in person.get_family_handle_list()]
|
||||||
|
|
||||||
for family in family_list:
|
for family in family_list:
|
||||||
if family:
|
if family:
|
||||||
@ -791,11 +793,11 @@ class GedcomWriter(UpdateCallback):
|
|||||||
self._writeln(level, 'FAX', url.get_path())
|
self._writeln(level, 'FAX', url.get_path())
|
||||||
else:
|
else:
|
||||||
self._writeln(level, 'OBJE')
|
self._writeln(level, 'OBJE')
|
||||||
self._writeln(level+1, 'FORM', 'URL')
|
self._writeln(level + 1, 'FORM', 'URL')
|
||||||
if url.get_description():
|
if url.get_description():
|
||||||
self._writeln(level+1, 'TITL', url.get_description())
|
self._writeln(level + 1, 'TITL', url.get_description())
|
||||||
if url.get_path():
|
if url.get_path():
|
||||||
self._writeln(level+1, 'FILE', url.get_path(), limit=255)
|
self._writeln(level + 1, 'FILE', url.get_path(), limit=255)
|
||||||
|
|
||||||
def _families(self):
|
def _families(self):
|
||||||
"""
|
"""
|
||||||
@ -831,7 +833,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
return
|
return
|
||||||
gramps_id = family.get_gramps_id()
|
gramps_id = family.get_gramps_id()
|
||||||
|
|
||||||
self._writeln(0, '@%s@' % gramps_id, 'FAM' )
|
self._writeln(0, '@%s@' % gramps_id, 'FAM')
|
||||||
|
|
||||||
self._family_reference('HUSB', family.get_father_handle())
|
self._family_reference('HUSB', family.get_father_handle())
|
||||||
self._family_reference('WIFE', family.get_mother_handle())
|
self._family_reference('WIFE', family.get_mother_handle())
|
||||||
@ -854,7 +856,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
for cref in child_ref_list]
|
for cref in child_ref_list]
|
||||||
|
|
||||||
for gid in child_list:
|
for gid in child_list:
|
||||||
if gid is None: continue
|
if gid is None:
|
||||||
|
continue
|
||||||
self._writeln(1, 'CHIL', '@%s@' % gid)
|
self._writeln(1, 'CHIL', '@%s@' % gid)
|
||||||
|
|
||||||
def _family_reference(self, token, person_handle):
|
def _family_reference(self, token, person_handle):
|
||||||
@ -880,7 +883,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
for event_ref in family.get_event_ref_list():
|
for event_ref in family.get_event_ref_list():
|
||||||
event = self.dbase.get_event_from_handle(event_ref.ref)
|
event = self.dbase.get_event_from_handle(event_ref.ref)
|
||||||
if event is None: continue
|
if event is None:
|
||||||
|
continue
|
||||||
self._process_family_event(event, event_ref)
|
self._process_family_event(event, event_ref)
|
||||||
self._dump_event_stats(event, event_ref)
|
self._dump_event_stats(event, event_ref)
|
||||||
|
|
||||||
@ -923,10 +927,10 @@ class GedcomWriter(UpdateCallback):
|
|||||||
for attr in attr_list:
|
for attr in attr_list:
|
||||||
if attr.get_type() == AttributeType.FATHER_AGE:
|
if attr.get_type() == AttributeType.FATHER_AGE:
|
||||||
self._writeln(level, 'HUSB')
|
self._writeln(level, 'HUSB')
|
||||||
self._writeln(level+1, 'AGE', attr.get_value())
|
self._writeln(level + 1, 'AGE', attr.get_value())
|
||||||
elif attr.get_type() == AttributeType.MOTHER_AGE:
|
elif attr.get_type() == AttributeType.MOTHER_AGE:
|
||||||
self._writeln(level, 'WIFE')
|
self._writeln(level, 'WIFE')
|
||||||
self._writeln(level+1, 'AGE', attr.get_value())
|
self._writeln(level + 1, 'AGE', attr.get_value())
|
||||||
|
|
||||||
def _family_attributes(self, attr_list, level):
|
def _family_attributes(self, attr_list, level):
|
||||||
"""
|
"""
|
||||||
@ -958,9 +962,9 @@ class GedcomWriter(UpdateCallback):
|
|||||||
self._writeln(1, 'FACT', value)
|
self._writeln(1, 'FACT', value)
|
||||||
self._writeln(2, 'TYPE', key)
|
self._writeln(2, 'TYPE', key)
|
||||||
|
|
||||||
self._note_references(attr.get_note_list(), level+1)
|
self._note_references(attr.get_note_list(), level + 1)
|
||||||
self._source_references(attr.get_citation_list(),
|
self._source_references(attr.get_citation_list(),
|
||||||
level+1)
|
level + 1)
|
||||||
|
|
||||||
def _sources(self):
|
def _sources(self):
|
||||||
"""
|
"""
|
||||||
@ -973,7 +977,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
for (source_id, handle) in sorted_list:
|
for (source_id, handle) in sorted_list:
|
||||||
self.update()
|
self.update()
|
||||||
source = self.dbase.get_source_from_handle(handle)
|
source = self.dbase.get_source_from_handle(handle)
|
||||||
if source is None: continue
|
if source is None:
|
||||||
|
continue
|
||||||
self._writeln(0, '@%s@' % source_id, 'SOUR')
|
self._writeln(0, '@%s@' % source_id, 'SOUR')
|
||||||
if source.get_title():
|
if source.get_title():
|
||||||
self._writeln(1, 'TITL', source.get_title())
|
self._writeln(1, 'TITL', source.get_title())
|
||||||
@ -1011,7 +1016,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
self.update()
|
self.update()
|
||||||
note_cnt += 1
|
note_cnt += 1
|
||||||
note = self.dbase.get_note_from_handle(note_handle)
|
note = self.dbase.get_note_from_handle(note_handle)
|
||||||
if note is None: continue
|
if note is None:
|
||||||
|
continue
|
||||||
self._note_record(note)
|
self._note_record(note)
|
||||||
|
|
||||||
def _note_record(self, note):
|
def _note_record(self, note):
|
||||||
@ -1025,7 +1031,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
+1 <<CHANGE_DATE>> {0:1}
|
+1 <<CHANGE_DATE>> {0:1}
|
||||||
"""
|
"""
|
||||||
if note:
|
if note:
|
||||||
self._writeln(0, '@%s@' % note.get_gramps_id(), 'NOTE ' + note.get())
|
self._writeln(0, '@%s@' % note.get_gramps_id(),
|
||||||
|
'NOTE ' + note.get())
|
||||||
|
|
||||||
def _repos(self):
|
def _repos(self):
|
||||||
"""
|
"""
|
||||||
@ -1050,8 +1057,9 @@ class GedcomWriter(UpdateCallback):
|
|||||||
for (repo_id, handle) in sorted_list:
|
for (repo_id, handle) in sorted_list:
|
||||||
self.update()
|
self.update()
|
||||||
repo = self.dbase.get_repository_from_handle(handle)
|
repo = self.dbase.get_repository_from_handle(handle)
|
||||||
if repo is None: continue
|
if repo is None:
|
||||||
self._writeln(0, '@%s@' % repo_id, 'REPO' )
|
continue
|
||||||
|
self._writeln(0, '@%s@' % repo_id, 'REPO')
|
||||||
if repo.get_name():
|
if repo.get_name():
|
||||||
self._writeln(1, 'NAME', repo.get_name())
|
self._writeln(1, 'NAME', repo.get_name())
|
||||||
for addr in repo.get_address_list():
|
for addr in repo.get_address_list():
|
||||||
@ -1084,14 +1092,14 @@ class GedcomWriter(UpdateCallback):
|
|||||||
|
|
||||||
repo_id = repo.get_gramps_id()
|
repo_id = repo.get_gramps_id()
|
||||||
|
|
||||||
self._writeln(level, 'REPO', '@%s@' % repo_id )
|
self._writeln(level, 'REPO', '@%s@' % repo_id)
|
||||||
|
|
||||||
self._note_references(reporef.get_note_list(), level+1)
|
self._note_references(reporef.get_note_list(), level + 1)
|
||||||
|
|
||||||
if reporef.get_call_number():
|
if reporef.get_call_number():
|
||||||
self._writeln(level+1, 'CALN', reporef.get_call_number() )
|
self._writeln(level + 1, 'CALN', reporef.get_call_number())
|
||||||
if reporef.get_media_type():
|
if reporef.get_media_type():
|
||||||
self._writeln(level+2, 'MEDI', str(reporef.get_media_type()))
|
self._writeln(level + 2, 'MEDI', str(reporef.get_media_type()))
|
||||||
|
|
||||||
def _person_event_ref(self, key, event_ref):
|
def _person_event_ref(self, key, event_ref):
|
||||||
"""
|
"""
|
||||||
@ -1117,10 +1125,10 @@ class GedcomWriter(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
self._writeln(level, 'CHAN')
|
self._writeln(level, 'CHAN')
|
||||||
time_val = time.gmtime(timeval)
|
time_val = time.gmtime(timeval)
|
||||||
self._writeln(level+1, 'DATE', '%d %s %d' % (
|
self._writeln(level + 1, 'DATE', '%d %s %d' % (
|
||||||
time_val[2], libgedcom.MONTH[time_val[1]], time_val[0]))
|
time_val[2], libgedcom.MONTH[time_val[1]], time_val[0]))
|
||||||
self._writeln(level+2, 'TIME', '%02d:%02d:%02d' % (
|
self._writeln(level + 2, 'TIME', '%02d:%02d:%02d' % (
|
||||||
time_val[3], time_val[4], time_val[5]))
|
time_val[3], time_val[4], time_val[5]))
|
||||||
|
|
||||||
def _dump_event_stats(self, event, event_ref):
|
def _dump_event_stats(self, event, event_ref):
|
||||||
"""
|
"""
|
||||||
@ -1134,12 +1142,11 @@ class GedcomWriter(UpdateCallback):
|
|||||||
self._date(2, dateobj)
|
self._date(2, dateobj)
|
||||||
if self._datewritten:
|
if self._datewritten:
|
||||||
# write out TIME if present
|
# write out TIME if present
|
||||||
times = [ attr.get_value() for attr in event.get_attribute_list()
|
times = [attr.get_value() for attr in event.get_attribute_list()
|
||||||
if int(attr.get_type()) == AttributeType.TIME ]
|
if int(attr.get_type()) == AttributeType.TIME]
|
||||||
# Not legal, but inserted by PhpGedView
|
# Not legal, but inserted by PhpGedView
|
||||||
if len(times) > 0:
|
if len(times) > 0:
|
||||||
time = times[0]
|
self._writeln(3, 'TIME', times[0])
|
||||||
self._writeln(3, 'TIME', time)
|
|
||||||
|
|
||||||
place = None
|
place = None
|
||||||
|
|
||||||
@ -1220,17 +1227,19 @@ class GedcomWriter(UpdateCallback):
|
|||||||
family_handle = lds_ord.get_family_handle()
|
family_handle = lds_ord.get_family_handle()
|
||||||
family = self.dbase.get_family_from_handle(family_handle)
|
family = self.dbase.get_family_from_handle(family_handle)
|
||||||
if family:
|
if family:
|
||||||
self._writeln(index+1, 'FAMC', '@%s@' % family.get_gramps_id())
|
self._writeln(index + 1, 'FAMC', '@%s@' %
|
||||||
|
family.get_gramps_id())
|
||||||
if lds_ord.get_temple():
|
if lds_ord.get_temple():
|
||||||
self._writeln(index+1, 'TEMP', lds_ord.get_temple())
|
self._writeln(index + 1, 'TEMP', lds_ord.get_temple())
|
||||||
if lds_ord.get_place_handle():
|
if lds_ord.get_place_handle():
|
||||||
place = self.dbase.get_place_from_handle(lds_ord.get_place_handle())
|
place = self.dbase.get_place_from_handle(
|
||||||
|
lds_ord.get_place_handle())
|
||||||
self._place(place, lds_ord.get_date_object(), 2)
|
self._place(place, lds_ord.get_date_object(), 2)
|
||||||
if lds_ord.get_status() != LdsOrd.STATUS_NONE:
|
if lds_ord.get_status() != LdsOrd.STATUS_NONE:
|
||||||
self._writeln(2, 'STAT', LDS_STATUS[lds_ord.get_status()])
|
self._writeln(2, 'STAT', LDS_STATUS[lds_ord.get_status()])
|
||||||
|
|
||||||
self._note_references(lds_ord.get_note_list(), index+1)
|
self._note_references(lds_ord.get_note_list(), index + 1)
|
||||||
self._source_references(lds_ord.get_citation_list(), index+1)
|
self._source_references(lds_ord.get_citation_list(), index + 1)
|
||||||
|
|
||||||
def _date(self, level, date):
|
def _date(self, level, date):
|
||||||
"""
|
"""
|
||||||
@ -1352,28 +1361,27 @@ class GedcomWriter(UpdateCallback):
|
|||||||
# Reference to the source
|
# Reference to the source
|
||||||
self._writeln(level, "SOUR", "@%s@" % src.get_gramps_id())
|
self._writeln(level, "SOUR", "@%s@" % src.get_gramps_id())
|
||||||
if citation.get_page() != "":
|
if citation.get_page() != "":
|
||||||
# PAGE <WHERE_WITHIN_SOURCE> can not have CONC lines.
|
# PAGE <WHERE_WITHIN_SOURCE> can not have CONC lines.
|
||||||
# WHERE_WITHIN_SOURCE:= {Size=1:248}
|
# WHERE_WITHIN_SOURCE:= {Size=1:248}
|
||||||
# Maximize line to 248 and set limit to 248, for no line split
|
# Maximize line to 248 and set limit to 248, for no line split
|
||||||
self._writeln(level+1, 'PAGE', citation.get_page()[0:248],
|
self._writeln(level + 1, 'PAGE', citation.get_page()[0:248],
|
||||||
limit=248)
|
limit=248)
|
||||||
|
|
||||||
|
|
||||||
conf = min(citation.get_confidence_level(),
|
conf = min(citation.get_confidence_level(),
|
||||||
Citation.CONF_VERY_HIGH)
|
Citation.CONF_VERY_HIGH)
|
||||||
if conf != Citation.CONF_NORMAL and conf != -1:
|
if conf != Citation.CONF_NORMAL and conf != -1:
|
||||||
self._writeln(level+1, "QUAY", QUALITY_MAP[conf])
|
self._writeln(level + 1, "QUAY", QUALITY_MAP[conf])
|
||||||
|
|
||||||
if not citation.get_date_object().is_empty():
|
if not citation.get_date_object().is_empty():
|
||||||
self._writeln(level+1, 'DATA')
|
self._writeln(level + 1, 'DATA')
|
||||||
self._date(level+2, citation.get_date_object())
|
self._date(level + 2, citation.get_date_object())
|
||||||
|
|
||||||
if len(citation.get_note_list()) > 0:
|
if len(citation.get_note_list()) > 0:
|
||||||
|
|
||||||
note_list = [ self.dbase.get_note_from_handle(h)
|
note_list = [self.dbase.get_note_from_handle(h)
|
||||||
for h in citation.get_note_list() ]
|
for h in citation.get_note_list()]
|
||||||
note_list = [ n for n in note_list
|
note_list = [n for n in note_list
|
||||||
if n.get_type() == NoteType.SOURCE_TEXT]
|
if n.get_type() == NoteType.SOURCE_TEXT]
|
||||||
|
|
||||||
if note_list:
|
if note_list:
|
||||||
ref_text = note_list[0].get()
|
ref_text = note_list[0].get()
|
||||||
@ -1381,28 +1389,28 @@ class GedcomWriter(UpdateCallback):
|
|||||||
ref_text = ""
|
ref_text = ""
|
||||||
|
|
||||||
if ref_text != "" and citation.get_date_object().is_empty():
|
if ref_text != "" and citation.get_date_object().is_empty():
|
||||||
self._writeln(level+1, 'DATA')
|
self._writeln(level + 1, 'DATA')
|
||||||
if ref_text != "":
|
if ref_text != "":
|
||||||
self._writeln(level+2, "TEXT", ref_text)
|
self._writeln(level + 2, "TEXT", ref_text)
|
||||||
|
|
||||||
note_list = [ self.dbase.get_note_from_handle(h)
|
note_list = [self.dbase.get_note_from_handle(h)
|
||||||
for h in citation.get_note_list() ]
|
for h in citation.get_note_list()]
|
||||||
note_list = [ n.handle for n in note_list
|
note_list = [n.handle for n in note_list
|
||||||
if n and n.get_type() != NoteType.SOURCE_TEXT]
|
if n and n.get_type() != NoteType.SOURCE_TEXT]
|
||||||
self._note_references(note_list, level+1)
|
self._note_references(note_list, level + 1)
|
||||||
|
|
||||||
self._photos(citation.get_media_list(), level+1)
|
self._photos(citation.get_media_list(), level + 1)
|
||||||
|
|
||||||
even = None
|
even = None
|
||||||
for srcattr in citation.get_attribute_list():
|
for srcattr in citation.get_attribute_list():
|
||||||
if str(srcattr.type) == "EVEN":
|
if str(srcattr.type) == "EVEN":
|
||||||
even = srcattr.value
|
even = srcattr.value
|
||||||
self._writeln(level+1, "EVEN", even)
|
self._writeln(level + 1, "EVEN", even)
|
||||||
break
|
break
|
||||||
if even:
|
if even:
|
||||||
for srcattr in citation.get_attribute_list():
|
for srcattr in citation.get_attribute_list():
|
||||||
if str(srcattr.type) == "EVEN:ROLE":
|
if str(srcattr.type) == "EVEN:ROLE":
|
||||||
self._writeln(level+2, "ROLE", srcattr.value)
|
self._writeln(level + 2, "ROLE", srcattr.value)
|
||||||
break
|
break
|
||||||
|
|
||||||
def _photo(self, photo, level):
|
def _photo(self, photo, level):
|
||||||
@ -1423,11 +1431,11 @@ class GedcomWriter(UpdateCallback):
|
|||||||
return
|
return
|
||||||
self._writeln(level, 'OBJE')
|
self._writeln(level, 'OBJE')
|
||||||
if form:
|
if form:
|
||||||
self._writeln(level+1, 'FORM', form)
|
self._writeln(level + 1, 'FORM', form)
|
||||||
self._writeln(level+1, 'TITL', photo_obj.get_description())
|
self._writeln(level + 1, 'TITL', photo_obj.get_description())
|
||||||
self._writeln(level+1, 'FILE', path, limit=255)
|
self._writeln(level + 1, 'FILE', path, limit=255)
|
||||||
|
|
||||||
self._note_references(photo_obj.get_note_list(), level+1)
|
self._note_references(photo_obj.get_note_list(), level + 1)
|
||||||
|
|
||||||
def _place(self, place, dateobj, level):
|
def _place(self, place, dateobj, level):
|
||||||
"""
|
"""
|
||||||
@ -1443,7 +1451,8 @@ class GedcomWriter(UpdateCallback):
|
|||||||
+2 LONG <PLACE_LONGITUDE> {1:1}
|
+2 LONG <PLACE_LONGITUDE> {1:1}
|
||||||
+1 <<NOTE_STRUCTURE>> {0:M}
|
+1 <<NOTE_STRUCTURE>> {0:M}
|
||||||
"""
|
"""
|
||||||
if place is None: return
|
if place is None:
|
||||||
|
return
|
||||||
place_name = _pd.display(self.dbase, place, dateobj)
|
place_name = _pd.display(self.dbase, place, dateobj)
|
||||||
self._writeln(level, "PLAC", place_name.replace('\r', ' '), limit=120)
|
self._writeln(level, "PLAC", place_name.replace('\r', ' '), limit=120)
|
||||||
longitude = place.get_longitude()
|
longitude = place.get_longitude()
|
||||||
@ -1451,9 +1460,9 @@ class GedcomWriter(UpdateCallback):
|
|||||||
if longitude and latitude:
|
if longitude and latitude:
|
||||||
(latitude, longitude) = conv_lat_lon(latitude, longitude, "GEDCOM")
|
(latitude, longitude) = conv_lat_lon(latitude, longitude, "GEDCOM")
|
||||||
if longitude and latitude:
|
if longitude and latitude:
|
||||||
self._writeln(level+1, "MAP")
|
self._writeln(level + 1, "MAP")
|
||||||
self._writeln(level+2, 'LATI', latitude)
|
self._writeln(level + 2, 'LATI', latitude)
|
||||||
self._writeln(level+2, 'LONG', longitude)
|
self._writeln(level + 2, 'LONG', longitude)
|
||||||
|
|
||||||
# The Gedcom standard shows that an optional address structure can
|
# The Gedcom standard shows that an optional address structure can
|
||||||
# be written out in the event detail.
|
# be written out in the event detail.
|
||||||
@ -1466,7 +1475,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
country = location.get(PlaceType.COUNTRY)
|
country = location.get(PlaceType.COUNTRY)
|
||||||
postal_code = place.get_code()
|
postal_code = place.get_code()
|
||||||
|
|
||||||
if (street or locality or city or state or postal_code or country):
|
if street or locality or city or state or postal_code or country:
|
||||||
self._writeln(level, "ADDR", street)
|
self._writeln(level, "ADDR", street)
|
||||||
if street:
|
if street:
|
||||||
self._writeln(level + 1, 'ADR1', street)
|
self._writeln(level + 1, 'ADR1', street)
|
||||||
@ -1481,7 +1490,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
if country:
|
if country:
|
||||||
self._writeln(level + 1, 'CTRY', country)
|
self._writeln(level + 1, 'CTRY', country)
|
||||||
|
|
||||||
self._note_references(place.get_note_list(), level+1)
|
self._note_references(place.get_note_list(), level + 1)
|
||||||
|
|
||||||
def __write_addr(self, level, addr):
|
def __write_addr(self, level, addr):
|
||||||
"""
|
"""
|
||||||
@ -1535,6 +1544,7 @@ class GedcomWriter(UpdateCallback):
|
|||||||
if addr.get_country():
|
if addr.get_country():
|
||||||
self._writeln(level + 1, 'CTRY', addr.get_country())
|
self._writeln(level + 1, 'CTRY', addr.get_country())
|
||||||
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user