14 |
|
|
15 |
import sys, os |
import sys, os |
16 |
import os.path |
import os.path |
|
from tempfile import mktemp |
|
17 |
|
|
18 |
import traceback |
import traceback |
19 |
|
|
20 |
from wxPython.wx import * |
from wxPython.wx import * |
21 |
|
from wxPython.lib.dialogs import wxScrolledMessageDialog |
22 |
|
|
23 |
from Thuban.Lib.connector import Publisher |
from Thuban.Lib.connector import Publisher |
24 |
|
from Thuban.Lib.fileutil import get_application_dir |
25 |
|
|
26 |
from Thuban import _ |
from Thuban import _ |
27 |
from Thuban.Model.session import create_empty_session |
from Thuban.Model.session import create_empty_session |
28 |
from Thuban.Model.save import save_session |
from Thuban.Model.save import save_session |
29 |
from Thuban.Model.load import load_session |
from Thuban.Model.load import load_session |
30 |
from Thuban.Model.messages import MAPS_CHANGED |
from Thuban.Model.messages import MAPS_CHANGED |
31 |
|
from Thuban.Model.layer import RasterLayer |
32 |
|
import Thuban.Model.resource |
33 |
|
|
34 |
import view |
import view |
35 |
import tree |
import tree |
74 |
def read_startup_files(self): |
def read_startup_files(self): |
75 |
"""Read the startup files.""" |
"""Read the startup files.""" |
76 |
# for now the startup file is ~/.thuban/thubanstart.py |
# for now the startup file is ~/.thuban/thubanstart.py |
77 |
if os.name == 'nt': |
dir = get_application_dir() |
|
# This should result in something like the user directory ... |
|
|
guess = os.path.dirname(os.path.dirname(os.path.dirname(mktemp()))) |
|
|
dir = os.path.join(guess, ".thuban") |
|
|
if not os.path.isdir(dir): |
|
|
os.mkdir(dir) |
|
|
else: |
|
|
dir =os.path.expanduser("~/.thuban") |
|
78 |
if os.path.isdir(dir): |
if os.path.isdir(dir): |
79 |
sys.path.append(dir) |
sys.path.append(dir) |
80 |
try: |
try: |
200 |
session.UnsetModified() |
session.UnsetModified() |
201 |
self.SetSession(session) |
self.SetSession(session) |
202 |
|
|
203 |
|
for map in session.Maps(): |
204 |
|
for layer in map.Layers(): |
205 |
|
if isinstance(layer, RasterLayer) \ |
206 |
|
and not Thuban.Model.resource.has_gdal_support(): |
207 |
|
msg = _("The current session contains Image layers,\n" + |
208 |
|
"but the GDAL library is not available to " + |
209 |
|
"draw them.") |
210 |
|
dlg = wx.wxMessageDialog(None, |
211 |
|
msg, |
212 |
|
_("Library not available"), |
213 |
|
wx.wxOK | wx.wxICON_INFORMATION) |
214 |
|
print msg |
215 |
|
dlg.ShowModal() |
216 |
|
dlg.Destroy() |
217 |
|
break |
218 |
|
|
219 |
def SaveSession(self): |
def SaveSession(self): |
220 |
save_session(self.session, self.session.filename) |
save_session(self.session, self.session.filename) |
221 |
|
|
224 |
self.top.SetMap(self.session.Maps()[0]) |
self.top.SetMap(self.session.Maps()[0]) |
225 |
else: |
else: |
226 |
self.top.SetMap(None) |
self.top.SetMap(None) |
227 |
|
|
228 |
|
in_exception_dialog = 0 # flag: are we already inside the exception dialog? |
229 |
|
|
230 |
|
def ShowExceptionDialog(self, exc_type, exc_value, exc_traceback): |
231 |
|
"""Show a message box with information about an exception. |
232 |
|
|
233 |
|
The parameters are the usual values describing an exception in |
234 |
|
Python, the exception type, the value and the traceback. |
235 |
|
|
236 |
|
This method can be used as a value for the sys.excepthook. |
237 |
|
""" |
238 |
|
if self.in_exception_dialog: |
239 |
|
return |
240 |
|
self.in_exception_dialog = 1 |
241 |
|
while wxIsBusy(): |
242 |
|
wxEndBusyCursor() # reset the mouse cursor |
243 |
|
|
244 |
|
try: |
245 |
|
lines = traceback.format_exception(exc_type, exc_value, |
246 |
|
exc_traceback) |
247 |
|
message = "An unhandled exception occurred:\n%s\n" % exc_value+\ |
248 |
|
"(please report to " \ |
249 |
|
"http://thuban.intevation.org/bugtracker.html)"\ |
250 |
|
"\n\n\n"+\ |
251 |
|
"".join(lines) |
252 |
|
print message |
253 |
|
|
254 |
|
# We don't use an explicit parent here because this method might |
255 |
|
# be called in circumstances where the main window doesn't exist |
256 |
|
# anymore. |
257 |
|
dlg = wxScrolledMessageDialog(None, message, |
258 |
|
"Thuban: Internal Error") |
259 |
|
dlg.ShowModal() |
260 |
|
dlg.Destroy() |
261 |
|
|
262 |
|
finally: |
263 |
|
self.in_exception_dialog = 0 |
264 |
|
# delete the last exception info that python keeps in |
265 |
|
# sys.last_* because especially last_traceback keeps |
266 |
|
# indirect references to all objects bound to local |
267 |
|
# variables and this might prevent some object from being |
268 |
|
# collected early enough. |
269 |
|
sys.last_type = sys.last_value = sys.last_traceback = None |
270 |
|
|