3175: Crash when undoing a family edit- part of undo being slow

svn: r14677
This commit is contained in:
Benny Malengier 2010-03-07 19:38:51 +00:00
parent d34e83d9ba
commit 6802502aeb
2 changed files with 55 additions and 34 deletions

View File

@ -858,13 +858,16 @@ class PedigreeView(NavigationView):
def person_rebuild(self, dummy=None):
"""Callback function for signals of change database."""
self.format_helper.clear_cache()
self.dirty = True
self.rebuild_trees(self.get_active())
if self.active:
self.format_helper.clear_cache()
self.dirty = True
self.rebuild_trees(self.get_active())
else:
self.dirty = True
def rebuild_trees(self, person_handle):
"""
Rebild tree with root person_handle.
Rebuild tree with root person_handle.
Called from many fuctions, when need full redraw tree.
"""
person = None

View File

@ -211,55 +211,72 @@ class RelationshipView(NavigationView):
self.redraw()
def person_update(self, handle_list):
person = self.get_active()
if person:
while not self.change_person(person):
pass
if self.active:
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def person_rebuild(self):
"""Large change to person database"""
if self.active:
self.bookmarks.redraw()
person = self.get_active()
if person:
while not self.change_person(person):
pass
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def family_update(self, handle_list):
person = self.get_active()
if person:
while not self.change_person(person):
pass
if self.active:
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def family_add(self, handle_list):
person = self.get_active()
if person:
while not self.change_person(person):
pass
if self.active:
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def family_delete(self, handle_list):
person = self.get_active()
if person:
while not self.change_person(person):
pass
if self.active:
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def family_rebuild(self):
person = self.get_active()
if person:
while not self.change_person(person):
pass
if self.active:
person = self.get_active()
if person:
while not self.change_person(person):
pass
else:
self.change_person(None)
else:
self.change_person(None)
self.dirty = True
def change_page(self):
NavigationView.change_page(self)
@ -553,6 +570,7 @@ class RelationshipView(NavigationView):
self.uistate.modify_statusbar(self.dbstate)
self.order_action.set_sensitive(self.reorder_sensitive)
self.dirty = False
return True