/[thuban]/branches/WIP-pyshapelib-bramz/ChangeLog
ViewVC logotype

Diff of /branches/WIP-pyshapelib-bramz/ChangeLog

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

revision 2085 by bh, Fri Feb 20 15:49:43 2004 UTC revision 2224 by bh, Fri May 28 17:29:30 2004 UTC
# Line 1  Line 1 
1    2004-05-28  Bernhard Herzog  <[email protected]>
2    
3            * Thuban/UI/baserenderer.py: Fix some typos.
4    
5    2004-05-18  Jan-Oliver Wagner <[email protected]>
6    
7            * Extensions/gns2shp/gns2shp.py (gns2shp): Fixed a bug
8            by increasing a field size.
9    
10    2004-05-17  Bernhard Herzog  <[email protected]>
11    
12            Update to newest shapelib and get rid of Thuban specific
13            extensions, i.e. use the new DBFUpdateHeader instead of our
14            DBFCommit kludge
15    
16            * libraries/shapelib/shpopen.c: Update to version from current
17            shapelib CVS.
18    
19            * libraries/shapelib/shapefil.h: Update to version from current
20            shapelib CVS.
21    
22            * libraries/shapelib/dbfopen.c: Update to version from current
23            shapelib CVS.
24            (DBFCommit): Effectively removed since shapelib itself has
25            DBFUpdateHeader now which is better for what DBFCommit wanted to
26            achieve.  
27            We're now using an unmodified version of dbfopen.
28    
29            * setup.py (extensions): Add the HAVE_UPDATE_HEADER macro with
30            value '1' to the Lib.dbflibc extension.  This simply reflects the
31            shapelib and pyshapelib updates
32    
33    2004-05-16  Jan-Oliver Wagner <[email protected]>
34    
35            Finished introduction of Menu.FindOrInsertMenu.
36    
37            * Extensions/drawshape/drawshape.py: Add the command
38            to the experimental menu additionally to the toolbar.
39    
40            * Extensions/svgexport/svgsaver.py: Use FindOrInsertMenu() instead of
41            finding menu on its own.
42    
43            * Doc/manual/thuban-manual.xml: updated sample file
44            to use FindOrInsertMenu().
45    
46            * Examples/simple_extensions/hello_world.py: Use FindOrInsertMenu()
47            instead of finding menu on its own.
48    
49    2004-05-11  Jan-Oliver Wagner <[email protected]>
50    
51            * test/test_menu.py (MenuTest.test): Added testing
52            of method Menu.FindOrInsertMenu.
53    
54    2004-05-10  Jan-Oliver Wagner <[email protected]>
55    
56            Introduce and use Menu.FindOrInsertMenu.
57    
58            * Thuban/UI/menu.py (Menu.FindOrInsertMenu): New. Find a
59              given menu or, if not found, insert it.
60    
61            * Extensions/bboxdump/bboxdump.py, /Extensions/gns2shp/gns2shp.py,
62            /Extensions/importAPR/importAPR.py, Extensions/profiling/profiling.py,
63            /Extensions/wms/wms.py: Use FindOrInsertMenu() instead of finding
64            menu on its own.
65    
66    2004-05-06  Jan-Oliver Wagner <[email protected]>
67    
68            Introduce a abstract ColorDialog class and remove
69            and outdated file.
70    
71            * Thuban/UI/proj4dialog.py: Removed. It is has been
72            replaced by projdialog for quite a while and is not used
73            anymore.
74    
75            * Thuban/UI/colordialog.py: New. Abstraction for color selection
76            dialog(s).
77    
78            * Thuban/UI/classifier.py (SelectPropertiesDialog.__GetColor):
79            Now calls the abstract ColorDialog instead of wxColourDialog.
80            This also removed the dependency to Color class conversion
81            from this function.
82    
83    2004-05-04  Frank Koormann  <[email protected]>
84    
85            * Extensions/bboxdump/__init__.py: Fixed string left over from
86            copying.
87    
88            * Extensions/bboxdump/bboxdump.py (bboxdump):
89            Use layer.ShapeStore().AllShapes() to loop over shapes instead of
90            xrange(layer.NumShapes()). Compile the bboxmessage from a list
91            of formatted outputs (string.join) instead of appending to the
92            message. Two progress bar dialogs to report progress on the sometimes
93            lenghty processing.
94    
95    2004-04-22  Frank Koormann  <[email protected]>
96    
97            New Extension to dump bounding boxes of all shapes of the selected
98            layer. An optional column can be specified to group the objects,
99            in this case the bounding box is a union of the separate boxes.
100            Dump can be displayed in a ScrolledMessageDialog or written to file.
101            The Extension is simply a combination of available and well tested
102            Thuban functionality.
103    
104            * Extensions/bboxdump/__init__.py: New: Init to make this
105            directory a package.
106    
107            * Extensions/bboxdump/bboxdump.py: New: Dump bounding boxes of
108            all shapes of the selected layer.
109    
110    2004-04-22  Jan-Oliver Wagner <[email protected]>
111    
112            * Thuban/UI/classgen.py (GenUniquePanel.__init__): Fixed two
113            strings to be i18n now.
114    
115    2004-04-18  Jan-Oliver Wagner <[email protected]>
116    
117            Changing popup menu of legend from direct building
118            to using the Menu construction as used for the mainwindow.
119    
120            * Thuban/UI/mainwindow.py: New method commands: layer_to_top,
121            layer_to_bottom, layer_visibility
122            (MainWindow.LayerToTop): New. Put current layer to the top.
123            (MainWindow.LayerToBottom): New. Put current layer to bottom.
124            (MainWindow.HideLayer, MainWindow.ShowLayer, _has_visible_map):
125            Replace 1,0 by True, False.
126            (MainWindow.ToggleLayerVisibility): New. Toggle visibility of
127            current layer.
128            (MainWindow.LayerShowTable): Removed raising of dialog.
129            (_has_selected_layer_visible): New. Support function.
130    
131            * Thuban/UI/legend.py: ID_POP_xxx: removed.
132            (LegendPanel.__init__): Removed EVT_MENU bindings.
133            (LegendTree._OnRightClick): Replace direct creation of
134            menu via wx Classes by applying the menu definition
135            as of Menu class of menu.py.
136            
137    2004-04-16  Jan-Oliver Wagner <[email protected]>
138    
139            * Thuban/UI/exceptiondialog.py (ExceptionDialog.dialog_layout): Improved
140        button string to stronger clearify that Thuban will be closed when hitting
141            the button.
142    
143            * Thuban/UI/mainwindow.py (MainWindow.LayerShowTable): Added docstring.
144            Now for layers without a ShapeStore a corresponding message is given
145            to the user, that this layer has no table to show.
146    
147    2004-04-15  Martin Schulze  <[email protected]>
148    
149            * Extensions/wms/layer.py (WMSLayer.setWMSFormat): Need to
150            recalculate the format for the internal render engine as well.
151    
152            * Extensions/wms/properties.py (wmsProperties): First start for a
153            properties dialog.  It's functional for a first selection of
154            layers, but still has some weired wxWidgets/GTK problems but
155            beautification can be done later.
156    
157            * Extensions/wms/layer.py: Added more documentation
158            (WMSLayer.getFormats): New: Return list of supported image formats
159            by the WMS server
160            (WMSLayer.getLayers): New: Return the list of layer names
161            supported by the WMS server
162            (WMSLayer.getLayerTitle): New: Return the title of the named layer
163            (WMSLayer.getWMSFormat): New: Return the image format that is used
164            for WMS GetMap requests
165            (WMSLayer.setWMSFormat): New: Set the image format that is used
166            for WMS GetMap requests
167            (WMSLayer.__init__): Move away from using only one layer to using
168            a list of layers (unsorted at the moment, though).
169            (WMSLayer.getVisibleLayers): New: Return the list of names for all
170            visible layers
171            (WMSLayer.setVisibleLayers): New: Set the list of names for all
172            visible layers
173    
174            * Extensions/wms/wms.py: Moved the WMS layer into layer.py in
175            order to establish a clean structure.
176    
177            * Extensions/wms/layer.py: Moved the WMS layer into a file on its
178            own in order to establish a clean structure.
179    
180    2004-04-13  Martin Schulze  <[email protected]>
181    
182            * Extensions/wms/parser.py (WMSCapabilitiesParser.grok): Added
183            support for oldstyle (WMS 1.0 apparently) image format
184            specification.
185    
186            * Extensions/wms/wms.py (WMSLayer.calcFormat): Reduce the list of
187            supported graphic formats back to JPEG and BMP, PNG and others are
188            too *cough* experimental...  Sorry, I meant to filter this out
189            before I committed this part.  This should make the WMS extension
190            run from CVS again.
191            (wms_dialog): Reset an empty URL to None so that the subsequent
192            program can depend on this, since the dialog will indeed return an
193            empty URL, causing another declaration of love by Python.
194    
195            * Extensions/wms/parser.py (WMSCapabilitiesParser.getLayerBBox):
196            Whenever a native BoundingBox request cannot be fulfilled, check
197            whether the requested SRS is EPSG:3426, in which case return the
198            LatLonBoundingBox values.
199    
200            * Extensions/wms/test/test_parser.py
201            (TestWMSCapabilitiesParser.test_LayerSRS): Added a test for
202            ignoring AUTO:* SRS.
203            (TestWMSCapabilitiesParser.test_LatLonBoundingBoxes_as_bboxes):
204            Added another test method to test whether the LatLonBoundingBox
205            values will be returned if BoundingBox values are requested with
206            SRS set to EPSG:3426.
207    
208            * Extensions/wms/parser.py (WMSCapabilitiesParser.peekLayers):
209            Added rudimentary support for non-EPSG SRS, i.e. ignore them for
210            the moment by placing them into a variable which is currently
211            unused.  Also test whether the EPSG SRS is numerical as it should
212            be and add an error message if it is not.
213    
214            * Extensions/wms/test/sample.xml: Added AUTO:* SRS since they
215            appear in the real world as well.  Since we cannot handle them yet
216            (OGCLib can't either), we will ignore them for the moment.
217    
218            * Extensions/wms/parser.py: Use a variable for denoting the sample
219            filename
220            (WMSCapabilitiesParser.peekLayers): Added support for error
221            messages during grok().  They will be aggregated in an array and
222            may be displayed later.  We may have to add a classification
223            "Warning" and "Error" to this.  That requires more experience,
224            though, since not every error may be lethal.
225    
226            * Thuban/UI/mainwindow.py (MainWindow.LayerShowTable): Raise the
227            ShowTable() dialog/frame when the user attempts to display it
228            while it has been opened before already and not closed again.
229    
230    2004-04-11  Martin Schulze  <[email protected]>
231    
232            * Extensions/wms/infodialog.py: Adjusted the class documentation
233    
234            * Extensions/wms/wms.py (WMSLayer.__init__, WMSLayer.GetMapImg):
235            Switch to using Thuban{Begin,End}BusyCursor instead of the pure
236            wxWidgets variants.
237            (WMSLayer.__init__): The epsg_id variable is named top_srs now.
238    
239            * Extensions/wms/infodialog.py: Added an information dialog that
240            will display various information about the WMS current resource,
241            so that additional information such as the title, the abstract,
242            fees and access constraints can be displayed for the user if they
243            are documented in the WMS XML.
244    
245    2004-04-10  Martin Schulze  <[email protected]>
246    
247            * Extensions/wms/parser.py (WMSCapabilitiesParser.grok): Adjusted
248            string handling.  It's "foo".lower() and not lower(foo) without
249            lower imported from strings or something.
250    
251            * Extensions/wms/wms.py (WMSLayer): Incorporated WMSCapabilities
252            from capabilities.py and parser.py.  Implement priority list for
253            supported graphics formats, take care of wbmp != bmp.  PNG, TIFF
254            and GIF are supported here, but not yet by main Thuban.  Hence,
255            support for them may be removed later.  Special contribution to
256            usability: get wxWidgets to change the cursor when we're waiting
257            for data from the network so the user won't start to worry.  This
258            causes a redrawing error/warning, though.
259    
260            * Extensions/wms/parser.py (WMSCapabilitiesParser.grok): Unlink
261            the DOM object.
262    
263    2004-04-01  Martin Schulze  <[email protected]>
264    
265            * Extensions/wms/capabilities.py: Adjusted documentation
266            (WMSCapabilities.__init__): Improved documentation, fixed syntax
267            (WMSCapabilities.saveCapabilities): Only catch IOError when
268            handling files
269            (WMSCapabilities.loadCapabilities): Only catch IOError when
270            handling files
271            __main__: corrected variable naming
272            (WMSCapabilities.fetchCapabilities,loadCapabilities): Make this
273            class a specialisation of WMSCapabilitiesParser as well.  Also
274            execute grok() after loading or fetching capabilities, if that
275            went well, so that subsequent calls can already access the data.
276            (WMSCapabilities.getVersion): Export the used version of the
277            GetCapabilities request, so we can use it for subsequent calls,
278            i.e. for GetMap requests.
279            (WMSCapabilities.fetchCapabilities): Added proper error handling
280            when the GetCapabilities request failed, so that the surrounding
281            program can act accordingly.
282    
283    2004-03-30  Martin Schulze  <[email protected]>
284    
285            * Extensions/wms/parser.py (WMSCapabilitiesParser.getLayerSRS):
286            Adjusted the getLayerSRS method to return the list of SRSes
287            extracted from <SRS> elements instead of <BoundingBox> elements.
288            Added a bit of documentation as well.
289            (WMSCapabilitiesParser.checkLayerSRS): Removed integrity test
290            since it was only implemented due to a misunderstanding.
291    
292            * Extensions/wms/test/test_parser.py
293            (TestWMSCapabilitiesParser.test_LayerSRS): Adjust the tests to
294            reflect the corrected interpretation of the standard: i.e. a layer
295            does not have to define a BoundingBox for all SRSes it supports.
296            Hence the <SRS></SRS> specification is authoritative, not the list
297            of BoundingBoxes.
298            (TestWMSCapabilitiesParser.test_BoundingBoxes): Added a new test
299            to ensure None is returned for a non-existing SRS.
300            (TestWMSCapabilitiesParser.test_grok): Removed test_grok method
301            since it is not applicable anymore.  Listing more SRSes in <SRS>
302            elements is valid according to the specs.
303    
304    2004-03-26  Bernhard Reiter <[email protected]>
305    
306            * README: Nicer formatting of text. Improved descriptions.
307            Reflected wxWidgets name change.
308            
309            * Thuban/UI/about.py: Extended copyright to 2004 and added
310            information about the thuban-devel mailinglist.
311    
312    2004-03-24  Martin Schulze  <[email protected]>
313    
314            * Extensions/wms/capabilities.py: Renamed the class to contain
315            'WMS', also added a linebreak where required
316    
317            * Extensions/wms/parser.py: Finally added the XML parser for the
318            GetCapabilities response.
319    
320            * Extensions/wms/test/sample.xml: Adjusted the sample file so that
321            <SRS> elements match the <BoundingBox> elements, except for the
322            layer 'beschriftung'.
323    
324            * Extensions/wms/test/test_parser.py: Encode non-ascii strings
325            since Python uses unicode strings internally, otherwise
326            comparisons will fail.  Removed tests for getLayerBBoxSRS() since
327            the SRS will be calculated anyway and this method is obsoleted by
328            getLayerSRS().  Denote SRS as strings and not as cardinal numbers.
329            Move loading the sample file into the setUp method.  Added a test
330            for finding the integrity problem in the sample response.
331            Improved formatting.
332    
333            * Extensions/wms/domutils.py: Added convenience routines for
334            handling of Document Object Model (DOM) nodes.
335    
336            * Extensions/wms/test/test_domutils.py: Added a test for the
337            domutils module
338    
339    2004-03-19  Martin Schulze  <[email protected]>
340    
341            * Extensions/wms/test/test_parser.py (TestWMSCapabilitiesParser):
342            Moved path detection and adding into a module of its own,
343            adjustpath, which exports thubandir as main Thuban directory.
344    
345            * Extensions/wms/test/test_ogclib.py (TestWMSLib): Moved path
346            detection and adding into a module of its own, adjustpath, which
347            exports thubandir as main Thuban directory.  Reorganised the
348            module in order to support the SkipTest feature for Thuban test
349            cases.
350    
351            * Extensions/wms/test/adjustpath.py: Moved path detection and
352            adding into a module of its own.
353    
354    2004-03-18  Martin Schulze  <[email protected]>
355    
356            * Extensions/wms/test/test_parser.py: Added another test for
357            checking whether the WMS XML parser (to be implemented) returns
358            the information we expect.  This requires a sample WMS WML file
359            (sample.xml) which has been extracted from the frida server and
360            "improved" manually.
361    
362            * Extensions/wms/test/test_ogclib.py: Added legacy code to add the
363            main Thuban directory to the path in order to be able to import
364            random modules.  Adjusted the PyOGCLib detection to reuse the
365            information gathered.  Also added a note about the PYTHONPATH
366            environment variable.
367    
368            * Extensions/wms/test/test_ogclib.py: The format specification is
369            a mime-type, not a graphic format, hence image/jpeg wou ld be the
370            proper format and not JPEG.  We'll also have to take care of the
371            encoding of / as %2F.
372    
373    2004-03-16  Martin Schulze  <[email protected]>
374    
375            * Extensions/wms/test/test_ogclib.py: Added a (hopefully)
376            comprehensive test for the getMapURL method, built compare URLs
377            according to the documentation in OGC 01-068r3
378    
379            * Extensions/wms/capabilities.py (WMSCapabilities): Added the
380            class WMSCapabilities to manage capabilites, will incorporate
381            parsing the capabilities response and provide details for other
382            classes.
383    
384    2004-03-12  Bernhard Herzog  <[email protected]>
385    
386            Support views in addition to normal tables in the postgis
387            shapestore
388    
389            * Thuban/Model/postgisdb.py
390            (PostGISShapeStore._fetch_table_information): Add a fallback for
391            the case where the table name is not in the geometry_columns
392            table.  This is usually the case for views.  Also, set
393            self.shapestore here.
394            (PostGISShapeStore.ShapeType): No need to query the database all
395            the time.  The shape type is now determined in
396            _fetch_table_information
397    
398            * test/postgissupport.py (PostgreSQLServer.new_postgis_db)
399            (PostgreSQLServer.get_static_data_db, PostGISDatabase.__init__):
400            New parameter to specify views.
401            (PostGISDatabase.has_data): Also compare the views.  New views
402            parameter
403            (PostGISDatabase.initdb): Create the views.
404            (PostgreSQLServer.get_default_static_data_db): Add the v_landmarks
405            view
406    
407            * test/test_postgis_db.py
408            (TestPostGISShapestorePointFromViews): New.  Test a
409            PostGISShapeStore with a view
410            (TestPostGISShapestorePointOIDAsGIDColumn.setUp): Pass the name of
411            the geometry_column explicitly to test whether that works
412    
413    2004-03-12  Bernhard Herzog  <[email protected]>
414    
415            Final step for explicit id/geometry columns: Loading and saving
416    
417            * Resources/XML/thuban-1.1.dtd: New.  Derived from thuban-1.0.dtd
418            with the following changes:
419            (dbshapesource): Two new attributes id_column and geometry_column
420    
421            * Thuban/Model/save.py (SessionSaver.write): Use the new dtd
422            (SessionSaver.write_session): Use the new namespace
423            (SessionSaver.write_data_containers): Write the new dbshapesource
424            parameters
425    
426            * Thuban/Model/load.py (SessionLoader.__init__): New namespace for
427            the new file format version
428            (SessionLoader.start_dbshapesource): Handle the new db parameters
429    
430            * test/test_save.py: Update to the new dtd and namespace
431            (SaveSessionTest.test_save_postgis): Update the NonConnectionStore
432            mock object to provide a working IDColumn method.
433    
434            * test/test_load_1_0.py: New.  Copy of the test_load.py before
435            today's changes but with the round-trip tests removed.
436    
437            * test/test_load_0_9.py: Update doc-string.
438    
439            * test/test_load.py: Update all .thuban files to the new dtd and
440            namespace.
441            (TestPostGISLayer.file_contents): Add the new dbshapesource
442            paramters
443    
444    2004-03-11  Bernhard Herzog  <[email protected]>
445    
446            Next step for explicit id/geometry columns: User interaction
447    
448            * Thuban/UI/dbdialog.py (ChooseDBTableDialog.__init__): Rework how
449            the dialog is constructed. Add combo boxes to select id and
450            geometry column.  Rename some instance variables.
451            (ChooseDBTableDialog.GetTable): Return id and geometry column
452            names
453            (ChooseDBTableDialog.OnTableSelect): New. Event handler for
454            selections in the table list
455    
456            * Thuban/UI/mainwindow.py (MainWindow.AddDBLayer): Use id_column
457            and geometry_column
458    
459            * Thuban/Model/session.py (Session.OpenDBShapeStore): Add the new
460            parameters for id_column and geometry column of PostGISShapeStore
461            here as well.
462    
463            * Thuban/Model/postgisdb.py (type_map): Add ROWID psycog type.
464            (_raw_type_map): New. Map raw PostgreSQL type ints to thuban types
465            (PostGISConnection.GeometryTables): Use a better query to
466            determine which relations in the database might be usable for
467            shapestores.  Now supports views as well but is more PostgreSQL
468            specific
469            (PostGISConnection.table_columns): New. Somewhat experimental
470            method to let the db dialogs provide lists of columns to users so
471            that they can select id and geometry columns.
472            (PostGISTable.__init__): The default value of the id_column
473            parameter is now None it still means "gid" effectively, though.
474            (PostGISTable.IDColumn): New introspection method to return a
475            column object for the id column
476            (PostGISShapeStore.GeometryColumn): New introspection method to
477            return a column object for the geometry column
478    
479            * test/test_postgis_db.py
480            (TestPostGISConnection.test_gis_tables_non_empty):
481            Removed. Subsumed by the new:
482            (TestPostGISConnection.test_gis_tables_with_views_and_tables):
483            New. Tes the GeometryTables and table_columns methods with actual
484            tables and views.
485            (PointTests.test_id_column, PointTests.test_geometry_column):
486            New. tests for the new methods.
487            (TestPostGISShapestorePoint.setUp)
488            (TestPostGISShapestorePointSRID.setUp)
489            (TestPostGISShapestorePointExplicitGIDColumn.setUp): Fill the
490            instance variables needed by the new tests
491    
492    2004-03-11  Bernhard Herzog  <[email protected]>
493    
494            * Thuban/UI/classgen.py (GenQuantilesPanel.GetList): The row
495            numbers given to ReadValue are ordinals.
496    
497    2004-03-11  Bernhard Herzog  <[email protected]>
498    
499            Elimiate the requirement for PostGIS tables to have a column
500            called "gid".
501    
502            * Thuban/Model/postgisdb.py (PostGISTable.__init__): New parameter
503            id_column to specify which column to use to identify rows.  Also
504            new instance variables id_column and quoted_id_column
505            (PostGISTable.RowIdToOrdinal, PostGISTable.RowOrdinalToId)
506            (PostGISTable.ReadRowAsDict, PostGISTable.ReadValue)
507            (PostGISTable.SimpleQuery): Use the id column name provided to the
508            constructor instead of "gid"
509            (PostGISShapeStore.__init__): New parameter id_column analogously
510            to PostGISTable.__init__.  This parameter is simply passed through
511            to the base class constructor
512            (PostGISShapeStore._create_col_from_description): Fix typo in
513            doc-string
514            (PostGISShapeStore.Shape, PostGISShapeStore.AllShapes)
515            (PostGISShapeStore.ShapesInRegion): Use the id column name
516            provided to the constructor instead of "gid"
517    
518            * test/postgissupport.py
519            (PostgreSQLServer.get_default_static_data_db): New static table
520            landmarks_point_id with an id column != "gid.  Update the comments
521            a bit.
522            (skip_if_addgeometrycolumn_does_not_use_quote_ident): Fix typo in
523            doc-
524            (upload_shapefile): New parameter gid_column to use a name other
525            than "gid" for the column to store the shape ids
526    
527            * test/test_postgis_db.py (TableTests): New.  Mixin-class
528            containing all tests previously in TestPostGISTable.  The actual
529            tests are the same but the code is a bit more configurable to
530            allow for different id columns etc.
531            (TestPostGISTable): Derive from TableTests now for the actual
532            tests.
533            (TestPostGISTableExplicitGIDColumn): New. Like TestPostGISTable
534            except that it the landmarks_point_id table to test the id_column
535            parameter
536            (PointTests): Extend the doc-string
537            (TestPostGISShapestorePointExplicitGIDColumn)
538            (TestPostGISShapestorePointOIDAsGIDColumn): New classes derived
539            from PointTests to test the explicit id_column parameter.  One
540            tests with the name of the column holding the shape ids, the other
541            uses PostgreSQL's OID column.  For the latter a number of methods
542            have to be overwritten to make them independent of the actual id
543            values.
544    
545    2004-03-08  Silke Reimer  <[email protected]>
546    
547            Update debian directory:
548    
549            * debian/changelog: Added new version.
550            * deiban/rules: Updated management of patches (with cbds)
551            * debian/control: Added cbds to dependencies
552            * debian/patches/*: New. Adds better support for patches of thuban in
553                            debian
554            * debian/menu: Syntax of menu changed slightly
555            * debian/setup.py.patch: removed because it has been moved to
556                            debian/patechs/setup.py.patch
557            
558    
559    2004-02-26  Bernhard Herzog  <[email protected]>
560    
561            Create the Doc/technotes directory for text files with information
562            for developers
563    
564            * Doc/technotes/README: New. README for the technotes
565    
566            * Doc/technotes/coding_guidelines.txt: New. Coding guidelines for
567            Thuban
568    
569            * Doc/technotes/release_process.txt: New. Used to be
570            HOWTO-Release.  Now slightly adapted to technote formatting style.
571    
572            * HOWTO-Release: Removed.  It's contents are now in
573            Doc/technotes/release_process.txt
574    
575    2004-02-25  Bernhard Herzog  <[email protected]>
576    
577            * libraries/thuban/wxproj.cpp (get_wx_version): New.  Return the
578            version of wxWindows the module was compiled with so we can check
579            that against the wxPython version.
580    
581            * Thuban/version.py (thuban_branch, thuban_release): New variables
582            controlling which and how Thuban versions are shown.  See the
583            comments for details.
584            (verify_versions): Also check that the wx version that wxproj is
585            compiled against matches that of the wxPython we use at runtime
586    
587    2004-02-20  Bernhard Herzog  <[email protected]>
588    
589            * Extensions/wms/wms.py (epsg_code_to_projection): Use
590            get_system_proj_file to read the epsg projections.  The old way
591            depended on the current directory being the top Thuban directory.
592    
593  2004-02-20  Bernhard Herzog  <[email protected]>  2004-02-20  Bernhard Herzog  <[email protected]>
594    
595          * Extensions/svgexport/test/test_svgmapwriter.py          * Extensions/svgexport/test/test_svgmapwriter.py
# Line 4200  Line 4792 
4792          Fix problem of hidden properties dialog under windows after double          Fix problem of hidden properties dialog under windows after double
4793          click on layer tree:          click on layer tree:
4794          The tree control always gets an Expanded / Collapsed event after          The tree control always gets an Expanded / Collapsed event after
4795          the ItemActivated  on double click, which raises the main window again.         We add a second ItemActivated event to the queue, which simply          the ItemActivated  on double click, which raises the main window again.
4796            We add a second ItemActivated event to the queue, which simply
4797          raises the already displayed window.          raises the already displayed window.
4798    
4799          * Thuban/UI/legend.py (LegendTree.__init__): Instance variable          * Thuban/UI/legend.py (LegendTree.__init__): Instance variable

Legend:
Removed from v.2085  
changed lines
  Added in v.2224

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26