# # Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2000 Donald N. Allingham # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # "View/Verify" #------------------------------------------------------------------------ # # standard python modules # #------------------------------------------------------------------------ import os #------------------------------------------------------------------------ # # GNOME/GTK modules # #------------------------------------------------------------------------ from gnome.ui import * import gtk import gtk.glade #------------------------------------------------------------------------ # # GRAMPS modules # #------------------------------------------------------------------------ import RelLib import Utils from intl import gettext as _ db = None glade_file = None verifySettings = None # returns the year of an event or 0 if no event==None or no year specified in the event def get_year( event ): year = 0 if event != None: dateObj = event.getDateObj() if dateObj != None: year = dateObj.getYear() return year def runTool(database,active_person,callback): global glade_file global db global verifySettings db = database base = os.path.dirname(__file__) glade_file = base + os.sep + "verify.glade" verifySettings = gtk.glade.XML(glade_file,"verify_settings") verifySettings.signal_autoconnect({ "destroy_passed_object" : Utils.destroy_passed_object, "on_verify_ok_clicked" : on_apply_clicked }) def on_apply_clicked(obj): global db global verifySettings personList = db.getPersonMap().values() oldage = int(verifySettings.get_widget("oldage").get_text()) yngmar = int(verifySettings.get_widget("yngmar").get_text()) oldmar = int(verifySettings.get_widget("oldmar").get_text()) oldmom = int(verifySettings.get_widget("oldmom").get_text()) yngmom = int(verifySettings.get_widget("yngmom").get_text()) olddad = int(verifySettings.get_widget("olddad").get_text()) yngdad = int(verifySettings.get_widget("yngdad").get_text()) wedder = int(verifySettings.get_widget("wedder").get_text()) lngwdw = int(verifySettings.get_widget("lngwdw").get_text()) oldunm = 99 # maximum age at death for unmarried person error = "" warn = "" for person in personList: idstr = person.getId() + " " +person.getPrimaryName().getName() # individual checks byear = get_year( person.getBirth() ) bapyear = 0 dyear = get_year( person.getDeath() ) buryear = 0 if byear>0 and bapyear>0: if byear > bapyear: error = "%sBaptized before birth %s born %d baptized %d.\n" % (error, idstr, byear, bapyear) if byear < bapyear: warn = "%sBaptized late %s born %d baptized %d.\n" % (warn, idstr, byear, bapyear) if dyear>0 and buryear>0: if dyear > buryear: error = "%sBuried before death %s died %d buried %d.\n" % (error, idstr, dyear, buryear) if dyear < buryear: warn = "%sBuried late %s died %d buried %d.\n" % (warn, idstr, dyear, buryear) if dyear>0 and (byear>dyear): error = "%sDied before birth %s born %d died %d.\n" % (error, idstr, byear, dyear) if dyear>0 and (bapyear>dyear): error = "%sDied before birth %s baptized %d died %d.\n" % (error, idstr, bapyear, dyear) if buryear>0 and (byear>buryear): error = "%sBuried before birth %s born %d died %d.\n" % (error, idstr, byear, buryear) if buryear>0 and (bapyear>buryear): error = "%sBuried before birth %s baptized %d died %d.\n" % (error, idstr, bapyear, buryear) if byear == 0: byear = bapyear # guess baptism = birth if dyear == 0: dyear = buryear # guess burial = death if byear>0 and dyear>0: ageatdeath = dyear - byear else: ageatdeath = 0 if ageatdeath > oldage: warn = "%sOld age %s born %d died %d age %d.\n" % (warn, idstr, byear, dyear, ageatdeath) # gender checks if person.getGender() == RelLib.Person.female: parstr = "mother " oldpar = oldmom yngpar = yngmom waswidstr = " was a widow " if person.getGender() == RelLib.Person.male: parstr = "father " oldpar = olddad yngpar = yngdad waswidstr = " was a widower " if (person.getGender() != RelLib.Person.female) and (person.getGender() != RelLib.Person.male): warn ="%sUnknown gender %s.\n" % (warn, idstr) parstr = "parent " oldpar = olddad yngpar = yngdad waswidstr = " was a widow " if (person.getGender() == RelLib.Person.female) and (person.getGender() == RelLib.Person.male): error ="%sAmbigous gender %s.\n" % (error, idstr) parstr = "parent " oldpar = olddad yngpar = yngdad waswidstr = " was a widow " # multiple parentage check if( len(person.getParentList()) > 1 ): warn = "%sMultiple parentage %s.\n" % (warn, idstr) # marriage checks nkids = 0 nfam = len( person.getFamilyList() ) if nfam > wedder: warn = "%sMarried often %s married %d times.\n" % (warn, idstr, nfam) if ageatdeath>oldunm and nfam == 0: warn = "%sOld and unmarried %s died unmarried aged %d years.\n" % (warn, idstr, ageatdeath) first_cbyear = 99999 last_cbyear=0 prev_cbyear=0 prev_maryear=0 prev_sdyear=0 fnum = 0 for family in person.getFamilyList(): fnum = fnum + 1 mother = family.getMother() father = family.getFather() if mother!=None and father!=None: if mother.getGender() == father.getGender(): warn = "%sHomosexual marriage %s family %s.\n" % (error, idstr, family.getId()) if family.getFather() == person and person.getGender() == RelLib.Person.female: error = "%sFemale husband %s family %s.\n" % (error, idstr, family.getId()) if family.getMother() == person and person.getGender() == RelLib.Person.male: error = "%sMale wife %s family %s.\n" % (error, idstr, family.getId()) if family.getFather() == person: spouse = family.getMother() else: spouse = family.getFather() if spouse != None: if person.getGender() == RelLib.Person.male and \ person.getPrimaryName().getSurname() == spouse.getPrimaryName().getSurname(): warn = "%sHusband and wife with same surname %s family %s %s.\n" % ( warn, idstr,family.getId(), spouse.getPrimaryName().getName()) sdyear = get_year( spouse.getDeath() ) if sdyear == 0: sdyear = 0 # burial year maryear = get_year( family.getMarriage() ) if maryear == 0: # estimate marriage year cnum=0 for child in family.getChildList(): cnum = cnum + 1 if maryear == 0: birthyear = get_year( child.getBirth() ) if birthyear > 0: maryear = birthyear-cnum if maryear > 0: if byear > 0: marage = maryear - byear if marage < 0: error = "%sMarried before birth %s born %d married %d to %s.\n" % (error, idstr, byear, maryear, spouse.getPrimaryName().getName()) else: if marage < yngmar: warn = "%sYoung marriage %s married at age %d to %s.\n" % (warn, idstr, marage, spouse.getPrimaryName().getName()) if marage > oldmar: warn = "%sOld marriage %s married at age %d to %s.\n" % (warn, idstr, marage, spouse.getPrimaryName().getName()) if dyear>0 and maryear > dyear: error = "%sMarried after death %s died %d married %d to %s.\n" % (error, idstr, dyear, maryear, spouse.getPrimaryName().getName()) if prev_cbyear > maryear: warn = "%sMarriage before birth from previous family %s married %d to %s previous birth %d.\n" % (warn, idstr, maryear, spouse.getPrimaryName().getName(), prev_cbyear) prev_maryear = maryear else: maryear = prev_maryear if maryear>0 and prev_sdyear > 0: wdwyear = maryear-prev_sdyear if wdwyear > lngwdw: warn = "%sLong widowhood %s %s %d years before family %s.\n" % (warn, idstr, waswidstr, wdwyear,family.getId() ) if fnum==nfam and dyear>0 and sdyear>0: wdwyear = dyear - sdyear if wdwyear > lngwdw: warn = "%sLong widowhood %s %s %d years.\n" % (warn, idstr, waswidstr, wdwyear) nkids = 0 for child in family.getChildList(): nkids = nkids+1 cbyear = get_year( child.getBirth() ) if cbyear>0 and cbyear < first_cbyear: first_cbyear = cbyear if cbyear>last_cbyear: last_cbyear = cbyear # parentage checks if byear>0 and cbyear>0: bage = cbyear - byear if bage > oldpar: warn = "%sOld %s %s age %d family %s child %s.\n" % (warn, parstr, idstr, bage, family.getId(), child.getPrimaryName().getName()) if bage < 0: error = "%sUnborn %s %s born %d family %s child %s born %d.\n" % (error, parstr, idstr, byear, family.getId(), child.getPrimaryName().getName(), cbyear) else: if bage < yngpar: warn = "%sYoung %s %s age %d family %s child %s.\n" % (warn, parstr, idstr, bage, family.getId(), child.getPrimaryName().getName()) if dyear>0 and cbyear>dyear: if person.getGender() == RelLib.Person.male: if cbyear-1>dyear: error = "%sDead %s %s died %d family %s child %s born %d.\n" % (error, parstr, idstr, dyear, family.getId(), child.getPrimaryName().getName(), cbyear) else: warn = "%sDead %s %s died %d family %s child %s born %d.\n" % (warn, parstr, idstr, dyear, family.getId(), child.getPrimaryName().getName(), cbyear) else: error = "%sDead %s %s died %d family %s child %s born %d.\n" % (error, parstr, idstr, dyear, family.getId(), child.getPrimaryName().getName(), cbyear) text = "" if error != "": text = "ERRORS:\n"+error+"\n" if warn != "": text = "WARNINGS:\n"+warn verifyResult = gtk.glade.XML(glade_file,"verify_result") verifyResult.signal_autoconnect({ "destroy_passed_object" : Utils.destroy_passed_object, }) top = verifyResult.get_widget("verify_result") textwindow = verifyResult.get_widget("textwindow") textwindow.get_buffer().set_text(text) top.show() #------------------------------------------------------------------------- # # # #------------------------------------------------------------------------- from Plugins import register_tool register_tool( runTool, _("Verify the database"), category=_("Utilities"), description=_("List exceptions to assertions or checks about the database") )