/[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 396 by jonathan, Mon Feb 10 15:28:17 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]>
849    
850            * Thuban/Model/load.py (XMLReader.read): Should have been checking
851            if the file_or_filename object had the 'read' attribute.
852    
853    2003-04-23  Jonathan Coles   <[email protected]>
854    
855            * Thuban/Model/resource.py: Fixes RTbug #1813.
856            (ReadProjFile): Add documentation about which exceptions are raised.
857            Always pass the exceptions up to the caller.
858            (GetProjFiles): If the directory can't be read return an empty list.
859            If any of the proj files can't be read skip that file and go
860            on to the next one.
861    
862            * test/test_proj.py: Added test cases to handle nonexistent files,
863            unreadable files, and files that don't parse correctly.
864    
865    2003-04-23  Jonathan Coles   <[email protected]>
866    
867            Projection dialog. Allows the user to select from a list
868            of projection templates and optionally edit them and save new ones.
869    
870            * Thuban/UI/projdialog.py (ProjFrame): New. Main dialog.
871            (ProjPanel): Base class for projection specific panels.
872            (TMPanel): Projection panel for Transverse Mercartor.
873            (UTMPanel): Projection panel for Universal Transverse Mercartor.
874            (LCCPanel): Projection panel for Lambert Conic Conformal.
875            (GeoPanel): Projetion panel for Geographic Projection.
876    
877    2003-04-23  Jonathan Coles   <[email protected]>
878    
879            * Thuban/Model/load.py (XMLReader): Renamed from XMLProcessor to
880            promote symmetry. There now exists XMLReader and XMLWriter.
881            (XMLReader.read): New. Call to read the given file descriptor or
882            filename.
883            (XMLReader.close): New. Make sure the file is closed.
884            (XMLReader.GetFileName): New. Return just the file name that is being
885            read from.
886            (XMLReader.GetDirectory): New. Return just the directory of the file
887            that is being read.
888            (XMLReader.AddDispatchers): New. Take a dictionary which contains
889            the names of functions to call as the XML tree is parsed.
890            (XMLReader.startElementNS): Updated to use new dispatcher dictionary.
891            (XMLReader.endElementNS): Updated to use new dispatcher dictionary.
892            (SessionLoader): Removed class variables start_dispatcher and
893            end_dispatcher since this functionality is now part of a class
894            instance. Fixes RTbug #1808.
895            (SessionLoader.__init__): Add dispatcher functions.
896            (load_xmlfile): Code was moved into the XMLReader.read().
897            (load_session): Use modified SessionLoader.
898    
899            * Thuban/Model/map.py (Map.GetProjection): New. Returns the
900            map's projection.
901    
902            * Thuban/Model/proj.py (Projection.GetParameters): Renamed to
903            GetAllParameters.
904            (Projection.GetParameter): Returns the value for the given parameter.
905    
906            * Thuban/Model/resource.py: Use XMLReader and XMLWriter.
907            (GetProjFiles): Renamed from GetProjections. Now returns a list
908            of ProjFile objects.
909            (GetSystemProjFiles): Renamed from GetSuppliedProjections. Returns
910            a list of ProjFile objects whose files are not user defined.
911            (GetUserProjFiles): Renamed from GetUserProjections. Returns a
912            list of ProjFile objects whose files are user defined.
913            (ProjFileReader): Extend new XMLReader.
914    
915            * Thuban/Model/save.py (XMLWriter): Renamed from XMLSaver to
916            promote symmetry.
917    
918            * Thuban/UI/classgen.py (ClassGenDialog.__init__): Use a wxChoice
919            control instead of a wxComboBox. wxChoice controls do not generate
920            events as the uses highlights possible choices which fixes problems
921            with resizing the dialog when the use selects an option.
922    
923            * Thuban/UI/classifier.py (Classifier.__init__): Use a wxChoice
924            control instead of a wxComboBox.
925    
926            * Thuban/UI/mainwindow.py (MainWindow.Projection): Use new projection
927            dialog.
928    
929            * test/test_proj.py (TestProjection.test): New tests for GetParameter
930            method.
931    
932    2003-04-22  Bernhard Herzog  <[email protected]>
933    
934            * Thuban/UI/mainwindow.py: Remove some unused imports and global
935            constants
936    
937            * Thuban/UI/identifyview.py (IdentifyListCtrl.selected_shape)
938            (IdentifyGridCtrl.selected_shape): Use table, not shapetable.
939    
940    2003-04-17  Bernhard Herzog  <[email protected]>
941    
942            * Thuban/Model/layer.py: Don't import LAYER_LEGEND_CHANGED.
943            (Layer): Update doc-string since LAYER_LEGEND_CHANGED is not used
944            anymore.
945            (Layer.BoundingBox, Layer.GetFieldType, Layer.NumShapes)
946            (Layer.ShapeType, Layer.Shape): No need to call
947            self.open_shapefile since it's always called in __init__
948    
949            * Thuban/UI/application.py (ThubanApplication.MainLoop): Removed.
950            In wxPython 2.4 there's no need to extend MainLoop anymore since
951            wxPython itself makes sure OnExit is called.
952    
953    2003-04-16  Jonathan Coles   <[email protected]>
954    
955            Initial putback of projection management code. Includes new
956            classes to read and write projection files. The current load
957            and save classes were abstracted a bit so they could be reused.
958            The Projection class was extended to provide new methods and
959            have a name.
960    
961            * Thuban/Model/load.py (XMLProcessor): New. Contains all the
962            general XML reading methods that were part of ProcessSession.
963    
964            * Thuban/Model/proj.py (Projection.__init__): Accepts an optional
965            name.
966            (ProjFile): New. Represents a file that contains projection
967            information.
968    
969            * Thuban/Model/resource.py: New. Contains general utilities
970            for read and writing projection files.
971    
972            * Thuban/Model/save.py (XMLSaver): New. Contains all the
973            general XML writing methods that were part of SessionSaver.
974            (SessionSaver): Renamed from Saver.
975    
976            * test/test_proj.py: New test cases for the projection
977            file read and write functions.
978    
979    2003-04-16  Jonathan Coles   <[email protected]>
980    
981            * Thuban/Model/classification.py: Use repr() around values
982            in the ClassGroup*.__repr__() methods so it is clearer when
983            a value is a string and when it is a number.
984    
985            * test/test_load.py: Rework the classification test to test
986            that we can load old files.
987            (testLabels): Test a file where the groups have labels.
988    
989    2003-04-16  Bernhard Herzog  <[email protected]>
990    
991            Safer implementation of the performance enhancements of the
992            low-level renderer:
993            
994            * extensions/thuban/wxproj.cpp (extract_projection)
995            (extract_pointer): Rename extract_projection to extract_pointer
996            and redefine its purpose to return the pointer stored in a CObject
997            returned by the object's cobject method. Update all callers.
998            (s_draw_info, free_draw_info, draw_polygon_init): Implement the
999            handling of these low-level parameters so that each s_draw_info
1000            instance is handled as a CObject at python level that also
1001            contains real references to the actual python objects which
1002            contain the values in the struct. Add free_draw_info as the
1003            destructor.
1004            (draw_polygon_shape): Add the py_draw_info parameter which must a
1005            cobject containing an s_draw_info pointer.
1006    
1007            * Thuban/UI/renderer.py (MapRenderer.polygon_render_param): New
1008            method to instantiat the low-level render parameter
1009            (MapRenderer.draw_shape_layer): Use the new method. Remove some
1010            commented out code.
1011            (MapRenderer.draw_polygon_shape): Make the first parameter not the
1012            layer but the low-level render parameter
1013            (ScreenRenderer.draw_shape_layer): Use the low-level render
1014            parameter.
1015    
1016    2003-04-15  Jonathan Coles   <[email protected]>
1017    
1018            * Thuban/Model/classification.py: Implemented __repr__ for
1019            the ClassGroup* classes to make debugging a bit easier.
1020            (ClassGroup.SetLabel): Check that the string is an instance
1021            of StringTypes not StringType. Accounts for Unicode strings.
1022    
1023            * Thuban/Model/color.py: Implemented __repr__ to make
1024            debugging a bit easier.
1025    
1026            * Thuban/Model/save.py (Saver.write_classification): Need to
1027            save the group label.
1028    
1029            * test/test_load.py (testClassification): New. Loads the
1030            iceland_sample_test.thuban file and checks if it was loaded
1031            correctly.
1032    
1033    2003-04-15  Jonathan Coles   <[email protected]>
1034    
1035            * extensions/thuban/wxproj.cpp (draw_polygon_init): New. Used
1036            to improve rendering performance by initializing the variables
1037            that are not change each time draw_polygon_shape() is called.
1038            The values are stored in a global struct draw_info.
1039            (draw_polygon_shape): Removed initialization code that is
1040            now in draw_polygon_init().
1041    
1042            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Make
1043            drawing initialization call to draw_polygon_init()
1044            (MapRenderer.draw_polygon_shape): Use new signature of
1045            draw_polygon_shape.
1046    
1047            * Thuban/UI/classgen.py (GenUniformPanel): Fix spin control
1048            weirdness by setting the range to (1, maxint).
1049    
1050            * Thuban/Model/classification.py (ClassGroupProperties): Make
1051            instance variables private and optimize comparison operator
1052            by first checking if the color references are the same.
1053            (ClassGroupSingleton): Make instance variables private.
1054            (ClassGroupRange): Make instance variables private.
1055    
1056            * HOWTO-Release: Filled in missing steps for releasing packages.
1057    
1058    2003-04-15  Bernhard Herzog  <[email protected]>
1059    
1060            First stab at internationalized messages:
1061    
1062            * Thuban/__init__.py (_): Implement the translation function for
1063            real using the python gettext module.
1064    
1065            * Thuban/UI/classifier.py (ClassTable.GetRowLabelValue): Don't
1066            translate empty strings.
1067    
1068            * Thuban/UI/application.py (ThubanApplication.read_startup_files):
1069            Add a missing space to a warning message
1070    
1071            * po/README: New. Notes about the management of the translation
1072            files.
1073    
1074            * po/Makefile: New. Makefile to help manage the translation files.
1075    
1076            * po/es.po: New. Spanish translation by Daniel Calvelo Aros
1077    
1078            * MANIFEST.in: Include the *.mo files in Resources/Locale and the
1079            translations and support files in po/
1080    
1081            * setup.py (data_files): Add the *.mo files to the data_files too
1082    
1083            * README: Add note about the translations when building from CVS
1084    
1085    2003-04-14  Jonathan Coles   <[email protected]>
1086    
1087            * Thuban/UI/dock.py: Fixes some window resizing problems most
1088            noticable under windows. Always assume the button bitmaps will
1089            be there. Code clean up.
1090            (DockabelWindow.Dock, DockableWindow.UnDock): Force all the
1091            images for the dock/undock button to the same images.
1092            Work around for RTbug #1801.
1093    
1094            * Thuban/UI/legend.py (LegendPanel.__init__): The toolbar should
1095            be allowed to grow within the sizer. Fixes a bug under Windows
1096            where the toolbar wasn't being drawn.
1097    
1098    2003-04-14  Frank Koormann   <[email protected]>
1099    
1100            * Resources/Bitmaps/dock_12.xpm, Resources/Bitmaps/undock_12.xpm:
1101            Updated design to try to make the button functionality more
1102            transparent.
1103    
1104    2003-04-14  Jonathan Coles   <[email protected]>
1105    
1106            * Thuban/UI/legend.py (LegendPanel.__init__): Call Create() to
1107            finalize the intialization of the panel.
1108    
1109            * Thuban/UI/dock.py (DockPanel.Create): New. Finalizes the
1110            creation of the panel. Should be the last thing called in the
1111            initializer of a subclass.
1112    
1113            * Thuban/UI/classgen.py (ClassGenDialog.__init__): Actively
1114            set the current selections in the combo boxes. This is needed
1115            under Windows.
1116    
1117            * Thuban/UI/classifier.py (Classifier.__init__): Add a top
1118            level panel to the dialog so that the background colors are
1119            consistent under Windows.
1120    
1121    2003-04-11  Jonathan Coles   <[email protected]>
1122    
1123            * Thuban/UI/classgen.py: Change color ramps to start at white
1124            not black.
1125    
1126            * Thuban/UI/legend.py: Enable/disable the legend buttons when
1127            the legend changes. Fixes RTbug #1793.
1128    
1129            * test/test_classification.py: Added test for copying of
1130            classifications.
1131    
1132    2003-04-11  Jonathan Coles   <[email protected]>
1133    
1134            * Thuban/UI/resource.py: New. Centralize the loading of resources
1135            such as bitmaps.
1136    
1137            * Thuban/UI/classgen.py (GenUniquePanel.__init__): Reordered buttons,
1138            added images to the move buttons, added 'reverse' button.
1139            (CustomRampPanel.__init__): Added images to the move buttons.
1140            (GreyRamp): New. Generates a ramp from white to black.
1141            (HotToColdRamp): New. Generates a ramp from cold to hot colors.
1142    
1143            * Thuban/UI/classifier.py: Refactored ID's from ID_CLASSIFY_* to
1144            ID_PROPERTY_*.
1145            (Classifier.__init__): Minor changes to the layout.
1146            (Classifier._OnTitleChanged): Listen for when the user edits the
1147            title and update the dialog's title and the layer's title.
1148    
1149            * Thuban/UI/dock.py: Use new bitmaps for the control buttons.
1150    
1151            * Thuban/UI/legend.py: Use new bitmaps for the control buttons.
1152            (LegendTree._OnMsgLayerTitleChanged): Change the displayed title
1153            if the layer's title changes.
1154    
1155            * Thuban/UI/mainwindow.py: Added new menu item and associated code
1156            to open a dialog to rename the map.
1157            (MainWindow): Use new resource class to import bitmaps.
1158    
1159    2003-04-11  Jonathan Coles   <[email protected]>
1160    
1161            * Resources/Bitmaps/close_12.xpm, Resources/Bitmaps/dock_12.xpm,
1162            Resources/Bitmaps/group_use.xpm, Resources/Bitmaps/group_use_all.xpm,
1163            Resources/Bitmaps/group_use_none.xpm,
1164            Resources/Bitmaps/group_use_not.xpm,
1165            Resources/Bitmaps/hide_layer.xpm,
1166            Resources/Bitmaps/layer_properties.xpm,
1167            Resources/Bitmaps/lower_layer.xpm, Resources/Bitmaps/raise_layer.xpm,
1168            Resources/Bitmaps/show_layer.xpm, Resources/Bitmaps/undock_12.xpm:
1169            New.
1170    
1171    2003-04-10  Jonathan Coles   <[email protected]>
1172    
1173            * Thuban/Model/classification.py: (ClassGroupRange.__init__):
1174            Should pass group to ClassGroup constructor.
1175    
1176    2003-04-10  Jonathan Coles   <[email protected]>
1177    
1178            * Thuban/Model/classification.py: (ClassGroup): Move all the common
1179            methods of the derived classes ([Set|Get]Properties(), __eq__, __ne__)
1180            here. Implement SetVisible(), IsVisible().
1181            (ClassGroup.__init__): Add group parameter which acts as a copy
1182            constructor.
1183    
1184            * Thuban/UI/classifier.py (ClassTable): Add a new column for the
1185            "Visible" check boxes.
1186            (Classifier): Rename the buttons and refactor the code to match
1187            the new labels.
1188    
1189            * Thuban/UI/legend.py: Classify button is now called "Properties".
1190            Refactored the code to change variable names.
1191            (LegendTree.__FillTreeLayer): Only list a group if it is visible.
1192    
1193            * Thuban/UI/mainwindow.py: MainWindow.OpenClassifier renamed to
1194            MainWindow.OpenLayerProperties. MainWindow.LayerEditProperties
1195            renamed to MainWindow.LayerEditProperties.
1196            (MainWindow.ToggleLegend): Don't include map name in legend title.
1197            (MainWindow.SetMap): Added the map name to the window title.
1198            (MainWindow.LayerFillColor, MainWindow.LayerTransparentFill,
1199            MainWindow.LayerOutlineColor, MainWindow.LayerNoOutline): Removed.
1200            Functionality is found in the layer properties dialog.
1201    
1202            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Only
1203            draw visible groups.
1204    
1205    2003-04-09  Jonathan Coles   <[email protected]>
1206    
1207            * Thuban/UI/classgen.py: Modifications to allow simple
1208            addition and selection of new color schemes.
1209            (MonochromaticRamp): New. Generates a ramp between two colors.
1210            (RedRamp): New. Generates a ramp of all red.
1211            (GreenRamp): New. Generates a ramp of all green.
1212            (BlueRamp): New. Generates a ramp of all blue.
1213    
1214    2003-04-09  Jonathan Coles   <[email protected]>
1215    
1216            * Thuban/Model/classification.py (Classification.__deepcopy__):
1217            Need to copy over field and fieldType attributes.
1218    
1219            * Thuban/Model/table.py (Table.field_range): New. Retrive the
1220            maximum and minimum values over the entire table for a given
1221            field.
1222            (Table.GetUniqueValues): New. Retrieve all the unique values
1223            in the table for a given field.
1224    
1225            * Thuban/UI/classgen.py: Renamed GenRangePanel to GenUniformPanel.
1226            (GenUniquePanel): New. Controls to allow the user to select
1227            which unique field values they would like in the classification.
1228            (CustomRampPanel): Code that was in ClassGenDialog that allows
1229            the user to select the properties for a custom ramp.
1230            (ClassGenerator.GenUniformDistribution): Was called GenerateRanges.
1231    
1232            * Thuban/UI/classifier.py: Removed a lot of debugging code.
1233            (Classifier._SetClassification): Callback method so that the
1234            class generator can set the classification in the grid.
1235            (ClassGroupPropertiesCtrl): New. Encapsulates the drawing and
1236            editing of a group properties class into a wxWindows control.
1237    
1238            * Thuban/UI/dock.py: It was decided that if the user closes
1239            a dockable window the window should simply hide itself. That
1240            way if the user wants to show the dock again it appears in the
1241            same place as it was when it was closed.
1242            (DockableWindow.Destroy): Call renamed method OnDockDestroy().
1243            (DockableWindow._OnButtonClose): Hide the window instead of
1244            destroying it.
1245            (DockableWindow._OnClose): Hide the window instead of
1246            destroying it.
1247    
1248            * Thuban/UI/legend.py (LegendTree): Use a private method to
1249            consistently set the font and style of the text. Fixes RTbug #1786.
1250    
1251            * Thuban/UI/mainwindow.py: Import just the Classifier class.
1252    
1253    2003-04-07  Bernhard Herzog  <[email protected]>
1254    
1255            * Thuban/UI/mainwindow.py (main_menu): Move the toggle_legend item
1256            to the map module
1257    
1258    2003-04-07  Bernhard Herzog  <[email protected]>
1259    
1260            * Thuban/UI/mainwindow.py (MainWindow.ShowSessionTree): Removed in
1261            favor of ToggleSessionTree
1262            (MainWindow.ToggleSessionTree): New method to toggle visibility of
1263            the session tree.
1264            (MainWindow.SessionTreeShown): New method to return whether the
1265            session tree is currently shown.
1266            (MainWindow.ToggleLegend): New method to toggle visibility of the
1267            legend
1268            (MainWindow.ShowLegend): Implement in terms of ToggleLegend and
1269            LegendShown
1270            (MainWindow.LegendShown): New method to return whether the legend
1271            is currently shown.
1272            (_method_command): Add checked parameter so we can define check
1273            menu items
1274            (_has_tree_window_shown, _has_legend_shown): Use the appropriate
1275            mainwindow methods.
1276            (show_session_tree, show_legend commands): Removed.
1277            (toggle_session_tree, toggle_legend commands): New commands to
1278            toggle the visibility of the dialogs
1279    
1280    2003-04-07  Jonathan Coles   <[email protected]>
1281    
1282            * Thuban/UI/classgen.py: Fix Windows problem.
1283    
1284            * Thuban/UI/dock.py: Fix Windows problem.
1285    
1286            * Thuban/UI/mainwindow.py: Use False instead of false.
1287            (MainWindow.ShowLegend): Remove unnecessary switch parameter.
1288    
1289    2003-04-07  Jonathan Coles   <[email protected]>
1290    
1291            Since we now say that the order of the groups in a classification
1292            matters, it makes sense to be able to manipulate that order. Most
1293            of the changes to Thuban/Model/classification.py are to that end.
1294    
1295            * Thuban/Model/classification.py (Classification.AppendGroup,
1296            Classification.InsertGroup, Classification.ReplaceGroup,
1297            Classification.RemoveGroup, Classification.GetGroup): Do as the
1298            names imply.
1299            (Classification.FindGroup): This was called GetGroup, but GetGroup
1300            takes an index, while FindGroup takes a value.
1301            (Classification.__deepcopy__): Copy all the groups, BUT NOT THE LAYER
1302            REFERENCE. Currently there is a cyclic reference between the layer
1303            and its classification. If the classification doesn't need to know
1304            its owning layer we can change this, since it may make sense to be
1305            able to use the same classification with different layers.
1306    
1307            * Thuban/Model/load.py: Use Classification.AppendGroup(), not AddGroup()
1308    
1309            * Thuban/UI/classgen.py: Use Classification.AppendGroup(),
1310            not AddGroup()
1311    
1312            * Thuban/UI/classifier.py: Now that we can depend on the order in
1313            a Classification and have methods to manipulate that order we don't
1314            need to use our own data structures in the grid. We can simply make
1315            the grid/table access the information they need from a copy of
1316            the classification object.
1317            (Classifier._OnCloseBtn): Event handler for when the user clicks
1318            'Close'. This is needed so if the user applies changes and then
1319            continues to change the table the user has the option of discarding
1320            the most recent changes and keeping what they applied.
1321    
1322            * Thuban/UI/mainwindow.py: Put "Show Legend" and "Show Session Tree"
1323            into the same group.
1324    
1325            * extensions/thuban/wxproj.cpp (check_version): If Thuban is compiled
1326            with a really old version of proj, PJ_VERSION won't even be defined.
1327            If it isn't defined then just compile so that the function always
1328            returns Py_False.
1329    
1330            * test/test_classification.py: Fix tests to use the renamed methods.
1331            Still need to write tests for the new methods.
1332    
1333    2003-04-04  Jonathan Coles   <[email protected]>
1334    
1335            * Thuban/UI/classifier.py (Classifier.__SelectField): Move the
1336            call to SetSelection out of the method and before the call
1337            to __SelectField in __init__. This prevents a recursion of events
1338            when _OnFieldSelect is triggered by the user.
1339    
1340    2003-04-04  Jonathan Coles   <[email protected]>
1341    
1342            * Thuban/Model/classification.py: Rename Color.None to
1343            Color.Transparent.
1344            (ClassGroupProperties.SetLineColori, ClassGroupProperties.SetFill):
1345            Don't bother copying the color, since Colors are immutable.
1346    
1347            * Thuban/Model/color.py, Thuban/Model/layer.py, Thuban/Model/load.py,
1348            Thuban/UI/classifier.py, Thuban/UI/mainwindow.py,
1349            Thuban/UI/renderer.py, Thuban/UI/view.py:
1350            Rename Color.None to Color.Transparent.
1351        
1352            * test/test_classification.py, test/test_load.py: Rename Color.None
1353            to Color.Transparent.
1354    
1355    2003-04-04  Jonathan Coles   <[email protected]>
1356    
1357            * Thuban/Model/classification.py: Fix assert calls.
1358            (ClassGroupProperties.SetLineColor, ClassGroupProperties.SetFill):
1359            Copy the color parameter rather than hold onto a reference.
1360    
1361            * Thuban/Model/color.py (Color.__copy__, Color.__deepcopy): Copy
1362            the color object.
1363            (NoColor.__copy__, NoColor.__deepcopy): Return 'self' so that we
1364            are sure there exists only one refernce to Color.None in the system.
1365            This allows us to use 'is' rather than the comparision functions.
1366            
1367            * Thuban/Model/save.py: Fix assert calls.
1368            
1369            * Thuban/UI/classifier.py: Fix assert calls.
1370            (ClassGrid._OnCellDClick): Call up to the classifier to open the
1371            dialog to edit the groups properties.
1372            (ClassGrid._OnCellResize): Make sure that the scollbars are drawn
1373            correctly if a cell is resized.
1374            (ClassTable.SetClassification): New. Changes the classification
1375            that is in the table.
1376            (ClassTable.__SetRow): Allow groups to be prepended.
1377            (Classifier): New code for opening the EditProperties and
1378            GenerateRanges dialogs.
1379            (SelectPropertiesDialog.__GetColor): Only set the color in the
1380            color dialog if the current color is not None.
1381            
1382            * Thuban/UI/dock.py: Fix assert calls.
1383            
1384            * Thuban/UI/legend.py: Fix assert calls.
1385            
1386            * Thuban/UI/renderer.py: Fix assert calls.
1387            
1388            * Thuban/UI/classgen.py (ClassGenDialog): Dialog for generating
1389            classifications.
1390            (GenRangePanel): Panel specific to range generation.
1391            (GenSingletonPanel): Panel specific to singleton generation.
1392            (ClassGenerator): Class responsible for actually generating
1393            the classification from the data gathered in the dialog box.
1394            (PropertyRamp): Generates properties whose values range from
1395            a starting property to an ending property.
1396    
1397    2003-04-03  Bernhard Herzog  <[email protected]>
1398    
1399            * test/support.py (print_garbage_information): New function that
1400            prints information about still connected messages and memory
1401            leaks.
1402            (run_suite): Removed.
1403            (run_tests): New function for use as a replacement of
1404            unittest.main in the test_* files. This one calls
1405            print_garbage_information at the end.
1406    
1407            * test/runtests.py (main): Use support.print_garbage_information
1408    
1409            * test/test_layer.py: Use support.run_tests instead of
1410            unittest.main so we get memory leak information
1411            (TestLayer.test_arc_layer, TestLayer.test_polygon_layer)
1412            (TestLayer.test_point_layer, TestLayer.test_empty_layer)
1413            (TestLayerLegend.test_visibility): Call the layer's Destroy method
1414            to fix a memory leak.
1415    
1416            * test/test_classification.py: Use support.run_tests instead of
1417            unittest.main so we get memory leak information
1418            (TestClassification.test_classification): Call the layer's Destroy
1419            method to fix a memory leak.
1420    
1421    2003-04-02  Bernhard Herzog  <[email protected]>
1422    
1423            * extensions/thuban/wxproj.cpp (check_version, check_version_gtk):
1424            Handle the reference counts of the return value and errors in
1425            PyArg_ParseTuple correctly.
1426    
1427            * Thuban/UI/application.py (ThubanApplication.OpenSession): Make
1428            sure the filename is absolute to avoid problems when saving the
1429            session again
1430    
1431            * Thuban/Model/table.py: Remove unnecessary import. Fix a typo.
1432    
1433    2003-04-01  Jonathan Coles   <[email protected]>
1434    
1435            *  Thuban/UI/renderer.py (MapRenderer.draw_point_shape): Check
1436            that there actually are points in the returned list of points
1437            before trying to index into the list. The list may be empty if
1438            the shape is a Null Shape.
1439    
1440    2003-04-01  Bernhard Herzog  <[email protected]>
1441    
1442            * test/test_map.py: Don't use from <module> import *
1443    
1444    2003-04-01  Jonathan Coles   <[email protected]>
1445    
1446            * Thuban/Model/session.py: Use LAYER_CHANGED instead of
1447            LAYER_LEGEND_CHANGED
1448    
1449            * Thuban/UI/dock.py (DockableWindow._OnButtonClose): Call
1450            self.Destroy() to close the window after yesterday's changes.
1451    
1452            * test/test_map.py, test/test_session.py: Fix messages that
1453            are sent from maps and layers.
1454    
1455    2003-03-31  Jonathan Coles   <[email protected]>
1456    
1457            * Thuban/UI/classifier.py: Commented out some debugging statements.
1458            (ClassDataPreviewer.Draw): Draw rectangles for polygon layers per
1459            RTbug #1769.
1460    
1461            * Thuban/UI/dock.py (DockableWindow.UnDock): Restore size and
1462            position (although position doesn't work yet under GTK).
1463            (DockableWindow.Destroy): New. Called when the window must be
1464            closed. Namely needed when the DockFrame closes and must close
1465            its children.
1466            (DockFrame): Listen for EVT_CLOSE and destroy all children.
1467    
1468            * Thuban/UI/legend.py (LegendPanel.Destroy): New. Cleans up
1469            when then window is told to close.
1470            (LegendTree._OnMsgLayerChanged): Fixes a seg fault bug. See
1471            comment in source for more info.
1472    
1473            * Thuban/UI/main.py: Show the legend by default when Thuban starts.
1474    
1475            * Thuban/UI/mainwindow.py: Renamed OnClose to _OnClose for
1476            symmetry with other such methods.
1477            (MainWindow.ShowLegend): Show the legend docked by default.
1478    
1479    2003-03-28  Jonathan Coles   <[email protected]>
1480    
1481            * Thuban/UI/classifier.py: Support for highlighting a specific
1482            group within the grid when the classification dialog is opened.
1483            Also contains a lot of debugging printouts which will later
1484            be removed.
1485    
1486            * Thuban/UI/dock.py: Complete rework on the dock code so that
1487            that it is fairly removed from the rest of the Thuban application.
1488            It is easy to add new docks which the rest of the program having
1489            to be aware of them.
1490    
1491            * Thuban/UI/legend.py: Modifications to support selecting a
1492            specific group in the classification dialog. Changed how layers
1493            are drawn when the layer is visible/invisible.
1494    
1495            * Thuban/UI/mainwindow.py: Removed legend specific code and
1496            replaced it with calls to the new dock code.
1497    
1498            * Thuban/UI/renderer.py (MapRenderer.__init__): Added assert
1499            to check if scale > 0. Trying to track down a divide by zero.
1500    
1501    2003-03-26  Jonathan Coles   <[email protected]>
1502    
1503            * Thuban/UI/legend.py: Removed unnecessary LegendDialog class.
1504            (LegendPanel): Removed _OnDock()/_OnUnDock() methods which are
1505            now part of DockableWindow.
1506            (LegendPanel.DoOnSelChanged): Select the current layer in the
1507            map.
1508            (LegendTree._OnSelChanged): Call LegendPanel.DoOnSelChanged()
1509            with the selected layer and/or group.
1510    
1511    2003-03-26  Jonathan Coles   <[email protected]>
1512    
1513            This putback contains the code for dockable windows. There is
1514            no support in wxWindows as of this date for windows that can
1515            attach themselves to other windows.
1516    
1517            The current model contains a DockableWindow which has a parent
1518            window for when it is detached and a dock window that it puts
1519            its contents in when it is docked. The contents of a DockableWindow
1520            must be a DockPanel. DockPanel itself derives from wxPanel.
1521    
1522            * Thuban/Model/layer.py (Layer.ClassChanged): Send a LAYER_CHANGED
1523            message, not a LAYER_LEGEND_CHANGED message.
1524    
1525            * Thuban/Model/map.py (Map): Forward LAYER_CHANGED messages.
1526    
1527            * Thuban/UI/classifier.py (Classifier.__init__): Use wxADJUST_MINSIZE
1528            as one of the style properties for the fieldTypeText item to
1529            be sure that its size is correct when the text changes.
1530    
1531            * Thuban/UI/dock.py: New. Classes for the DockPanel and
1532            DockableWindow.
1533    
1534            * Thuban/UI/legend.py: Added some more buttons and made the
1535            LegendPanel a DockPanel.
1536    
1537            * Thuban/UI/mainwindow.py: Added sash windows to the main window
1538            and supporting functions for manipulating the sashes.
1539            (MainWindow.ShowLegend): Create a DockableWindow with the
1540            LegendPanel as the contents.
1541    
1542            * Thuban/UI/messages.py: Added DOCKABLE_* messages
1543    
1544            * Thuban/UI/view.py (MapCanves.SetMap): Listen for LAYER_CHANGED,
1545            not LAYER_LEGEND_CHANGED, messages.
1546    
1547    2003-03-25  Jonathan Coles   <[email protected]>
1548    
1549            * setup.py: Added custom script bdist_rpm_build_script so that
1550            when the rpm is built the path to wx-config is correct.
1551    
1552            * setup.cfg: Added line saying to use the custom build script
1553    
1554    2003-03-20  Jonathan Coles   <[email protected]>
1555    
1556            Initial implementation of the Legend.
1557    
1558            * Thuban/UI/legend.py: New. Creates a window that shows the map's
1559            Legend information and allows the user to add/modify classifications
1560            and how the layers are drawn on the map.
1561    
1562            * setup.py: New command 'build_docs' which currently uses
1563            happydoc to generate html documentation for Thuban.
1564    
1565            * Thuban/Model/classification.py (ClassGroup.GetDisplayText): New.
1566            Returns a string which is appropriately describes the group.
1567    
1568            * Thuban/Model/layer.py (Layer.SetClassification): Generate a
1569            LAYER_CHANGED event instead of a LAYER_LEGEND_CHANGED event.
1570    
1571            * Thuban/Model/map.py (Map): Rename messages and use new, more
1572            specific, messages.
1573    
1574            * Thuban/Model/messages.py: New message to indicate that a layer's
1575            data has changed (LAYER_CHANGED). New map messages to indicate
1576            when layers have been added/removed/changed or if the stacking order
1577            of the layers has changed.
1578    
1579            * Thuban/Model/session.py: Rename and use new messages.
1580    
1581            * Thuban/UI/classifier.py: Remember if any changes have actually
1582            been applied so that if the dialog is cancelled without an application
1583            of changes we don't have to set a new classification.
1584            (ClassDataPreviewer): Pulled out the window specific code and put it
1585            ClassDataPreviewWindow. ClassDataPreviewer can then be used to draw
1586            symbols on any DC.
1587            
1588            * Thuban/UI/mainwindow.py: New code to open the legend.
1589    
1590            * Thuban/UI/view.py: Use new message names.
1591    
1592    2003-03-19  Jonathan Coles   <[email protected]>
1593    
1594            * Thuban/UI/main.py (verify_versions): New. Checks the versions
1595            of Python, wxPython, and some other libraries.
1596    
1597            * extensions/thuban/wxproj.cpp (check_version): Checks the given
1598            version against what wxproj was compiled with.
1599            (check_version_gtk): If wxproj was compiled with gtk then check
1600            the given version against the version of the gtk library
1601            currently being used.
1602    
1603    2003-03-14  Bernhard Herzog  <[email protected]>
1604    
1605            * test/test_command.py: Run the tests when the module is run as a
1606            script
1607    
1608    2003-03-14  Bernhard Herzog  <[email protected]>
1609    
1610            Implement selection of multiple selected shapes in the same layer:
1611    
1612            - Introduce a new class to hold the selection. This basically
1613              replaces the interactor which was nothing more than the
1614              selection anyway. A major difference is of course that the new
1615              selection class supports multiple selected shapes in one layer
1616            
1617            - Move the object that represents the selection from the
1618              application to the canvas. The canvas is a better place than the
1619              application because the selection represents which shapes and
1620              layer of the map displayed by the canvas are selected and
1621              affects how the map is drawn.
1622    
1623            - Make the selection and its messages publicly available through
1624              the mainwindow.
1625    
1626            - The non-modal dialogs do not get a reference to the interactor
1627              anymore as they can simply refer to their parent, the
1628              mainwindow, for the what the interactor had to offer.
1629    
1630            * Thuban/UI/selection.py: New module with a class to represent the
1631            selection.
1632    
1633            * Thuban/UI/messages.py (SELECTED_TABLE, SELECTED_MAP): Remove
1634            these unused messages
1635    
1636            * Thuban/UI/application.py (ThubanApplication.OnInit)
1637            (ThubanApplication.OnExit, ThubanApplication.SetSession): The
1638            interactor is gone now.
1639            (ThubanApplication.CreateMainWindow): There is no interactor
1640            anymore so we pass None as the interactor argument for now for
1641            compatibility.
1642    
1643            * Thuban/UI/view.py (MapCanvas.delegated_messages)
1644            (MapCanvas.Subscribe, MapCanvas.Unsubscribe): In Subscribe and
1645            Unsubscribe, delegate messages according to the delegated_messages
1646            class variable.
1647            (MapCanvas.__getattr__, MapCanvas.delegated_methods): Get some
1648            attributes from instance variables as described with the
1649            delegated_methods class variable.
1650            (MapCanvas.__init__): New instance variable selection holding the
1651            current selection
1652            (MapCanvas.do_redraw): Deal with multiple selected shapes. Simply
1653            pass them on to the renderer
1654            (MapCanvas.SetMap): Clear the selection when a different map is
1655            selected.
1656            (MapCanvas.shape_selected): Simple force a complete redraw. The
1657            selection class now takes care of only issueing SHAPES_SELECTED
1658            messages when the set of selected shapes actually does change.
1659            (MapCanvas.SelectShapeAt): The selection is now managed in
1660            self.selection
1661    
1662            * Thuban/UI/mainwindow.py (MainWindow.delegated_messages)
1663            (MainWindow.Subscribe, MainWindow.Unsubscribe): In Subscribe and
1664            Unsubscribe, delegate messages according to the delegated_messages
1665            class variable.
1666            (MainWindow.delegated_methods, MainWindow.__getattr__): Get some
1667            attributes from instance variables as described with the
1668            delegated_methods class variable.
1669            (MainWindow.__init__): The interactor as ivar is gone. The
1670            parameter is still there for compatibility. The selection messages
1671            now come from the canvas.
1672            (MainWindow.current_layer, MainWindow.has_selected_layer):
1673            Delegate to the the canvas.
1674            (MainWindow.LayerShowTable, MainWindow.Classify)
1675            (MainWindow.identify_view_on_demand): The dialogs don't need the
1676            interactor parameter anymore.
1677    
1678            * Thuban/UI/tableview.py (TableFrame.__init__)
1679            (LayerTableFrame.__init__, LayerTableFrame.OnClose)
1680            (LayerTableFrame.row_selected): The interactor is gone. It's job
1681            from the dialog's point of view is now done by the mainwindow,
1682            i.e. the parent. Subscribe to SHAPES_SELECTED instead
1683            of SELECTED_SHAPE
1684            
1685            * Thuban/UI/dialogs.py (NonModalDialog.__init__): The interactor
1686            is gone. It's job from the dialog's point of view is now done by
1687            the mainwindow, i.e. the parent.
1688            
1689            * Thuban/UI/classifier.py (Classifier.__init__): The interactor is
1690            gone. It's job from the dialog's point of view is now done by the
1691            mainwindow, i.e. the parent.
1692    
1693            * Thuban/UI/tree.py (SessionTreeView.__init__): The interactor is
1694            gone. It's job from the dialog's point of view is now done by the
1695            mainwindow, i.e. the parent.
1696            (SessionTreeCtrl.__init__): New parameter mainwindow which is
1697            stored as self.mainwindow. The mainwindow is need so that the tree
1698            can still subscribe to the selection messages.
1699            (SessionTreeCtrl.__init__, SessionTreeCtrl.unsubscribe_all)
1700            (SessionTreeCtrl.update_tree, SessionTreeCtrl.OnSelChanged): The
1701            selection is now accessible through the mainwindow. Subscribe to
1702            SHAPES_SELECTED instead of SELECTED_SHAPE
1703    
1704            * Thuban/UI/identifyview.py (IdentifyView.__init__): Use the
1705            SHAPES_SELECTED message now.
1706            (IdentifyView.selected_shape): Now subscribed to SHAPES_SELECTED,
1707            so deal with multiple shapes
1708            (IdentifyView.__init__, IdentifyView.OnClose): The interactor is
1709            gone. It's job from the dialog's point of view is now done by the
1710            mainwindow, i.e. the parent.
1711    
1712            * Thuban/UI/controls.py (RecordListCtrl.fill_list): The second
1713            parameter is now a list of shape ids.
1714            (RecordTable.SetTable): The second parameter is now a list of
1715            indices.
1716    
1717            * Thuban/UI/renderer.py (ScreenRenderer.RenderMap): Rename the
1718            selected_shape parameter and ivar to selected_shapes. It's now a
1719            list of shape ids.
1720            (MapRenderer.draw_label_layer): Deal with multiple selected
1721            shapes. Rearrange the code a bit so that the setup and shape type
1722            distinctions are only executed once.
1723    
1724            * test/test_selection.py: Test cases for the selection class
1725    
1726    2003-03-11  Jonathan Coles   <[email protected]>
1727    
1728            * Thuban/Model/load.py: Temporary fix so that the xml reader
1729            doesn't cause Thuban to crash.
1730    
1731            * Thuban/Model/layer.py: Handle the cyclic references between
1732            a layer and its classification better, and be sure to disconnect
1733            the classification from the layer when the layer is destroyed
1734            so that we don't maintain a cyclic reference that may not be
1735            garbage collected.
1736    
1737            * Thuban/Model/classification.py: See comment for layer.py.
1738    
1739    2003-03-12  Jan-Oliver Wagner <[email protected]>
1740    
1741            * HOWTO-Release: New. Information on the steps for releasing
1742            a new version of Thuban.
1743    
1744    2003-03-11  Jonathan Coles   <[email protected]>
1745    
1746            * Thuban/UI/classifier.py: Add normal border to SelectPropertiesDialog.
1747            Use True instead of true.
1748            (Classifier): Should have a single panel in which all the controls lie.
1749    
1750            * Thuban/UI/proj4dialog.py: Add normal border.
1751    
1752            * Thuban/UI/tree.py: Fixed problem with bad item images under Windows.
1753    
1754            * Thuban/UI/mainwindow.py: Use True instead of true.
1755    
1756            * setup.py: Update some definitions to use wxWindows2.4 files
1757    
1758            * Data/iceland_sample_class.thuban: Fixed file so that the
1759            field_type information is present.
1760    
1761    2003-03-10  Jonathan Coles   <[email protected]>
1762    
1763            * Thuban/UI/classifier.py (Classifier.__init__): Make the
1764            field type label grow so that when the text changes the
1765            size is updated correctly. This may be a wxWindows bug.
1766    
1767    2003-03-10  Jonathan Coles   <[email protected]>
1768    
1769            * Thuban/UI/application.py: Changed SESSION_CHANGED to
1770            SESSION_REPLACED.
1771    
1772            * Thuban/UI/classifier.py: Wrap text with _().
1773            (ClassGrid.CreateTable): Set dimensions and size hints here,
1774            instead of in Reset, so we only set the size once.
1775    
1776            * Thuban/UI/dialogs.py: Don't need Shutdown(); just use Close()!
1777    
1778            * Thuban/UI/mainwindow.py (MainWindow.prepare_new_session):
1779            Call Close() instead of Shutdown().
1780    
1781            * Thuban/UI/messages.py: Changed SESSION_CHANGED to SESSION_REPLACED.
1782    
1783            * Thuban/UI/tree.py: Changed SESSION_CHANGED to SESSION_REPLACED.
1784            Go back to using OnClose() instead of Shutdown().
1785    
1786    2003-03-10  Jonathan Coles   <[email protected]>
1787    
1788            * Thuban/UI/classifier.py (Classifier): SelectField() needed
1789            to know the old field index as well as the new one.
1790    
1791    2003-03-10  Jonathan Coles   <[email protected]>
1792    
1793            * Thuban/UI/classifier.py (Classifier): Use __SelectField()
1794            to correctly set the table information and call this from
1795            __init__ and from _OnFieldSelect so that all the information
1796            is up to date when the dialog opens and when a field is changed.
1797    
1798    2003-03-10  Jonathan Coles   <[email protected]>
1799    
1800            * Thuban/Model/classification.py (Classification): Don't use
1801            layer's message function directly, use the ClassChanged() method
1802            when then classification changes. SetField/SetFieldType/SetLayer
1803            must keep the information about field name and field type in
1804            sync when an owning layer is set or removed.
1805    
1806            * Thuban/Model/layer.py: Added ClassChanged() so that the
1807            classification can tell the layer when its data has changed.
1808            (Layer.SetClassification): Accepts None as an arguement to
1809            remove the current classification and correctly handles
1810            adding a new classification.
1811    
1812            * Thuban/Model/load.py: Comment out print statement
1813    
1814            * test/test_classification.py, test/test_save.py: New and
1815            improved tests.
1816    
1817    2003-03-07  Jonathan Coles   <[email protected]>
1818    
1819            * Thuban/Model/classification.py: Implemented __copy__ and
1820            __deepcopy__ for ClassGroup* and ClassGroupProperites so
1821            they can easily be copied by the classifier dialog.
1822            (ClassGroupProperites.__init__): The default line color should
1823            have been Color.Black.
1824    
1825            * Thuban/UI/classifier.py: Setting and Getting table values now
1826            uses a consistent set of functions.
1827            (Classifier): Now non-modal. Has field type label which changes
1828            as the field changes. Keep track of buttons in a list so that
1829            we can enable/disable the buttons when the None field is selected.
1830            (SelectPropertiesDialog): Add buttons to make the colors transparent.
1831    
1832            * Thuban/UI/dialogs.py (NonModalDialog.Shutdown): New method which
1833            does what OnClose did, but can be called by the application to
1834            close a window. Needed when a session changes, and we have to
1835            close the classifier windows.
1836    
1837            * Thuban/UI/mainwindow.py (MainWindow.prepare_new_session):
1838            Shuts down open dialogs. Used when a new session is created
1839            or a session is opened.
1840            (MainWindow.SaveSession): Should only call application.SaveSession()
1841            if we don't call SaveSessionAs first.
1842            (MainWindow.Classify): Allow different classifier dialogs for
1843            different layers.
1844    
1845            * Thuban/UI/tree.py (SessionTreeView): Remove OnClose and let
1846            the parent class handle it. Add Shutdown() to unsubscibe from
1847            event notification and call the parent Shutdown(). This was
1848            necessary so the application can close the tree window.
1849    
1850    2003-03-06  Jonathan Coles   <[email protected]>
1851    
1852            * Thuban/Model/classification.py: Minor documentation changes,
1853            Addition of __eq__ and __ne__ methods.
1854            (Classification.SetLayer): prevent recursion between this method
1855            and Layer.SetClassification().
1856    
1857            * Thuban/Model/color.py: Addition of __eq__ and __ne__ methods.
1858    
1859            * Thuban/Model/layer.py (SetClassification): prevent recursion
1860            between this method and Classification.SetLayer().
1861    
1862            * test/test_classification.py, test/test_load.py,
1863            test/test_session.py: Fixed and added tests for the classification
1864            classes.
1865    
1866    2003-03-06  Bernhard Herzog  <[email protected]>
1867    
1868            * Thuban/UI/classifier.py (ClassGrid.__init__)
1869            (ClassGrid.CreateTable): Move the SetSelectionMode call to
1870            CreateTable because otherwise it triggers an assertion in
1871            wxPython/wxGTK 2.4.
1872    
1873    2003-03-05  Jonathan Coles   <[email protected]>
1874    
1875            * Thuban/common.py: Move FIELDTYPE constants back to table.py.
1876    
1877            * Thuban/Model/load.py: import FIELDTYPE constants from table.
1878    
1879            * Thuban/UI/classifier.py: import FIELDTYPE constants from table.
1880    
1881            * Thuban/Model/table.py: Put FIELDTYPE constants back.
1882    
1883    2003-03-05  Jonathan Coles   <[email protected]>
1884    
1885            * Thuban/UI/classifier.py: Added class documentation.
1886            Fixed RTbug #1713, #1714. Added Move[Up|Down] buttons.
1887            Store just the groups in the table and generate the other
1888            column information when it is requested. Add "None" field
1889            to pull-down to select no classification.
1890    
1891            * Thuban/common.py: Moved FIELDTYPE constants from table.py
1892            (Str2Num): Only catch ValueError exceptions.
1893    
1894            * Thuban/Model/classification.py: Class documentation. Renaming
1895            of methods with Stroke to Line. Groups are stored in a single
1896            list with the default as the first element. Groups are searched
1897            in the order they appear in the list.
1898    
1899            * Thuban/Model/color.py: Documentation.
1900    
1901            * Thuban/Model/layer.py (Layer): Add GetFieldType to retreive
1902            the kind of data represented by a field.
1903    
1904            * Thuban/Model/load.py (ProcessSession): Use proper string
1905            conversion function; fixes RTbug #1713.
1906    
1907            * Thuban/Model/save.py (Saver): Store field type information.
1908    
1909            * Thuban/Model/table.py: Put FIELDTYPE constants in common.py.
1910            (Table): Add field_info_by_name() to retrieve field information
1911            by specifying the field name, not the number.
1912    
1913            * Thuban/UI/mainwindow.py: Function name changes.
1914    
1915            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Only
1916            get the layer classification once. Don't try to classify
1917            values when the field is None: just use the default properties.
1918    
1919            * Thuban/UI/view.py: Function name changes.
1920    
1921            * Doc/thuban.dtd: Add field_type attribute to a classification.
1922    
1923    2003-03-04  Bernhard Herzog  <[email protected]>
1924    
1925            * Doc/thuban.dtd: Use correct syntax for optional attributes. Make
1926            the fill and stroke layer attributes optional with suitable
1927            default values. Add the stroke_width layer attribute. Use correct
1928            syntax for empty elements. Make the attribute list for labels
1929            refer to the label element.
1930    
1931    2003-03-04  Bernhard Herzog  <[email protected]>
1932    
1933            * setup.py (thuban_build_py.build): Add a comment about distutils in
1934            Python 2.3 containing some of the functionality we implement in
1935            setup.py ourselves.
1936    
1937            * Thuban/UI/classifier.py (ClassGrid.__init__): Set the table
1938            before the selection mode. Doing it the other way round triggers
1939            an assertion in wxWindows.
1940    
1941            * Thuban/Model/save.py (escape): Fix typo in doc-string
1942    
1943            * Thuban/Model/classification.py: Remove unnecessary wxPython
1944            import
1945    
1946    2003-03-04  Jonathan Coles   <[email protected]>
1947    
1948            * Thuban/Model/classification.py (ClassGroupRange.GetProperties):
1949            Parameter 'value' should default to None.
1950    
1951            * Thuban/UI/mainwindow.py: Use Layer.GetClassification() since
1952            the class attribute __classification is now private.
1953    
1954            * Thuban/UI/classifier.py (ClassGrid): Moved OnCellDClick() from
1955            Classifier to ClassGrid. Added support for removing selected rows,
1956            which including code for keeping track of when cells are selected,
1957            and deselected.
1958            (ClassTable): Support for added/removing rows. Fixed a problem
1959            with __ParseInput whereby it would not allow strings (only numbers)
1960            to be entered.
1961            (Classifier): Added button and supporting code for removing
1962            selected rows.
1963    
1964    2003-02-27  Jonathan Coles   <[email protected]>
1965    
1966            * Thuban/common.py: Moved color conversion functions into
1967            Thuban/UI/common.py.
1968            (Str2Num): Now converts the float (not the string) to a long/int
1969            so that an exception isn't thrown.
1970    
1971            * Thuban/UI/common.py: Common functions used in several UI modules
1972    
1973            * Thuban/Model/classification.py: Changed the class hierarchy
1974            so that a Classification consists of Groups which return
1975            Properties when a value matches a Group.
1976    
1977            * Thuban/Model/layer.py: Fixed name resolution problem.
1978    
1979            * Thuban/Model/load.py: Use new Classification and Group functions.
1980    
1981            * Thuban/Model/save.py (Saver.write_attribs): Fixes a test case
1982            failure.
1983            (Saver.write_classification): Use new Classification and Group
1984            functions.
1985    
1986            * Thuban/UI/classifier.py: Changes to use new Classification and Group
1987            functions. Fix to create a tuple with a single value instead of
1988            simply returning the value.
1989    
1990            * Thuban/UI/renderer.py: Use new Classification and Group functions.
1991            Use common.py functions.
1992    
1993            * Thuban/UI/tree.py: Use common.py functions.
1994            
1995            * test/test_classification.py: Use new Classification and Group
1996            classes.
1997    
1998    2003-02-24  Jonathan Coles   <[email protected]>
1999    
2000            * Thuban/common.py (Color2wxColour, wxColour2Color): Conversion
2001            functions from Thuban color objects to wxWindow colour objects.
2002    
2003            * Thuban/Model/classification.py (Classification): Renamed
2004            GetProperties() to GetClassData(). Used the new iterator
2005            in TreeInfo().
2006            (ClassIterator): Iterator implementation to iterate over the
2007            ClassData objects in a classification object.
2008    
2009            * Thuban/Model/save.py (Saver.write_classificaton): Uses
2010            the new iterator to save the classification information.
2011    
2012            * Thuban/UI/classifier.py (SelectPropertiesDialog): Support
2013            for changing the stroke and fill colors and previewing the
2014            changes.
2015    
2016            * Thuban/UI/mainwindow.py (MainWindow.OpenSession,
2017            MainWindow.SaveSessionAs): Text string changes so the dialogs
2018            have more meaningful titles.
2019    
2020            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Change
2021            Classification method name from GetProperties to GetClassData.
2022    
2023            * Thuban/UI/view.py (MapCanvas.find_shape_at): Use method calls
2024            instead of accessing now non-existent class variables.
2025    
2026    2003-02-24  Bernhard Herzog  <[email protected]>
2027    
2028            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Remove
2029            unneeded Shape() call. Rendering is substantially faster without
2030            it and it avoids some problems with broken shape files.
2031    
2032    2003-02-20  Frank Koormann   <[email protected]>
2033    
2034            Force minimal size of identify and label dialogs. The autosizing
2035            looked too ugly.
2036    
2037            * Thuban/UI/controls.py (RecordListCtrl): Set minimal width for columns.
2038            * Thuban/UI/labeldialog.py (LabelDialog.dialog_layout):
2039            Set size of listctrl.
2040            * Thuban/UI/identifyview.py (IdentifyView.__init__):
2041            Set size of dialog.
2042    
2043    2003-02-19  Jonathan Coles   <[email protected]>
2044    
2045            * test/test_classification.py, test/test_layer.py,
2046            test/test_load.py, test/test_map.py, test/test_session.py:
2047            Updated the tests to use the new functions that are in the
2048            respective classes.
2049    
2050            * Thuban/Model/classification.py (Classification):
2051            Uses the new ClassData* classes. Modification messages are
2052            passed up to the parent layer (if it exists).
2053            (ClassData): New class to encapsulate the common data in each
2054            classification property.
2055            (ClassDataDefault): Represents the Default class. data.
2056            (ClassDataPoint): Represents a single class. data point
2057            (ClassDataRange): Represents a class. range
2058            (ClassDataMap): Represents a class. map (unused).
2059    
2060            * Thuban/Model/color.py: Added Color.None to represent something
2061            with no color. Color.Black represents the color black.
2062            (NoColor): Helper class derived from Color to represent something
2063            with no color.
2064    
2065            * Thuban/Model/layer.py (Layer): Removed references to fill, stroke,
2066            stroke_width attributes. Made the 'classification' attribute private.
2067            New methods for setting/getting the classification.
2068    
2069            * Thuban/Model/load.py (ProcessSession): Use new methods on Layer
2070            to get the classifcation and use the new ClassData* classes to
2071            hold the classification data. Use Str2Num to convert numbers
2072            properly.
2073    
2074            * Thuban/Model/save.py (Saver): Use new Color and Classification
2075            methods
2076    
2077            * Thuban/UI/classifier.py (ClassGrid): New class to represent a
2078            custom grid.
2079            (ClassTable): Support for editing Values and Labels and for
2080            changing what type (point or range) of data is stored in each
2081            property based on how the user enters the data.
2082            (Classifier): Support for saving the new classifications and
2083            launching the dialog to edit a property.
2084            (SelectPropertiesDialog): New class for editing the visual
2085            properties of a classification (stroke color, width, and fill color)
2086            (ClassPreviewer): Took the Draw method from ClassRenderer and
2087            made most of it into this new class. Intend to use this class in
2088            the SelectPropertiesDialog for previewing changes.
2089    
2090            * Thuban/UI/renderer.py: Use new Color and Classification methods.
2091    
2092            * Thuban/UI/tree.py: Formatting changes.
2093    
2094            * Doc/thuban.dtd: Add 'label' element
2095    
2096            * Thuban/common.py: New. Contains common routines used throughout
2097            the code.
2098            (Str2Num): Takes a string and converts it to the "best" type of
2099            number.
2100    
2101    2003-02-14  Bernhard Herzog  <[email protected]>
2102    
2103            * Thuban/UI/view.py (MapCanvas.OnLeftUp): Make sure that the
2104            dragging flag is always set to 0 even when the tool implementation
2105            raises an exception
2106    
2107    2003-02-11  Bernhard Herzog  <[email protected]>
2108    
2109            * Thuban/UI/application.py (ThubanApplication.splash_screen): New
2110            method to create a splash screen.
2111            (ThubanApplication.ShowMainWindow): New. Show the main window.
2112            Needed so the splash screen can display the mainwindow
2113            (ThubanApplication.OnInit): Call the
2114            new splash_screen method to determine whether the application
2115            should display a splash screen. If it displays a splash screen do
2116            not immediately show the main window.
2117    
2118    2003-02-11  Jonathan Coles  <[email protected]>
2119    
2120            * Thuban/Model/classification.py: Added import line to fix
2121            feature conflicts between running on python2.2 and python2.1.
2122    
2123            * Thuban/UI/classifier.py (ClassTable): Didn't need to hang
2124            onto the clinfo parameter, so removed the deepcopy().
2125    
2126  2003-02-10  Jonathan Coles  <[email protected]>  2003-02-10  Jonathan Coles  <[email protected]>
2127    
2128          * Thuban/Model/save.py (Saver.open_element, Saver.close_element):          * Thuban/Model/save.py (Saver.open_element, Saver.close_element):
2129          Added element_open variable to track opening and closing of tags          Added element_open variable to track opening and closing of tags
2130          so that tags that don't span more than one line are closed with          so that tags that don't span more than one line are closed with
2131          /> instead of </tag_name>. Use the GetDefault*() methods of          /> instead of </tag_name>. Use the GetDefault*() methods of
# Line 13  Line 2138 
2138          (ClassData): New class to encapsulate the classification data          (ClassData): New class to encapsulate the classification data
2139    
2140          * Thuban/Model/layer.py (Layer): Remove the          * Thuban/Model/layer.py (Layer): Remove the
2141          Set[Fill|Stroke|StrokeWidth]() methods. Code should call the          Set[Fill|Stroke|StrokeWidth]() methods. Code should call the
2142          SetDefault*() methods on the layer's classification object.          SetDefault*() methods on the layer's classification object.
2143          (Layer.__init__): Use the new SetDefault*() methods in the          (Layer.__init__): Use the new SetDefault*() methods in the
2144          Classification class.          Classification class.
2145    
2146          * Thuban/Model/load.py (ProcessSession): Use the new ClassData          * Thuban/Model/load.py (ProcessSession): Use the new ClassData
2147          object instead of a dictionary.          object instead of a dictionary.
2148    
2149          * Thuban/UI/classifier.py (ClassRenderer): New class to          * Thuban/UI/classifier.py (ClassRenderer): New class to
2150          draw the classifications in the dialog box's table.          draw the classifications in the dialog box's table.
2151          (Classifier): Modified to use the ClassRenderer class.          (Classifier): Modified to use the ClassRenderer class.
2152    
2153          * Thuban/UI/mainwindow.py (MainWindow): Use the SetDefault*()          * Thuban/UI/mainwindow.py (MainWindow): Use the SetDefault*()
2154          methods of the Classification class.              methods of the Classification class.
2155    
2156          * Thuban/UI/renderer.py (MapRenderer): Use the Get*() methods          * Thuban/UI/renderer.py (MapRenderer): Use the Get*() methods
2157          of the ClassData class.          of the ClassData class.
# Line 49  Line 2174 
2174  2003-01-28  Jonathan Coles  <[email protected]>  2003-01-28  Jonathan Coles  <[email protected]>
2175    
2176          * Thuban/UI/classifier.py (Classifier): Resolved merging conflicts.          * Thuban/UI/classifier.py (Classifier): Resolved merging conflicts.
2177          Fixed crashing problem on some systems. Dialog box shows          Fixed crashing problem on some systems. Dialog box shows
2178          classification data.          classification data.
2179    
2180          * Thuban/UI/tree.py (SessionTreeCtrl.add_items): Handle drawing          * Thuban/UI/tree.py (SessionTreeCtrl.add_items): Handle drawing
# Line 62  Line 2187 
2187          function to add information about the classification into the          function to add information about the classification into the
2188          tree view.          tree view.
2189    
2190  2003-01-27      Jan-Oliver Wagner <[email protected]>  2003-01-27  Jan-Oliver Wagner <[email protected]>
2191    
2192          * Thuban/__init__.py (_): New.          * Thuban/__init__.py (_): New.
2193    
2194          * Thuban/Model/classification.py, Thuban/Model/extension.py,          * Thuban/Model/classification.py, Thuban/Model/extension.py,
2195          Thuban/Model/layer.py, Thuban/Model/load.py, Thuban/Model/map.py,          Thuban/Model/layer.py, Thuban/Model/load.py, Thuban/Model/map.py,
2196          Thuban/Model/session.py, Thuban/UI/application.py, Thuban/UI/classifier.py,          Thuban/Model/session.py, Thuban/UI/application.py,
2197          Thuban/UI/context.py, Thuban/UI/controls.py, Thuban/UI/identifyview.py,          Thuban/UI/classifier.py, Thuban/UI/context.py, Thuban/UI/controls.py,
2198          Thuban/UI/labeldialog.py, Thuban/UI/mainwindow.py, Thuban/UI/menu.py,          Thuban/UI/identifyview.py, Thuban/UI/labeldialog.py,
2199          Thuban/UI/proj4dialog.py, Thuban/UI/renderer.py, Thuban/UI/tree.py,          Thuban/UI/mainwindow.py, Thuban/UI/menu.py, Thuban/UI/proj4dialog.py,
2200          Thuban/Lib/connector.py, Thuban/Lib/fileutil.py:          Thuban/UI/renderer.py, Thuban/UI/tree.py, Thuban/Lib/connector.py,
2201          Replace user string by _() for i18n.          Thuban/Lib/fileutil.py: Replace user string by _() for i18n.
2202    
2203  2003-01-27  Jonathan Coles  <[email protected]>  2003-01-27  Jonathan Coles  <[email protected]>
2204    
2205    * Thuban/Model/layer.py: Classification initialization calls.          * Thuban/Model/layer.py: Classification initialization calls.
2206    
2207    * Thuban/Model/classification.py: Created class to encapsulate          * Thuban/Model/classification.py: Created class to encapsulate
2208    a layer classification. Supports specific data points and          a layer classification. Supports specific data points and
2209    ranges.          ranges.
2210    
2211    * Thuban/Model/load.py: Added support for loading classification          * Thuban/Model/load.py: Added support for loading classification
2212    information.          information.
2213    
2214    * Thuban/Model/save.py: Added support for saving classification          * Thuban/Model/save.py: Added support for saving classification
2215    information.          information.
2216    
2217    * Thuban/UI/classifier.py: Initial class for a dialog box for          * Thuban/UI/classifier.py: Initial class for a dialog box for
2218    specifying classification information.          specifying classification information.
2219    
2220    * Thuban/UI/mainwindows.py: Support for opening the classifier          * Thuban/UI/mainwindows.py: Support for opening the classifier
2221    dialog.          dialog.
2222    
2223    * Thuban/UI/renderer.py: Support for drawing a layer with the          * Thuban/UI/renderer.py: Support for drawing a layer with the
2224    classification information.          classification information.
2225    
2226    * Data/iceland_sample_class.thuban: iceland_sample with          * Data/iceland_sample_class.thuban: iceland_sample with
2227    classification data.          classification data.
2228    
2229    * test/test_classification: Tests for the Classification class.          * test/test_classification: Tests for the Classification class.
2230    
2231  2002-12-09  Bernhard Herzog  <[email protected]>  2002-12-09  Bernhard Herzog  <[email protected]>
2232    
# Line 137  Line 2262 
2262          * Thuban/UI/mainwindow.py: Altered the order of tools in the          * Thuban/UI/mainwindow.py: Altered the order of tools in the
2263          toolbar: First now are all navigation tools (Zoom In/Out, Pan,          toolbar: First now are all navigation tools (Zoom In/Out, Pan,
2264          Full Extent).          Full Extent).
2265        
2266  2002-10-23  Bernhard Herzog  <[email protected]>  2002-10-23  Bernhard Herzog  <[email protected]>
2267    
2268          * setup.py (setup call): version now 0.1.3          * setup.py (setup call): version now 0.1.3
# Line 248  Line 2373 
2373          * Thuban/UI/mainwindow.py (MainWindow.OnClose): Unsubscribe          * Thuban/UI/mainwindow.py (MainWindow.OnClose): Unsubscribe
2374          VIEW_POSITION          VIEW_POSITION
2375    
2376  2002-09-04  Frank Koormann   <[email protected]>  2002-09-04  Frank Koormann  <[email protected]>
2377    
2378          * Resources/Bitmaps/fullextent.xpm: Updated Icon (removed "potatoe")          * Resources/Bitmaps/fullextent.xpm: Updated Icon (removed "potatoe")
2379    
# Line 335  Line 2460 
2460    
2461          * Thuban/Model/table.py (Table.write_record): New method to write          * Thuban/Model/table.py (Table.write_record): New method to write
2462          records.          records.
2463          (Table.__init__): Open the DBF file for writing too.          (Table.__init__): Open the DBF file for writing too.
2464    
2465          * Thuban/UI/controls.py (RecordTable.SetValue): Write the value          * Thuban/UI/controls.py (RecordTable.SetValue): Write the value
2466          into the underlying table.          into the underlying table.
# Line 373  Line 2498 
2498          * setup.py (ThubanInstall.run): Don't repr install_lib_orig          * setup.py (ThubanInstall.run): Don't repr install_lib_orig
2499          because thubaninit_contents will do it for us.          because thubaninit_contents will do it for us.
2500    
2501  2002-08-16      Jan-Oliver Wagner <[email protected]>  2002-08-16  Jan-Oliver Wagner <[email protected]>
2502    
2503          * Thuban/UI/mainwindow.py: menu item 'show session tree' now disable if          * Thuban/UI/mainwindow.py: menu item 'show session tree' now disable if
2504          tree window already open          tree window already open
# Line 501  Line 2626 
2626          * Thuban/UI/tree.py: We can now simply subscribe to the session's          * Thuban/UI/tree.py: We can now simply subscribe to the session's
2627          CHANGED channel to be informed of changes.          CHANGED channel to be informed of changes.
2628          (SessionTreeCtrl.session_channels): Not needed any longer.          (SessionTreeCtrl.session_channels): Not needed any longer.
2629          (SessionTreeCtrl.unsubscribe_all, SessionTreeCtrl.session_changed):          (SessionTreeCtrl.unsubscribe_all, SessionTreeCtrl.session_changed):
2630          Only have to (un)subscribe CHANGED          Only have to (un)subscribe CHANGED
2631    
2632          * Thuban/Model/map.py (Map.TreeInfo): Deal better with empty maps.          * Thuban/Model/map.py (Map.TreeInfo): Deal better with empty maps.
# Line 562  Line 2687 
2687          * Thuban/Model/layer.py (Layer.TreeInfo),          * Thuban/Model/layer.py (Layer.TreeInfo),
2688          Thuban/Model/extension.py (Extension.TreeInfo),          Thuban/Model/extension.py (Extension.TreeInfo),
2689          Thuban/Model/map.py (Map.TreeInfo),          Thuban/Model/map.py (Map.TreeInfo),
2690          Thuban/Model/session.py (Session.TreeInfo):          Thuban/Model/session.py (Session.TreeInfo):
2691          Add TreeInfo methods to implement the new tree view update scheme          Add TreeInfo methods to implement the new tree view update scheme
2692    
2693  2002-07-16  Bernhard Herzog  <[email protected]>  2002-07-16  Bernhard Herzog  <[email protected]>
# Line 643  Line 2768 
2768          * setup.py: In the setup call, make sure that the library          * setup.py: In the setup call, make sure that the library
2769          directories are under $prefix/lib not directly under $prefix.          directories are under $prefix/lib not directly under $prefix.
2770    
2771  2002-06-20      Jan-Oliver Wagner <[email protected]>  2002-06-20  Jan-Oliver Wagner <[email protected]>
2772    
2773          * Thuban/Model/extension.py: new module to handle extension objects.          * Thuban/Model/extension.py: new module to handle extension objects.
2774          * Thuban/Model/messages.py: new messages for extensions.          * Thuban/Model/messages.py: new messages for extensions.
# Line 872  Line 2997 
2997          * Thuban/UI/messages.py (VIEW_POSITION): New message for the          * Thuban/UI/messages.py (VIEW_POSITION): New message for the
2998          position in the statusbar          position in the statusbar
2999    
3000  2002-04-26      Frank Koormann <[email protected]>  2002-04-26  Frank Koormann <[email protected]>
3001    
3002          * Thuban/UI/mainwindow.py: AddLayer, Dialog title s/session/data          * Thuban/UI/mainwindow.py: AddLayer, Dialog title s/session/data
3003    
3004  2002-04-24      Frank Koormann <[email protected]>  2002-04-24  Frank Koormann <[email protected]>
3005            
3006          * Resources/Bitmaps/identify.xpm: shadow added          * Resources/Bitmaps/identify.xpm: shadow added
3007    
3008          * Resources/Bitmaps/fullextent.xpm: new          * Resources/Bitmaps/fullextent.xpm: new
           
 2002-04-22      Jan-Oliver Wagner <[email protected]>  
3009    
3010          * Thuban/UI/tree.py (update_tree): added test for None on map bounding box  2002-04-22  Jan-Oliver Wagner <[email protected]>
3011    
3012            * Thuban/UI/tree.py (update_tree): added test for None on map bounding
3013            box
3014    
3015  2002-04-21      Jan-Oliver Wagner <[email protected]>  2002-04-21  Jan-Oliver Wagner <[email protected]>
3016    
3017          * Thuban/UI/proj4dialog.py (UTMProposeZoneDialog): new          * Thuban/UI/proj4dialog.py (UTMProposeZoneDialog): new
3018    
3019          * Thuban/UI/tree.py (update_tree): added added map extent          * Thuban/UI/tree.py (update_tree): added added map extent
3020    
3021          * Thuban/UI/mainwindow.py (_method_command): extended by parameter          * Thuban/UI/mainwindow.py (_method_command): extended by parameter
3022          icon; added map_full_extend as tool          icon; added map_full_extend as tool
3023    
3024  2002-04-19      Jan-Oliver Wagner <[email protected]>  2002-04-19  Jan-Oliver Wagner <[email protected]>
3025    
3026          * Thuban/UI/mainwindow.py (SaveSession): launch save as dialog for          * Thuban/UI/mainwindow.py (SaveSession): launch save as dialog for
3027          saving _new_ sessions          saving _new_ sessions
# Line 997  Line 3123 
3123    
3124          * setup.py: increase version number to 0.1          * setup.py: increase version number to 0.1
3125          (data_dist): New command class for data distribution          (data_dist): New command class for data distribution
           
3126    
3127  2001-09-14  Bernhard Herzog  <[email protected]>  2001-09-14  Bernhard Herzog  <[email protected]>
3128    
3129          * Thuban/UI/identifyview.py (IdentifyListCtrl.selected_shape):          * Thuban/UI/identifyview.py (IdentifyListCtrl.selected_shape):
3130          Handle the case of no layer (i.e. layer is None) properly.          Handle the case of no layer (i.e. layer is None) properly.
3131    
3132          * Thuban/UI/proj4dialog.py (UTMDialog.__init__, Proj4Dialog.__init__):          * Thuban/UI/proj4dialog.py (UTMDialog.__init__, Proj4Dialog.__init__):
3133          Set the initial selection of the combo boxes to reflect the          Set the initial selection of the combo boxes to reflect the
3134          projection we're starting with in a way that works on windows,          projection we're starting with in a way that works on windows,
3135          too.          too.
# Line 1114  Line 3239 
3239          (MainWindow.identify_view_on_demand): Store the interactor in an          (MainWindow.identify_view_on_demand): Store the interactor in an
3240          instvar and use that reference instead of going through main.app          instvar and use that reference instead of going through main.app
3241    
3242          * Thuban/UI/mainwindow.py (MainWindow.ShowSessionTree):          * Thuban/UI/mainwindow.py (MainWindow.ShowSessionTree):
3243          * Thuban/UI/application.py (ThubanApplication.OnInit):          * Thuban/UI/application.py (ThubanApplication.OnInit):
3244          * Thuban/UI/main.py (main): Create the session tree view in main          * Thuban/UI/main.py (main): Create the session tree view in main
3245          with the new mainwindow method ShowSessionTree and not directly          with the new mainwindow method ShowSessionTree and not directly
3246          the application's OnInit method          the application's OnInit method
# Line 1131  Line 3256 
3256          layer to the tableview dialog.          layer to the tableview dialog.
3257    
3258          * Thuban/UI/tableview.py: Add some doc-strings          * Thuban/UI/tableview.py: Add some doc-strings
3259          (TableGrid):          (TableGrid):
3260          (TableGrid.OnRangeSelect):          (TableGrid.OnRangeSelect):
3261          (TableGrid.OnSelectCell):          (TableGrid.OnSelectCell):
3262          (TableFrame.__init__):          (TableFrame.__init__):
# Line 1198  Line 3323 
3323  2001-09-05  Bernhard Herzog  <[email protected]>  2001-09-05  Bernhard Herzog  <[email protected]>
3324    
3325          * Thuban/UI/view.py (MapCanvas.__init__): New argument, interactor.          * Thuban/UI/view.py (MapCanvas.__init__): New argument, interactor.
3326            
3327          * Thuban/UI/mainwindow.py (MainWindow.__init__): New argument          * Thuban/UI/mainwindow.py (MainWindow.__init__): New argument
3328          interactor to pass through to the MapCanvas          interactor to pass through to the MapCanvas
3329            
3330          * Thuban/UI/application.py (ThubanApplication.OnInit): Use the new          * Thuban/UI/application.py (ThubanApplication.OnInit): Use the new
3331          argument to the MainWindow constructor to get rid of the ugly hack          argument to the MainWindow constructor to get rid of the ugly hack
3332          that made main.app available early just so that the mapcanvas          that made main.app available early just so that the mapcanvas
# Line 1248  Line 3373 
3373          (ThubanInstall.run): Remove the leading install root from the          (ThubanInstall.run): Remove the leading install root from the
3374          script filename if an install root was specified and use the new          script filename if an install root was specified and use the new
3375          link_file method          link_file method
3376            
3377          * Thuban/UI/mainwindow.py (MainWindow.AddLayer): Fit the map to          * Thuban/UI/mainwindow.py (MainWindow.AddLayer): Fit the map to
3378          the window when the first layer is added to the map.          the window when the first layer is added to the map.
3379    
# Line 1285  Line 3410 
3410          (InnoIconItem): Helper class for bdist_inno          (InnoIconItem): Helper class for bdist_inno
3411          (thuban_bdist_inno): Thuban specific version of bdist_inno. Added          (thuban_bdist_inno): Thuban specific version of bdist_inno. Added
3412          this together with the appropriate parameters, to the setup call.          this together with the appropriate parameters, to the setup call.
3413            
3414          * setup.cfg (bdist_inno): added new section for the inno setup          * setup.cfg (bdist_inno): added new section for the inno setup
3415          installer          installer
3416    

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26