0007014: Errors handling owner/submitter information in GEDCOM files.

Only import researcher from GEDCOM or XML if the family tree was
originally empty.
This commit is contained in:
kulath 2015-02-02 18:57:05 +00:00
parent ed921b1a53
commit 65523e0442
5 changed files with 33 additions and 3 deletions

View File

@ -296,7 +296,10 @@ class CLIManager(object):
# apply preferred researcher if loaded file has none # apply preferred researcher if loaded file has none
res = self.dbstate.db.get_researcher() res = self.dbstate.db.get_researcher()
owner = get_researcher() owner = get_researcher()
if res.get_name() == "" and owner.get_name() != "": # If the DB Owner Info is empty and
# [default] Researcher is not empty and
# database is empty, then copy default researcher to DB owner
if res.is_empty() and not owner.is_empty() and self.dbstate.db.is_empty():
self.dbstate.db.set_researcher(owner) self.dbstate.db.set_researcher(owner)
name_displayer.set_name_format(self.dbstate.db.name_formats) name_displayer.set_name_format(self.dbstate.db.name_formats)

View File

@ -966,6 +966,18 @@ class DbBsddbRead(DbReadBase, Callback):
""" """
return self.get_number_of_records(self.tag_map) return self.get_number_of_records(self.tag_map)
def is_empty(self):
"""
Return true if there are no [primary] records in the database
"""
for obj_map in [self.person_map, self.family_map, self.event_map,
self.place_map, self.source_map, self.citation_map,
self.media_map, self.repository_map, self.note_map,
self.tag_map]:
if self.get_number_of_records(obj_map) > 0:
return False
return True
def all_handles(self, table): def all_handles(self, table):
""" return all the keys of a database table """ return all the keys of a database table
CAREFUL: For speed the keys are directly returned, so on python3 CAREFUL: For speed the keys are directly returned, so on python3

View File

@ -146,3 +146,10 @@ class Researcher(LocationBase):
['name', 'addr', 'locality', 'city', 'state', ['name', 'addr', 'locality', 'city', 'state',
'country', 'postal', 'phone', 'email'] 'country', 'postal', 'phone', 'email']
] ]
def is_empty(self):
for attr in ['name', 'addr', 'locality', 'city', 'state',
'country', 'postal', 'phone', 'email']:
if getattr(self, attr) != "":
return False
return True

View File

@ -511,6 +511,10 @@ class GrampsParser(UpdateCallback):
self.replace_import_handle = (self.db.get_number_of_people() > 0 and self.replace_import_handle = (self.db.get_number_of_people() > 0 and
not LOG.isEnabledFor(logging.DEBUG)) not LOG.isEnabledFor(logging.DEBUG))
# Similarly, if the data is imported into an empty family tree, we also
# import the Researcher; if the tree was not empty, the existing
# Researcher is retained
self.import_researcher = self.db.is_empty()
self.ord = None self.ord = None
self.objref = None self.objref = None
self.object = None self.object = None
@ -943,6 +947,9 @@ class GrampsParser(UpdateCallback):
# Register new formats # Register new formats
name_displayer.set_name_format(self.db.name_formats) name_displayer.set_name_format(self.db.name_formats)
# If the database was originally empty we update the researcher from
# the XML (or initialised to no researcher)
if self.import_researcher:
self.db.set_researcher(self.owner) self.db.set_researcher(self.owner)
if self.home is not None: if self.home is not None:
person = self.db.get_person_from_handle(self.home) person = self.db.get_person_from_handle(self.home)

View File

@ -1847,6 +1847,7 @@ class GedcomParser(UpdateCallback):
self.number_of_errors = 0 self.number_of_errors = 0
self.maxpeople = stage_one.get_person_count() self.maxpeople = stage_one.get_person_count()
self.dbase = dbase self.dbase = dbase
self.import_researcher = self.dbase.is_empty()
self.emapper = IdFinder(dbase.get_gramps_ids(EVENT_KEY), self.emapper = IdFinder(dbase.get_gramps_ids(EVENT_KEY),
dbase.event_prefix) dbase.event_prefix)
self.famc_map = stage_one.get_famc_map() self.famc_map = stage_one.get_famc_map()
@ -3292,7 +3293,7 @@ class GedcomParser(UpdateCallback):
self.__parse_level(state, self.subm_parse_tbl, self.__undefined) self.__parse_level(state, self.subm_parse_tbl, self.__undefined)
# If this is the submitter that we were told about in the HEADer, then # If this is the submitter that we were told about in the HEADer, then
# we will need to update the researcher # we will need to update the researcher
if line.token_text == self.subm: if line.token_text == self.subm and self.import_researcher:
self.dbase.set_researcher(state.res) self.dbase.set_researcher(state.res)
submitter_name = _("SUBM (Submitter): @%s@") % line.token_text submitter_name = _("SUBM (Submitter): @%s@") % line.token_text