diff --git a/gramps2/ChangeLog b/gramps2/ChangeLog index e17a1377a..2f471c594 100644 --- a/gramps2/ChangeLog +++ b/gramps2/ChangeLog @@ -1,3 +1,7 @@ +2004-02-15 Don Allingham + * src/Relationship.py: more fixes + * src/gramps_main.py: changed db on relationship calculator when db changes. + 2004-02-15 Alex Roitman * src/Relationship.py: More corrections. * src/plugins/rel_ru.py: Corrections. diff --git a/gramps2/src/ChooseParents.py b/gramps2/src/ChooseParents.py index 8f59a9944..00562e336 100644 --- a/gramps2/src/ChooseParents.py +++ b/gramps2/src/ChooseParents.py @@ -489,7 +489,7 @@ class ChooseParents: class ModifyParents: - def __init__(self,db,person,family,family_update,full_update,parent_window=None): + def __init__(self,db,person,family_id,family_update,full_update,parent_window=None): """ Creates a ChoosePerson dialog box. @@ -501,12 +501,12 @@ class ModifyParents: """ self.db = db self.person = person - self.family = family + self.family = self.db.find_family_from_id(family_id) self.family_update = family_update self.full_update = full_update - self.father = self.family.get_father_id() - self.mother = self.family.get_mother_id() + self.father = self.db.find_person_from_id(self.family.get_father_id()) + self.mother = self.db.find_person_from_id(self.family.get_mother_id()) self.glade = gtk.glade.XML(const.gladeFile,"modparents","gramps") self.top = self.glade.get_widget("modparents") @@ -523,7 +523,7 @@ class ModifyParents: self.orig_mrel = _("Birth") self.orig_frel = _("Birth") for (f,mr,fr) in self.person.get_parent_family_id_list(): - if f == self.family: + if f == self.family.get_id(): self.orig_mrel = _(mr) self.orig_frel = _(fr) @@ -588,8 +588,8 @@ class ModifyParents: mod = 0 if mother_rel != self.orig_mrel or father_rel != self.orig_frel: - self.person.remove_parent_family_id(self.family) - self.person.add_parent_family_id(self.family,mother_rel,father_rel) + self.person.remove_parent_family_id(self.family.get_id()) + self.person.add_parent_family_id(self.family.get_id(),mother_rel,father_rel) mod = 1 Utils.modified() @@ -599,7 +599,7 @@ class ModifyParents: plist = self.person.get_parent_family_id_list() if make_pref: if self.family != plist[0]: - self.person.set_main_parent_family_id(self.family) + self.person.set_main_parent_family_id(self.family.get_id()) Utils.modified() mod = 1 else: diff --git a/gramps2/src/FamilyView.py b/gramps2/src/FamilyView.py index f80bc08a3..60b74d7bb 100644 --- a/gramps2/src/FamilyView.py +++ b/gramps2/src/FamilyView.py @@ -473,11 +473,11 @@ class FamilyView: def child_rel(self,obj): person = self.parent.db.get_person(obj.get_data(Utils.OBJECT)) - SelectChild.EditRel(person,self.family,self.load_family) + SelectChild.EditRel(self.parent.db,person,self.family,self.load_family) def child_rel_by_id(self,id): person = self.parent.db.get_person(id) - SelectChild.EditRel(person,self.family,self.load_family) + SelectChild.EditRel(self.parent.db,person,self.family,self.load_family) def spouse_changed(self,obj): model, iter = obj.get_selected() diff --git a/gramps2/src/Relationship.py b/gramps2/src/Relationship.py index eca1ad53e..5a1cb5faf 100644 --- a/gramps2/src/Relationship.py +++ b/gramps2/src/Relationship.py @@ -160,18 +160,22 @@ class RelationshipCalculator: def __init__(self,db): self.db = db - def apply_filter(self,person_id,index,plist,pmap): - if person_id == None: - return - plist.append(person_id) - pmap[person_id] = index + def set_db(self,db): + self.db = db + + def apply_filter(self,person,index,plist,pmap): + if person == None: + return + plist.append(person.get_id()) + pmap[person.get_id()] = index - person = self.db.find_person_from_id(person_id) family_id = person.get_main_parents_family_id() family = self.db.find_family_from_id(family_id) if family != None: - self.apply_filter(family.get_father_id(),index+1,plist,pmap) - self.apply_filter(family.get_mother_id(),index+1,plist,pmap) + father = self.db.find_person_from_id(family.get_father_id()) + mother = self.db.find_person_from_id(family.get_mother_id()) + self.apply_filter(father,index+1,plist,pmap) + self.apply_filter(mother,index+1,plist,pmap) def get_cousin(self,level,removed): if removed > len(_removed_level)-1 or level>len(_level_name)-1: @@ -254,7 +258,7 @@ class RelationshipCalculator: secondList = [] common = [] rank = 9999999 - + if orig_person == None: return ("undefined",[]) @@ -265,11 +269,11 @@ class RelationshipCalculator: return ("spouse",[]) try: - self.apply_filter(orig_person.get_id(),0,firstList,firstMap) - self.apply_filter(other_person.get_id(),0,secondList,secondMap) + self.apply_filter(orig_person,0,firstList,firstMap) + self.apply_filter(other_person,0,secondList,secondMap) except RuntimeError,msg: return (_("Relationship loop detected"),None) - + for person_id in firstList: if person_id in secondList: new_rank = firstMap[person_id] @@ -286,7 +290,7 @@ class RelationshipCalculator: person_id = common[0] secondRel = firstMap[person_id] firstRel = secondMap[person_id] - + if firstRel == -1: return ("",[]) elif firstRel == 0: @@ -337,8 +341,8 @@ class RelationshipCalculator: return ('', []) try: - self.apply_filter(orig_person.get_id(),0,firstList,firstMap) - self.apply_filter(other_person.get_id(),0,secondList,secondMap) + self.apply_filter(orig_person,0,firstList,firstMap) + self.apply_filter(other_person,0,secondList,secondMap) except RuntimeError,msg: return (_("Relationship loop detected"),None) diff --git a/gramps2/src/SelectChild.py b/gramps2/src/SelectChild.py index 8db4b1f3b..b692aa2a0 100644 --- a/gramps2/src/SelectChild.py +++ b/gramps2/src/SelectChild.py @@ -84,8 +84,8 @@ class SelectChild: self.add_child = self.xml.get_widget("childlist") if (self.family): - father = self.family.get_father_id() - mother = self.family.get_mother_id() + father = self.db.find_person_from_id(self.family.get_father_id()) + mother = self.db.find_person_from_id(self.family.get_mother_id()) if father != None: fname = father.get_primary_name().get_name() @@ -145,7 +145,7 @@ class SelectChild: elif family.get_mother_id(): slist[ffamily.get_mother_id()] = 1 for c in family.get_child_id_list(): - slist[c.get_id()] = 1 + slist[c] = 1 person_list = [] for key in self.db.sort_person_keys(): @@ -221,16 +221,16 @@ class SelectChild: else: self.family.set_mother_id(self.person) - self.family.add_child_id(select_child) + self.family.add_child_id(select_child.get_id()) mrel = const.child_relations.find_value(self.mrel.get_text()) - mother = self.family.get_mother_id() + mother = self.db.find_person_from_id(self.family.get_mother_id()) if mother and mother.get_gender() != RelLib.Person.female: if mrel == "Birth": mrel = "Unknown" frel = const.child_relations.find_value(self.frel.get_text()) - father = self.family.get_father_id() + father = self.db.find_person_from_id(self.family.get_father_id()) if father and father.get_gender() !=RelLib. Person.male: if frel == "Birth": frel = "Unknown" @@ -293,7 +293,8 @@ class SelectChild: class EditRel: - def __init__(self,child,family,update): + def __init__(self,db,child,family,update): + self.db = db self.update = update self.child = child self.family = family @@ -311,8 +312,8 @@ class EditRel: Utils.set_titles(self.top,self.xml.get_widget('title'), _('Relationships of %s') % name) - father = self.family.get_father_id() - mother = self.family.get_mother_id() + father = self.db.find_person_from_id(self.family.get_father_id()) + mother = self.db.find_person_from_id(self.family.get_mother_id()) if father: fname = father.get_primary_name().get_name() @@ -354,17 +355,17 @@ class EditRel: def on_ok_clicked(self,obj): mrel = const.child_relations.find_value(self.mentry.get_text()) - mother = self.family.get_mother_id() + mother = self.db.find_person_from_id(self.family.get_mother_id()) if mother and mother.get_gender() != RelLib.Person.female: if mrel == "Birth": mrel = "Unknown" frel = const.child_relations.find_value(self.fentry.get_text()) - father = self.family.get_father_id() + father = self.db.find_person_from_id(self.family.get_father_id()) if father and father.get_gender() !=RelLib. Person.male: if frel == "Birth": frel = "Unknown" - self.child.change_parent_family_id(self.family,mrel,frel) + self.child.change_parent_family_id(self.family.get_id(),mrel,frel) self.update() self.top.destroy() diff --git a/gramps2/src/gramps_main.py b/gramps2/src/gramps_main.py index ff3049ba4..aa3a14383 100755 --- a/gramps2/src/gramps_main.py +++ b/gramps2/src/gramps_main.py @@ -886,6 +886,8 @@ class Gramps: self.db.set_sprefix(GrampsCfg.sprefix) self.db.set_pprefix(GrampsCfg.pprefix) + self.relationship.set_db(self.db) + self.place_view.change_db(self.db) self.people_view.change_db(self.db) self.source_view.change_db(self.db)