0005785: print statements in Check.py causing a crash in Windows (pythonw.exe) after outputting 4096 characters. Change to logging.warning and logging.info.
svn: r19993
This commit is contained in:
parent
e8a8c866f2
commit
df36baafc8
@ -48,7 +48,6 @@ from collections import defaultdict
|
||||
#
|
||||
#------------------------------------------------------------------------
|
||||
import logging
|
||||
LOG_OBJ = logging.getLogger(".CheckRepair")
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -78,10 +77,6 @@ from glade import Glade
|
||||
# All except 09, 0A, 0D are replaced with space.
|
||||
strip_dict = dict.fromkeys(range(9)+range(11,13)+range(14, 32), u" ")
|
||||
|
||||
# This is assigned so that it can be either LOG_OBJ.debug or print, depending on
|
||||
# which is deemed to better interface for Gramps
|
||||
LOG = print
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Low Level repair
|
||||
@ -101,7 +96,7 @@ def cross_table_duplicates(db):
|
||||
"""
|
||||
progress = ProgressMeter(_('Checking Database'),'')
|
||||
progress.set_pass(_('Looking for cross table duplicates'), 9)
|
||||
LOG('Looking for cross table duplicates')
|
||||
logging.info('Looking for cross table duplicates')
|
||||
total_nr_handles = 0
|
||||
all_handles = set([])
|
||||
for the_map in [db.person_map, db.family_map, db.event_map, db.place_map,
|
||||
@ -113,8 +108,11 @@ def cross_table_duplicates(db):
|
||||
progress.step()
|
||||
progress.close()
|
||||
num_errors = total_nr_handles - len(all_handles)
|
||||
LOG(' OK: No cross table duplicates' if num_errors == 0 else
|
||||
' FAIL: Found %d cross table duplicates' % num_errors)
|
||||
if num_errors == 0:
|
||||
logging.info(' OK: No cross table duplicates')
|
||||
else:
|
||||
logging.warning(' FAIL: Found %d cross table duplicates' %
|
||||
num_errors)
|
||||
return total_nr_handles > len(all_handles)
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
@ -251,7 +249,7 @@ class CheckIntegrity(object):
|
||||
"""
|
||||
self.progress.set_pass(_('Looking for invalid name format references'),
|
||||
self.db.get_number_of_people())
|
||||
LOG('Looking for invalid name format references')
|
||||
logging.info('Looking for invalid name format references')
|
||||
|
||||
deleted_name_formats = [number for (number, name, fmt_str,act)
|
||||
in self.db.name_formats if not act]
|
||||
@ -297,13 +295,13 @@ class CheckIntegrity(object):
|
||||
only_active=False)
|
||||
|
||||
if len(self.removed_name_format) == 0:
|
||||
LOG(' OK: no invalid name formats found found')
|
||||
logging.info(' OK: no invalid name formats found found')
|
||||
|
||||
def cleanup_duplicate_spouses(self):
|
||||
|
||||
self.progress.set_pass(_('Looking for duplicate spouses'),
|
||||
self.db.get_number_of_people())
|
||||
LOG('Looking for duplicate spouses')
|
||||
logging.info('Looking for duplicate spouses')
|
||||
previous_errors = len(self.duplicate_links)
|
||||
|
||||
for handle in self.db.person_map.keys():
|
||||
@ -321,12 +319,12 @@ class CheckIntegrity(object):
|
||||
self.progress.step()
|
||||
|
||||
if previous_errors == len(self.duplicate_links):
|
||||
LOG(' OK: no duplicate spouses found')
|
||||
logging.info(' OK: no duplicate spouses found')
|
||||
|
||||
def fix_encoding(self):
|
||||
self.progress.set_pass(_('Looking for character encoding errors'),
|
||||
self.db.get_number_of_media_objects())
|
||||
LOG('Looking for character encoding errors')
|
||||
logging.info('Looking for character encoding errors')
|
||||
error_count = 0
|
||||
for handle in self.db.media_map.keys():
|
||||
data = self.db.media_map[handle]
|
||||
@ -336,11 +334,13 @@ class CheckIntegrity(object):
|
||||
obj.desc = Utils.fix_encoding( obj.desc, errors='ignore')
|
||||
self.db.commit_media_object(obj, self.trans)
|
||||
if not isinstance(data[2], unicode):
|
||||
LOG(' FAIL: encoding error on media object "%s"'
|
||||
' path "%s"' % (obj.gramps_id, obj.path))
|
||||
logging.warning(' FAIL: encoding error on media object '
|
||||
'"%(gid)s" path "%(path)s"' %
|
||||
{'gid' : obj.gramps_id, 'path' : obj.path})
|
||||
if not isinstance(data[2], unicode):
|
||||
LOG(' FAIL: encoding error on media object "%s"'
|
||||
' description "%s"' % (obj.gramps_id, obj.desc))
|
||||
logging.warning(' FAIL: encoding error on media object '
|
||||
'"%(gid)s" description "%(desc)s"' %
|
||||
{'gid' : obj.gramps_id, 'desc' : obj.desc})
|
||||
error_count += 1
|
||||
# Once we are here, fix the mime string if not str
|
||||
if not isinstance(data[3], str):
|
||||
@ -353,17 +353,18 @@ class CheckIntegrity(object):
|
||||
except:
|
||||
obj.mime = ""
|
||||
self.db.commit_media_object(obj, self.trans)
|
||||
LOG(' FAIL: encoding error on media object "%s"'
|
||||
' mime "%s"' % (obj.desc, obj.mime))
|
||||
logging.warning(' FAIL: encoding error on media object '
|
||||
'"%(desc)s" mime "%(mime)s"' %
|
||||
{'desc' : obj.desc, 'mime' : obj.mime})
|
||||
error_count += 1
|
||||
self.progress.step()
|
||||
if error_count == 0:
|
||||
LOG(' OK: no encoding errors found')
|
||||
logging.info(' OK: no encoding errors found')
|
||||
|
||||
def fix_ctrlchars_in_notes(self):
|
||||
self.progress.set_pass(_('Looking for ctrl characters in notes'),
|
||||
self.db.get_number_of_notes())
|
||||
LOG('Looking for ctrl characters in notes')
|
||||
logging.info('Looking for ctrl characters in notes')
|
||||
error_count = 0
|
||||
for handle in self.db.note_map.keys():
|
||||
note = self.db.get_note_from_handle(handle)
|
||||
@ -371,7 +372,7 @@ class CheckIntegrity(object):
|
||||
old_text = unicode(stext)
|
||||
new_text = old_text.translate(strip_dict)
|
||||
if old_text != new_text:
|
||||
LOG(' FAIL: control characters found in note "%s"' %
|
||||
logging.warning(' FAIL: control characters found in note "%s"' %
|
||||
self.db.note_map[handle][1])
|
||||
error_count += 1
|
||||
# Commit only if ctrl char found.
|
||||
@ -380,7 +381,7 @@ class CheckIntegrity(object):
|
||||
self.db.commit_note(note, self.trans)
|
||||
self.progress.step()
|
||||
if error_count == 0:
|
||||
LOG(' OK: no ctrl characters in notes found')
|
||||
logging.info(' OK: no ctrl characters in notes found')
|
||||
|
||||
def check_for_broken_family_links(self):
|
||||
# Check persons referenced by the family objects
|
||||
@ -389,7 +390,7 @@ class CheckIntegrity(object):
|
||||
self.progress.set_pass(_('Looking for broken family links'),
|
||||
len(fhandle_list) +
|
||||
self.db.get_number_of_people())
|
||||
LOG('Looking for broken family links')
|
||||
logging.info('Looking for broken family links')
|
||||
previous_errors = len(self.broken_parent_links + self.broken_links)
|
||||
|
||||
for family_handle in fhandle_list:
|
||||
@ -406,8 +407,10 @@ class CheckIntegrity(object):
|
||||
family.set_father_handle(None)
|
||||
self.db.commit_family(family, self.trans)
|
||||
self.broken_parent_links.append((father_handle, family_handle))
|
||||
LOG(" FAIL: family '%s' father handle '%s'"
|
||||
" does not exist" % (family.gramps_id, father_handle))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' "
|
||||
"father handle '%(hand)s' does not exist" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'hand' : father_handle})
|
||||
father_handle = None
|
||||
if mother_handle:
|
||||
mother = self.db.get_person_from_handle(mother_handle)
|
||||
@ -419,8 +422,10 @@ class CheckIntegrity(object):
|
||||
family.set_mother_handle(None)
|
||||
self.db.commit_family(family, self.trans)
|
||||
self.broken_parent_links.append((mother_handle, family_handle))
|
||||
LOG(" FAIL: family '%s' mother handle '%s'"
|
||||
" does not exist" % (family.gramps_id, mother_handle))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' "
|
||||
"mother handle '%(hand)s' does not exist" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'hand' : mother_handle})
|
||||
mother_handle = None
|
||||
|
||||
if father_handle and father and \
|
||||
@ -431,9 +436,10 @@ class CheckIntegrity(object):
|
||||
self.broken_parent_links.append((father_handle, family_handle))
|
||||
father.add_family_handle(family_handle)
|
||||
self.db.commit_person(father, self.trans)
|
||||
LOG(" FAIL: family '%s' father '%s'"
|
||||
" does not refer back to the family" %
|
||||
(family.gramps_id, father_handle))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' father "
|
||||
"'%(hand)s' does not refer back to the family" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'hand' : father_handle})
|
||||
|
||||
if mother_handle and mother and \
|
||||
family_handle not in mother.get_family_handle_list():
|
||||
@ -443,9 +449,10 @@ class CheckIntegrity(object):
|
||||
self.broken_parent_links.append((mother_handle, family_handle))
|
||||
mother.add_family_handle(family_handle)
|
||||
self.db.commit_person(mother, self.trans)
|
||||
LOG(" FAIL: family '%s' mother '%s'"
|
||||
" does not refer back to the family" %
|
||||
(family.gramps_id, mother_handle))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' mother "
|
||||
"'%(hand)s' does not refer back to the family" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'hand' : mother_handle})
|
||||
|
||||
for child_ref in family.get_child_ref_list():
|
||||
child_handle = child_ref.ref
|
||||
@ -456,9 +463,11 @@ class CheckIntegrity(object):
|
||||
# such child from the family
|
||||
# This is tested by TestcaseGenerator where the father
|
||||
# is "Broken19"
|
||||
LOG(" FAIL: family '%s' child '%s'"
|
||||
" is one of the parents" %
|
||||
(family.gramps_id, child.gramps_id))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' "
|
||||
"child '%(child_gid)s' is one of the "
|
||||
"parents" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'child_gid' : child.gramps_id})
|
||||
family.remove_child_ref(child_ref)
|
||||
self.db.commit_family(family, self.trans)
|
||||
self.broken_links.append((child_handle, family_handle))
|
||||
@ -470,9 +479,11 @@ class CheckIntegrity(object):
|
||||
# The referenced child has no reference to the family
|
||||
# This is tested by TestcaseGenerator where the father
|
||||
# is "Broken8"
|
||||
LOG(" FAIL: family '%s' child '%s'"
|
||||
" has no reference to the family" %
|
||||
(family.gramps_id, child.gramps_id))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' "
|
||||
"child '%(child_gid)s' has no reference"
|
||||
" to the family" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'child_gid' : child.gramps_id})
|
||||
family.remove_child_ref(child_ref)
|
||||
self.db.commit_family(family, self.trans)
|
||||
self.broken_links.append((child_handle, family_handle))
|
||||
@ -481,9 +492,10 @@ class CheckIntegrity(object):
|
||||
# does not exist in the database
|
||||
# This is tested by TestcaseGenerator where the father
|
||||
# is "Broken20"
|
||||
LOG(" FAIL: family '%s' child '%s'"
|
||||
" does not exist in the database" %
|
||||
(family.gramps_id, child_handle))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' child "
|
||||
"'%(hand)s' does not exist in the database" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'hand' : child_handle})
|
||||
family.remove_child_ref(child_ref)
|
||||
self.db.commit_family(family, self.trans)
|
||||
self.broken_links.append((child_handle, family_handle))
|
||||
@ -529,9 +541,11 @@ class CheckIntegrity(object):
|
||||
# Person is not a child in the referenced parent family
|
||||
# This is tested by TestcaseGenerator where the father
|
||||
# is "Broken9"
|
||||
LOG(" FAIL: family '%s' person '%s'"
|
||||
" is not a child in the referenced parent family" %
|
||||
(family.gramps_id, person.gramps_id))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' person "
|
||||
"'%(pers_gid)s' is not a child in the "
|
||||
"referenced parent family" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'pers_gid' :person.gramps_id})
|
||||
person.remove_parent_family_handle(par_family_handle)
|
||||
self.db.commit_person(person, self.trans)
|
||||
self.broken_links.append((person_handle,family_handle))
|
||||
@ -541,9 +555,11 @@ class CheckIntegrity(object):
|
||||
# The referenced family does not exist in database
|
||||
# This is tested by TestcaseGenerator where the father
|
||||
# is "Broken20"
|
||||
LOG(" FAIL: person '%s' refers to "
|
||||
"family '%s' which is not in the database" %
|
||||
(person.gramps_id, family_handle))
|
||||
logging.warning(" FAIL: person '%(pers_gid)s' refers to "
|
||||
"family '%(hand)s' which is not in the "
|
||||
"database" %
|
||||
{'pers_gid' : person.gramps_id,
|
||||
'hand' : family_handle})
|
||||
person.remove_family_handle(family_handle)
|
||||
self.db.commit_person(person, self.trans)
|
||||
self.broken_links.append((person_handle, family_handle))
|
||||
@ -557,22 +573,24 @@ class CheckIntegrity(object):
|
||||
# "Broken2" and the family misses the link to the father, and
|
||||
# where the mother is "Broken3" and the family misses the link
|
||||
# to the mother
|
||||
LOG(" FAIL: family '%s' person '%s'"
|
||||
" is not member of the referenced family" %
|
||||
(family.gramps_id, person.gramps_id))
|
||||
logging.warning(" FAIL: family '%(fam_gid)s' person "
|
||||
"'%(pers_gid)s' is not member of the referenced"
|
||||
" family" %
|
||||
{'fam_gid' : family.gramps_id,
|
||||
'pers_gid' : person.gramps_id})
|
||||
person.remove_family_handle(family_handle)
|
||||
self.db.commit_person(person, self.trans)
|
||||
self.broken_links.append((person_handle, family_handle))
|
||||
self.progress.step()
|
||||
|
||||
if previous_errors == len(self.broken_parent_links + self.broken_links):
|
||||
LOG(' OK: no broken family links found')
|
||||
logging.info(' OK: no broken family links found')
|
||||
|
||||
def cleanup_missing_photos(self, cl=0):
|
||||
|
||||
self.progress.set_pass(_('Looking for unused objects'),
|
||||
len(self.db.get_media_object_handles()))
|
||||
LOG('Looking for missing photos')
|
||||
logging.info('Looking for missing photos')
|
||||
|
||||
missmedia_action = 0
|
||||
#-------------------------------------------------------------------------
|
||||
@ -617,17 +635,18 @@ class CheckIntegrity(object):
|
||||
|
||||
self.removed_photo.append(ObjectId)
|
||||
self.db.remove_object(ObjectId,self.trans)
|
||||
LOG(' FAIL: media object and all references to it removed')
|
||||
logging.warning(' FAIL: media object and all references to '
|
||||
'it removed')
|
||||
|
||||
def leave_clicked():
|
||||
self.bad_photo.append(ObjectId)
|
||||
LOG(' FAIL: references to missing file kept')
|
||||
logging.warning(' FAIL: references to missing file kept')
|
||||
|
||||
def select_clicked():
|
||||
# File is lost => select a file to replace the lost one
|
||||
def fs_close_window(obj):
|
||||
self.bad_photo.append(ObjectId)
|
||||
LOG(' FAIL: references to missing file kept')
|
||||
logging.warning(' FAIL: references to missing file kept')
|
||||
|
||||
def fs_ok_clicked(obj):
|
||||
name = Utils.get_unicode_path_from_file_chooser(fs_top.get_filename())
|
||||
@ -637,10 +656,11 @@ class CheckIntegrity(object):
|
||||
self.db.commit_media_object(obj, self.trans)
|
||||
self.replaced_photo.append(ObjectId)
|
||||
self.last_img_dir = os.path.dirname(name)
|
||||
LOG(' FAIL: media object reselected to "%s"' % name)
|
||||
logging.warning(' FAIL: media object reselected to '
|
||||
'"%s"' % name)
|
||||
else:
|
||||
self.bad_photo.append(ObjectId)
|
||||
LOG(' FAIL: references to missing file kept')
|
||||
logging.warning(' FAIL: references to missing file kept')
|
||||
|
||||
fs_top = gtk.FileChooserDialog("%s - Gramps" % _("Select file"),
|
||||
buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
||||
@ -664,12 +684,16 @@ class CheckIntegrity(object):
|
||||
if cl:
|
||||
# Convert to file system encoding before prining
|
||||
fn = os.path.basename(photo_name).encode(sys.getfilesystemencoding())
|
||||
print ("Warning: media file %s was not found." % fn)
|
||||
logging.warning(" FAIL: media file %s was not found." %
|
||||
fn)
|
||||
self.bad_photo.append(ObjectId)
|
||||
else:
|
||||
if missmedia_action == 0:
|
||||
LOG(' FAIL: media object "%s" reference to missing '
|
||||
'file "%s" found' % (photo_desc, photo_name))
|
||||
logging.warning(' FAIL: media object "%(desc)s" '
|
||||
'reference to missing file "%(name)s" '
|
||||
'found' %
|
||||
{'desc' : photo_desc,
|
||||
'name' : photo_name})
|
||||
mmd = MissingMediaDialog(_("Media object could not be found"),
|
||||
_("The file:\n %(file_name)s \nis referenced in the database, but no longer exists. "
|
||||
"The file may have been deleted or moved to a different location. "
|
||||
@ -679,20 +703,29 @@ class CheckIntegrity(object):
|
||||
remove_clicked, leave_clicked, select_clicked)
|
||||
missmedia_action = mmd.default_action
|
||||
elif missmedia_action == 1:
|
||||
LOG(' FAIL: media object "%s" reference to missing '
|
||||
'file "%s" found' % (photo_desc, photo_name))
|
||||
logging.warning(' FAIL: media object "%(desc)s" '
|
||||
'reference to missing file "%(name)s" '
|
||||
'found' %
|
||||
{'desc' : photo_desc,
|
||||
'name' : photo_name})
|
||||
remove_clicked()
|
||||
elif missmedia_action == 2:
|
||||
LOG(' FAIL: media object "%s" reference to missing '
|
||||
'file "%s" found' % (photo_desc, photo_name))
|
||||
logging.warning(' FAIL: media object "%(desc)s" '
|
||||
'reference to missing file "%(name)s" '
|
||||
'found' %
|
||||
{'desc' : photo_desc,
|
||||
'name' : photo_name})
|
||||
leave_clicked()
|
||||
elif missmedia_action == 3:
|
||||
LOG(' FAIL: media object "%s" reference to missing '
|
||||
'file "%s" found' % (photo_desc, photo_name))
|
||||
logging.warning(' FAIL: media object "%(desc)s" '
|
||||
'reference to missing file "%(name)s" '
|
||||
'found' %
|
||||
{'desc' : photo_desc,
|
||||
'name' : photo_name})
|
||||
select_clicked()
|
||||
self.progress.step()
|
||||
if len(self.bad_photo + self.removed_photo) == 0:
|
||||
LOG(' OK: no missing photos found')
|
||||
logging.info(' OK: no missing photos found')
|
||||
|
||||
def cleanup_empty_objects(self):
|
||||
#the position of the change column in the primary objects
|
||||
@ -817,22 +850,23 @@ class CheckIntegrity(object):
|
||||
with cursor_func() as cursor:
|
||||
total = total_func()
|
||||
self.progress.set_pass(text, total)
|
||||
LOG(text)
|
||||
logging.info(text)
|
||||
|
||||
for handle, data in cursor:
|
||||
self.progress.step()
|
||||
if check_func(data):
|
||||
# we cannot remove here as that would destroy cursor
|
||||
# so save the handles for later removal
|
||||
LOG(' FAIL: empty %s record with handle "%s" was found'
|
||||
% (the_type, handle))
|
||||
logging.warning(' FAIL: empty %(type)s record with '
|
||||
'handle "%(hand)s" was found' %
|
||||
{'type' : the_type, 'hand' : handle})
|
||||
self.empty_objects[the_type].append(handle)
|
||||
|
||||
#now remove
|
||||
for handle in self.empty_objects[the_type]:
|
||||
remove_func(handle, self.trans)
|
||||
if len(self.empty_objects[the_type]) == 0:
|
||||
LOG(' OK: no empty %s found' % the_type)
|
||||
logging.info(' OK: no empty %s found' % the_type)
|
||||
|
||||
def _check_empty(self, data, empty_data, changepos):
|
||||
"""compare the data with the data of an empty object
|
||||
@ -850,7 +884,7 @@ class CheckIntegrity(object):
|
||||
|
||||
self.progress.set_pass(_('Looking for empty families'),
|
||||
len(fhandle_list))
|
||||
LOG('Looking for empty families')
|
||||
logging.info('Looking for empty families')
|
||||
previous_errors = len(self.empty_family)
|
||||
for family_handle in fhandle_list:
|
||||
self.progress.step()
|
||||
@ -866,7 +900,7 @@ class CheckIntegrity(object):
|
||||
self.delete_empty_family(family_handle)
|
||||
|
||||
if previous_errors == len(self.empty_family):
|
||||
LOG(' OK: no empty families found')
|
||||
logging.info(' OK: no empty families found')
|
||||
|
||||
def delete_empty_family(self, family_handle):
|
||||
for key in self.db.get_person_handles(sort_handles=False):
|
||||
@ -885,7 +919,7 @@ class CheckIntegrity(object):
|
||||
fhandle_list = self.db.get_family_handles()
|
||||
self.progress.set_pass(_('Looking for broken parent relationships'),
|
||||
len(fhandle_list))
|
||||
LOG('Looking for broken parent relationships')
|
||||
logging.info('Looking for broken parent relationships')
|
||||
previous_errors = len(self.fam_rel)
|
||||
|
||||
for family_handle in fhandle_list:
|
||||
@ -909,7 +943,7 @@ class CheckIntegrity(object):
|
||||
if (fgender == gen.lib.Person.FEMALE
|
||||
or mgender == gen.lib.Person.MALE) and fgender != mgender:
|
||||
# swap. note: (at most) one handle may be None
|
||||
LOG(' FAIL: the family "%s" has a father=female or '
|
||||
logging.warning(' FAIL: the family "%s" has a father=female or '
|
||||
' mother=male in a different sex family' % family.gramps_id)
|
||||
family.set_father_handle(mother_handle)
|
||||
family.set_mother_handle(father_handle)
|
||||
@ -917,13 +951,13 @@ class CheckIntegrity(object):
|
||||
self.fam_rel.append(family_handle)
|
||||
|
||||
if previous_errors == len(self.fam_rel):
|
||||
LOG(' OK: no broken parent relationships found')
|
||||
logging.info(' OK: no broken parent relationships found')
|
||||
|
||||
def check_events(self):
|
||||
self.progress.set_pass(_('Looking for event problems'),
|
||||
self.db.get_number_of_people()
|
||||
+self.db.get_number_of_families())
|
||||
LOG('Looking for event problems')
|
||||
logging.info('Looking for event problems')
|
||||
|
||||
for key in self.db.get_person_handles(sort_handles=False):
|
||||
self.progress.step()
|
||||
@ -945,17 +979,21 @@ class CheckIntegrity(object):
|
||||
Utils.make_unknown(birth_handle, self.explanation.handle,
|
||||
self.class_event, self.commit_event, self.trans,
|
||||
type=gen.lib.EventType.BIRTH)
|
||||
LOG(' FAIL: the person "%s" refers to a birth event'
|
||||
' "%s" which does not exist in the database' %
|
||||
(person.gramps_id, birth_handle))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers to '
|
||||
'a birth event "%(hand)s" which does not '
|
||||
'exist in the database' %
|
||||
{'gid' : person.gramps_id,
|
||||
'hand' : birth_handle})
|
||||
self.invalid_events.add(key)
|
||||
else:
|
||||
if int(birth.get_type()) != gen.lib.EventType.BIRTH:
|
||||
# Birth event was not of the type "Birth"
|
||||
# This is tested by TestcaseGenerator person "Broken14"
|
||||
LOG(' FAIL: the person "%s" refers to a birth event'
|
||||
' which is of type "%s" instead of Birth' %
|
||||
(person.gramps_id, int(birth.get_type())))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers '
|
||||
'to a birth event which is of type '
|
||||
'"%(type)s" instead of Birth' %
|
||||
{'gid' : person.gramps_id,
|
||||
'type' : int(birth.get_type())})
|
||||
birth.set_type(gen.lib.EventType(gen.lib.EventType.BIRTH))
|
||||
self.db.commit_event(birth, self.trans)
|
||||
self.invalid_birth_events.add(key)
|
||||
@ -976,9 +1014,11 @@ class CheckIntegrity(object):
|
||||
# The death event referenced by the death handle
|
||||
# does not exist in the database
|
||||
# This is tested by TestcaseGenerator person "Broken12"
|
||||
LOG(' FAIL: the person "%s" refers to a death event'
|
||||
' "%s" which does not exist in the database' %
|
||||
(person.gramps_id, death_handle))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers to '
|
||||
'a death event "%(hand)s" which does not '
|
||||
'exist in the database' %
|
||||
{'gid' : person.gramps_id,
|
||||
'hand' : death_handle})
|
||||
Utils.make_unknown(death_handle, self.explanation.handle,
|
||||
self.class_event, self.commit_event, self.trans,
|
||||
type=gen.lib.EventType.DEATH)
|
||||
@ -987,9 +1027,11 @@ class CheckIntegrity(object):
|
||||
if int(death.get_type()) != gen.lib.EventType.DEATH:
|
||||
# Death event was not of the type "Death"
|
||||
# This is tested by TestcaseGenerator person "Broken15"
|
||||
LOG(' FAIL: the person "%s" refers to a death event'
|
||||
' which is of type "%s" instead of Death' %
|
||||
(person.gramps_id, int(death.get_type())))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers '
|
||||
'to a death event which is of type '
|
||||
'"%(type)s" instead of Death' %
|
||||
{'gid' : person.gramps_id,
|
||||
'type' : int(death.get_type())})
|
||||
death.set_type(gen.lib.EventType(gen.lib.EventType.DEATH))
|
||||
self.db.commit_event(death, self.trans)
|
||||
self.invalid_death_events.add(key)
|
||||
@ -1014,9 +1056,11 @@ class CheckIntegrity(object):
|
||||
# This is tested by TestcaseGenerator person "Broken11"
|
||||
# This is tested by TestcaseGenerator person "Broken12"
|
||||
# This is tested by TestcaseGenerator person "Broken13"
|
||||
LOG(' FAIL: the person "%s" refers to an event'
|
||||
' "%s" which does not exist in the database' %
|
||||
(person.gramps_id, event_handle))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers '
|
||||
'to an event "%(hand)s" which does not '
|
||||
'exist in the database' %
|
||||
{ 'gid' : person.gramps_id,
|
||||
'hand' : event_handle})
|
||||
Utils.make_unknown(event_handle,
|
||||
self.explanation.handle, self.class_event,
|
||||
self.commit_event, self.trans)
|
||||
@ -1026,7 +1070,7 @@ class CheckIntegrity(object):
|
||||
self.db.commit_person(person, self.trans)
|
||||
elif not isinstance(person.get_event_ref_list(), list):
|
||||
# event_list is None or other garbage
|
||||
LOG(' FAIL: the person "%s" has an event ref list'
|
||||
logging.warning(' FAIL: the person "%s" has an event ref list'
|
||||
' which is invalid' % (person.gramps_id))
|
||||
person.set_event_ref_list([])
|
||||
self.db.commit_person(person, self.trans)
|
||||
@ -1048,9 +1092,11 @@ class CheckIntegrity(object):
|
||||
if not event:
|
||||
# The event referenced by the family
|
||||
# does not exist in the database
|
||||
LOG(' FAIL: the family "%s" refers to an event'
|
||||
' "%s" which does not exist in the database' %
|
||||
(family.gramps_id, event_handle))
|
||||
logging.warning(' FAIL: the family "%(gid)s" refers '
|
||||
'to an event "%(hand)s" which does not '
|
||||
'exist in the database' %
|
||||
{'gid' : family.gramps_id,
|
||||
'hand' : event_handle})
|
||||
Utils.make_unknown(event_handle, self.explanation,
|
||||
self.class_event, self.commit_event, self.trans)
|
||||
self.invalid_events.add(key)
|
||||
@ -1059,7 +1105,7 @@ class CheckIntegrity(object):
|
||||
self.db.commit_family(family, self.trans)
|
||||
elif not isinstance(family.get_event_ref_list(), list):
|
||||
# event_list is None or other garbage
|
||||
LOG(' FAIL: the family "%s" has an event ref list'
|
||||
logging.warning(' FAIL: the family "%s" has an event ref list'
|
||||
' which is invalid' % (family.gramps_id))
|
||||
family.set_event_ref_list([])
|
||||
self.db.commit_family(family, self.trans)
|
||||
@ -1067,14 +1113,14 @@ class CheckIntegrity(object):
|
||||
|
||||
if len (self.invalid_birth_events) + len(self.invalid_death_events) +\
|
||||
len(self.invalid_events) == 0:
|
||||
LOG(' OK: no event problems found')
|
||||
logging.info(' OK: no event problems found')
|
||||
|
||||
def check_person_references(self):
|
||||
plist = self.db.get_person_handles()
|
||||
|
||||
self.progress.set_pass(_('Looking for person reference problems'),
|
||||
len(plist))
|
||||
LOG('Looking for person reference problems')
|
||||
logging.info('Looking for person reference problems')
|
||||
|
||||
for key in plist:
|
||||
self.progress.step()
|
||||
@ -1097,14 +1143,14 @@ class CheckIntegrity(object):
|
||||
self.db.commit_person(person, self.trans)
|
||||
|
||||
if len (self.invalid_person_references) == 0:
|
||||
LOG(' OK: no event problems found')
|
||||
logging.info(' OK: no event problems found')
|
||||
|
||||
def check_family_references(self):
|
||||
plist = self.db.get_person_handles()
|
||||
|
||||
self.progress.set_pass(_('Looking for family reference problems'),
|
||||
len(plist))
|
||||
LOG('Looking for family reference problems')
|
||||
logging.info('Looking for family reference problems')
|
||||
|
||||
for key in plist:
|
||||
self.progress.step()
|
||||
@ -1121,14 +1167,14 @@ class CheckIntegrity(object):
|
||||
self.invalid_family_references.add(key)
|
||||
|
||||
if len (self.invalid_family_references) == 0:
|
||||
LOG(' OK: no event problems found')
|
||||
logging.info(' OK: no event problems found')
|
||||
|
||||
def check_repo_references(self):
|
||||
slist = self.db.get_source_handles()
|
||||
|
||||
self.progress.set_pass(_('Looking for repository reference problems'),
|
||||
len(slist))
|
||||
LOG('Looking for repository reference problems')
|
||||
logging.info('Looking for repository reference problems')
|
||||
|
||||
for key in slist:
|
||||
self.progress.step()
|
||||
@ -1151,7 +1197,7 @@ class CheckIntegrity(object):
|
||||
self.db.commit_source(source, self.trans)
|
||||
|
||||
if len (self.invalid_repo_references) == 0:
|
||||
LOG(' OK: no repository reference problems found')
|
||||
logging.info(' OK: no repository reference problems found')
|
||||
|
||||
def check_place_references(self):
|
||||
plist = self.db.get_person_handles()
|
||||
@ -1159,7 +1205,7 @@ class CheckIntegrity(object):
|
||||
elist = self.db.get_event_handles()
|
||||
self.progress.set_pass(_('Looking for place reference problems'),
|
||||
len(elist)+len(plist)+len(flist))
|
||||
LOG('Looking for place reference problems')
|
||||
logging.info('Looking for place reference problems')
|
||||
|
||||
# check persons -> the LdsOrd references a place
|
||||
for key in plist:
|
||||
@ -1176,9 +1222,11 @@ class CheckIntegrity(object):
|
||||
Utils.make_unknown(place_handle,
|
||||
self.explanation.handle, self.class_place,
|
||||
self.commit_place, self.trans)
|
||||
LOG(' FAIL: the person "%s" refers to an LdsOrd'
|
||||
' place "%s" which does not exist in the database' %
|
||||
(person.gramps_id, place_handle))
|
||||
logging.warning(' FAIL: the person "%(gid)s" refers '
|
||||
'to an LdsOrd place "%(hand)s" which '
|
||||
'does not exist in the database' %
|
||||
{'gid' : person.gramps_id,
|
||||
'hand' : place_handle})
|
||||
self.invalid_place_references.add(key)
|
||||
# check families -> the LdsOrd references a place
|
||||
for key in flist:
|
||||
@ -1193,9 +1241,11 @@ class CheckIntegrity(object):
|
||||
Utils.make_unknown(place_handle,
|
||||
self.explanation.handle, self.class_place,
|
||||
self.commit_place, self.trans)
|
||||
LOG(' FAIL: the family "%s" refers to an LdsOrd'
|
||||
' place "%s" which does not exist in the database' %
|
||||
(family.gramps_id, place_handle))
|
||||
logging.warning(' FAIL: the family "%(gid)s" refers '
|
||||
'to an LdsOrd place "%(hand)s" which '
|
||||
'does not exist in the database' %
|
||||
{'gid' : family.gramps_id,
|
||||
'hand' : place_handle})
|
||||
self.invalid_place_references.add(key)
|
||||
# check events
|
||||
for key in elist:
|
||||
@ -1209,13 +1259,15 @@ class CheckIntegrity(object):
|
||||
Utils.make_unknown(place_handle,
|
||||
self.explanation.handle, self.class_place,
|
||||
self.commit_place, self.trans)
|
||||
LOG(' FAIL: the event "%s" refers to an LdsOrd place'
|
||||
' "%s" which does not exist in the database' %
|
||||
(event.gramps_id, place_handle))
|
||||
logging.warning(' FAIL: the event "%(gid)s" refers '
|
||||
'to an LdsOrd place "%(hand)s" which '
|
||||
'does not exist in the database' %
|
||||
{'gid' : event.gramps_id,
|
||||
'hand' : place_handle})
|
||||
self.invalid_place_references.add(key)
|
||||
|
||||
if len (self.invalid_place_references) == 0:
|
||||
LOG(' OK: no place reference problems found')
|
||||
logging.info(' OK: no place reference problems found')
|
||||
|
||||
def check_citation_references(self):
|
||||
known_handles = self.db.get_citation_handles()
|
||||
@ -1233,7 +1285,7 @@ class CheckIntegrity(object):
|
||||
|
||||
self.progress.set_pass(_('Looking for citation reference problems'),
|
||||
total)
|
||||
LOG('Looking for citation reference problems')
|
||||
logging.info('Looking for citation reference problems')
|
||||
|
||||
for handle in self.db.person_map.keys():
|
||||
self.progress.step()
|
||||
@ -1356,13 +1408,13 @@ class CheckIntegrity(object):
|
||||
self.invalid_source_references.add(created[0].handle)
|
||||
|
||||
if len(self.invalid_citation_references) == 0:
|
||||
LOG(' OK: no citation reference problems found')
|
||||
logging.info(' OK: no citation reference problems found')
|
||||
|
||||
def check_source_references(self):
|
||||
clist = self.db.get_citation_handles()
|
||||
self.progress.set_pass(_('Looking for source reference problems'),
|
||||
len(clist))
|
||||
LOG('Looking for source reference problems')
|
||||
logging.info('Looking for source reference problems')
|
||||
|
||||
for key in clist:
|
||||
self.progress.step()
|
||||
@ -1378,12 +1430,14 @@ class CheckIntegrity(object):
|
||||
# The referenced source does not exist in the database
|
||||
Utils.make_unknown(source_handle, self.explanation.handle,
|
||||
self.class_source, self.commit_source, self.trans)
|
||||
LOG(' FAIL: the citation "%s" refers to source '
|
||||
' "%s" which does not exist in the database' %
|
||||
(citation.gramps_id, source_handle))
|
||||
logging.warning(' FAIL: the citation "%(gid)s" refers '
|
||||
'to source "%(hand)s" which does not exist '
|
||||
'in the database' %
|
||||
{'gid' : citation.gramps_id,
|
||||
'hand' : source_handle})
|
||||
self.invalid_source_references.add(key)
|
||||
if len(self.invalid_source_references) == 0:
|
||||
LOG(' OK: no source reference problems found')
|
||||
logging.info(' OK: no source reference problems found')
|
||||
|
||||
def check_media_references(self):
|
||||
known_handles = self.db.get_media_object_handles(False)
|
||||
@ -1399,7 +1453,7 @@ class CheckIntegrity(object):
|
||||
|
||||
self.progress.set_pass(_('Looking for media object reference problems'),
|
||||
total)
|
||||
LOG('Looking for media object reference problems')
|
||||
logging.info('Looking for media object reference problems')
|
||||
|
||||
for handle in self.db.person_map.keys():
|
||||
self.progress.step()
|
||||
@ -1502,7 +1556,7 @@ class CheckIntegrity(object):
|
||||
self.class_object, self.commit_object, self.trans)
|
||||
|
||||
if len (self.invalid_media_references) == 0:
|
||||
LOG(' OK: no media reference problems found')
|
||||
logging.info(' OK: no media reference problems found')
|
||||
|
||||
def check_note_references(self):
|
||||
# Here I assume check note_references runs after all the next checks.
|
||||
@ -1535,7 +1589,7 @@ class CheckIntegrity(object):
|
||||
|
||||
self.progress.set_pass(_('Looking for note reference problems'),
|
||||
total)
|
||||
LOG('Looking for note reference problems')
|
||||
logging.info('Looking for note reference problems')
|
||||
|
||||
for handle in self.db.person_map.keys():
|
||||
self.progress.step()
|
||||
@ -1670,7 +1724,7 @@ class CheckIntegrity(object):
|
||||
self.class_note, self.commit_note, self.trans)
|
||||
|
||||
if len (self.invalid_note_references) == 0:
|
||||
LOG(' OK: no note reference problems found')
|
||||
logging.info(' OK: no note reference problems found')
|
||||
else:
|
||||
if not missing_references:
|
||||
self.db.add_note(self.explanation, self.trans, set_gid=True)
|
||||
@ -1687,7 +1741,7 @@ class CheckIntegrity(object):
|
||||
|
||||
self.progress.set_pass(_('Looking for tag reference problems'),
|
||||
total)
|
||||
LOG('Looking for tag reference problems')
|
||||
logging.info('Looking for tag reference problems')
|
||||
|
||||
for handle in self.db.person_map.keys():
|
||||
self.progress.step()
|
||||
@ -1758,7 +1812,7 @@ class CheckIntegrity(object):
|
||||
self.commit_tag, self.trans)
|
||||
|
||||
if len(self.invalid_tag_references) == 0:
|
||||
LOG(' OK: no tag reference problems found')
|
||||
logging.info(' OK: no tag reference problems found')
|
||||
|
||||
def class_person(self, handle):
|
||||
person = gen.lib.Person()
|
||||
|
Loading…
Reference in New Issue
Block a user