/[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 1855 by bh, Wed Oct 22 09:39:53 2003 UTC revision 1967 by bh, Thu Nov 20 18:16:10 2003 UTC
# Line 1  Line 1 
1    2003-11-20  Bernhard Herzog  <[email protected]>
2    
3            * test/test_proj.py (ProjFileReadTests.test_read_unreadable_file):
4            Skip this test if run under non-posix systems since it only works
5            there
6    
7    2003-11-19  Bernhard Herzog  <[email protected]>
8    
9            * Thuban/Model/resource.py: Rework the way gdal support is
10            determined so that we can give a reason in the about why gdal is
11            not supported.
12            (gdal_support_status): New. Variable holding a string with the
13            reason for no gdal support
14    
15            * Thuban/UI/about.py (About.__init__): Add the reason why gdal is
16            not supported to the message
17    
18    2003-11-19  Bernhard Herzog  <[email protected]>
19    
20            Remove the old table interface and its test cases
21    
22            * Thuban/Model/table.py (OldTableInterfaceMixin): Removed.
23            (DBFTable, MemoryTable): Do not derive from OldTableInterfaceMixin
24            anymore
25    
26            * Thuban/Model/transientdb.py (TransientTableBase)
27            (AutoTransientTable): Do not derive from OldTableInterfaceMixin
28            anymore
29    
30            * test/test_table.py: Removed since the old interface it tests is
31            gone.
32    
33            * test/runtests.py (main): The old table interface is gone and
34            with it the deprecation warnings so remove the code that turns
35            these warnings into errors
36    
37    2003-11-19  Bernhard Herzog  <[email protected]>
38    
39            * test/test_table.py: Revert to revision 1.5 again. Changing the
40            tests to use the new table interface is completely wrong since the
41            whole purpose of the tests in this module is to test the old
42            interface.
43    
44    2003-11-18  Bernhard Herzog  <[email protected]>
45    
46            * Thuban/Model/postgisdb.py (PostGISConnection.MatchesParameters):
47            New. Test whether the connection matches a set of connection
48            parameters
49    
50            * Thuban/UI/dbdialog.py (DBFrame.conns_changed): Fix doc-string
51            (DBFrame.OnAdd): Use the new MatchesParameters method when looking
52            for existing connections with the same parameters and break out of
53            the loop correctly.
54    
55            * test/test_postgis_db.py (TestBriefDescription)
56            (TestPostGISSimple.test_brief_description): Rename
57            TestBriefDescription to TestPostGISSimple and the test method to
58            test_brief_description so that we can add more test methods.
59            (TestPostGISSimple.test_matches_parameters): New. Test the new
60            MatchesParameters method
61    
62    2003-11-18  Bernhard Herzog  <[email protected]>
63    
64            * Thuban/Lib/connector.py (Publisher): Introduce a new flag,
65            _was_destroyed, to indicate whether an publisher instance has
66            already been destroyed.
67            (Publisher.Unsubscribe): Only disconnect if the publisher has not
68            been destroyed yet.
69            (Publisher.Destroy): Set the _was_destroyed flag to true.
70    
71            * test/test_connector.py
72            (TestPublisher.test_unsubscribe_after_destroy): New. Test that
73            calling Unsubscribe after Destroy doesn't raise an exception
74    
75    2003-11-14  Bernhard Herzog  <[email protected]>
76    
77            * Thuban/UI/identifyview.py (IdentifyView.selected_shape): Fix
78            typo in doc-string
79    
80    2003-11-13  Bernhard Herzog  <[email protected]>
81    
82            Quote table and column names properly for postgis.
83    
84            * Thuban/Model/postgisdb.py (quote_identifier): New. Function to
85            quote an identifier for use in an sql statement
86            (PostGISColumn.__init__): Add the quoted_name attribute
87            (PostGISTable.__init__): New instance variable quoted_tablename
88            (PostGISTable._fetch_table_information): Use the quoted table
89            name. New isntance variable quoted_geo_col with a quoted version
90            of geometry_column
91            (PostGISTable.NumRows, PostGISTable.RowIdToOrdinal)
92            (PostGISTable.RowOrdinalToId): Use the quoted table name
93            (PostGISTable.ReadValue, PostGISTable.ValueRange)
94            (PostGISTable.UniqueValues, PostGISTable.SimpleQuery)
95            (PostGISShapeStore.BoundingBox, PostGISShapeStore.Shape)
96            (PostGISShapeStore.AllShapes, PostGISShapeStore.ShapesInRegion):
97            Use quoted table and column names
98    
99            * test/test_postgis_db.py (TestPostGISSpecialCases)
100            (TestPostGISIgnoredColumns): Rename the class to
101            TestPostGISSpecialCases because that better describes the new
102            cases
103            (TestPostGISSpecialCases.test_unsupported_types)
104            (TestPostGISSpecialCases.test): Rename the method to
105            test_unsupported_types because we need a more descriptive name now
106            that there are more methods
107            (TestPostGISSpecialCases.test_table_name_quoting)
108            (TestPostGISSpecialCases.test_column_name_quoting)
109            (TestPostGISSpecialCases.test_shapestore_name_quoting): New test
110            cases to test quoting of table and column names in PostGISTable
111            and PostGISShapeStore
112    
113            * test/postgissupport.py
114            (skip_if_addgeometrycolumn_does_not_use_quote_ident): New. Skip if
115            AddGeometryColumn desn't support table or column names with sapces
116            or double quotes
117    
118    2003-11-12  Jan-Oliver Wagner <[email protected]>
119    
120            * Extensions/wms/__init__.py: New: Init to make this
121            directory a package.
122    
123            * Extensions/wms/wms.py: New: Provide layers via OGC WMS.
124    
125    2003-11-11  Bernhard Herzog  <[email protected]>
126    
127            * Thuban/Model/resource.py (EPSG_DEPRECATED_PROJ_FILE): New.
128            Constant for the file woth deprecated epsg projections
129            (get_system_proj_file): Update doc-string
130    
131            * Thuban/UI/projdialog.py (ProjFrame.build_dialog): Add a space
132            above the EPS widgets, introduce a check box for the deprecated
133            eps projections and a label for the epsg widgets
134            (ProjFrame._OnShowEPSG): Handle the deprecated EPSG projections
135            too
136    
137    2003-11-11  Bernhard Herzog  <[email protected]>
138    
139            Avoid warnings when run under Python 2.3
140    
141            * Thuban/UI/baserenderer.py (BaseRenderer.draw_point_shape)
142            (BaseRenderer.draw_label_layer): Coordinates must be ints.
143    
144            * Thuban/UI/renderer.py (MapRenderer.make_point): Turn this into a
145            real method so that we can convert to int.
146            (MapRenderer.label_font): The font size mist be an int.
147    
148            * Thuban/UI/common.py (Color2wxColour): The color values must be
149            ints. Also, remove the unnecessary asserts.
150    
151            * test/test_load_0_8.py (TestUnicodeStrings.file_contents)
152            (TestUnicodeStrings.test): Python source code should not contain
153            non-ascii characters unless an encoding is specified in the file.
154            Therefore use \x escapes in the string literals for non-ascii
155            characters.
156    
157    2003-11-11  Bernhard Herzog  <[email protected]>
158    
159            * Thuban/Model/resource.py (get_system_proj_file): Add a filename
160            parameter so that this function can be used for all proj files in
161            Resource/Projections
162            (DEFAULT_PROJ_FILE, EPSG_PROJ_FILE): New. Predefined filenames for
163            get_system_proj_file
164    
165            * Thuban/UI/projdialog.py (ProjFrame.__init__): Instead of one
166            ProjFile self.__sysProjFile use a dictionary of system ProjFile
167            objects self._sys_proj_files
168            (ProjFrame.build_dialog): Adapt to the new changes in the
169            ProjectionList constructor. Add a check button to toggle whether
170            EPSG projections are shown
171            (ProjFrame._OnShowEPSG): New. Handler for the epsg check button
172            events.
173            (ProjFrame.load_user_proj, ProjFrame.load_system_proj): Only show
174            the busy cursor if the files have not yet been loaded by the
175            dialog.
176            (ProjFrame.load_system_proj): Add a parameter for the name of the
177            proj file. Maintain the dictionary of system projections
178            self._sys_proj_files
179    
180            * Thuban/UI/projlist.py (ProjectionList): Merge the system_projs,
181            user_projs parameters into one parameter proj_files which is a
182            list of proj files.
183            (ProjectionList._subscribe_proj_files)
184            (ProjectionList._unsubscribe_proj_files): New. Move
185            subscription/unsubscription of projfile messages to separate
186            methods
187            (ProjectionList.Destroy): The unsubscribe is now done in
188            _unsubscribe_proj_files
189            (ProjectionList.update_projections): We now have a list of proj
190            file objects
191            (ProjectionList.SetProjFiles): New method to set a new list of
192            proj file objects
193    
194            * test/test_proj.py (ProjFileReadTests.test_get_system_proj_file):
195            Specify explicitly which system proj file to load.
196    
197    2003-11-11  Bernhard Herzog  <[email protected]>
198    
199            * Thuban/Model/load.py (SessionLoader.Destroy): New. Clear all
200            instance variables to cut cyclic references. The GC would have
201            collected the loader eventually but it can happen that it doesn't
202            run at all until thuban is closed (2.3 but not 2.2 tries a bit
203            harder and forces a collection when the interpreter terminates)
204            (load_session): Call the handler's Destroy method to make sure
205            that it gets garbage collected early. Otherwise it will be
206            collected very late if at all and it holds some references to e.g.
207            shapestores and the session which can lead to leaks (of e.g. the
208            temporary files)
209    
210            * test/test_load.py (TestSingleLayer.test_leak): New. test for the
211            resource leak in load_session
212    
213    2003-11-10  Bernhard Herzog  <[email protected]>
214    
215            * Thuban/UI/baserenderer.py: Add a way to specify how layers in
216            extensions are to be rendered.
217            (_renderer_extensions): New. List with renderer for layers in
218            extensions
219            (add_renderer_extension): New. Add a renderer extension
220            (init_renderer_extensions): New. Init the renderer extensions
221            (BaseRenderer.render_map_incrementally): Search
222            _renderer_extensions for how to draw unknown layer types
223            (BaseRenderer.draw_raster_data): Add format parameter so that
224            formats other than BMP can be drawn
225            (BaseRenderer.draw_raster_layer): Pass an explicit format to
226            draw_raster_data
227    
228            * Thuban/UI/renderer.py (raster_format_map): New. Mapping form the
229            strings of the format parameter of draw_raster_data method to wx
230            constants
231            (MapRenderer.draw_raster_data): Add the format parameter and use
232            raster_format_map to map it to the right wxwindows constant for
233            wxImageFromStream
234    
235            * test/test_baserenderer.py (SimpleRenderer.draw_raster_data): Add
236            the format parameter and record it
237            (TestBaseRenderer.test_raster_no_projection): check the format
238            paramter of the draw_raster_data method
239            (TestBaseRenderer.test_renderer_extension): New. Test the renderer
240            extension facility
241    
242    2003-11-07  Bernhard Herzog  <[email protected]>
243    
244            Tweak the usage of the sqlite database to make common use cases
245            more responsive. In most cases copying the data to the sqlite
246            database takes so long that using sqlite doesn't have enough
247            advantages.
248    
249            * Thuban/Model/transientdb.py (TransientTableBase.ValueRange): Add
250            comments about performance and query the min and max in separate
251            statements because only that way will indexes be used.
252            (TransientTableBase.UniqueValues): Add some comments about
253            performance.
254            (AutoTransientTable.ValueRange, AutoTransientTable.UniqueValues):
255            Do not copy the data to the transient DB but use the transient
256            copy if it exists. See the new comments for the performance trade
257            offs
258    
259            * test/test_transientdb.py
260            (TestTransientTable.test_auto_transient_table): Make sure that the
261            data is copied to the transient database at some point.
262    
263    2003-11-03  Bernhard Herzog  <[email protected]>
264    
265            * Thuban/Model/data.py (ShapefileStore.ShapesInRegion): Bind some
266            globals to locals so that it's a bit faster
267    
268    2003-11-03  Bernhard Herzog  <[email protected]>
269    
270            * Thuban/UI/baserenderer.py
271            (BaseRenderer.draw_shape_layer_incrementally): Use the ReadValue
272            method. ReadValue is faster than ReadRowAsDict since it only reads
273            one cell especially now that the dbf file objects actually
274            implement it.
275    
276            * Thuban/Model/table.py (DBFTable.ReadValue): Use the new
277            read_attribute method of the dbf objects
278    
279    2003-11-03  Bernhard Herzog  <[email protected]>
280    
281            * Extensions/profiling/profiling.py (popup_dialog_box): New config
282            variable to indicate whether the result should be shown in a
283            dialog box
284            (profile_screen_renderer, time_screen_renderer): Only show a
285            dialog box if popup_dialog_box is true.
286            (profile_screen_renderer): Flush stdout after the printing the
287            first part of the "profiling..." message
288    
289            * Thuban/UI/baserenderer.py
290            (BaseRenderer.draw_shape_layer_incrementally): Cache the pens and
291            brushes for the groups so that they're not created over and over
292            again
293    
294            * Thuban/Model/classification.py (Classification.__getattr__)
295            (Classification._compile_classification)
296            (Classification._clear_compiled_classification): New. Methods to
297            manage a 'compiled' representation of the classification groups
298            which is created on demand
299            (Classification.InsertGroup, Classification.RemoveGroup)
300            (Classification.ReplaceGroup): reset the compiled representation
301            (Classification.FindGroup): Use the compiled representation to
302            find the matching group
303            (ClassGroupRange.GetRangeTuple): New. Return the range as a tuple
304    
305    2003-10-31  Bernhard Herzog  <[email protected]>
306    
307            * Thuban/Model/classification.py (Classification.SetDefaultGroup):
308            Send a CLASS_CHANGED message
309            (Classification.RemoveGroup): Send a CLASS_CHANGED message and do
310            not return the removed group since it wasn't used.
311    
312            * test/test_classification.py
313            (TestClassification.test_set_default_group): New. Test the
314            SetDefaultGroup method
315            (TestClassification.test_insert_group): New. Test the InsertGroup
316            method
317            (TestClassification.test_remove_group): New. Test the RemoveGroup
318            method
319            (TestClassification.test_replace_group): New. Test the
320            ReplaceGroup method
321    
322    2003-10-31  Bernhard Herzog  <[email protected]>
323    
324            * test/test_classification.py (TestClassification.setUp):
325            Subscribe to the CLASS_CHANGED messages
326            (TestClassification.tearDown): New. Destroy the classification
327            properly
328            (TestClassification.test_defaults): Add tests for the default line
329            width and whether no messages were sent yet
330            (TestClassification.test_set_default_properties): Add tests for
331            messages and setting the default line width
332            (TestClassification.test_add_singleton)
333            (TestClassification.test_add_range)
334            (TestClassification.test_multiple_groups): Add tests for messages
335    
336    2003-10-31  Bernhard Herzog  <[email protected]>
337    
338            Some more refactoring in preparation for new tests:
339    
340            * test/test_classification.py (TestClassification.setUp): New.
341            Instantiate the classification here. Update the test methods
342            accordingly.
343            (TestClassification.test_multiple_groups): Make sure that the two
344            singletons matching 1 are considered different.
345    
346    2003-10-31  Bernhard Herzog  <[email protected]>
347    
348            * test/test_classification.py (red, green, blue): New. These
349            constants were used in several cases. Update the relevant methods.
350            (TestClassification.test_defaults)
351            (TestClassification.test_set_default_properties)
352            (TestClassification.test_add_singleton)
353            (TestClassification.test_add_range)
354            (TestClassification.test_multiple_groups)
355            (TestClassification.test_deepcopy): New. These were formerly all
356            part of the single method test.
357            (TestClassification.test_deepcopy): Removed.
358            (TestClassIterator): Removed. The test case is now a method of
359            TestClassification since it tests part of the public interface of
360            Classification
361            (TestClassification.test_iterator): New. Used to be
362            TestClassIterator effectively
363    
364    2003-10-31  Jan-Oliver Wagner <[email protected]>
365    
366            GUIfied the functions of the profiling extension.
367    
368            * /Extensions/profiling/__init__.py: New: Init to make this
369            directory a package.
370    
371            * Extensions/profiling/profiling.py: Moved menu entries to
372            the Extensions menu. Applied _() for strings.
373            (profile_screen_renderer): Catch the detailed printout and present
374            it in a dialog.
375            (time_screen_renderer): Raise a dialog to present the result instead
376            of printing it to stdout.
377    
378    2003-10-31  Bernhard Herzog  <[email protected]>
379    
380            * test/test_classification.py (TestClassGroupProperties)
381            (TestClassGroup, TestClassGroupDefault, TestClassGroupRange)
382            (TestClassGroupSingleton, TestClassIterator, TestClassification):
383            Split TestClassification into several classes, one for each class
384            being tested. TestClassification itself now only tests
385            Classification. This split makes changes to the tests a bit easier
386    
387    2003-10-31  Bernhard Herzog  <[email protected]>
388    
389            * Extensions/profiling/profiling.py: New. Extension to measure
390            Thuban performance
391    
392    2003-10-31  Frank Koormann <[email protected]>
393    
394            Added two items to legend popup menu: Remove Layer and Show Layer Table
395    
396            * Thuban/UI/legend.py (LegendPanel._OnRemoveLayer,
397            LegendPanel._OnShowTable): New event handlers, call the corresponding
398            mainwindow methods.
399            (LegendTree._OnRightClick): Added items to popup menu.
400    
401    2003-10-30  Bernhard Herzog  <[email protected]>
402    
403            * Thuban/UI/dialogs.py (ThubanFrame.__init__): Handle
404            EVT_WINDOW_DESTROY
405            (ThubanFrame.OnDestroy): New. Handler for EVT_WINDOW_DESTROY. Does
406            nothing but is convenient for the derived classes.
407    
408            * Thuban/UI/tableview.py
409            (TableFrame.OnDestroy, LayerTableFrame.OnDestroy): New.
410            Unsubscribe the messages here not in OnClose because that might
411            get called multiple times. Fixes RT #2196
412            (TableFrame.OnClose, LayerTableFrame.OnClose): Removed. Not needed
413            anymore.
414    
415            * README: Update the minimum requirement for wxPython. Since we
416            now use the EVT_WINDOW_DESTROY event, we need at least 2.4.0.4,
417            the version in which that was introduced for all platforms
418    
419    2003-10-30  Frank Koormann <[email protected]>
420    
421            * Thuban/UI/join.py (JoinDialog.OnJoin): Wrapped the major parts of
422            the join process in a ThubanBeginBusyCursor, ThubanEndBusyCursor
423            frame.
424    
425    2003-10-30  Jan-Oliver Wagner <[email protected]>
426    
427            Improved APR import extension, added further EPSG definitions
428            and some cleanup regarding string class.
429    
430            * test/test_proj.py (TestProjection.test_get_projection_units_geo):
431            Added test for alias 'longlat'.
432    
433            * Resources/Projections/epsg-deprecated.proj: New. Contains
434            deprecated EPSG definitions.
435    
436            * Extensions/importAPR/odb.py (ODBBaseObject.TreeInfo): Added
437            the variable names for objects.
438    
439            * Extensions/importAPR/apr.py (APR_BLnSym, APR_BMkSym, APR_BShSym): New.
440            Copied from importAPR and provided with documentation.
441    
442            * Extensions/importAPR/importAPR.py (APR_BLnSym, APR_BMkSym, APR_BShSym):
443            Moved to apr.py.
444            (APR_View): Added object ref 'ITheme'.
445    
446            * Thuban/Lib/fileutil.py, Thuban/UI/proj4dialog.py: Replaced string
447            split function by corresponding use of the string class method.
448    
449            * Thuban/Model/xmlwriter.py: Replaced string replace function by
450            corresponding string method.
451    
452    2003-10-29  Bernhard Herzog  <[email protected]>
453    
454            * Thuban/UI/baserenderer.py
455            (BaseRenderer.draw_shape_layer_incrementally): Speed up the
456            special case of a classification that only has the default group
457    
458    2003-10-27  Bernhard Herzog  <[email protected]>
459    
460            * po/fr.po, po/es.po: Updated translations from Daniel Calvelo
461    
462            * po/de.po: Update.
463    
464            * Thuban/UI/application.py
465            (ThubanApplication.ShowExceptionDialog): Handle translation of the
466            dialog message properly
467    
468    2003-10-27  Bernhard Herzog  <[email protected]>
469    
470            Rework how localization works so that we use wx's translation
471            functions when running Thuban as a normal application but not when
472            we don't need any UI, such as in the test suite. See the comment
473            in Thuban/__init__.py for details
474    
475            * Thuban/__init__.py (_): Add one level of indirection to make the
476            translation handling more flexible and to make it possible to use
477            either wx's translation services or not.
478            (gettext_identity, translation_function_installed)
479            (install_translation_function): New function to help with this
480    
481            * Thuban/UI/__init__.py: Install the wx specific translation
482            function if it's OK to do that
483    
484            * test/support.py (initthuban): Install a dummy translation
485            function so that importing Thuban.UI doesn't install a wx specific
486            one for which would need to import wxPython
487    
488    2003-10-27  Bernhard Herzog  <[email protected]>
489    
490            * HOWTO-Release: Source archives should be created first and the
491            binary packages should be created from the source archives.
492            There's an official debian package now so there's no need to test
493            the rpm on debian anymore
494    
495    2003-10-27  Bernhard Herzog  <[email protected]>
496    
497            Several rendering changes:
498    
499             - Render the selection into a separate bitmap so that only that
500               bitmap needs to be redrawn when the selection changes
501    
502             - Render incrementally showing previews and allowing interaction
503               before rendering is complete
504    
505             - Update the renderer interface a bit. Most parameters of
506               RenderMap are now parameters of the constructor
507    
508            * Thuban/UI/baserenderer.py (BaseRenderer.__init__): Add the map
509            and the update region as parameters. Update the doc-string
510            (BaseRenderer.render_map_incrementally): New. Generator function
511            to renders the map incrementally
512            (BaseRenderer.render_map): Remove the map argument (it's now in
513            the constructor) and simply iterate over the
514            render_map_incrementally generator to draw the map.
515            (BaseRenderer.draw_shape_layer_incrementally)
516            (BaseRenderer.draw_shape_layer): Renamed to
517            draw_shape_layer_incrementally and changed into a generator that
518            yields True every 500 shapes. Used by render_map_incrementally to
519            render shape layers incrementally
520    
521            * Thuban/UI/renderer.py (ScreenRenderer.RenderMap): Removed the
522            map and region parameters which are now in the constructor
523            (ScreenRenderer.RenderMapIncrementally): New. Public frontend for
524            the inherited render_map_incrementally.
525            (BaseRenderer.draw_shape_layer): Removed.
526            (ScreenRenderer.draw_selection_incrementally): New. The selection
527            drawing part of the removed draw_shape_layer as a generator
528            (ScreenRenderer.layer_shapes): Update because of the region
529            parameter change
530            (ExportRenderer.__init__): New. Extend the inherited constructor
531            with the destination region for the drawing
532            (ExportRenderer.RenderMap): Removed the map and region parameters
533            which are now in the constructor
534    
535            * Thuban/UI/view.py (MapCanvas.PreviewBitmap): New. Return a
536            bitmap suitable for a preview in a tool
537            (CanvasPanTool.MouseMove): Use the PreviewBitmap method to get the
538            bitmap
539            (MapPrintout.draw_on_dc): Adapt to new renderer interface
540            (MapCanvas.OnPaint): Handle drawing the selection bitmap if it
541            exists
542            (MapCanvas.OnIdle): Update the logic to deal with incremental
543            rendering and the selection bitmap
544            (MapCanvas._do_redraw): Handle the instantiation of the render
545            iterator and the redraws during rendering
546            (MapCanvas._render_iterator): New. Generator to incrementally
547            redraw both bitmaps
548            (MapCanvas.Export): Adapt to new renderer interface.
549            (MapCanvas.full_redraw): Reset the selection bitmap and the
550            renderer iterator too
551            (MapCanvas.redraw_selection): New. Force a redraw of the selection
552            bitmap
553            (MapCanvas.shape_selected): Only redraw the selection bitmap
554    
555            * test/test_baserenderer.py
556            (TestBaseRenderer.test_polygon_no_projection)
557            (TestBaseRenderer.test_raster_no_projection)
558            (TestBaseRenderer.test_point_map_projection)
559            (TestBaseRenderer.test_point_layer_and_map_projection)
560            (TestBaseRenderer.test_point_layer_projection)
561            (TestBaseRenderer.test_point_with_classification): Adapt to new
562            renderer interface
563    
564    2003-10-24  Bernhard Herzog  <[email protected]>
565    
566            * libraries/thuban/wxproj.cpp (draw_polygon_shape)
567            (point_in_polygon_shape, shape_centroid): Raise an exception if
568            the shape can't be read. Previously invalid shape ids would lead
569            to a segfault.
570    
571            * test/test_wxproj.py (TestShapeCentroid.test_invalid_shape_id):
572            New. test whether an exception is raised for invalid shape ids
573    
574    2003-10-24  Jan-Oliver Wagner <[email protected]>
575    
576            * Thuban/Model/proj.py (Projection.GetProjectedUnits): Added 'longlat'
577            as alias for 'latlong'.
578    
579            * Thuban/UI/projdialog.py (ProjFrame.__init__): Added 'longlat'
580            as alias for 'latlong'.
581    
582    2003-10-24  Jan-Oliver Wagner <[email protected]>
583    
584            * Thuban/UI/projdialog.py (ProjFrame.proj_selection_changed): Set
585            the projection even for the UnknownPanel.
586            (UnknownProjPanel.__init__): Define the text and create the textctrl
587            widget.
588            (UnknownProjPanel._DoLayout): Replaced static text widget by the
589            textctrl created in __init__.
590            (UnknownProjPanel.SetProjection): Set the text for the text ctrl
591            including the parameters of the projection.
592            
593    2003-10-24  Jan-Oliver Wagner <[email protected]>
594    
595            * Resources/Projections/epsg.proj: New. This is a list of
596            EPSG codes with parameters for proj. The list has been
597            generated using devtools/create_epsg.py based on the
598            file nad/epsg of the proj 4.4.7 package. Four projection
599            definitions have been deleted as they are not accepted by proj:
600            "CH1903+ / LV95", "Bern 1898 (Bern) / LV03C", "CH1903 / LV03"
601            and "HD72 / EOV".
602    
603  2003-10-22  Bernhard Herzog  <[email protected]>  2003-10-22  Bernhard Herzog  <[email protected]>
604    
605          Some more tweaks to the projection dialog which should fix RT          Some more tweaks to the projection dialog which should fix RT

Legend:
Removed from v.1855  
changed lines
  Added in v.1967

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26