38 |
from messages import SESSION_REPLACED |
from messages import SESSION_REPLACED |
39 |
|
|
40 |
|
|
|
|
|
41 |
class ThubanApplication(wxApp, Publisher): |
class ThubanApplication(wxApp, Publisher): |
42 |
|
|
43 |
""" |
""" |
49 |
""" |
""" |
50 |
|
|
51 |
def OnInit(self): |
def OnInit(self): |
52 |
|
sys.excepthook = self.ShowExceptionDialog |
53 |
self.splash = self.splash_screen() |
self.splash = self.splash_screen() |
54 |
if self.splash is not None: |
if self.splash is not None: |
55 |
self.splash.Show() |
self.splash.Show() |
189 |
""" |
""" |
190 |
self.SetSession(create_empty_session()) |
self.SetSession(create_empty_session()) |
191 |
|
|
192 |
def OpenSession(self, filename): |
def OpenSession(self, filename, db_connection_callback = None): |
193 |
"""Open the session in the file named filename""" |
"""Open the session in the file named filename""" |
194 |
# Make sure we deal with an absolute pathname. Otherwise we can |
# Make sure we deal with an absolute pathname. Otherwise we can |
195 |
# get problems when saving because the saving code expects an |
# get problems when saving because the saving code expects an |
196 |
# absolute directory name |
# absolute directory name |
197 |
filename = os.path.abspath(filename) |
filename = os.path.abspath(filename) |
198 |
session = load_session(filename) |
session = load_session(filename, |
199 |
|
db_connection_callback = db_connection_callback) |
200 |
session.SetFilename(filename) |
session.SetFilename(filename) |
201 |
session.UnsetModified() |
session.UnsetModified() |
202 |
self.SetSession(session) |
self.SetSession(session) |
205 |
for layer in map.Layers(): |
for layer in map.Layers(): |
206 |
if isinstance(layer, RasterLayer) \ |
if isinstance(layer, RasterLayer) \ |
207 |
and not Thuban.Model.resource.has_gdal_support(): |
and not Thuban.Model.resource.has_gdal_support(): |
208 |
msg = _("The current session contains Image layers,\n" + |
msg = _("The current session contains Image layers,\n" |
209 |
"but the GDAL library is not available to " + |
"but the GDAL library is not available to " |
210 |
"draw them.") |
"draw them.") |
211 |
dlg = wx.wxMessageDialog(None, |
dlg = wx.wxMessageDialog(None, |
212 |
msg, |
msg, |
213 |
_("Library not available"), |
_("Library not available"), |
214 |
wx.wxOK | wx.wxICON_INFORMATION) |
wx.wxOK | wx.wxICON_INFORMATION) |
215 |
print msg |
print msg |
226 |
else: |
else: |
227 |
self.top.SetMap(None) |
self.top.SetMap(None) |
228 |
|
|
229 |
in_exception_dialog = 0 # flag: are we already inside the exception dialog? |
in_exception_dialog = 0 # flag: are we already inside the exception dialog? |
|
|
|
|
def show_exception_dialog(exc_type, exc_value, exc_traceback): |
|
|
"""Show a message box with information about an exception. |
|
|
|
|
|
The parameters are the usual values describing an exception in |
|
|
Python, the exception type, the value and the traceback. |
|
|
|
|
|
This method can be used as a value for the sys.excepthook. |
|
|
""" |
|
|
global in_exception_dialog |
|
230 |
|
|
231 |
if in_exception_dialog: |
def ShowExceptionDialog(self, exc_type, exc_value, exc_traceback): |
232 |
return |
"""Show a message box with information about an exception. |
233 |
in_exception_dialog = 1 |
|
234 |
while wxIsBusy(): |
The parameters are the usual values describing an exception in |
235 |
wxEndBusyCursor() # reset the mouse cursor |
Python, the exception type, the value and the traceback. |
236 |
|
|
237 |
try: |
This method can be used as a value for the sys.excepthook. |
238 |
lines = traceback.format_exception(exc_type, exc_value, |
""" |
239 |
exc_traceback) |
|
240 |
message = "An unhandled exception occurred:\n%s\n" % exc_value+\ |
if self.in_exception_dialog: |
241 |
"(please report to " \ |
return |
242 |
"http://thuban.intevation.org/bugtracker.html)"\ |
self.in_exception_dialog = 1 |
243 |
"\n\n\n"+\ |
while wxIsBusy(): |
244 |
"".join(lines) |
wxEndBusyCursor() # reset the mouse cursor |
245 |
print message |
|
246 |
|
try: |
247 |
# We don't use an explicit parent here because this method might |
lines = traceback.format_exception(exc_type, exc_value, |
248 |
# be called in circumstances where the main window doesn't exist |
exc_traceback) |
249 |
# anymore. |
message = "An unhandled exception occurred:\n%s\n" % exc_value+\ |
250 |
dlg = wxScrolledMessageDialog(None, message, |
"(please report to " \ |
251 |
"Thuban: Internal Error") |
"http://thuban.intevation.org/bugtracker.html)"\ |
252 |
dlg.ShowModal() |
"\n\n\n"+\ |
253 |
dlg.Destroy() |
"".join(lines) |
254 |
|
print message |
255 |
finally: |
|
256 |
in_exception_dialog = 0 |
# We don't use an explicit parent here because this method might |
257 |
# delete the last exception info that python keeps in |
# be called in circumstances where the main window doesn't exist |
258 |
# sys.last_* because especially last_traceback keeps |
# anymore. |
259 |
# indirect references to all objects bound to local |
dlg = wxScrolledMessageDialog(None, message, |
260 |
# variables and this might prevent some object from being |
"Thuban: Internal Error") |
261 |
# collected early enough. |
dlg.ShowModal() |
262 |
sys.last_type = sys.last_value = sys.last_traceback = None |
dlg.Destroy() |
263 |
|
|
264 |
|
finally: |
265 |
|
self.in_exception_dialog = 0 |
266 |
|
# delete the last exception info that python keeps in |
267 |
|
# sys.last_* because especially last_traceback keeps |
268 |
|
# indirect references to all objects bound to local |
269 |
|
# variables and this might prevent some object from being |
270 |
|
# collected early enough. |
271 |
|
sys.last_type = sys.last_value = sys.last_traceback = None |
272 |
|
|