/[thuban]/branches/WIP-pyshapelib-bramz/Thuban/UI/application.py
ViewVC logotype

Contents of /branches/WIP-pyshapelib-bramz/Thuban/UI/application.py

Parent Directory Parent Directory | Revision Log Revision Log


Revision 765 - (show annotations)
Tue Apr 29 12:42:14 2003 UTC (21 years, 10 months ago) by bh
Original Path: trunk/thuban/Thuban/UI/application.py
File MIME type: text/x-python
File size: 6940 byte(s)
Next step of table implementation. Introduce a transient database
using SQLite that some of the data is copied to on demand. This
allows us to do joins and other operations that require an index
for good performance with reasonable efficiency. Thuban now needs
SQLite 2.8.0 and pysqlite 0.4.1. Older versions may work but I
haven't tested that.

* Thuban/Model/transientdb.py: New. Transient database
implementation.

* test/test_transientdb.py: New. Tests for the transient DB
classes.

* Thuban/Model/session.py (AutoRemoveFile, AutoRemoveDir): New
classes to help automatically remove temporary files and
directories.
(Session.__init__): New instance variables temp_dir for the
temporary directory and transient_db for the SQLite database
(Session.temp_directory): New. Create a temporary directory if not
yet done and return its name. Use AutoRemoveDir to have it
automatically deleted
(Session.TransientDB): Instantiate the transient database if not
done yet and return it.

* Thuban/Model/data.py (ShapefileStore.__init__): Use an
AutoTransientTable so that data is copied to the transient DB on
demand.
(SimpleStore): New class that simply combines a table and a
shapefile

* Thuban/Model/table.py (Table, DBFTable): Rename Table into
DBFTable and update its doc-string to reflect the fact that this
is only the table interface to a DBF file. Table is now an alias
for DBFTable for temporary backwards compatibility.

* Thuban/UI/application.py (ThubanApplication.OnExit): Make sure
the last reference to the session goes away so that the temporary
files are removed properly.

* test/test_load.py (LoadSessionTest.tearDown): Remove the
reference to the session to make sure the temporary files are
removed.

1 # Copyright (C) 2001, 2002, 2003 by Intevation GmbH
2 # Authors:
3 # Jan-Oliver Wagner <[email protected]>
4 # Bernhard Herzog <[email protected]>
5 #
6 # This program is free software under the GPL (>=v2)
7 # Read the file COPYING coming with Thuban for details.
8
9 """
10 Thuban's application object.
11 """
12
13 __version__ = "$Revision$"
14
15 import sys, os
16 import traceback
17
18 from wxPython.wx import *
19
20 from Thuban.Lib.connector import Publisher
21
22 from Thuban import _
23 from Thuban.Model.session import create_empty_session
24 from Thuban.Model.save import save_session
25 from Thuban.Model.load import load_session
26 from Thuban.Model.messages import MAPS_CHANGED
27
28 import view
29 import tree
30 import mainwindow
31
32 from messages import SESSION_REPLACED
33
34
35
36 class ThubanApplication(wxApp, Publisher):
37
38 """
39 Thuban's application class.
40
41 All wxWindows programs have to have an instance of an application
42 class derived from wxApp. In Thuban the application class holds
43 references to the main window and the session.
44 """
45
46 def OnInit(self):
47 self.splash = self.splash_screen()
48 if self.splash is not None:
49 self.splash.Show()
50 self.read_startup_files()
51 self.top = self.CreateMainWindow()
52 self.SetTopWindow(self.top)
53 if self.splash is None:
54 self.ShowMainWindow()
55 self.session = None
56 self.create_session()
57 return True
58
59 def OnExit(self):
60 """Clean up code.
61
62 Extend this in derived classes if needed.
63 """
64 self.session.Destroy()
65 self.session = None
66 Publisher.Destroy(self)
67
68 def read_startup_files(self):
69 """Read the startup files."""
70 # for now the startup file is ~/.thuban/thubanstart.py
71 dir =os.path.expanduser("~/.thuban")
72 if os.path.isdir(dir):
73 sys.path.append(dir)
74 try:
75 import thubanstart
76 except ImportError:
77 tb = sys.exc_info()[2]
78 try:
79 if tb.tb_next is not None:
80 # The ImportError exception was raised from
81 # inside the thubanstart module.
82 sys.stderr.write(_("Cannot import the thubanstart"
83 " module\n"))
84 traceback.print_exc(None, sys.stderr)
85 else:
86 # There's no thubanstart module.
87 sys.stderr.write(_("No thubanstart module available\n"))
88 finally:
89 # make sure we delete the traceback object,
90 # otherwise there's be circular references involving
91 # the current stack frame
92 del tb
93 except:
94 sys.stderr.write(_("Cannot import the thubanstart module\n"))
95 traceback.print_exc(None, sys.stderr)
96 else:
97 # There's no .thuban directory
98 sys.stderr.write(_("No ~/.thuban directory\n"))
99
100 def splash_screen(self):
101 """Create and return a splash screen.
102
103 This method is called by OnInit to determine whether the
104 application should have a splashscreen. If the application
105 should display a splash screen override this method in a derived
106 class and have it create and return the wxSplashScreen instance.
107 The implementation of this method in the derived class should
108 also arranged for ShowMainWindow to be called.
109
110 The default implementation simply returns None so that no splash
111 screen is shown and ShowMainWindow will be called automatically.
112 """
113 return None
114
115 def ShowMainWindow(self):
116 """Show the main window
117
118 Normally this method is automatically called by OnInit to show
119 the main window. However, if the splash_screen method has
120 returned a splashscreen it is expected that the derived class
121 also arranges for ShowMainWindow to be called at the appropriate
122 time.
123 """
124 self.top.Show(True)
125
126 def CreateMainWindow(self):
127 """Create and return the main window for the application.
128
129 Override this in subclasses to instantiate the Thuban mainwindow
130 with different parameters or to use a different class for the
131 main window.
132 """
133 msg = (_("This is the wxPython-based Graphical User Interface"
134 " for exploring geographic data"))
135 return mainwindow.MainWindow(NULL, -1, "Thuban", self, None,
136 initial_message = msg)
137
138 def Session(self):
139 """Return the application's session object"""
140 return self.session
141
142 def SetSession(self, session):
143 """Make session the new session.
144
145 Issue SESSION_REPLACED after self.session has become the new
146 session. After the session has been assigned call
147 self.subscribe_session() with the new session and
148 self.unsubscribe_session with the old one.
149 """
150 oldsession = self.session
151 self.session = session
152 self.subscribe_session(self.session)
153 self.issue(SESSION_REPLACED)
154 self.maps_changed()
155 if oldsession is not None:
156 self.unsubscribe_session(oldsession)
157 oldsession.Destroy()
158
159 def subscribe_session(self, session):
160 """Subscribe to some of the sessions channels.
161
162 Extend this method in derived classes if you need additional
163 channels.
164 """
165 session.Subscribe(MAPS_CHANGED, self.maps_changed)
166
167 def unsubscribe_session(self, session):
168 """Unsubscribe from the sessions channels.
169
170 Extend this method in derived classes if you subscribed to
171 additional channels in subscribe_session().
172 """
173 session.Unsubscribe(MAPS_CHANGED, self.maps_changed)
174
175 def create_session(self):
176 """Create a default session.
177
178 Override this method in derived classes to instantiate the
179 session differently or to use a different session class. Don't
180 subscribe to channels here yet. Do that in the
181 subscribe_session() method.
182 """
183 self.SetSession(create_empty_session())
184
185 def OpenSession(self, filename):
186 """Open the session in the file named filename"""
187 # Make sure we deal with an absolute pathname. Otherwise we can
188 # get problems when saving because the saving code expects an
189 # absolute directory name
190 filename = os.path.abspath(filename)
191 session = load_session(filename)
192 session.SetFilename(filename)
193 session.UnsetModified()
194 self.SetSession(session)
195
196 def SaveSession(self):
197 save_session(self.session, self.session.filename)
198
199 def maps_changed(self, *args):
200 if self.session.HasMaps():
201 self.top.SetMap(self.session.Maps()[0])
202 else:
203 self.top.SetMap(None)

Properties

Name Value
svn:eol-style native
svn:keywords Author Date Id Revision

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26