From 0742d69347a0dd1ecb74610df1964d85dbd4ffdd Mon Sep 17 00:00:00 2001 From: Don Allingham Date: Sun, 19 Mar 2006 23:34:23 +0000 Subject: [PATCH] performance enhancements svn: r6179 --- ChangeLog | 7 +++ src/DataViews/_PersonView.py | 1 - src/Editors/_EditFamily.py | 8 ++- src/NameDisplay.py | 113 ++++++++++++++++++++++++++++++++--- src/PeopleModel.py | 12 ++-- src/SelectPerson.py | 15 ++--- 6 files changed, 129 insertions(+), 27 deletions(-) diff --git a/ChangeLog b/ChangeLog index 267873a59..e232ac655 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2006-03-19 Don Allingham + * src/Editors/_EditFamily.py: select person used for children + * src/PeopleModel.py: used raw data functions for name display + * src/NameDisplay.py: add raw functions for name display to + avoid the need to create a Name instance + * src/SelectPerson.py: fixed widths + 2006-03-18 Don Allingham * src/Editors/_EditFamily.py: add add_person functionality * src/DisplayTabs.py: add share option to sources diff --git a/src/DataViews/_PersonView.py b/src/DataViews/_PersonView.py index 4c7d13ea7..701c5beef 100644 --- a/src/DataViews/_PersonView.py +++ b/src/DataViews/_PersonView.py @@ -169,7 +169,6 @@ class PersonView(PageView.PersonNavView): self.tree.connect('button-press-event', self.button_press) self.tree.connect('drag_data_get', self.drag_data_get) - self.selection = self.tree.get_selection() self.selection.set_mode(gtk.SELECTION_MULTIPLE) self.selection.connect('changed',self.row_changed) diff --git a/src/Editors/_EditFamily.py b/src/Editors/_EditFamily.py index 860bd3007..8a5b5a257 100644 --- a/src/Editors/_EditFamily.py +++ b/src/Editors/_EditFamily.py @@ -77,6 +77,8 @@ from GrampsWidgets import * from ObjectSelector import PersonSelector,PersonFilterSpec +from SelectPerson import SelectPerson + class ChildEmbedList(EmbeddedList): """ The child embed list is specific to the Edit Family dialog, so it @@ -204,7 +206,7 @@ class ChildEmbedList(EmbeddedList): sel = SelectPerson(self.dbstate.db, "Select Child", skip=[ x for x in skip if x]) person = sel.run() - + if person: self.family.add_child_handle(person.get_handle()) self.rebuild() @@ -246,6 +248,10 @@ class ChildEmbedList(EmbeddedList): # RelLib.Person.__name__)) # selector_window.close() + def run(self,skip): + SelectPerson(self.dbstate.db, "Select Child", + skip=[ x for x in skip if x]) + def del_button_clicked(self,obj): handle = self.get_selected() if handle: diff --git a/src/NameDisplay.py b/src/NameDisplay.py index 02b5a1882..dfe33d37e 100644 --- a/src/NameDisplay.py +++ b/src/NameDisplay.py @@ -49,6 +49,14 @@ class NameDisplay: @type use_upper: bool """ self.force_upper = use_upper + + self.fn_array = [ + self._lnfn, self._lnfn, self._fnln, + self._ptfn, self._empty ] + + self.raw_fn_array = ( + self._lnfn_raw, self._lnfn_raw, self._fnln_raw, + self._ptfn_raw, self._empty_raw ) def use_upper(self,upper): """ @@ -87,6 +95,9 @@ class NameDisplay: def _empty(self,name): return name.first_name + def _empty_raw(self,raw_data): + return raw_data[2] + def _ptfn(self,name): """ Prints the Western style first name, last name style. @@ -112,6 +123,36 @@ class NameDisplay: return "%s %s, %s" % (name.prefix, last, first) else: return "%s, %s" % (last, first) + + def _ptfn_raw(self,raw_data): + """ + Prints the Western style first name, last name style. + Typically this is:: + + SurnamePrefix Patronymic SurnameSuffix, FirstName + """ + + first = raw_data[2] + surname = raw_data[3] + suffix = raw_data[4] + prefix = raw_data[7] + patronymic = raw_data[8] + + if self.force_upper: + last = patronymic.upper() + else: + last = patronymic + + if suffix: + if prefix: + return "%s %s %s, %s" % (prefix, last, suffix, first) + else: + return "%s %s, %s" % (last, suffix, first) + else: + if name.prefix: + return "%s %s, %s" % (prefix, last, first) + else: + return "%s, %s" % (last, first) def _fnln(self,name,nickname=""): """ @@ -141,6 +182,38 @@ class NameDisplay: else: return "%s %s" % (first, last) + def _fnln_raw(self,raw_data): + """ + Prints the Western style first name, last name style. + Typically this is:: + + FirstName Patronymic SurnamePrefix Surname SurnameSuffix + """ + first = raw_data[2] + surname = raw_data[3] + suffix = raw_data[4] + prefix = raw_data[7] + patronymic = raw_data[8] + + if patronymic: + first = "%s %s" % (first, patronymic) + + if self.force_upper: + last = surname.upper() + else: + last = surname + + if suffix: + if prefix: + return "%s %s %s, %s" % (first, prefix, last, suffix) + else: + return "%s %s, %s" % (first, last, suffix) + else: + if prefix: + return "%s %s %s" % (first, prefix, last) + else: + return "%s %s" % (first, last) + def _lnfn(self,name,nickname=u""): """ Prints the Western style last name, first name style. @@ -158,13 +231,25 @@ class NameDisplay: return " ".join([x for x in [name.prefix, last, name.first_name, name.patronymic, name.suffix]]) - - fn_array = { Name.FNLN : _fnln, - Name.PTFN : _ptfn, - Name.FN : _empty, - Name.LNFN : _lnfn, - } + def _lnfn_raw(self,raw_data): + """ + Prints the Western style last name, first name style. + Typically this is:: + + SurnamePrefix Surname, FirstName Patronymic SurnameSuffix + """ + if self.force_upper: + last = raw_data[3].upper() + else: + last = raw_data[3] + + if last: + last += "," + + return " ".join([x for x in [raw_data[7], last, raw_data[2], + raw_data[8], raw_data[4]]]) + def sorted_name(self,name): """ Returns a text string representing the L{Name} instance @@ -176,7 +261,21 @@ class NameDisplay: @returns: Returns the L{Name} string representation @rtype: str """ - return self.fn_array.get(name.sort_as,self._lnfn)(name) + return self.fn_array[name.sort_as](name) + #return self.fn_array.get(name.sort_as,self._lnfn)(name) + + def raw_sorted_name(self,raw_data): + """ + Returns a text string representing the L{Name} instance + in a manner that should be used for displaying a sorted + name. + + @param name: L{Name} instance that is to be displayed. + @type name: L{Name} + @returns: Returns the L{Name} string representation + @rtype: str + """ + return self.raw_fn_array[raw_data[11]](raw_data) def display_given(self,person): name = person.get_primary_name() diff --git a/src/PeopleModel.py b/src/PeopleModel.py index b05c5c376..a010db929 100644 --- a/src/PeopleModel.py +++ b/src/PeopleModel.py @@ -145,7 +145,7 @@ class PeopleModel(gtk.GenericTreeModel): return ngn = NameDisplay.displayer.name_grouping_name - nsn = NameDisplay.displayer.sorted_name + nsn = NameDisplay.displayer.raw_sorted_name flist = set(skip) self.sortnames = {} @@ -157,12 +157,10 @@ class PeopleModel(gtk.GenericTreeModel): n,d = node d = pickle.loads(d) handle = d[0] - primary_name = Name(data=d[_NAME_COL]) - #surname = ngn(self.db,primary_name) surname = n if not (handle in skip or (dfilter and not dfilter.match(handle))): - self.sortnames[handle] = nsn(primary_name) + self.sortnames[handle] = nsn(d[_NAME_COL]) self.temp_sname_sub[surname] = [handle] node = cursor.next_dup() @@ -170,9 +168,8 @@ class PeopleModel(gtk.GenericTreeModel): n,d = node d = pickle.loads(d) handle = d[0] - primary_name = Name(data=d[_NAME_COL]) if not (handle in skip or (dfilter and not dfilter.match(handle))): - self.sortnames[handle] = nsn(primary_name) + self.sortnames[handle] = nsn(d[_NAME_COL]) try: self.temp_sname_sub[surname].append(handle) except: @@ -194,10 +191,9 @@ class PeopleModel(gtk.GenericTreeModel): slist = [ (locale.strxfrm(self.sortnames[x]),x) \ for x in self.temp_sname_sub[name] ] slist.sort() - entries = [ x[1] for x in slist ] val = 0 - for person_handle in entries: + for (junk,person_handle) in slist: tpl = (name,val) self.temp_iter2path[person_handle] = tpl self.temp_path2iter[tpl] = person_handle diff --git a/src/SelectPerson.py b/src/SelectPerson.py index d8b7efef2..00e3503c5 100644 --- a/src/SelectPerson.py +++ b/src/SelectPerson.py @@ -32,9 +32,9 @@ from TransUtils import sgettext as _ # GTK/Gnome modules # #------------------------------------------------------------------------- - import gtk import gtk.glade +import pango #------------------------------------------------------------------------- # @@ -55,14 +55,16 @@ class SelectPerson: def __init__(self, db, title, filter=None, skip=[], parent_window=None): self.renderer = gtk.CellRendererText() + self.renderer.set_property('ellipsize',pango.ELLIPSIZE_END) self.db = db self.glade = gtk.glade.XML(const.gladeFile,"select_person","gramps") self.top = self.glade.get_widget('select_person') - title_label = self.glade.get_widget('title') self.plist = self.glade.get_widget('plist') self.notebook = self.glade.get_widget('notebook') - Utils.set_titles(self.top,title_label,title) + Utils.set_titles(self.top, + self.glade.get_widget('title'), + title) self.model = PeopleModel.PeopleModel(self.db, data_filter=filter, @@ -78,23 +80,16 @@ class SelectPerson: def add_columns(self,tree): tree.set_fixed_height_mode(True) column = gtk.TreeViewColumn(_('Name'), self.renderer, text=0) - column.set_resizable(True) - column.set_clickable(True) - column.set_sort_column_id(0) column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED) column.set_fixed_width(225) tree.append_column(column) column = gtk.TreeViewColumn(_('ID'), self.renderer, text=1) - column.set_resizable(True) - column.set_clickable(True) - column.set_sort_column_id(1) column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED) column.set_fixed_width(75) tree.append_column(column) column = gtk.TreeViewColumn(_('Birth date'), self.renderer, text=3) - column.set_clickable(True) column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED) column.set_fixed_width(160) tree.append_column(column)