2 |
# Authors: |
# Authors: |
3 |
# Jonathan Coles <[email protected]> |
# Jonathan Coles <[email protected]> |
4 |
# Bernhard Reiter <[email protected]> |
# Bernhard Reiter <[email protected]> |
5 |
|
# Silke Reimer <[email protected]> |
6 |
# |
# |
7 |
# This program is free software under the GPL (>=v2) |
# This program is free software under the GPL (>=v2) |
8 |
# Read the file COPYING coming with Thuban for details. |
# Read the file COPYING coming with Thuban for details. |
15 |
|
|
16 |
from wxPython.wx import * |
from wxPython.wx import * |
17 |
|
|
18 |
|
from locale import getdefaultlocale |
19 |
|
|
20 |
from Thuban import _ |
from Thuban import _ |
21 |
from Thuban.version import versions |
from Thuban.version import versions |
22 |
from Thuban.Model.resource import gdal_support_status |
from Thuban.Model.resource import gdal_support_status |
23 |
|
|
24 |
|
from Thuban.UI.extensionregistry import ext_registry |
25 |
|
|
26 |
class About(wxDialog): |
class About(wxDialog): |
27 |
|
|
28 |
def __init__(self, parent): |
def __init__(self, parent): |
37 |
# Note: The source code is in ASCII, so we escape some |
# Note: The source code is in ASCII, so we escape some |
38 |
# characters to get byte strings in latin1. |
# characters to get byte strings in latin1. |
39 |
lead_developer = 'Bernhard Herzog' |
lead_developer = 'Bernhard Herzog' |
40 |
developers = [ 'Jonathan Coles', 'Frank Koormann', |
developers = [ 'Jonathan Coles', |
41 |
unicodeToLocale(u'Martin M\xfcller'), 'Jan-Oliver Wagner' ] |
'Frank Koormann', |
42 |
|
unicodeToLocale(u'Martin M\xfcller'), |
43 |
|
'Bernhard Reiter', |
44 |
|
'Jan-Oliver Wagner' ] |
45 |
translators = [ ( _('French'), 'Daniel Calvelo Aros' ), |
translators = [ ( _('French'), 'Daniel Calvelo Aros' ), |
46 |
( _('German'), unicodeToLocale(u'Bj\xf6rn Broscheit')), |
( _('German'), unicodeToLocale(u'Bj\xf6rn Broscheit')), |
47 |
|
( _('Hungarian'), 'Norbert Solymosi'), |
48 |
( _('Italian'), 'Maurizio Napolitano'), |
( _('Italian'), 'Maurizio Napolitano'), |
49 |
( _('Portuguese (Brazilian)'), 'Eduardo Patto Kanegae'), |
( _('Portuguese (Brazilian)'), 'Eduardo Patto Kanegae'), |
50 |
( _('Russian'), 'Alex Shevlakov'), |
( _('Russian'), 'Alex Shevlakov'), |
51 |
( _('Spanish'), 'Daniel Calvelo Aros') ] |
( _('Spanish'), 'Daniel Calvelo Aros') ] |
52 |
other_contributors = [ 'Jonathan Byron', 'Silke Reimer', |
other_contributors = [ 'Jonathan Byron', |
53 |
'Bernhard Reiter' ] |
'Ole Rahn', |
54 |
|
'Silke Reimer' ] |
55 |
dyn_modules = [ ('wxPython', versions['wxPython']), |
dyn_modules = [ ('wxPython', versions['wxPython']), |
56 |
('Python', versions['python']), |
('Python', versions['python']), |
57 |
('PySQLite', versions['pysqlite']), |
('PySQLite', versions['pysqlite']), |
80 |
text+= '\t%s %s\n' % (name, version) |
text+= '\t%s %s\n' % (name, version) |
81 |
text += '\n' |
text += '\n' |
82 |
|
|
83 |
|
text += _('Extensions:\n') |
84 |
|
if ext_registry: |
85 |
|
for ext in ext_registry: |
86 |
|
text += '\t%s %s\n' % (ext.name, ext.version) |
87 |
|
else: |
88 |
|
text += _('\tNone registered.\n') |
89 |
|
text += '\n' |
90 |
|
|
91 |
text += _('Lead Developer:\n') |
text += _('Lead Developer:\n') |
92 |
text += '\t%s\n\n' % lead_developer |
text += '\t%s\n\n' % lead_developer |
93 |
|
|
113 |
"\tThuban team at Intevation:\n\t\t<[email protected]>\n" |
"\tThuban team at Intevation:\n\t\t<[email protected]>\n" |
114 |
) |
) |
115 |
|
|
116 |
|
text += '\n\n' |
117 |
|
|
118 |
|
text += _("Details on the registered extensions:\n\n") |
119 |
|
|
120 |
|
if ext_registry: |
121 |
|
for ext in ext_registry: |
122 |
|
text += '%s %s:\n' % (ext.name, ext.version) |
123 |
|
text += _('Copyright %s\n') % ext.copyright |
124 |
|
text += _('Authors:\n') |
125 |
|
for author in ext.authors: |
126 |
|
text+= '\t%s\n' % author |
127 |
|
text += ext.desc |
128 |
|
text += '\n\n' |
129 |
|
else: |
130 |
|
text += _('\tNone registered.\n') |
131 |
|
|
132 |
self.text = text |
self.text = text |
133 |
|
|
134 |
text_title = wxStaticText(self, -1, |
text_title = wxStaticText(self, -1, |
164 |
|
|
165 |
|
|
166 |
def unicodeToLocale(unicodeStr): |
def unicodeToLocale(unicodeStr): |
167 |
" Function to convert a unicode object to an object \ in the user's locale encoding" |
"Function to convert unicode to the user's locale encoding" |
168 |
|
# Under a german windows 2000 getlocale returns an encoding name |
169 |
|
# that's not direcly usable (it's missing a "cp" at the beginning). |
170 |
from locale import getlocale |
# getdefaultlocale does return a usable encoding name so we use that |
171 |
|
# instead. |
172 |
return unicodeStr.encode(getlocale()[1]) |
locale=getdefaultlocale()[1] |
173 |
|
if locale is None: |
174 |
|
locale = 'iso-8859-15' |
175 |
|
return unicodeStr.encode(locale) |