8555: Database repair tool always modify all source objects

This commit is contained in:
romjerome 2016-11-26 12:49:09 +01:00
parent 10781bde6b
commit 46d8839880

View File

@ -1950,6 +1950,7 @@ class CheckIntegrity(object):
source = Source() source = Source()
source.unserialize(info) source.unserialize(info)
new_media_ref_list = [] new_media_ref_list = []
citation_changed = False
for media_ref in source.get_media_list(): for media_ref in source.get_media_list():
citation_list = media_ref.get_citation_list() citation_list = media_ref.get_citation_list()
new_citation_list = [] new_citation_list = []
@ -1972,6 +1973,7 @@ class CheckIntegrity(object):
citation_handle = create_id() citation_handle = create_id()
new_citation.set_handle(citation_handle) new_citation.set_handle(citation_handle)
self.replaced_sourceref.append(handle) self.replaced_sourceref.append(handle)
citation_changed = True
logging.warning(' FAIL: the source "%s" has a media ' logging.warning(' FAIL: the source "%s" has a media '
'reference with a source citation ' 'reference with a source citation '
'which is invalid' % (source.gramps_id)) 'which is invalid' % (source.gramps_id))
@ -1982,8 +1984,9 @@ class CheckIntegrity(object):
media_ref.set_citation_list(new_citation_list) media_ref.set_citation_list(new_citation_list)
new_media_ref_list.append(media_ref) new_media_ref_list.append(media_ref)
source.set_media_list(new_media_ref_list) if citation_changed:
self.db.commit_source(source, self.trans) source.set_media_list(new_media_ref_list)
self.db.commit_source(source, self.trans)
if len(self.replaced_sourceref) > 0: if len(self.replaced_sourceref) > 0:
logging.info(' OK: no broken source citations on mediarefs found') logging.info(' OK: no broken source citations on mediarefs found')