* src/ChooseParents.py: handle the addition of a person correctly.
Warn if the person just added is suppressed by the filter. * src/MergePeople.py: use __debug__ for print statements * src/MergePeople.py: fixed name merging, incorporate Martin's patches. svn: r4653
This commit is contained in:
parent
a169d828bc
commit
2281e7246f
@ -1,3 +1,12 @@
|
|||||||
|
2005-05-21 Don Allingham <don@gramps-project.org>
|
||||||
|
* src/ChooseParents.py: handle the addition of a person correctly.
|
||||||
|
Warn if the person just added is suppressed by the filter.
|
||||||
|
* src/MergePeople.py: use __debug__ for print statements
|
||||||
|
|
||||||
|
2005-05-20 Don Allingham <don@gramps-project.org>
|
||||||
|
* src/MergePeople.py: fixed name merging, incorporate Martin's
|
||||||
|
patches.
|
||||||
|
|
||||||
2005-05-20 Eero Tamminen <eerot@sf>
|
2005-05-20 Eero Tamminen <eerot@sf>
|
||||||
* src/po/fi.po: Merge PO file and (finally) translate the welcome
|
* src/po/fi.po: Merge PO file and (finally) translate the welcome
|
||||||
message. Otherwise translation is not yet updated
|
message. Otherwise translation is not yet updated
|
||||||
|
@ -57,7 +57,7 @@ import Date
|
|||||||
import NameDisplay
|
import NameDisplay
|
||||||
import DateHandler
|
import DateHandler
|
||||||
import GenericFilter
|
import GenericFilter
|
||||||
from QuestionDialog import ErrorDialog
|
from QuestionDialog import ErrorDialog, WarningDialog
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -284,12 +284,16 @@ class ChooseParents:
|
|||||||
gnome.help_display('gramps-manual','gramps-edit-quick')
|
gnome.help_display('gramps-manual','gramps-edit-quick')
|
||||||
|
|
||||||
def redraw(self,handle_list):
|
def redraw(self,handle_list):
|
||||||
self.father_model.rebuild_data()
|
self.redrawf()
|
||||||
self.mother_model.rebuild_data()
|
self.redrawm()
|
||||||
|
# self.father_model.rebuild_data()
|
||||||
|
# self.mother_model.rebuild_data()
|
||||||
|
|
||||||
def redraw2(self):
|
def redraw2(self):
|
||||||
self.father_model.rebuild_data()
|
self.redrawf()
|
||||||
self.mother_model.rebuild_data()
|
self.redrawm()
|
||||||
|
# self.father_model.rebuild_data()
|
||||||
|
# self.mother_model.rebuild_data()
|
||||||
|
|
||||||
def redrawf(self):
|
def redrawf(self):
|
||||||
"""Redraws the potential father list"""
|
"""Redraws the potential father list"""
|
||||||
@ -518,17 +522,31 @@ class ChooseParents:
|
|||||||
if self.type == RelLib.Family.CIVIL_UNION:
|
if self.type == RelLib.Family.CIVIL_UNION:
|
||||||
self.parent_relation_changed(self.prel)
|
self.parent_relation_changed(self.prel)
|
||||||
elif person.get_gender() == RelLib.Person.MALE:
|
elif person.get_gender() == RelLib.Person.MALE:
|
||||||
path = self.father_model.on_get_path(handle)
|
try:
|
||||||
top_path = self.father_model.on_get_path(name)
|
path = self.father_model.on_get_path(handle)
|
||||||
self.father_list.expand_row(top_path,0)
|
top_path = self.father_model.on_get_path(name)
|
||||||
self.father_selection.select_path(path)
|
self.father_list.expand_row(top_path,0)
|
||||||
self.father_list.scroll_to_cell(path,None,1,0.5,0)
|
self.father_selection.select_path(path)
|
||||||
|
self.father_list.scroll_to_cell(path,None,1,0.5,0)
|
||||||
|
except KeyError:
|
||||||
|
WarningDialog(_("Added person is not visible"),
|
||||||
|
_("The person you added is currently "
|
||||||
|
"not visible due to the chosen filter. "
|
||||||
|
"This may occur if you did not specify "
|
||||||
|
"a birth date."))
|
||||||
else:
|
else:
|
||||||
path = self.mother_model.on_get_path(handle)
|
try:
|
||||||
top_path = self.mother_model.on_get_path(name)
|
path = self.mother_model.on_get_path(handle)
|
||||||
self.mother_list.expand_row(top_path,0)
|
top_path = self.mother_model.on_get_path(name)
|
||||||
self.mother_selection.select_path(path)
|
self.mother_list.expand_row(top_path,0)
|
||||||
self.mother_list.scroll_to_cell(path,None,1,0.5,0)
|
self.mother_selection.select_path(path)
|
||||||
|
self.mother_list.scroll_to_cell(path,None,1,0.5,0)
|
||||||
|
except:
|
||||||
|
WarningDialog(_("Added person is not visible"),
|
||||||
|
_("The person you added is currently "
|
||||||
|
"not visible due to the chosen filter. "
|
||||||
|
"This may occur if you did not specify "
|
||||||
|
"a birth date."))
|
||||||
|
|
||||||
def add_parent_clicked(self,obj):
|
def add_parent_clicked(self,obj):
|
||||||
"""Called with the Add New Person button is pressed. Calls the QuickAdd
|
"""Called with the Add New Person button is pressed. Calls the QuickAdd
|
||||||
|
@ -281,6 +281,16 @@ class MergePeople:
|
|||||||
else:
|
else:
|
||||||
one.add_source_reference(xsrc)
|
one.add_source_reference(xsrc)
|
||||||
|
|
||||||
|
def debug_person(self,person, msg=""):
|
||||||
|
if __debug__:
|
||||||
|
print "## %s person handle %s" % (msg,person.get_handle())
|
||||||
|
for h in person.get_family_handle_list():
|
||||||
|
fam = self.db.get_family_from_handle(h)
|
||||||
|
print " - family %s has father: %s, mother: %s" % \
|
||||||
|
(h,fam.get_father_handle(),fam.get_mother_handle())
|
||||||
|
for h,m1,m2 in person.get_parent_family_handle_list():
|
||||||
|
print " - parent family %s" % h
|
||||||
|
|
||||||
def merge_person_information(self,new,trans):
|
def merge_person_information(self,new,trans):
|
||||||
self.old_handle = self.p2.get_handle()
|
self.old_handle = self.p2.get_handle()
|
||||||
self.new_handle = self.p1.get_handle()
|
self.new_handle = self.p1.get_handle()
|
||||||
@ -296,11 +306,6 @@ class MergePeople:
|
|||||||
new.set_attribute_list(self.p1.get_attribute_list() +
|
new.set_attribute_list(self.p1.get_attribute_list() +
|
||||||
self.p2.get_attribute_list())
|
self.p2.get_attribute_list())
|
||||||
|
|
||||||
# copy names
|
|
||||||
|
|
||||||
new.set_alternate_names(self.p1.get_alternate_names() +
|
|
||||||
self.p2.get_alternate_names())
|
|
||||||
|
|
||||||
# copy addresses
|
# copy addresses
|
||||||
new.set_address_list(self.p1.get_address_list() + self.p2.get_address_list())
|
new.set_address_list(self.p1.get_address_list() + self.p2.get_address_list())
|
||||||
|
|
||||||
@ -328,12 +333,15 @@ class MergePeople:
|
|||||||
|
|
||||||
def merge(self):
|
def merge(self):
|
||||||
|
|
||||||
|
self.debug_person(self.p1, "P1")
|
||||||
|
self.debug_person(self.p2, "P2")
|
||||||
new = RelLib.Person()
|
new = RelLib.Person()
|
||||||
trans = self.db.transaction_begin()
|
trans = self.db.transaction_begin()
|
||||||
|
|
||||||
self.merge_person_information(new,trans)
|
self.merge_person_information(new,trans)
|
||||||
self.merge_family_information(new,trans)
|
self.merge_family_information(new,trans)
|
||||||
self.db.commit_person(new,trans)
|
self.db.commit_person(new,trans)
|
||||||
|
self.debug_person(new, "NEW")
|
||||||
self.db.remove_person(self.old_handle,trans)
|
self.db.remove_person(self.old_handle,trans)
|
||||||
self.db.transaction_commit(trans,"Merge Person")
|
self.db.transaction_commit(trans,"Merge Person")
|
||||||
|
|
||||||
@ -344,13 +352,14 @@ class MergePeople:
|
|||||||
|
|
||||||
for child_id in family.get_child_handle_list():
|
for child_id in family.get_child_handle_list():
|
||||||
if child_id == id2:
|
if child_id == id2:
|
||||||
new_list.append(id1)
|
if id1 not in new_list:
|
||||||
change = True
|
new_list.append(id1)
|
||||||
else:
|
change = True
|
||||||
|
elif child_id not in new_list:
|
||||||
new_list.append(child_id)
|
new_list.append(child_id)
|
||||||
if change:
|
#if change:
|
||||||
family.set_child_handle_list(new_list)
|
family.set_child_handle_list(new_list)
|
||||||
self.db.commit_family(family,trans)
|
self.db.commit_family(family,trans)
|
||||||
|
|
||||||
def merge_parents(self, new, trans):
|
def merge_parents(self, new, trans):
|
||||||
f1_list = self.p1.get_parent_family_handle_list()
|
f1_list = self.p1.get_parent_family_handle_list()
|
||||||
@ -359,9 +368,10 @@ class MergePeople:
|
|||||||
parent_list = f1_list
|
parent_list = f1_list
|
||||||
|
|
||||||
for fid in f2_list:
|
for fid in f2_list:
|
||||||
self.convert_child_ids(fid[0], self.new_handle, self.old_handle, trans)
|
if fid not in parent_list:
|
||||||
parent_list.append(fid)
|
parent_list.append(fid)
|
||||||
for fid in parent_list:
|
for fid in parent_list:
|
||||||
|
self.convert_child_ids(fid[0], self.new_handle, self.old_handle, trans)
|
||||||
new.add_parent_family_handle(fid[0],fid[1],fid[2])
|
new.add_parent_family_handle(fid[0],fid[1],fid[2])
|
||||||
|
|
||||||
def merge_family_information(self, new, trans):
|
def merge_family_information(self, new, trans):
|
||||||
@ -369,6 +379,8 @@ class MergePeople:
|
|||||||
self.merge_families(new, trans)
|
self.merge_families(new, trans)
|
||||||
|
|
||||||
def find_family(self,family):
|
def find_family(self,family):
|
||||||
|
if __debug__:
|
||||||
|
print "SourceFamily: %s" % family.get_handle()
|
||||||
if self.p1.get_gender() == RelLib.Person.MALE:
|
if self.p1.get_gender() == RelLib.Person.MALE:
|
||||||
mother_handle = family.get_mother_handle()
|
mother_handle = family.get_mother_handle()
|
||||||
father_handle = self.p1.get_handle()
|
father_handle = self.p1.get_handle()
|
||||||
@ -379,8 +391,13 @@ class MergePeople:
|
|||||||
for myfamily_handle in self.db.get_family_handles():
|
for myfamily_handle in self.db.get_family_handles():
|
||||||
myfamily = self.db.get_family_from_handle(myfamily_handle)
|
myfamily = self.db.get_family_from_handle(myfamily_handle)
|
||||||
if (myfamily.get_father_handle() == father_handle and
|
if (myfamily.get_father_handle() == father_handle and
|
||||||
myfamily.get_mother_handle() == mother_handle):
|
myfamily.get_mother_handle() == mother_handle and
|
||||||
|
myfamily_handle != family.get_handle()):
|
||||||
|
if __debug__:
|
||||||
|
print "TargetFamily: %s" % myfamily.get_handle()
|
||||||
return myfamily
|
return myfamily
|
||||||
|
if __debug__:
|
||||||
|
print "TargetFamily: None"
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def merge_family_pair(self,tgt_family,src_family,trans):
|
def merge_family_pair(self,tgt_family,src_family,trans):
|
||||||
@ -465,9 +482,13 @@ class MergePeople:
|
|||||||
|
|
||||||
if father and src_family_handle in father.get_family_handle_list():
|
if father and src_family_handle in father.get_family_handle_list():
|
||||||
father.remove_family_handle(src_family_handle)
|
father.remove_family_handle(src_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Removed family %s from father %s" % (src_family_handle, father_id)
|
||||||
self.db.commit_person(father,trans)
|
self.db.commit_person(father,trans)
|
||||||
if mother and src_family_handle in mother.get_family_handle_list():
|
if mother and src_family_handle in mother.get_family_handle_list():
|
||||||
mother.remove_family_handle(src_family_handle)
|
mother.remove_family_handle(src_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Removed family %s from mother %s" % (src_family_handle, mother_id)
|
||||||
self.db.commit_person(mother,trans)
|
self.db.commit_person(mother,trans)
|
||||||
|
|
||||||
self.merge_family_pair(tgt_family,src_family,trans)
|
self.merge_family_pair(tgt_family,src_family,trans)
|
||||||
@ -480,6 +501,8 @@ class MergePeople:
|
|||||||
|
|
||||||
# delete the old source family
|
# delete the old source family
|
||||||
self.db.remove_family(src_family_handle,trans)
|
self.db.remove_family(src_family_handle,trans)
|
||||||
|
if __debug__:
|
||||||
|
print "Deleted src_family %s" % src_family_handle
|
||||||
self.db.commit_family(tgt_family,trans)
|
self.db.commit_family(tgt_family,trans)
|
||||||
|
|
||||||
new.add_family_handle(tgt_family_handle)
|
new.add_family_handle(tgt_family_handle)
|
||||||
@ -507,14 +530,22 @@ class MergePeople:
|
|||||||
if father_handle:
|
if father_handle:
|
||||||
father = self.db.get_person_from_handle(father_handle)
|
father = self.db.get_person_from_handle(father_handle)
|
||||||
father.remove_family_handle(src_family_handle)
|
father.remove_family_handle(src_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Removed family %s from father %s" % (src_family_handle, father_handle)
|
||||||
father.add_family_handle(tgt_family_handle)
|
father.add_family_handle(tgt_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Added family %s to father %s" % (tgt_family_handle, father_handle)
|
||||||
self.db.commit_person(father,trans)
|
self.db.commit_person(father,trans)
|
||||||
|
|
||||||
mother_handle = src_family.get_mother_handle()
|
mother_handle = src_family.get_mother_handle()
|
||||||
if mother_handle:
|
if mother_handle:
|
||||||
mother = self.db.get_person_from_handle(mother_handle)
|
mother = self.db.get_person_from_handle(mother_handle)
|
||||||
mother.remove_family_handle(src_family_handle)
|
mother.remove_family_handle(src_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Removed family %s from mother %s" % (src_family_handle, mother_handle)
|
||||||
mother.add_family_handle(tgt_family_handle)
|
mother.add_family_handle(tgt_family_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Added family %s to mother %s" % (tgt_family_handle, mother_handle)
|
||||||
self.db.commit_person(mother,trans)
|
self.db.commit_person(mother,trans)
|
||||||
|
|
||||||
for child_handle in src_family.get_child_handle_list():
|
for child_handle in src_family.get_child_handle_list():
|
||||||
@ -525,22 +556,29 @@ class MergePeople:
|
|||||||
|
|
||||||
new.remove_family_handle(src_family_handle)
|
new.remove_family_handle(src_family_handle)
|
||||||
self.db.remove_family(src_family_handle,trans)
|
self.db.remove_family(src_family_handle,trans)
|
||||||
|
if __debug__:
|
||||||
|
print "Deleted src_family %s" % src_family_handle
|
||||||
else:
|
else:
|
||||||
|
|
||||||
for fid in self.p1.get_family_handle_list():
|
for fid in self.p1.get_family_handle_list():
|
||||||
new.add_family_handle(fid)
|
if fid not in new.get_family_handle_list():
|
||||||
|
new.add_family_handle(fid)
|
||||||
|
|
||||||
|
# for src_family_handle in self.p2.get_family_handle_list():
|
||||||
|
if src_family_handle in new.get_family_handle_list():
|
||||||
|
continue
|
||||||
|
src_family = self.db.get_family_from_handle(src_family_handle)
|
||||||
|
new.add_family_handle(src_family_handle)
|
||||||
|
if src_family.get_father_handle() == self.old_handle:
|
||||||
|
src_family.set_father_handle(self.new_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Family %s now has father %s" % (src_family_handle, self.new_handle)
|
||||||
|
if src_family.get_mother_handle() == self.old_handle:
|
||||||
|
src_family.set_mother_handle(self.new_handle)
|
||||||
|
if __debug__:
|
||||||
|
print "Family %s now has mother %s" % (src_family_handle, self.new_handle)
|
||||||
|
self.db.commit_family(src_family,trans)
|
||||||
|
|
||||||
for src_family_handle in self.p2.get_family_handle_list():
|
|
||||||
if src_family_handle in self.p1.get_family_handle_list():
|
|
||||||
continue
|
|
||||||
src_family = self.db.get_family_from_handle(src_family_handle)
|
|
||||||
new.add_family_handle(src_family_handle)
|
|
||||||
if src_family.get_father_handle() == self.old_handle:
|
|
||||||
src_family.set_father_handle(self.new_handle)
|
|
||||||
if src_family.get_mother_handle() == self.old_handle:
|
|
||||||
src_family.set_mother_handle(self.new_handle)
|
|
||||||
self.db.commit_family(src_family,trans)
|
|
||||||
|
|
||||||
# a little debugging here
|
# a little debugging here
|
||||||
|
|
||||||
@ -576,6 +614,8 @@ class MergePeople:
|
|||||||
child.remove_parent_family_handle(family_handle)
|
child.remove_parent_family_handle(family_handle)
|
||||||
self.db.commit_person(child,trans)
|
self.db.commit_person(child,trans)
|
||||||
self.db.remove_family(family_handle,trans)
|
self.db.remove_family(family_handle,trans)
|
||||||
|
if __debug__:
|
||||||
|
print "Deleted empty family %s" % family_handle
|
||||||
|
|
||||||
def merge_gramps_ids(self,new):
|
def merge_gramps_ids(self,new):
|
||||||
new.set_gramps_id(self.p1.get_gramps_id())
|
new.set_gramps_id(self.p1.get_gramps_id())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user