2007-06-21 Alex Roitman <shura@gramps-project.org>
* src/GrampsCfg.py (cb_format_changed): Catch new exception; escape special chars from displayed span. * src/NameDisplay.py (_gen_cooked_func): Only replace known parameters, leave the rest as is; (_format_str_base): Catch formatting exceptions and raise our own. * src/Errors.py (NameDisplayError): Add class. svn: r8620
This commit is contained in:
parent
79257df532
commit
e63bc9936d
@ -1,3 +1,11 @@
|
|||||||
|
2007-06-21 Alex Roitman <shura@gramps-project.org>
|
||||||
|
* src/GrampsCfg.py (cb_format_changed): Catch new exception;
|
||||||
|
escape special chars from displayed span.
|
||||||
|
* src/NameDisplay.py (_gen_cooked_func): Only replace known
|
||||||
|
parameters, leave the rest as is;
|
||||||
|
(_format_str_base): Catch formatting exceptions and raise our own.
|
||||||
|
* src/Errors.py (NameDisplayError): Add class.
|
||||||
|
|
||||||
2007-06-22 Zsolt Foldvari <zfoldvar@users.sourceforge.net>
|
2007-06-22 Zsolt Foldvari <zfoldvar@users.sourceforge.net>
|
||||||
* src/NameDisplay.py: fix indentation (use only spaces).
|
* src/NameDisplay.py: fix indentation (use only spaces).
|
||||||
* src/GrampsCfg.py: handle invalid name format: #1025.
|
* src/GrampsCfg.py: handle invalid name format: #1025.
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# Gramps - a GTK+/GNOME based genealogy program
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
#
|
#
|
||||||
# Copyright (C) 2003-2006 Donald N. Allingham
|
# Copyright (C) 2003-2007 Donald N. Allingham
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# This program is free software; you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU General Public License as published by
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -135,3 +135,13 @@ class MaskError(Exception):
|
|||||||
class ValidationError(Exception):
|
class ValidationError(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class NameDisplayError(Exception):
|
||||||
|
"""
|
||||||
|
Error used to report that the name display format string is invalid.
|
||||||
|
"""
|
||||||
|
def __init__(self,value):
|
||||||
|
Exception.__init__(self)
|
||||||
|
self.value = value
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return self.value
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
from gettext import gettext as _
|
from gettext import gettext as _
|
||||||
|
from xml.sax.saxutils import escape
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -46,6 +47,7 @@ from RelLib import Name
|
|||||||
import ManagedWindow
|
import ManagedWindow
|
||||||
from GrampsWidgets import *
|
from GrampsWidgets import *
|
||||||
import QuestionDialog
|
import QuestionDialog
|
||||||
|
from Errors import NameDisplayError
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -620,10 +622,10 @@ class NameFormatEditDlg:
|
|||||||
|
|
||||||
def cb_format_changed(self, obj):
|
def cb_format_changed(self, obj):
|
||||||
try:
|
try:
|
||||||
t = (_nd.format_str(self.name, obj.get_text()))
|
t = (_nd.format_str(self.name, escape(obj.get_text())))
|
||||||
sample = '<span weight="bold" style="italic">%s</span>' % t
|
sample = '<span weight="bold" style="italic">%s</span>' % t
|
||||||
self.valid = True
|
self.valid = True
|
||||||
except ValueError, msg:
|
except NameDisplayError:
|
||||||
t = _("Invalid or incomplete format definition")
|
t = _("Invalid or incomplete format definition")
|
||||||
sample = '<span foreground="#FF0000">%s</span>' % t
|
sample = '<span foreground="#FF0000">%s</span>' % t
|
||||||
self.valid = False
|
self.valid = False
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# Gramps - a GTK+/GNOME based genealogy program
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
#
|
#
|
||||||
# Copyright (C) 2004-2006 Donald N. Allingham
|
# Copyright (C) 2004-2007 Donald N. Allingham
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# This program is free software; you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU General Public License as published by
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -39,6 +39,7 @@ import re
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
from RelLib import Name
|
from RelLib import Name
|
||||||
import Config
|
import Config
|
||||||
|
from Errors import NameDisplayError
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -373,7 +374,7 @@ class NameDisplay:
|
|||||||
# for each one we find the variable name that is needed to
|
# for each one we find the variable name that is needed to
|
||||||
# replace it and add this to a list. This list will be used
|
# replace it and add this to a list. This list will be used
|
||||||
# generate the replacement tuple.
|
# generate the replacement tuple.
|
||||||
pat = re.compile("%.")
|
pat = re.compile('|'.join(d.keys()))
|
||||||
|
|
||||||
param = ()
|
param = ()
|
||||||
mat = pat.search(format_str)
|
mat = pat.search(format_str)
|
||||||
@ -433,7 +434,11 @@ class NameDisplay:
|
|||||||
func = self._gen_cooked_func(format_str)
|
func = self._gen_cooked_func(format_str)
|
||||||
self.__class__.format_funcs[format_str] = func
|
self.__class__.format_funcs[format_str] = func
|
||||||
|
|
||||||
|
try:
|
||||||
s = func(first,surname,prefix,suffix,patronymic,title,call)
|
s = func(first,surname,prefix,suffix,patronymic,title,call)
|
||||||
|
except (ValueError,TypeError,):
|
||||||
|
raise NameDisplayError, "Incomplete format string"
|
||||||
|
|
||||||
return ' '.join(s.split())
|
return ' '.join(s.split())
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
|
Loading…
x
Reference in New Issue
Block a user