2007-01-16 Don Allingham <don@gramps-project.org>

* src/DataViews/_PersonView.py: optimization
	* src/ViewManager.py: remove double build call
	* src/DisplayModels/_PeopleModel.py: optimization



svn: r7920
This commit is contained in:
Don Allingham 2007-01-17 00:31:06 +00:00
parent dd38db4c4d
commit 38cff6178c
4 changed files with 45 additions and 19 deletions

View File

@ -1,3 +1,8 @@
2007-01-16 Don Allingham <don@gramps-project.org>
* src/DataViews/_PersonView.py: optimization
* src/ViewManager.py: remove double build call
* src/DisplayModels/_PeopleModel.py: optimization
2007-01-17 Richard Taylor <rjt-gramps@thegrindstone.me.uk>
* src/NameDisplay.py: fast implementation

View File

@ -422,6 +422,21 @@ class PersonView(PageView.PersonNavView):
db.connect('person-update', self.person_updated)
db.connect('person-delete', self.person_removed)
db.connect('person-rebuild', self.build_tree)
# import hotshot, hotshot.stats
# pr = hotshot.Profile('mystats.profile')
# print "Start"
# pr.runcall(self.build_tree)
# print "Finished"
# pr.close()
# print "Loading profile"
# stats = hotshot.stats.load('mystats.profile')
# print "done"
# stats.strip_dirs()
# stats.sort_stats('time','calls')
# stats.print_stats(100)
self.build_tree()
self.bookmarks.update_bookmarks(db.get_bookmarks())
if self.active:
@ -510,7 +525,6 @@ class PersonView(PageView.PersonNavView):
since it can change when rows are unselected when the model is set.
"""
if self.active:
if Config.get(Config.FILTER):
filter_info = (PeopleModel.GENERIC, self.generic_filter)
else:

View File

@ -140,6 +140,7 @@ class PeopleModel(gtk.GenericTreeModel):
gtk.GenericTreeModel.__init__(self)
self.db = db
self.in_build = False
Config.client.notify_add("/apps/gramps/preferences/todo-color",
self.update_todo)
@ -160,7 +161,7 @@ class PeopleModel(gtk.GenericTreeModel):
self.path2iter = {}
self.sname_sub = {}
if filter_info:
if filter_info and filter_info != (1, (0, u'', False)):
if filter_info[0] == PeopleModel.GENERIC:
data_filter = filter_info[1]
self._build_data = self._build_filter_sub
@ -248,6 +249,7 @@ class PeopleModel(gtk.GenericTreeModel):
"""
Calculates the new path to node values for the model.
"""
self.in_build = True
self.lru_data = LRU(_CACHE_SIZE)
self.lru_name = LRU(_CACHE_SIZE)
self.lru_bdate = LRU(_CACHE_SIZE)
@ -267,6 +269,7 @@ class PeopleModel(gtk.GenericTreeModel):
self.temp_top_path2iter = locale_sort(self.temp_sname_sub.keys())
for name in self.temp_top_path2iter:
self.build_sub_entry(name)
self.in_build = False
def clear_cache(self):
self.lru_data = LRU(_CACHE_SIZE)
@ -350,7 +353,8 @@ class PeopleModel(gtk.GenericTreeModel):
data = self.lru_data[node]
except:
data = self.db.get_raw_person_data(str(node))
self.lru_data[node] = data
if not self.in_build:
self.lru_data[node] = data
return PeopleModel.COLUMN_DEFS[col][PeopleModel.COLUMN_DEF_LIST](self,
data, node)
except:
@ -431,11 +435,12 @@ class PeopleModel(gtk.GenericTreeModel):
return spouses_names
def column_name(self, data, node):
try:
name = self.lru_name[node]
except:
name = NameDisplay.displayer.raw_sorted_name(data[PeopleModel._NAME_COL])
self.lru_name[node] = name
try:
name = self.lru_name[node]
except:
name = NameDisplay.displayer.raw_sorted_name(data[PeopleModel._NAME_COL])
if not self.in_build:
self.lru_name[node] = name
return name
def column_id(self, data, node):
@ -451,11 +456,12 @@ class PeopleModel(gtk.GenericTreeModel):
return PeopleModel._GENDER[data[PeopleModel._GENDER_COL]]
def column_birth_day(self, data, node):
try:
value = self.lru_bdate[node]
except:
value = self._get_birth_data(data,node)
self.lru_bdate[node] = value
try:
value = self.lru_bdate[node]
except:
value = self._get_birth_data(data,node)
if not self.in_build:
self.lru_bdate[node] = value
return value
def _get_birth_data(self, data, node):
@ -486,11 +492,12 @@ class PeopleModel(gtk.GenericTreeModel):
return u""
def column_death_day(self, data, node):
try:
value = self.lru_ddate[node]
except:
value = self._get_death_data(data,node)
self.lru_ddate[node] = value
try:
value = self.lru_ddate[node]
except:
value = self._get_death_data(data,node)
if not self.in_build:
self.lru_ddate[node] = value
return value
def _get_death_data(self, data, node):

View File

@ -935,7 +935,7 @@ class ViewManager:
self.state.db.enable_signals()
self.state.signal_change()
self.state.db.request_rebuild()
# self.state.db.request_rebuild()
Config.set(Config.RECENT_FILE,filename)