* src/plugins/Check.py: Add check for PersonRef referencing non existant person
svn: r7597
This commit is contained in:
parent
3a10a016bc
commit
3d8852ba25
@ -1,6 +1,8 @@
|
|||||||
2006-11-09 Martin Hawlisch <Martin.Hawlisch@gmx.de>
|
2006-11-09 Martin Hawlisch <Martin.Hawlisch@gmx.de>
|
||||||
* src/QuestionDialog.py: Set Window titles to make window manager
|
* src/QuestionDialog.py: Set Window titles to make window manager
|
||||||
and taskbar happy
|
and taskbar happy
|
||||||
|
* src/plugins/Check.py: Add check for PersonRef referencing non
|
||||||
|
existant person
|
||||||
|
|
||||||
2006-11-08 Alex Roitman <shura@gramps-project.org>
|
2006-11-08 Alex Roitman <shura@gramps-project.org>
|
||||||
* src/plugins/SimpleBookTitle.py: Fix the object selection.
|
* src/plugins/SimpleBookTitle.py: Fix the object selection.
|
||||||
|
@ -180,6 +180,7 @@ class Check(Tool.BatchTool):
|
|||||||
total = checker.family_errors()
|
total = checker.family_errors()
|
||||||
|
|
||||||
checker.check_events()
|
checker.check_events()
|
||||||
|
checker.check_person_references()
|
||||||
checker.check_place_references()
|
checker.check_place_references()
|
||||||
checker.check_source_references()
|
checker.check_source_references()
|
||||||
self.db.transaction_commit(trans, _("Check Integrity"))
|
self.db.transaction_commit(trans, _("Check Integrity"))
|
||||||
@ -211,6 +212,7 @@ class CheckIntegrity:
|
|||||||
self.invalid_events = []
|
self.invalid_events = []
|
||||||
self.invalid_birth_events = []
|
self.invalid_birth_events = []
|
||||||
self.invalid_death_events = []
|
self.invalid_death_events = []
|
||||||
|
self.invalid_person_references = []
|
||||||
self.invalid_place_references = []
|
self.invalid_place_references = []
|
||||||
self.invalid_source_references = []
|
self.invalid_source_references = []
|
||||||
self.removed_name_format = []
|
self.removed_name_format = []
|
||||||
@ -658,6 +660,22 @@ class CheckIntegrity:
|
|||||||
self.db.commit_family(family,self.trans)
|
self.db.commit_family(family,self.trans)
|
||||||
self.invalid_events.append(key)
|
self.invalid_events.append(key)
|
||||||
|
|
||||||
|
def check_person_references(self):
|
||||||
|
plist = self.db.get_person_handles()
|
||||||
|
|
||||||
|
self.progress.set_pass(_('Looking for person reference problems'),
|
||||||
|
len(plist))
|
||||||
|
|
||||||
|
for key in plist:
|
||||||
|
person = self.db.get_person_from_handle(key)
|
||||||
|
for pref in person.get_person_ref_list():
|
||||||
|
p = self.db.get_person_from_handle( pref.ref)
|
||||||
|
if not p:
|
||||||
|
# The referenced person does not exist in the database
|
||||||
|
person.get_person_ref_list().remove(pref)
|
||||||
|
self.db.commit_person(person,self.trans)
|
||||||
|
self.invalid_person_references.append(key)
|
||||||
|
|
||||||
def check_place_references(self):
|
def check_place_references(self):
|
||||||
elist = self.db.get_event_handles()
|
elist = self.db.get_event_handles()
|
||||||
|
|
||||||
@ -797,12 +815,13 @@ class CheckIntegrity:
|
|||||||
birth_invalid = len(self.invalid_birth_events)
|
birth_invalid = len(self.invalid_birth_events)
|
||||||
death_invalid = len(self.invalid_death_events)
|
death_invalid = len(self.invalid_death_events)
|
||||||
person = birth_invalid + death_invalid
|
person = birth_invalid + death_invalid
|
||||||
|
person_references = len(self.invalid_person_references)
|
||||||
place_references = len(self.invalid_place_references)
|
place_references = len(self.invalid_place_references)
|
||||||
source_references = len(self.invalid_source_references)
|
source_references = len(self.invalid_source_references)
|
||||||
name_format = len(self.removed_name_format)
|
name_format = len(self.removed_name_format)
|
||||||
|
|
||||||
errors = blink + efam + photos + rel + person \
|
errors = blink + efam + photos + rel + person + event_invalid\
|
||||||
+ event_invalid + place_references + source_references
|
+ person_references + place_references + source_references
|
||||||
|
|
||||||
if errors == 0:
|
if errors == 0:
|
||||||
if cl:
|
if cl:
|
||||||
@ -879,6 +898,10 @@ class CheckIntegrity:
|
|||||||
self.text.write(_("1 corrupted family relationship fixed\n"))
|
self.text.write(_("1 corrupted family relationship fixed\n"))
|
||||||
elif rel > 1:
|
elif rel > 1:
|
||||||
self.text.write(_("%d corrupted family relationship fixed\n") % rel)
|
self.text.write(_("%d corrupted family relationship fixed\n") % rel)
|
||||||
|
if person_references == 1:
|
||||||
|
self.text.write(_("1 person was referenced but not found\n"))
|
||||||
|
elif person_references > 1:
|
||||||
|
self.text.write(_("%d person were referenced, but not found\n") % person_references)
|
||||||
if photos == 1:
|
if photos == 1:
|
||||||
self.text.write(_("1 media object was referenced, but not found\n"))
|
self.text.write(_("1 media object was referenced, but not found\n"))
|
||||||
elif photos > 1:
|
elif photos > 1:
|
||||||
|
Loading…
Reference in New Issue
Block a user