removal of u2l, papersizes read from XML file

svn: r1194
This commit is contained in:
Don Allingham 2002-11-19 04:15:02 +00:00
parent a3708b62dc
commit af2fb7180c
10 changed files with 167 additions and 126 deletions

View File

@ -54,10 +54,11 @@ class DisplayTrace:
def __init__(self): def __init__(self):
data = sys.exc_info() data = sys.exc_info()
msg = cStringIO.StringIO() msg = cStringIO.StringIO()
msg.write(_('GRAMPS has encountered an internal error.\n' msg.write(_('GRAMPS %s has encountered an internal error.\n'
'Please copy the message below and post a bug report ' 'Please copy the message below and post a bug report '
'at http://sourceforge.net/projects/gramps or send an ' 'at http://sourceforge.net/projects/gramps or send an '
'email message to gramps-users@lists.sourceforge.net\n\n')) 'email message to gramps-users@lists.sourceforge.net\n\n')
% const.version)
traceback.print_exception(data[0],data[1],data[2],None,msg) traceback.print_exception(data[0],data[1],data[2],None,msg)

View File

@ -19,8 +19,6 @@
# #
import const import const
from latin_utf8 import utf8_to_latin
u2l = utf8_to_latin
ADOPT_NONE = 0 ADOPT_NONE = 0
ADOPT_EVENT = 1 ADOPT_EVENT = 1
@ -175,15 +173,13 @@ class GedInfoParser:
p.ParseFile(file) p.ParseFile(file)
def startElement(self,tag,attrs): def startElement(self,tag,attrs):
tag = u2l(tag)
if tag == "target": if tag == "target":
name = u2l(attrs['name']) name = attrs['name']
self.current = GedcomDescription(name) self.current = GedcomDescription(name)
self.parent.add_description(name,self.current) self.parent.add_description(name,self.current)
elif tag == "dest": elif tag == "dest":
self.current.set_dest(u2l(attrs['val'])) self.current.set_dest(attrs['val'])
elif tag == "adopt": elif tag == "adopt":
val = u2l(attrs['val'])
if val == 'none': if val == 'none':
self.current.set_adopt(ADOPT_NONE) self.current.set_adopt(ADOPT_NONE)
elif val == 'event': elif val == 'event':
@ -195,10 +191,9 @@ class GedInfoParser:
elif val == 'pedigree': elif val == 'pedigree':
self.current.set_adopt(ADOPT_PEDI) self.current.set_adopt(ADOPT_PEDI)
elif tag == "conc": elif tag == "conc":
if u2l(attrs['val']) == 'broken': if attrs['val'] == 'broken':
self.current.set_conc(CONC_BROKEN) self.current.set_conc(CONC_BROKEN)
elif tag == "alternate_names": elif tag == "alternate_names":
val = u2l(attrs['val'])
if val == 'none': if val == 'none':
self.current.set_alt_name(ALT_NAME_NONE) self.current.set_alt_name(ALT_NAME_NONE)
elif val == 'event_aka': elif val == 'event_aka':
@ -210,13 +205,13 @@ class GedInfoParser:
elif val == '_alias': elif val == '_alias':
self.current.set_alt_name(ALT_NAME_UALIAS) self.current.set_alt_name(ALT_NAME_UALIAS)
elif tag == "calendars": elif tag == "calendars":
if u2l(attrs['val']) == 'no': if attrs['val'] == 'no':
self.current.set_alt_calendar(CALENDAR_NO) self.current.set_alt_calendar(CALENDAR_NO)
elif tag == "event": elif tag == "event":
self.current.add_tag_value(u2l(attrs['tag']),u2l(attrs['value'])) self.current.add_tag_value(attrs['tag'],attrs['value'])
elif tag == "object_support": elif tag == "object_support":
if u2l(attrs['val']) == 'no': if attrs['val'] == 'no':
self.current.set_obje(OBJE_NO) self.current.set_obje(OBJE_NO)
elif tag == "residence": elif tag == "residence":
if u2l(attrs['val']) == 'place': if attrs['val'] == 'place':
self.current.set_resi(RESIDENCE_PLAC) self.current.set_resi(RESIDENCE_PLAC)

View File

@ -41,9 +41,6 @@ import os
from string import find,join,strip,replace from string import find,join,strip,replace
import gtk import gtk
from latin_utf8 import utf8_to_latin
u2l = utf8_to_latin
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# GRAMPS modules # GRAMPS modules
@ -777,32 +774,30 @@ class FilterParser(handler.ContentHandler):
def startElement(self,tag,attrs): def startElement(self,tag,attrs):
if tag == "filter": if tag == "filter":
self.f = GenericFilter() self.f = GenericFilter()
self.f.set_name(u2l(attrs['name'])) self.f.set_name(attrs['name'])
if attrs.has_key('function'): if attrs.has_key('function'):
try: try:
if int(u2l(attrs['function'])): if int(attrs['function']):
op = 'or' op = 'or'
else: else:
op = 'and' op = 'and'
except ValueError: except ValueError:
op = u2l(attrs['function']) op = attrs['function']
self.f.set_logical_op(op) self.f.set_logical_op(op)
if attrs.has_key('comment'): if attrs.has_key('comment'):
self.f.set_comment(u2l(attrs['comment'])) self.f.set_comment(attrs['comment'])
if attrs.has_key('invert'): if attrs.has_key('invert'):
try: try:
self.f.set_invert(int(u2l(attrs['invert']))) self.f.set_invert(int(attrs['invert']))
except ValueError: except ValueError:
pass pass
self.gfilter_list.add(self.f) self.gfilter_list.add(self.f)
elif tag == "rule": elif tag == "rule":
c = attrs['class'] name = _(attrs['class'])
name = _(u2l(c))
self.a = [] self.a = []
self.cname = tasks[name] self.cname = tasks[name]
elif tag == "arg": elif tag == "arg":
c = attrs['value'] self.a.append(attrs['value'])
self.a.append(u2l(c))
def endElement(self,tag): def endElement(self,tag):
if tag == "rule": if tag == "rule":

View File

@ -28,7 +28,6 @@ class ListModel:
self.mylist = [TYPE_STRING]*l + [TYPE_PYOBJECT] self.mylist = [TYPE_STRING]*l + [TYPE_PYOBJECT]
self.new_model() self.new_model()
self.connect_model()
self.selection = self.tree.get_selection() self.selection = self.tree.get_selection()
@ -45,17 +44,21 @@ class ListModel:
else: else:
column.set_resizable(gtk.TRUE) column.set_resizable(gtk.TRUE)
cnum = cnum + 1 cnum = cnum + 1
tree.append_column(column) self.tree.append_column(column)
self.column = None
num = 0 num = 0
for name in dlist: for name in dlist:
column = tree.get_column(num) column = self.tree.get_column(num)
if name[1] != -1: if name[1] != -1:
column.set_sort_column_id(name[1]) column.set_sort_column_id(name[1])
if num == 0: if not self.column:
column.clicked() self.column = column
num = num + 1 num = num + 1
self.connect_model()
self.column.clicked()
if select_func: if select_func:
self.selection.connect('changed',select_func) self.selection.connect('changed',select_func)
if event_func: if event_func:
@ -67,6 +70,7 @@ class ListModel:
def connect_model(self): def connect_model(self):
self.tree.set_model(self.model) self.tree.set_model(self.model)
self.column.clicked()
def get_selected(self): def get_selected(self):
return self.selection.get_selected() return self.selection.get_selected()

View File

@ -18,26 +18,45 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
import TextDoc #-------------------------------------------------------------------------
#
# GNOME modules
#
#-------------------------------------------------------------------------
import gtk import gtk
#-------------------------------------------------------------------------
#
# GRAMPS modules
#
#-------------------------------------------------------------------------
import TextDoc
import GrampsCfg import GrampsCfg
import const
from intl import gettext as _
from intl import gettext #-------------------------------------------------------------------------
_ = gettext #
# Try to abstract SAX1 from SAX2
#
#-------------------------------------------------------------------------
try:
from xml.sax import make_parser,handler,SAXParseException
except:
from _xmlplus.sax import make_parser,handler,SAXParseException
paper_sizes = [ #-------------------------------------------------------------------------
TextDoc.PaperStyle("Letter",27.94,21.59), #
TextDoc.PaperStyle("Legal",35.56,21.59), #
TextDoc.PaperStyle("A3",42.0,29.7), #
TextDoc.PaperStyle("A4",29.7,21.0), #-------------------------------------------------------------------------
TextDoc.PaperStyle("A5",21.0,14.8), paper_sizes = []
TextDoc.PaperStyle("B4",35.3,25.0),
TextDoc.PaperStyle("B6",17.6,12.5),
TextDoc.PaperStyle("C4",32.4,22.9),
TextDoc.PaperStyle("C5",22.9,16.2),
TextDoc.PaperStyle("C6",16.2,11.4)
]
#-------------------------------------------------------------------------
#
# make_paper_menu
#
#-------------------------------------------------------------------------
def make_paper_menu(main_menu): def make_paper_menu(main_menu):
index = 0 index = 0
@ -53,6 +72,11 @@ def make_paper_menu(main_menu):
index = index + 1 index = index + 1
main_menu.set_menu(myMenu) main_menu.set_menu(myMenu)
#-------------------------------------------------------------------------
#
# make_orientation_menu
#
#-------------------------------------------------------------------------
def make_orientation_menu(main_menu): def make_orientation_menu(main_menu):
myMenu = gtk.Menu() myMenu = gtk.Menu()
@ -68,3 +92,46 @@ def make_orientation_menu(main_menu):
main_menu.set_menu(myMenu) main_menu.set_menu(myMenu)
#-------------------------------------------------------------------------
#
# FilterParser
#
#-------------------------------------------------------------------------
class PageSizeParser(handler.ContentHandler):
"""Parses the XML file and builds the list of page sizes"""
def __init__(self,paper_list):
handler.ContentHandler.__init__(self)
self.paper_list = paper_list
def setDocumentLocator(self,locator):
self.locator = locator
def startElement(self,tag,attrs):
if tag == "page":
name = attrs['name']
height = float(attrs['height'])
width = float(attrs['width'])
self.paper_list.append(TextDoc.PaperStyle(name,height,width))
#-------------------------------------------------------------------------
#
# Parse XML file. If failed, used default
#
#-------------------------------------------------------------------------
try:
parser = make_parser()
parser.setContentHandler(PageSizeParser(paper_sizes))
parser.parse(const.papersize)
except (IOError,OSError,SAXParseException):
paper_sizes = [
TextDoc.PaperStyle("Letter",27.94,21.59),
TextDoc.PaperStyle("Legal",35.56,21.59),
TextDoc.PaperStyle("A4",29.7,21.0),
TextDoc.PaperStyle("A5",21.0,14.8),
TextDoc.PaperStyle("B4",35.3,25.0),
TextDoc.PaperStyle("B6",17.6,12.5),
TextDoc.PaperStyle("C4",32.4,22.9),
TextDoc.PaperStyle("C5",22.9,16.2),
TextDoc.PaperStyle("C6",16.2,11.4)
]

View File

@ -52,11 +52,7 @@ import TextDoc
import StyleEditor import StyleEditor
import GrampsCfg import GrampsCfg
import PaperMenu import PaperMenu
import intl from intl import gettext as _
import latin_utf8
u2l = latin_utf8.utf8_to_latin
_ = intl.gettext
from QuestionDialog import ErrorDialog from QuestionDialog import ErrorDialog
@ -1077,7 +1073,7 @@ class TemplateParser(handler.ContentHandler):
""" """
if tag == "template": if tag == "template":
self.data[u2l(attrs['title'])] = u2l(attrs['file']) self.data[attrs['title']] = attrs['file']
try: try:
parser = make_parser() parser = make_parser()

View File

@ -30,8 +30,7 @@ import os
# internationalization # internationalization
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
from intl import gettext from intl import gettext as _
_ = gettext
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -61,6 +60,7 @@ good_xpm = "%s/good.xpm" % rootDir
bad_xpm = "%s/bad.xpm" % rootDir bad_xpm = "%s/bad.xpm" % rootDir
caution_xpm = "%s/caution.xpm" % rootDir caution_xpm = "%s/caution.xpm" % rootDir
papersize = "%s/papersize.xml" % rootDir
system_filters = "%s/system_filters.xml" % rootDir system_filters = "%s/system_filters.xml" % rootDir
custom_filters = "~/.gramps/custom_filters.xml" custom_filters = "~/.gramps/custom_filters.xml"
icon = "%s/gramps.xpm" % rootDir icon = "%s/gramps.xpm" % rootDir

14
gramps2/src/papersize.xml Normal file
View File

@ -0,0 +1,14 @@
<?xml version="1.0" encoding="iso-8859-1"?>
<paper>
<page name="Letter" height="27.94" width="21.59"/>
<page name="Legal" height="35.56" width="21.59"/>
<page name="Banana" height="42.0" width="29.7"/>
<page name="A3" height="42.0" width="29.7"/>
<page name="A4" height="29.7" width="21.0"/>
<page name="A5" height="21.0" width="14.8"/>
<page name="B4" height="35.3" width="25.0"/>
<page name="B6" height="17.6" width="12.5"/>
<page name="C4" height="32.4" width="22.9"/>
<page name="C5" height="22.9" width="16.2"/>
<page name="C6" height="16.2" width="11.4"/>
</paper>

View File

@ -20,18 +20,33 @@
"Utilities/Relationship calculator" "Utilities/Relationship calculator"
#-------------------------------------------------------------------------
#
# Standard python modules
#
#-------------------------------------------------------------------------
import os import os
#-------------------------------------------------------------------------
#
# GNOME libraries
#
#-------------------------------------------------------------------------
from gtk import * from gtk import *
from gnome.ui import * from gnome.ui import *
import gtk.glade import gtk.glade
#-------------------------------------------------------------------------
#
# GRAMPS modules
#
#-------------------------------------------------------------------------
import RelLib import RelLib
import sort import sort
import intl
import Utils import Utils
import ListModel
_ = intl.gettext from intl import gettext as _
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -297,7 +312,7 @@ class RelCalc:
self.db = database self.db = database
base = os.path.dirname(__file__) base = os.path.dirname(__file__)
glade_file = base + os.sep + "relcalc.glade" glade_file = "%s/relcalc.glade" % base
self.glade = gtk.glade.XML(glade_file,"relcalc") self.glade = gtk.glade.XML(glade_file,"relcalc")
name = self.person.getPrimaryName().getRegularName() name = self.person.getPrimaryName().getRegularName()
@ -305,18 +320,16 @@ class RelCalc:
self.glade.get_widget("name").set_text(_("Relationship to %s") % name) self.glade.get_widget("name").set_text(_("Relationship to %s") % name)
self.people = self.glade.get_widget("peopleList") self.people = self.glade.get_widget("peopleList")
name_list = self.db.getPersonMap().values() self.clist = ListModel.ListModel(self.people, [(_('Name'),3,150),(_('ID'),1,50),
name_list.sort(sort.by_last_name) (_('Birthday'),4,150),
index = 0 ('',-1,0),('',-1,0)])
self.people.freeze() self.clist.new_model()
for p in name_list: for key in self.db.getPersonKeys():
name = p.getPrimaryName().getName() p = self.db.getPerson(key)
birthday = p.getBirth().getDate() val = self.db.getPersonDisplay(key)
id = p.getId() self.clist.add([val[0],val[1],val[3],val[5],val[6]],p.getId())
self.people.append([name,id,birthday])
self.people.set_row_data(index,p) self.clist.connect_model()
index = index + 1
self.people.thaw()
self.glade.signal_autoconnect({ self.glade.signal_autoconnect({
"on_close_clicked" : Utils.destroy_passed_object, "on_close_clicked" : Utils.destroy_passed_object,
@ -331,10 +344,12 @@ class RelCalc:
common = [] common = []
rank = 9999999 rank = 9999999
if len(self.people.selection) == 0: model,iter = self.clist.get_selected()
if not iter:
return return
other_person = self.people.get_row_data(self.people.selection[0]) id = self.clist.get_object(iter)
other_person = self.db.getPerson(id)
filter(self.person,0,firstList,firstMap) filter(self.person,0,firstList,firstMap)
filter(other_person,0,secondList,secondMap) filter(other_person,0,secondList,secondMap)

View File

@ -108,59 +108,13 @@
<property name="window_placement">GTK_CORNER_TOP_LEFT</property> <property name="window_placement">GTK_CORNER_TOP_LEFT</property>
<child> <child>
<widget class="GtkCList" id="peopleList"> <widget class="GtkTreeView" id="peopleList">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="n_columns">3</property> <property name="headers_visible">True</property>
<property name="column_widths">236,56,80</property> <property name="rules_hint">True</property>
<property name="selection_mode">GTK_SELECTION_SINGLE</property> <property name="reorderable">False</property>
<property name="show_titles">True</property> <property name="enable_search">True</property>
<property name="shadow_type">GTK_SHADOW_IN</property>
<child>
<widget class="GtkLabel" id="label9">
<property name="label" translatable="yes">Name</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label10">
<property name="label" translatable="yes">ID</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
</child>
<child>
<widget class="GtkLabel" id="label11">
<property name="label" translatable="yes">Birthday</property>
<property name="use_underline">False</property>
<property name="use_markup">False</property>
<property name="justify">GTK_JUSTIFY_LEFT</property>
<property name="wrap">False</property>
<property name="selectable">False</property>
<property name="xalign">0.5</property>
<property name="yalign">0.5</property>
<property name="xpad">0</property>
<property name="ypad">0</property>
</widget>
</child>
</widget> </widget>
</child> </child>
</widget> </widget>