/[thuban]/branches/greater-ms3/thuban/ChangeLog
ViewVC logotype

Diff of /branches/greater-ms3/thuban/ChangeLog

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 721 by jonathan, Thu Apr 24 10:11:55 2003 UTC revision 889 by jonathan, Fri May 9 16:41:52 2003 UTC
# Line 1  Line 1 
1    2003-05-09  Jonathan Coles   <[email protected]>
2    
3            Introduces Range class from SciParam into the ClassGroupRange class,
4            and such ranges can now be saved and loaded from disk.
5    
6            Quantiles are now available in the Classification Generator.
7    
8            Initial support for building Queries on a table. Doesn't do anything
9            but run some tests.
10    
11            * Thuban/Model/classification.py: Explicit imports.
12            (ClassGroupRange): Use the Range class to store the underlying
13            range information. The interface remains the same, except for
14            GetRange(), and you can also supply a Range object as the min
15            parameter to SetRange or __init__.
16    
17            * Thuban/Model/load.py (XMLReader.encode): New. Encodes the given
18            string appropriately for use in Thuban. Fixes RTbug #1851.
19            (SessionLoader.end_projection): Handle the context of the
20            projection tag a bit better by looking at what objects are not
21            None. There was an assumption that a projection tag for a map
22            could occur before any layers.
23            (SessionLoader.start_clrange): Provide backward compatibility for
24            reading min/max values as well as the new range parameter.
25    
26            * Thuban/Model/map.py: Explicit imports.
27    
28            * Thuban/Model/resource.py: Import _.
29            (ProjFileSaver.write): write header using projfile.dtd.
30    
31            * Thuban/Model/save.py: Explicit imports.
32            (XMLWriter.encode): New. Encode the given string from a format
33            used by Thuban into UTF-8. Fixes RTbug #1851.
34    
35            * Thuban/UI/classgen.py: Explicit imports.
36            (ClassGenDialog.__init__): Clean up the code and add support
37            for Quantiles.
38            (ClassGenDialog.OnOK): Add support for Quantiles.
39            (GenQuantilesPanel): New. Input panel for Quantiles.
40            (ClassGenerator, CustomRamp, MonochromaticRamp, GreyRamp, RedRamp,
41            GreenRamp, BlueRamp, HotToColdRamp): Move to Thuban/Model/classgen.py
42    
43            * Thuban/Model/classgen.py: New. Contains all the classes named above.
44    
45            * Thuban/UI/classifier.py: Explicit imports.
46            (ClassTable.GetValueAsCust, ClassTable.__ParseInput,
47            ClassTable.SetValueAsCustom): Reworked to use new Range class.
48    
49            * Thuban/UI/legend.py: Explicit imports.
50    
51            * Thuban/UI/mainwindow.py: Add support for the Join Dialog. Added
52            a Table menu and associated method calls.
53            (MainWindow.choose_color): Removed. No longer needed.
54    
55            * Thuban/UI/projdialog.py (ProjFrame.__VerifyButtons): Save button
56            should be disabled if no projection is selected in the available
57            list.
58    
59            * Thuban/UI/renderer.py: Explicit imports.
60    
61            * Thuban/UI/tableview.py (TableGrid.OnRangeSelect): Fix some issues
62            with correctly selecting the rows and issuing the right events.
63            Be sure to call Skip() to allow the grid to do some of its own
64            handling which allows the rows to actually be selected.
65            (LayerTableGrid.select_shapes): Rename from select_shape. Supports
66            selecting multiple shapes.
67            (LayerTableFrame): Support for building Queries.
68            (LayerTableFrame.select_shapes): Allow multiple shapes to be selected.
69    
70            * Thuban/UI/tree.py: Explicit imports.
71    
72            * Thuban/UI/view.py (MapCanvas): Delegate "SelectedShapes" so the
73            table view can call it.
74    
75            * test/test_classification.py: Explicit imports.
76            (TestClassification.test_ClassGroupRange): Fix test for new
77            Range class.
78    
79            * Doc/thuban.dtd: Add range parameter for clrange.
80    
81            * Thuban/Model/range.py: Taken from SciParam. Used as the underlying
82            object in ClassGroupRange, and also uesd for inputting ranges in
83            the classifer table and elsewhere.
84    
85            * Thuban/UI/join.py: New. Initial Join dialog. No real functionality
86            yet.
87    
88    2003-05-09  Frank Koormann <[email protected]>
89    
90            * Thuban/UI/scalebar.py (DrawScaleBar): Draw only if interval > 0.0.
91    
92    2003-05-08  Frank Koormann <[email protected]>
93    
94            Coding style updates
95    
96            * test/test_scalebar.py: Replaced tab indentation by spaces.
97    
98            * Thuban/UI/scalebar.py: Explicit imports.
99    
100    2003-05-08  Frank Koormann <[email protected]>
101    
102            * Thuban/UI/scalebar.py
103            (ScaleBar.DrawScalebar): Format string bug fixed.
104    
105    2003-05-08  Frank Koormann <[email protected]>
106    
107            Reorganization of scalebar component (no wx in Thuban/Model)
108    
109            * Thuban/Model/scalebar.py: Rendering moved to Thuban/UI/scalebar.py
110            (deriveInterval):
111            Calculate scalebar interval and unit which fits in width for scale.
112            (roundInterval): Round float.
113    
114            * Thuban/UI/scalebar.py (ScaleBar): Scalebar rendering
115    
116            * test/test_scalebar.py: Test for Thuban/Model/scalebar.py methods.
117    
118            * Thuban/UI/legend.py: Import Thuban.UI.scalebar
119    
120    2003-05-08  Frank Koormann <[email protected]>
121    
122            * Thuban/UI/legend.py (ScalebarBitmap.SetCanvas):
123            Initialize ScaleBar with canvas.map
124    
125            * Thuban/Model/scalebar.py (ScaleBar.roundInterval()): New,
126            round intervals to display smarter lengths
127            (ScaleBar.DrawScalebar): Draw Scalebar only if the map contains a
128            layer. If the maps has no projection applied grey the scalebar.
129    
130    2003-05-07  Frank Koormann <[email protected]>
131            
132            Basic Scalebar features added.
133    
134            * Thuban/Model/scalebar.py (ScaleBar): New, scalebar rendering.
135    
136            * Thuban/UI/legend.py (LegendPanel): Added scalebar bitmap
137            (ScaleBarBitmap): New, links the scalebar bitmap with view messages
138            and the renderer.
139    
140            * Thuban/UI/view.py (MapCanvas.set_view_transform): Issue SCALE_CHANGED.
141    
142            * Thuban/UI/messages.py: SCALE_CHANGED added.
143    
144    2003-05-07  Bernhard Herzog  <[email protected]>
145    
146            * Thuban/Model/session.py (Session.__init__): New instance
147            variable shapestores to hold a list of all open shapestore objects
148            (Session.ShapeStores): New. Accessor method for the shapestores
149            list.
150            (Session._add_shapestore, Session._clean_weak_store_refs): New.
151            Internal methods to maintain the shapestores list.
152            (Session.Tables): New. Return all tables open in the session.
153            (Session.OpenShapefile): Insert the new ShapeStore into the
154            shapestores list.
155    
156            * test/test_session.py (TestSessionSimple.test_initial_state): Add
157            tests for ShapeStores and Tables
158            (TestSessionWithContent.test_shape_stores)
159            (TestSessionWithContent.test_tables): New. Test cases for
160            ShapeStores and Tables
161    
162    2003-05-07  Bernhard Herzog  <[email protected]>
163    
164            * Thuban/Model/transientdb.py (TransientTableBase.ReadRowAsDict):
165            Add comments about the optimizations used.
166            (AutoTransientTable.ReadValue, TransientTableBase.ReadValue): New.
167            Implement the ReadValue table interface method.
168    
169            * test/test_transientdb.py
170            (TestTransientTable.run_iceland_political_tests)
171            (TestTransientTable.test_transient_joined_table): Add tests for
172            ReadValue
173    
174    2003-05-07  Frank Koormann <[email protected]>
175    
176            * Resources/Bitmaps/fulllayerextent.xpm,
177            Resources/Bitmaps/fullselextent.xpm: Replaced the place holders with
178            new icons.
179    
180    2003-05-06  Bernhard Herzog  <[email protected]>
181    
182            * Thuban/Model/transientdb.py (AutoTransientTable.SimpleQuery):
183            New. Simply delegate to the transient table's version.
184    
185            * test/test_transientdb.py
186            (TestTransientTable.test_auto_transient_table_query): New. Test
187            case for AutoTransientTable's SimpleQuery
188    
189    2003-05-06  Bernhard Herzog  <[email protected]>
190    
191            * Thuban/Model/transientdb.py (TransientTableBase.SimpleQuery):
192            Implement a simple query method for the query dialog
193            (TransientTableBase.create): Add an INTEGER PRIMARY KEY that holds
194            the row index or shapeid.
195            (TransientTable.create): Insert the right value of the row index
196            (TransientJoinedTable.create): Copy the row index of the left
197            table to the joined result table
198    
199            * test/test_transientdb.py
200            (TestTransientTable.test_transient_table_read_twice): Fix
201            doc-string
202            (TestTransientTable.test_transient_table_query): New. Test for the
203            SimpleQuery method
204    
205    2003-05-06  Bernhard Herzog  <[email protected]>
206    
207            Convert all table users to use the new table interface. This only
208            covers Thuban itself, not GREAT-ER or other applications built on
209            Thuban yet, so the compatibility interface stays in place for the
210            time being but it now issues DeprecationWarnings.
211    
212            Finally, the new Table interface has a new method, HasColumn.
213    
214            * Thuban/Model/table.py (OldTableInterfaceMixin): All methods
215            issue deprecation warnings when they're. The warnings refer to the
216            caller of the method.
217            (OldTableInterfaceMixin.__deprecation_warning): New. Helper method
218            for the deprecation warnings
219    
220            * test/test_table.py: Ignore the deprecation warnings for the old
221            table in the tests in this module. The purpose of the tests is to
222            test the old interface, after all.
223    
224            * test/test_transientdb.py
225            (TestTransientTable.run_iceland_political_tests): Use the
226            constants for the types. Add a test for HasColumn
227            (TestTransientTable.test_transient_joined_table): Adapt to new
228            table interface. Add a test for HasColumn
229            (TestTransientTable.test_transient_table_read_twice): Adapt to new
230            table interface
231    
232            * Thuban/UI/tableview.py (DataTable.SetTable, DataTable.GetValue):
233            Adapt to new table interface
234    
235            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Adapt to
236            new table interface
237    
238            * Thuban/UI/controls.py (RecordListCtrl.fill_list)
239            (RecordTable.SetTable): Adapt to new table interface
240    
241            * Thuban/UI/classifier.py (Classifier.__init__)
242            (Classifier.__init__): Adapt to new table interface
243    
244            * Thuban/UI/classgen.py (ClassGenDialog.__init__)
245            (GenUniformPanel._OnRetrieve, GenUniquePanel._OnRetrieve): Adapt
246            to new table interface
247    
248            * Thuban/Model/transientdb.py (TransientTableBase.HasColumn)
249            (AutoTransientTable.HasColumn): Implement the new table interface
250            method
251            (AutoTransientTable.ReadRowAsDict, AutoTransientTable.ValueRange)
252            (AutoTransientTable.UniqueValues): Adapt to new table interface
253    
254            * Thuban/Model/layer.py (Layer.SetShapeStore, Layer.GetFieldType):
255            Adapt to new table interface
256    
257            * test/test_layer.py (TestLayer.open_shapefile): Helper method to
258            simplify opening shapefiles a bit easier.
259            (TestLayer.test_arc_layer, TestLayer.test_polygon_layer)
260            (TestLayer.test_point_layer): Use the new helper method
261            (TestLayer.test_get_field_type): New. Test for the GetFieldType
262            method
263    
264            * test/test_dbf_table.py (TestDBFTable.test_has_column): Test for
265            the new table method
266    
267            * test/test_memory_table.py (TestMemoryTable.test_has_column):
268            Test for the new table method HasColumn
269    
270    2003-05-06  Jonathan Coles   <[email protected]>
271    
272            Addresses the "Selection Extent" wish of RTbug #1787.
273    
274            * Resources/Bitmaps/fulllayerextent.xpm,
275            Resources/Bitmaps/fullselextent.xpm: Bitmaps for layer and selection
276            extent. These are just place holders for the real bitmaps.
277    
278            * Thuban/Model/layer.py (Shape): Since a Shape is immutable only
279            calculate the bounding box once (the first time compute_bbox() is
280            called).
281            (Layer.ShapesBoundingBox): New. Given a list of shape ids, return
282            the bounding box for the shapes in lat/long coordinates.
283    
284            * Thuban/UI/mainwindow.py: Added new "Full selection extent" menu
285            option.
286            (MainWindow.has_selected_shapes): New. Returns true if there are
287            any selected shapes.
288            (MainWindow.FullSelectionExtent): New. Calls
289            MapCanvas.FitSelectedToWindow() when the user selects the menu option.
290            (_has_selected_shapes): New. Returns true if there are any
291            selected shapes.
292    
293            * Thuban/UI/selection.py (Selection.HasSelectedShapes): New. Returns
294            true if there are any selected shapes.
295    
296            * Thuban/UI/view.py (MapCanvas): Added delegated method
297            HasSelectedShapes.
298            (MapCanvas.FitSelectedToWindow): New. Centers and scales any selected
299            shapes on the canvas using the map projection (if any).
300    
301            * test/test_layer.py (TestLayer.test_arc_layer): Add some tests
302            for Layer.ShapesBoundingBox().
303    
304    2003-05-06  Bernhard Herzog  <[email protected]>
305    
306            * Resources/Projections/defaults.proj: Fix spelling of Mercator
307    
308    2003-05-05  Jonathan Coles   <[email protected]>
309    
310            Addresses the "Full Layer Extent" wish of RTbug #1787.
311    
312            * Resources/Projections/defaults.proj: Added UK National Grid.
313    
314            * Thuban/UI/mainwindow.py: Added new "Full layer extent" menu option.
315            (MainWindow.FullLayerExtent): New. Calls MapCanvas.FitLayerToWindow()
316            when the user selects the menu option.
317    
318            * Thuban/UI/view.py (MapCanvas.FitLayerToWindow): New. Centers and
319            scales the given layer on the canvas using the map projection.
320    
321    2003-05-05  Bernhard Herzog  <[email protected]>
322    
323            Convert the table implementations to a new table interface. All
324            tables use a common mixin class to provide backwards compatibility
325            until all table users have been updated.
326    
327            * Thuban/Model/table.py (OldTableInterfaceMixin): Mixin class to
328            provide backwards compatibility for table classes implementing the
329            new interface
330            (DBFTable, MemoryTable): Implement the new table interface. Use
331            OldTableInterfaceMixin as base for compatibility
332            (DBFColumn, MemoryColumn): New. Column description for DBFTable
333            and MemoryTable resp.
334    
335            * test/test_dbf_table.py: New. Test cases for the DBFTable with
336            the new table interface.
337    
338            * test/test_memory_table.py: New. Test cases for the MemoryTable
339            with the new table interface.
340    
341            * test/test_table.py: Document the all tests in this file as only
342            for backwards compatibility. The equivalent tests for the new
343            interface are in test_memory_table.py and test_dbf_table.py
344            (MemoryTableTest.test_read): field_info should be returning tuples
345            with four items
346            (MemoryTableTest.test_write): Make doc-string a more precise.
347    
348            * Thuban/Model/transientdb.py (TransientTableBase): Convert to new
349            table interface. Derive from from OldTableInterfaceMixin for
350            compatibility.
351            (TransientTableBase.create): New intance variable column_map to
352            map from names and indices to column objects
353            (TransientTable.create): Use the new table interface of the input
354            table
355            (AutoTransientTable): Convert to new table interface. Derive from
356            from OldTableInterfaceMixin for compatibility.
357            (AutoTransientTable.write_record): Removed. It's not implemented
358            yet and we still have to decide how to handle writing with the new
359            table and data framework.
360    
361            * test/test_transientdb.py
362            (TestTransientTable.run_iceland_political_tests)
363            (TestTransientTable.test_transient_joined_table): Use the new
364            table interface
365    
366    2003-05-05  Jonathan Coles   <[email protected]>
367    
368            This is namely a collection of UI updates to improve user interactivity.
369            Tabbing between controls now exists and you can use ESC to close dialog
370            boxes; ENTER will active the default button.
371    
372            * Thuban/UI/classgen.py (ClassGenDialog.__init__): Rearrange the
373            order that the controls are created so that tabbing works correctly.
374            (ClassGenDialog.OnOK): Renamed from _OnGenerate() so that the
375            wxDialog can handle the default button correctly.
376            (ClassGenDialog.OnCancel): Renamed from _OnCloseBtn() for the
377            same reasons as for OnOK.
378            (GenUniformPanel._OnRetrieve): Call wxBeginBusyCursor/wxEndBusyCursor
379            when we ask the table for the maximum/minimum values of a field
380            which could take a very long time.
381    
382            * Thuban/UI/classifier.py (Classifier.__init__): Rearrange the
383            order that the controls are created so that tabbing works correctly.
384            (SelectPropertiesDialog.__init__): Rearrange the order that the
385            controls are created so that tabbing works correctly.
386    
387            * Thuban/UI/dialogs.py: Copied NonModalDialog box and changed it
388            to derive from a wxDialog but behave like the original implementation
389            which was derived from a wxFrame. wxDialog provides useful key
390            handling functionality like ESC calling OnCancel and ENTER calling
391            OnOK which is lost with wxFrame.
392    
393            * Thuban/UI/mainwindow.py: Add "..." to menu items that will open
394            new dialogs.
395    
396            * Thuban/UI/projdialog.py (ProjFrame.__init__): Rearrange the
397            order that the controls are created so that tabbing works correctly.
398            (ProjFrame.OnApply): Renamed from _OnTry() to use wxDialog behaviour.
399            (ProjFrame.OnOK): Renamed from _OnOK() to use wxDialog behaviour.
400            (ProjFrame.OnCancel): Renamed from _OnClose() to use wxDialog behaviour.
401            (ProjPanel.__init__): Add "Airy" to the list of ellipsoids so we
402            can provide the "UK National Grid" as a default projection.
403            (UTMPanel.__init__): Rearrange the order that the controls are
404            created so that tabbing works correctly.
405    
406    2003-05-05  Bernhard Herzog  <[email protected]>
407    
408            * extensions/thuban/wxproj.cpp: Fix some of the comments.
409            (project_point): If a map projection but no layer projection is
410            given, convert degrees to radians before applying the map
411            projection.
412    
413            * Thuban/UI/tableview.py (TableGrid.disallow_messages)
414            (TableGrid.allow_messages): New methods to make it possible to
415            inhibit message sending.
416            (TableGrid.issue): Only send the message if not inhibited.
417            (LayerTableGrid.select_shape): Use the new methods to make sure
418            that no ROW_SELECTED message is sent while we're updating the
419            selected rows to match the selected shapes.
420    
421    2003-05-02  Jan-Oliver Wagner <[email protected]>
422    
423            Implementation of MemoryTable.
424    
425            * Thuban/Model/table.py (MemoryTable): New. Quite simple table
426            implementation that operates on a list of tuples. All of the data
427            are kept in the memory.
428    
429            * test/test_table.py (MemoryTableTest): New.
430    
431            * test/test_transientdb.py (SimpleTable): Removed.
432            (TestTransientTable.test_transient_joined_table,
433            (TestTransientTable.test_transient_table_read_twice): Replaced
434            SimpleTable by MemoryTable.
435    
436    2003-04-30  Jonathan Coles   <[email protected]>
437    
438            * Data/iceland_sample.thuban: Now contains correct projections
439            for each of the layers.
440    
441            * Resources/Projections/defaults.proj: Geographic projection
442            contains unit conversion parameter.
443    
444    2003-04-30  Jonathan Coles   <[email protected]>
445    
446            The most important part of this putback is the projection changes.
447            It should now be possible to specify the projection that a layer
448            is in and then specify a different projection for the map. The
449            projection dialog has an extra parameter for a geographic projection
450            which lets the user select if the input is in degrees or radians.
451    
452            * Thuban/Model/layer.py (Layer.ShapesInRegion): Fix docstring
453            to say that the parameter is a tuple of unprojected
454            points (which is what the callers to this method were assuming).
455            Also, since the points are unprojected we need to projected them.
456    
457            * Thuban/UI/legend.py (LegendTree.MoveCurrentItemUp,
458            LegendTree.MoveCurrentItemDown): If the layer or any of the layer's
459            groups are selected, move the layer up/down. Fixes RTbug #1833.
460    
461            * Thuban/UI/mainwindow.py: Move menu item map_rename up.
462    
463            * Thuban/UI/projdialog.py (ProjFrame._OnSave): Add missing
464            parameter in call to SetClientData.
465            (GeoPanel): Add support for selecting the units that the
466            source data is in (Radians or Degrees).
467    
468            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Optimize
469            the rendering loop by reducing the number of if's, removing the
470            unnecessary try/except block, and checking if the old group
471            is the same as the new one (which happens a lot if there is
472            no classification, or lots of shapes are in the same group).
473    
474            * Thuban/UI/view.py (MapCanvas.OnPaint): Add a try/except block
475            around the redraw routine to try to catch problems that the user
476            may create by selecting invalid projections for the data set and
477            map. Clears the display if there are any problems and prints the
478            error.
479            (MapCanvas.do_redraw): Use DC.Clear() instead of drawing a filled
480            rectangle.
481    
482            * extensions/thuban/wxproj.cpp (project_point): First invert the
483            supplied point (which should be in projected coordinates) using
484            the layer's projection and then project the point using the
485            map's projection.
486            (project_points): Use project_point() to project each point.
487    
488    2003-04-30  Jan-Oliver Wagner <[email protected]>
489    
490            * Thuban/Model/layer.py (Layer.SetShapeStore): Fixed a bug:
491            don't set the Classification to None if the classfication field
492            is None (ie only a DEFAULT).
493    
494    2003-04-30  Bernhard Herzog  <[email protected]>
495    
496            * Thuban/UI/view.py: Fix some typos.
497    
498            * Thuban/UI/mainwindow.py (MainWindow.identify_view_on_demand): Do
499            not pop up the dialog if the selection becomes empty (this could
500            happen if e.g. a new selection is opened while the identify tool
501            is active and dialog had been closed)
502    
503    2003-04-30  Bernhard Herzog  <[email protected]>
504    
505            * Thuban/Model/transientdb.py (TransientTableBase.__init__): New
506            instance variable read_record_last_result
507            (TransientTableBase.read_record): Make sure reading the same
508            record twice works. The implementation uses the new instance
509            variable read_record_last_result
510    
511            * test/test_transientdb.py
512            (TestTransientTable.test_transient_table_read_twice): New test
513            case for the above bug-fix.
514    
515    2003-04-29  Jonathan Coles   <[email protected]>
516    
517            * Thuban/common.py: Removed. No longer needed Str2Num. RTbug #1832.
518    
519            * Thuban/UI/classgen.py: Remove all uses of Str2Num.
520    
521            * Thuban/UI/classifier.py: Remove all uses of Str2Num.
522            (ClassTable.SetValueAsCustom): Rename keyword argument in
523            ClassGroup* constructors to match argument name.
524    
525    2003-04-29  Bernhard Herzog  <[email protected]>
526    
527            * Thuban/Model/session.py (Session.Destroy): Explicitly close the
528            transient DB if it exists to make sure it doesn't leave a journal
529            file in the temp directory.
530    
531            * Thuban/Model/transientdb.py (TransientDatabase.close): Set
532            self.conn to None after closing the connection to make sure it's
533            not closed twice
534    
535    2003-04-29  Jonathan Coles   <[email protected]>
536    
537            Add a visible parameter in the layer XML tag. The default value is
538            "true". If anything other than "false" is specified we also assume
539            "true". Addresses RTbug #1025.
540    
541            * Doc/thuban.dtd: Add visible parameter to a layer.
542    
543            * Thuban/Model/layer.py (BaseLayer.__init__): Change default value
544            of visible from 1 to True.
545            (Layer.__init__): Change default value of visible from 1 to True.
546    
547            * Thuban/Model/load.py (SessionLoader.start_layer): Read visible
548            parameter.
549    
550            * Thuban/Model/save.py (SessionSaver.write_layer): Save visible
551            parameter.
552    
553            * test/test_load.py: Add new test data contents_test_visible.
554            (LoadSessionTest.setUp): save test data.
555            (LoadSessionTest.testLayerVisibility): Test if the visible flag
556            is loaded correctly.
557    
558            * test/test_save.py (SaveSessionTest.testSingleLayer): Add test
559            for saving an invisible layer.
560    
561    2003-04-29  Jonathan Coles   <[email protected]>
562    
563            * Thuban/UI/mainwindow.py (MainWindow.SetMap): Look up the
564            legend dialog box and tell it to change its map to the one
565            supplied to SetMap(). Fixes RTbug #1770.
566    
567    2003-04-29  Bernhard Herzog  <[email protected]>
568    
569            Next step of table implementation. Introduce a transient database
570            using SQLite that some of the data is copied to on demand. This
571            allows us to do joins and other operations that require an index
572            for good performance with reasonable efficiency. Thuban now needs
573            SQLite 2.8.0 and pysqlite 0.4.1. Older versions may work but I
574            haven't tested that.
575            
576            * Thuban/Model/transientdb.py: New. Transient database
577            implementation.
578    
579            * test/test_transientdb.py: New. Tests for the transient DB
580            classes.
581    
582            * Thuban/Model/session.py (AutoRemoveFile, AutoRemoveDir): New
583            classes to help automatically remove temporary files and
584            directories.
585            (Session.__init__): New instance variables temp_dir for the
586            temporary directory and transient_db for the SQLite database
587            (Session.temp_directory): New. Create a temporary directory if not
588            yet done and return its name. Use AutoRemoveDir to have it
589            automatically deleted
590            (Session.TransientDB): Instantiate the transient database if not
591            done yet and return it.
592    
593            * Thuban/Model/data.py (ShapefileStore.__init__): Use an
594            AutoTransientTable so that data is copied to the transient DB on
595            demand.
596            (SimpleStore): New class that simply combines a table and a
597            shapefile
598    
599            * Thuban/Model/table.py (Table, DBFTable): Rename Table into
600            DBFTable and update its doc-string to reflect the fact that this
601            is only the table interface to a DBF file. Table is now an alias
602            for DBFTable for temporary backwards compatibility.
603    
604            * Thuban/UI/application.py (ThubanApplication.OnExit): Make sure
605            the last reference to the session goes away so that the temporary
606            files are removed properly.
607    
608            * test/test_load.py (LoadSessionTest.tearDown): Remove the
609            reference to the session to make sure the temporary files are
610            removed.
611    
612    2003-04-29  Bernhard Herzog  <[email protected]>
613    
614            * Thuban/Model/load.py (XMLReader.__init__, XMLReader.read): Turn
615            the __parser instance variable into a normal local variable in
616            read. It's only used there and read will never be called more than
617            once. Plus it introduces a reference cycle that keeps can keep the
618            session object alive for a long time.
619    
620    2003-04-29  Jonathan Coles   <[email protected]>
621    
622            * Thuban/Model/proj.py (Projection): Removed Set*() methods to make
623            Projection an immutable item. Fixes RTbug #1825.
624            (Projection.__init__): Initialize instance variables here.
625            (ProjFile.Replace): New. Replace the given projection object with
626            the new projection object. This solves the problem of needing the
627            mutator Projection.SetProjection() in the ProjFrame class and
628            allows a projection to change parameters without changing its
629            location in the file.
630    
631            * Thuban/UI/mainwindow.py (MainWindow.SaveSessionAs): Dialog should
632            be of type wxSAVE and should verify overwriting a file.
633    
634            * Thuban/UI/projdialog.py (ProjFrame._OnSave): Use the new
635            ProjFile.Replace() method instead of the mutator
636            Projection.SetProjection(). Also requires that we reassign the
637            client data to the new projection.
638    
639            * test/test_proj.py (TestProjection.test): Test GetName() and
640            GetAllParameters()
641            (TestProjFile.test): Remove tests for Set*() methods. Add tests
642            for Replace().
643    
644    2003-04-25  Jonathan Coles   <[email protected]>
645    
646            * Thuban/Model/save.py (SessionSaver.write_projection): Make sure
647            to save the name of the projection.
648    
649            * test/test_save.py (SaveSessionTest.testLayerProjection): New
650            test to verify layer projections are saved correctly.
651    
652    2003-04-25  Jonathan Coles   <[email protected]>
653    
654            * Thuban/Model/proj.py (Projection.SetName): Set the name
655            to "Unknown" if name is None.
656            (Projection.SetAllParameters): New. Set the projection's
657            parameter list to the one supplied.
658            (Projection.SetProjection): New. Set the projection's
659            properties to those of the supplied Projection.
660    
661            * Thuban/UI/mainwindow.py (MainWindow.MapProjection): Set
662            the dialog title to include the map's title.
663            (MainWindow.LayerProjection): Set the dialog title to include
664            the layer's title.
665    
666            * Thuban/UI/projdialog.py (ProjFrame.__ShowError): Consolidate
667            error dialogs into a single method call.
668            (ProjFrame.__VerifyButtons): Add more states to check.
669            (ProjFrame.__GetProjection): Return the current state of an
670            edited projection or None.
671            (ProjFrame.__FillAvailList): Remove checks for states that
672            shouldn't exist.
673            (ProjFrame._OnNew): Clear all selected items and supply
674            a projection panel if necessary.
675    
676            * test/test_proj.py (TestProjFile.test): Add tests for
677            ProjFile.SetAllParameters, ProjFile.SetProjection,
678            ProjFile.SetName.
679    
680    2003-04-25  Jonathan Coles   <[email protected]>
681    
682            * Thuban/UI/projdialog.py (ProjFrame.__FillAvailList): Now
683            takes an optional argument to select the current projection.
684            This does not guarantee that the item is visible due to
685            limited wxWindows functionality. Fixes RTBug #1821.
686    
687    2003-04-25  Jonathan Coles   <[email protected]>
688    
689            * Thuban/Model/load.py (SessionLoader.start_projection): Remember
690            the projection name and use it when constructing the Projection
691            object.
692    
693            * Thuban/Model/proj.py (Projection.__init__): Change the default
694            value for 'name' to None and then test if name is equal to None
695            in the body of the constructor. This way the caller doesn't have to
696            know what the default value should be. Namely, useful in load.py
697            where we have to pick a default value if the 'name' parameter
698            doesn't exist in the XML file.
699    
700            * test/test_load.py (LoadSessionTest.testLayerProjection): New.
701            Tests a file where a layer has a projection.
702    
703    2003-04-25  Jonathan Coles   <[email protected]>
704    
705            * Thuban/Model/layer.py (Layer.TreeInfo): Add an item to the
706            tree for projection information.
707    
708            * Thuban/Model/load.py (XMLReader.GetFilename): Renamed from
709            XMLReader.GetFileName.
710            (SessionLoader): Added support for loading projection tags that
711            appear inside a layer.
712    
713            * Thuban/Model/proj.py (ProjFile): Document the class. Move
714            back to using a list because the order of the projections in
715            the file is important to maintain. Fixes RTbug #1817.
716    
717            * Thuban/Model/resource.py: Rename calls to ProjFile.GetFileName
718            to ProjFile.GetFilename.
719    
720            * Thuban/Model/save.py (SessionSaver.write_layer): Save projection
721            information.
722    
723            * Thuban/UI/projdialog.py (ProjFrame._OnAddToList): Renamed from
724            ProjFrame._OnSaveAs. Removed old dead code from previous
725            implementation.
726            (ProjFrame._OnExport): Add support for exporting more than one
727            projection to a single file.
728            (ProjFrame.__FillAvailList): use string formatting (% operator)
729            to build strings that are (partly) translated. Fixes RTbug #1818.
730    
731            * test/test_proj.py (TestProjFile.test): New. Tests the base ProjFile
732            class.
733    
734    2003-04-24  Bernhard Herzog  <[email protected]>
735    
736            * po/es.po: Updated Spanish translation by Daniel Calvelo Aros
737    
738            * po/fr.po: New. French translation by Daniel Calvelo Aros
739    
740            * Thuban/UI/projdialog.py (ProjFrame._OnSaveAs): Don't translate
741            empty strings.
742    
743    2003-04-24  Jonathan Coles   <[email protected]>
744    
745            * Thuban/Model/layer.py (Layer.GetProjection): New. Needed to
746            implement the interface that the ProjFrame dialog expects.
747    
748            * Thuban/Model/proj.py (Projection.SetName): New. Allows the
749            name of the projection to be changed.
750            (ProjFile): Use a dictionary instead of a list so that removing
751            projections is easier and we are sure about uniqueness.
752            (ProjFile.Remove): Remove the given projection object.
753    
754            * Thuban/Model/resource.py (GetSystemProjFiles, GetUserProjFiles):
755            Return a list with only one projection file instead of searching for
756            any projection file. This simplifies many things if the user can
757            only have one system file and one user file.
758    
759            * Thuban/UI/classgen.py: Change all references to
760            genCombo to genChoice.
761    
762            * Thuban/UI/mainwindow.py: Add a Projection option under the
763            layer menu.
764            (MainWindow.LayerProjection): New. Open up a projection window
765            for a layer.
766    
767            * Thuban/UI/projdialog.py: Large changes to how the dialog is
768            laid out. Use three panels instead of one. One for the list of
769            projections, one for the edit controls, and one for the buttons.
770            Fixed resizing problems so that the dialog resizes correctly
771            when the projection panel changes. Added import/export, save, and
772            new buttons/functionality.
773    
774    2003-04-24  Bernhard Herzog  <[email protected]>
775    
776            First step towards table management. Introduce a simple data
777            abstraction so that we replace the data a layer uses more easily
778            in the next step.
779    
780            * Thuban/Model/data.py: New file with a simple data abstraction
781            that bundles shapefile and dbffile into one object.
782    
783            * Thuban/Model/session.py (Session.OpenShapefile): New method to
784            open shapefiles and return a shape store object
785    
786            * Thuban/Model/layer.py (Layer.__init__): Pass the data as a store
787            object instead of a shapefile filename. This introduces a new
788            instance variable store holding the datastore. For intermediate
789            backwards compatibility keep the old instance variables.
790            (open_shapefile): Removed. No longer needed with the shape store.
791            (Layer.SetShapeStore, Layer.ShapeStore): New methods to set and
792            get the shape store used by a layer.
793            (Layer.Destroy): No need to explicitly destroy the shapefile or
794            table anymore.
795    
796            * Thuban/UI/mainwindow.py (MainWindow.AddLayer)
797            (MainWindow.AddLayer): Use the session's OpenShapefile method to
798            open shapefiles
799    
800            * Thuban/Model/load.py (ProcessSession.start_layer): Use the
801            session's OpenShapefile method to open shapefiles
802    
803            * test/test_classification.py
804            (TestClassification.test_classification): Use the session's
805            OpenShapefile method to open shapefiles and build the filename in
806            a more platform independed way
807    
808            * test/test_layer.py (TestLayer.setUp, TestLayer.tearDown):
809            Implement to have a session to use in the tests
810            (TestLayer.test_arc_layer, TestLayer.test_polygon_layer)
811            (TestLayer.test_point_layer, TestLayer.test_empty_layer): Use the
812            session's OpenShapefile method to open shapefiles
813            (TestLayerLegend.setUp): Instantiate a session so that we can use
814            it to open shapefiles.
815            (TestLayerLegend.tearDown): Make sure that all references to
816            layers and session are removed otherwise we may get a resource
817            leak
818    
819            * test/test_map.py (TestMapAddLayer.test_add_layer)
820            (TestMapWithContents.setUp): Instantiate a session so that we can
821            use it to open shapefiles.
822            (TestMapWithContents.tearDown): Make sure that all references to
823            layers, maps and sessions are removed otherwise we may get a
824            resource leak
825            ("__main__"): use support.run_tests() so that more info about
826            uncollected garbage is printed
827    
828            * test/test_save.py (SaveSessionTest.testSingleLayer): Use the
829            session's OpenShapefile method to open shapefiles
830            ("__main__"): use support.run_tests() so that more info about
831            uncollected garbage is printed
832    
833            * test/test_selection.py (TestSelection.tearDown): Make sure that
834            all references to the session and the selection are removed
835            otherwise we may get a resource leak
836            (TestSelection.get_layer): Instantiate a session so that we can
837            use it to open shapefiles.
838            ("__main__"): use support.run_tests() so that more info about
839            uncollected garbage is printed
840    
841            * test/test_session.py (TestSessionBase.tearDown)
842            (TestSessionWithContent.tearDown): Make sure that all references
843            to the session and layers are removed otherwise we may get a
844            resource leak
845            (TestSessionWithContent.setUp): Use the session's OpenShapefile
846            method to open shapefiles
847    
848  2003-04-24  Jonathan Coles   <[email protected]>  2003-04-24  Jonathan Coles   <[email protected]>
849    
850          * Thuban/Model/load.py (XMLReader.read): Should have been checking          * Thuban/Model/load.py (XMLReader.read): Should have been checking

Legend:
Removed from v.721  
changed lines
  Added in v.889

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26