Check-in [b3b307832b]
Not logged in

Many hyperlinks are disabled.
Use anonymous login to enable hyperlinks.

Overview
Comment:MapView: initial implementation
Timelines: family | ancestors | descendants | both | trunk
Files: files | file ages | folders
SHA1: b3b307832ba8e008a6e130ce121e4c513ee74c5f
User & Date: sandro 2017-02-05 19:33:36
Context
2017-02-05
19:39
adding a missing source check-in: f3509fff0c user: sandro tags: trunk
19:33
MapView: initial implementation check-in: b3b307832b user: sandro tags: trunk
2017-01-04
13:49
adding a missing source: WmsDialog.cpp check-in: e1df71334f user: sandro tags: trunk
Changes
Hide Diffs Unified Diffs Ignore Whitespace Patch

Changes to Classdef.h.

128
129
130
131
132
133
134

135
136
137
138
139
140
141
...
152
153
154
155
156
157
158








159
160
161
162
163
164
165
...
213
214
215
216
217
218
219

220




221

222
223
224
225
226
227
228
...
243
244
245
246
247
248
249












250
251
252
253
254
255
256
...
662
663
664
665
666
667
668

669
670
671
672
673
674
675
...
695
696
697
698
699
700
701


702
703
704
705
706
707
708
...
882
883
884
885
886
887
888







889
890
891
892
893
894
895
896
897
898
899
900

901
902
903
904
905

906
907
908
909
910
911
912
913
...
914
915
916
917
918
919
920



921
922
923
924
925
926
927
928

929
930
931
932
933
934
935
...
951
952
953
954
955
956
957











958
959
960
961
962
963
964
....
1040
1041
1042
1043
1044
1045
1046

1047
1048

1049
1050
1051
1052




1053
1054
1055
1056
1057
1058
1059
1060
1061




1062
1063
1064
1065
1066
1067
1068
....
1070
1071
1072
1073
1074
1075
1076

1077


1078
1079
1080
1081
1082
1083
1084


1085
1086
1087
1088
1089
1090
1091
....
1101
1102
1103
1104
1105
1106
1107




1108
1109
1110
1111
1112
1113
1114
....
1626
1627
1628
1629
1630
1631
1632

1633
1634
1635
1636
1637
1638
1639
....
1660
1661
1662
1663
1664
1665
1666


1667
1668
1669
1670
1671
1672
1673
....
1698
1699
1700
1701
1702
1703
1704


1705
1706
1707
1708
1709
1710
1711
....
1740
1741
1742
1743
1744
1745
1746

1747
1748
1749
1750
1751
1752


1753
1754




1755
1756
1757
1758
1759
1760
1761
....
1773
1774
1775
1776
1777
1778
1779

1780
1781
1782
1783
1784
1785



1786
1787
1788
1789
1790
1791
1792
....
1816
1817
1818
1819
1820
1821
1822



1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835

1836
1837
1838
1839
1840
1841


1842
1843
1844
1845
1846
1847
1848
....
1872
1873
1874
1875
1876
1877
1878


1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891


1892
1893
1894
1895
1896
1897




1898
1899
1900
1901
1902
1903
1904
....
1926
1927
1928
1929
1930
1931
1932
1933


1934
1935
1936
1937
1938
1939
1940
....
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112

2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128

2129
2130
2131
2132
2133
2134
2135
2136
2137
....
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153

2154
2155
2156
2157
2158

2159
2160
2161
2162
2163
2164
2165
2166
....
2201
2202
2203
2204
2205
2206
2207

2208
2209
2210
2211
2212

2213
2214
2215
2216
2217
2218
2219




2220
2221
2222
2223
2224
2225
2226
....
2271
2272
2273
2274
2275
2276
2277




2278
2279
2280
2281
2282
2283
2284
....
2755
2756
2757
2758
2759
2760
2761
























































































2762
2763
2764
2765
2766
2767
2768
....
3402
3403
3404
3405
3406
3407
3408

3409
3410
3411
3412
3413
3414
3415
....
3471
3472
3473
3474
3475
3476
3477

3478
3479
3480
3481
3482
3483
3484
....
3902
3903
3904
3905
3906
3907
3908






3909
3910
3911















3912
3913
3914
3915
3916
3917
3918
....
3947
3948
3949
3950
3951
3952
3953
3954

3955
3956
3957
3958
3959
3960
3961
....
3962
3963
3964
3965
3966
3967
3968
3969
3970
3971
3972
3973
3974
3975
3976
3977
3978
3979
3980
3981
3982
3983
3984
3985
3986
3987
3988
3989


3990


3991

3992
3993
3994
3995
3996
3997
3998
3999
4000
4001

4002
4003
4004
4005
4006
4007
4008
....
5677
5678
5679
5680
5681
5682
5683

5684
5685
5686
5687
5688
5689
5690
....
5787
5788
5789
5790
5791
5792
5793




5794
5795
5796
5797
5798
5799
5800
....
7011
7012
7013
7014
7015
7016
7017


























7018
7019
7020
7021
7022
7023
7024
....
8188
8189
8190
8191
8192
8193
8194
8195
8196
8197
8198
8199
8200
8201
8202


8203
8204
8205
8206
8207
8208
8209
8210
8211
8212
8213


8214
8215
8216
8217
8218
8219
8220
....
8243
8244
8245
8246
8247
8248
8249
















8250
8251
8252
8253
8254
8255
8256
8257
8258
8259
8260
8261
8262
8263
8264
8265
8266
8267
8268
8269
8270
....
8271
8272
8273
8274
8275
8276
8277


8278
8279
8280
8281
8282
8283
8284
8285
8286
8287
8288
8289
8290
8291
8292
8293
8294
8295
8296
8297


8298
8299
8300
8301
8302
8303
8304
....
8323
8324
8325
8326
8327
8328
8329








8330


















































































































































































































































































































































































































































































































































































8331
8332
8333
8334
8335
8336
8337
....
8975
8976
8977
8978
8979
8980
8981






























8982
8983
8984
8985
8986
8987
8988
....
9883
9884
9885
9886
9887
9888
9889
9890

9891
9892
9893


9894
9895
9896

9897

9898

9899

9900

9901

9902
9903
9904
9905
9906
9907
9908
9909
....
9940
9941
9942
9943
9944
9945
9946
9947
9948
9949
9950
9951
9952
9953
9954
9955
9956
.....
11822
11823
11824
11825
11826
11827
11828





















































































































































































































































































































































































































































  ID_CreateNew,
  ID_Disconnect,
  ID_MemoryDbLoad,
  ID_MemoryDbNew,
  ID_MemoryDbClock,
  ID_MemoryDbSave,
  ID_Vacuum,

  ID_SqlScript,
  ID_QueryViewComposer,
  ID_LoadShp,
  ID_LoadTxt,
  ID_LoadDbf,
  ID_LoadXL,
  ID_VirtualShp,
................................................................................
  ID_Attach,
  ID_SqlLog,
  ID_DbStatus,
  ID_CheckGeom,
  ID_SaneGeom,
  ID_WFS,
  ID_DXF,








  Tree_NewTable,
  Tree_NewView,
  Tree_NewIndex,
  Tree_NewTrigger,
  Tree_NewColumn,
  Tree_NewRasterStyle,
  Tree_ReloadRasterStyle,
................................................................................
  Tree_SldSeRasterStyles,
  Tree_SldSeVectorStyles,
  Tree_ImportRaster,
  Tree_Pyramidize,
  Tree_PyramidizeMonolithic,
  Tree_DePyramidize,
  Tree_RasterDrop,

  Tree_VectorRegister,




  Tree_VectorUnregister,

  Tree_CreateRasterCoverage,
  Tree_UpdateRasterExtent,
  Tree_UpdateRasterExtentAll,
  Tree_UpdateVectorExtent,
  Tree_UpdateVectorExtentAll,
  Tree_Raster_SRIDs,
  Tree_Vector_SRIDs,
................................................................................
  Tree_SimpleLineSymbolizer,
  Tree_SimplePolygonSymbolizer,
  Tree_SimpleTextSymbolizer,
  Tree_CloneTable,
  Tree_RegisterWmsLayer,
  Tree_UnregisterWmsLayer,
  Tree_ConfigureWmsLayer,












  Grid_Clear,
  Grid_All,
  Grid_Column,
  Grid_Row,
  Grid_Copy,
  Grid_Blob,
  Grid_Delete,
................................................................................
  ID_CVG_SAME_RES,
  ID_CVG_VERT_RES,
  ID_CVG_STRICT_RES,
  ID_CVG_MIXED_RES,
  ID_CVG_PATHS,
  ID_CVG_MD5,
  ID_CVG_SUMMARY,

  ID_LOAD_FORCE_SRID,
  ID_LOAD_SRID,
  ID_LOAD_WITH_WORLDFILE,
  ID_LOAD_PYRAMIDIZE,
  ID_LOAD_LIST_DONE,
  ID_LOAD_ABORT,
  ID_LOAD_RASTER_THREAD_FINISHED,
................................................................................
  ID_LOAD_FONT_START,
  ID_LOAD_FONT_STOP,
  ID_LOAD_FONT_SKIP,
  ID_VECTOR_GRID,
  ID_VECTOR_COVERAGE,
  ID_VECTOR_TITLE,
  ID_VECTOR_ABSTRACT,


  ID_VECTOR_SRID_ADD,
  ID_VECTOR_SRID_REMOVE,
  ID_VECTOR_SRID,
  ID_VECTOR_SRID_GRID,
  ID_RASTER_SRID_ADD,
  ID_RASTER_SRID_REMOVE,
  ID_RASTER_SRID,
................................................................................
  ID_WMS_OK,
  ID_WMS_ENABLE_PROXY,
  ID_WMS_PROXY,
  ID_WMS_LIST,
  ID_WMS_LAYER,
  ID_WMS_ENABLE_BGCOLOR,
  ID_WMS_BGCOLOR,







  ID_PANE_MAIN,
  ID_PANE_STROKE1,
  ID_PANE_STROKE2,
  ID_PANE_STROKE3,
  ID_PANE_FILL1,
  ID_PANE_FILL2,
  ID_PANE_POSITION,
  ID_PANE_GRAPHIC,
  ID_PANE_MARK,
  ID_PANE_FONT,
  ID_PANE_PLACEMENT,
  ID_PANE_PREVIEW

};

enum
{
// tree item data types

  MY_TABLE = 0,
  MY_VTABLE,
  MY_VIEW,
  MY_TILE_DATA,
  MY_COLUMN,
  MY_VIEW_COLUMN,
  MY_VIRTUAL_COLUMN,
  MY_GEOMETRY,
................................................................................
  MY_GEOMETRY_INDEX,
  MY_GEOMETRY_CACHED,
  MY_VIEW_GEOMETRY,
  MY_VIEW_GEOMETRY_INDEX,
  MY_VIEW_GEOMETRY_CACHED,
  MY_VIRTUAL_GEOMETRY,
  MY_VIRTUAL_GPKG_GEOMETRY,



  MY_INDEX,
  MY_TRIGGER,
  MY_ATTACHED,
  MY_INT_VARIANT,
  MY_DBL_VARIANT,
  MY_TXT_VARIANT,
  MY_BLOB_VARIANT,
  MY_NULL_VARIANT

};

enum
{
// control IDs for timers
  ID_AUTO_SAVE_TIMER = 20000,
  ID_DB_STATUS_TIMER,
................................................................................
enum
{
// METADATA TYPEs
  METADATA_UNKNOWN = 0,
  METADATA_LEGACY,
  METADATA_CURRENT
};












class RasterCoverageItem
{
//
// a class wrapping a Raster Coverage related Table or View
//
private:
................................................................................

class VectorCoverageSet
{
//
// a class representing a full Vector Coverage Set
//
private:

  wxString Name;
  int Srid;

public:
    VectorCoverageSet(const char *name, int srid);
   ~VectorCoverageSet()
  {;




  }
  wxString & GetName()
  {
    return Name;
  }
  int GetSrid()
  {
    return Srid;
  }




};

class MyObject:public wxTreeItemData
{
//
// a class to store TreeItemData
//
................................................................................
  int Type;                     // the object type
  wxString DbAlias;             // the DB alias [Attached DB] 
  wxString Name;                // the object name
  wxString Column;              // the column name [optional]
  bool Temporary;               // the TMP switch
  bool Coverage;                // TRUE only if Raster Coverage related
  bool Topology;                // TRUE only if TopoGeo or TopoNet related

public:


    MyObject(int type, wxString & name);
    MyObject(int type, wxString & name, bool tmp, bool coverage =
             false, bool topology = false);
    MyObject(int type, wxString & dbAlias, wxString & name, bool tmp);
    MyObject(int type, wxString & name, wxString & column);
    MyObject(int type, bool attached, wxString & dbAlias, wxString & name,
             bool coverage = false, bool topology = false);


    virtual ~ MyObject()
  {;
  }
  int GetType()
  {
    return Type;
  }
................................................................................
  {
    return Column;
  }
  bool IsTemporary()
  {
    return Temporary;
  }




  bool IsAttached()
  {
    if (DbAlias.Len() > 0)
      return true;
    else
      return false;
  }
................................................................................
//
private:
  wxString DbPrefix;
  wxString Name;
  int Srid;
  bool HasZ;
public:

    TopoGeoSet(const char *db_prefix, const char *name, int srid, bool has_z);
   ~TopoGeoSet()
  {;
  }
  wxString & GetDbPrefix()
  {
    return DbPrefix;
................................................................................
private:
  sqlite3 * DbHandle;
  wxString DbPrefix;
  wxString Name;
  wxTreeItemId TopologyNode;
  TopoGeo *Next;
public:


    TopoGeo(class MyTableTree * tree, wxTreeItemId & root,
            wxString & db_prefix, wxString & topology, int srid, bool has_z);
   ~TopoGeo()
  {;
  }
  wxTreeItemId *Check(wxString & table);
  bool CheckTopoFeature(wxString & table);
................................................................................
    Count = 0;
  }
   ~TopoGeoList()
  {
    Flush();
  }
  void Flush();


  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & db_prefix, wxString & topology, int srid, bool has_z);
  wxTreeItemId *FindNode(wxString & table);
  int GetCount()
  {
    return Count;
  }
................................................................................

class TopoNetSet
{
//
// a class representing a full TopoNet Set
//
private:

  wxString Name;
  bool Spatial;
  int Srid;
  bool HasZ;
public:
    TopoNetSet(const char *name, bool spatial, int srid, bool has_z);


   ~TopoNetSet()
  {;




  }
  wxString & GetName()
  {
    return Name;
  }
  bool IsSpatial()
  {
................................................................................

class TopoNet
{
//
// TopoNet container
//
private:

  wxString Name;
  wxTreeItemId NetworkNode;
  TopoNet *Next;
public:
    TopoNet(class MyTableTree * tree, wxTreeItemId & root,
            wxString & network, bool spatial, int srid, bool has_z);



   ~TopoNet()
  {;
  }
  wxTreeItemId *Check(wxString & table);
  TopoNet *GetNext()
  {
    return Next;
................................................................................
   ~TopoNetList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & network, bool spatial, int srid, bool has_z);



  wxTreeItemId *FindNode(wxString & table);
  int GetCount()
  {
    return Count;
  }
};

class RasterCoverage
{
//
// Raster Coverage container
//
private:

  wxString Name;
  wxTreeItemId CoverageNode;
  RasterCoverage *Next;
public:
    RasterCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & coverage, int srid);


   ~RasterCoverage()
  {;
  }
  wxTreeItemId *Check(wxString & table, bool * tile_data);
  RasterCoverage *GetNext()
  {
    return Next;
................................................................................
   ~RasterCoverageList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & coverage, int srid);


  wxTreeItemId *FindNode(wxString & table, bool * tile_data);
  int GetCount()
  {
    return Count;
  }
};

class VectorCoverage
{
//
// Vector Coverage container
//
private:


  wxString Name;
  wxTreeItemId CoverageNode;
  VectorCoverage *Next;
public:
    VectorCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & coverage, int srid);




   ~VectorCoverage()
  {;
  }
  VectorCoverage *GetNext()
  {
    return Next;
  }
................................................................................
  }
   ~VectorCoverageList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & coverage, int srid);


  int GetCount()
  {
    return Count;
  }
};

class RootNodes
................................................................................
    CollapseAllChildren(RootIsoMetadata);
    Collapse(RootMetadata);
    Collapse(RootInternal);
    Collapse(RootSpatialIndex);
  }
  void AddTopology(TopoGeoSet * topology)
  {
    Topologies.Add(this, RootTopologies, topology->GetDbPrefix(),
                   topology->GetName(), topology->GetSrid(),
                   topology->GetHasZ());
  }
  void AddAltTopology(wxTreeItemId & rootTopologies, TopoGeoSet * topology)

  {
    AltTopologies.Add(this, rootTopologies, topology->GetDbPrefix(),
                      topology->GetName(), topology->GetSrid(),
                      topology->GetHasZ());
  }
  void DeleteTopologies(wxTreeItemId & root_topologies);
  void DeleteAltTopologies(void)
  {
    AltTopologies.Flush();
  }
  void AddNetwork(TopoNetSet * network)
  {
    Networks.Add(this, RootNetworks, network->GetName(), network->IsSpatial(),
                 network->GetSrid(), network->GetHasZ());
  }
  void AddAltNetwork(wxTreeItemId & rootNetworks, TopoNetSet * network)

  {
    AltNetworks.Add(this, rootNetworks, network->GetName(),
                    network->IsSpatial(), network->GetSrid(),
                    network->GetHasZ());
  }
  void DeleteNetworks(wxTreeItemId & root_networks);
  void DeleteAltNetworks(void)
  {
    AltNetworks.Flush();
................................................................................
  }
  void AddRasterCoverage(RasterCoverageSet * coverage)
  {
    RasterCoverages.Add(this, RootRasterCoverages, coverage->GetName(),
                        coverage->GetSrid());
  }
  void AddAltRasterCoverage(wxTreeItemId & rootRasterCoverages,
                            RasterCoverageSet * coverage)
  {
    AltRasterCoverages.Add(this, rootRasterCoverages, coverage->GetName(),
                           coverage->GetSrid());
  }
  void AddVectorCoverage(VectorCoverageSet * coverage)
  {
    VectorCoverages.Add(this, RootVectorCoverages, coverage->GetName(),
                        coverage->GetSrid());

  }
  void AddAltVectorCoverage(wxTreeItemId & rootVectorCoverages,
                            VectorCoverageSet * coverage)
  {
    AltVectorCoverages.Add(this, rootVectorCoverages, coverage->GetName(),

                           coverage->GetSrid());
  }
  bool GetCurrentlySelectedTable(wxString & table_name);
  void DeleteRasterCoverages(wxTreeItemId & root_coverages);
  void DeleteVectorCoverages(wxTreeItemId & root_coverages);
  void DeleteAltRasterCoverages(void)
  {
    AltRasterCoverages.Flush();
................................................................................
  void OnCmdSimplePointSymbolizer(wxCommandEvent & event);
  void OnCmdSimpleTextSymbolizer(wxCommandEvent & event);
  void OnCmdImportRaster(wxCommandEvent & event);
  void OnCmdPyramidize(wxCommandEvent & event);
  void OnCmdPyramidizeMonolithic(wxCommandEvent & event);
  void OnCmdDePyramidize(wxCommandEvent & event);
  void OnCmdRasterDrop(wxCommandEvent & event);

  void OnCmdRasterSRIDs(wxCommandEvent & event);
  void OnCmdRasterKeywords(wxCommandEvent & event);
  void OnCmdUpdateRasterExtent(wxCommandEvent & event);
  void OnCmdUpdateRasterExtentAll(wxCommandEvent & event);
  void OnCmdVectorUnregister(wxCommandEvent & event);

  void OnCmdVectorSRIDs(wxCommandEvent & event);
  void OnCmdVectorKeywords(wxCommandEvent & event);
  void OnCmdUpdateVectorExtent(wxCommandEvent & event);
  void OnCmdUpdateVectorExtentAll(wxCommandEvent & event);
  void OnCmdRegisterWmsLayer(wxCommandEvent & event);
  void OnCmdUnregisterWmsLayer(wxCommandEvent & event);
  void OnCmdConfigureWmsLayer(wxCommandEvent & event);




  void OnCmdShow(wxCommandEvent & event);
  void OnCmdDrop(wxCommandEvent & event);
  void OnCmdRename(wxCommandEvent & event);
  void OnCmdSelect(wxCommandEvent & event);
  void OnCmdSelectTiles(wxCommandEvent & event);
  void OnCmdRefresh(wxCommandEvent & event);
  void OnRefreshDeferred(wxCommandEvent & event);
................................................................................
  void OnCmdDetachDB(wxCommandEvent & event);
  void OnCmdCheckGeometries(wxCommandEvent & event);
  void OnCmdSanitizeGeometries(wxCommandEvent & event);
  void OnCmdSldSeRasterStyles(wxCommandEvent & event);
  void OnCmdSldSeVectorStyles(wxCommandEvent & event);
  void OnCreateRasterCoverage(wxCommandEvent & event);
  void OnRegisterVectorCoverage(wxCommandEvent & event);




  void OnItemCollapsed(wxTreeEvent & event);
  void OnItemExpanding(wxTreeEvent & event);
};

class SqlThreadParams
{
//
................................................................................
  wxString & GetTmpPrefix()
  {
    return TmpPrefix;
  }
  void OnYes(wxCommandEvent & event);
  void OnNo(wxCommandEvent & event);
};

























































































class WfsParams
{
// parameters for WFS download
private:
  class WfsDialog * Mother;
  wxGauge *ProgressCtrl;
................................................................................
class MyFrame:public wxFrame
{
//
// the main GUI frame
//
private:
  char *Old_SPATIALITE_SECURITY_ENV;

  wxString AutoFDOmsg;
  wxString AutoGPKGmsg;
  bool SpatiaLiteMetadata;
  wxAuiManager Manager;         // the GUI manager
  wxString ConfigLayout;        // PERSISTENCY - the layout configuration
  int ConfigPaneX;              // PERSISTENCY - the main pane screen origin X
  int ConfigPaneY;              // PERSISTENCY - the main pane screen origin Y
................................................................................
  wxBitmap *BtnAttach;          // button icon for ATTACH
  wxBitmap *BtnSqlLog;          // button icon for SQL LOG
  wxBitmap *BtnDbStatus;        // button icon for DB STATUS
  wxBitmap *BtnCheckGeom;       // button icon for CheckGeom
  wxBitmap *BtnSaneGeom;        // button icon for SaneGeom
  wxBitmap *BtnWFS;             // button icon for WFS
  wxBitmap *BtnDXF;             // button icon for DXF

  bool ReadOnlyConnection;
// AutoSave timer
  int AutoSaveInterval;
  int LastTotalChanges;
  wxTimer *TimerAutoSave;
  gaiaGeomCollPtr GeomFromPoint(gaiaPointPtr pt, int srid);
  gaiaGeomCollPtr GeomFromLinestring(gaiaLinestringPtr ln, int srid);
................................................................................
  bool GetTilePreview(wxString & currentTileData, int currentTileId,
                      unsigned char **blob, int *blobSize);
  class RasterCoverageStylesList *FindRasterCoverageStyles(wxString & coverage);
  class RasterCoverageStylesList *FindRasterStyles();
  class VectorCoverageStylesList *FindVectorCoverageStyles(wxString & coverage);
  class VectorCoverageStylesList *FindVectorStyles();
  class CandidateVectorCoveragesList *FindUnregisteredVectorCoverages();






  bool DoRegisterVectorCoverage(wxString & name, wxString & table,
                                wxString & geometry, wxString & title,
                                wxString & abstract);















  bool ValidateRasterStyle(const char *path, void **blob, int *blob_size);
  bool ValidateRasterStyle(void **blob, int *blob_size, const char *xml);
  bool DoInsertRasterSymbolizer(char *xml);
  bool ValidateVectorStyle(const char *path, void **blob, int *blob_size);
  bool ValidateVectorStyle(void **blob, int *blob_size, const char *xml);
  bool DoInsertVectorSymbolizer(char *xml);
  bool ValidateExternalGraphicResource(const char *path, void **blob,
................................................................................
                            int NumBands, int Compression, int Quality,
                            int TileWidth, int TileHeight,
                            bool NotGeoreferenced, int Srid,
                            double HorzResolution, double VertResolution,
                            wxString NoData, bool StrictResolution,
                            bool MixedResolutions, bool InputPaths, bool MD5,
                            bool Summary, int RedBand, int GreenBand,
                            int BlueBand, int NIRband, bool AutoNDVI);

  static void DoubleQuoted(wxString & str);
  bool IsView(wxString & view);
  bool IsWritableView(wxString & view);
  void GetWritableViewPK(wxString & view, wxString & pk_name);

  bool HasFlippedAxes(const char *crs);
  bool BBoxFromLongLat(const char *crs_str, double *minx, double *maxx,
................................................................................
                       double *miny, double *maxy);
  char *GetProjParams(int srid);

  void CreateWmsTables();
  bool IsDefinedWmsGetCapabilities(const char *url);
  bool IsDefinedWmsGetMap(const char *getmap_url, const char *layer_name);
  bool RegisterWmsGetCapabilities(const char *url, const char *title,
                                     const char *abstract);
  bool RegisterWmsGetMap(const char *getcapabilities_url,
                         const char *getmap_url, const char *layer_name,
                         const char *title, const char *abstract,
                         const char *version, const char *ref_sys,
                         const char *image_format, const char *style,
                         int transparent, int flip_axes, int is_queryable,
                         int tiled, int cached, int tile_width, int tile_height,
                         const char *bgcolor);
  bool RegisterWmsSetting(const char *url, const char *layer_name,
                          const char *key, const char *value, int is_default);
  bool RegisterWmsSRS(const char *url, const char *layer_name,
                      const char *ref_sys, double minx, double miny,
                      double maxx, double maxy, int is_default);
  bool TransformWmsBBox(const char *ref_sys, double geoMinX, double geoMinY,
                        double geoMaxX, double geoMaxY, double *minx,
                        double *miny, double *maxx, double *maxy);
  bool UnRegisterWmsGetMap(const char *url, const char *layer);
  void DoRegisterWMS();
  void DoUnRegisterWMS();
  void DoConfigureWMS();





  void OnQuit(wxCommandEvent & event);

  void OnAbout(wxCommandEvent & event);
  void OnConnect(wxCommandEvent & event);
  void OnConnectReadOnly(wxCommandEvent & event);
  void OnCreateNew(wxCommandEvent & event);
  void OnDisconnect(wxCommandEvent & event);
  void OnMemoryDbLoad(wxCommandEvent & event);
  void OnMemoryDbNew(wxCommandEvent & event);
  void OnMemoryDbClock(wxCommandEvent & event);
  void OnMemoryDbSave(wxCommandEvent & event);
  void OnVacuum(wxCommandEvent & event);

  void OnSqlScript(wxCommandEvent & event);
  void OnQueryViewComposer(wxCommandEvent & event);
  void OnCharset(wxCommandEvent & event);
  void OnLoadShp(wxCommandEvent & event);
  void OnLoadTxt(wxCommandEvent & event);
  void OnLoadDbf(wxCommandEvent & event);
  void OnLoadXL(wxCommandEvent & event);
................................................................................
  double VertResolution;
  wxString NoData;
  bool StrictResolution;
  bool MixedResolutions;
  bool InputPaths;
  bool MD5;
  bool Summary;

  bool IsValidNoData(wxString & no_data, int sample, int num_bands);
public:
    CreateRasterCoverageDialog()
  {;
  }
  bool Create(MyFrame * parent);
  virtual ~ CreateRasterCoverageDialog()
................................................................................
  {
    return MD5;
  }
  bool IsSummary()
  {
    return Summary;
  }




  void OnSampleChanged(wxCommandEvent & event);
  void OnPixelChanged(wxCommandEvent & event);
  void OnCompressionChanged(wxCommandEvent & event);
  void OnNumBandsChanged(wxCommandEvent & event);
  void OnRedBandChanged(wxCommandEvent & event);
  void OnGreenBandChanged(wxCommandEvent & event);
  void OnBlueBandChanged(wxCommandEvent & event);
................................................................................
  virtual ~ RasterDropDialog()
  {;
  }
  void CreateControls();
  bool DoDropCoverage(void);
  void OnOk(wxCommandEvent & event);
};



























class RasterCoverageStylesDialog:public wxDialog
{
//
// a dialog for handling SLD/SE Raster Coverage's Styles
//
private:
................................................................................
  int GetSelectedCount();
  int GetSelectedStyleId(int idx);
  void OnOk(wxCommandEvent & event);
};

class CandidateVectorCoverage
{
// an SLD/SE Vector style
private:
  wxString TableName;
  wxString GeometryColumn;
  int Srid;
  wxString GeometryType;
  bool VectorCoverage;
  bool RasterCoverage;


  CandidateVectorCoverage *Next;
public:
    CandidateVectorCoverage(wxString & table, wxString & geometry, int srid,
                            wxString & type)
  {
    TableName = table;
    GeometryColumn = geometry;
    Srid = srid;
    GeometryType = type;
    VectorCoverage = false;
    RasterCoverage = false;


    Next = NULL;
  }
   ~CandidateVectorCoverage()
  {;
  }
  wxString & GetTableName()
  {
................................................................................
  void MarkRasterCoverage()
  {
    RasterCoverage = true;
  }
  bool IsRasterCoverage()
  {
    return RasterCoverage;
















  }
  CandidateVectorCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateVectorCoverage * next)
  {
    Next = next;
  }
};

class CandidateVectorCoveragesList
{
// a container for candidate Vector Coverages
private:
  CandidateVectorCoverage * First;
  CandidateVectorCoverage *Last;
public:
    CandidateVectorCoveragesList()
  {
    First = NULL;
................................................................................
    Last = NULL;
  }
   ~CandidateVectorCoveragesList();
  void Add(wxString & table_name, wxString & geometry, int srid,
           wxString & type);
  void MarkVectorCoverage(wxString & table, wxString & geometry);
  void MarkRasterCoverage(wxString & table, wxString & geometry);


  CandidateVectorCoverage *GetFirst()
  {
    return First;
  }
};

class VectorRegisterDialog:public wxDialog
{
//
// a dialog for Register Vector Coverage
//
private:
  MyFrame * MainFrame;
  CandidateVectorCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString TableName;
  wxString GeometryColumn;
  wxString Title;
  wxString Abstract;


public:
    VectorRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ VectorRegisterDialog()
................................................................................
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }








  void OnOk(wxCommandEvent & event);


















































































































































































































































































































































































































































































































































































};

class VectorCoverageSRID
{
// a Vector Coverage alternative SRID
private:
  int Srid;
................................................................................
    return wxSize(48, 24);
  }
  void SetGraphic(wxImage * graphic)
  {
    Graphic = graphic;
  }
};































class MyFontCellRenderer:public wxGridCellRenderer
{
// a Grid CellRenderer supporting a Text Font
private:
  wxImage * FontExample;
public:
................................................................................
  int Opaque;
  int SwapXY;
  int Tiled;
  int TileWidth;
  int TileHeight;
  int Queryable;
  void GetButtonBitmap(const char *color, wxBitmap & bmp);
  void ParseBgColor(const char *color, unsigned char *red, unsigned char *green, unsigned char *blue);

  unsigned char ParseHex(const char *byte);
public:
    WmsConfigDialog(){;}


    virtual ~ WmsConfigDialog()
    {
		if (Version != NULL) free(Version);

		if (MaxVersion != NULL) free(MaxVersion);

		if (RefSys != NULL) free(RefSys);

		if (Style != NULL) free(Style);

		if (ImageFormat != NULL) free(ImageFormat);

		if (BgColor != NULL) free(BgColor);

	}
  bool Create(MyFrame * parent, wxString url, wxString layer);
  void CreateControls();
  const char *GetVersion()
  {
    return Version;
  }
  const char *GetStyle()
................................................................................
  }
  int GetTileHeight()
  {
    return TileHeight;
  }
  void LoadData();
  void FindMaxVersion();
  void PopulateRefSys(wxComboBox *crsList);
  void PopulateImageFormats(wxComboBox *fmtList);
  void PopulateStyles(wxComboBox *stlList);
  void UpdateSwapXY(void);
  void OnCrsChanged(wxCommandEvent & event);
  void OnVersionChanged(wxCommandEvent & event);
  void OnSwapXYChanged(wxCommandEvent & event);
  void OnTiledChanged(wxCommandEvent & event);
  void OnBgColorEnabledChanged(wxCommandEvent & event);
  void OnBgColorChanged(wxCommandEvent & event);
................................................................................
    DATA_TYPE_MULTIPOINT,
    DATA_TYPE_MULTILINESTRING,
    DATA_TYPE_MULTIPOLYGON,
    DATA_TYPE_GEOMETRYCOLLECTION,
    DATA_TYPE_GEOMETRY
  };
};




























































































































































































































































































































































































































































>







 







>
>
>
>
>
>
>
>







 







>

>
>
>
>

>







 







>
>
>
>
>
>
>
>
>
>
>
>







 







>







 







>
>







 







>
>
>
>
>
>
>











|
>





>
|







 







>
>
>







|
>







 







>
>
>
>
>
>
>
>
>
>
>







 







>


>

|


>
>
>
>









>
>
>
>







 







>

>
>







>
>







 







>
>
>
>







 







>







 







>
>







 







>
>







 







>






>
>


>
>
>
>







 







>






>
>
>







 







>
>
>













>






>
>







 







>
>













>
>





|
>
>
>
>







 







|
>
>







 







|



|
>

|













|
>

|







 







|

|
|



|
|
>


|

|
>
|







 







>





>







>
>
>
>







 







>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>







 







>







 







>
>
>
>
>
>


|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|
>







 







|







|












>
>

>
>

>










>







 







>







 







>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|







>
>











>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>













|







 







>
>









|










>
>







 







>
>
>
>
>
>
>
>

>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|
>


|
>
>
|
|
|
>
|
>
|
>
|
>
|
>
|
>
|







 







|
|
|







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
...
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
...
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
...
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
...
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
...
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
...
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
...
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
...
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
....
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
....
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
....
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
....
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
....
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
....
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
....
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
....
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
....
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
....
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
....
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
....
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
....
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
....
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
....
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
....
2874
2875
2876
2877
2878
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
2901
2902
2903
2904
2905
2906
2907
2908
2909
2910
2911
2912
2913
2914
2915
2916
2917
2918
2919
2920
2921
2922
2923
2924
2925
2926
2927
2928
2929
2930
2931
2932
2933
2934
2935
2936
2937
2938
2939
2940
2941
2942
2943
2944
2945
2946
2947
2948
2949
2950
2951
2952
2953
2954
2955
2956
2957
2958
2959
2960
2961
2962
2963
2964
2965
2966
2967
2968
2969
2970
2971
2972
2973
2974
2975
....
3609
3610
3611
3612
3613
3614
3615
3616
3617
3618
3619
3620
3621
3622
3623
....
3679
3680
3681
3682
3683
3684
3685
3686
3687
3688
3689
3690
3691
3692
3693
....
4111
4112
4113
4114
4115
4116
4117
4118
4119
4120
4121
4122
4123
4124
4125
4126
4127
4128
4129
4130
4131
4132
4133
4134
4135
4136
4137
4138
4139
4140
4141
4142
4143
4144
4145
4146
4147
4148
....
4177
4178
4179
4180
4181
4182
4183
4184
4185
4186
4187
4188
4189
4190
4191
4192
....
4193
4194
4195
4196
4197
4198
4199
4200
4201
4202
4203
4204
4205
4206
4207
4208
4209
4210
4211
4212
4213
4214
4215
4216
4217
4218
4219
4220
4221
4222
4223
4224
4225
4226
4227
4228
4229
4230
4231
4232
4233
4234
4235
4236
4237
4238
4239
4240
4241
4242
4243
4244
4245
....
5914
5915
5916
5917
5918
5919
5920
5921
5922
5923
5924
5925
5926
5927
5928
....
6025
6026
6027
6028
6029
6030
6031
6032
6033
6034
6035
6036
6037
6038
6039
6040
6041
6042
....
7253
7254
7255
7256
7257
7258
7259
7260
7261
7262
7263
7264
7265
7266
7267
7268
7269
7270
7271
7272
7273
7274
7275
7276
7277
7278
7279
7280
7281
7282
7283
7284
7285
7286
7287
7288
7289
7290
7291
7292
....
8456
8457
8458
8459
8460
8461
8462
8463
8464
8465
8466
8467
8468
8469
8470
8471
8472
8473
8474
8475
8476
8477
8478
8479
8480
8481
8482
8483
8484
8485
8486
8487
8488
8489
8490
8491
8492
....
8515
8516
8517
8518
8519
8520
8521
8522
8523
8524
8525
8526
8527
8528
8529
8530
8531
8532
8533
8534
8535
8536
8537
8538
8539
8540
8541
8542
8543
8544
8545
8546
8547
8548
8549
8550
8551
8552
8553
8554
8555
8556
8557
8558
....
8559
8560
8561
8562
8563
8564
8565
8566
8567
8568
8569
8570
8571
8572
8573
8574
8575
8576
8577
8578
8579
8580
8581
8582
8583
8584
8585
8586
8587
8588
8589
8590
8591
8592
8593
8594
8595
8596
....
8615
8616
8617
8618
8619
8620
8621
8622
8623
8624
8625
8626
8627
8628
8629
8630
8631
8632
8633
8634
8635
8636
8637
8638
8639
8640
8641
8642
8643
8644
8645
8646
8647
8648
8649
8650
8651
8652
8653
8654
8655
8656
8657
8658
8659
8660
8661
8662
8663
8664
8665
8666
8667
8668
8669
8670
8671
8672
8673
8674
8675
8676
8677
8678
8679
8680
8681
8682
8683
8684
8685
8686
8687
8688
8689
8690
8691
8692
8693
8694
8695
8696
8697
8698
8699
8700
8701
8702
8703
8704
8705
8706
8707
8708
8709
8710
8711
8712
8713
8714
8715
8716
8717
8718
8719
8720
8721
8722
8723
8724
8725
8726
8727
8728
8729
8730
8731
8732
8733
8734
8735
8736
8737
8738
8739
8740
8741
8742
8743
8744
8745
8746
8747
8748
8749
8750
8751
8752
8753
8754
8755
8756
8757
8758
8759
8760
8761
8762
8763
8764
8765
8766
8767
8768
8769
8770
8771
8772
8773
8774
8775
8776
8777
8778
8779
8780
8781
8782
8783
8784
8785
8786
8787
8788
8789
8790
8791
8792
8793
8794
8795
8796
8797
8798
8799
8800
8801
8802
8803
8804
8805
8806
8807
8808
8809
8810
8811
8812
8813
8814
8815
8816
8817
8818
8819
8820
8821
8822
8823
8824
8825
8826
8827
8828
8829
8830
8831
8832
8833
8834
8835
8836
8837
8838
8839
8840
8841
8842
8843
8844
8845
8846
8847
8848
8849
8850
8851
8852
8853
8854
8855
8856
8857
8858
8859
8860
8861
8862
8863
8864
8865
8866
8867
8868
8869
8870
8871
8872
8873
8874
8875
8876
8877
8878
8879
8880
8881
8882
8883
8884
8885
8886
8887
8888
8889
8890
8891
8892
8893
8894
8895
8896
8897
8898
8899
8900
8901
8902
8903
8904
8905
8906
8907
8908
8909
8910
8911
8912
8913
8914
8915
8916
8917
8918
8919
8920
8921
8922
8923
8924
8925
8926
8927
8928
8929
8930
8931
8932
8933
8934
8935
8936
8937
8938
8939
8940
8941
8942
8943
8944
8945
8946
8947
8948
8949
8950
8951
8952
8953
8954
8955
8956
8957
8958
8959
8960
8961
8962
8963
8964
8965
8966
8967
8968
8969
8970
8971
8972
8973
8974
8975
8976
8977
8978
8979
8980
8981
8982
8983
8984
8985
8986
8987
8988
8989
8990
8991
8992
8993
8994
8995
8996
8997
8998
8999
9000
9001
9002
9003
9004
9005
9006
9007
9008
9009
9010
9011
9012
9013
9014
9015
9016
9017
9018
9019
9020
9021
9022
9023
9024
9025
9026
9027
9028
9029
9030
9031
9032
9033
9034
9035
9036
9037
9038
9039
9040
9041
9042
9043
9044
9045
9046
9047
9048
9049
9050
9051
9052
9053
9054
9055
9056
9057
9058
9059
9060
9061
9062
9063
9064
9065
9066
9067
9068
9069
9070
9071
9072
9073
9074
9075
9076
9077
9078
9079
9080
9081
9082
9083
9084
9085
9086
9087
9088
9089
9090
9091
9092
9093
9094
9095
9096
9097
9098
9099
9100
9101
9102
9103
9104
9105
9106
9107
9108
9109
9110
9111
9112
9113
9114
9115
9116
9117
9118
9119
9120
9121
9122
9123
9124
9125
9126
9127
9128
9129
9130
9131
9132
9133
9134
9135
9136
9137
9138
9139
9140
9141
9142
9143
9144
9145
9146
9147
9148
9149
9150
9151
9152
9153
9154
9155
9156
9157
9158
9159
9160
9161
9162
9163
9164
9165
9166
9167
9168
9169
9170
9171
9172
9173
9174
9175
9176
9177
9178
9179
9180
9181
9182
9183
9184
9185
9186
9187
9188
9189
9190
9191
9192
9193
9194
9195
9196
9197
9198
9199
....
9837
9838
9839
9840
9841
9842
9843
9844
9845
9846
9847
9848
9849
9850
9851
9852
9853
9854
9855
9856
9857
9858
9859
9860
9861
9862
9863
9864
9865
9866
9867
9868
9869
9870
9871
9872
9873
9874
9875
9876
9877
9878
9879
9880
.....
10775
10776
10777
10778
10779
10780
10781
10782
10783
10784
10785
10786
10787
10788
10789
10790
10791
10792
10793
10794
10795
10796
10797
10798
10799
10800
10801
10802
10803
10804
10805
10806
10807
10808
10809
10810
.....
10841
10842
10843
10844
10845
10846
10847
10848
10849
10850
10851
10852
10853
10854
10855
10856
10857
.....
12723
12724
12725
12726
12727
12728
12729
12730
12731
12732
12733
12734
12735
12736
12737
12738
12739
12740
12741
12742
12743
12744
12745
12746
12747
12748
12749
12750
12751
12752
12753
12754
12755
12756
12757
12758
12759
12760
12761
12762
12763
12764
12765
12766
12767
12768
12769
12770
12771
12772
12773
12774
12775
12776
12777
12778
12779
12780
12781
12782
12783
12784
12785
12786
12787
12788
12789
12790
12791
12792
12793
12794
12795
12796
12797
12798
12799
12800
12801
12802
12803
12804
12805
12806
12807
12808
12809
12810
12811
12812
12813
12814
12815
12816
12817
12818
12819
12820
12821
12822
12823
12824
12825
12826
12827
12828
12829
12830
12831
12832
12833
12834
12835
12836
12837
12838
12839
12840
12841
12842
12843
12844
12845
12846
12847
12848
12849
12850
12851
12852
12853
12854
12855
12856
12857
12858
12859
12860
12861
12862
12863
12864
12865
12866
12867
12868
12869
12870
12871
12872
12873
12874
12875
12876
12877
12878
12879
12880
12881
12882
12883
12884
12885
12886
12887
12888
12889
12890
12891
12892
12893
12894
12895
12896
12897
12898
12899
12900
12901
12902
12903
12904
12905
12906
12907
12908
12909
12910
12911
12912
12913
12914
12915
12916
12917
12918
12919
12920
12921
12922
12923
12924
12925
12926
12927
12928
12929
12930
12931
12932
12933
12934
12935
12936
12937
12938
12939
12940
12941
12942
12943
12944
12945
12946
12947
12948
12949
12950
12951
12952
12953
12954
12955
12956
12957
12958
12959
12960
12961
12962
12963
12964
12965
12966
12967
12968
12969
12970
12971
12972
12973
12974
12975
12976
12977
12978
12979
12980
12981
12982
12983
12984
12985
12986
12987
12988
12989
12990
12991
12992
12993
12994
12995
12996
12997
12998
12999
13000
13001
13002
13003
13004
13005
13006
13007
13008
13009
13010
13011
13012
13013
13014
13015
13016
13017
13018
13019
13020
13021
13022
13023
13024
13025
13026
13027
13028
13029
13030
13031
13032
13033
13034
13035
13036
13037
13038
13039
13040
13041
13042
13043
13044
13045
13046
13047
13048
13049
13050
13051
13052
13053
13054
13055
13056
13057
13058
13059
13060
13061
13062
13063
13064
13065
13066
13067
13068
13069
13070
13071
13072
13073
13074
13075
13076
13077
13078
13079
13080
13081
13082
13083
13084
13085
13086
13087
13088
13089
13090
13091
13092
13093
13094
13095
13096
13097
13098
13099
13100
13101
13102
13103
13104
13105
13106
13107
13108
13109
13110
13111
13112
13113
13114
13115
13116
13117
13118
13119
13120
13121
13122
13123
13124
13125
13126
13127
13128
13129
13130
13131
13132
13133
13134
13135
13136
13137
13138
13139
13140
13141
13142
13143
13144
13145
13146
13147
13148
13149
13150
13151
13152
13153
13154
13155
13156
13157
13158
13159
13160
13161
13162
13163
13164
13165
13166
  ID_CreateNew,
  ID_Disconnect,
  ID_MemoryDbLoad,
  ID_MemoryDbNew,
  ID_MemoryDbClock,
  ID_MemoryDbSave,
  ID_Vacuum,
  ID_MapPanel,
  ID_SqlScript,
  ID_QueryViewComposer,
  ID_LoadShp,
  ID_LoadTxt,
  ID_LoadDbf,
  ID_LoadXL,
  ID_VirtualShp,
................................................................................
  ID_Attach,
  ID_SqlLog,
  ID_DbStatus,
  ID_CheckGeom,
  ID_SaneGeom,
  ID_WFS,
  ID_DXF,
  ID_AddLayer,
  ID_Center,
  ID_Identify,
  ID_ZoomIn,
  ID_ZoomOut,
  ID_UserScale,
  ID_Pan,
  ID_Printer,
  Tree_NewTable,
  Tree_NewView,
  Tree_NewIndex,
  Tree_NewTrigger,
  Tree_NewColumn,
  Tree_NewRasterStyle,
  Tree_ReloadRasterStyle,
................................................................................
  Tree_SldSeRasterStyles,
  Tree_SldSeVectorStyles,
  Tree_ImportRaster,
  Tree_Pyramidize,
  Tree_PyramidizeMonolithic,
  Tree_DePyramidize,
  Tree_RasterDrop,
  Tree_RasterInfos,
  Tree_VectorRegister,
  Tree_SpatialViewRegister,
  Tree_VirtualShapeRegister,
  Tree_TopoGeoRegister,
  Tree_TopoNetRegister,
  Tree_VectorUnregister,
  Tree_VectorInfos,
  Tree_CreateRasterCoverage,
  Tree_UpdateRasterExtent,
  Tree_UpdateRasterExtentAll,
  Tree_UpdateVectorExtent,
  Tree_UpdateVectorExtentAll,
  Tree_Raster_SRIDs,
  Tree_Vector_SRIDs,
................................................................................
  Tree_SimpleLineSymbolizer,
  Tree_SimplePolygonSymbolizer,
  Tree_SimpleTextSymbolizer,
  Tree_CloneTable,
  Tree_RegisterWmsLayer,
  Tree_UnregisterWmsLayer,
  Tree_ConfigureWmsLayer,
  Tree_CreateTopoGeo,
  Tree_DropTopoGeo,
  Tree_CreateTopoNet,
  Tree_DropTopoNet,
  Tree_MapRemoveAll,
  Tree_MapShowAll,
  Tree_MapHideAll,
  Tree_MapVisible,
  Tree_MapConfigure,
  Tree_MapLayerInfo,
  Tree_MapRemoveLayer,
  Tree_MapDeleteItem,
  Grid_Clear,
  Grid_All,
  Grid_Column,
  Grid_Row,
  Grid_Copy,
  Grid_Blob,
  Grid_Delete,
................................................................................
  ID_CVG_SAME_RES,
  ID_CVG_VERT_RES,
  ID_CVG_STRICT_RES,
  ID_CVG_MIXED_RES,
  ID_CVG_PATHS,
  ID_CVG_MD5,
  ID_CVG_SUMMARY,
  ID_CVG_QUERYABLE,
  ID_LOAD_FORCE_SRID,
  ID_LOAD_SRID,
  ID_LOAD_WITH_WORLDFILE,
  ID_LOAD_PYRAMIDIZE,
  ID_LOAD_LIST_DONE,
  ID_LOAD_ABORT,
  ID_LOAD_RASTER_THREAD_FINISHED,
................................................................................
  ID_LOAD_FONT_START,
  ID_LOAD_FONT_STOP,
  ID_LOAD_FONT_SKIP,
  ID_VECTOR_GRID,
  ID_VECTOR_COVERAGE,
  ID_VECTOR_TITLE,
  ID_VECTOR_ABSTRACT,
  ID_VECTOR_QUERYABLE,
  ID_VECTOR_EDITABLE,
  ID_VECTOR_SRID_ADD,
  ID_VECTOR_SRID_REMOVE,
  ID_VECTOR_SRID,
  ID_VECTOR_SRID_GRID,
  ID_RASTER_SRID_ADD,
  ID_RASTER_SRID_REMOVE,
  ID_RASTER_SRID,
................................................................................
  ID_WMS_OK,
  ID_WMS_ENABLE_PROXY,
  ID_WMS_PROXY,
  ID_WMS_LIST,
  ID_WMS_LAYER,
  ID_WMS_ENABLE_BGCOLOR,
  ID_WMS_BGCOLOR,
  ID_TOPO_NAME,
  ID_TOPO_SRID,
  ID_TOPO_3D,
  ID_TOPO_TOLERANCE,
  ID_TOPO_SPATIAL,
  ID_TOPO_COINCIDENT,
  ID_LAYER_TYPE,
  ID_PANE_MAIN,
  ID_PANE_STROKE1,
  ID_PANE_STROKE2,
  ID_PANE_STROKE3,
  ID_PANE_FILL1,
  ID_PANE_FILL2,
  ID_PANE_POSITION,
  ID_PANE_GRAPHIC,
  ID_PANE_MARK,
  ID_PANE_FONT,
  ID_PANE_PLACEMENT,
  ID_PANE_PREVIEW,
  ID_LAYERS_LIST
};

enum
{
// tree item data types
  MY_ROOT_NODE = 0,
  MY_TABLE,
  MY_VTABLE,
  MY_VIEW,
  MY_TILE_DATA,
  MY_COLUMN,
  MY_VIEW_COLUMN,
  MY_VIRTUAL_COLUMN,
  MY_GEOMETRY,
................................................................................
  MY_GEOMETRY_INDEX,
  MY_GEOMETRY_CACHED,
  MY_VIEW_GEOMETRY,
  MY_VIEW_GEOMETRY_INDEX,
  MY_VIEW_GEOMETRY_CACHED,
  MY_VIRTUAL_GEOMETRY,
  MY_VIRTUAL_GPKG_GEOMETRY,
  MY_TOPO_GEO,
  MY_TOPO_NET,
  MY_COVERAGE,
  MY_INDEX,
  MY_TRIGGER,
  MY_ATTACHED,
  MY_INT_VARIANT,
  MY_DBL_VARIANT,
  MY_TXT_VARIANT,
  MY_BLOB_VARIANT,
  MY_NULL_VARIANT,
  MY_UNDEFINED
};

enum
{
// control IDs for timers
  ID_AUTO_SAVE_TIMER = 20000,
  ID_DB_STATUS_TIMER,
................................................................................
enum
{
// METADATA TYPEs
  METADATA_UNKNOWN = 0,
  METADATA_LEGACY,
  METADATA_CURRENT
};

enum
{
// Map Layer TYPEs
  MAP_LAYER_UNKNOWN = 0,
  MAP_LAYER_WMS,
  MAP_LAYER_VECTOR,
  MAP_LAYER_TOPOLOGY,
  MAP_LAYER_NETWORK,
  MAP_LAYER_RASTER
};

class RasterCoverageItem
{
//
// a class wrapping a Raster Coverage related Table or View
//
private:
................................................................................

class VectorCoverageSet
{
//
// a class representing a full Vector Coverage Set
//
private:
  wxString Prefix;
  wxString Name;
  int Srid;
  int GeometryType;
public:
    VectorCoverageSet(const char *prefix, const char *name, int srid, int type);
   ~VectorCoverageSet()
  {;
  }
  wxString & GetPrefix()
  {
    return Prefix;
  }
  wxString & GetName()
  {
    return Name;
  }
  int GetSrid()
  {
    return Srid;
  }
  int GetGeometryType()
  {
    return GeometryType;
  }
};

class MyObject:public wxTreeItemData
{
//
// a class to store TreeItemData
//
................................................................................
  int Type;                     // the object type
  wxString DbAlias;             // the DB alias [Attached DB] 
  wxString Name;                // the object name
  wxString Column;              // the column name [optional]
  bool Temporary;               // the TMP switch
  bool Coverage;                // TRUE only if Raster Coverage related
  bool Topology;                // TRUE only if TopoGeo or TopoNet related
  bool RootAttached;            // valid only for Type=MY_ROOT_NODE
public:
    MyObject();
    MyObject(bool attached);
    MyObject(int type, wxString & name);
    MyObject(int type, wxString & name, bool tmp, bool coverage =
             false, bool topology = false);
    MyObject(int type, wxString & dbAlias, wxString & name, bool tmp);
    MyObject(int type, wxString & name, wxString & column);
    MyObject(int type, bool attached, wxString & dbAlias, wxString & name,
             bool coverage = false, bool topology = false);
    MyObject(wxString & coverage);
    MyObject(wxString & dbAlias, wxString & coverage);
    virtual ~ MyObject()
  {;
  }
  int GetType()
  {
    return Type;
  }
................................................................................
  {
    return Column;
  }
  bool IsTemporary()
  {
    return Temporary;
  }
  bool IsRootAttached()
  {
    return RootAttached;
  }
  bool IsAttached()
  {
    if (DbAlias.Len() > 0)
      return true;
    else
      return false;
  }
................................................................................
//
private:
  wxString DbPrefix;
  wxString Name;
  int Srid;
  bool HasZ;
public:
    TopoGeoSet(const char *name, int srid, bool has_z);
    TopoGeoSet(const char *db_prefix, const char *name, int srid, bool has_z);
   ~TopoGeoSet()
  {;
  }
  wxString & GetDbPrefix()
  {
    return DbPrefix;
................................................................................
private:
  sqlite3 * DbHandle;
  wxString DbPrefix;
  wxString Name;
  wxTreeItemId TopologyNode;
  TopoGeo *Next;
public:
    TopoGeo(class MyTableTree * tree, wxTreeItemId & root,
            wxString & topology, int srid, bool has_z);
    TopoGeo(class MyTableTree * tree, wxTreeItemId & root,
            wxString & db_prefix, wxString & topology, int srid, bool has_z);
   ~TopoGeo()
  {;
  }
  wxTreeItemId *Check(wxString & table);
  bool CheckTopoFeature(wxString & table);
................................................................................
    Count = 0;
  }
   ~TopoGeoList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & topology, int srid, bool has_z);
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & db_prefix, wxString & topology, int srid, bool has_z);
  wxTreeItemId *FindNode(wxString & table);
  int GetCount()
  {
    return Count;
  }
................................................................................

class TopoNetSet
{
//
// a class representing a full TopoNet Set
//
private:
  wxString DbPrefix;
  wxString Name;
  bool Spatial;
  int Srid;
  bool HasZ;
public:
    TopoNetSet(const char *name, bool spatial, int srid, bool has_z);
    TopoNetSet(const char *db_prefix, const char *name, bool spatial, int srid,
               bool has_z);
   ~TopoNetSet()
  {;
  }
  wxString & GetDbPrefix()
  {
    return DbPrefix;
  }
  wxString & GetName()
  {
    return Name;
  }
  bool IsSpatial()
  {
................................................................................

class TopoNet
{
//
// TopoNet container
//
private:
  wxString DbPrefix;
  wxString Name;
  wxTreeItemId NetworkNode;
  TopoNet *Next;
public:
    TopoNet(class MyTableTree * tree, wxTreeItemId & root,
            wxString & network, bool spatial, int srid, bool has_z);
    TopoNet(class MyTableTree * tree, wxTreeItemId & root,
            wxString & dbPrefix, wxString & network, bool spatial, int srid,
            bool has_z);
   ~TopoNet()
  {;
  }
  wxTreeItemId *Check(wxString & table);
  TopoNet *GetNext()
  {
    return Next;
................................................................................
   ~TopoNetList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & network, bool spatial, int srid, bool has_z);
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & db_prefix, wxString & network, bool spatial, int srid,
           bool has_z);
  wxTreeItemId *FindNode(wxString & table);
  int GetCount()
  {
    return Count;
  }
};

class RasterCoverage
{
//
// Raster Coverage container
//
private:
  wxString DbPrefix;
  wxString Name;
  wxTreeItemId CoverageNode;
  RasterCoverage *Next;
public:
    RasterCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & coverage, int srid);
    RasterCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & dbPrefix, wxString & coverage, int srid);
   ~RasterCoverage()
  {;
  }
  wxTreeItemId *Check(wxString & table, bool * tile_data);
  RasterCoverage *GetNext()
  {
    return Next;
................................................................................
   ~RasterCoverageList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & coverage, int srid);
  void Add(class MyTableTree * tree, wxTreeItemId & root, wxString & dbPrefix,
           wxString & coverage, int srid);
  wxTreeItemId *FindNode(wxString & table, bool * tile_data);
  int GetCount()
  {
    return Count;
  }
};

class VectorCoverage
{
//
// Vector Coverage container
//
private:
  wxString DbPrefix;
  wxString Prefix;
  wxString Name;
  wxTreeItemId CoverageNode;
  VectorCoverage *Next;
public:
    VectorCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & prefix, wxString & coverage, int srid,
                   int geometry_type);
    VectorCoverage(class MyTableTree * tree, wxTreeItemId & root,
                   wxString & dbPrefix, wxString & prefix, wxString & coverage,
                   int srid, int geometry_type);
   ~VectorCoverage()
  {;
  }
  VectorCoverage *GetNext()
  {
    return Next;
  }
................................................................................
  }
   ~VectorCoverageList()
  {
    Flush();
  }
  void Flush();
  void Add(class MyTableTree * tree, wxTreeItemId & root,
           wxString & prefix, wxString & coverage, int srid, int geometry_type);
  void Add(class MyTableTree * tree, wxTreeItemId & root, wxString & dbPrefix,
           wxString & prefix, wxString & coverage, int srid, int geometry_type);
  int GetCount()
  {
    return Count;
  }
};

class RootNodes
................................................................................
    CollapseAllChildren(RootIsoMetadata);
    Collapse(RootMetadata);
    Collapse(RootInternal);
    Collapse(RootSpatialIndex);
  }
  void AddTopology(TopoGeoSet * topology)
  {
    Topologies.Add(this, RootTopologies,
                   topology->GetName(), topology->GetSrid(),
                   topology->GetHasZ());
  }
  void AddAltTopology(wxTreeItemId & rootTopologies, wxString & dbAlias,
                      TopoGeoSet * topology)
  {
    AltTopologies.Add(this, rootTopologies, dbAlias,
                      topology->GetName(), topology->GetSrid(),
                      topology->GetHasZ());
  }
  void DeleteTopologies(wxTreeItemId & root_topologies);
  void DeleteAltTopologies(void)
  {
    AltTopologies.Flush();
  }
  void AddNetwork(TopoNetSet * network)
  {
    Networks.Add(this, RootNetworks, network->GetName(), network->IsSpatial(),
                 network->GetSrid(), network->GetHasZ());
  }
  void AddAltNetwork(wxTreeItemId & rootNetworks, wxString & dbAlias,
                     TopoNetSet * network)
  {
    AltNetworks.Add(this, rootNetworks, dbAlias, network->GetName(),
                    network->IsSpatial(), network->GetSrid(),
                    network->GetHasZ());
  }
  void DeleteNetworks(wxTreeItemId & root_networks);
  void DeleteAltNetworks(void)
  {
    AltNetworks.Flush();
................................................................................
  }
  void AddRasterCoverage(RasterCoverageSet * coverage)
  {
    RasterCoverages.Add(this, RootRasterCoverages, coverage->GetName(),
                        coverage->GetSrid());
  }
  void AddAltRasterCoverage(wxTreeItemId & rootRasterCoverages,
                            wxString & dbAlias, RasterCoverageSet * coverage)
  {
    AltRasterCoverages.Add(this, rootRasterCoverages, dbAlias,
                           coverage->GetName(), coverage->GetSrid());
  }
  void AddVectorCoverage(VectorCoverageSet * coverage)
  {
    VectorCoverages.Add(this, RootVectorCoverages, coverage->GetPrefix(),
                        coverage->GetName(), coverage->GetSrid(),
                        coverage->GetGeometryType());
  }
  void AddAltVectorCoverage(wxTreeItemId & rootVectorCoverages,
                            wxString & dbAlias, VectorCoverageSet * coverage)
  {
    AltVectorCoverages.Add(this, rootVectorCoverages, dbAlias,
                           coverage->GetPrefix(), coverage->GetName(),
                           coverage->GetSrid(), coverage->GetGeometryType());
  }
  bool GetCurrentlySelectedTable(wxString & table_name);
  void DeleteRasterCoverages(wxTreeItemId & root_coverages);
  void DeleteVectorCoverages(wxTreeItemId & root_coverages);
  void DeleteAltRasterCoverages(void)
  {
    AltRasterCoverages.Flush();
................................................................................
  void OnCmdSimplePointSymbolizer(wxCommandEvent & event);
  void OnCmdSimpleTextSymbolizer(wxCommandEvent & event);
  void OnCmdImportRaster(wxCommandEvent & event);
  void OnCmdPyramidize(wxCommandEvent & event);
  void OnCmdPyramidizeMonolithic(wxCommandEvent & event);
  void OnCmdDePyramidize(wxCommandEvent & event);
  void OnCmdRasterDrop(wxCommandEvent & event);
  void OnCmdRasterInfos(wxCommandEvent & event);
  void OnCmdRasterSRIDs(wxCommandEvent & event);
  void OnCmdRasterKeywords(wxCommandEvent & event);
  void OnCmdUpdateRasterExtent(wxCommandEvent & event);
  void OnCmdUpdateRasterExtentAll(wxCommandEvent & event);
  void OnCmdVectorUnregister(wxCommandEvent & event);
  void OnCmdVectorInfos(wxCommandEvent & event);
  void OnCmdVectorSRIDs(wxCommandEvent & event);
  void OnCmdVectorKeywords(wxCommandEvent & event);
  void OnCmdUpdateVectorExtent(wxCommandEvent & event);
  void OnCmdUpdateVectorExtentAll(wxCommandEvent & event);
  void OnCmdRegisterWmsLayer(wxCommandEvent & event);
  void OnCmdUnregisterWmsLayer(wxCommandEvent & event);
  void OnCmdConfigureWmsLayer(wxCommandEvent & event);
  void OnCmdCreateTopoGeo(wxCommandEvent & event);
  void OnCmdDropTopoGeo(wxCommandEvent & event);
  void OnCmdCreateTopoNet(wxCommandEvent & event);
  void OnCmdDropTopoNet(wxCommandEvent & event);
  void OnCmdShow(wxCommandEvent & event);
  void OnCmdDrop(wxCommandEvent & event);
  void OnCmdRename(wxCommandEvent & event);
  void OnCmdSelect(wxCommandEvent & event);
  void OnCmdSelectTiles(wxCommandEvent & event);
  void OnCmdRefresh(wxCommandEvent & event);
  void OnRefreshDeferred(wxCommandEvent & event);
................................................................................
  void OnCmdDetachDB(wxCommandEvent & event);
  void OnCmdCheckGeometries(wxCommandEvent & event);
  void OnCmdSanitizeGeometries(wxCommandEvent & event);
  void OnCmdSldSeRasterStyles(wxCommandEvent & event);
  void OnCmdSldSeVectorStyles(wxCommandEvent & event);
  void OnCreateRasterCoverage(wxCommandEvent & event);
  void OnRegisterVectorCoverage(wxCommandEvent & event);
  void OnRegisterSpatialViewCoverage(wxCommandEvent & event);
  void OnRegisterVirtualShapeCoverage(wxCommandEvent & event);
  void OnRegisterTopoGeoCoverage(wxCommandEvent & event);
  void OnRegisterTopoNetCoverage(wxCommandEvent & event);
  void OnItemCollapsed(wxTreeEvent & event);
  void OnItemExpanding(wxTreeEvent & event);
};

class SqlThreadParams
{
//
................................................................................
  wxString & GetTmpPrefix()
  {
    return TmpPrefix;
  }
  void OnYes(wxCommandEvent & event);
  void OnNo(wxCommandEvent & event);
};

class CreateTopoGeoDialog:public wxDialog
{
//
// a Dialog for creating a new Topology-Geometry
//
private:
  MyFrame * MainFrame;
  wxString TopologyName;
  int Srid;
  bool HasZ;
  double Tolerance;
public:
    CreateTopoGeoDialog()
  {;
  }
  bool Create(MyFrame * parent);
  virtual ~ CreateTopoGeoDialog()
  {;
  }
  void CreateControls();

  wxString & GetTopologyName()
  {
    return TopologyName;
  }
  int GetSrid()
  {
    return Srid;
  }
  bool Is3D()
  {
    return HasZ;
  }
  double GetTolerance()
  {
    return Tolerance;
  }
  void OnOk(wxCommandEvent & event);
  void OnCancel(wxCommandEvent & event);
};

class CreateTopoNetDialog:public wxDialog
{
//
// a Dialog for creating a new Topology-Network
//
private:
  MyFrame * MainFrame;
  wxString NetworkName;
  bool Spatial;
  int Srid;
  bool HasZ;
  bool Coincident;
public:
    CreateTopoNetDialog()
  {;
  }
  bool Create(MyFrame * parent);
  virtual ~ CreateTopoNetDialog()
  {;
  }
  void CreateControls();

  wxString & GetNetworkName()
  {
    return NetworkName;
  }
  bool IsSpatial()
  {
    return Spatial;
  }
  int GetSrid()
  {
    return Srid;
  }
  bool Is3D()
  {
    return HasZ;
  }
  bool AllowsCoincident()
  {
    return Coincident;
  }
  void OnSpatialChanged(wxCommandEvent & event);
  void OnOk(wxCommandEvent & event);
  void OnCancel(wxCommandEvent & event);
};

class WfsParams
{
// parameters for WFS download
private:
  class WfsDialog * Mother;
  wxGauge *ProgressCtrl;
................................................................................
class MyFrame:public wxFrame
{
//
// the main GUI frame
//
private:
  char *Old_SPATIALITE_SECURITY_ENV;
  class MyMapPanel *MapPanel;   // the Map Panel
  wxString AutoFDOmsg;
  wxString AutoGPKGmsg;
  bool SpatiaLiteMetadata;
  wxAuiManager Manager;         // the GUI manager
  wxString ConfigLayout;        // PERSISTENCY - the layout configuration
  int ConfigPaneX;              // PERSISTENCY - the main pane screen origin X
  int ConfigPaneY;              // PERSISTENCY - the main pane screen origin Y
................................................................................
  wxBitmap *BtnAttach;          // button icon for ATTACH
  wxBitmap *BtnSqlLog;          // button icon for SQL LOG
  wxBitmap *BtnDbStatus;        // button icon for DB STATUS
  wxBitmap *BtnCheckGeom;       // button icon for CheckGeom
  wxBitmap *BtnSaneGeom;        // button icon for SaneGeom
  wxBitmap *BtnWFS;             // button icon for WFS
  wxBitmap *BtnDXF;             // button icon for DXF
  wxBitmap *BtnMap;             // button icon for Map Panel
  bool ReadOnlyConnection;
// AutoSave timer
  int AutoSaveInterval;
  int LastTotalChanges;
  wxTimer *TimerAutoSave;
  gaiaGeomCollPtr GeomFromPoint(gaiaPointPtr pt, int srid);
  gaiaGeomCollPtr GeomFromLinestring(gaiaLinestringPtr ln, int srid);
................................................................................
  bool GetTilePreview(wxString & currentTileData, int currentTileId,
                      unsigned char **blob, int *blobSize);
  class RasterCoverageStylesList *FindRasterCoverageStyles(wxString & coverage);
  class RasterCoverageStylesList *FindRasterStyles();
  class VectorCoverageStylesList *FindVectorCoverageStyles(wxString & coverage);
  class VectorCoverageStylesList *FindVectorStyles();
  class CandidateVectorCoveragesList *FindUnregisteredVectorCoverages();
  class CandidateSpatialViewCoveragesList
    * FindUnregisteredSpatialViewCoverages();
  class CandidateVirtualShapeCoveragesList
    * FindUnregisteredVirtualShapeCoverages();
  class CandidateTopoGeoCoveragesList *FindUnregisteredTopoGeoCoverages();
  class CandidateTopoNetCoveragesList *FindUnregisteredTopoNetCoverages();
  bool DoRegisterVectorCoverage(wxString & name, wxString & table,
                                wxString & geometry, wxString & title,
                                wxString & abstract, bool isQueryable,
                                bool isEditable);
  bool DoRegisterSpatialViewCoverage(wxString & name, wxString & view,
                                     wxString & geometry, wxString & title,
                                     wxString & abstract, bool isQueryable,
                                     bool isEditable);
  bool DoRegisterVirtualShapeCoverage(wxString & name, wxString & virt_table,
                                      wxString & virt_geometry,
                                      wxString & title, wxString & abstract,
                                      bool isQueryable);
  bool DoRegisterTopoGeoCoverage(wxString & name, wxString & topology,
                                 wxString & title, wxString & abstract,
                                 bool isQueryable, bool isEditable);
  bool DoRegisterTopoNetCoverage(wxString & name, wxString & network,
                                 wxString & title, wxString & abstract,
                                 bool isQueryable, bool isEditable);
  bool ValidateRasterStyle(const char *path, void **blob, int *blob_size);
  bool ValidateRasterStyle(void **blob, int *blob_size, const char *xml);
  bool DoInsertRasterSymbolizer(char *xml);
  bool ValidateVectorStyle(const char *path, void **blob, int *blob_size);
  bool ValidateVectorStyle(void **blob, int *blob_size, const char *xml);
  bool DoInsertVectorSymbolizer(char *xml);
  bool ValidateExternalGraphicResource(const char *path, void **blob,
................................................................................
                            int NumBands, int Compression, int Quality,
                            int TileWidth, int TileHeight,
                            bool NotGeoreferenced, int Srid,
                            double HorzResolution, double VertResolution,
                            wxString NoData, bool StrictResolution,
                            bool MixedResolutions, bool InputPaths, bool MD5,
                            bool Summary, int RedBand, int GreenBand,
                            int BlueBand, int NIRband, bool AutoNDVI,
                            bool isQueryable);
  static void DoubleQuoted(wxString & str);
  bool IsView(wxString & view);
  bool IsWritableView(wxString & view);
  void GetWritableViewPK(wxString & view, wxString & pk_name);

  bool HasFlippedAxes(const char *crs);
  bool BBoxFromLongLat(const char *crs_str, double *minx, double *maxx,
................................................................................
                       double *miny, double *maxy);
  char *GetProjParams(int srid);

  void CreateWmsTables();
  bool IsDefinedWmsGetCapabilities(const char *url);
  bool IsDefinedWmsGetMap(const char *getmap_url, const char *layer_name);
  bool RegisterWmsGetCapabilities(const char *url, const char *title,
                                  const char *abstract);
  bool RegisterWmsGetMap(const char *getcapabilities_url,
                         const char *getmap_url, const char *layer_name,
                         const char *title, const char *abstract,
                         const char *version, const char *ref_sys,
                         const char *image_format, const char *style,
                         int transparent, int flip_axes, int is_queryable,
                         int tiled, int cached, int tile_width, int tile_height,
                         const char *bgcolor, const char *getfeatureinfo);
  bool RegisterWmsSetting(const char *url, const char *layer_name,
                          const char *key, const char *value, int is_default);
  bool RegisterWmsSRS(const char *url, const char *layer_name,
                      const char *ref_sys, double minx, double miny,
                      double maxx, double maxy, int is_default);
  bool TransformWmsBBox(const char *ref_sys, double geoMinX, double geoMinY,
                        double geoMaxX, double geoMaxY, double *minx,
                        double *miny, double *maxx, double *maxy);
  bool UnRegisterWmsGetMap(const char *url, const char *layer);
  void DoRegisterWMS();
  void DoUnRegisterWMS();
  void DoConfigureWMS();
  void DoCreateTopoGeo();
  void DoCreateTopoNet();

  void MapPanelClosing();

  void OnQuit(wxCommandEvent & event);
  void OnClose(wxCloseEvent & event);
  void OnAbout(wxCommandEvent & event);
  void OnConnect(wxCommandEvent & event);
  void OnConnectReadOnly(wxCommandEvent & event);
  void OnCreateNew(wxCommandEvent & event);
  void OnDisconnect(wxCommandEvent & event);
  void OnMemoryDbLoad(wxCommandEvent & event);
  void OnMemoryDbNew(wxCommandEvent & event);
  void OnMemoryDbClock(wxCommandEvent & event);
  void OnMemoryDbSave(wxCommandEvent & event);
  void OnVacuum(wxCommandEvent & event);
  void OnMapPanel(wxCommandEvent & event);
  void OnSqlScript(wxCommandEvent & event);
  void OnQueryViewComposer(wxCommandEvent & event);
  void OnCharset(wxCommandEvent & event);
  void OnLoadShp(wxCommandEvent & event);
  void OnLoadTxt(wxCommandEvent & event);
  void OnLoadDbf(wxCommandEvent & event);
  void OnLoadXL(wxCommandEvent & event);
................................................................................
  double VertResolution;
  wxString NoData;
  bool StrictResolution;
  bool MixedResolutions;
  bool InputPaths;
  bool MD5;
  bool Summary;
  bool Queryable;
  bool IsValidNoData(wxString & no_data, int sample, int num_bands);
public:
    CreateRasterCoverageDialog()
  {;
  }
  bool Create(MyFrame * parent);
  virtual ~ CreateRasterCoverageDialog()
................................................................................
  {
    return MD5;
  }
  bool IsSummary()
  {
    return Summary;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  void OnSampleChanged(wxCommandEvent & event);
  void OnPixelChanged(wxCommandEvent & event);
  void OnCompressionChanged(wxCommandEvent & event);
  void OnNumBandsChanged(wxCommandEvent & event);
  void OnRedBandChanged(wxCommandEvent & event);
  void OnGreenBandChanged(wxCommandEvent & event);
  void OnBlueBandChanged(wxCommandEvent & event);
................................................................................
  virtual ~ RasterDropDialog()
  {;
  }
  void CreateControls();
  bool DoDropCoverage(void);
  void OnOk(wxCommandEvent & event);
};

class RasterInfosDialog:public wxDialog
{
//
// a dialog for editing Raster Coverage Data
//
private:
  MyFrame * MainFrame;
  wxString CoverageName;
  wxString Title;
  wxString Abstract;
  bool IsQueryable;
  bool DoReadCoverage();
  void DoUpdateCoverage();
public:
    RasterInfosDialog()
  {;
  }
  bool Create(MyFrame * parent, wxString & coverage);
  virtual ~ RasterInfosDialog()
  {;
  }
  void CreateControls();
  void OnOk(wxCommandEvent & event);
  void OnCancel(wxCommandEvent & event);
};

class RasterCoverageStylesDialog:public wxDialog
{
//
// a dialog for handling SLD/SE Raster Coverage's Styles
//
private:
................................................................................
  int GetSelectedCount();
  int GetSelectedStyleId(int idx);
  void OnOk(wxCommandEvent & event);
};

class CandidateVectorCoverage
{
// a candidate Vector Coverage - SpatialTable
private:
  wxString TableName;
  wxString GeometryColumn;
  int Srid;
  wxString GeometryType;
  bool VectorCoverage;
  bool RasterCoverage;
  bool TopoGeo;
  bool TopoNet;
  CandidateVectorCoverage *Next;
public:
    CandidateVectorCoverage(wxString & table, wxString & geometry, int srid,
                            wxString & type)
  {
    TableName = table;
    GeometryColumn = geometry;
    Srid = srid;
    GeometryType = type;
    VectorCoverage = false;
    RasterCoverage = false;
    TopoGeo = false;
    TopoNet = false;
    Next = NULL;
  }
   ~CandidateVectorCoverage()
  {;
  }
  wxString & GetTableName()
  {
................................................................................
  void MarkRasterCoverage()
  {
    RasterCoverage = true;
  }
  bool IsRasterCoverage()
  {
    return RasterCoverage;
  }
  void MarkTopoGeoCoverage()
  {
    TopoGeo = true;
  }
  bool IsTopoGeo()
  {
    return TopoGeo;
  }
  void MarkTopoNetCoverage()
  {
    TopoNet = true;
  }
  bool IsTopoNet()
  {
    return TopoNet;
  }
  CandidateVectorCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateVectorCoverage * next)
  {
    Next = next;
  }
};

class CandidateVectorCoveragesList
{
// a container for candidate Vector Coverages - SpatialTables
private:
  CandidateVectorCoverage * First;
  CandidateVectorCoverage *Last;
public:
    CandidateVectorCoveragesList()
  {
    First = NULL;
................................................................................
    Last = NULL;
  }
   ~CandidateVectorCoveragesList();
  void Add(wxString & table_name, wxString & geometry, int srid,
           wxString & type);
  void MarkVectorCoverage(wxString & table, wxString & geometry);
  void MarkRasterCoverage(wxString & table, wxString & geometry);
  void MarkTopoGeoCoverage(wxString & table, wxString & geometry);
  void MarkTopoNetCoverage(wxString & table, wxString & geometry);
  CandidateVectorCoverage *GetFirst()
  {
    return First;
  }
};

class VectorRegisterDialog:public wxDialog
{
//
// a dialog for Register Vector Coverage - SpatialTables
//
private:
  MyFrame * MainFrame;
  CandidateVectorCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString TableName;
  wxString GeometryColumn;
  wxString Title;
  wxString Abstract;
  bool Queryable;
  bool Editable;
public:
    VectorRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ VectorRegisterDialog()
................................................................................
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  bool IsEditable()
  {
    return Editable;
  }
  void OnOk(wxCommandEvent & event);
};

class CandidateSpatialViewCoverage
{
// a candidate Vector Coverage - SpatialView
private:
  wxString ViewName;
  wxString ViewGeometry;
  int Srid;
  wxString GeometryType;
  bool VectorCoverage;
  CandidateSpatialViewCoverage *Next;
public:
    CandidateSpatialViewCoverage(wxString & view_name, wxString & view_geometry,
                                 int srid, wxString & type)
  {
    ViewName = view_name;
    ViewGeometry = view_geometry;
    Srid = srid;
    GeometryType = type;
    VectorCoverage = false;
    Next = NULL;
  }
   ~CandidateSpatialViewCoverage()
  {;
  }
  wxString & GetViewName()
  {
    return ViewName;
  }
  wxString & GetViewGeometry()
  {
    return ViewGeometry;
  }
  int GetSrid()
  {
    return Srid;
  }
  wxString & GetGeometryType()
  {
    return GeometryType;
  }
  void MarkVectorCoverage()
  {
    VectorCoverage = true;
  }
  bool IsVectorCoverage()
  {
    return VectorCoverage;
  }
  CandidateSpatialViewCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateSpatialViewCoverage * next)
  {
    Next = next;
  }
};

class CandidateSpatialViewCoveragesList
{
// a container for candidate Vector Coverages - SpatialViews
private:
  CandidateSpatialViewCoverage * First;
  CandidateSpatialViewCoverage *Last;
public:
    CandidateSpatialViewCoveragesList()
  {
    First = NULL;
    Last = NULL;
  }
   ~CandidateSpatialViewCoveragesList();
  void Add(wxString & view_name, wxString & geometry, int srid,
           wxString & type);
  void MarkVectorCoverage(wxString & view, wxString & geometry);
  CandidateSpatialViewCoverage *GetFirst()
  {
    return First;
  }
};

class SpatialViewRegisterDialog:public wxDialog
{
//
// a dialog for Register Vector Coverage - SpatialView
//
private:
  MyFrame * MainFrame;
  CandidateSpatialViewCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString ViewName;
  wxString ViewGeometry;
  wxString Title;
  wxString Abstract;
  bool Queryable;
  bool Editable;
public:
    SpatialViewRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ SpatialViewRegisterDialog()
  {
    if (List != NULL)
      delete List;
  }
  void CreateControls();
  wxString & GetCoverageName()
  {
    return CoverageName;
  }
  wxString & GetViewName()
  {
    return ViewName;
  }
  wxString & GetViewGeometry()
  {
    return ViewGeometry;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  bool IsEditable()
  {
    return Editable;
  }
  void OnOk(wxCommandEvent & event);
};

class CandidateVirtualShapeCoverage
{
// a candidate Vector Coverage - VirtualShape
private:
  wxString VirtName;
  wxString VirtGeometry;
  int Srid;
  wxString GeometryType;
  bool VectorCoverage;
  CandidateVirtualShapeCoverage *Next;
public:
    CandidateVirtualShapeCoverage(wxString & virt_name,
                                  wxString & virt_geometry, int srid,
                                  wxString & type)
  {
    VirtName = virt_name;
    VirtGeometry = virt_geometry;
    Srid = srid;
    GeometryType = type;
    VectorCoverage = false;
    Next = NULL;
  }
   ~CandidateVirtualShapeCoverage()
  {;
  }
  wxString & GetVirtName()
  {
    return VirtName;
  }
  wxString & GetVirtGeometry()
  {
    return VirtGeometry;
  }
  int GetSrid()
  {
    return Srid;
  }
  wxString & GetGeometryType()
  {
    return GeometryType;
  }
  void MarkVectorCoverage()
  {
    VectorCoverage = true;
  }
  bool IsVectorCoverage()
  {
    return VectorCoverage;
  }
  CandidateVirtualShapeCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateVirtualShapeCoverage * next)
  {
    Next = next;
  }
};

class CandidateVirtualShapeCoveragesList
{
// a container for candidate Vector Coverages - VirtualShape
private:
  CandidateVirtualShapeCoverage * First;
  CandidateVirtualShapeCoverage *Last;
public:
    CandidateVirtualShapeCoveragesList()
  {
    First = NULL;
    Last = NULL;
  }
   ~CandidateVirtualShapeCoveragesList();
  void Add(wxString & view_name, wxString & geometry, int srid,
           wxString & type);
  void MarkVectorCoverage(wxString & view, wxString & geometry);
  CandidateVirtualShapeCoverage *GetFirst()
  {
    return First;
  }
};

class VirtualShapeRegisterDialog:public wxDialog
{
//
// a dialog for Register Vector Coverage - VirtualShape
//
private:
  MyFrame * MainFrame;
  CandidateVirtualShapeCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString VirtName;
  wxString VirtGeometry;
  wxString Title;
  wxString Abstract;
  bool Queryable;
public:
    VirtualShapeRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ VirtualShapeRegisterDialog()
  {
    if (List != NULL)
      delete List;
  }
  void CreateControls();
  wxString & GetCoverageName()
  {
    return CoverageName;
  }
  wxString & GetVirtName()
  {
    return VirtName;
  }
  wxString & GetVirtGeometry()
  {
    return VirtGeometry;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  void OnOk(wxCommandEvent & event);
};

class CandidateTopoGeoCoverage
{
// a candidate TopoGeo Coverage
private:
  wxString TopologyName;
  int Srid;
  wxString Dimensions;
  double Tolerance;
  bool VectorCoverage;
  CandidateTopoGeoCoverage *Next;
public:
    CandidateTopoGeoCoverage(wxString & topology, int srid,
                             wxString & dimensions, double tolerance)
  {
    TopologyName = topology;
    Srid = srid;
    Dimensions = dimensions;
    Tolerance = tolerance;
    VectorCoverage = false;
    Next = NULL;
  }
   ~CandidateTopoGeoCoverage()
  {;
  }
  wxString & GetTopologyName()
  {
    return TopologyName;
  }
  int GetSrid()
  {
    return Srid;
  }
  wxString & GetDimensions()
  {
    return Dimensions;
  }
  double GetTolerance()
  {
    return Tolerance;
  }
  void MarkVectorCoverage()
  {
    VectorCoverage = true;
  }
  bool IsVectorCoverage()
  {
    return VectorCoverage;
  }
  CandidateTopoGeoCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateTopoGeoCoverage * next)
  {
    Next = next;
  }
};

class CandidateTopoGeoCoveragesList
{
// a container for candidate TopoGeo Coverages
private:
  CandidateTopoGeoCoverage * First;
  CandidateTopoGeoCoverage *Last;
public:
    CandidateTopoGeoCoveragesList()
  {
    First = NULL;
    Last = NULL;
  }
   ~CandidateTopoGeoCoveragesList();
  void Add(wxString & topology, int srid, wxString & dimensions,
           double tolerance);
  void MarkVectorCoverage(wxString & topology);
  CandidateTopoGeoCoverage *GetFirst()
  {
    return First;
  }
};

class TopoGeoRegisterDialog:public wxDialog
{
//
// a dialog for Register TopoGeo Coverage
//
private:
  MyFrame * MainFrame;
  CandidateTopoGeoCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString TopologyName;
  wxString Title;
  wxString Abstract;
  bool Queryable;
  bool Editable;
public:
    TopoGeoRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ TopoGeoRegisterDialog()
  {
    if (List != NULL)
      delete List;
  }
  void CreateControls();
  wxString & GetCoverageName()
  {
    return CoverageName;
  }
  wxString & GetTopologyName()
  {
    return TopologyName;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  bool IsEditable()
  {
    return Editable;
  }
  void OnOk(wxCommandEvent & event);
};

class CandidateTopoNetCoverage
{
// a candidate TopoNet Coverage
private:
  wxString NetworkName;
  int Srid;
  wxString Dimensions;
  bool VectorCoverage;
  CandidateTopoNetCoverage *Next;
public:
    CandidateTopoNetCoverage(wxString & network, int srid,
                             wxString & dimensions)
  {
    NetworkName = network;
    Srid = srid;
    Dimensions = dimensions;
    VectorCoverage = false;
    Next = NULL;
  }
   ~CandidateTopoNetCoverage()
  {;
  }
  wxString & GetNetworkName()
  {
    return NetworkName;
  }
  int GetSrid()
  {
    return Srid;
  }
  wxString & GetDimensions()
  {
    return Dimensions;
  }
  void MarkVectorCoverage()
  {
    VectorCoverage = true;
  }
  bool IsVectorCoverage()
  {
    return VectorCoverage;
  }
  CandidateTopoNetCoverage *GetNext()
  {
    return Next;
  }
  void SetNext(CandidateTopoNetCoverage * next)
  {
    Next = next;
  }
};

class CandidateTopoNetCoveragesList
{
// a container for candidate TopoNet Coverages
private:
  CandidateTopoNetCoverage * First;
  CandidateTopoNetCoverage *Last;
public:
    CandidateTopoNetCoveragesList()
  {
    First = NULL;
    Last = NULL;
  }
   ~CandidateTopoNetCoveragesList();
  void Add(wxString & network, int srid, wxString & dimensions);
  void MarkVectorCoverage(wxString & network);
  CandidateTopoNetCoverage *GetFirst()
  {
    return First;
  }
};

class TopoNetRegisterDialog:public wxDialog
{
//
// a dialog for Register TopoNet Coverage
//
private:
  MyFrame * MainFrame;
  CandidateTopoNetCoveragesList *List;
  wxGrid *GridCtrl;
  wxString CoverageName;
  wxString NetworkName;
  wxString Title;
  wxString Abstract;
  bool Queryable;
  bool Editable;
public:
    TopoNetRegisterDialog()
  {
    List = NULL;
  }
  bool Create(MyFrame * parent);
  virtual ~ TopoNetRegisterDialog()
  {
    if (List != NULL)
      delete List;
  }
  void CreateControls();
  wxString & GetCoverageName()
  {
    return CoverageName;
  }
  wxString & GetNetworkName()
  {
    return NetworkName;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  bool IsEditable()
  {
    return Editable;
  }
  void OnOk(wxCommandEvent & event);
};

class VectorInfosDialog:public wxDialog
{
//
// a dialog for editing Vector Coverage Data
//
private:
  MyFrame * MainFrame;
  wxString CoverageName;
  wxString Title;
  wxString Abstract;
  bool IsQueryable;
  bool IsEditable;
  bool DoReadCoverage();
  void DoUpdateCoverage();
public:
    VectorInfosDialog()
  {;
  }
  bool Create(MyFrame * parent, wxString & coverage);
  virtual ~ VectorInfosDialog()
  {;
  }
  void CreateControls();
  void OnOk(wxCommandEvent & event);
  void OnCancel(wxCommandEvent & event);
};

class VectorCoverageSRID
{
// a Vector Coverage alternative SRID
private:
  int Srid;
................................................................................
    return wxSize(48, 24);
  }
  void SetGraphic(wxImage * graphic)
  {
    Graphic = graphic;
  }
};

class MyBitmapCellRenderer:public wxGridCellRenderer
{
// a Grid CellRenderer supporting a Bitmap
private:
  wxImage Graphic;
public:
  virtual wxGridCellRenderer * Clone() const
  {
    return new MyBitmapCellRenderer;
  }
  virtual void Draw(wxGrid & grid, wxGridCellAttr & attr, wxDC & dc,
                    const wxRect & rect, int row, int col, bool isSelected);
  virtual wxSize GetBestSize(wxGrid & grid, wxGridCellAttr & attr, wxDC & dc,
                             int row, int col)
  {
    // silencing stupid compiler warnings about unused args
    if (grid.IsEditable() && attr.HasFont() && dc.IsOk())
      {
        if (row == col)
          col = row;
      }

    return wxSize(Graphic.GetWidth(), Graphic.GetHeight());
  }
  void SetGraphic(wxBitmap & graphic)
  {
    Graphic = graphic.ConvertToImage();
  }
};

class MyFontCellRenderer:public wxGridCellRenderer
{
// a Grid CellRenderer supporting a Text Font
private:
  wxImage * FontExample;
public:
................................................................................
  int Opaque;
  int SwapXY;
  int Tiled;
  int TileWidth;
  int TileHeight;
  int Queryable;
  void GetButtonBitmap(const char *color, wxBitmap & bmp);
  void ParseBgColor(const char *color, unsigned char *red, unsigned char *green,
                    unsigned char *blue);
  unsigned char ParseHex(const char *byte);
public:
    WmsConfigDialog()
  {;
  }
  virtual ~ WmsConfigDialog()
  {
    if (Version != NULL)
      free(Version);
    if (MaxVersion != NULL)
      free(MaxVersion);
    if (RefSys != NULL)
      free(RefSys);
    if (Style != NULL)
      free(Style);
    if (ImageFormat != NULL)
      free(ImageFormat);
    if (BgColor != NULL)
      free(BgColor);
  }
  bool Create(MyFrame * parent, wxString url, wxString layer);
  void CreateControls();
  const char *GetVersion()
  {
    return Version;
  }
  const char *GetStyle()
................................................................................
  }
  int GetTileHeight()
  {
    return TileHeight;
  }
  void LoadData();
  void FindMaxVersion();
  void PopulateRefSys(wxComboBox * crsList);
  void PopulateImageFormats(wxComboBox * fmtList);
  void PopulateStyles(wxComboBox * stlList);
  void UpdateSwapXY(void);
  void OnCrsChanged(wxCommandEvent & event);
  void OnVersionChanged(wxCommandEvent & event);
  void OnSwapXYChanged(wxCommandEvent & event);
  void OnTiledChanged(wxCommandEvent & event);
  void OnBgColorEnabledChanged(wxCommandEvent & event);
  void OnBgColorChanged(wxCommandEvent & event);
................................................................................
    DATA_TYPE_MULTIPOINT,
    DATA_TYPE_MULTILINESTRING,
    DATA_TYPE_MULTIPOLYGON,
    DATA_TYPE_GEOMETRYCOLLECTION,
    DATA_TYPE_GEOMETRY
  };
};

class MapLayer
{
//
// a class corresponding to a Map layer 
//
private:
  wxString Name;
  wxString Title;
  wxString Abstract;
  int Type;
  bool Visible;
  MapLayer *Prev;
  MapLayer *Next;
public:
    MapLayer(const char *name, const char *title,
             const char *abstract, int type);
   ~MapLayer()
  {;
  }
  wxString & GetName()
  {
    return Name;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  int GetType()
  {
    return Type;
  }
  bool IsVisible()
  {
    return Visible;
  }
  void Hide()
  {
    Visible = false;
  }
  void Show()
  {
    Visible = true;
  }
  void SetPrev(MapLayer * prev)
  {
    Prev = prev;
  }
  MapLayer *GetPrev()
  {
    return Prev;
  }
  void SetNext(MapLayer * next)
  {
    Next = next;
  }
  MapLayer *GetNext()
  {
    return Next;
  }
};

class MyLayerTree:public wxTreeCtrl
{
//
// a tree-control used for Map Layers
//
private:
  class MyMapPanel * MapPanel;
  bool Changed;
  wxTreeItemId Root;            // the root node
  wxImageList *Images;          // the images list
  wxTreeItemId CurrentItem;     // the tree item holding the current context menu
  wxTreeItemId DraggedItem;     // the tree item to be moved
public:
    MyLayerTree()
  {;
  }
  MyLayerTree(MyMapPanel * parent, wxWindowID id = wxID_ANY);
  virtual ~ MyLayerTree();
  void FlushAll()
  {
    DeleteChildren(Root);
    Changed = true;
  }
  wxTreeItemId & GetRoot()
  {
    return Root;
  }
  void CleanUp();
  void AddLayer(MapLayer * layer);
  void SetLayerIcons();
  void MarkCurrentItem();
  void SelectActiveItem(MapLayer * layer);
  void UpdateDefault(wxTreeItemId item, wxImageList * imageList);
  void OnSelChanged(wxTreeEvent & event);
  void OnItemActivated(wxTreeEvent & event);
  void OnRightClick(wxTreeEvent & event);
  void OnCmdRemoveAll(wxCommandEvent & event);
  void OnCmdShowAll(wxCommandEvent & event);
  void OnCmdHideAll(wxCommandEvent & event);
  void OnCmdVisible(wxCommandEvent & event);
  void OnCmdConfigure(wxCommandEvent & event);
  void OnCmdRemoveLayer(wxCommandEvent & event);
  void OnCmdDeleteItem(wxCommandEvent & event);
  void OnCmdLayerInfo(wxCommandEvent & event);
  void OnDragStart(wxTreeEvent & event);
  void OnDragEnd(wxTreeEvent & event);
};

class MapLayerObject:public wxTreeItemData
{
//
// a class to store TreeItemData - Map Layer wrapper
//
private:
  MapLayer * Layer;
public:
  MapLayerObject(MapLayer * lyr)
  {
    Layer = lyr;
  }
  virtual ~ MapLayerObject()
  {;
  }
  MapLayer *GetLayer()
  {
    return Layer;
  }
};

class MyMapView:public wxPanel
{
//
// a panel used  to show the Map
//
private:
  class MyMapPanel * MapPanel;
  wxBitmap MapBitmap;
  wxBitmap ScreenBitmap;
  int BitmapWidth;
  int BitmapHeight;
  wxCursor CursorCross;
  wxCursor CursorHand;
  bool ValidMap;
  MapLayer *FirstLayer;
  MapLayer *LastLayer;
  MapLayer *ActiveLayer;
public:
    MyMapView()
  {;
  }
  MyMapView(MyMapPanel * parent, wxWindowID id = wxID_ANY);
  virtual ~ MyMapView();
  void Invalidate();
  void PrepareMap();

  void SetActiveMapLayer(MapLayer * layer)
  {
    ActiveLayer = layer;
  }
  bool IsActiveLayer(MapLayer * layer)
  {
    if (ActiveLayer == layer)
      return true;
    return false;
  }
  bool IsValidMap()
  {
    return ValidMap;
  }
  bool CanIdentify();
  void ResetMapLayers();
  void RemoveMapLayer(MapLayer * layer);
  void ReinsertMapLayer(MapLayer * layer);

  void OnEraseBackground(wxEraseEvent & WXUNUSED(event))
  {;
  }
  void OnSize(wxSizeEvent & event);
  void OnPaint(wxPaintEvent & event);
};

class MyMapPanel:public wxFrame
{
//
// the main Map Panel
//
private:
  MyFrame * Parent;
  wxAuiManager Manager;         // the GUI manager
  wxString ConfigLayout;        // PERSISTENCY - the layout configuration
  int ConfigPaneX;              // PERSISTENCY - the map pane screen origin X
  int ConfigPaneY;              // PERSISTENCY - the map pane screen origin Y
  int ConfigPaneWidth;          // PERSISTENCY - the map pane screen width
  int ConfigPaneHeight;         // PERSISTENCY - the map pane screen height
  MyLayerTree *LayerTree;       // the layer tree list
  MyMapView *MapView;           // the map panel
  wxBitmap *BtnAddLayer;        // button icon for adding a Map Layer
  wxBitmap *BtnCenter;          // button icon for Zoom to Full Extent
  wxBitmap *BtnIdentify;        // buttom icon for Identify
  wxBitmap *BtnZoomIn;          // button icon for Zoom In
  wxBitmap *BtnZoomOut;         // buttom icon for Zoom Out
  wxBitmap *BtnUserScale;       // buttom icon for User Scale
  wxBitmap *BtnPan;             // button icon for Pan
  wxBitmap *BtnPrinter;         // button icon for Printer
  wxBitmap *BtnAbout;           // button icon for ABOUT
  wxBitmap *BtnExit;            // button icon for EXIT
  bool IsIdentify;              // current map click is: Identify
  bool IsZoomIn;                // current map click is: ZoomIn
  bool IsZoomOut;               // current map click is: ZoomOut
  bool IsPan;                   // current map click is: Pan
public:
    MyMapPanel(MyFrame * parent, const wxString & title, const wxPoint & pos,
               const wxSize & size);
    virtual ~ MyMapPanel();

  void UpdateTools();
  void ParentQuit();

  void ResetMapLayers()
  {
    MapView->ResetMapLayers();
  }
  void ReinsertMapLayer(MapLayer * layer)
  {
    MapView->ReinsertMapLayer(layer);
  }
  void SetActiveMapLayer(MapLayer * layer)
  {
    MapView->SetActiveMapLayer(layer);
  }
  bool IsActiveLayer(MapLayer * layer)
  {
    return MapView->IsActiveLayer(layer);
  }
  void RemoveMapLayer(MapLayer * layer)
  {
    MapView->RemoveMapLayer(layer);
  }
  void RefreshMap()
  {
    MapView->PrepareMap();
  }
  sqlite3 *GetSqlite()
  {
    return Parent->GetSqlite();
  }

  void OnAddLayer(wxCommandEvent & event);
  void OnCenter(wxCommandEvent & event);
  void OnIdentify(wxCommandEvent & event);
  void OnZoomIn(wxCommandEvent & event);
  void OnZoomOut(wxCommandEvent & event);
  void OnUserScale(wxCommandEvent & event);
  void OnPan(wxCommandEvent & event);
  void OnPrinter(wxCommandEvent & event);
  void OnQuit(wxCommandEvent & event);
  void OnAbout(wxCommandEvent & event);
};

class LayerListItem
{
// a class wrapping a Layer
private:
  wxString DbPrefix;
  wxString LayerPrefix;
  int LayerType;
  wxString LayerName;
  wxString Title;
  wxString Abstract;
  char *f_table_name;
  char *f_geometry_column;
  char *topology_name;
  char *network_name;
  int GeometryType;
  bool HasZ;
  int NativeSrid;
  bool Queryable;
  bool Editable;
  bool SpatialIndex;
  LayerListItem *Next;
public:
    LayerListItem(wxString & db_prefix, int type, wxString & name,
                  wxString & title, wxString & abstract, bool queryable);
    LayerListItem(wxString & db_prefix, wxString & layer_prefix,
                  wxString & name, wxString & title, wxString & abstract,
                  const char *f_table_name, const char *f_geometry_column,
                  int geom_type, int srid, bool queryable, bool editable,
                  bool spatial_index);
    LayerListItem(wxString & db_prefix, int type, wxString & name,
                  wxString & title, wxString & abstract, const char *topo_name,
                  bool has_z, int srid, bool queryable, bool editable);
   ~LayerListItem();
    wxString & GetDbPrefix()
  {
    return DbPrefix;
  }
  wxString & GetLayerPrefix()
  {
    return LayerPrefix;
  }
  int GetLayerType()
  {
    return LayerType;
  }
  wxString & GetLayerName()
  {
    return LayerName;
  }
  wxString & GetTitle()
  {
    return Title;
  }
  wxString & GetAbstract()
  {
    return Abstract;
  }
  const char *GetTableName()
  {
    return f_table_name;
  }
  const char *GetGeometryColumn()
  {
    return f_geometry_column;
  }
  const char *GetTopologyName()
  {
    return topology_name;
  }
  const char *GetNetworkName()
  {
    return network_name;
  }
  int GetGeometryType()
  {
    return GeometryType;
  }
  bool GetHasZ()
  {
    return HasZ;
  }
  int GetSrid()
  {
    return NativeSrid;
  }
  bool IsQueryable()
  {
    return Queryable;
  }
  bool IsEditable()
  {
    return Editable;
  }
  bool HasSpatialIndex()
  {
    return SpatialIndex;
  }
  void SetNext(LayerListItem * next)
  {
    Next = next;
  }
  LayerListItem *GetNext()
  {
    return Next;
  }
};

class AddMapLayerDialog:public wxDialog
{
//
// a Dialog for adding a Map Layer
//
private:
  MyMapPanel * MapPanel;
  LayerListItem *First;
  LayerListItem *Last;
  wxGrid *Layers;
  void FlushList();
  void AddLayer2List(wxString & db_prefix, int layer_type, wxString & name,
                     wxString & title, wxString & abstract, bool queryable);
  void AddLayer2List(wxString & db_prefix, wxString & layer_prefix,
                     wxString & name, wxString & title, wxString & abstract,
                     const char *f_table_name, const char *f_geometry_column,
                     int geom_type, int srid, bool queryable, bool editable,
                     bool spatial_index);
  void AddLayer2List(wxString & db_prefix, int type, wxString & name,
                     wxString & title, wxString & abstract,
                     const char *topo_name, bool has_z, int srid,
                     bool queryable, bool editable);
  void DoLoadVectorCoverages();
  void DoLoadTopoGeoCoverages();
  void DoLoadTopoNetCoverages();
  void DoLoadRasterCoverages();
  void DoLoadWmsCoverages();
  char *QueryVectorCoverages(const char *db_prefix, const char *old_sql);
  char *QuerySpatialViewCoverages(const char *db_prefix, const char *old_sql);
  char *QueryVirtualShapeCoverages(const char *db_prefix, const char *old_sql);
  char *QueryTopoGeoCoverages(const char *db_prefix, const char *old_sql);
  char *QueryTopoNetCoverages(const char *db_prefix, const char *old_sql);
  char *QueryRasterCoverages(const char *db_prefix, const char *old_sql);
  char *QueryWmsCoverages(const char *db_prefix, const char *old_sql);
  bool DoCheckGeometryColumns(const char *db_prefix);
  bool DoCheckViewsGeometryColumns(const char *db_prefix);
  bool DoCheckVirtsGeometryColumns(const char *db_prefix);
  bool DoCheckTopologies(const char *db_prefix);
  bool DoCheckNetworks(const char *db_prefix);
  bool DoCheckVectorCoverages(const char *db_prefix);
  bool DoCheckTopoGeoCoverages(const char *db_prefix);
  bool DoCheckTopoNetCoverages(const char *db_prefix);
  bool DoCheckRasterCoverages(const char *db_prefix);
  bool DoCheckWmsCoverages(const char *db_prefix);
public:
    AddMapLayerDialog()
  {
    MapPanel = NULL;
    First = NULL;
    Last = NULL;
  }
  AddMapLayerDialog(MyMapPanel * parent)
  {
    Create(parent);
  }
  bool Create(MyMapPanel * parent);
  virtual ~ AddMapLayerDialog()
  {
    FlushList();
  }
  void CreateControls();

  void OnOk(wxCommandEvent & event);
  void OnCancel(wxCommandEvent & event);
};

Changes to Main.cpp.

71
72
73
74
75
76
77

78
79
80
81
82
83
84
...
109
110
111
112
113
114
115

116
117
118
119
120
121
122
...
327
328
329
330
331
332
333

334
335
336
337
338
339
340
...
431
432
433
434
435
436
437








438
439
440
441
442
443
444
...
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
...
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551

552
553
554
555
556
557
558
...
601
602
603
604
605
606
607
608
609
610
611
612

613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688

689
690
691
692
693
694
695
...
729
730
731
732
733
734
735


736
737
738
739
740
741
742
...
781
782
783
784
785
786
787


788
789
790
791
792
793
794
...
806
807
808
809
810
811
812


813
814
815
816
817
818
819
...
825
826
827
828
829
830
831


832
833
834
835
836
837
838
...
843
844
845
846
847
848
849


850
851
852
853
854
855
856
...
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
...
985
986
987
988
989
990
991

992
993
994
995
996
997
998
....
1026
1027
1028
1029
1030
1031
1032

1033
1034
1035
1036
1037
1038
1039
....
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081











1082
1083
1084
1085
1086
1087
1088
....
1554
1555
1556
1557
1558
1559
1560

1561
1562
1563
1564
1565
1566
1567
....
1595
1596
1597
1598
1599
1600
1601

1602
1603
1604
1605
1606
1607
1608
....
1656
1657
1658
1659
1660
1661
1662

1663
1664
1665
1666
1667
1668
1669
....
1681
1682
1683
1684
1685
1686
1687

1688
1689
1690
1691
1692
1693
1694
....
1761
1762
1763
1764
1765
1766
1767

1768
1769
1770
1771
1772
1773
1774
....
1802
1803
1804
1805
1806
1807
1808

1809
1810
1811
1812
1813
1814
1815
....
1865
1866
1867
1868
1869
1870
1871

1872
1873
1874
1875
1876
1877
1878
....
1898
1899
1900
1901
1902
1903
1904

1905
1906
1907
1908
1909
1910
1911
....
1967
1968
1969
1970
1971
1972
1973

1974
1975
1976
1977
1978
1979
1980
....
2001
2002
2003
2004
2005
2006
2007

2008
2009
2010
2011
2012
2013
2014
....
2150
2151
2152
2153
2154
2155
2156

2157
2158
2159
2160
2161
2162
2163
....
2191
2192
2193
2194
2195
2196
2197

2198
2199
2200
2201
2202
2203
2204
....
2293
2294
2295
2296
2297
2298
2299

2300
2301
2302
2303
2304
2305
2306
....
2327
2328
2329
2330
2331
2332
2333

2334
2335
2336
2337
2338
2339
2340
....
2759
2760
2761
2762
2763
2764
2765










































2766
2767
2768
2769
2770
2771
2772
....
4314
4315
4316
4317
4318
4319
4320
4321
4322
4323
4324
4325
4326
4327
4328
....
4329
4330
4331
4332
4333
4334
4335

4336
4337
4338
4339
4340
4341
4342
....
4403
4404
4405
4406
4407
4408
4409


4410
4411
4412
4413
4414
4415
4416
4417
4418
4419
4420
4421
4422
....
4910
4911
4912
4913
4914
4915
4916
4917
4918
4919
4920
4921
4922
4923
4924
....
5673
5674
5675
5676
5677
5678
5679



5680

5681
5682
5683
5684
5685
5686
5687
....
7667
7668
7669
7670
7671
7672
7673
7674
7675
7676
7677
7678
















7679
7680
7681
7682
7683
7684
7685
....
7691
7692
7693
7694
7695
7696
7697

7698
7699

7700
7701
7702
7703
7704
7705
7706
7707
....
7848
7849
7850
7851
7852
7853
7854
7855
7856
7857
7858
7859
7860
7861
7862
....
7866
7867
7868
7869
7870
7871
7872














7873
7874
7875
7876
7877
7878
7879
....
7902
7903
7904
7905
7906
7907
7908
7909
7910
7911
7912
7913
7914
7915
7916
....
7942
7943
7944
7945
7946
7947
7948
7949
7950
7951
7952
7953
7954
7955
7956
....
7977
7978
7979
7980
7981
7982
7983
7984

7985
7986
7987
7988
7989
7990
7991
7992
7993
7994
7995
7996
7997
7998
7999




















8000
8001
8002
8003
8004
8005
8006
....
8012
8013
8014
8015
8016
8017
8018

8019
8020

8021
8022

8023
8024
8025
8026
8027
8028
8029
#include "icons/attach.xpm"
#include "icons/sql_log.xpm"
#include "icons/db_status.xpm"
#include "icons/checkgeom.xpm"
#include "icons/sanegeom.xpm"
#include "icons/wfs.xpm"
#include "icons/dxf.xpm"

#include "icons/security_lock.xpm"
#include "icons/security_relaxed.xpm"
#include "icons/security_rdonly.xpm"


#if defined(_WIN32) && !defined(__MINGW32__)
#define unlink	_unlink
................................................................................
//
// main GUI frame constructor
//
  setlocale(LC_ALL, "");
// forcing DECIMAL POINT IS COMMA
  setlocale(LC_NUMERIC, "C");


  Old_SPATIALITE_SECURITY_ENV = NULL;
  RL2MaxThreads = 1;
  wxImage::AddHandler(new wxPNGHandler);
  MemoryDatabase = false;
  AutoSaveInterval = 0;
  LastTotalChanges = 0;
  TimerAutoSave = NULL;
................................................................................
  BtnAttach = new wxBitmap(attach_xpm);
  BtnSqlLog = new wxBitmap(sql_log_xpm);
  BtnDbStatus = new wxBitmap(db_status_xpm);
  BtnCheckGeom = new wxBitmap(checkgeom_xpm);
  BtnSaneGeom = new wxBitmap(sanegeom_xpm);
  BtnWFS = new wxBitmap(wfs_xpm);
  BtnDXF = new wxBitmap(dxf_xpm);


//
// setting up the application icon
//      
  wxIcon MyIcon(icon_xpm);
  SetIcon(MyIcon);

................................................................................
  menuItem->SetBitmap(*BtnDisconnect);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_Vacuum,
                   wxT("&Optimizing current SQLite DB [VACUUM]"));
  menuItem->SetBitmap(*BtnVacuum);
  menuFile->Append(menuItem);








  menuFile->AppendSeparator();
  wxMenu *advancedMenu = new wxMenu();
  menuItem =
    new wxMenuItem(advancedMenu, ID_SqlScript, wxT("&Execute SQL script"));
  menuItem->SetBitmap(*BtnSqlScript);
  advancedMenu->Append(menuItem);
  advancedMenu->AppendSeparator();
................................................................................
  menuItem->SetBitmap(*BtnSrids);
  advancedMenu->Append(menuItem);
  menuItem =
    new wxMenuItem(advancedMenu, ID_Charset, wxT("&Default Output Charset"));
  menuItem->SetBitmap(*BtnCharset);
  advancedMenu->Append(menuItem);
  menuFile->AppendSubMenu(advancedMenu, wxT("&Advanced"));
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, ID_Attach, wxT("&Attach DataBase"));
  menuItem->SetBitmap(*BtnAttach);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem =
    new wxMenuItem(menuFile, ID_SqlLog, wxT("&SQL Log"), wxT("&SQL Log"),
                   wxITEM_CHECK);
  menuFile->Append(menuItem);
  menuItem = new wxMenuItem(menuFile, ID_DbStatus, wxT("&DB Status"));
  menuFile->Append(menuItem);
................................................................................
  menuItem->SetBitmap(*BtnAbout);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, wxID_EXIT, wxT("&Quit"));
  menuItem->SetBitmap(*BtnExit);
  menuFile->Append(menuItem);
  wxMenuBar *menuBar = new wxMenuBar;
  menuBar->Append(menuFile, wxT("&Files"));
  SetMenuBar(menuBar);

//
// setting up menu initial state 
//
  menuBar->Enable(ID_Disconnect, false);
  menuBar->Enable(ID_MemoryDbClock, false);
  menuBar->Enable(ID_MemoryDbSave, false);
  menuBar->Enable(ID_Vacuum, false);

  menuBar->Enable(ID_SqlScript, false);
  menuBar->Enable(ID_QueryViewComposer, false);
  menuBar->Enable(ID_LoadShp, false);
  menuBar->Enable(ID_VirtualShp, false);
  menuBar->Enable(ID_LoadTxt, false);
  menuBar->Enable(ID_VirtualTxt, false);
  menuBar->Enable(ID_LoadDbf, false);
................................................................................
                   wxT("Saving the current MEMORY-DB"));
  toolBar->AddTool(ID_Disconnect, wxT("Disconnecting current SQLite DB"),
                   *BtnDisconnect, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Disconnecting current SQLite DB"));
  toolBar->AddTool(ID_Vacuum, wxT("Optimizing current SQLite DB [VACUUM]"),
                   *BtnVacuum, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Optimizing current SQLite DB [VACUUM]"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Attach, wxT("Attach DataBase"),
                   *BtnAttach, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Attach DataBase"));
  //toolBar->AddSeparator();

  toolBar->AddTool(ID_SqlLog, wxT("SQL Log"),
                   *BtnSqlLog, wxNullBitmap, wxITEM_CHECK, wxT("SQL Log"));
  toolBar->AddTool(ID_DbStatus, wxT("DB Status"),
                   *BtnDbStatus, wxNullBitmap, wxITEM_NORMAL, wxT("DB Status"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_CheckGeom, wxT("Check Geometries"),
                   *BtnCheckGeom, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Check Geometries"));
  toolBar->AddTool(ID_SaneGeom, wxT("Sanitize Geometries"), *BtnSaneGeom,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Sanitize Geometries"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_SqlScript, wxT("Execute SQL script"), *BtnSqlScript,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Execute SQL script"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_QueryViewComposer, wxT("Query/View Composer"),
                   *BtnQueryComposer, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Query/View Composer"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_LoadShp, wxT("Load Shapefile"), *BtnLoadShp, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load Shapefile"));
  toolBar->AddTool(ID_VirtualShp, wxT("Virtual Shapefile"), *BtnVirtualShp,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual Shapefile"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_LoadTxt, wxT("Load CSV/TXT"), *BtnLoadTxt, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load CSV/TXT"));
  toolBar->AddTool(ID_VirtualTxt, wxT("Virtual CSV/TXT"), *BtnVirtualTxt,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual CSV/TXT"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_LoadDbf, wxT("Load DBF"), *BtnLoadDbf, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load DBF"));
  toolBar->AddTool(ID_VirtualDbf, wxT("Virtual DBF"), *BtnVirtualDbf,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual DBF"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_LoadXL, wxT("Load XLS"), *BtnLoadXL, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load XLS"));
  toolBar->AddTool(ID_VirtualXL, wxT("Virtual XLS"), *BtnVirtualXL,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual XLS"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Network, wxT("Build Network"), *BtnNetwork, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Build Network"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Exif, wxT("Import EXIF photos"), *BtnExif, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Import EXIF photos"));
  toolBar->AddTool(ID_GpsPics, wxT("Import GPS photos"), *BtnGpsPics,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Import GPS photos"));
  toolBar->AddTool(ID_LoadXml, wxT("Import XML Documents"), *BtnLoadXml,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Import XML Documents"));
  toolBar->AddTool(ID_WFS, wxT("Import data from WFS datasource"), *BtnWFS,
                   wxNullBitmap, wxITEM_NORMAL,
                   wxT("Import data from WFS datasource"));
  toolBar->AddTool(ID_DXF, wxT("Import DXF drawings"), *BtnDXF, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Import DXF drawings"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Srids, wxT("Search SRID by name"), *BtnSrids,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Search SRID by name"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Charset, wxT("Default Output Charset"), *BtnCharset,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Default Output Charset"));
  //toolBar->AddSeparator();
  toolBar->AddTool(ID_Help, wxT("Help"), *BtnHelp, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Help"));
  toolBar->AddTool(wxID_ABOUT, wxT("About ..."), *BtnAbout, wxNullBitmap,
                   wxITEM_NORMAL, wxT("About ..."));
  //toolBar->AddSeparator();
  toolBar->AddTool(wxID_EXIT, wxT("Quit"), *BtnExit, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Quit"));
  toolBar->Realize();
  SetToolBar(toolBar);

//
// setting up the toolbar initial state
//
  toolBar->EnableTool(ID_Disconnect, false);
  toolBar->EnableTool(ID_MemoryDbClock, false);
  toolBar->EnableTool(ID_MemoryDbSave, false);
  toolBar->EnableTool(ID_Vacuum, false);

  toolBar->EnableTool(ID_SqlScript, false);
  toolBar->EnableTool(ID_QueryViewComposer, false);
  toolBar->EnableTool(ID_LoadShp, false);
  toolBar->EnableTool(ID_VirtualShp, false);
  toolBar->EnableTool(ID_LoadTxt, false);
  toolBar->EnableTool(ID_VirtualTxt, false);
  toolBar->EnableTool(ID_LoadDbf, false);
................................................................................
          (wxObjectEventFunction) & MyFrame::OnMemoryDbNew);
  Connect(ID_MemoryDbClock, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnMemoryDbClock);
  Connect(ID_MemoryDbSave, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnMemoryDbSave);
  Connect(ID_Vacuum, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnVacuum);


  Connect(ID_SqlScript, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnSqlScript);
  Connect(ID_QueryViewComposer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnQueryViewComposer);
  Connect(ID_LoadShp, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnLoadShp);
  Connect(ID_VirtualShp, wxEVT_COMMAND_MENU_SELECTED,
................................................................................
          (wxObjectEventFunction) & MyFrame::OnSanitizeGeometries);
  Connect(ID_Help, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnHelp);
  Connect(wxID_ABOUT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnAbout);
  Connect(wxID_EXIT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnQuit);


  Connect(wxID_ANY, wxEVT_MOTION, wxMouseEventHandler(MyFrame::OnMouseMove),
          NULL, this);

//
// setting up event handlers for mouse
//
  TableTree->Connect(wxID_ANY, wxEVT_MOTION,
................................................................................
}

MyFrame::~MyFrame()
{
//
// main GUI frame destructor
//


  if (TimerAutoSave)
    {
      TimerAutoSave->Stop();
      delete TimerAutoSave;
    }
  LastDitchMemoryDbSave();
  ConfigLayout = Manager.SavePerspective();
................................................................................
  if (SqliteHandle)
    sqlite3_close(SqliteHandle);
  if (SpliteInternalCache)
    spatialite_cleanup_ex(SpliteInternalCache);
  spatialite_shutdown();
  SaveConfig();
  Manager.UnInit();


  if (BtnConnect != NULL)
    delete BtnConnect;
  if (BtnConnectReadOnly != NULL)
    delete BtnConnectReadOnly;
  if (BtnCreateNew != NULL)
    delete BtnCreateNew;
  if (BtnDisconnect != NULL)
................................................................................
    delete BtnMemDbNew;
  if (BtnMemDbClock != NULL)
    delete BtnMemDbClock;
  if (BtnMemDbSave != NULL)
    delete BtnMemDbSave;
  if (BtnVacuum != NULL)
    delete BtnVacuum;


  if (BtnSqlScript != NULL)
    delete BtnSqlScript;
  if (BtnQueryComposer != NULL)
    delete BtnQueryComposer;
  if (BtnLoadShp != NULL)
    delete BtnLoadShp;
  if (BtnVirtualShp != NULL)
................................................................................
}

void MyFrame::SaveConfig()
{
//
// saves layout configuration
//

  wxConfig *config = new wxConfig(wxT("SpatialiteGui"));
  config->Write(wxT("Layout"), ConfigLayout);
  config->Write(wxT("PaneX"), ConfigPaneX);
  config->Write(wxT("PaneY"), ConfigPaneY);
  config->Write(wxT("PaneWidth"), ConfigPaneWidth);
  config->Write(wxT("PaneHeight"), ConfigPaneHeight);
  config->Write(wxT("SqlitePath"), SqlitePath);
................................................................................
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_CreateNew, false);
          menuBar->Enable(ID_Disconnect, true);
          menuBar->Enable(ID_Vacuum, true);

          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_CreateNew, false);
          toolBar->EnableTool(ID_Disconnect, true);
          toolBar->EnableTool(ID_Vacuum, true);

          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
}

void MyFrame::OnQuit(wxCommandEvent & WXUNUSED(event))
{
//
// EXIT - event handler
//
  CloseDB();
  Close(true);
}












void MyFrame::OnAttachDatabase(wxCommandEvent & WXUNUSED(event))
{
//
// Attach Database - event handler
//
  int ret;
................................................................................
              menuBar->Enable(ID_MemoryDbClock, true);
          } else
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_Vacuum, true);

          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
              toolBar->EnableTool(ID_MemoryDbClock, true);
          } else
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_Vacuum, true);

          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
      mode2 = false;
      mode3 = false;
    }

  wxMenuBar *menuBar = GetMenuBar();
  menuBar->Enable(ID_Disconnect, mode);
  menuBar->Enable(ID_Vacuum, mode);

  menuBar->Enable(ID_SqlScript, mode);
  menuBar->Enable(ID_QueryViewComposer, mode2);
  menuBar->Enable(ID_LoadShp, mode);
  menuBar->Enable(ID_VirtualShp, mode);
  menuBar->Enable(ID_LoadTxt, mode);
  menuBar->Enable(ID_VirtualTxt, mode);
  menuBar->Enable(ID_LoadDbf, mode);
................................................................................
  menuBar->Enable(ID_SqlLog, mode);
  menuBar->Enable(ID_DbStatus, mode);
  menuBar->Enable(ID_CheckGeom, mode);
  menuBar->Enable(ID_SaneGeom, mode);
  wxToolBar *toolBar = GetToolBar();
  toolBar->EnableTool(ID_Disconnect, mode);
  toolBar->EnableTool(ID_Vacuum, mode);

  toolBar->EnableTool(ID_SqlScript, mode);
  toolBar->EnableTool(ID_QueryViewComposer, mode2);
  toolBar->EnableTool(ID_LoadShp, mode);
  toolBar->EnableTool(ID_VirtualShp, mode);
  toolBar->EnableTool(ID_LoadTxt, mode);
  toolBar->EnableTool(ID_VirtualTxt, mode);
  toolBar->EnableTool(ID_LoadDbf, mode);
................................................................................
              menuBar->Enable(ID_MemoryDbClock, true);
          } else
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_Vacuum, true);

          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
              toolBar->EnableTool(ID_MemoryDbClock, true);
          } else
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_Vacuum, true);

          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
  menuBar->Enable(ID_CreateNew, true);
  menuBar->Enable(ID_Disconnect, false);
  menuBar->Enable(ID_MemoryDbLoad, true);
  menuBar->Enable(ID_MemoryDbNew, true);
  menuBar->Enable(ID_MemoryDbSave, false);
  menuBar->Enable(ID_MemoryDbClock, false);
  menuBar->Enable(ID_Vacuum, false);

  menuBar->Enable(ID_SqlScript, false);
  menuBar->Enable(ID_QueryViewComposer, false);
  menuBar->Enable(ID_LoadShp, false);
  menuBar->Enable(ID_VirtualShp, false);
  menuBar->Enable(ID_LoadTxt, false);
  menuBar->Enable(ID_VirtualTxt, false);
  menuBar->Enable(ID_LoadDbf, false);
................................................................................
  toolBar->EnableTool(ID_CreateNew, true);
  toolBar->EnableTool(ID_Disconnect, false);
  toolBar->EnableTool(ID_MemoryDbLoad, true);
  toolBar->EnableTool(ID_MemoryDbNew, true);
  toolBar->EnableTool(ID_MemoryDbSave, false);
  toolBar->EnableTool(ID_MemoryDbClock, false);
  toolBar->EnableTool(ID_Vacuum, false);

  toolBar->EnableTool(ID_SqlScript, false);
  toolBar->EnableTool(ID_QueryViewComposer, false);
  toolBar->EnableTool(ID_LoadShp, false);
  toolBar->EnableTool(ID_VirtualShp, false);
  toolBar->EnableTool(ID_LoadTxt, false);
  toolBar->EnableTool(ID_VirtualTxt, false);
  toolBar->EnableTool(ID_LoadDbf, false);
................................................................................
      menuBar->Enable(ID_CreateNew, false);
      menuBar->Enable(ID_Disconnect, true);
      menuBar->Enable(ID_MemoryDbLoad, false);
      menuBar->Enable(ID_MemoryDbNew, false);
      menuBar->Enable(ID_MemoryDbSave, false);
      menuBar->Enable(ID_MemoryDbClock, false);
      menuBar->Enable(ID_Vacuum, true);

      menuBar->Enable(ID_SqlScript, true);
      menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
      menuBar->Enable(ID_LoadShp, true);
      menuBar->Enable(ID_VirtualShp, true);
      menuBar->Enable(ID_LoadTxt, true);
      menuBar->Enable(ID_VirtualTxt, true);
      menuBar->Enable(ID_LoadDbf, true);
................................................................................
      toolBar->EnableTool(ID_CreateNew, false);
      toolBar->EnableTool(ID_Disconnect, true);
      toolBar->EnableTool(ID_MemoryDbLoad, false);
      toolBar->EnableTool(ID_MemoryDbNew, false);
      toolBar->EnableTool(ID_MemoryDbSave, false);
      toolBar->EnableTool(ID_MemoryDbClock, false);
      toolBar->EnableTool(ID_Vacuum, true);

      toolBar->EnableTool(ID_SqlScript, true);
      toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
      toolBar->EnableTool(ID_LoadShp, true);
      toolBar->EnableTool(ID_VirtualShp, true);
      toolBar->EnableTool(ID_LoadTxt, true);
      toolBar->EnableTool(ID_VirtualTxt, true);
      toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
          menuBar->Enable(ID_MemoryDbClock, true);
      } else
        {
          menuBar->Enable(ID_MemoryDbSave, false);
          menuBar->Enable(ID_MemoryDbClock, false);
        }
      menuBar->Enable(ID_Vacuum, true);

      menuBar->Enable(ID_SqlScript, true);
      menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
      menuBar->Enable(ID_LoadShp, true);
      menuBar->Enable(ID_VirtualShp, true);
      menuBar->Enable(ID_LoadTxt, true);
      menuBar->Enable(ID_VirtualTxt, true);
      menuBar->Enable(ID_LoadDbf, true);
................................................................................
          toolBar->EnableTool(ID_MemoryDbClock, true);
      } else
        {
          toolBar->EnableTool(ID_MemoryDbSave, false);
          toolBar->EnableTool(ID_MemoryDbClock, false);
        }
      toolBar->EnableTool(ID_Vacuum, true);

      toolBar->EnableTool(ID_SqlScript, true);
      toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
      toolBar->EnableTool(ID_LoadShp, true);
      toolBar->EnableTool(ID_VirtualShp, true);
      toolBar->EnableTool(ID_LoadTxt, true);
      toolBar->EnableTool(ID_VirtualTxt, true);
      toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
  menuBar->Enable(ID_CreateNew, false);
  menuBar->Enable(ID_Disconnect, true);
  menuBar->Enable(ID_MemoryDbLoad, false);
  menuBar->Enable(ID_MemoryDbNew, false);
  menuBar->Enable(ID_MemoryDbSave, true);
  menuBar->Enable(ID_MemoryDbClock, true);
  menuBar->Enable(ID_Vacuum, true);

  menuBar->Enable(ID_SqlScript, true);
  menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
  menuBar->Enable(ID_LoadShp, true);
  menuBar->Enable(ID_VirtualShp, true);
  menuBar->Enable(ID_LoadTxt, true);
  menuBar->Enable(ID_VirtualTxt, true);
  menuBar->Enable(ID_LoadDbf, true);
................................................................................
  toolBar->EnableTool(ID_CreateNew, false);
  toolBar->EnableTool(ID_Disconnect, true);
  toolBar->EnableTool(ID_MemoryDbLoad, false);
  toolBar->EnableTool(ID_MemoryDbNew, false);
  toolBar->EnableTool(ID_MemoryDbSave, true);
  toolBar->EnableTool(ID_MemoryDbClock, true);
  toolBar->EnableTool(ID_Vacuum, true);

  toolBar->EnableTool(ID_SqlScript, true);
  toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
  toolBar->EnableTool(ID_LoadShp, true);
  toolBar->EnableTool(ID_VirtualShp, true);
  toolBar->EnableTool(ID_LoadTxt, true);
  toolBar->EnableTool(ID_VirtualTxt, true);
  toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
                  totalPages - totalPages2);
          msg += wxString::FromUTF8(dummy);
        }
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
    }
  ::wxEndBusyCursor();
}











































char *MyFrame::ReadSqlLine(FILE * in, int *len, int *eof)
{
//
// reading an SQL script line
//
  int c;
................................................................................
                                   int Quality, int TileWidth, int TileHeight,
                                   bool NotGeoreferenced, int Srid,
                                   double HorzResolution, double VertResolution,
                                   wxString NoData, bool StrictResolution,
                                   bool MixedResolutions, bool InputPaths,
                                   bool MD5, bool Summary, int RedBand,
                                   int GreenBand, int BlueBand, int NIRband,
                                   bool AutoNDVI)
{
//
// actual creation of a Raster Coverage 
//
  int ret;
  const char *sql;
  char *errMsg = NULL;
................................................................................
  sqlite3_stmt *stmt = NULL;
  char *err_msg = NULL;
  int strict_resolution = 0;
  int mixed_resolutions = 0;
  int section_paths = 0;
  int section_md5 = 0;
  int section_summary = 0;

  rl2PalettePtr palette = NULL;
  rl2PixelPtr no_data = NULL;
  bool retval = false;
  char *dummy;

// starting a transaction 
  ret = sqlite3_exec(SqliteHandle, "BEGIN", NULL, NULL, &errMsg);
................................................................................
    mixed_resolutions = 1;
  if (InputPaths)
    section_paths = 1;
  if (MD5)
    section_md5 = 1;
  if (Summary)
    section_summary = 1;



  if (rl2_create_dbms_coverage
      (SqliteHandle, CoverageName.ToUTF8(), SampleType, PixelType, NumBands,
       Compression, Quality, TileWidth, TileHeight, Srid, HorzResolution,
       VertResolution, no_data, palette, strict_resolution, mixed_resolutions,
       section_paths, section_md5, section_summary) != RL2_OK)
    {
      wxMessageBox(wxT("ERROR: unable to create Raster Coverage ") +
                   CoverageName, wxT("spatialite_gui"), wxOK | wxICON_ERROR,
                   this);
      return false;
    }
  if (PixelType == RL2_PIXEL_MULTIBAND)
................................................................................
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("BEGIN error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
// just in case, attempting to (re)create raster meta-tables
  ret =
    sqlite3_exec(SqliteHandle, "SELECT CreateStylingTables()", NULL,
                 NULL, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("CreateStylingTables() error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
................................................................................
  sql += dbAlias2 + wxT("\".geometry_columns WHERE spatial_index_enabled = 1");
  xsql = (char *) malloc((sql.Len() * 4) + 1);
  strcpy(xsql, sql.ToUTF8());
  int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                              &rows, &columns, &errMsg);
  free(xsql);
  if (ret != SQLITE_OK)



    return false;

  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          name = results[(i * columns) + 0];
................................................................................
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsVectorCoverages())
    {
      // fetching Vector Coverages
      sql =
        wxT("SELECT c.coverage_name, g.srid FROM main.vector_coverages AS c ");
      sql += wxT("JOIN geometry_columns AS g ON (");
      sql += wxT("Lower(c.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(c.f_geometry_column) = Lower(g.f_geometry_column))");
















      xsql = (char *) malloc((sql.Len() * 4) + 1);
      strcpy(xsql, sql.ToUTF8());
      int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                                  &rows, &columns, &errMsg);
      free(xsql);
      if (ret != SQLITE_OK)
        {
................................................................................
      if (rows < 1)
        ;
      else
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Vector Coverage

              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);

              VectorCoverageSet coverage(name, srid);
              TableTree->AddVectorCoverage(&coverage);
            }
        }
      sqlite3_free_table(results);
    }
// fetching persistent tables and views
  sql =
................................................................................
  wxTreeItemId rootTopologies =
    TableTree->AppendItem(db, wxT("Topology-Geometry"));
  wxTreeItemId rootNetworks =
    TableTree->AppendItem(db, wxT("Topology-Network"));
  wxTreeItemId rootRasterCoverages =
    TableTree->AppendItem(db, wxT("Raster Coverages"));
  wxTreeItemId rootVectorCoverages =
    TableTree->AppendItem(db, wxT("VectorRaster Coverages"));
  wxTreeItemId rootWMS =
    TableTree->AppendItem(db, wxT("Registered WMS layers"));
  wxTreeItemId rootMetadata = TableTree->AppendItem(db, wxT("Metadata"));
  wxTreeItemId rootInternal = TableTree->AppendItem(db, wxT("Internal Data"));
  wxTreeItemId rootSpatialIndex =
    TableTree->AppendItem(db, wxT("Spatial Index"));
  TableTree->SetItemImage(rootUserData, 17);
................................................................................
  TableTree->SetItemImage(rootVectorCoverages, 24);
  TableTree->SetItemImage(rootWMS, 26);
  TableTree->SetItemImage(rootStyling, 17);
  TableTree->SetItemImage(rootIsoMetadata, 17);
  TableTree->SetItemImage(rootMetadata, 17);
  TableTree->SetItemImage(rootInternal, 17);
  TableTree->SetItemImage(rootSpatialIndex, 17);














  RootNodes nodes =
    RootNodes(dbAlias, rootUserData, rootTopologies, rootNetworks,
              rootRasterCoverages, rootVectorCoverages, rootStyling, rootWMS,
              rootIsoMetadata, rootMetadata, rootInternal, rootSpatialIndex);
  if (ExistsTopologies(dbAlias))
    {
      // fetching topologies
................................................................................
              // adding some Topology
              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);
              bool hasZ = false;
              if (atoi(results[(i * columns) + 2]))
                hasZ = true;
              TopoGeoSet topology(dbAlias.ToUTF8(), name, srid, hasZ);
              TableTree->AddAltTopology(rootTopologies, &topology);
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsNetworks(dbAlias))
    {
      // fetching topologies
................................................................................
              if (atoi(results[(i * columns) + 1]))
                spatial = true;
              int srid = atoi(results[(i * columns) + 2]);
              bool hasZ = false;
              if (atoi(results[(i * columns) + 3]))
                hasZ = true;
              TopoNetSet network(name, spatial, srid, hasZ);
              TableTree->AddAltNetwork(rootNetworks, &network);
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsRasterCoverages(dbAlias))
    {
      // fetching Raster Coverages
................................................................................
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Raster Coverage
              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);
              RasterCoverageSet coverage(name, srid);
              TableTree->AddAltRasterCoverage(rootRasterCoverages, &coverage);

            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsVectorCoverages(dbAlias))
    {
      // fetching Vector Coverages
      wxString dbAlias2 = dbAlias;
      DoubleQuoted(dbAlias2);
      sql =
        wxT("SELECT c.coverage_name, g.srid FROM \"") + dbAlias2 +
        wxT("\".vector_coverages AS c ");
      sql += wxT("JOIN ") + dbAlias2 + wxT(".geometry_columns AS g ON (");
      sql += wxT("Lower(c.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(c.f_geometry_column) = Lower(g.f_geometry_column))");




















      xsql = (char *) malloc((sql.Len() * 4) + 1);
      strcpy(xsql, sql.ToUTF8());
      int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                                  &rows, &columns, &errMsg);
      free(xsql);
      if (ret != SQLITE_OK)
        {
................................................................................
      if (rows < 1)
        ;
      else
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Vector Coverage

              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);

              VectorCoverageSet coverage(name, srid);
              TableTree->AddAltVectorCoverage(rootVectorCoverages, &coverage);

            }
        }
      sqlite3_free_table(results);
    }
// fetching tables and views
  sql = wxT("SELECT name, sql, type FROM \"");
  wxString dbAlias2 = dbAlias;







>







 







>







 







>







 







>
>
>
>
>
>
>
>







 







<
<
<
<







 







|









>







 







<



|
>




<





<


<



<




<




<




<




<


<











<


<


<




<












>







 







>
>







 







>
>







 







>
>







 







>
>







 







>
>







 







<







 







>







 







>







 







<


>
>
>
>
>
>
>
>
>
>
>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|







 







>







 







>
>





|







 







|







 







>
>
>
|
>







 







|
|
|

|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
|
|
>
|







 







|







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|







 







|







 







|
>










|
|
|

|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
|
|
>
|
|
>







71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
...
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
...
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
...
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
...
518
519
520
521
522
523
524




525
526
527
528
529
530
531
...
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
...
609
610
611
612
613
614
615

616
617
618
619
620
621
622
623
624

625
626
627
628
629

630
631

632
633
634

635
636
637
638

639
640
641
642

643
644
645
646

647
648
649
650

651
652

653
654
655
656
657
658
659
660
661
662
663

664
665

666
667

668
669
670
671

672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
...
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
...
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
...
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
...
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
...
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
...
914
915
916
917
918
919
920

921
922
923
924
925
926
927
...
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
....
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
....
1079
1080
1081
1082
1083
1084
1085

1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
....
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
....
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
....
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
....
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
....
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
....
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
....
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
....
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
....
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
....
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
....
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
....
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
....
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
....
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
....
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
....
4387
4388
4389
4390
4391
4392
4393
4394
4395
4396
4397
4398
4399
4400
4401
....
4402
4403
4404
4405
4406
4407
4408
4409
4410
4411
4412
4413
4414
4415
4416
....
4477
4478
4479
4480
4481
4482
4483
4484
4485
4486
4487
4488
4489
4490
4491
4492
4493
4494
4495
4496
4497
4498
....
4986
4987
4988
4989
4990
4991
4992
4993
4994
4995
4996
4997
4998
4999
5000
....
5749
5750
5751
5752
5753
5754
5755
5756
5757
5758
5759
5760
5761
5762
5763
5764
5765
5766
5767
....
7747
7748
7749
7750
7751
7752
7753
7754
7755
7756
7757
7758
7759
7760
7761
7762
7763
7764
7765
7766
7767
7768
7769
7770
7771
7772
7773
7774
7775
7776
7777
7778
7779
7780
7781
....
7787
7788
7789
7790
7791
7792
7793
7794
7795
7796
7797
7798
7799
7800
7801
7802
7803
7804
7805
....
7946
7947
7948
7949
7950
7951
7952
7953
7954
7955
7956
7957
7958
7959
7960
....
7964
7965
7966
7967
7968
7969
7970
7971
7972
7973
7974
7975
7976
7977
7978
7979
7980
7981
7982
7983
7984
7985
7986
7987
7988
7989
7990
7991
....
8014
8015
8016
8017
8018
8019
8020
8021
8022
8023
8024
8025
8026
8027
8028
....
8054
8055
8056
8057
8058
8059
8060
8061
8062
8063
8064
8065
8066
8067
8068
....
8089
8090
8091
8092
8093
8094
8095
8096
8097
8098
8099
8100
8101
8102
8103
8104
8105
8106
8107
8108
8109
8110
8111
8112
8113
8114
8115
8116
8117
8118
8119
8120
8121
8122
8123
8124
8125
8126
8127
8128
8129
8130
8131
8132
8133
8134
8135
8136
8137
8138
8139
....
8145
8146
8147
8148
8149
8150
8151
8152
8153
8154
8155
8156
8157
8158
8159
8160
8161
8162
8163
8164
8165
#include "icons/attach.xpm"
#include "icons/sql_log.xpm"
#include "icons/db_status.xpm"
#include "icons/checkgeom.xpm"
#include "icons/sanegeom.xpm"
#include "icons/wfs.xpm"
#include "icons/dxf.xpm"
#include "icons/map_go.xpm"
#include "icons/security_lock.xpm"
#include "icons/security_relaxed.xpm"
#include "icons/security_rdonly.xpm"


#if defined(_WIN32) && !defined(__MINGW32__)
#define unlink	_unlink
................................................................................
//
// main GUI frame constructor
//
  setlocale(LC_ALL, "");
// forcing DECIMAL POINT IS COMMA
  setlocale(LC_NUMERIC, "C");

  MapPanel = NULL;
  Old_SPATIALITE_SECURITY_ENV = NULL;
  RL2MaxThreads = 1;
  wxImage::AddHandler(new wxPNGHandler);
  MemoryDatabase = false;
  AutoSaveInterval = 0;
  LastTotalChanges = 0;
  TimerAutoSave = NULL;
................................................................................
  BtnAttach = new wxBitmap(attach_xpm);
  BtnSqlLog = new wxBitmap(sql_log_xpm);
  BtnDbStatus = new wxBitmap(db_status_xpm);
  BtnCheckGeom = new wxBitmap(checkgeom_xpm);
  BtnSaneGeom = new wxBitmap(sanegeom_xpm);
  BtnWFS = new wxBitmap(wfs_xpm);
  BtnDXF = new wxBitmap(dxf_xpm);
  BtnMap = new wxBitmap(map_go_xpm);

//
// setting up the application icon
//      
  wxIcon MyIcon(icon_xpm);
  SetIcon(MyIcon);

................................................................................
  menuItem->SetBitmap(*BtnDisconnect);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_Vacuum,
                   wxT("&Optimizing current SQLite DB [VACUUM]"));
  menuItem->SetBitmap(*BtnVacuum);
  menuFile->Append(menuItem);
  menuItem = new wxMenuItem(menuFile, ID_Attach, wxT("&Attach DataBase"));
  menuItem->SetBitmap(*BtnAttach);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem =
    new wxMenuItem(menuFile, ID_MapPanel, wxT("Map &Panel"), wxT("Map &Panel"),
                   wxITEM_CHECK);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  wxMenu *advancedMenu = new wxMenu();
  menuItem =
    new wxMenuItem(advancedMenu, ID_SqlScript, wxT("&Execute SQL script"));
  menuItem->SetBitmap(*BtnSqlScript);
  advancedMenu->Append(menuItem);
  advancedMenu->AppendSeparator();
................................................................................
  menuItem->SetBitmap(*BtnSrids);
  advancedMenu->Append(menuItem);
  menuItem =
    new wxMenuItem(advancedMenu, ID_Charset, wxT("&Default Output Charset"));
  menuItem->SetBitmap(*BtnCharset);
  advancedMenu->Append(menuItem);
  menuFile->AppendSubMenu(advancedMenu, wxT("&Advanced"));




  menuFile->AppendSeparator();
  menuItem =
    new wxMenuItem(menuFile, ID_SqlLog, wxT("&SQL Log"), wxT("&SQL Log"),
                   wxITEM_CHECK);
  menuFile->Append(menuItem);
  menuItem = new wxMenuItem(menuFile, ID_DbStatus, wxT("&DB Status"));
  menuFile->Append(menuItem);
................................................................................
  menuItem->SetBitmap(*BtnAbout);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, wxID_EXIT, wxT("&Quit"));
  menuItem->SetBitmap(*BtnExit);
  menuFile->Append(menuItem);
  wxMenuBar *menuBar = new wxMenuBar;
  menuBar->Append(menuFile, wxT("&Menu"));
  SetMenuBar(menuBar);

//
// setting up menu initial state 
//
  menuBar->Enable(ID_Disconnect, false);
  menuBar->Enable(ID_MemoryDbClock, false);
  menuBar->Enable(ID_MemoryDbSave, false);
  menuBar->Enable(ID_Vacuum, false);
  menuBar->Enable(ID_MapPanel, false);
  menuBar->Enable(ID_SqlScript, false);
  menuBar->Enable(ID_QueryViewComposer, false);
  menuBar->Enable(ID_LoadShp, false);
  menuBar->Enable(ID_VirtualShp, false);
  menuBar->Enable(ID_LoadTxt, false);
  menuBar->Enable(ID_VirtualTxt, false);
  menuBar->Enable(ID_LoadDbf, false);
................................................................................
                   wxT("Saving the current MEMORY-DB"));
  toolBar->AddTool(ID_Disconnect, wxT("Disconnecting current SQLite DB"),
                   *BtnDisconnect, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Disconnecting current SQLite DB"));
  toolBar->AddTool(ID_Vacuum, wxT("Optimizing current SQLite DB [VACUUM]"),
                   *BtnVacuum, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Optimizing current SQLite DB [VACUUM]"));

  toolBar->AddTool(ID_Attach, wxT("Attach DataBase"),
                   *BtnAttach, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Attach DataBase"));
  toolBar->AddTool(ID_MapPanel, wxT("Map Panel"),
                   *BtnMap, wxNullBitmap, wxITEM_CHECK, wxT("Map Panel"));
  toolBar->AddTool(ID_SqlLog, wxT("SQL Log"),
                   *BtnSqlLog, wxNullBitmap, wxITEM_CHECK, wxT("SQL Log"));
  toolBar->AddTool(ID_DbStatus, wxT("DB Status"),
                   *BtnDbStatus, wxNullBitmap, wxITEM_NORMAL, wxT("DB Status"));

  toolBar->AddTool(ID_CheckGeom, wxT("Check Geometries"),
                   *BtnCheckGeom, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Check Geometries"));
  toolBar->AddTool(ID_SaneGeom, wxT("Sanitize Geometries"), *BtnSaneGeom,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Sanitize Geometries"));

  toolBar->AddTool(ID_SqlScript, wxT("Execute SQL script"), *BtnSqlScript,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Execute SQL script"));

  toolBar->AddTool(ID_QueryViewComposer, wxT("Query/View Composer"),
                   *BtnQueryComposer, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Query/View Composer"));

  toolBar->AddTool(ID_LoadShp, wxT("Load Shapefile"), *BtnLoadShp, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load Shapefile"));
  toolBar->AddTool(ID_VirtualShp, wxT("Virtual Shapefile"), *BtnVirtualShp,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual Shapefile"));

  toolBar->AddTool(ID_LoadTxt, wxT("Load CSV/TXT"), *BtnLoadTxt, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load CSV/TXT"));
  toolBar->AddTool(ID_VirtualTxt, wxT("Virtual CSV/TXT"), *BtnVirtualTxt,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual CSV/TXT"));

  toolBar->AddTool(ID_LoadDbf, wxT("Load DBF"), *BtnLoadDbf, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load DBF"));
  toolBar->AddTool(ID_VirtualDbf, wxT("Virtual DBF"), *BtnVirtualDbf,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual DBF"));

  toolBar->AddTool(ID_LoadXL, wxT("Load XLS"), *BtnLoadXL, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Load XLS"));
  toolBar->AddTool(ID_VirtualXL, wxT("Virtual XLS"), *BtnVirtualXL,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Virtual XLS"));

  toolBar->AddTool(ID_Network, wxT("Build Network"), *BtnNetwork, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Build Network"));

  toolBar->AddTool(ID_Exif, wxT("Import EXIF photos"), *BtnExif, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Import EXIF photos"));
  toolBar->AddTool(ID_GpsPics, wxT("Import GPS photos"), *BtnGpsPics,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Import GPS photos"));
  toolBar->AddTool(ID_LoadXml, wxT("Import XML Documents"), *BtnLoadXml,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Import XML Documents"));
  toolBar->AddTool(ID_WFS, wxT("Import data from WFS datasource"), *BtnWFS,
                   wxNullBitmap, wxITEM_NORMAL,
                   wxT("Import data from WFS datasource"));
  toolBar->AddTool(ID_DXF, wxT("Import DXF drawings"), *BtnDXF, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Import DXF drawings"));

  toolBar->AddTool(ID_Srids, wxT("Search SRID by name"), *BtnSrids,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Search SRID by name"));

  toolBar->AddTool(ID_Charset, wxT("Default Output Charset"), *BtnCharset,
                   wxNullBitmap, wxITEM_NORMAL, wxT("Default Output Charset"));

  toolBar->AddTool(ID_Help, wxT("Help"), *BtnHelp, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Help"));
  toolBar->AddTool(wxID_ABOUT, wxT("About ..."), *BtnAbout, wxNullBitmap,
                   wxITEM_NORMAL, wxT("About ..."));

  toolBar->AddTool(wxID_EXIT, wxT("Quit"), *BtnExit, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Quit"));
  toolBar->Realize();
  SetToolBar(toolBar);

//
// setting up the toolbar initial state
//
  toolBar->EnableTool(ID_Disconnect, false);
  toolBar->EnableTool(ID_MemoryDbClock, false);
  toolBar->EnableTool(ID_MemoryDbSave, false);
  toolBar->EnableTool(ID_Vacuum, false);
  toolBar->EnableTool(ID_MapPanel, false);
  toolBar->EnableTool(ID_SqlScript, false);
  toolBar->EnableTool(ID_QueryViewComposer, false);
  toolBar->EnableTool(ID_LoadShp, false);
  toolBar->EnableTool(ID_VirtualShp, false);
  toolBar->EnableTool(ID_LoadTxt, false);
  toolBar->EnableTool(ID_VirtualTxt, false);
  toolBar->EnableTool(ID_LoadDbf, false);
................................................................................
          (wxObjectEventFunction) & MyFrame::OnMemoryDbNew);
  Connect(ID_MemoryDbClock, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnMemoryDbClock);
  Connect(ID_MemoryDbSave, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnMemoryDbSave);
  Connect(ID_Vacuum, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnVacuum);
  Connect(ID_MapPanel, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnMapPanel);
  Connect(ID_SqlScript, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnSqlScript);
  Connect(ID_QueryViewComposer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnQueryViewComposer);
  Connect(ID_LoadShp, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnLoadShp);
  Connect(ID_VirtualShp, wxEVT_COMMAND_MENU_SELECTED,
................................................................................
          (wxObjectEventFunction) & MyFrame::OnSanitizeGeometries);
  Connect(ID_Help, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnHelp);
  Connect(wxID_ABOUT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnAbout);
  Connect(wxID_EXIT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyFrame::OnQuit);
  Connect(wxID_ANY, wxEVT_CLOSE_WINDOW,
          (wxObjectEventFunction) & MyFrame::OnClose);
  Connect(wxID_ANY, wxEVT_MOTION, wxMouseEventHandler(MyFrame::OnMouseMove),
          NULL, this);

//
// setting up event handlers for mouse
//
  TableTree->Connect(wxID_ANY, wxEVT_MOTION,
................................................................................
}

MyFrame::~MyFrame()
{
//
// main GUI frame destructor
//
  if (MapPanel != NULL)
    MapPanel->ParentQuit();
  if (TimerAutoSave)
    {
      TimerAutoSave->Stop();
      delete TimerAutoSave;
    }
  LastDitchMemoryDbSave();
  ConfigLayout = Manager.SavePerspective();
................................................................................
  if (SqliteHandle)
    sqlite3_close(SqliteHandle);
  if (SpliteInternalCache)
    spatialite_cleanup_ex(SpliteInternalCache);
  spatialite_shutdown();
  SaveConfig();
  Manager.UnInit();
  if (MapPanel != NULL)
    MapPanel->ParentQuit();
  if (BtnConnect != NULL)
    delete BtnConnect;
  if (BtnConnectReadOnly != NULL)
    delete BtnConnectReadOnly;
  if (BtnCreateNew != NULL)
    delete BtnCreateNew;
  if (BtnDisconnect != NULL)
................................................................................
    delete BtnMemDbNew;
  if (BtnMemDbClock != NULL)
    delete BtnMemDbClock;
  if (BtnMemDbSave != NULL)
    delete BtnMemDbSave;
  if (BtnVacuum != NULL)
    delete BtnVacuum;
  if (BtnMap != NULL)
    delete BtnMap;
  if (BtnSqlScript != NULL)
    delete BtnSqlScript;
  if (BtnQueryComposer != NULL)
    delete BtnQueryComposer;
  if (BtnLoadShp != NULL)
    delete BtnLoadShp;
  if (BtnVirtualShp != NULL)
................................................................................
}

void MyFrame::SaveConfig()
{
//
// saves layout configuration
//

  wxConfig *config = new wxConfig(wxT("SpatialiteGui"));
  config->Write(wxT("Layout"), ConfigLayout);
  config->Write(wxT("PaneX"), ConfigPaneX);
  config->Write(wxT("PaneY"), ConfigPaneY);
  config->Write(wxT("PaneWidth"), ConfigPaneWidth);
  config->Write(wxT("PaneHeight"), ConfigPaneHeight);
  config->Write(wxT("SqlitePath"), SqlitePath);
................................................................................
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_CreateNew, false);
          menuBar->Enable(ID_Disconnect, true);
          menuBar->Enable(ID_Vacuum, true);
          menuBar->Enable(ID_MapPanel, true);
          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_CreateNew, false);
          toolBar->EnableTool(ID_Disconnect, true);
          toolBar->EnableTool(ID_Vacuum, true);
          toolBar->EnableTool(ID_MapPanel, true);
          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
}

void MyFrame::OnQuit(wxCommandEvent & WXUNUSED(event))
{
//
// EXIT - event handler
//

  Close(true);
}

void MyFrame::OnClose(wxCloseEvent & event)
{
//
// immedtiately before closing the main window
//
  wxString db_path = SqlitePath;
  CloseDB();
  SqlitePath = db_path;
  Destroy();
}

void MyFrame::OnAttachDatabase(wxCommandEvent & WXUNUSED(event))
{
//
// Attach Database - event handler
//
  int ret;
................................................................................
              menuBar->Enable(ID_MemoryDbClock, true);
          } else
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_Vacuum, true);
          menuBar->Enable(ID_MapPanel, true);
          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
              toolBar->EnableTool(ID_MemoryDbClock, true);
          } else
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_Vacuum, true);
          toolBar->EnableTool(ID_MapPanel, true);
          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
      mode2 = false;
      mode3 = false;
    }

  wxMenuBar *menuBar = GetMenuBar();
  menuBar->Enable(ID_Disconnect, mode);
  menuBar->Enable(ID_Vacuum, mode);
  menuBar->Enable(ID_MapPanel, mode);
  menuBar->Enable(ID_SqlScript, mode);
  menuBar->Enable(ID_QueryViewComposer, mode2);
  menuBar->Enable(ID_LoadShp, mode);
  menuBar->Enable(ID_VirtualShp, mode);
  menuBar->Enable(ID_LoadTxt, mode);
  menuBar->Enable(ID_VirtualTxt, mode);
  menuBar->Enable(ID_LoadDbf, mode);
................................................................................
  menuBar->Enable(ID_SqlLog, mode);
  menuBar->Enable(ID_DbStatus, mode);
  menuBar->Enable(ID_CheckGeom, mode);
  menuBar->Enable(ID_SaneGeom, mode);
  wxToolBar *toolBar = GetToolBar();
  toolBar->EnableTool(ID_Disconnect, mode);
  toolBar->EnableTool(ID_Vacuum, mode);
  toolBar->EnableTool(ID_MapPanel, mode);
  toolBar->EnableTool(ID_SqlScript, mode);
  toolBar->EnableTool(ID_QueryViewComposer, mode2);
  toolBar->EnableTool(ID_LoadShp, mode);
  toolBar->EnableTool(ID_VirtualShp, mode);
  toolBar->EnableTool(ID_LoadTxt, mode);
  toolBar->EnableTool(ID_VirtualTxt, mode);
  toolBar->EnableTool(ID_LoadDbf, mode);
................................................................................
              menuBar->Enable(ID_MemoryDbClock, true);
          } else
            {
              menuBar->Enable(ID_MemoryDbSave, false);
              menuBar->Enable(ID_MemoryDbClock, false);
            }
          menuBar->Enable(ID_Vacuum, true);
          menuBar->Enable(ID_MapPanel, true);
          menuBar->Enable(ID_SqlScript, true);
          menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
          menuBar->Enable(ID_LoadShp, true);
          menuBar->Enable(ID_VirtualShp, true);
          menuBar->Enable(ID_LoadTxt, true);
          menuBar->Enable(ID_VirtualTxt, true);
          menuBar->Enable(ID_LoadDbf, true);
................................................................................
              toolBar->EnableTool(ID_MemoryDbClock, true);
          } else
            {
              toolBar->EnableTool(ID_MemoryDbSave, false);
              toolBar->EnableTool(ID_MemoryDbClock, false);
            }
          toolBar->EnableTool(ID_Vacuum, true);
          toolBar->EnableTool(ID_MapPanel, true);
          toolBar->EnableTool(ID_SqlScript, true);
          toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
          toolBar->EnableTool(ID_LoadShp, true);
          toolBar->EnableTool(ID_VirtualShp, true);
          toolBar->EnableTool(ID_LoadTxt, true);
          toolBar->EnableTool(ID_VirtualTxt, true);
          toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
  menuBar->Enable(ID_CreateNew, true);
  menuBar->Enable(ID_Disconnect, false);
  menuBar->Enable(ID_MemoryDbLoad, true);
  menuBar->Enable(ID_MemoryDbNew, true);
  menuBar->Enable(ID_MemoryDbSave, false);
  menuBar->Enable(ID_MemoryDbClock, false);
  menuBar->Enable(ID_Vacuum, false);
  menuBar->Enable(ID_MapPanel, false);
  menuBar->Enable(ID_SqlScript, false);
  menuBar->Enable(ID_QueryViewComposer, false);
  menuBar->Enable(ID_LoadShp, false);
  menuBar->Enable(ID_VirtualShp, false);
  menuBar->Enable(ID_LoadTxt, false);
  menuBar->Enable(ID_VirtualTxt, false);
  menuBar->Enable(ID_LoadDbf, false);
................................................................................
  toolBar->EnableTool(ID_CreateNew, true);
  toolBar->EnableTool(ID_Disconnect, false);
  toolBar->EnableTool(ID_MemoryDbLoad, true);
  toolBar->EnableTool(ID_MemoryDbNew, true);
  toolBar->EnableTool(ID_MemoryDbSave, false);
  toolBar->EnableTool(ID_MemoryDbClock, false);
  toolBar->EnableTool(ID_Vacuum, false);
  toolBar->EnableTool(ID_MapPanel, false);
  toolBar->EnableTool(ID_SqlScript, false);
  toolBar->EnableTool(ID_QueryViewComposer, false);
  toolBar->EnableTool(ID_LoadShp, false);
  toolBar->EnableTool(ID_VirtualShp, false);
  toolBar->EnableTool(ID_LoadTxt, false);
  toolBar->EnableTool(ID_VirtualTxt, false);
  toolBar->EnableTool(ID_LoadDbf, false);
................................................................................
      menuBar->Enable(ID_CreateNew, false);
      menuBar->Enable(ID_Disconnect, true);
      menuBar->Enable(ID_MemoryDbLoad, false);
      menuBar->Enable(ID_MemoryDbNew, false);
      menuBar->Enable(ID_MemoryDbSave, false);
      menuBar->Enable(ID_MemoryDbClock, false);
      menuBar->Enable(ID_Vacuum, true);
      menuBar->Enable(ID_MapPanel, true);
      menuBar->Enable(ID_SqlScript, true);
      menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
      menuBar->Enable(ID_LoadShp, true);
      menuBar->Enable(ID_VirtualShp, true);
      menuBar->Enable(ID_LoadTxt, true);
      menuBar->Enable(ID_VirtualTxt, true);
      menuBar->Enable(ID_LoadDbf, true);
................................................................................
      toolBar->EnableTool(ID_CreateNew, false);
      toolBar->EnableTool(ID_Disconnect, true);
      toolBar->EnableTool(ID_MemoryDbLoad, false);
      toolBar->EnableTool(ID_MemoryDbNew, false);
      toolBar->EnableTool(ID_MemoryDbSave, false);
      toolBar->EnableTool(ID_MemoryDbClock, false);
      toolBar->EnableTool(ID_Vacuum, true);
      toolBar->EnableTool(ID_MapPanel, true);
      toolBar->EnableTool(ID_SqlScript, true);
      toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
      toolBar->EnableTool(ID_LoadShp, true);
      toolBar->EnableTool(ID_VirtualShp, true);
      toolBar->EnableTool(ID_LoadTxt, true);
      toolBar->EnableTool(ID_VirtualTxt, true);
      toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
          menuBar->Enable(ID_MemoryDbClock, true);
      } else
        {
          menuBar->Enable(ID_MemoryDbSave, false);
          menuBar->Enable(ID_MemoryDbClock, false);
        }
      menuBar->Enable(ID_Vacuum, true);
      menuBar->Enable(ID_MapPanel, true);
      menuBar->Enable(ID_SqlScript, true);
      menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
      menuBar->Enable(ID_LoadShp, true);
      menuBar->Enable(ID_VirtualShp, true);
      menuBar->Enable(ID_LoadTxt, true);
      menuBar->Enable(ID_VirtualTxt, true);
      menuBar->Enable(ID_LoadDbf, true);
................................................................................
          toolBar->EnableTool(ID_MemoryDbClock, true);
      } else
        {
          toolBar->EnableTool(ID_MemoryDbSave, false);
          toolBar->EnableTool(ID_MemoryDbClock, false);
        }
      toolBar->EnableTool(ID_Vacuum, true);
      toolBar->EnableTool(ID_MapPanel, true);
      toolBar->EnableTool(ID_SqlScript, true);
      toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
      toolBar->EnableTool(ID_LoadShp, true);
      toolBar->EnableTool(ID_VirtualShp, true);
      toolBar->EnableTool(ID_LoadTxt, true);
      toolBar->EnableTool(ID_VirtualTxt, true);
      toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
  menuBar->Enable(ID_CreateNew, false);
  menuBar->Enable(ID_Disconnect, true);
  menuBar->Enable(ID_MemoryDbLoad, false);
  menuBar->Enable(ID_MemoryDbNew, false);
  menuBar->Enable(ID_MemoryDbSave, true);
  menuBar->Enable(ID_MemoryDbClock, true);
  menuBar->Enable(ID_Vacuum, true);
  menuBar->Enable(ID_MapPanel, true);
  menuBar->Enable(ID_SqlScript, true);
  menuBar->Enable(ID_QueryViewComposer, HasViewsMetadata());
  menuBar->Enable(ID_LoadShp, true);
  menuBar->Enable(ID_VirtualShp, true);
  menuBar->Enable(ID_LoadTxt, true);
  menuBar->Enable(ID_VirtualTxt, true);
  menuBar->Enable(ID_LoadDbf, true);
................................................................................
  toolBar->EnableTool(ID_CreateNew, false);
  toolBar->EnableTool(ID_Disconnect, true);
  toolBar->EnableTool(ID_MemoryDbLoad, false);
  toolBar->EnableTool(ID_MemoryDbNew, false);
  toolBar->EnableTool(ID_MemoryDbSave, true);
  toolBar->EnableTool(ID_MemoryDbClock, true);
  toolBar->EnableTool(ID_Vacuum, true);
  toolBar->EnableTool(ID_MapPanel, true);
  toolBar->EnableTool(ID_SqlScript, true);
  toolBar->EnableTool(ID_QueryViewComposer, HasViewsMetadata());
  toolBar->EnableTool(ID_LoadShp, true);
  toolBar->EnableTool(ID_VirtualShp, true);
  toolBar->EnableTool(ID_LoadTxt, true);
  toolBar->EnableTool(ID_VirtualTxt, true);
  toolBar->EnableTool(ID_LoadDbf, true);
................................................................................
                  totalPages - totalPages2);
          msg += wxString::FromUTF8(dummy);
        }
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
    }
  ::wxEndBusyCursor();
}

void MyFrame::MapPanelClosing()
{
//
// the Map Panel is closing
//
  MapPanel = NULL;
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  menuBar->Check(ID_MapPanel, false);
  toolBar->ToggleTool(ID_MapPanel, false);
}

void MyFrame::OnMapPanel(wxCommandEvent & WXUNUSED(event))
{
//
// Opening / Closing the Map Panel
//
  if (MapPanel == NULL)
    {
      // opening the Map Panel
      MapPanel = new MyMapPanel(this, wxT("SpatiaLiteMap"),
                                wxPoint(0, 0), wxSize(640, 480));
      MapPanel->Show(true);
  } else
    {
      // closing the Map Panel
      MapPanel->Show(false);
      MapPanel->Close(true);
    }
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  if (MapPanel == NULL)
    {
      menuBar->Check(ID_MapPanel, false);
      toolBar->ToggleTool(ID_MapPanel, false);
  } else
    {
      menuBar->Check(ID_MapPanel, true);
      toolBar->ToggleTool(ID_MapPanel, true);
    }
}

char *MyFrame::ReadSqlLine(FILE * in, int *len, int *eof)
{
//
// reading an SQL script line
//
  int c;
................................................................................
                                   int Quality, int TileWidth, int TileHeight,
                                   bool NotGeoreferenced, int Srid,
                                   double HorzResolution, double VertResolution,
                                   wxString NoData, bool StrictResolution,
                                   bool MixedResolutions, bool InputPaths,
                                   bool MD5, bool Summary, int RedBand,
                                   int GreenBand, int BlueBand, int NIRband,
                                   bool AutoNDVI, bool isQueryable)
{
//
// actual creation of a Raster Coverage 
//
  int ret;
  const char *sql;
  char *errMsg = NULL;
................................................................................
  sqlite3_stmt *stmt = NULL;
  char *err_msg = NULL;
  int strict_resolution = 0;
  int mixed_resolutions = 0;
  int section_paths = 0;
  int section_md5 = 0;
  int section_summary = 0;
  int queryable = 0;
  rl2PalettePtr palette = NULL;
  rl2PixelPtr no_data = NULL;
  bool retval = false;
  char *dummy;

// starting a transaction 
  ret = sqlite3_exec(SqliteHandle, "BEGIN", NULL, NULL, &errMsg);
................................................................................
    mixed_resolutions = 1;
  if (InputPaths)
    section_paths = 1;
  if (MD5)
    section_md5 = 1;
  if (Summary)
    section_summary = 1;
  if (isQueryable)
    queryable = 1;

  if (rl2_create_dbms_coverage
      (SqliteHandle, CoverageName.ToUTF8(), SampleType, PixelType, NumBands,
       Compression, Quality, TileWidth, TileHeight, Srid, HorzResolution,
       VertResolution, no_data, palette, strict_resolution, mixed_resolutions,
       section_paths, section_md5, section_summary, queryable) != RL2_OK)
    {
      wxMessageBox(wxT("ERROR: unable to create Raster Coverage ") +
                   CoverageName, wxT("spatialite_gui"), wxOK | wxICON_ERROR,
                   this);
      return false;
    }
  if (PixelType == RL2_PIXEL_MULTIBAND)
................................................................................
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("BEGIN error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
// just in case, attempting to (re)create styling meta-tables
  ret =
    sqlite3_exec(SqliteHandle, "SELECT CreateStylingTables()", NULL,
                 NULL, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("CreateStylingTables() error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
................................................................................
  sql += dbAlias2 + wxT("\".geometry_columns WHERE spatial_index_enabled = 1");
  xsql = (char *) malloc((sql.Len() * 4) + 1);
  strcpy(xsql, sql.ToUTF8());
  int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                              &rows, &columns, &errMsg);
  free(xsql);
  if (ret != SQLITE_OK)
    {
      if (results != NULL)
        sqlite3_free_table(results);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          name = results[(i * columns) + 0];
................................................................................
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsVectorCoverages())
    {
      // fetching Vector Coverages
      sql = wxT("SELECT 'table', c.coverage_name, g.srid, g.geometry_type ");
      sql += wxT("FROM main.vector_coverages AS c ");
      sql += wxT("JOIN main.geometry_columns AS g ON (");
      sql += wxT("Lower(c.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(c.f_geometry_column) = Lower(g.f_geometry_column)) ");
      sql += wxT("UNION ");
      sql += wxT("SELECT 'view', c.coverage_name, g.srid, g.geometry_type ");
      sql += wxT("FROM main.vector_coverages AS c ");
      sql += wxT("JOIN main.views_geometry_columns AS v ON ");
      sql += wxT("(Lower(c.view_name) = Lower(v.view_name) AND ");
      sql += wxT("Lower(c.view_geometry) = Lower(v.view_geometry)) ");
      sql += wxT("JOIN main.geometry_columns AS g ON ");
      sql += wxT("(Lower(v.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(v.f_geometry_column) = Lower(g.f_geometry_column)) ");
      sql += wxT("UNION ");
      sql += wxT("SELECT 'shp', c.coverage_name, v.srid, v.geometry_type ");
      sql += wxT("FROM main.vector_coverages AS c ");
      sql += wxT("JOIN main.virts_geometry_columns AS v ON ");
      sql += wxT("(Lower(c.virt_name) = Lower(v.virt_name) AND ");
      sql += wxT("Lower(c.virt_geometry) = Lower(v.virt_geometry)) ");
      sql += wxT("ORDER BY 2");
      xsql = (char *) malloc((sql.Len() * 4) + 1);
      strcpy(xsql, sql.ToUTF8());
      int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                                  &rows, &columns, &errMsg);
      free(xsql);
      if (ret != SQLITE_OK)
        {
................................................................................
      if (rows < 1)
        ;
      else
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Vector Coverage
              const char *prefix = results[(i * columns) + 0];
              const char *name = results[(i * columns) + 1];
              int srid = atoi(results[(i * columns) + 2]);
              int type = atoi(results[(i * columns) + 3]);
              VectorCoverageSet coverage(prefix, name, srid, type);
              TableTree->AddVectorCoverage(&coverage);
            }
        }
      sqlite3_free_table(results);
    }
// fetching persistent tables and views
  sql =
................................................................................
  wxTreeItemId rootTopologies =
    TableTree->AppendItem(db, wxT("Topology-Geometry"));
  wxTreeItemId rootNetworks =
    TableTree->AppendItem(db, wxT("Topology-Network"));
  wxTreeItemId rootRasterCoverages =
    TableTree->AppendItem(db, wxT("Raster Coverages"));
  wxTreeItemId rootVectorCoverages =
    TableTree->AppendItem(db, wxT("Vector Coverages"));
  wxTreeItemId rootWMS =
    TableTree->AppendItem(db, wxT("Registered WMS layers"));
  wxTreeItemId rootMetadata = TableTree->AppendItem(db, wxT("Metadata"));
  wxTreeItemId rootInternal = TableTree->AppendItem(db, wxT("Internal Data"));
  wxTreeItemId rootSpatialIndex =
    TableTree->AppendItem(db, wxT("Spatial Index"));
  TableTree->SetItemImage(rootUserData, 17);
................................................................................
  TableTree->SetItemImage(rootVectorCoverages, 24);
  TableTree->SetItemImage(rootWMS, 26);
  TableTree->SetItemImage(rootStyling, 17);
  TableTree->SetItemImage(rootIsoMetadata, 17);
  TableTree->SetItemImage(rootMetadata, 17);
  TableTree->SetItemImage(rootInternal, 17);
  TableTree->SetItemImage(rootSpatialIndex, 17);
  TableTree->SetItemData(rootUserData, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootTopologies,
                         (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootNetworks, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootRasterCoverages,
                         (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootVectorCoverages,
                         (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootWMS, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootStyling, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootMetadata, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootInternal, (wxTreeItemData *) (new MyObject(true)));
  TableTree->SetItemData(rootSpatialIndex,
                         (wxTreeItemData *) (new MyObject(true)));
  RootNodes nodes =
    RootNodes(dbAlias, rootUserData, rootTopologies, rootNetworks,
              rootRasterCoverages, rootVectorCoverages, rootStyling, rootWMS,
              rootIsoMetadata, rootMetadata, rootInternal, rootSpatialIndex);
  if (ExistsTopologies(dbAlias))
    {
      // fetching topologies
................................................................................
              // adding some Topology
              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);
              bool hasZ = false;
              if (atoi(results[(i * columns) + 2]))
                hasZ = true;
              TopoGeoSet topology(dbAlias.ToUTF8(), name, srid, hasZ);
              TableTree->AddAltTopology(rootTopologies, dbAlias, &topology);
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsNetworks(dbAlias))
    {
      // fetching topologies
................................................................................
              if (atoi(results[(i * columns) + 1]))
                spatial = true;
              int srid = atoi(results[(i * columns) + 2]);
              bool hasZ = false;
              if (atoi(results[(i * columns) + 3]))
                hasZ = true;
              TopoNetSet network(name, spatial, srid, hasZ);
              TableTree->AddAltNetwork(rootNetworks, dbAlias, &network);
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsRasterCoverages(dbAlias))
    {
      // fetching Raster Coverages
................................................................................
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Raster Coverage
              const char *name = results[(i * columns) + 0];
              int srid = atoi(results[(i * columns) + 1]);
              RasterCoverageSet coverage(name, srid);
              TableTree->AddAltRasterCoverage(rootRasterCoverages, dbAlias,
                                              &coverage);
            }
        }
      sqlite3_free_table(results);
    }
  if (ExistsVectorCoverages(dbAlias))
    {
      // fetching Vector Coverages
      wxString dbAlias2 = dbAlias;
      DoubleQuoted(dbAlias2);
      sql =
        wxT("SELECT 'table', c.coverage_name, g.srid, g.geometry_type FROM \"")
        + dbAlias2 + wxT("\".vector_coverages AS c ");
      sql += wxT("JOIN \"") + dbAlias2 + wxT("\".geometry_columns AS g ON (");
      sql += wxT("Lower(c.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(c.f_geometry_column) = Lower(g.f_geometry_column)) ");
      sql += wxT("UNION ");
      sql +=
        wxT("SELECT 'view', c.coverage_name, g.srid, g.geometry_type FROM \"") +
        dbAlias2 + wxT("\".vector_coverages AS c ");
      sql +=
        wxT("JOIN \"") + dbAlias2 + wxT("\".views_geometry_columns AS v ON (");
      sql += wxT("Lower(c.view_name) = Lower(v.view_name) AND ");
      sql += wxT("Lower(c.view_geometry) = Lower(v.view_geometry))");
      sql += wxT("JOIN \"") + dbAlias2 + wxT("\".geometry_columns AS g ON (");
      sql += wxT("Lower(v.f_table_name) = Lower(g.f_table_name) AND ");
      sql += wxT("Lower(v.f_geometry_column) = Lower(g.f_geometry_column)) ");
      sql += wxT("UNION ");
      sql +=
        wxT("SELECT 'shp', c.coverage_name, v.srid, v.geometry_type FROM \"") +
        dbAlias2 + wxT("\".vector_coverages AS c ");
      sql +=
        wxT("JOIN \"") + dbAlias2 + wxT("\".virts_geometry_columns AS v ON (");
      sql += wxT("Lower(c.virt_name) = Lower(v.virt_name) AND ");
      sql += wxT("Lower(c.virt_geometry) = Lower(v.virt_geometry))");
      sql += wxT("ORDER BY 2");
      xsql = (char *) malloc((sql.Len() * 4) + 1);
      strcpy(xsql, sql.ToUTF8());
      int ret = sqlite3_get_table(SqliteHandle, xsql, &results,
                                  &rows, &columns, &errMsg);
      free(xsql);
      if (ret != SQLITE_OK)
        {
................................................................................
      if (rows < 1)
        ;
      else
        {
          for (i = 1; i <= rows; i++)
            {
              // adding some Vector Coverage
              const char *prefix = results[(i * columns) + 0];
              const char *name = results[(i * columns) + 1];
              int srid = atoi(results[(i * columns) + 2]);
              int type = atoi(results[(i * columns) + 3]);
              VectorCoverageSet coverage(prefix, name, srid, type);
              TableTree->AddAltVectorCoverage(rootVectorCoverages, dbAlias,
                                              &coverage);
            }
        }
      sqlite3_free_table(results);
    }
// fetching tables and views
  sql = wxT("SELECT name, sql, type FROM \"");
  wxString dbAlias2 = dbAlias;

Changes to Makefile-static-MinGW.

2
3
4
5
6
7
8

9
10
11
12
13
14

15
16
17
18
19
20
21
...
104
105
106
107
108
109
110












111
112
113
# Makefile ( Mingw & wxwidgets) for spatialite-GUI

SRC = Main.cpp TableTree.cpp QueryView.cpp ResultSetView.cpp BlobExplorer.cpp \
	Dialogs.cpp Shapefiles.cpp Network.cpp Exif.cpp TextCsv.cpp \
	Objects.cpp QueryViewComposer.cpp MalformedGeoms.cpp DialogsGraph.cpp \
	Raster.cpp Styles.cpp RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp Wfs.cpp SqlFilterComposer.cpp \

	win_resource/resource.rc
OBJ = Main.o TableTree.o QueryView.o ResultSetView.o BlobExplorer.o \
	Dialogs.o Shapefiles.o Network.o Exif.o TextCsv.o Objects.o \
	QueryViewComposer.o MalformedGeoms.o DialogsGraph.o \
	Raster.o Styles.o RasterSymbolizers.o VectorSymbolizers1.o \
	VectorSymbolizers2.o Wfs.o SqlFiltersComposer.o \

	win_resource/resource.o 
EXE = ./static_bin/spatialite_gui.exe
INCLUDE = Classdef.h 

# Define default flags:
CXXFLAGS = $(shell wx-config --cxxflags)
LIB = -Wl,--subsystem,windows /usr/local/lib/libwx_mswu-3.0.a \
................................................................................
	$(CXX) -c Objects.cpp $(CXXFLAGS) $(EXTRAFLAGS)

QueryViewComposer.o: QueryViewComposer.cpp $(INCLUDE)
	$(CXX) -c QueryViewComposer.cpp $(CXXFLAGS) $(EXTRAFLAGS)

MalformedGeoms.o: MalformedGeoms.cpp $(INCLUDE)
	$(CXX) -c MalformedGeoms.cpp $(CXXFLAGS) $(EXTRAFLAGS)












			
win_resource/resource.o: win_resource/resource.rc
	$(REZ) -i win_resource/resource.rc -o win_resource/resource.o 







>






>







 







>
>
>
>
>
>
>
>
>
>
>
>



2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
...
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# Makefile ( Mingw & wxwidgets) for spatialite-GUI

SRC = Main.cpp TableTree.cpp QueryView.cpp ResultSetView.cpp BlobExplorer.cpp \
	Dialogs.cpp Shapefiles.cpp Network.cpp Exif.cpp TextCsv.cpp \
	Objects.cpp QueryViewComposer.cpp MalformedGeoms.cpp DialogsGraph.cpp \
	Raster.cpp Styles.cpp RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp Wfs.cpp SqlFilterComposer.cpp \
	WmsDialog.cpp LayerTree.cpp MapPanel.cpp MapView.cpp \
	win_resource/resource.rc
OBJ = Main.o TableTree.o QueryView.o ResultSetView.o BlobExplorer.o \
	Dialogs.o Shapefiles.o Network.o Exif.o TextCsv.o Objects.o \
	QueryViewComposer.o MalformedGeoms.o DialogsGraph.o \
	Raster.o Styles.o RasterSymbolizers.o VectorSymbolizers1.o \
	VectorSymbolizers2.o Wfs.o SqlFiltersComposer.o \
	WmsDialog.o LayerTree.o MapPanel.o MapView.o \
	win_resource/resource.o 
EXE = ./static_bin/spatialite_gui.exe
INCLUDE = Classdef.h 

# Define default flags:
CXXFLAGS = $(shell wx-config --cxxflags)
LIB = -Wl,--subsystem,windows /usr/local/lib/libwx_mswu-3.0.a \
................................................................................
	$(CXX) -c Objects.cpp $(CXXFLAGS) $(EXTRAFLAGS)

QueryViewComposer.o: QueryViewComposer.cpp $(INCLUDE)
	$(CXX) -c QueryViewComposer.cpp $(CXXFLAGS) $(EXTRAFLAGS)

MalformedGeoms.o: MalformedGeoms.cpp $(INCLUDE)
	$(CXX) -c MalformedGeoms.cpp $(CXXFLAGS) $(EXTRAFLAGS)

WmsDialog.o: WmsDialog.cpp $(INCLUDE)
	$(CXX) -c WmsDialog.cpp $(CXXFLAGS) $(EXTRAFLAGS)

LayerTree.o: LayerTree.cpp $(INCLUDE)
	$(CXX) -c TableTree.cpp $(CXXFLAGS) $(EXTRAFLAGS)

MapPanel.o: MapPanel.cpp $(INCLUDE)
	$(CXX) -c MapPanel.cpp $(CXXFLAGS) $(EXTRAFLAGS)

MapView.o: MapView.cpp $(INCLUDE)
	$(CXX) -c MapView.cpp $(CXXFLAGS) $(EXTRAFLAGS)
			
win_resource/resource.o: win_resource/resource.rc
	$(REZ) -i win_resource/resource.rc -o win_resource/resource.o 

Changes to Makefile.am.

8
9
10
11
12
13
14
15

16
17
18
19
20
21
22
23
24
25
26
27
28
spatialite_gui_SOURCES = Classdef.h BlobExplorer.cpp \
	Dialogs.cpp DialogsGraph.cpp WmsDialog.cpp Exif.cpp \
	Main.cpp MalformedGeoms.cpp Network.cpp \
	Objects.cpp QueryView.cpp QueryViewComposer.cpp \
	ResultSetView.cpp Shapefiles.cpp TableTree.cpp \
	TextCsv.cpp Wfs.cpp Raster.cpp Styles.cpp \
	RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp SqlFiltersComposer.cpp


LDADD = @WX_LIBS@ @LIBSPATIALITE_LIBS@ \
	@LIBRASTERLITE2_LIBS@ @LIBFREEXL_LIBS@ @LIBXML2_LIBS@ -lgeos_c

EXTRA_DIST = Makefile-static-MinGW \
        Makefile-static-Linux \
        Makefile-static-MacOsX \
        indent_me

AUTOMAKE_OPTIONS = dist-zip foreign

SUBDIRS = icons win_resource mac_resource gnome_resource








|
>













8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
spatialite_gui_SOURCES = Classdef.h BlobExplorer.cpp \
	Dialogs.cpp DialogsGraph.cpp WmsDialog.cpp Exif.cpp \
	Main.cpp MalformedGeoms.cpp Network.cpp \
	Objects.cpp QueryView.cpp QueryViewComposer.cpp \
	ResultSetView.cpp Shapefiles.cpp TableTree.cpp \
	TextCsv.cpp Wfs.cpp Raster.cpp Styles.cpp \
	RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp SqlFiltersComposer.cpp \
	MapPanel.cpp MapView.cpp LayerTree.cpp

LDADD = @WX_LIBS@ @LIBSPATIALITE_LIBS@ \
	@LIBRASTERLITE2_LIBS@ @LIBFREEXL_LIBS@ @LIBXML2_LIBS@ -lgeos_c

EXTRA_DIST = Makefile-static-MinGW \
        Makefile-static-Linux \
        Makefile-static-MacOsX \
        indent_me

AUTOMAKE_OPTIONS = dist-zip foreign

SUBDIRS = icons win_resource mac_resource gnome_resource

Changes to Makefile.in.

111
112
113
114
115
116
117
118

119
120
121
122
123
124
125
...
412
413
414
415
416
417
418
419

420
421
422
423
424
425
426
...
541
542
543
544
545
546
547

548
549


550
551
552
553
554
555
556
...
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
...
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
...
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
	DialogsGraph.$(OBJEXT) WmsDialog.$(OBJEXT) Exif.$(OBJEXT) \
	Main.$(OBJEXT) MalformedGeoms.$(OBJEXT) Network.$(OBJEXT) \
	Objects.$(OBJEXT) QueryView.$(OBJEXT) \
	QueryViewComposer.$(OBJEXT) ResultSetView.$(OBJEXT) \
	Shapefiles.$(OBJEXT) TableTree.$(OBJEXT) TextCsv.$(OBJEXT) \
	Wfs.$(OBJEXT) Raster.$(OBJEXT) Styles.$(OBJEXT) \
	RasterSymbolizers.$(OBJEXT) VectorSymbolizers1.$(OBJEXT) \
	VectorSymbolizers2.$(OBJEXT) SqlFiltersComposer.$(OBJEXT)

spatialite_gui_OBJECTS = $(am_spatialite_gui_OBJECTS)
spatialite_gui_LDADD = $(LDADD)
spatialite_gui_DEPENDENCIES =
AM_V_lt = $(am__v_lt_@AM_V@)
am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
am__v_lt_0 = --silent
am__v_lt_1 = 
................................................................................
spatialite_gui_SOURCES = Classdef.h BlobExplorer.cpp \
	Dialogs.cpp DialogsGraph.cpp WmsDialog.cpp Exif.cpp \
	Main.cpp MalformedGeoms.cpp Network.cpp \
	Objects.cpp QueryView.cpp QueryViewComposer.cpp \
	ResultSetView.cpp Shapefiles.cpp TableTree.cpp \
	TextCsv.cpp Wfs.cpp Raster.cpp Styles.cpp \
	RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp SqlFiltersComposer.cpp


LDADD = @WX_LIBS@ @LIBSPATIALITE_LIBS@ \
	@LIBRASTERLITE2_LIBS@ @LIBFREEXL_LIBS@ @LIBXML2_LIBS@ -lgeos_c

EXTRA_DIST = Makefile-static-MinGW \
        Makefile-static-Linux \
        Makefile-static-MacOsX \
................................................................................
distclean-compile:
	-rm -f *.tab.c

@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/BlobExplorer.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Dialogs.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/DialogsGraph.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Exif.Po@am__quote@

@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Main.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MalformedGeoms.Po@am__quote@


@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Network.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Objects.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/QueryView.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/QueryViewComposer.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Raster.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/RasterSymbolizers.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ResultSetView.Po@am__quote@
................................................................................
	|| find "$(distdir)" -type d ! -perm -755 \
		-exec chmod u+rwx,go+rx {} \; -o \
	  ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
	  ! -type d ! -perm -400 -exec chmod a+r {} \; -o \
	  ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \
	|| chmod -R a+r "$(distdir)"
dist-gzip: distdir
	tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
	$(am__post_remove_distdir)

dist-bzip2: distdir
	tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2
	$(am__post_remove_distdir)

dist-lzip: distdir
................................................................................
	tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z
	$(am__post_remove_distdir)

dist-shar: distdir
	@echo WARNING: "Support for shar distribution archives is" \
	               "deprecated." >&2
	@echo WARNING: "It will be removed altogether in Automake 2.0" >&2
	shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz
	$(am__post_remove_distdir)
dist-zip: distdir
	-rm -f $(distdir).zip
	zip -rq $(distdir).zip $(distdir)
	$(am__post_remove_distdir)

dist dist-all:
................................................................................

# This target untars the dist file and tries a VPATH configuration.  Then
# it guarantees that the distribution is self-contained by making another
# tarfile.
distcheck: dist
	case '$(DIST_ARCHIVES)' in \
	*.tar.gz*) \
	  GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\
	*.tar.bz2*) \
	  bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\
	*.tar.lz*) \
	  lzip -dc $(distdir).tar.lz | $(am__untar) ;;\
	*.tar.xz*) \
	  xz -dc $(distdir).tar.xz | $(am__untar) ;;\
	*.tar.Z*) \
	  uncompress -c $(distdir).tar.Z | $(am__untar) ;;\
	*.shar.gz*) \
	  GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\
	*.zip*) \
	  unzip $(distdir).zip ;;\
	esac
	chmod -R a-w $(distdir)
	chmod u+w $(distdir)
	mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst
	chmod a-w $(distdir)







|
>







 







|
>







 







>


>
>







 







|







 







|







 







|









|







111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
...
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
...
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
...
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
...
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
...
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
	DialogsGraph.$(OBJEXT) WmsDialog.$(OBJEXT) Exif.$(OBJEXT) \
	Main.$(OBJEXT) MalformedGeoms.$(OBJEXT) Network.$(OBJEXT) \
	Objects.$(OBJEXT) QueryView.$(OBJEXT) \
	QueryViewComposer.$(OBJEXT) ResultSetView.$(OBJEXT) \
	Shapefiles.$(OBJEXT) TableTree.$(OBJEXT) TextCsv.$(OBJEXT) \
	Wfs.$(OBJEXT) Raster.$(OBJEXT) Styles.$(OBJEXT) \
	RasterSymbolizers.$(OBJEXT) VectorSymbolizers1.$(OBJEXT) \
	VectorSymbolizers2.$(OBJEXT) SqlFiltersComposer.$(OBJEXT) \
	MapPanel.$(OBJEXT) MapView.$(OBJEXT) LayerTree.$(OBJEXT)
spatialite_gui_OBJECTS = $(am_spatialite_gui_OBJECTS)
spatialite_gui_LDADD = $(LDADD)
spatialite_gui_DEPENDENCIES =
AM_V_lt = $(am__v_lt_@AM_V@)
am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
am__v_lt_0 = --silent
am__v_lt_1 = 
................................................................................
spatialite_gui_SOURCES = Classdef.h BlobExplorer.cpp \
	Dialogs.cpp DialogsGraph.cpp WmsDialog.cpp Exif.cpp \
	Main.cpp MalformedGeoms.cpp Network.cpp \
	Objects.cpp QueryView.cpp QueryViewComposer.cpp \
	ResultSetView.cpp Shapefiles.cpp TableTree.cpp \
	TextCsv.cpp Wfs.cpp Raster.cpp Styles.cpp \
	RasterSymbolizers.cpp VectorSymbolizers1.cpp \
	VectorSymbolizers2.cpp SqlFiltersComposer.cpp \
	MapPanel.cpp MapView.cpp LayerTree.cpp

LDADD = @WX_LIBS@ @LIBSPATIALITE_LIBS@ \
	@LIBRASTERLITE2_LIBS@ @LIBFREEXL_LIBS@ @LIBXML2_LIBS@ -lgeos_c

EXTRA_DIST = Makefile-static-MinGW \
        Makefile-static-Linux \
        Makefile-static-MacOsX \
................................................................................
distclean-compile:
	-rm -f *.tab.c

@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/BlobExplorer.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Dialogs.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/DialogsGraph.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Exif.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/LayerTree.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Main.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MalformedGeoms.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MapPanel.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MapView.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Network.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Objects.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/QueryView.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/QueryViewComposer.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Raster.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/RasterSymbolizers.Po@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ResultSetView.Po@am__quote@
................................................................................
	|| find "$(distdir)" -type d ! -perm -755 \
		-exec chmod u+rwx,go+rx {} \; -o \
	  ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
	  ! -type d ! -perm -400 -exec chmod a+r {} \; -o \
	  ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \
	|| chmod -R a+r "$(distdir)"
dist-gzip: distdir
	tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz
	$(am__post_remove_distdir)

dist-bzip2: distdir
	tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2
	$(am__post_remove_distdir)

dist-lzip: distdir
................................................................................
	tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z
	$(am__post_remove_distdir)

dist-shar: distdir
	@echo WARNING: "Support for shar distribution archives is" \
	               "deprecated." >&2
	@echo WARNING: "It will be removed altogether in Automake 2.0" >&2
	shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz
	$(am__post_remove_distdir)
dist-zip: distdir
	-rm -f $(distdir).zip
	zip -rq $(distdir).zip $(distdir)
	$(am__post_remove_distdir)

dist dist-all:
................................................................................

# This target untars the dist file and tries a VPATH configuration.  Then
# it guarantees that the distribution is self-contained by making another
# tarfile.
distcheck: dist
	case '$(DIST_ARCHIVES)' in \
	*.tar.gz*) \
	  eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\
	*.tar.bz2*) \
	  bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\
	*.tar.lz*) \
	  lzip -dc $(distdir).tar.lz | $(am__untar) ;;\
	*.tar.xz*) \
	  xz -dc $(distdir).tar.xz | $(am__untar) ;;\
	*.tar.Z*) \
	  uncompress -c $(distdir).tar.Z | $(am__untar) ;;\
	*.shar.gz*) \
	  eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\
	*.zip*) \
	  unzip $(distdir).zip ;;\
	esac
	chmod -R a-w $(distdir)
	chmod u+w $(distdir)
	mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst
	chmod a-w $(distdir)

Changes to MalformedGeoms.cpp.

23
24
25
26
27
28
29

30
31
32
33
34
35
36
....
1832
1833
1834
1835
1836
1837
1838



































































































































































































































































































































































































































/
*/

#include "Classdef.h"

#include "wx/clipbrd.h"
#include "wx/colordlg.h"


#if defined(_WIN32) || defined (__MINGW32__)
#define FORMAT_64	"%I64d"
#else
#define FORMAT_64	"%lld"
#endif

................................................................................
{
//
// all done: 
//
  //wxDialog::EndModal(wxID_OK);
  Destroy();
}










































































































































































































































































































































































































































>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
....
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
/
*/

#include "Classdef.h"

#include "wx/clipbrd.h"
#include "wx/colordlg.h"
#include "wx/spinctrl.h"

#if defined(_WIN32) || defined (__MINGW32__)
#define FORMAT_64	"%I64d"
#else
#define FORMAT_64	"%lld"
#endif

................................................................................
{
//
// all done: 
//
  //wxDialog::EndModal(wxID_OK);
  Destroy();
}

void MyFrame::DoCreateTopoGeo()
{
//
// creating a new Topology-Geometry
//
  CreateTopoGeoDialog dlg;
  dlg.Create(this);
  int ret = dlg.ShowModal();
  if (ret == wxID_OK)
    {
      const char *sql;
      wxString name = dlg.GetTopologyName();
      int srid = dlg.GetSrid();
      bool has_z = dlg.Is3D();
      double tolerance = dlg.GetTolerance();
      if (tolerance > 0.0)
        sql = "SELECT CreateTopology(?, ?, ?, ?)";
      else
        sql = "SELECT CreateTopology(?, ?, ?)";
      sqlite3_stmt *stmt;
      int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql), &stmt, NULL);
      if (ret != SQLITE_OK)
        {
          const char *msg = sqlite3_errmsg(SqliteHandle);
          wxMessageBox(wxT("ERROR - CreateTopology: ") +
                       wxString::FromUTF8(msg), wxT("spatialite_gui"),
                       wxOK | wxICON_ERROR, this);
          return;
        }
      sqlite3_reset(stmt);
      sqlite3_clear_bindings(stmt);
      char *xname = (char *) malloc((name.Len() * 4) + 1);
      strcpy(xname, name.ToUTF8());
      sqlite3_bind_text(stmt, 1, xname, strlen(xname), free);
      sqlite3_bind_int(stmt, 2, srid);
      if (has_z)
        sqlite3_bind_int(stmt, 3, 1);
      else
        sqlite3_bind_int(stmt, 3, 0);
      if (tolerance > 0)
        sqlite3_bind_double(stmt, 4, tolerance);
      int valid = 0;
      while (1)
        {
          ret = sqlite3_step(stmt);
          if (ret == SQLITE_DONE)
            break;
          if (ret == SQLITE_ROW)
            {
              if (sqlite3_column_type(stmt, 0) == SQLITE_INTEGER)
                valid = sqlite3_column_int(stmt, 0);
          } else
            {
              const char *msg = sqlite3_errmsg(SqliteHandle);
              wxMessageBox(wxT("ERROR - CreateTopology: ") +
                           wxString::FromUTF8(msg), wxT("spatialite_gui"),
                           wxOK | wxICON_ERROR, this);
              break;
            }
        }
      sqlite3_finalize(stmt);
      if (valid)
        wxMessageBox(wxT("Topology-Geometry succesfully created."),
                     wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
      else
        wxMessageBox(wxT("Topology-Geometry creation failed."),
                     wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      return;
    }
}

bool CreateTopoGeoDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  HasZ = false;
  if (wxDialog::Create(parent, wxID_ANY,
                       wxT("Creating a new Topology-Geometry")) == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  return true;
}

void CreateTopoGeoDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// first row: Topology Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_CENTRE_VERTICAL | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("Topology &Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_TOPO_NAME, wxT(""),
                                        wxDefaultPosition, wxSize(300, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: SRID
  wxBoxSizer *sridSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(sridSizer, 0, wxALIGN_LEFT | wxALL, 0);
  wxStaticText *sridLabel = new wxStaticText(this, wxID_STATIC, wxT("&SRID:"));
  sridSizer->Add(sridLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_TOPO_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(80, 20),
                                        wxSP_ARROW_KEYS, -1, 1000000, -1);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 1);
// third row: Has Z
  wxBoxSizer *hasZSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(hasZSizer, 0, wxALIGN_LEFT | wxALL, 0);
  wxString dims[2];
  dims[0] = wxT("&2D");
  dims[1] = wxT("&3D");
  wxRadioBox *hasZBox = new wxRadioBox(this, ID_TOPO_3D,
                                       wxT("Dimensions"),
                                       wxDefaultPosition,
                                       wxDefaultSize, 2,
                                       dims, 1,
                                       wxRA_SPECIFY_ROWS);
  hasZSizer->Add(hasZBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  hasZBox->SetSelection(0);
// fourth row: Tolerance
  wxBoxSizer *tolSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(tolSizer, 0, wxALIGN_CENTRE_VERTICAL | wxALL, 0);
  wxStaticText *tolLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Tolerance:"));
  tolSizer->Add(tolLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *tolCtrl = new wxTextCtrl(this, ID_TOPO_TOLERANCE, wxT(""),
                                       wxDefaultPosition, wxSize(150, 22));
  tolSizer->Add(tolCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Create"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & CreateTopoGeoDialog::OnOk);
}

void CreateTopoGeoDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_TOPO_NAME);
  wxSpinCtrl *sridCtrl = (wxSpinCtrl *) FindWindow(ID_TOPO_SRID);
  wxRadioBox *hasZBox = (wxRadioBox *) FindWindow(ID_TOPO_3D);
  wxTextCtrl *tolCtrl = (wxTextCtrl *) FindWindow(ID_TOPO_TOLERANCE);
  wxString str = nameCtrl->GetValue().Trim();
  TopologyName = str.Trim(false);
  if (TopologyName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Topology Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  Srid = sridCtrl->GetValue();
  if (hasZBox->GetSelection() == 1)
    HasZ = true;
  else
    HasZ = false;
  wxString tol = tolCtrl->GetValue();
  if (tol.ToDouble(&Tolerance) == false)
    {
      wxMessageBox(wxT("invalid Tolerance value"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (Tolerance < 0.0)
    {
      wxMessageBox(wxT("Tolerance should be a positive value"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  wxDialog::EndModal(wxID_OK);
}

void MyFrame::DoCreateTopoNet()
{
//
// creating a new Topology-Network
//
  CreateTopoNetDialog dlg;
  dlg.Create(this);
  int ret = dlg.ShowModal();
  if (ret == wxID_OK)
    {
      const char *sql;
      wxString name = dlg.GetNetworkName();
      bool is_spatial = dlg.IsSpatial();
      int srid = dlg.GetSrid();
      bool has_z = dlg.Is3D();
      bool coincident = dlg.AllowsCoincident();
      if (is_spatial == false)
        sql = "SELECT CreateNetwork(?, 0)";
      else
        sql = "SELECT CreateNetwork(?, 1, ?, ?, ?)";
      sqlite3_stmt *stmt;
      int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql), &stmt, NULL);
      if (ret != SQLITE_OK)
        {
          const char *msg = sqlite3_errmsg(SqliteHandle);
          wxMessageBox(wxT("ERROR - CreateNetwork: ") +
                       wxString::FromUTF8(msg), wxT("spatialite_gui"),
                       wxOK | wxICON_ERROR, this);
          return;
        }
      sqlite3_reset(stmt);
      sqlite3_clear_bindings(stmt);
      char *xname = (char *) malloc((name.Len() * 4) + 1);
      strcpy(xname, name.ToUTF8());
      sqlite3_bind_text(stmt, 1, xname, strlen(xname), free);
      if (is_spatial)
        {
          sqlite3_bind_int(stmt, 2, srid);
          if (has_z)
            sqlite3_bind_int(stmt, 3, 1);
          else
            sqlite3_bind_int(stmt, 3, 0);
          if (coincident)
            sqlite3_bind_int(stmt, 4, 1);
          else
            sqlite3_bind_int(stmt, 4, 0);
        }
      int valid = 0;
      while (1)
        {
          ret = sqlite3_step(stmt);
          if (ret == SQLITE_DONE)
            break;
          if (ret == SQLITE_ROW)
            {
              if (sqlite3_column_type(stmt, 0) == SQLITE_INTEGER)
                valid = sqlite3_column_int(stmt, 0);
          } else
            {
              const char *msg = sqlite3_errmsg(SqliteHandle);
              wxMessageBox(wxT("ERROR - CreateNetwork: ") +
                           wxString::FromUTF8(msg), wxT("spatialite_gui"),
                           wxOK | wxICON_ERROR, this);
              break;
            }
        }
      sqlite3_finalize(stmt);
      if (valid)
        wxMessageBox(wxT("Topology-Network succesfully created."),
                     wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
      else
        wxMessageBox(wxT("Topology-Network creation failed."),
                     wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      return;
    }
}

bool CreateTopoNetDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  Spatial = true;
  HasZ = false;
  if (wxDialog::Create(parent, wxID_ANY,
                       wxT("Creating a new Topology-Network")) == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  return true;
}

void CreateTopoNetDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// first row: Network Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_CENTRE_VERTICAL | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("Network &Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_TOPO_NAME, wxT(""),
                                        wxDefaultPosition, wxSize(300, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: Spatial Network
  wxBoxSizer *spatSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(spatSizer, 0, wxALIGN_CENTRE_VERTICAL | wxALL, 0);
  wxCheckBox *spatCtrl =
    new wxCheckBox(this, ID_TOPO_SPATIAL, wxT("&Spatial Network"));
  spatCtrl->SetValue(true);
  spatSizer->Add(spatCtrl, 0, wxALIGN_LEFT | wxALL, 1);
// third row: SRID
  wxBoxSizer *sridSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(sridSizer, 0, wxALIGN_LEFT | wxALL, 0);
  wxStaticText *sridLabel = new wxStaticText(this, wxID_STATIC, wxT("&SRID:"));
  sridSizer->Add(sridLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_TOPO_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(80, 20),
                                        wxSP_ARROW_KEYS, -1, 1000000, -1);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 1);
// fourth row: Has Z
  wxBoxSizer *hasZSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(hasZSizer, 0, wxALIGN_LEFT | wxALL, 0);
  wxString dims[2];
  dims[0] = wxT("&2D");
  dims[1] = wxT("&3D");
  wxRadioBox *hasZBox = new wxRadioBox(this, ID_TOPO_3D,
                                       wxT("Dimensions"),
                                       wxDefaultPosition,
                                       wxDefaultSize, 2,
                                       dims, 1,
                                       wxRA_SPECIFY_ROWS);
  hasZSizer->Add(hasZBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  hasZBox->SetSelection(0);
// fifth row: Allow Coincident
  wxBoxSizer *coinSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(coinSizer, 0, wxALIGN_CENTRE_VERTICAL | wxALL, 0);
  wxCheckBox *coinCtrl =
    new wxCheckBox(this, ID_TOPO_COINCIDENT, wxT("&Allow Coincident items)"));
  coinCtrl->SetValue(true);
  coinSizer->Add(coinCtrl, 0, wxALIGN_LEFT | wxALL, 1);
// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Create"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & CreateTopoNetDialog::OnOk);
// appends event handlers for radio buttons etc
  Connect(ID_TOPO_SPATIAL, wxEVT_COMMAND_CHECKBOX_CLICKED,
          (wxObjectEventFunction) & CreateTopoNetDialog::OnSpatialChanged);
}

void CreateTopoNetDialog::OnSpatialChanged(wxCommandEvent & WXUNUSED(event))
{
//
// Spatial / Logical
//
  wxCheckBox *spatCtrl = (wxCheckBox *) FindWindow(ID_TOPO_SPATIAL);
  wxSpinCtrl *sridCtrl = (wxSpinCtrl *) FindWindow(ID_TOPO_SRID);
  wxRadioBox *hasZCtrl = (wxRadioBox *) FindWindow(ID_TOPO_3D);
  wxCheckBox *coinCtrl = (wxCheckBox *) FindWindow(ID_TOPO_COINCIDENT);
  if (Spatial == true)
    {
      Spatial = false;
      spatCtrl->SetValue(false);
      sridCtrl->Enable(false);
      hasZCtrl->Enable(false);
      coinCtrl->Enable(false);
  } else
    {
      Spatial = true;
      spatCtrl->SetValue(true);
      sridCtrl->Enable(true);
      hasZCtrl->Enable(true);
      coinCtrl->Enable(true);
    }
}

void CreateTopoNetDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_TOPO_NAME);
  wxCheckBox *spatCtrl = (wxCheckBox *) FindWindow(ID_TOPO_SPATIAL);
  wxSpinCtrl *sridCtrl = (wxSpinCtrl *) FindWindow(ID_TOPO_SRID);
  wxRadioBox *hasZBox = (wxRadioBox *) FindWindow(ID_TOPO_3D);
  wxCheckBox *coinCtrl = (wxCheckBox *) FindWindow(ID_TOPO_COINCIDENT);
  wxString str = nameCtrl->GetValue().Trim();
  NetworkName = str.Trim(false);
  if (NetworkName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Network Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (spatCtrl->GetValue() == true)
    Spatial = true;
  else
    Spatial = false;
  Srid = sridCtrl->GetValue();
  if (hasZBox->GetSelection() == 1)
    HasZ = true;
  else
    HasZ = false;
  if (coinCtrl->GetValue() == true)
    Coincident = true;
  else
    Coincident = false;
  wxDialog::EndModal(wxID_OK);
}

Added MapPanel.cpp.











































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
/*
/ MapPanel.cpp
/ the Map Panel of spatialite_gui  - a SQLite /SpatiaLite GUI tool
/
/ version 2.0, 2017 January 8
/
/ Author: Sandro Furieri a-furieri@lqt.it
/
/ Copyright (C) 2017  Alessandro Furieri
/
/    This program is free software: you can redistribute it and/or modify
/    it under the terms of the GNU General Public License as published by
/    the Free Software Foundation, either version 3 of the License, or
/    (at your option) any later version.
/
/    This program is distributed in the hope that it will be useful,
/    but WITHOUT ANY WARRANTY; without even the implied warranty of
/    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
/    GNU General Public License for more details.
/
/    You should have received a copy of the GNU General Public License
/    along with this program.  If not, see <http://www.gnu.org/licenses/>.
/
*/

#include "Classdef.h"

#include "wx/menu.h"
#include "wx/aboutdlg.h"
#include "wx/config.h"

#include "icons/icon_map.xpm"
#include "icons/linestrings_on.xpm"
#include "icons/linestrings_off.xpm"
#include "icons/points_on.xpm"
#include "icons/points_off.xpm"
#include "icons/polygons_on.xpm"
#include "icons/polygons_off.xpm"
#include "icons/vector.xpm"
#include "icons/vector_off.xpm"
#include "icons/topo_geo.xpm"
#include "icons/topo_geo_off.xpm"
#include "icons/topo_net.xpm"
#include "icons/topo_net_off.xpm"
#include "icons/coverage.xpm"
#include "icons/coverage_off.xpm"
#include "icons/wms.xpm"
#include "icons/wms_off.xpm"
#include "icons/icon_info.xpm"
#include "icons/map_add.xpm"
#include "icons/center.xpm"
#include "icons/identify.xpm"
#include "icons/zoom_in.xpm"
#include "icons/zoom_out.xpm"
#include "icons/user_scale.xpm"
#include "icons/pan.xpm"
#include "icons/printer.xpm"
#include "icons/about.xpm"
#include "icons/exit.xpm"

MyMapPanel::MyMapPanel(MyFrame * parent, const wxString & title,
                       const wxPoint & pos,
                       const wxSize & size):wxFrame((wxFrame *) NULL, -1, title,
                                                    pos, size)
{
//
// Map Panel frame constructor
//
  Parent = parent;

//
// setting up the application icon
//      
  wxIcon MyIcon(icon_map_xpm);
  SetIcon(MyIcon);

  BtnAddLayer = new wxBitmap(map_add_xpm);
  BtnCenter = new wxBitmap(center_xpm);
  BtnIdentify = new wxBitmap(identify_xpm);
  BtnZoomIn = new wxBitmap(zoom_in_xpm);
  BtnZoomOut = new wxBitmap(zoom_out_xpm);
  BtnUserScale = new wxBitmap(user_scale_xpm);
  BtnPan = new wxBitmap(pan_xpm);
  BtnPrinter = new wxBitmap(printer_xpm);
  BtnAbout = new wxBitmap(about_xpm);
  BtnExit = new wxBitmap(exit_xpm);

//
// setting up panes
//
  LayerTree = new MyLayerTree(this);
  MapView = new MyMapView(this);
  Manager.SetManagedWindow(this);
  wxAuiPaneInfo paneView = wxAuiPaneInfo().Centre();
  paneView.Name(wxT("map_view"));
  paneView.CaptionVisible(false);
  paneView.Floatable(true);
  paneView.Dockable(true);
  paneView.Movable(true);
  paneView.Gripper(false);
  paneView.CloseButton(false);
  Manager.AddPane(MapView, paneView);
  wxAuiPaneInfo paneTree = wxAuiPaneInfo().Left();
  paneTree.Name(wxT("tree_view"));
  paneTree.DefaultPane();
  paneTree.CaptionVisible(false);
  paneTree.Floatable(true);
  paneTree.Dockable(true);
  paneTree.Movable(true);
  paneTree.Gripper(true);
  paneTree.CloseButton(false);
  paneTree.BestSize(wxSize(200, 480));
  Manager.AddPane(LayerTree, paneTree, wxPoint(0, 10));
  Manager.Update();
  Centre();
  //ClearLayerTree();

//
// setting up the status bar
//
  wxStatusBar *statusBar = new wxStatusBar(this);
  statusBar->SetFieldsCount(4);
  int fldWidth[4];
  fldWidth[0] = -1;
  fldWidth[1] = -1;
  fldWidth[2] = -1;
  fldWidth[3] = -1;
  statusBar->SetStatusWidths(4, fldWidth);
  SetStatusBar(statusBar);

//
// setting up the menu bar
//
  wxMenu *menuFile = new wxMenu;
  wxMenuItem *menuItem;
  menuItem = new wxMenuItem(menuFile, ID_AddLayer, wxT("Add a Map &Layer"));
  menuItem->SetBitmap(*BtnAddLayer);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, ID_Center, wxT("Zoom to &Full Extent"));
  menuItem->SetBitmap(*BtnCenter);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_ZoomIn, wxT("Zoom &In"), wxT(""), wxITEM_RADIO);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_ZoomOut,
                   wxT("Zoom &Out"), wxT(""), wxITEM_RADIO);
  menuFile->Append(menuItem);
  menuItem = new wxMenuItem(menuFile, ID_UserScale, wxT("User defined &Scale"));
  menuItem->SetBitmap(*BtnUserScale);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_Pan, wxT("&Pan"), wxT(""), wxITEM_RADIO);
  menuFile->Append(menuItem);
  menuItem =
    new wxMenuItem(menuFile, ID_Identify,
                   wxT("Identify"), wxT(""), wxITEM_RADIO);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, ID_Printer, wxT("&Printer"));
  menuItem->SetBitmap(*BtnPrinter);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, wxID_ABOUT, wxT("&About ..."));
  menuItem->SetBitmap(*BtnAbout);
  menuFile->Append(menuItem);
  menuFile->AppendSeparator();
  menuItem = new wxMenuItem(menuFile, wxID_EXIT, wxT("&Quit"));
  menuItem->SetBitmap(*BtnExit);
  menuFile->Append(menuItem);
  wxMenuBar *menuBar = new wxMenuBar;
  menuBar->Append(menuFile, wxT("&Menu"));
  SetMenuBar(menuBar);

//
// setting up menu initial state 
//
  menuBar->Enable(ID_AddLayer, true);
  menuBar->Enable(ID_Center, false);
  menuBar->Enable(ID_Identify, false);
  menuBar->Enable(ID_ZoomIn, false);
  menuBar->Enable(ID_ZoomOut, false);
  menuBar->Enable(ID_UserScale, false);
  menuBar->Enable(ID_Pan, false);
  menuBar->Enable(ID_Printer, false);

//
// setting up the toolbar
//      
  wxToolBar *toolBar = CreateToolBar();
  toolBar->AddTool(ID_AddLayer, wxT("Add a Map Layer"),
                   *BtnAddLayer, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Add a Map Layer"));
  toolBar->AddSeparator();
  toolBar->AddTool(ID_Center, wxT("Zoom to Full Extent"),
                   *BtnCenter, wxNullBitmap, wxITEM_NORMAL,
                   wxT("Zoom to Full Extent"));
  toolBar->AddTool(ID_ZoomIn, wxT("Zoom In"), *BtnZoomIn, wxNullBitmap,
                   wxITEM_RADIO, wxT("Zoom In"));
  toolBar->AddTool(ID_ZoomOut, wxT("Zoom Out"), *BtnZoomOut, wxNullBitmap,
                   wxITEM_RADIO, wxT("Zoom Out"));
  toolBar->AddTool(ID_UserScale, wxT("User defined Scale"), *BtnUserScale,
                   wxNullBitmap, wxITEM_RADIO, wxT("User defined Scale"));
  toolBar->AddTool(ID_Pan, wxT("Pan"), *BtnPan, wxNullBitmap, wxITEM_RADIO,
                   wxT("Pan"));
  toolBar->AddTool(ID_Identify, wxT("Identify"), *BtnIdentify, wxNullBitmap,
                   wxITEM_RADIO, wxT("Identify"));
  toolBar->AddSeparator();
  toolBar->AddTool(ID_Printer, wxT("Printer"),
                   *BtnPrinter, wxNullBitmap, wxITEM_NORMAL, wxT("Printer"));
  toolBar->AddSeparator();
  toolBar->AddTool(wxID_ABOUT, wxT("About ..."), *BtnAbout, wxNullBitmap,
                   wxITEM_NORMAL, wxT("About ..."));
  toolBar->AddSeparator();
  toolBar->AddTool(wxID_EXIT, wxT("Quit"), *BtnExit, wxNullBitmap,
                   wxITEM_NORMAL, wxT("Quit"));
  toolBar->Realize();
  SetToolBar(toolBar);

//
// setting up the toolbar initial state
//
  toolBar->EnableTool(ID_AddLayer, true);
  toolBar->EnableTool(ID_Center, false);
  toolBar->EnableTool(ID_Identify, false);
  toolBar->EnableTool(ID_ZoomIn, false);
  toolBar->EnableTool(ID_ZoomOut, false);
  toolBar->EnableTool(ID_UserScale, false);
  toolBar->EnableTool(ID_Pan, false);
  toolBar->EnableTool(ID_Printer, false);

//
// setting up event handlers for menu and toolbar
//
  Connect(ID_AddLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnAddLayer);
  Connect(ID_Center, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnCenter);
  Connect(ID_Identify, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnIdentify);
  Connect(ID_ZoomIn, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnZoomIn);
  Connect(ID_ZoomOut, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnZoomOut);
  Connect(ID_UserScale, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnUserScale);
  Connect(ID_Pan, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnPan);
  Connect(ID_Printer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnPrinter);
  Connect(wxID_ABOUT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnAbout);
  Connect(wxID_EXIT, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyMapPanel::OnQuit);
}

MyMapPanel::~MyMapPanel()
{
//
// Map Panel frame destructor
//
  if (Parent != NULL)
    Parent->MapPanelClosing();
  Manager.UnInit();
  if (BtnAddLayer != NULL)
    delete BtnAddLayer;
  if (BtnCenter != NULL)
    delete BtnCenter;
  if (BtnIdentify != NULL)
    delete BtnIdentify;
  if (BtnZoomIn != NULL)
    delete BtnZoomIn;
  if (BtnZoomOut != NULL)
    delete BtnZoomOut;
  if (BtnUserScale != NULL)
    delete BtnUserScale;
  if (BtnPan != NULL)
    delete BtnPan;
  if (BtnPrinter != NULL)
    delete BtnPrinter;
  if (BtnAbout != NULL)
    delete BtnAbout;
  if (BtnExit != NULL)
    delete BtnExit;
}

void MyMapPanel::UpdateTools()
{
//
// updating the Tools State
//
  wxMenuBar *menuBar = GetMenuBar();
  menuBar->Enable(ID_AddLayer, true);
  if (MapView->IsValidMap() == false)
    {
      menuBar->Enable(ID_Center, false);
      menuBar->Enable(ID_ZoomIn, false);
      menuBar->Enable(ID_ZoomOut, false);
      menuBar->Enable(ID_UserScale, false);
      menuBar->Enable(ID_Pan, false);
      menuBar->Enable(ID_Identify, false);
      menuBar->Enable(ID_Printer, false);
  } else
    {
      menuBar->Enable(ID_Center, true);
      menuBar->Enable(ID_ZoomIn, true);
      menuBar->Enable(ID_ZoomOut, true);
      menuBar->Enable(ID_UserScale, true);
      menuBar->Enable(ID_Pan, true);
      if (MapView->CanIdentify() == true)
        menuBar->Enable(ID_Identify, true);
      else
        menuBar->Enable(ID_Identify, false);
      menuBar->Enable(ID_Printer, true);
    }

  wxToolBar *toolBar = GetToolBar();
  toolBar->EnableTool(ID_AddLayer, true);
  if (MapView->IsValidMap() == false)
    {
      toolBar->EnableTool(ID_Center, false);
      toolBar->EnableTool(ID_ZoomIn, false);
      toolBar->EnableTool(ID_ZoomOut, false);
      toolBar->EnableTool(ID_UserScale, false);
      toolBar->EnableTool(ID_Pan, false);
      toolBar->EnableTool(ID_Identify, false);
      toolBar->EnableTool(ID_Printer, false);
  } else
    {
      toolBar->EnableTool(ID_Center, true);
      toolBar->EnableTool(ID_ZoomIn, true);
      toolBar->EnableTool(ID_ZoomOut, true);
      toolBar->EnableTool(ID_UserScale, true);
      toolBar->EnableTool(ID_Pan, true);
      if (MapView->CanIdentify() == true)
        toolBar->EnableTool(ID_Identify, true);
      else
        toolBar->EnableTool(ID_Identify, false);
      toolBar->EnableTool(ID_Printer, true);
    }

  if (MapView->IsValidMap() == false)
    {
      IsIdentify = false;
      IsZoomIn = false;
      IsZoomOut = false;
      IsPan = false;
  } else
    {
      if (IsIdentify == false && IsPan == false && IsZoomOut == false)
        IsZoomIn = true;
      if (IsIdentify == true)
        {
          menuBar->Check(ID_Identify, true);
          toolBar->ToggleTool(ID_Identify, true);
        }
      if (IsPan == true)
        {
          menuBar->Check(ID_Pan, true);
          toolBar->ToggleTool(ID_Pan, true);
        }
      if (IsZoomIn == true)
        {
          menuBar->Check(ID_ZoomIn, true);
          toolBar->ToggleTool(ID_ZoomIn, true);
        }
      if (IsZoomOut == true)
        {
          menuBar->Check(ID_ZoomOut, true);
          toolBar->ToggleTool(ID_ZoomOut, true);
        }
    }
}

void MyMapPanel::OnAddLayer(wxCommandEvent & WXUNUSED(event))
{
//
// adding a Map Layer
//
  AddMapLayerDialog dlg;
  dlg.Create(this);
  int ret = dlg.ShowModal();
  if (ret == wxID_OK)
    {
      MapView->PrepareMap();
    }
}

void MyMapPanel::OnCenter(wxCommandEvent & WXUNUSED(event))
{
//
// resetting to Full Extent
//
  //MapView->SetFullExtent();
  MapView->PrepareMap();
}

void MyMapPanel::OnIdentify(wxCommandEvent & WXUNUSED(event))
{
//
// current map click is: Identify
//
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  if (IsIdentify == false)
    {
      if (menuBar)
        menuBar->Check(ID_Identify, true);
      if (toolBar)
        toolBar->ToggleTool(ID_Identify, true);
      IsIdentify = true;
      IsZoomIn = false;
      IsZoomOut = false;
      IsPan = false;
    }
}

void MyMapPanel::OnZoomIn(wxCommandEvent & WXUNUSED(event))
{
//
// current map click is: ZoomIn
//
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  if (IsZoomIn == false)
    {
      menuBar->Check(ID_ZoomIn, true);
      if (toolBar)
        toolBar->ToggleTool(ID_ZoomIn, true);
      IsIdentify = false;
      IsZoomIn = true;
      IsZoomOut = false;
      IsPan = false;
    }
}

void MyMapPanel::OnZoomOut(wxCommandEvent & WXUNUSED(event))
{
//
// current map click is: ZoomOut
//
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  if (IsZoomOut == false)
    {
      if (menuBar)
        menuBar->Check(ID_ZoomOut, true);
      if (toolBar)
        toolBar->ToggleTool(ID_ZoomOut, true);
      IsIdentify = false;
      IsZoomIn = false;
      IsZoomOut = true;
      IsPan = false;
    }
}

void MyMapPanel::OnUserScale(wxCommandEvent & WXUNUSED(event))
{
//
// User selected Scale
//
}

void MyMapPanel::OnPrinter(wxCommandEvent & WXUNUSED(event))
{
//
// Printer
//
}

void MyMapPanel::OnPan(wxCommandEvent & WXUNUSED(event))
{
//
// current map click is: Pan
//
  wxMenuBar *menuBar = GetMenuBar();
  wxToolBar *toolBar = GetToolBar();
  if (IsPan == false)
    {
      if (menuBar)
        menuBar->Check(ID_Pan, true);
      if (toolBar)
        toolBar->ToggleTool(ID_Pan, true);
      IsIdentify = false;
      IsZoomIn = false;
      IsZoomOut = false;
      IsPan = true;
    }
}

void MyMapPanel::OnAbout(wxCommandEvent & WXUNUSED(event))
{
//
// ABOUT dialog - event handler
//
  char ver[128];
  wxAboutDialogInfo dlg;
  dlg.SetIcon(wxIcon(icon_info_xpm));
  dlg.SetName(wxT("spatialite_gui"));
  const char *version = VERSION;
  dlg.SetVersion(wxString::FromUTF8(version));
  wxString str = wxT("a GUI-tool for SQLite / SpatiaLite\n\n");
  sprintf(ver, "%d.%d.%d", wxMAJOR_VERSION, wxMINOR_VERSION, wxRELEASE_NUMBER);
  strcpy(ver, spatialite_target_cpu());
  str += wxT("Target CPU ") + wxString::FromUTF8(ver) + wxT("\n");
  dlg.SetDescription(str);
  dlg.SetCopyright(wxT("by Alessandro Furieri - 2008/2014"));
  dlg.SetWebSite(wxT("http://www.gaia-gis.it"));
  wxString license =
    wxT("This program is free software; you can redistribute it\n");
  license +=
    wxT("and/or modify it under the terms of the GNU General Public License\n");
  license += wxT("(GPL) as published by the Free Software Foundation\n\n");
  license +=
    wxT
    ("A copy of the GPL can be found at\nhttp://www.gnu.org/licenses/gpl.txt");
  dlg.SetLicense(license);
  ::wxAboutBox(dlg);
}

void MyMapPanel::ParentQuit()
{
//
// the Parent is quitting
//
  Parent = NULL;
  Close(true);
}

void MyMapPanel::OnQuit(wxCommandEvent & WXUNUSED(event))
{
//
// EXIT - event handler
//
  Close(true);
}

void MyBitmapCellRenderer::Draw(wxGrid & grid, wxGridCellAttr & attr,
                                wxDC & dc, const wxRect & rect, int row,
                                int col, bool isSelected)
{
// drawing a Graphic cell
  if (col == row && isSelected)
    row = col;                  // silencing stupid compiler warnings about unused args

  wxBitmap bmp = wxBitmap(Graphic);
  wxColour color = attr.GetBackgroundColour();
  if (grid.IsEnabled() == false)
    {
      color = wxSystemSettings::GetColour(wxSYS_COLOUR_MENU);
      wxImage img = Graphic.ConvertToGreyscale();
      bmp = wxBitmap(img);
    }
  dc.SetBrush(wxBrush(color));
  dc.SetPen(*wxTRANSPARENT_PEN);
  dc.DrawRectangle(rect);
  int x = (rect.GetWidth() - bmp.GetWidth()) / 2;
  int y = (rect.GetHeight() - bmp.GetHeight()) / 2;
  dc.DrawBitmap(bmp, rect.x + x, rect.y + y, true);
}

bool AddMapLayerDialog::Create(MyMapPanel * parent)
{
//
// creating the dialog
//
  MapPanel = parent;
  First = NULL;
  Last = NULL;
  if (wxDialog::Create(parent, wxID_ANY, wxT("Add Map Layer(s)")) == false)
    return false;
// populates individual controls
  DoLoadVectorCoverages();
  DoLoadTopoGeoCoverages();
  DoLoadTopoNetCoverages();
  DoLoadRasterCoverages();
  DoLoadWmsCoverages();
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  return true;
}

void AddMapLayerDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// first row: Layers list
  wxBoxSizer *listSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(listSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  Layers =
    new wxGrid(this, ID_LAYERS_LIST, wxDefaultPosition, wxSize(700, 400));
  int count = 0;
  LayerListItem *pL = First;
  while (pL)
    {
      // counting how many layers are there
      count++;
      pL = pL->GetNext();
    }
  Layers->CreateGrid(count, 5, wxGrid::wxGridSelectRows);
  Layers->SetColLabelValue(0, wxT("DB"));
  Layers->SetColLabelValue(1, wxT("Type"));
  Layers->SetColLabelValue(2, wxT("Name"));
  Layers->SetColLabelValue(3, wxT("Title"));
  Layers->SetColLabelValue(4, wxT("Abstract"));
  count = 0;
  wxString cell;
  pL = First;
  while (pL)
    {
      // feeding grid rows
      MyBitmapCellRenderer *renderer = new MyBitmapCellRenderer;
      wxBitmap bmp;
      switch (pL->GetLayerType())
        {
          case MAP_LAYER_VECTOR:
            switch (pL->GetGeometryType())
              {
                case 1:
                case 1001:
                case 2001:
                case 3001:
                case 4:
                case 1004:
                case 2004:
                case 3004:
                  bmp = wxBitmap(points_on_xpm);
                  break;
                case 2:
                case 1002:
                case 2002:
                case 3002:
                case 5:
                case 1005:
                case 2005:
                case 3005:
                  bmp = wxBitmap(linestrings_on_xpm);
                  break;
                case 3:
                case 1003:
                case 2003:
                case 3003:
                case 6:
                case 1006:
                case 2006:
                case 3006:
                  bmp = wxBitmap(polygons_on_xpm);
                  break;
                default:
                  bmp = wxBitmap(vector_xpm);
                  break;
              }
            break;
          case MAP_LAYER_TOPOLOGY:
            bmp = wxBitmap(topo_geo_xpm);
            break;
          case MAP_LAYER_NETWORK:
            bmp = wxBitmap(topo_net_xpm);
            break;
          case MAP_LAYER_RASTER:
            bmp = wxBitmap(coverage_xpm);
            break;
          case MAP_LAYER_WMS:
            bmp = wxBitmap(wms_xpm);
            break;
          default:
            pL = pL->GetNext();
            continue;
        };
      renderer->SetGraphic(bmp);
      Layers->SetCellValue(count, 0, pL->GetDbPrefix());
      Layers->SetCellRenderer(count, 1, renderer);
      if (pL->GetLayerType() == MAP_LAYER_VECTOR)
        {
          wxString prefixName = pL->GetLayerPrefix();
          prefixName += wxT(".");
          prefixName += pL->GetLayerName();
          Layers->SetCellValue(count, 2, prefixName);
      } else
        Layers->SetCellValue(count, 2, pL->GetLayerName());
      Layers->SetCellValue(count, 3, pL->GetTitle());
      Layers->SetCellValue(count, 4, pL->GetAbstract());
      count++;
      pL = pL->GetNext();
    }
  Layers->SetRowLabelSize(wxGRID_AUTOSIZE);
  Layers->AutoSize();
  Layers->EnableEditing(false);
  listSizer->Add(Layers, 0, wxALIGN_RIGHT | wxALL, 5);
// OK - CANCEL buttons
  wxBoxSizer *okCancelBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(okCancelBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&OK"));
  okCancelBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  okCancelBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & AddMapLayerDialog::OnOk);
}

void AddMapLayerDialog::FlushList()
{
// resetting the Layers List
  LayerListItem *pL;
  LayerListItem *pLn;
  pL = First;
  while (pL)
    {
      pLn = pL->GetNext();
      delete pL;
      pL = pLn;
    }
  First = NULL;
  Last = NULL;
}

LayerListItem::LayerListItem(wxString & db_prefix, int layer_type,
                             wxString & name, wxString & title,
                             wxString & abstract, bool queryable)
{
// ctor - Raster or WMS Layer
  DbPrefix = db_prefix;
  if (layer_type == MAP_LAYER_RASTER || layer_type == MAP_LAYER_WMS)
    LayerType = layer_type;
  else
    LayerType = MAP_LAYER_UNKNOWN;
  LayerName = name;
  Title = title;
  Abstract = abstract;
  f_table_name = NULL;
  f_geometry_column = NULL;
  topology_name = NULL;
  network_name = NULL;
  GeometryType = -1;
  HasZ = false;
  NativeSrid = -1;
  Queryable = queryable;
  Editable = false;
  SpatialIndex = false;
  Next = NULL;
}

LayerListItem::LayerListItem(wxString & db_prefix, wxString & layer_prefix,
                             wxString & name, wxString & title,
                             wxString & abstract, const char *table_name,
                             const char *geometry_column, int geom_type,
                             int srid, bool queryable, bool editable,
                             bool spatial_index)
{
// ctor - Vector Layer
  int len;
  DbPrefix = db_prefix;
  LayerPrefix = layer_prefix;
  LayerType = MAP_LAYER_VECTOR;
  LayerName = name;
  Title = title;
  Abstract = abstract;
  len = strlen(table_name);
  f_table_name = (char *) malloc(len + 1);
  strcpy(f_table_name, table_name);
  len = strlen(geometry_column);
  f_geometry_column = (char *) malloc(len + 1);
  strcpy(f_geometry_column, geometry_column);
  topology_name = NULL;
  network_name = NULL;
  GeometryType = geom_type;
  HasZ = false;
  NativeSrid = srid;
  Queryable = queryable;
  Editable = editable;
  SpatialIndex = spatial_index;
  Next = NULL;
}

LayerListItem::LayerListItem(wxString & db_prefix, int type, wxString & name,
                             wxString & title, wxString & abstract,
                             const char *topo_name, bool has_z, int srid,
                             bool queryable, bool editable)
{
// ctor - TopoGeo or TopoNet Layer
  int len;
  DbPrefix = db_prefix;
  if (type == MAP_LAYER_TOPOLOGY || type == MAP_LAYER_NETWORK)
    LayerType = type;
  else
    LayerType = MAP_LAYER_UNKNOWN;
  LayerName = name;
  Title = title;
  Abstract = abstract;
  f_table_name = NULL;
  f_geometry_column = NULL;
  if (type == MAP_LAYER_TOPOLOGY)
    {
      len = strlen(topo_name);
      topology_name = (char *) malloc(len + 1);
      strcpy(topology_name, topo_name);
  } else
    topology_name = NULL;
  if (type == MAP_LAYER_NETWORK)
    {
      len = strlen(topo_name);
      network_name = (char *) malloc(len + 1);
      strcpy(network_name, topo_name);
  } else
    network_name = NULL;
  GeometryType = -1;
  HasZ = has_z;
  NativeSrid = srid;
  Queryable = queryable;
  Editable = editable;
  SpatialIndex = false;
  Next = NULL;
}

LayerListItem::~LayerListItem()
{
// dtor
  if (f_table_name != NULL)
    free(f_table_name);
  if (f_geometry_column != NULL)
    free(f_geometry_column);
  if (topology_name != NULL)
    free(topology_name);
  if (network_name != NULL)
    free(network_name);
}

void AddMapLayerDialog::AddLayer2List(wxString & db_prefix, int layer_type,
                                      wxString & name, wxString & title,
                                      wxString & abstract, bool queryable)
{
// adding a layer item to the list
  LayerListItem *pL =
    new LayerListItem(db_prefix, layer_type, name, title, abstract, queryable);
  if (First == NULL)
    First = pL;
  if (Last != NULL)
    Last->SetNext(pL);
  Last = pL;
}

void AddMapLayerDialog::AddLayer2List(wxString & db_prefix,
                                      wxString & layer_prefix, wxString & name,
                                      wxString & title, wxString & abstract,
                                      const char *f_table_name,
                                      const char *f_geometry_column,
                                      int geom_type, int srid, bool queryable,
                                      bool editable, bool spatial_index)
{
// adding a layer item to the list
  LayerListItem *pL =
    new LayerListItem(db_prefix, layer_prefix, name, title, abstract,
                      f_table_name, f_geometry_column,
                      geom_type, srid, queryable, editable, spatial_index);
  if (First == NULL)
    First = pL;
  if (Last != NULL)
    Last->SetNext(pL);
  Last = pL;
}

void AddMapLayerDialog::AddLayer2List(wxString & db_prefix, int layer_type,
                                      wxString & name, wxString & title,
                                      wxString & abstract,
                                      const char *topo_name, bool has_z,
                                      int srid, bool queryable, bool editable)
{
// adding a layer item to the list
  LayerListItem *pL =
    new LayerListItem(db_prefix, layer_type, name, title, abstract, topo_name,
                      has_z, srid,
                      queryable, editable);
  if (First == NULL)
    First = pL;
  if (Last != NULL)
    Last->SetNext(pL);
  Last = pL;
}

bool AddMapLayerDialog::DoCheckGeometryColumns(const char *db_prefix)
{
// checking GEOMETRY_COLUMNS for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_table_name = false;
  bool ok_geometry_column = false;
  bool ok_geometry_type = false;
  bool ok_srid = false;
  bool ok_spatial_index = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql =
    sqlite3_mprintf("PRAGMA \"%s\".table_info(geometry_columns)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "f_table_name") == 0)
            ok_table_name = true;
          if (strcasecmp(value, "f_geometry_column") == 0)
            ok_geometry_column = true;
          if (strcasecmp(value, "geometry_type") == 0)
            ok_geometry_type = true;
          if (strcasecmp(value, "srid") == 0)
            ok_srid = true;
          if (strcasecmp(value, "spatial_index_enabled") == 0)
            ok_spatial_index = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_table_name && ok_geometry_column && ok_geometry_type && ok_srid
      && ok_spatial_index)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckViewsGeometryColumns(const char *db_prefix)
{
// checking VIEWS_GEOMETRY_COLUMNS for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_view_name = false;
  bool ok_view_geometry = false;
  bool ok_view_rowid = false;
  bool ok_f_table_name = false;
  bool ok_f_geometry_column = false;
  bool ok_read_only = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql =
    sqlite3_mprintf("PRAGMA \"%s\".table_info(views_geometry_columns)",
                    qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "view_name") == 0)
            ok_view_name = true;
          if (strcasecmp(value, "view_geometry") == 0)
            ok_view_geometry = true;
          if (strcasecmp(value, "view_rowid") == 0)
            ok_view_rowid = true;
          if (strcasecmp(value, "f_table_name") == 0)
            ok_f_table_name = true;
          if (strcasecmp(value, "f_geometry_column") == 0)
            ok_f_geometry_column = true;
          if (strcasecmp(value, "read_only") == 0)
            ok_read_only = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_view_name && ok_view_geometry && ok_view_rowid && ok_f_table_name
      && ok_f_geometry_column && ok_read_only)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckVirtsGeometryColumns(const char *db_prefix)
{
// checking VIRTS_GEOMETRY_COLUMNS for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_virt_name = false;
  bool ok_virt_geometry = false;
  bool ok_geometry_type = false;
  bool ok_srid = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql =
    sqlite3_mprintf("PRAGMA \"%s\".table_info(virts_geometry_columns)",
                    qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "virt_name") == 0)
            ok_virt_name = true;
          if (strcasecmp(value, "virt_geometry") == 0)
            ok_virt_geometry = true;
          if (strcasecmp(value, "geometry_type") == 0)
            ok_geometry_type = true;
          if (strcasecmp(value, "srid") == 0)
            ok_srid = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_virt_name && ok_virt_geometry && ok_geometry_type && ok_srid)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckVectorCoverages(const char *db_prefix)
{
// checking VECTOR_COVERAGES for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_coverage_name = false;
  bool ok_table_name = false;
  bool ok_geometry_column = false;
  bool ok_topology_name = false;
  bool ok_network_name = false;
  bool ok_view_name = false;
  bool ok_view_geometry = false;
  bool ok_virt_name = false;
  bool ok_virt_geometry = false;
  bool ok_geo_minx = false;
  bool ok_geo_miny = false;
  bool ok_geo_maxx = false;
  bool ok_geo_maxy = false;
  bool ok_ext_minx = false;
  bool ok_ext_miny = false;
  bool ok_ext_maxx = false;
  bool ok_ext_maxy = false;
  bool ok_title = false;
  bool ok_abstract = false;
  bool ok_queryable = false;
  bool ok_editable = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql =
    sqlite3_mprintf("PRAGMA \"%s\".table_info(vector_coverages)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "coverage_name") == 0)
            ok_coverage_name = true;
          if (strcasecmp(value, "f_table_name") == 0)
            ok_table_name = true;
          if (strcasecmp(value, "f_geometry_column") == 0)
            ok_geometry_column = true;
          if (strcasecmp(value, "topology_name") == 0)
            ok_topology_name = true;
          if (strcasecmp(value, "network_name") == 0)
            ok_network_name = true;
          if (strcasecmp(value, "view_name") == 0)
            ok_view_name = true;
          if (strcasecmp(value, "view_geometry") == 0)
            ok_view_geometry = true;
          if (strcasecmp(value, "virt_name") == 0)
            ok_virt_name = true;
          if (strcasecmp(value, "virt_geometry") == 0)
            ok_virt_geometry = true;
          if (strcasecmp(value, "geo_minx") == 0)
            ok_geo_minx = true;
          if (strcasecmp(value, "geo_miny") == 0)
            ok_geo_miny = true;
          if (strcasecmp(value, "geo_maxx") == 0)
            ok_geo_maxx = true;
          if (strcasecmp(value, "geo_maxy") == 0)
            ok_geo_maxy = true;
          if (strcasecmp(value, "extent_minx") == 0)
            ok_ext_minx = true;
          if (strcasecmp(value, "extent_miny") == 0)
            ok_ext_miny = true;
          if (strcasecmp(value, "extent_maxx") == 0)
            ok_ext_maxx = true;
          if (strcasecmp(value, "extent_maxy") == 0)
            ok_ext_maxy = true;
          if (strcasecmp(value, "title") == 0)
            ok_title = true;
          if (strcasecmp(value, "abstract") == 0)
            ok_abstract = true;
          if (strcasecmp(value, "is_queryable") == 0)
            ok_queryable = true;
          if (strcasecmp(value, "is_editable") == 0)
            ok_editable = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_coverage_name && ok_table_name && ok_geometry_column
      && ok_topology_name && ok_network_name && ok_view_name && ok_view_geometry
      && ok_virt_name && ok_virt_geometry && ok_geo_minx && ok_geo_miny
      && ok_geo_maxx && ok_geo_maxy && ok_ext_minx && ok_ext_miny && ok_ext_maxx
      && ok_ext_maxy && ok_title && ok_abstract && ok_queryable && ok_editable)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckTopologies(const char *db_prefix)
{
// checking TOPOLOGIES for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_topology_name = false;
  bool ok_srid = false;
  bool ok_has_z = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql = sqlite3_mprintf("PRAGMA \"%s\".table_info(topologies)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "topology_name") == 0)
            ok_topology_name = true;
          if (strcasecmp(value, "srid") == 0)
            ok_srid = true;
          if (strcasecmp(value, "has_z") == 0)
            ok_has_z = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_topology_name && ok_srid && ok_has_z)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckNetworks(const char *db_prefix)
{
// checking NETWORKS for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_network_name = false;
  bool ok_srid = false;
  bool ok_has_z = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql = sqlite3_mprintf("PRAGMA \"%s\".table_info(networks)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "network_name") == 0)
            ok_network_name = true;
          if (strcasecmp(value, "srid") == 0)
            ok_srid = true;
          if (strcasecmp(value, "has_z") == 0)
            ok_has_z = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_network_name && ok_srid && ok_has_z)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckRasterCoverages(const char *db_prefix)
{
// checking RASTER_COVERAGES for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_coverage_name = false;
  bool ok_title = false;
  bool ok_abstract = false;
  bool ok_queryable = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql =
    sqlite3_mprintf("PRAGMA \"%s\".table_info(raster_coverages)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "coverage_name") == 0)
            ok_coverage_name = true;
          if (strcasecmp(value, "title") == 0)
            ok_title = true;
          if (strcasecmp(value, "abstract") == 0)
            ok_abstract = true;
          if (strcasecmp(value, "is_queryable") == 0)
            ok_queryable = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_coverage_name && ok_title && ok_abstract && ok_queryable)
    return true;
  return false;
}

bool AddMapLayerDialog::DoCheckWmsCoverages(const char *db_prefix)
{
// checking WMS_GETMAP for validity
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  bool ok_layer_name = false;
  bool ok_title = false;
  bool ok_abstract = false;
  bool ok_queryable = false;
  char *qprefix = gaiaDoubleQuotedSql(db_prefix);
  char *sql = sqlite3_mprintf("PRAGMA \"%s\".table_info(wms_getmap)", qprefix);
  free(qprefix);
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          if (strcasecmp(value, "layer_name") == 0)
            ok_layer_name = true;
          if (strcasecmp(value, "title") == 0)
            ok_title = true;
          if (strcasecmp(value, "abstract") == 0)
            ok_abstract = true;
          if (strcasecmp(value, "is_queryable") == 0)
            ok_queryable = true;
        }
    }
  sqlite3_free_table(results);
  if (ok_layer_name && ok_title && ok_abstract && ok_queryable)
    return true;
  return false;
}

char *AddMapLayerDialog::QueryVectorCoverages(const char *db_prefix,
                                              const char *old_sql)
{
// GeoTable Vector Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckVectorCoverages(db_prefix) == false
      || DoCheckGeometryColumns(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, 'table' AS prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "v.f_table_name, v.f_geometry_column, g.srid, g.geometry_type, "
                            "g.spatial_index_enabled FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".geometry_columns AS g ON (v.f_table_name = g.f_table_name AND "
                            "v.f_geometry_column = g.f_geometry_column) "
                            "WHERE v.topology_name IS NULL AND v.network_name IS NULL",
                            db_prefix, qprefix, qprefix);
  } else
    {
      sql =
        sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, 'table' AS prefix, "
                        "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                        "v.f_table_name, v.f_geometry_column, g.srid, g.geometry_type, "
                        "g.spatial_index_enabled FROM \"%s\".vector_coverages AS v "
                        "JOIN \"%s\".geometry_columns AS g ON (v.f_table_name = g.f_table_name AND "
                        "v.f_geometry_column = g.f_geometry_column) "
                        "WHERE v.topology_name IS NULL AND v.network_name IS NULL",
                        old_sql, db_prefix, qprefix, qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QuerySpatialViewCoverages(const char *db_prefix,
                                                   const char *old_sql)
{
// SpatialView Vector Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckVectorCoverages(db_prefix) == false
      || DoCheckViewsGeometryColumns(db_prefix) == false
      || DoCheckGeometryColumns(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, 'view' AS prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "v.view_name, v.view_geometry, g.srid, g.geometry_type, g.spatial_index_enabled "
                            "FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".views_geometry_columns AS x ON (v.view_name = x.view_name AND "
                            "v.view_geometry = x.view_geometry) "
                            "JOIN \"%s\".geometry_columns AS g ON (x.f_table_name = g.f_table_name AND "
                            "x.f_geometry_column = g.f_geometry_column) "
                            "WHERE v.view_name IS NOT NULL AND v.view_geometry IS NOT NULL",
                            db_prefix, qprefix, qprefix, qprefix);
  } else
    {
      sql =
        sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, 'view' AS prefix, "
                        "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                        "v.view_name, v.view_geometry, g.srid, g.geometry_type, g.spatial_index_enabled "
                        "FROM \"%s\".vector_coverages AS v "
                        "JOIN \"%s\".views_geometry_columns AS x ON (v.view_name = x.view_name AND "
                        "v.view_geometry = x.view_geometry) "
                        "JOIN \"%s\".geometry_columns AS g ON (x.f_table_name = g.f_table_name AND "
                        "x.f_geometry_column = g.f_geometry_column) "
                        "WHERE v.view_name IS NOT NULL AND v.view_geometry IS NOT NULL",
                        old_sql, db_prefix, qprefix, qprefix, qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QueryVirtualShapeCoverages(const char *db_prefix,
                                                    const char *old_sql)
{
// VirtualShape Vector Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckVectorCoverages(db_prefix) == false
      || DoCheckVirtsGeometryColumns(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, 'shp' AS prefix, "
                            "c.coverage_name, c.title, c.abstract, c.is_queryable, 0, v.virt_name, "
                            "v.virt_geometry, v.srid, v.geometry_type, 0 "
                            "FROM \"%s\".vector_coverages AS c "
                            "JOIN \"%s\".virts_geometry_columns AS v ON (c.virt_name = v.virt_name "
                            "AND c.virt_geometry = v.virt_geometry) "
                            "WHERE c.virt_name IS NOT NULL AND c.virt_geometry IS NOT NULL",
                            db_prefix, qprefix, qprefix);
  } else
    {
      sql =
        sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, 'shp' AS prefix, "
                        "c.coverage_name, c.title, c.abstract, c.is_queryable, 0, v.virt_name, "
                        "v.virt_geometry, v.srid, v.geometry_type, 0 "
                        "FROM \"%s\".vector_coverages AS c "
                        "JOIN \"%s\".virts_geometry_columns AS v ON (c.virt_name = v.virt_name "
                        "AND c.virt_geometry = v.virt_geometry) "
                        "WHERE c.virt_name IS NOT NULL AND c.virt_geometry IS NOT NULL",
                        old_sql, db_prefix, qprefix, qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QueryTopoGeoCoverages(const char *db_prefix,
                                               const char *old_sql)
{
// TopoGeo Vector Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckVectorCoverages(db_prefix) == false
      || DoCheckTopologies(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "t.topology_name, t.srid, t.has_z "
                            "FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".topologies AS t ON (v.topology_name = t.topology_name) "
                            "WHERE v.topology_name IS NOT NULL AND v.network_name IS NULL",
                            db_prefix, qprefix, qprefix);
  } else
    {
      sql = sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "t.topology_name, t.srid, t.has_z "
                            "FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".topologies AS t ON (v.topology_name = t.topology_name) "
                            "WHERE v.topology_name IS NOT NULL AND v.network_name IS NULL",
                            old_sql, db_prefix, qprefix, qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QueryTopoNetCoverages(const char *db_prefix,
                                               const char *old_sql)
{
// TopoNet Vector Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckVectorCoverages(db_prefix) == false
      || DoCheckNetworks(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "n.network_name, n.srid, n.has_z "
                            "FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".networks AS n ON (v.network_name = n.network_name) "
                            "WHERE v.topology_name IS NULL AND v.network_name IS NOT NULL",
                            db_prefix, qprefix, qprefix);
  } else
    {
      sql = sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, "
                            "v.coverage_name, v.title, v.abstract, v.is_queryable, v.is_editable, "
                            "n.network_name, n.srid, n.has_z "
                            "FROM \"%s\".vector_coverages AS v "
                            "JOIN \"%s\".networks AS n ON (v.network_name = n.network_name) "
                            "WHERE v.topology_name IS NULL AND v.network_name IS NOT NULL",
                            old_sql, db_prefix, qprefix, qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QueryRasterCoverages(const char *db_prefix,
                                              const char *old_sql)
{
// Raster Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckRasterCoverages(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, "
                            "coverage_name, title, abstract, is_queryable "
                            "FROM \"%s\".raster_coverages ", db_prefix,
                            qprefix);
  } else
    {
      sql = sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, "
                            "coverage_name, title, abstract, is_queryable "
                            "FROM \"%s\".raster_coverages ", old_sql, db_prefix,
                            qprefix);
    }
  free(qprefix);
  return sql;
}

char *AddMapLayerDialog::QueryWmsCoverages(const char *db_prefix,
                                           const char *old_sql)
{
// WMS Coverages - composing the SQL query
  char *sql = NULL;
  char *qprefix;

  if (DoCheckWmsCoverages(db_prefix) == false)
    {
      if (old_sql != NULL)
        return sqlite3_mprintf("%s", old_sql);
      else
        return NULL;
    }

  qprefix = gaiaDoubleQuotedSql(db_prefix);
  if (old_sql == NULL)
    {
      sql = sqlite3_mprintf("SELECT %Q AS db_prefix, "
                            "layer_name, title, abstract, is_queryable "
                            "FROM \"%s\".wms_getmap ", db_prefix, qprefix);
  } else
    {
      sql = sqlite3_mprintf("%s\nUNION\nSELECT %Q AS db_prefix, "
                            "layer_name, title, abstract, is_queryable "
                            "FROM \"%s\".wms_getmap ", old_sql, db_prefix,
                            qprefix);
    }
  free(qprefix);
  return sql;
}

void AddMapLayerDialog::DoLoadVectorCoverages()
{
// populating the layers list (Vector Coverages)
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;
  char *sql2 = NULL;
  char *sql_save = NULL;

  sql = "pragma database_list";
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          // searching for GeoTables
          sql_save = sql2;
          sql2 = QueryVectorCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
          // searching for SpatialViews
          sql_save = sql2;
          sql2 = QuerySpatialViewCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
          // searching for VirtualShapes
          sql_save = sql2;
          sql2 = QueryVirtualShapeCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
        }
    }
  sqlite3_free_table(results);
  if (sql2 == NULL)
    return;

  sql_save = sql2;
  sql2 =
    sqlite3_mprintf("%s\nORDER BY v.coverage_name, db_prefix, prefix",
                    sql_save);
  sqlite3_free(sql_save);
  ret = sqlite3_get_table(sqlite, sql2, &results, &rows, &columns, &errMsg);
  sqlite3_free(sql2);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString db_prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          wxString name = wxString::FromUTF8(value);
          value = results[(i * columns) + 3];
          wxString title = wxString::FromUTF8(value);
          value = results[(i * columns) + 4];
          wxString abstract = wxString::FromUTF8(value);
          bool queryable = false;
          value = results[(i * columns) + 5];
          if (atoi(value))
            queryable = true;
          bool editable = false;
          value = results[(i * columns) + 6];
          if (atoi(value))
            editable = true;
          const char *f_table_name = results[(i * columns) + 7];
          const char *f_geometry_column = results[(i * columns) + 8];
          value = results[(i * columns) + 9];
          int srid = atoi(value);
          value = results[(i * columns) + 10];
          int geom_type = atoi(value);
          bool spatial_index = false;
          value = results[(i * columns) + 11];
          if (atoi(value) == 1)
            spatial_index = true;
          AddLayer2List(db_prefix, prefix, name, title, abstract, f_table_name,
                        f_geometry_column, geom_type, srid, queryable,
                        editable, spatial_index);
        }
    }
  sqlite3_free_table(results);
}

void AddMapLayerDialog::DoLoadTopoGeoCoverages()
{
// populating the layers list (TopoGeo Coverages)
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;
  char *sql2 = NULL;
  char *sql_save = NULL;

  sql = "pragma database_list";
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          sql_save = sql2;
          sql2 = QueryTopoGeoCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
        }
    }
  sqlite3_free_table(results);
  if (sql2 == NULL)
    return;

  sql_save = sql2;
  sql2 = sqlite3_mprintf("%s\nORDER BY v.coverage_name, db_prefix", sql_save);
  sqlite3_free(sql_save);
  ret = sqlite3_get_table(sqlite, sql2, &results, &rows, &columns, &errMsg);
  sqlite3_free(sql2);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString db_prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString name = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          wxString title = wxString::FromUTF8(value);
          value = results[(i * columns) + 3];
          wxString abstract = wxString::FromUTF8(value);
          bool queryable = false;
          value = results[(i * columns) + 4];
          if (atoi(value))
            queryable = true;
          bool editable = false;
          value = results[(i * columns) + 5];
          if (atoi(value))
            editable = true;
          const char *topology_name = results[(i * columns) + 6];
          bool has_z = false;
          value = results[(i * columns) + 7];
          if (atoi(value))
            has_z = true;
          value = results[(i * columns) + 8];
          int srid = atoi(value);
          AddLayer2List(db_prefix, MAP_LAYER_TOPOLOGY, name, title, abstract,
                        topology_name, has_z, srid, queryable, editable);
        }
    }
  sqlite3_free_table(results);
}

void AddMapLayerDialog::DoLoadTopoNetCoverages()
{
// populating the layers list (TopoNet Coverages)
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;
  char *sql2 = NULL;
  char *sql_save = NULL;

  sql = "pragma database_list";
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          sql_save = sql2;
          sql2 = QueryTopoNetCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
        }
    }
  sqlite3_free_table(results);
  if (sql2 == NULL)
    return;

  sql_save = sql2;
  sql2 = sqlite3_mprintf("%s\nORDER BY v.coverage_name, db_prefix", sql_save);
  sqlite3_free(sql_save);
  ret = sqlite3_get_table(sqlite, sql2, &results, &rows, &columns, &errMsg);
  sqlite3_free(sql2);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString db_prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString name = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          wxString title = wxString::FromUTF8(value);
          value = results[(i * columns) + 3];
          wxString abstract = wxString::FromUTF8(value);
          bool queryable = false;
          value = results[(i * columns) + 4];
          if (atoi(value))
            queryable = true;
          bool editable = false;
          value = results[(i * columns) + 5];
          if (atoi(value))
            editable = true;
          const char *network_name = results[(i * columns) + 6];
          bool has_z = false;
          value = results[(i * columns) + 7];
          if (atoi(value))
            has_z = true;
          value = results[(i * columns) + 8];
          int srid = atoi(value);
          AddLayer2List(db_prefix, MAP_LAYER_NETWORK, name, title, abstract,
                        network_name, has_z, srid, queryable, editable);
        }
    }
  sqlite3_free_table(results);
}

void AddMapLayerDialog::DoLoadRasterCoverages()
{
// populating the layers list (Raster Coverages)
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;
  char *sql2 = NULL;
  char *sql_save = NULL;

  sql = "pragma database_list";
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          sql_save = sql2;
          sql2 = QueryRasterCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
        }
    }
  sqlite3_free_table(results);
  if (sql2 == NULL)
    return;

  sql_save = sql2;
  sql2 = sqlite3_mprintf("%s\nORDER BY coverage_name, db_prefix", sql_save);
  sqlite3_free(sql_save);
  ret = sqlite3_get_table(sqlite, sql2, &results, &rows, &columns, &errMsg);
  sqlite3_free(sql2);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString db_prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString name = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          wxString title = wxString::FromUTF8(value);
          value = results[(i * columns) + 3];
          wxString abstract = wxString::FromUTF8(value);
          bool queryable = false;
          value = results[(i * columns) + 4];
          if (atoi(value))
            queryable = true;
          AddLayer2List(db_prefix, MAP_LAYER_RASTER, name, title, abstract,
                        queryable);
        }
    }
  sqlite3_free_table(results);
}

void AddMapLayerDialog::DoLoadWmsCoverages()
{
// populating the layers list (WMS Coverages)
  sqlite3 *sqlite = MapPanel->GetSqlite();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;
  char *sql2 = NULL;
  char *sql_save = NULL;

  sql = "pragma database_list";
  int ret = sqlite3_get_table(sqlite, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 1];
          sql_save = sql2;
          sql2 = QueryWmsCoverages(value, sql_save);
          if (sql_save != NULL)
            sqlite3_free(sql_save);
        }
    }
  sqlite3_free_table(results);
  if (sql2 == NULL)
    return;

  sql_save = sql2;
  sql2 = sqlite3_mprintf("%s\nORDER BY layer_name, db_prefix", sql_save);
  sqlite3_free(sql_save);
  ret = sqlite3_get_table(sqlite, sql2, &results, &rows, &columns, &errMsg);
  sqlite3_free(sql2);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString db_prefix = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString name = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          wxString title = wxString::FromUTF8(value);
          value = results[(i * columns) + 3];
          wxString abstract = wxString::FromUTF8(value);
          bool queryable = false;
          value = results[(i * columns) + 4];
          if (atoi(value))
            queryable = true;
          AddLayer2List(db_prefix, MAP_LAYER_WMS, name, title, abstract,
                        queryable);
        }
    }
  sqlite3_free_table(results);
}

void AddMapLayerDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxDialog::EndModal(wxID_OK);
}

Added MapView.cpp.















































































































































































































































































































































































































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
/*
/ MapView.cpp
/ the Map View of spatialite_gui  - a SQLite /SpatiaLite GUI tool
/
/ version 2.0, 2017 January 8
/
/ Author: Sandro Furieri a-furieri@lqt.it
/
/ Copyright (C) 2017  Alessandro Furieri
/
/    This program is free software: you can redistribute it and/or modify
/    it under the terms of the GNU General Public License as published by
/    the Free Software Foundation, either version 3 of the License, or
/    (at your option) any later version.
/
/    This program is distributed in the hope that it will be useful,
/    but WITHOUT ANY WARRANTY; without even the implied warranty of
/    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
/    GNU General Public License for more details.
/
/    You should have received a copy of the GNU General Public License
/    along with this program.  If not, see <http://www.gnu.org/licenses/>.
/
*/

#include "Classdef.h"

#include "icons/crosshair.xpm"

MyMapView::MyMapView(MyMapPanel * parent, wxWindowID id):
wxPanel(parent, id, wxDefaultPosition, wxSize(440, 480),
        wxBORDER_SUNKEN | wxWANTS_CHARS)
{
//
// constructor: a frame to show the Map
//
  MapPanel = parent;
  Invalidate();

  BitmapWidth = wxSystemSettings::GetMetric(wxSYS_SCREEN_X);
  BitmapHeight = wxSystemSettings::GetMetric(wxSYS_SCREEN_Y);
  MapBitmap = wxBitmap(BitmapWidth, BitmapHeight, -1);
  ScreenBitmap = wxBitmap(BitmapWidth, BitmapHeight, -1);

  wxImage crossImage = wxBitmap(crosshair_xpm).ConvertToImage();
#ifdef __WXMSW__
// setting up a WINDOWS cursor
  crossImage.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_X, 8);
  crossImage.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_Y, 8);
  CursorCross = wxCursor(crossImage);
#else
#ifdef __WXMAC__
// setting up a MacOsX cursor
  crossImage.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_X, 8);
  crossImage.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_Y, 8);
  CursorCross = wxCursor(crossImage);
#else
// setting up an UNIX -likecursor
  int row;
  int col;
  unsigned short bits[16];
  unsigned short mask[16];
  for (row = 0; row < 16; row++)
    {
      bits[row] = 0x0000;
      mask[row] = 0x0000;
      for (col = 0; col < 16; col++)
        {
          unsigned char pixel = crossImage.GetRed(col, row);
          if (pixel == 0)
            {
              switch (col)
                {
                  case 0:
                    bits[row] |= 0x8000;
                    break;
                  case 1:
                    bits[row] |= 0x4000;
                    break;
                  case 2:
                    bits[row] |= 0x2000;
                    break;
                  case 3:
                    bits[row] |= 0x1000;
                    break;
                  case 4:
                    bits[row] |= 0x0800;
                    break;
                  case 5:
                    bits[row] |= 0x0400;
                    break;
                  case 6:
                    bits[row] |= 0x0200;
                    break;
                  case 7:
                    bits[row] |= 0x0100;
                    break;
                  case 8:
                    bits[row] |= 0x0080;
                    break;
                  case 9:
                    bits[row] |= 0x0040;
                    break;
                  case 10:
                    bits[row] |= 0x0020;
                    break;
                  case 11:
                    bits[row] |= 0x0010;
                    break;
                  case 12:
                    bits[row] |= 0x0008;
                    break;
                  case 13:
                    bits[row] |= 0x0004;
                    break;
                  case 14:
                    bits[row] |= 0x0002;
                    break;
                  case 15:
                    bits[row] |= 0x0001;
                    break;
                };
              switch (col)
                {
                  case 0:
                    mask[row] |= 0x8000;
                    break;
                  case 1:
                    mask[row] |= 0x4000;
                    break;
                  case 2:
                    mask[row] |= 0x2000;
                    break;
                  case 3:
                    mask[row] |= 0x1000;
                    break;
                  case 4:
                    mask[row] |= 0x0800;
                    break;
                  case 5:
                    mask[row] |= 0x0400;
                    break;
                  case 6:
                    mask[row] |= 0x0200;
                    break;
                  case 7:
                    mask[row] |= 0x0100;
                    break;
                  case 8:
                    mask[row] |= 0x0080;
                    break;
                  case 9:
                    mask[row] |= 0x0040;
                    break;
                  case 10:
                    mask[row] |= 0x0020;
                    break;
                  case 11:
                    mask[row] |= 0x0010;
                    break;
                  case 12:
                    mask[row] |= 0x0008;
                    break;
                  case 13:
                    mask[row] |= 0x0004;
                    break;
                  case 14:
                    mask[row] |= 0x0002;
                    break;
                  case 15:
                    mask[row] |= 0x0001;
                    break;
                };
            }
          if (pixel == 255)
            {
              switch (col)
                {
                  case 0:
                    mask[row] |= 0x8000;
                    break;
                  case 1:
                    mask[row] |= 0x4000;
                    break;
                  case 2:
                    mask[row] |= 0x2000;
                    break;
                  case 3:
                    mask[row] |= 0x1000;
                    break;
                  case 4:
                    mask[row] |= 0x0800;
                    break;
                  case 5:
                    mask[row] |= 0x0400;
                    break;
                  case 6:
                    mask[row] |= 0x0200;
                    break;
                  case 7:
                    mask[row] |= 0x0100;
                    break;
                  case 8:
                    mask[row] |= 0x0080;
                    break;
                  case 9:
                    mask[row] |= 0x0040;
                    break;
                  case 10:
                    mask[row] |= 0x0020;
                    break;
                  case 11:
                    mask[row] |= 0x0010;
                    break;
                  case 12:
                    mask[row] |= 0x0008;
                    break;
                  case 13:
                    mask[row] |= 0x0004;
                    break;
                  case 14:
                    mask[row] |= 0x0002;
                    break;
                  case 15:
                    mask[row] |= 0x0001;
                    break;
                };
            }
        }
    }
  CursorCross =
    wxCursor((char *) bits, 16, 16, 8, 8, (char *) mask, wxWHITE, wxBLACK);
#endif
#endif
  CursorHand = wxCursor(wxCURSOR_HAND);
  SetCursor(CursorCross);

// setting up event handlers
  Connect(wxID_ANY, wxEVT_ERASE_BACKGROUND,
          (wxObjectEventFunction) & MyMapView::OnEraseBackground);
  Connect(wxID_ANY, wxEVT_SIZE, (wxObjectEventFunction) & MyMapView::OnSize);
  Connect(wxID_ANY, wxEVT_PAINT, (wxObjectEventFunction) & MyMapView::OnPaint);
}

MyMapView::~MyMapView()
{
}

void MyMapView::OnSize(wxSizeEvent & WXUNUSED(event))
{
//
// this window has changed its size
//

// refreshing the map
  /*
     if (PrintInProgress == true)
     return;
     if (DownloadInProgress == true)
     PendingWmsAbort = true;
     PendingOnSize = true;
     if (ProgressControl != NULL)
     {
     // resizing the Progress control
     wxRect rect;
     if (MainFrame->GetProgressRect(rect) == true)
     ProgressControl->SetSize(rect);
     }
     PrepareMap();
     ResetMarker();
     if (IdentifyPanel != NULL)
     IdentifyPanel->Reset();
   */
}

void MyMapView::OnPaint(wxPaintEvent & WXUNUSED(event))
{
//
// this window needs to be repainted
//
  wxPaintDC dc(this);
  if (ValidMap == false)
    {
      // no map: black background
      wxSize sz = GetClientSize();
      dc.SetBrush(wxBrush(wxColour(128, 110, 96), wxSOLID));
      dc.SetPen(wxPen(wxColour(0, 0, 0), 1));
      dc.DrawRectangle(0, 0, sz.GetWidth(), sz.GetHeight());
      dc.SetBrush(wxNullBrush);
      dc.SetPen(wxNullPen);
  } else if (dc.IsOk() && ScreenBitmap.IsOk())
    {
      wxMemoryDC *memDC = new wxMemoryDC(ScreenBitmap);
      dc.Blit(0, 0, BitmapWidth, BitmapHeight, memDC, 0, 0);
      delete memDC;
    }
  //MainFrame->UpdateMapCRS();
}

void MyMapView::Invalidate()
{
// resetting to initial state
  ValidMap = false;
  /*
     ActiveLayer = NULL;
     DragStartX = -1;
     DragStartY = -1;
     LastDragX = -1;
     LastDragY = -1;
     if (UpdateTimer)
     {
     UpdateTimer->Stop();
     delete UpdateTimer;
     }
     UpdateTimer = NULL;
     if (TimerMouseWheel)
     {
     TimerMouseWheel->Stop();
     delete TimerMouseWheel;
     }
     TimerMouseWheel = NULL;
     if (TimerDynamic)
     {
     TimerDynamic->Stop();
     delete TimerDynamic;
     }
     TimerDynamic = NULL;
     WheelTics = 0;
   */
}

void MyMapView::PrepareMap()
{
//
// draws the MapBitmap
//
}

void MyMapView::ResetMapLayers()
{
//
// resetting the Map Layer list
//
  FirstLayer = NULL;
  LastLayer = NULL;
}

void MyMapView::ReinsertMapLayer(MapLayer * lyr)
{
//
// reinserting yet again a Map Layer (Tree new order)
//
  lyr->SetPrev(NULL);
  lyr->SetNext(NULL);
  if (FirstLayer == NULL)
    FirstLayer = lyr;
  lyr->SetPrev(LastLayer);
  if (LastLayer != NULL)
    LastLayer->SetNext(lyr);
  LastLayer = lyr;
}

void MyMapView::RemoveMapLayer(MapLayer * layer)
{
//
// removing a Map layer
//
  if (ActiveLayer == layer)
    ActiveLayer = NULL;
  if (layer->GetPrev() != NULL)
    layer->GetPrev()->SetNext(layer->GetNext());
  if (layer->GetNext() != NULL)
    layer->GetNext()->SetPrev(layer->GetPrev());
  if (FirstLayer == layer)
    FirstLayer = layer->GetNext();
  if (LastLayer == layer)
    LastLayer = layer->GetPrev();
  delete layer;
}

bool MyMapView::CanIdentify()
{
//
// test if Identify could be currently be enabled
//
  if (ActiveLayer == NULL)
    return false;
  if (ActiveLayer->IsVisible() == 0)
    return false;
  return true;
}

Changes to Objects.cpp.

20
21
22
23
24
25
26













































27
28
29
30
31
32
33
34
35
36
37
38
39

40
41
42
43
44
45
46
..
48
49
50
51
52
53
54















55
56
57
58
59
60
61
62
63
64
65
66
67

68
69
70
71
72
73
74
..
76
77
78
79
80
81
82

83
84
85
86
87
88
89
....
1655
1656
1657
1658
1659
1660
1661























1662
1663
1664
1665
1666
1667
1668
....
1674
1675
1676
1677
1678
1679
1680




1681
1682
1683
1684
1685
1686
1687
....
1776
1777
1778
1779
1780
1781
1782













1783
1784
1785
1786
1787
1788
1789
....
1809
1810
1811
1812
1813
1814
1815





























1816
1817
1818
1819
1820
1821
1822
....
1826
1827
1828
1829
1830
1831
1832




1833
1834
1835
1836
1837
1838
1839
....
1873
1874
1875
1876
1877
1878
1879














1880
1881
1882
1883
1884
1885
1886
....
1892
1893
1894
1895
1896
1897
1898

1899
1900
1901
1902
1903
1904
1905
1906

1907
1908
1909



















1910
























































1911
1912
1913

1914
1915
1916
1917
1918
1919
1920





































1921


1922
1923
1924
1925
1926
1927
1928
....
1972
1973
1974
1975
1976
1977
1978













1979
1980
1981
1982
1983
1984
1985
....
2006
2007
2008
2009
2010
2011
2012
















2013
2014
2015
2016

2017
2018
2019
2020
2021
2022
2023
....
3256
3257
3258
3259
3260
3261
3262
3263

3264
3265

3266
3267

3268
3269
3270
3271
3272
3273
3274
/
/    You should have received a copy of the GNU General Public License
/    along with this program.  If not, see <http://www.gnu.org/licenses/>.
/
*/

#include "Classdef.h"














































MyObject::MyObject(int type, wxString & name)
{
//
// constructor - TreeItemData
//
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;
  Topology = false;

}

MyObject::MyObject(int type, wxString & name, bool tmp, bool coverage,
                   bool topology)
{
//
// constructor - TreeItemData
................................................................................
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = tmp;
  Coverage = coverage;
  Topology = topology;















}

MyObject::MyObject(int type, wxString & name, wxString & column)
{
//
// constructor - TreeItemData
//
  Type = type;
  Name = name;
  Column = column;
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;

}

MyObject::MyObject(int type, bool WXUNUSED(attached), wxString & dbAlias,
                   wxString & name, bool coverage, bool topology)
{
//
// constructor - TreeItemData
................................................................................
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = dbAlias;
  Temporary = false;
  Coverage = coverage;
  Topology = topology;

}

void MyVariant::Copy(MyVariant * other)
{
// 
// transfers a BLOB value
//
................................................................................
MyPieChartLabel *MyPieChartLabels::GetRightLabel(int idx)
{
// return a Right Label pointer by index
  if (idx >= 0 && idx < NumRightLabels)
    return *(RightLabels + idx);
  return NULL;
}
























TopoGeo::TopoGeo(MyTableTree * tree, wxTreeItemId & root,
                 wxString & db_prefix, wxString & name, int srid, bool has_z)
{
// constructor: TopoGeo Tree Node
  DbHandle = tree->GetSQLiteHandle();
  DbPrefix = db_prefix;
................................................................................
  xname += wxString::FromUTF8(bufSrid);
  if (has_z == true)
    xname += wxT(" 3D");
  else
    xname += wxT(" 2D");
  TopologyNode = tree->AppendItem(root, xname);
  tree->SetItemImage(TopologyNode, 20);




  Next = NULL;
}

bool TopoGeo::CheckTopoFeature(wxString & table)
{
// checking if some table is a TopoFeatures table
  char topo_name[1024];
................................................................................
      delete pT;
      pT = pTn;
    }
  First = NULL;
  Last = NULL;
  Count = 0;
}














void TopoGeoList::Add(class MyTableTree * tree, wxTreeItemId & root,
                      wxString & db_prefix, wxString & name, int srid,
                      bool has_z)
{
// inserting a TopoGeo into the list
  TopoGeo *pT = new TopoGeo(tree, root, db_prefix, name, srid, has_z);
................................................................................
  return NULL;
}

TopoNet::TopoNet(MyTableTree * tree, wxTreeItemId & root,
                 wxString & name, bool spatial, int srid, bool has_z)
{
// constructor: TopoNet Tree Node





























  Name = name;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  if (spatial == false)
    xname += wxT(" - Logical Network");
  else
................................................................................
      if (has_z == true)
        xname += wxT(" 3D");
      else
        xname += wxT(" 2D");
    }
  NetworkNode = tree->AppendItem(root, xname);
  tree->SetItemImage(NetworkNode, 25);




  Next = NULL;
}

wxTreeItemId *TopoNet::Check(wxString & table)
{
// checking if some table belongs to this TopoNet
  wxString cfr = Name + wxT("_link");
................................................................................
  Count++;
  if (First == NULL)
    First = pT;
  if (Last != NULL)
    Last->SetNext(pT);
  Last = pT;
}















wxTreeItemId *TopoNetList::FindNode(wxString & table)
{
// searching corresponding TopoNet Node (if any)
  TopoNet *pT = First;
  while (pT)
    {
................................................................................
  return NULL;
}

RasterCoverage::RasterCoverage(MyTableTree * tree, wxTreeItemId & root,
                               wxString & coverage, int srid)
{
// constructor: Raster Coverage Tree Node

  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);
  tree->SetItemImage(CoverageNode, 22);

  Next = NULL;
}




















VectorCoverage::VectorCoverage(MyTableTree * tree, wxTreeItemId & root,
























































                               wxString & coverage, int srid)
{
// constructor: Vector Coverage Tree Node

  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);





































  tree->SetItemImage(CoverageNode, 24);


  Next = NULL;
}

wxTreeItemId *RasterCoverage::Check(wxString & table, bool * tile_data)
{
// checking if some table belongs to this Raster Coverage
  *tile_data = false;
................................................................................
  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}














wxTreeItemId *RasterCoverageList::FindNode(wxString & table, bool * tile_data)
{
// searching corresponding RasterCoverage Node (if any)
  RasterCoverage *pC = First;
  while (pC)
    {
................................................................................
    }
  First = NULL;
  Last = NULL;
  Count = 0;
}

void VectorCoverageList::Add(class MyTableTree * tree, wxTreeItemId & root,
















                             wxString & coverage, int srid)
{
// inserting a Vector Coverage into the list
  VectorCoverage *pC = new VectorCoverage(tree, root, coverage, srid);

  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}
................................................................................
// constructor
  Name = wxString::FromUTF8(name);
  Spatial = spatial;
  Srid = srid;
  HasZ = has_z;
}

VectorCoverageSet::VectorCoverageSet(const char *name, int srid)

{
// constructor

  Name = wxString::FromUTF8(name);
  Srid = srid;

}

RasterCoverageSet::RasterCoverageSet(const char *name, int srid)
{
// constructor
  Name = wxString::FromUTF8(name);
  Srid = srid;







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>













>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>













>







 







>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>








>



>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>

>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|


>



|



>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|


|
>







 







|
>


>


>







20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
..
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
...
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
....
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
....
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
....
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
....
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
....
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
....
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
....
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
....
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
....
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
....
3553
3554
3555
3556
3557
3558
3559
3560
3561
3562
3563
3564
3565
3566
3567
3568
3569
3570
3571
3572
3573
3574
/
/    You should have received a copy of the GNU General Public License
/    along with this program.  If not, see <http://www.gnu.org/licenses/>.
/
*/

#include "Classdef.h"

MyObject::MyObject(bool attached)
{
//
// constructor - TreeItemData
//
  Type = MY_ROOT_NODE;
  Name = wxT("");
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;
  Topology = false;
  RootAttached = attached;
}

MyObject::MyObject(wxString & coverage)
{
//
// constructor - TreeItemData
//
  Type = MY_COVERAGE;
  Name = coverage;
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;
  Topology = false;
  RootAttached = false;
}

MyObject::MyObject(wxString & db_alias, wxString & coverage)
{
//
// constructor - TreeItemData
//
  Type = MY_COVERAGE;
  Name = coverage;
  Column = wxT("");
  DbAlias = db_alias;
  Temporary = false;
  Coverage = false;
  Topology = false;
  RootAttached = true;
}

MyObject::MyObject(int type, wxString & name)
{
//
// constructor - TreeItemData
//
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;
  Topology = false;
  RootAttached = false;
}

MyObject::MyObject(int type, wxString & name, bool tmp, bool coverage,
                   bool topology)
{
//
// constructor - TreeItemData
................................................................................
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = wxT("");
  Temporary = tmp;
  Coverage = coverage;
  Topology = topology;
  RootAttached = false;
}

MyObject::MyObject(int type, wxString & db_alias, wxString & name, bool temp)
{
//
// constructor - TreeItemData
//
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = db_alias;
  Temporary = temp;
  Coverage = false;
  RootAttached = false;
}

MyObject::MyObject(int type, wxString & name, wxString & column)
{
//
// constructor - TreeItemData
//
  Type = type;
  Name = name;
  Column = column;
  DbAlias = wxT("");
  Temporary = false;
  Coverage = false;
  RootAttached = false;
}

MyObject::MyObject(int type, bool WXUNUSED(attached), wxString & dbAlias,
                   wxString & name, bool coverage, bool topology)
{
//
// constructor - TreeItemData
................................................................................
  Type = type;
  Name = name;
  Column = wxT("");
  DbAlias = dbAlias;
  Temporary = false;
  Coverage = coverage;
  Topology = topology;
  RootAttached = true;
}

void MyVariant::Copy(MyVariant * other)
{
// 
// transfers a BLOB value
//
................................................................................
MyPieChartLabel *MyPieChartLabels::GetRightLabel(int idx)
{
// return a Right Label pointer by index
  if (idx >= 0 && idx < NumRightLabels)
    return *(RightLabels + idx);
  return NULL;
}

TopoGeo::TopoGeo(MyTableTree * tree, wxTreeItemId & root,
                 wxString & name, int srid, bool has_z)
{
// constructor: TopoGeo Tree Node
  DbHandle = tree->GetSQLiteHandle();
  DbPrefix = wxT("");
  Name = name;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  if (has_z == true)
    xname += wxT(" 3D");
  else
    xname += wxT(" 2D");
  TopologyNode = tree->AppendItem(root, xname);
  tree->SetItemImage(TopologyNode, 20);
  tree->SetItemData(TopologyNode,
                    (wxTreeItemData *) (new MyObject(MY_TOPO_GEO, Name)));
  Next = NULL;
}

TopoGeo::TopoGeo(MyTableTree * tree, wxTreeItemId & root,
                 wxString & db_prefix, wxString & name, int srid, bool has_z)
{
// constructor: TopoGeo Tree Node
  DbHandle = tree->GetSQLiteHandle();
  DbPrefix = db_prefix;
................................................................................
  xname += wxString::FromUTF8(bufSrid);
  if (has_z == true)
    xname += wxT(" 3D");
  else
    xname += wxT(" 2D");
  TopologyNode = tree->AppendItem(root, xname);
  tree->SetItemImage(TopologyNode, 20);
  tree->SetItemData(TopologyNode,
                    (wxTreeItemData *) (new
                                        MyObject(MY_TOPO_GEO, db_prefix, Name,
                                                 false)));
  Next = NULL;
}

bool TopoGeo::CheckTopoFeature(wxString & table)
{
// checking if some table is a TopoFeatures table
  char topo_name[1024];
................................................................................
      delete pT;
      pT = pTn;
    }
  First = NULL;
  Last = NULL;
  Count = 0;
}

void TopoGeoList::Add(class MyTableTree * tree, wxTreeItemId & root,
                      wxString & name, int srid, bool has_z)
{
// inserting a TopoGeo into the list
  TopoGeo *pT = new TopoGeo(tree, root, name, srid, has_z);
  Count++;
  if (First == NULL)
    First = pT;
  if (Last != NULL)
    Last->SetNext(pT);
  Last = pT;
}

void TopoGeoList::Add(class MyTableTree * tree, wxTreeItemId & root,
                      wxString & db_prefix, wxString & name, int srid,
                      bool has_z)
{
// inserting a TopoGeo into the list
  TopoGeo *pT = new TopoGeo(tree, root, db_prefix, name, srid, has_z);
................................................................................
  return NULL;
}

TopoNet::TopoNet(MyTableTree * tree, wxTreeItemId & root,
                 wxString & name, bool spatial, int srid, bool has_z)
{
// constructor: TopoNet Tree Node
  DbPrefix = wxT("");
  Name = name;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  if (spatial == false)
    xname += wxT(" - Logical Network");
  else
    {
      sprintf(bufSrid, " [SRID=%d]", srid);
      xname += wxString::FromUTF8(bufSrid);
      if (has_z == true)
        xname += wxT(" 3D");
      else
        xname += wxT(" 2D");
    }
  NetworkNode = tree->AppendItem(root, xname);
  tree->SetItemImage(NetworkNode, 25);
  tree->SetItemData(NetworkNode,
                    (wxTreeItemData *) (new MyObject(MY_TOPO_NET, Name)));
  Next = NULL;
}

TopoNet::TopoNet(MyTableTree * tree, wxTreeItemId & root,
                 wxString & dbPrefix, wxString & name, bool spatial, int srid,
                 bool has_z)
{
// constructor: TopoNet Tree Node
  DbPrefix = dbPrefix;
  Name = name;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  if (spatial == false)
    xname += wxT(" - Logical Network");
  else
................................................................................
      if (has_z == true)
        xname += wxT(" 3D");
      else
        xname += wxT(" 2D");
    }
  NetworkNode = tree->AppendItem(root, xname);
  tree->SetItemImage(NetworkNode, 25);
  tree->SetItemData(NetworkNode,
                    (wxTreeItemData *) (new
                                        MyObject(MY_TOPO_NET, DbPrefix, Name,
                                                 false)));
  Next = NULL;
}

wxTreeItemId *TopoNet::Check(wxString & table)
{
// checking if some table belongs to this TopoNet
  wxString cfr = Name + wxT("_link");
................................................................................
  Count++;
  if (First == NULL)
    First = pT;
  if (Last != NULL)
    Last->SetNext(pT);
  Last = pT;
}

void TopoNetList::Add(class MyTableTree * tree, wxTreeItemId & root,
                      wxString & dbPrefix, wxString & name, bool spatial,
                      int srid, bool has_z)
{
// inserting a TopoNet into the list
  TopoNet *pT = new TopoNet(tree, root, dbPrefix, name, spatial, srid, has_z);
  Count++;
  if (First == NULL)
    First = pT;
  if (Last != NULL)
    Last->SetNext(pT);
  Last = pT;
}

wxTreeItemId *TopoNetList::FindNode(wxString & table)
{
// searching corresponding TopoNet Node (if any)
  TopoNet *pT = First;
  while (pT)
    {
................................................................................
  return NULL;
}

RasterCoverage::RasterCoverage(MyTableTree * tree, wxTreeItemId & root,
                               wxString & coverage, int srid)
{
// constructor: Raster Coverage Tree Node
  DbPrefix = wxT("");
  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);
  tree->SetItemImage(CoverageNode, 22);
  tree->SetItemData(CoverageNode, (wxTreeItemData *) (new MyObject(coverage)));
  Next = NULL;
}

RasterCoverage::RasterCoverage(MyTableTree * tree, wxTreeItemId & root,
                               wxString & dbPrefix, wxString & coverage,
                               int srid)
{
// constructor: Raster Coverage Tree Node
  DbPrefix = dbPrefix;
  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);
  tree->SetItemImage(CoverageNode, 22);
  tree->SetItemData(CoverageNode,
                    (wxTreeItemData *) (new MyObject(dbPrefix, coverage)));
  Next = NULL;
}

VectorCoverage::VectorCoverage(MyTableTree * tree, wxTreeItemId & root,
                               wxString & prefix, wxString & coverage, int srid,
                               int type)
{
// constructor: Vector Coverage Tree Node
  DbPrefix = wxT("");
  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = prefix + wxT(".") + Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);
  int index = 24;
  switch (type)
    {
      case 1:
      case 1001:
      case 2001:
      case 3001:
      case 4:
      case 1004:
      case 2004:
      case 3004:
        index = 27;
        break;
      case 2:
      case 1002:
      case 2002:
      case 3002:
      case 5:
      case 1005:
      case 2005:
      case 3005:
        index = 28;
        break;
      case 3:
      case 1003:
      case 2003:
      case 3003:
      case 6:
      case 1006:
      case 2006:
      case 3006:
        index = 29;
        break;
      default:
        index = 24;
        break;
    };
  tree->SetItemImage(CoverageNode, index);
  tree->SetItemData(CoverageNode, (wxTreeItemData *) (new MyObject(coverage)));
  Next = NULL;
}

VectorCoverage::VectorCoverage(MyTableTree * tree, wxTreeItemId & root,
                               wxString & dbPrefix, wxString & prefix,
                               wxString & coverage, int srid, int type)
{
// constructor: Vector Coverage Tree Node
  DbPrefix = dbPrefix;
  Name = coverage;
  wxString xname;
  char bufSrid[64];
  xname = prefix + wxT(".") + Name;
  sprintf(bufSrid, " [SRID=%d]", srid);
  xname += wxString::FromUTF8(bufSrid);
  CoverageNode = tree->AppendItem(root, xname);
  int index = 24;
  switch (type)
    {
      case 1:
      case 1001:
      case 2001:
      case 3001:
      case 4:
      case 1004:
      case 2004:
      case 3004:
        index = 27;
        break;
      case 2:
      case 1002:
      case 2002:
      case 3002:
      case 5:
      case 1005:
      case 2005:
      case 3005:
        index = 28;
        break;
      case 3:
      case 1003:
      case 2003:
      case 3003:
      case 6:
      case 1006:
      case 2006:
      case 3006:
        index = 29;
        break;
      default:
        index = 24;
        break;
    };
  tree->SetItemImage(CoverageNode, index);
  tree->SetItemData(CoverageNode,
                    (wxTreeItemData *) (new MyObject(dbPrefix, coverage)));
  Next = NULL;
}

wxTreeItemId *RasterCoverage::Check(wxString & table, bool * tile_data)
{
// checking if some table belongs to this Raster Coverage
  *tile_data = false;
................................................................................
  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void RasterCoverageList::Add(class MyTableTree * tree, wxTreeItemId & root,
                             wxString & dbPrefix, wxString & coverage, int srid)
{
// inserting a Raster Coverage into the list
  RasterCoverage *pC = new RasterCoverage(tree, root, dbPrefix, coverage, srid);
  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

wxTreeItemId *RasterCoverageList::FindNode(wxString & table, bool * tile_data)
{
// searching corresponding RasterCoverage Node (if any)
  RasterCoverage *pC = First;
  while (pC)
    {
................................................................................
    }
  First = NULL;
  Last = NULL;
  Count = 0;
}

void VectorCoverageList::Add(class MyTableTree * tree, wxTreeItemId & root,
                             wxString & prefix, wxString & coverage, int srid,
                             int type)
{
// inserting a Vector Coverage into the list
  VectorCoverage *pC =
    new VectorCoverage(tree, root, prefix, coverage, srid, type);
  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void VectorCoverageList::Add(class MyTableTree * tree, wxTreeItemId & root,
                             wxString & dbPrefix, wxString & prefix,
                             wxString & coverage, int srid, int type)
{
// inserting a Vector Coverage into the list
  VectorCoverage *pC =
    new VectorCoverage(tree, root, dbPrefix, prefix, coverage, srid, type);
  Count++;
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}
................................................................................
// constructor
  Name = wxString::FromUTF8(name);
  Spatial = spatial;
  Srid = srid;
  HasZ = has_z;
}

VectorCoverageSet::VectorCoverageSet(const char *prefix, const char *name,
                                     int srid, int type)
{
// constructor
  Prefix = wxString::FromUTF8(prefix);
  Name = wxString::FromUTF8(name);
  Srid = srid;
  GeometryType = type;
}

RasterCoverageSet::RasterCoverageSet(const char *name, int srid)
{
// constructor
  Name = wxString::FromUTF8(name);
  Srid = srid;

Changes to QueryView.cpp.

66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
...
590
591
592
593
594
595
596


597
598
599
600
601
602
603
...
607
608
609
610
611
612
613








614
615
616
617
618
619
620
...
667
668
669
670
671
672
673
674








675


676
677
678
679
680
681
682
....
1391
1392
1393
1394
1395
1396
1397


1398
1399
1400
1401
1402
1403
1404
....
1959
1960
1961
1962
1963
1964
1965




1966
1967
1968
1969
1970
1971
1972
....
2122
2123
2124
2125
2126
2127
2128




2129
2130
2131
2132
2133
2134
2135
    new wxBitmapButton(this, ID_SQL_FILTER, wxBitmap(filter_xpm),
                       wxPoint(340, 38), wxSize(32, 32));
  BtnSqlFilter->SetToolTip(wxT("Apply/Remove SQL filters"));
  BtnSqlFilter->Enable(false);
  BtnSqlErase =
    new wxBitmapButton(this, ID_SQL_ERASE, wxBitmap(sql_erase_xpm),
                       wxPoint(340, 70), wxSize(32, 32));
  BtnSqlErase->SetToolTip(wxT("Clean SQL query"));
  BtnSqlErase->Enable(true);
  BtnSqlAbort =
    new wxBitmapButton(this, ID_SQL_ABORT, wxBitmap(sql_abort_xpm),
                       wxPoint(340, 102), wxSize(32, 32));
  BtnSqlAbort->SetBitmapDisabled(wxBitmap(sql_abort_no_xpm));
  BtnSqlAbort->SetToolTip(wxT("Abort SQL query"));
  BtnHistoryBack =
................................................................................
    return true;
  if (str.CmpNoCase(wxT("WMS_RegisterGetMap")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_UnRegisterGetMap")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_SetGetMapInfos")) == 0)
    return true;


  if (str.CmpNoCase(wxT("WMS_SetGetMapOptions")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_RegisterSetting")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_UnRegisterSetting")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_DefaultSetting")) == 0)
................................................................................
  if (str.CmpNoCase(wxT("WMS_UnRegisterRefSys")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_DefaultRefSys")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_GetMapRequestURL")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_GetFeatureInfoRequestURL")) == 0)








    return true;
  if (str.CmpNoCase(wxT("GeometryConstraints")) == 0)
    return true;
  if (str.CmpNoCase(wxT("CheckSpatialMetaData")) == 0)
    return true;
  if (str.CmpNoCase(wxT("AutoFDOStart")) == 0)
    return true;
................................................................................
  if (str.CmpNoCase(wxT("CreateMetaCatalogTables")) == 0)
    return true;
  if (str.CmpNoCase(wxT("UpdateMetaCatalogStatistics")) == 0)
    return true;
  if (str.CmpNoCase(wxT("CreateStylingTables")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterVectorCoverage")) == 0)
    return true;








  if (str.CmpNoCase(wxT("SE_UnregisterVectorCoverage")) == 0)


    return true;
  if (str.CmpNoCase(wxT("SE_SetVectorCoverageInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterVectorCoverageSrid")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_UnregisterVectorCoverageSrid")) == 0)
    return true;
................................................................................
  if (str.CmpNoCase(wxT("PointOnSurface")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_PointOnSurface")) == 0)
    return true;
  if (str.CmpNoCase(wxT("Area")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_Area")) == 0)


    return true;
  if (str.CmpNoCase(wxT("ExteriorRing")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_ExteriorRing")) == 0)
    return true;
  if (str.CmpNoCase(wxT("NumInteriorRing")) == 0)
    return true;
................................................................................
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_RemoveDanglingNodes")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_NewEdgeHeal")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_ModEdgeHeal")) == 0)
    return true;




  if (str.CmpNoCase(wxT("TopoGeo_Clone")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_GetEdgeSeed")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_GetFaceSeed")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_UpdateSeeds")) == 0)
................................................................................
    return true;
  if (str.CmpNoCase(wxT("RL2_DropRasterCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SetRasterCoverageInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_SetRasterCoverageInfos")) == 0)
    return true;




  if (str.CmpNoCase(wxT("SetRasterCoverageDefaultBands")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_SetRasterCoverageDefaultBands")) == 0)
    return true;
  if (str.CmpNoCase(wxT("EnableRasterCoverageAutoNDVI")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_EnableRasterCoverageAutoNDVI")) == 0)







|







 







>
>







 







>
>
>
>
>
>
>
>







 








>
>
>
>
>
>
>
>

>
>







 







>
>







 







>
>
>
>







 







>
>
>
>







66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
...
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
...
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
...
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
....
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
....
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
....
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
    new wxBitmapButton(this, ID_SQL_FILTER, wxBitmap(filter_xpm),
                       wxPoint(340, 38), wxSize(32, 32));
  BtnSqlFilter->SetToolTip(wxT("Apply/Remove SQL filters"));
  BtnSqlFilter->Enable(false);
  BtnSqlErase =
    new wxBitmapButton(this, ID_SQL_ERASE, wxBitmap(sql_erase_xpm),
                       wxPoint(340, 70), wxSize(32, 32));
  BtnSqlErase->SetToolTip(wxT("Clear SQL query"));
  BtnSqlErase->Enable(true);
  BtnSqlAbort =
    new wxBitmapButton(this, ID_SQL_ABORT, wxBitmap(sql_abort_xpm),
                       wxPoint(340, 102), wxSize(32, 32));
  BtnSqlAbort->SetBitmapDisabled(wxBitmap(sql_abort_no_xpm));
  BtnSqlAbort->SetToolTip(wxT("Abort SQL query"));
  BtnHistoryBack =
................................................................................
    return true;
  if (str.CmpNoCase(wxT("WMS_RegisterGetMap")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_UnRegisterGetMap")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_SetGetMapInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_SetGetMapCopyright")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_SetGetMapOptions")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_RegisterSetting")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_UnRegisterSetting")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_DefaultSetting")) == 0)
................................................................................
  if (str.CmpNoCase(wxT("WMS_UnRegisterRefSys")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_DefaultRefSys")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_GetMapRequestURL")) == 0)
    return true;
  if (str.CmpNoCase(wxT("WMS_GetFeatureInfoRequestURL")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RegisterDataLicense")) == 0)
    return true;
  if (str.CmpNoCase(wxT("UnRegisterDataLicense")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RenameDataLicense")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SetDataLicenseUrl")) == 0)
    return true;
  if (str.CmpNoCase(wxT("GeometryConstraints")) == 0)
    return true;
  if (str.CmpNoCase(wxT("CheckSpatialMetaData")) == 0)
    return true;
  if (str.CmpNoCase(wxT("AutoFDOStart")) == 0)
    return true;
................................................................................
  if (str.CmpNoCase(wxT("CreateMetaCatalogTables")) == 0)
    return true;
  if (str.CmpNoCase(wxT("UpdateMetaCatalogStatistics")) == 0)
    return true;
  if (str.CmpNoCase(wxT("CreateStylingTables")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterVectorCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterSpatialViewCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterVirtualShapeCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterTopoGeoCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterTopoNetCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_UnregisterVectorCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_SetVectorCoverageCopyright")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_SetVectorCoverageInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_RegisterVectorCoverageSrid")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SE_UnregisterVectorCoverageSrid")) == 0)
    return true;
................................................................................
  if (str.CmpNoCase(wxT("PointOnSurface")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_PointOnSurface")) == 0)
    return true;
  if (str.CmpNoCase(wxT("Area")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_Area")) == 0)
    return true;
  if (str.CmpNoCase(wxT("Circularity")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ExteriorRing")) == 0)
    return true;
  if (str.CmpNoCase(wxT("ST_ExteriorRing")) == 0)
    return true;
  if (str.CmpNoCase(wxT("NumInteriorRing")) == 0)
    return true;
................................................................................
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_RemoveDanglingNodes")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_NewEdgeHeal")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_ModEdgeHeal")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_NewEdgesSplit")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_ModEdgesSplit")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_Clone")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_GetEdgeSeed")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_GetFaceSeed")) == 0)
    return true;
  if (str.CmpNoCase(wxT("TopoGeo_UpdateSeeds")) == 0)
................................................................................
    return true;
  if (str.CmpNoCase(wxT("RL2_DropRasterCoverage")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SetRasterCoverageInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_SetRasterCoverageInfos")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SetRasterCoverageCopyright")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_SetRasterCoverageCopyright")) == 0)
    return true;
  if (str.CmpNoCase(wxT("SetRasterCoverageDefaultBands")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_SetRasterCoverageDefaultBands")) == 0)
    return true;
  if (str.CmpNoCase(wxT("EnableRasterCoverageAutoNDVI")) == 0)
    return true;
  if (str.CmpNoCase(wxT("RL2_EnableRasterCoverageAutoNDVI")) == 0)

Changes to Raster.cpp.

331
332
333
334
335
336
337


338
339
340
341
342
343
344
345
346
...
356
357
358
359
360
361
362














363
364
365
366
367
368
369
....
2012
2013
2014
2015
2016
2017
2018





2019
2020
2021
2022
2023
2024
2025
....
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
....
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
....
3123
3124
3125
3126
3127
3128
3129











































































































































































































































3130
3131
3132
3133
3134
3135
3136
  wxSpinCtrl *heightCtrl = new wxSpinCtrl(this, ID_CVG_HEIGHT, wxEmptyString,
                                          wxDefaultPosition, wxSize(60, 20),
                                          wxSP_ARROW_KEYS,
                                          256, 1024, 512);
  heightCtrl->Enable(false);
  tileHSizer->Add(heightCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// sixth row, column #2: SRID


  wxBoxSizer *sridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  mixSizer->Add(sridBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *sridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT("Georeferencing"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *geoSizer = new wxStaticBoxSizer(sridBox, wxVERTICAL);
  sridBoxSizer->Add(geoSizer, 0, wxALIGN_RIGHT | wxALL, 5);
  wxBoxSizer *norefSizer = new wxBoxSizer(wxHORIZONTAL);
................................................................................
  sridSizer->Add(sridLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  int srid = 0;
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_CVG_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(80, 20),
                                        wxSP_ARROW_KEYS,
                                        -1, 1000000, srid);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);














// sixth row, column #3: Pixel Resolution
  wxBoxSizer *resBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  mixSizer->Add(resBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *resBox = new wxStaticBox(this, wxID_STATIC,
                                        wxT("Pixel Resolution"),
                                        wxDefaultPosition,
                                        wxDefaultSize);
................................................................................
  else
    MD5 = false;
  wxCheckBox *summaryCtrl = (wxCheckBox *) FindWindow(ID_CVG_SUMMARY);
  if (summaryCtrl->IsChecked() == true)
    Summary = true;
  else
    Summary = false;





  wxDialog::EndModal(wxID_OK);
  return;
}

bool ImportRasterDialog::Create(MyFrame * parent, wxString & coverage,
                                wxArrayString & paths, wxString & path,
                                wxString & title, wxString & abstract,
................................................................................
    new wxStaticText(this, wxID_STATIC, wxT("Import &File(s):"));
  fileSizer->Add(fileLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *filesCtrl = new wxTextCtrl(this, wxID_ANY, Path,
                                         wxDefaultPosition, wxSize(600, 60),
                                         wxTE_MULTILINE | wxTE_READONLY);
  fileSizer->Add(filesCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// eighth  row: Import Options
  int space_sz = 35;
  wxBoxSizer *optBoxSizer = new wxBoxSizer(wxVERTICAL);
  boxSizer->Add(optBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *optBox = new wxStaticBox(this, wxID_STATIC,
                                        wxT("Import Options"),
                                        wxDefaultPosition,
                                        wxDefaultSize);
  wxBoxSizer *optSizer = new wxStaticBoxSizer(optBox, wxHORIZONTAL);
................................................................................
  optSizer->AddSpacer(space_sz);
  wxCheckBox *forceSridCtrl = new wxCheckBox(this, ID_LOAD_FORCE_SRID,
                                             wxT("Forced SRID value"),
                                             wxDefaultPosition, wxDefaultSize);
  forceSridCtrl->SetValue(false);
  sridSizer->Add(forceSridCtrl, 0, wxALIGN_LEFT | wxALL, 5);
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_LOAD_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(60, 20),
                                        wxSP_ARROW_KEYS, -1, 1000000, Srid);
  sridCtrl->Enable(false);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 1);
  wxCheckBox *worldCtrl = new wxCheckBox(this, ID_LOAD_WITH_WORLDFILE,
                                         wxT("With WorldFile support"),
                                         wxDefaultPosition, wxDefaultSize);
  worldCtrl->SetValue(false);
................................................................................
                 ("You could now eventually consider to execute VACUUM in order to reclaim the unused disk space."),
                 wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
  else
    wxMessageBox(wxT("Failure: some unexpected error occurred"),
                 wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
  wxDialog::EndModal(wxID_CANCEL);
}












































































































































































































































bool VectorUnregisterDialog::Create(MyFrame * parent, wxString & coverage,
                                    wxString & title, wxString & abstract,
                                    wxString & type)
{
//
// creating the dialog







>
>

|







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>







 







|







 







|







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
...
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
....
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
....
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
....
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
....
3144
3145
3146
3147
3148
3149
3150
3151
3152
3153
3154
3155
3156
3157
3158
3159
3160
3161
3162
3163
3164
3165
3166
3167
3168
3169
3170
3171
3172
3173
3174
3175
3176
3177
3178
3179
3180
3181
3182
3183
3184
3185
3186
3187
3188
3189
3190
3191
3192
3193
3194
3195
3196
3197
3198
3199
3200
3201
3202
3203
3204
3205
3206
3207
3208
3209
3210
3211
3212
3213
3214
3215
3216
3217
3218
3219
3220
3221
3222
3223
3224
3225
3226
3227
3228
3229
3230
3231
3232
3233
3234
3235
3236
3237
3238
3239
3240
3241
3242
3243
3244
3245
3246
3247
3248
3249
3250
3251
3252
3253
3254
3255
3256
3257
3258
3259
3260
3261
3262
3263
3264
3265
3266
3267
3268
3269
3270
3271
3272
3273
3274
3275
3276
3277
3278
3279
3280
3281
3282
3283
3284
3285
3286
3287
3288
3289
3290
3291
3292
3293
3294
3295
3296
3297
3298
3299
3300
3301
3302
3303
3304
3305
3306
3307
3308
3309
3310
3311
3312
3313
3314
3315
3316
3317
3318
3319
3320
3321
3322
3323
3324
3325
3326
3327
3328
3329
3330
3331
3332
3333
3334
3335
3336
3337
3338
3339
3340
3341
3342
3343
3344
3345
3346
3347
3348
3349
3350
3351
3352
3353
3354
3355
3356
3357
3358
3359
3360
3361
3362
3363
3364
3365
3366
3367
3368
3369
3370
3371
3372
3373
3374
3375
3376
3377
3378
3379
3380
3381
3382
3383
3384
3385
3386
3387
3388
3389
3390
3391
3392
  wxSpinCtrl *heightCtrl = new wxSpinCtrl(this, ID_CVG_HEIGHT, wxEmptyString,
                                          wxDefaultPosition, wxSize(60, 20),
                                          wxSP_ARROW_KEYS,
                                          256, 1024, 512);
  heightCtrl->Enable(false);
  tileHSizer->Add(heightCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// sixth row, column #2: SRID
  wxBoxSizer *sridQueryableSizer = new wxBoxSizer(wxVERTICAL);
  mixSizer->Add(sridQueryableSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxBoxSizer *sridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  sridQueryableSizer->Add(sridBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *sridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT("Georeferencing"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *geoSizer = new wxStaticBoxSizer(sridBox, wxVERTICAL);
  sridBoxSizer->Add(geoSizer, 0, wxALIGN_RIGHT | wxALL, 5);
  wxBoxSizer *norefSizer = new wxBoxSizer(wxHORIZONTAL);
................................................................................
  sridSizer->Add(sridLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  int srid = 0;
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_CVG_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(80, 20),
                                        wxSP_ARROW_KEYS,
                                        -1, 1000000, srid);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// sixth row, column #2/bis: queryable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  sridQueryableSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_CVG_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);
// sixth row, column #3: Pixel Resolution
  wxBoxSizer *resBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  mixSizer->Add(resBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *resBox = new wxStaticBox(this, wxID_STATIC,
                                        wxT("Pixel Resolution"),
                                        wxDefaultPosition,
                                        wxDefaultSize);
................................................................................
  else
    MD5 = false;
  wxCheckBox *summaryCtrl = (wxCheckBox *) FindWindow(ID_CVG_SUMMARY);
  if (summaryCtrl->IsChecked() == true)
    Summary = true;
  else
    Summary = false;
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_CVG_QUERYABLE);
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  wxDialog::EndModal(wxID_OK);
  return;
}

bool ImportRasterDialog::Create(MyFrame * parent, wxString & coverage,
                                wxArrayString & paths, wxString & path,
                                wxString & title, wxString & abstract,
................................................................................
    new wxStaticText(this, wxID_STATIC, wxT("Import &File(s):"));
  fileSizer->Add(fileLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *filesCtrl = new wxTextCtrl(this, wxID_ANY, Path,
                                         wxDefaultPosition, wxSize(600, 60),
                                         wxTE_MULTILINE | wxTE_READONLY);
  fileSizer->Add(filesCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// eighth  row: Import Options
  int space_sz = 25;
  wxBoxSizer *optBoxSizer = new wxBoxSizer(wxVERTICAL);
  boxSizer->Add(optBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *optBox = new wxStaticBox(this, wxID_STATIC,
                                        wxT("Import Options"),
                                        wxDefaultPosition,
                                        wxDefaultSize);
  wxBoxSizer *optSizer = new wxStaticBoxSizer(optBox, wxHORIZONTAL);
................................................................................
  optSizer->AddSpacer(space_sz);
  wxCheckBox *forceSridCtrl = new wxCheckBox(this, ID_LOAD_FORCE_SRID,
                                             wxT("Forced SRID value"),
                                             wxDefaultPosition, wxDefaultSize);
  forceSridCtrl->SetValue(false);
  sridSizer->Add(forceSridCtrl, 0, wxALIGN_LEFT | wxALL, 5);
  wxSpinCtrl *sridCtrl = new wxSpinCtrl(this, ID_LOAD_SRID, wxEmptyString,
                                        wxDefaultPosition, wxSize(80, 20),
                                        wxSP_ARROW_KEYS, -1, 1000000, Srid);
  sridCtrl->Enable(false);
  sridSizer->Add(sridCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 1);
  wxCheckBox *worldCtrl = new wxCheckBox(this, ID_LOAD_WITH_WORLDFILE,
                                         wxT("With WorldFile support"),
                                         wxDefaultPosition, wxDefaultSize);
  worldCtrl->SetValue(false);
................................................................................
                 ("You could now eventually consider to execute VACUUM in order to reclaim the unused disk space."),
                 wxT("spatialite_gui"), wxOK | wxICON_INFORMATION, this);
  else
    wxMessageBox(wxT("Failure: some unexpected error occurred"),
                 wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
  wxDialog::EndModal(wxID_CANCEL);
}

bool RasterInfosDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;
  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  if (DoReadCoverage() == false)
    return false;
  if (wxDialog::Create(parent, wxID_ANY, wxT("Edit Raster Coverage Infos"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  return true;
}

void RasterInfosDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// first row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_CVG_NAME, CoverageName,
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_CVG_TITLE, Title,
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_CVG_ABSTRACT, Abstract,
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: queryable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_CVG_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  if (IsQueryable == false)
    queryableBox->SetSelection(0);
  else
    queryableBox->SetSelection(1);
// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&OK"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & RasterInfosDialog::OnOk);
}

bool RasterInfosDialog::DoReadCoverage()
{
// will retrieve to read the given Coverage definition
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  char *sql;
  char cvg[1024];
  int count = 0;

  wxCharBuffer buffer = CoverageName.ToUTF8();
  sprintf(cvg, "%s", buffer.data());
  sql =
    sqlite3_mprintf
    ("SELECT title, abstract, is_queryable "
     "FROM raster_coverages WHERE Lower(coverage_name) = Lower(%Q)", cvg);
  int ret = sqlite3_get_table(MainFrame->GetSqlite(), sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          Title = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          Abstract = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          if (atoi(value) == 0)
            IsQueryable = false;
          else
            IsQueryable = true;
          count++;
        }
    }
  sqlite3_free_table(results);
  if (count == 1)
    return true;
  return false;
}

void RasterInfosDialog::DoUpdateCoverage()
{
// will retrieve to update the given Coverage definition
  int ret;
  sqlite3_stmt *stmt = NULL;
  char *dummy;
  const char *sql = "SELECT RL2_SetRasterCoverageInfos(?, ?, ?, ?)";
  ret =
    sqlite3_prepare_v2(MainFrame->GetSqlite(), sql, strlen(sql), &stmt, NULL);
  if (ret != SQLITE_OK)
    {
      const char *msg = sqlite3_errmsg(MainFrame->GetSqlite());
      wxMessageBox(wxT("ERROR - SetRasterCoverageInfos: ") +
                   wxString::FromUTF8(msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      return;
    }
  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((CoverageName.Len() * 4) + 1);
  strcpy(dummy, CoverageName.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((Title.Len() * 4) + 1);
  strcpy(dummy, Title.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((Abstract.Len() * 4) + 1);
  strcpy(dummy, Abstract.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (IsQueryable == false)
    sqlite3_bind_int(stmt, 4, 0);
  else
    sqlite3_bind_int(stmt, 4, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      const char *msg = sqlite3_errmsg(MainFrame->GetSqlite());
      wxMessageBox(wxT("ERROR - SetRasterCoverageInfos: ") +
                   wxString::FromUTF8(msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
    }
  sqlite3_finalize(stmt);
}

void RasterInfosDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_CVG_NAME);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_CVG_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_CVG_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_CVG_QUERYABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    IsQueryable = true;
  else
    IsQueryable = false;
  DoUpdateCoverage();
  wxDialog::EndModal(wxID_OK);
}

bool VectorUnregisterDialog::Create(MyFrame * parent, wxString & coverage,
                                    wxString & title, wxString & abstract,
                                    wxString & type)
{
//
// creating the dialog

Changes to ResultSetView.cpp.

497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
    ThreadParams.Abort();
}

const char *MyResultSetView::CleanSqlTail(const char *dirty)
{
// strips any leading white-space
  const char *p = dirty;
  while (p != '\0')
    {
      if (*p == ' ')
        {
          p++;
          continue;
        }
      if (*p == '\t')







|







497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
    ThreadParams.Abort();
}

const char *MyResultSetView::CleanSqlTail(const char *dirty)
{
// strips any leading white-space
  const char *p = dirty;
  while (*p != '\0')
    {
      if (*p == ' ')
        {
          p++;
          continue;
        }
      if (*p == '\t')

Changes to Styles.cpp.

1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636




































1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652

















































































































































































































































































































































































































































































































































1653
1654
1655
1656
1657
1658
1659
....
1772
1773
1774
1775
1776
1777
1778
1779
1780

1781
1782
1783
1784
1785
1786
1787
....
1797
1798
1799
1800
1801
1802
1803

1804
1805
1806





























































































1807
1808
1809
1810
1811
1812
1813
....
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827

1828
1829
1830
1831
1832
1833
1834
1835
1836

1837
1838
1839
1840
1841
1842
1843























































































































1844
1845
1846
1847
1848
1849
1850
....
1864
1865
1866
1867
1868
1869
1870






























































































































































































































1871
1872
1873
1874
1875
1876
1877
....
1882
1883
1884
1885
1886
1887
1888







1889
1890
1891
1892
1893
1894
1895
....
2478
2479
2480
2481
2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
....
2493
2494
2495
2496
2497
2498
2499
2500

2501
2502
2503
2504
2505
2506
2507
....
2527
2528
2529
2530
2531
2532
2533
2534

2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548

2549
2550
2551
2552
2553
2554
2555
....
2557
2558
2559
2560
2561
2562
2563
2564

2565
2566
2567
2568
2569
2570
2571
....
2605
2606
2607
2608
2609
2610
2611


























2612
2613
2614
2615
2616
2617
2618
....
2626
2627
2628
2629
2630
2631
2632


2633
2634
2635
2636
2637
2638
2639
....
2674
2675
2676
2677
2678
2679
2680
















































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































2681
2682
2683
2684
2685
2686
2687
....
3587
3588
3589
3590
3591
3592
3593







3594
3595
3596
3597
3598
3599
3600
....
4041
4042
4043
4044
4045
4046
4047







4048
4049
4050
4051
4052
4053
4054
....
5448
5449
5450
5451
5452
5453
5454
5455
5456
5457
5458
5459
5460
5461
5462
5463
5464
5465
5466
5467
5468
5469
5470
5471
5472
5473
5474
5475
5476
5477
      pC = pC->GetNext();
    }
}

void CandidateVectorCoveragesList::MarkRasterCoverage(wxString & table,
                                                      wxString & geometry)
{
// marking a some table related to an already registered Raster Coverage
  CandidateVectorCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetTableName().CmpNoCase(table) == 0
          && pC->GetGeometryColumn().CmpNoCase(geometry) == 0)
        {
          pC->MarkRasterCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}





































CandidateVectorCoveragesList *MyFrame::FindUnregisteredVectorCoverages()
{
// will retrieve all not yet registered Geometries
  CandidateVectorCoveragesList *list = new CandidateVectorCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from GEOMETRY_COLUMNS
  sql =
    "SELECT f_table_name, f_geometry_column, srid, geometry_type "
    "FROM geometry_columns " "ORDER BY f_table_name, f_geometry_column";

















































































































































































































































































































































































































































































































































  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
                break;
            };
          list->Add(table, geometry, srid, type);
        }
    }
  sqlite3_free_table(results);

// marking any already registered Vector Coverage
  sql = "SELECT f_table_name, f_geometry_column FROM vector_coverages";

  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
          wxString table = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          list->MarkVectorCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);


// marking any table related to an already registered Raster Coverage
  sql = "SELECT coverage_name FROM raster_coverages";





























































































  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value) + wxT("_sections");
          wxString geometry = wxT("geometry");
          list->MarkRasterCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_tiles");
          list->MarkRasterCoverage(table, geometry);

        }
    }
  sqlite3_free_table(results);
  return list;
}

bool MyFrame::DoRegisterVectorCoverage(wxString & name, wxString & table,
                                       wxString & geometry, wxString & title,
                                       wxString & abstract)

{
//
// attempting to register a Vector Coverage
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql = "SELECT SE_RegisterVectorCoverage(?, ?, ?, ?, ?)";























































































































  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
................................................................................
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 5, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);






























































































































































































































  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
................................................................................

bool VectorCoverageStylesDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;







  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorCoverageStyles(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................
bool VectorRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredVectorCoverages();
  if (wxDialog::Create(parent, wxID_ANY, wxT("Register Vector Coverage"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
................................................................................
// centers the dialog window
  Centre();
  int count = 0;
  CandidateVectorCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true)

        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
................................................................................
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT("Candidate Vector Coverages"),

                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateVectorCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true)

        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 4, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("f_table_name"));
  GridCtrl->SetColLabelValue(1, wxT("f_geometry_column"));
  GridCtrl->SetColLabelValue(2, wxT("SRID"));
................................................................................
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true)

        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetTableName());
          GridCtrl->SetCellValue(count, 1, pC->GetGeometryColumn());
          sprintf(dummy, "%d", pC->GetSrid());
................................................................................
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);



























// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
................................................................................
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);


  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
................................................................................
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
















































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































  wxDialog::EndModal(wxID_OK);
}

bool ReloadVectorStyleDialog::Create(MyFrame * parent, wxString & path)
{
//
// creating the dialog
................................................................................

bool VectorSRIDsDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;







  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorAlternativeSRIDs(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................

bool VectorKeywordsDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;







  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorKeywords(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................
      path = params->GetPathByIndex(i);
      params->SetCurrentPath(path);
      report = wxT("Loading and Validating: ") + path;
      evt_start.SetString(report);
      params->GetDlg()->GetEventHandler()->AddPendingEvent(evt_start);
      clock_start = clock();
      wxString abstract;
      if (params->
          GetMainFrame()->ValidateExternalGraphicResource(path.ToUTF8(), &blob,
                                                          &blob_size,
                                                          abstract) == true)
        {
          wxFileName fn(path);
          wxString xlink_href =
            wxT("http://www.utopia.gov/") + fn.GetFullName();
          wxString filename = fn.GetFullName();
          wxString title = fn.GetName();
          if (params->
              GetDlg()->RegisterExternalGraphic(stmt, xlink_href.ToUTF8(),
                                                title.ToUTF8(),
                                                abstract.ToUTF8(),
                                                filename.ToUTF8(), blob,
                                                blob_size) != true)
            {
              params->SetError();
              goto error;
            }
          clock_end = clock();
          seconds =
            (double) (clock_end - clock_start) / (double) CLOCKS_PER_SEC;







|














>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>


|












|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







|
|
>







 







>
|
<
<
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







<
<
<
|
<
>








|
>


|



|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>







 







|







 







|
>







 







|
>













|
>







 







|
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>







 







>
>
>
>
>
>
>







 







|
|
<
|






|
|
<
|
<
|







1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
....
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
....
2363
2364
2365
2366
2367
2368
2369
2370
2371


2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392
2393
2394
2395
2396
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416
2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
....
2474
2475
2476
2477
2478
2479
2480



2481

2482
2483
2484
2485
2486
2487
2488
2489
2490
2491
2492
2493
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539
2540
2541
2542
2543
2544
2545
2546
2547
2548
2549
2550
2551
2552
2553
2554
2555
2556
2557
2558
2559
2560
2561
2562
2563
2564
2565
2566
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588
2589
2590
2591
2592
2593
2594
2595
2596
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
....
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731
2732
2733
2734
2735
2736
2737
2738
2739
2740
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764
2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797
2798
2799
2800
2801
2802
2803
2804
2805
2806
2807
2808
2809
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859
2860
2861
2862
2863
2864
2865
2866
2867
2868
2869
2870
2871
2872
2873
2874
....
2879
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
....
3482
3483
3484
3485
3486
3487
3488
3489
3490
3491
3492
3493
3494
3495
3496
....
3497
3498
3499
3500
3501
3502
3503
3504
3505
3506
3507
3508
3509
3510
3511
3512
....
3532
3533
3534
3535
3536
3537
3538
3539
3540
3541
3542
3543
3544
3545
3546
3547
3548
3549
3550
3551
3552
3553
3554
3555
3556
3557
3558
3559
3560
3561
3562
....
3564
3565
3566
3567
3568
3569
3570
3571
3572
3573
3574
3575
3576
3577
3578
3579
....
3613
3614
3615
3616
3617
3618
3619
3620
3621
3622
3623
3624
3625
3626
3627
3628
3629
3630
3631
3632
3633
3634
3635
3636
3637
3638
3639
3640
3641
3642
3643
3644
3645
3646
3647
3648
3649
3650
3651
3652
....
3660
3661
3662
3663
3664
3665
3666
3667
3668
3669
3670
3671
3672
3673
3674
3675
....
3710
3711
3712
3713
3714
3715
3716
3717
3718
3719
3720
3721
3722
3723
3724
3725
3726
3727
3728
3729
3730
3731
3732
3733
3734
3735
3736
3737
3738
3739
3740
3741
3742
3743
3744
3745
3746
3747
3748
3749
3750
3751
3752
3753
3754
3755
3756
3757
3758
3759
3760
3761
3762
3763
3764
3765
3766
3767
3768
3769
3770
3771
3772
3773
3774
3775
3776
3777
3778
3779
3780
3781
3782
3783
3784
3785
3786
3787
3788
3789
3790
3791
3792
3793
3794
3795
3796
3797
3798
3799
3800
3801
3802
3803
3804
3805
3806
3807
3808
3809
3810
3811
3812
3813
3814
3815
3816
3817
3818
3819
3820
3821
3822
3823
3824
3825
3826
3827
3828
3829
3830
3831
3832
3833
3834
3835
3836
3837
3838
3839
3840
3841
3842
3843
3844
3845
3846
3847
3848
3849
3850
3851
3852
3853
3854
3855
3856
3857
3858
3859
3860
3861
3862
3863
3864
3865
3866
3867
3868
3869
3870
3871
3872
3873
3874
3875
3876
3877
3878
3879
3880
3881
3882
3883
3884
3885
3886
3887
3888
3889
3890
3891
3892
3893
3894
3895
3896
3897
3898
3899
3900
3901
3902
3903
3904
3905
3906
3907
3908
3909
3910
3911
3912
3913
3914
3915
3916
3917
3918
3919
3920
3921
3922
3923
3924
3925
3926
3927
3928
3929
3930
3931
3932
3933
3934
3935
3936
3937
3938
3939
3940
3941
3942
3943
3944
3945
3946
3947
3948
3949
3950
3951
3952
3953
3954
3955
3956
3957
3958
3959
3960
3961
3962
3963
3964
3965
3966
3967
3968
3969
3970
3971
3972
3973
3974
3975
3976
3977
3978
3979
3980
3981
3982
3983
3984
3985
3986
3987
3988
3989
3990
3991
3992
3993
3994
3995
3996
3997
3998
3999
4000
4001
4002
4003
4004
4005
4006
4007
4008
4009
4010
4011
4012
4013
4014
4015
4016
4017
4018
4019
4020
4021
4022
4023
4024
4025
4026
4027
4028
4029
4030
4031
4032
4033
4034
4035
4036
4037
4038
4039
4040
4041
4042
4043
4044
4045
4046
4047
4048
4049
4050
4051
4052
4053
4054
4055
4056
4057
4058
4059
4060
4061
4062
4063
4064
4065
4066
4067
4068
4069
4070
4071
4072
4073
4074
4075
4076
4077
4078
4079
4080
4081
4082
4083
4084
4085
4086
4087
4088
4089
4090
4091
4092
4093
4094
4095
4096
4097
4098
4099
4100
4101
4102
4103
4104
4105
4106
4107
4108
4109
4110
4111
4112
4113
4114
4115
4116
4117
4118
4119
4120
4121
4122
4123
4124
4125
4126
4127
4128
4129
4130
4131
4132
4133
4134
4135
4136
4137
4138
4139
4140
4141
4142
4143
4144
4145
4146
4147
4148
4149
4150
4151
4152
4153
4154
4155
4156
4157
4158
4159
4160
4161
4162
4163
4164
4165
4166
4167
4168
4169
4170
4171
4172
4173
4174
4175
4176
4177
4178
4179
4180
4181
4182
4183
4184
4185
4186
4187
4188
4189
4190
4191
4192
4193
4194
4195
4196
4197
4198
4199
4200
4201
4202
4203
4204
4205
4206
4207
4208
4209
4210
4211
4212
4213
4214
4215
4216
4217
4218
4219
4220
4221
4222
4223
4224
4225
4226
4227
4228
4229
4230
4231
4232
4233
4234
4235
4236
4237
4238
4239
4240
4241
4242
4243
4244
4245
4246
4247
4248
4249
4250
4251
4252
4253
4254
4255
4256
4257
4258
4259
4260
4261
4262
4263
4264
4265
4266
4267
4268
4269
4270
4271
4272
4273
4274
4275
4276
4277
4278
4279
4280
4281
4282
4283
4284
4285
4286
4287
4288
4289
4290
4291
4292
4293
4294
4295
4296
4297
4298
4299
4300
4301
4302
4303
4304
4305
4306
4307
4308
4309
4310
4311
4312
4313
4314
4315
4316
4317
4318
4319
4320
4321
4322
4323
4324
4325
4326
4327
4328
4329
4330
4331
4332
4333
4334
4335
4336
4337
4338
4339
4340
4341
4342
4343
4344
4345
4346
4347
4348
4349
4350
4351
4352
4353
4354
4355
4356
4357
4358
4359
4360
4361
4362
4363
4364
4365
4366
4367
4368
4369
4370
4371
4372
4373
4374
4375
4376
4377
4378
4379
4380
4381
4382
4383
4384
4385
4386
4387
4388
4389
4390
4391
4392
4393
4394
4395
4396
4397
4398
4399
4400
4401
4402
4403
4404
4405
4406
4407
4408
4409
4410
4411
4412
4413
4414
4415
4416
4417
4418
4419
4420
4421
4422
4423
4424
4425
4426
4427
4428
4429
4430
4431
4432
4433
4434
4435
4436
4437
4438
4439
4440
4441
4442
4443
4444
4445
4446
4447
4448
4449
4450
4451
4452
4453
4454
4455
4456
4457
4458
4459
4460
4461
4462
4463
4464
4465
4466
4467
4468
4469
4470
4471
4472
4473
4474
4475
4476
4477
4478
4479
4480
4481
4482
4483
4484
4485
4486
4487
4488
4489
4490
4491
4492
4493
4494
4495
4496
4497
4498
4499
4500
4501
4502
4503
4504
4505
4506
4507
4508
4509
4510
4511
4512
4513
4514
4515
4516
4517
4518
4519
4520
4521
4522
4523
4524
4525
4526
4527
4528
4529
4530
4531
4532
4533
4534
4535
4536
4537
4538
4539
4540
4541
4542
4543
4544
4545
4546
4547
4548
4549
4550
4551
4552
4553
4554
4555
4556
4557
4558
4559
4560
4561
4562
4563
4564
4565
4566
4567
4568
4569
4570
4571
4572
4573
4574
4575
4576
4577
4578
4579
4580
4581
4582
4583
4584
4585
4586
4587
4588
4589
4590
4591
4592
4593
4594
4595
4596
4597
4598
4599
4600
4601
4602
4603
4604
4605
4606
4607
4608
4609
4610
4611
4612
4613
4614
4615
4616
4617
4618
4619
4620
4621
4622
4623
4624
4625
4626
4627
4628
4629
4630
4631
4632
4633
4634
4635
4636
4637
4638
4639
4640
4641
4642
4643
4644
4645
4646
4647
4648
4649
4650
4651
4652
4653
4654
4655
4656
4657
4658
4659
4660
4661
4662
4663
4664
4665
4666
4667
4668
4669
4670
4671
4672
4673
4674
4675
4676
4677
4678
4679
4680
4681
4682
4683
4684
4685
4686
4687
4688
4689
4690
4691
4692
4693
4694
4695
4696
4697
4698
4699
4700
4701
4702
4703
4704
4705
4706
4707
4708
4709
4710
4711
4712
4713
4714
4715
4716
4717
4718
4719
4720
4721
4722
4723
4724
4725
4726
4727
4728
4729
4730
4731
4732
4733
4734
4735
4736
4737
4738
4739
4740
4741
4742
4743
4744
4745
4746
4747
4748
4749
4750
4751
4752
4753
4754
4755
4756
4757
4758
4759
4760
4761
4762
4763
4764
4765
4766
4767
4768
4769
4770
4771
4772
4773
4774
4775
4776
4777
4778
4779
4780
4781
4782
4783
4784
4785
4786
4787
4788
4789
4790
4791
4792
4793
4794
4795
4796
4797
4798
4799
4800
4801
4802
4803
4804
4805
4806
4807
4808
4809
4810
4811
4812
4813
4814
4815
4816
4817
4818
4819
4820
4821
4822
4823
4824
4825
4826
4827
4828
4829
4830
4831
4832
4833
4834
4835
4836
4837
4838
4839
4840
4841
4842
4843
4844
4845
4846
4847
4848
4849
4850
4851
4852
4853
4854
4855
4856
4857
4858
4859
4860
4861
4862
4863
4864
4865
4866
4867
4868
4869
4870
4871
4872
4873
4874
4875
4876
4877
4878
4879
4880
4881
4882
4883
4884
4885
4886
4887
4888
4889
4890
4891
4892
4893
4894
4895
4896
4897
4898
4899
4900
4901
4902
4903
4904
4905
4906
4907
4908
4909
4910
4911
4912
4913
4914
4915
4916
4917
4918
4919
4920
4921
4922
4923
4924
4925
4926
4927
4928
4929
4930
4931
4932
4933
4934
4935
4936
4937
4938
4939
4940
4941
4942
4943
4944
4945
4946
4947
4948
4949
4950
4951
4952
4953
4954
4955
....
5855
5856
5857
5858
5859
5860
5861
5862
5863
5864
5865
5866
5867
5868
5869
5870
5871
5872
5873
5874
5875
....
6316
6317
6318
6319
6320
6321
6322
6323
6324
6325
6326
6327
6328
6329
6330
6331
6332
6333
6334
6335
6336
....
7730
7731
7732
7733
7734
7735
7736
7737
7738

7739
7740
7741
7742
7743
7744
7745
7746
7747

7748

7749
7750
7751
7752
7753
7754
7755
7756
      pC = pC->GetNext();
    }
}

void CandidateVectorCoveragesList::MarkRasterCoverage(wxString & table,
                                                      wxString & geometry)
{
// marking some table related to a Raster Coverage
  CandidateVectorCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetTableName().CmpNoCase(table) == 0
          && pC->GetGeometryColumn().CmpNoCase(geometry) == 0)
        {
          pC->MarkRasterCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

void CandidateVectorCoveragesList::MarkTopoGeoCoverage(wxString & table,
                                                       wxString & geometry)
{
// marking some table related to Topology-Geometry
  CandidateVectorCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetTableName().CmpNoCase(table) == 0
          && pC->GetGeometryColumn().CmpNoCase(geometry) == 0)
        {
          pC->MarkTopoGeoCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

void CandidateVectorCoveragesList::MarkTopoNetCoverage(wxString & table,
                                                       wxString & geometry)
{
// marking some table related to Topology-Network
  CandidateVectorCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetTableName().CmpNoCase(table) == 0
          && pC->GetGeometryColumn().CmpNoCase(geometry) == 0)
        {
          pC->MarkTopoNetCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

CandidateVectorCoveragesList *MyFrame::FindUnregisteredVectorCoverages()
{
// will retrieve all not yet registered GeoTables
  CandidateVectorCoveragesList *list = new CandidateVectorCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from GEOMETRY_COLUMNS
  sql =
    "SELECT f_table_name, f_geometry_column, srid, geometry_type "
    "FROM geometry_columns ORDER BY f_table_name, f_geometry_column";
  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          int srid = atoi(value);
          value = results[(i * columns) + 3];
          int gtype = atoi(value);
          wxString type = wxT("***  UNKNOWN  ***");
          switch (gtype)
            {
              case 0:
              case 1000:
              case 2000:
              case 3000:
                type = wxT("GEOMETRY");
                break;
              case 1:
              case 1001:
              case 2001:
              case 3001:
                type = wxT("POINT");
                break;
              case 2:
              case 1002:
              case 2002:
              case 3002:
                type = wxT("LINESTRING");
                break;
              case 3:
              case 1003:
              case 2003:
              case 3003:
                type = wxT("POLYGON");
                break;
              case 4:
              case 1004:
              case 2004:
              case 3004:
                type = wxT("MULTIPOINT");
                break;
              case 5:
              case 1005:
              case 2005:
              case 3005:
                type = wxT("MULTILINESTRING");
                break;
              case 6:
              case 1006:
              case 2006:
              case 3006:
                type = wxT("MULTIPOLYGON");
                break;
              case 7:
              case 1007:
              case 2007:
              case 3007:
                type = wxT("GEOMETRYCOLLECTION");
                break;
              default:
                type = wxT("***  UNKNOWN  ***");
                break;
            };
          switch (gtype)
            {
              case 0:
              case 1:
              case 2:
              case 3:
              case 4:
              case 5:
              case 6:
              case 7:
                type += wxT(" XY");
                break;
              case 1000:
              case 1001:
              case 1002:
              case 1003:
              case 1004:
              case 1005:
              case 1006:
              case 1007:
                type += wxT(" XYZ");
                break;
              case 2000:
              case 2001:
              case 2002:
              case 2003:
              case 2004:
              case 2005:
              case 2006:
              case 2007:
                type += wxT(" XYM");
                break;
              case 3000:
              case 3001:
              case 3002:
              case 3003:
              case 3004:
              case 3005:
              case 3006:
              case 3007:
                type += wxT(" XYZM");
                break;
            };
          list->Add(table, geometry, srid, type);
        }
    }
  sqlite3_free_table(results);

// marking any already registered Vector Coverage
  sql = "SELECT f_table_name, f_geometry_column FROM vector_coverages "
    "WHERE f_table_name IS NOT NULL AND f_geometry_column IS NOT NULL";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          list->MarkVectorCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);

// marking any table related to some Raster Coverage
  sql = "SELECT coverage_name FROM raster_coverages";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value) + wxT("_sections");
          wxString geometry = wxT("geometry");
          list->MarkRasterCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_tiles");
          list->MarkRasterCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);

// marking any table related to some Topology-Geometry
  sql = "SELECT topology_name FROM topologies";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value) + wxT("_face");
          wxString geometry = wxT("mbr");
          list->MarkTopoGeoCoverage(table, geometry);
          geometry = wxT("geom");
          table = wxString::FromUTF8(value) + wxT("_node");
          list->MarkTopoGeoCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_edge");
          list->MarkTopoGeoCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_seeds");
          list->MarkTopoGeoCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);

// marking any table related to some Topology-Network
  sql = "SELECT network_name FROM networks";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value) + wxT("_link");
          wxString geometry = wxT("geometry");
          list->MarkTopoNetCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_node");
          list->MarkTopoNetCoverage(table, geometry);
          table = wxString::FromUTF8(value) + wxT("_seeds");
          list->MarkTopoNetCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);
  return list;
}

CandidateSpatialViewCoveragesList::~CandidateSpatialViewCoveragesList()
{
// destructor
  CandidateSpatialViewCoverage *pC;
  CandidateSpatialViewCoverage *pCn;
  pC = First;
  while (pC != NULL)
    {
      pCn = pC->GetNext();
      delete pC;
      pC = pCn;
    }
}

void CandidateSpatialViewCoveragesList::Add(wxString & view_name,
                                            wxString & geometry, int srid,
                                            wxString & type)
{
// inserting a new candidate Vector Coverage - SpatialView
  CandidateSpatialViewCoverage *pC =
    new CandidateSpatialViewCoverage(view_name, geometry, srid, type);
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void CandidateSpatialViewCoveragesList::MarkVectorCoverage(wxString & view,
                                                           wxString & geometry)
{
// marking an already registered Vector Coverage
  CandidateSpatialViewCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetViewName().CmpNoCase(view) == 0
          && pC->GetViewGeometry().CmpNoCase(geometry) == 0)
        {
          pC->MarkVectorCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

CandidateSpatialViewCoveragesList
  * MyFrame::FindUnregisteredSpatialViewCoverages()
{
// will retrieve all not yet registered SpatialViews
  CandidateSpatialViewCoveragesList *list =
    new CandidateSpatialViewCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from VIEWS_GEOMETRY_COLUMNS
  sql =
    "SELECT v.view_name, v.view_geometry, g.srid, g.geometry_type "
    "FROM views_geometry_columns AS v "
    "JOIN geometry_columns AS g ON (Lower(v.f_table_name) = Lower(g.f_table_name) "
    "AND Lower(v.f_geometry_column) = Lower(g.f_geometry_column)) "
    "ORDER BY v.view_name, v.view_geometry";
  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString view = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          int srid = atoi(value);
          value = results[(i * columns) + 3];
          int gtype = atoi(value);
          wxString type = wxT("***  UNKNOWN  ***");
          switch (gtype)
            {
              case 0:
              case 1000:
              case 2000:
              case 3000:
                type = wxT("GEOMETRY");
                break;
              case 1:
              case 1001:
              case 2001:
              case 3001:
                type = wxT("POINT");
                break;
              case 2:
              case 1002:
              case 2002:
              case 3002:
                type = wxT("LINESTRING");
                break;
              case 3:
              case 1003:
              case 2003:
              case 3003:
                type = wxT("POLYGON");
                break;
              case 4:
              case 1004:
              case 2004:
              case 3004:
                type = wxT("MULTIPOINT");
                break;
              case 5:
              case 1005:
              case 2005:
              case 3005:
                type = wxT("MULTILINESTRING");
                break;
              case 6:
              case 1006:
              case 2006:
              case 3006:
                type = wxT("MULTIPOLYGON");
                break;
              case 7:
              case 1007:
              case 2007:
              case 3007:
                type = wxT("GEOMETRYCOLLECTION");
                break;
              default:
                type = wxT("***  UNKNOWN  ***");
                break;
            };
          switch (gtype)
            {
              case 0:
              case 1:
              case 2:
              case 3:
              case 4:
              case 5:
              case 6:
              case 7:
                type += wxT(" XY");
                break;
              case 1000:
              case 1001:
              case 1002:
              case 1003:
              case 1004:
              case 1005:
              case 1006:
              case 1007:
                type += wxT(" XYZ");
                break;
              case 2000:
              case 2001:
              case 2002:
              case 2003:
              case 2004:
              case 2005:
              case 2006:
              case 2007:
                type += wxT(" XYM");
                break;
              case 3000:
              case 3001:
              case 3002:
              case 3003:
              case 3004:
              case 3005:
              case 3006:
              case 3007:
                type += wxT(" XYZM");
                break;
            };
          list->Add(view, geometry, srid, type);
        }
    }
  sqlite3_free_table(results);

// marking any already registered SpatialView Coverage
  sql = "SELECT view_name, view_geometry FROM vector_coverages "
    "WHERE view_name IS NOT NULL AND view_geometry IS NOT NULL";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString table = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          list->MarkVectorCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);
  return list;
}

CandidateVirtualShapeCoveragesList::~CandidateVirtualShapeCoveragesList()
{
// destructor
  CandidateVirtualShapeCoverage *pC;
  CandidateVirtualShapeCoverage *pCn;
  pC = First;
  while (pC != NULL)
    {
      pCn = pC->GetNext();
      delete pC;
      pC = pCn;
    }
}

void CandidateVirtualShapeCoveragesList::Add(wxString & virt_name,
                                             wxString & geometry, int srid,
                                             wxString & type)
{
// inserting a new candidate Vector Coverage - VirtualShape
  CandidateVirtualShapeCoverage *pC =
    new CandidateVirtualShapeCoverage(virt_name, geometry, srid, type);
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void CandidateVirtualShapeCoveragesList::MarkVectorCoverage(wxString & table,
                                                            wxString & geometry)
{
// marking an already registered Vector Coverage
  CandidateVirtualShapeCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetVirtName().CmpNoCase(table) == 0
          && pC->GetVirtGeometry().CmpNoCase(geometry) == 0)
        {
          pC->MarkVectorCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

CandidateVirtualShapeCoveragesList
  * MyFrame::FindUnregisteredVirtualShapeCoverages()
{
// will retrieve all not yet registered VirtualShape
  CandidateVirtualShapeCoveragesList *list =
    new CandidateVirtualShapeCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from VIERTS_GEOMETRY_COLUMNS
  sql =
    "SELECT virt_name, virt_geometry, srid, geometry_type "
    "FROM virts_geometry_columns AS v " "ORDER BY virt_name, v.virt_geometry";
  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
                break;
            };
          list->Add(table, geometry, srid, type);
        }
    }
  sqlite3_free_table(results);

// marking any already registered VirtualShape Coverage
  sql = "SELECT virt_name, virt_geometry FROM vector_coverages "
    "WHERE virt_name IS NOT NULL AND virt_geometry IS NOT NULL";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
          wxString table = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          wxString geometry = wxString::FromUTF8(value);
          list->MarkVectorCoverage(table, geometry);
        }
    }
  sqlite3_free_table(results);
  return list;
}



CandidateTopoGeoCoveragesList::~CandidateTopoGeoCoveragesList()
{
// destructor
  CandidateTopoGeoCoverage *pC;
  CandidateTopoGeoCoverage *pCn;
  pC = First;
  while (pC != NULL)
    {
      pCn = pC->GetNext();
      delete pC;
      pC = pCn;
    }
}

void CandidateTopoGeoCoveragesList::Add(wxString & topology, int srid,
                                        wxString & dimensions, double tolerance)
{
// inserting a new candidate TopoGeo Coverage
  CandidateTopoGeoCoverage *pC =
    new CandidateTopoGeoCoverage(topology, srid, dimensions, tolerance);
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void CandidateTopoGeoCoveragesList::MarkVectorCoverage(wxString & topology)
{
// marking an already registered TopoGeo Coverage
  CandidateTopoGeoCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetTopologyName().CmpNoCase(topology) == 0)
        {
          pC->MarkVectorCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

CandidateTopoGeoCoveragesList *MyFrame::FindUnregisteredTopoGeoCoverages()
{
// will retrieve all not yet registered Topology-Geometries
  CandidateTopoGeoCoveragesList *list = new CandidateTopoGeoCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from TOPOLOGIES
  sql =
    "SELECT topology_name, srid, has_z, tolerance "
    "FROM topologies ORDER BY topology_name";
  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString topology = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          int srid = atoi(value);
          wxString dimensions = wxT("2D");
          value = results[(i * columns) + 2];
          if (atoi(value))
            dimensions = wxT("3D");
          value = results[(i * columns) + 3];
          double tolerance = atof(value);
          list->Add(topology, srid, dimensions, tolerance);
        }
    }
  sqlite3_free_table(results);

// marking any already registered Vector Coverage
  sql = "SELECT topology_name FROM vector_coverages "
    "WHERE topology_name IS NOT NULL";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
................................................................................
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];



          wxString topology = wxString::FromUTF8(value);

          list->MarkVectorCoverage(topology);
        }
    }
  sqlite3_free_table(results);
  return list;
}

bool MyFrame::DoRegisterVectorCoverage(wxString & name, wxString & table,
                                       wxString & geometry, wxString & title,
                                       wxString & abstract, bool isQueryable,
                                       bool isEditable)
{
//
// attempting to register a Vector Coverage - SpatialTable
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql = "SELECT SE_RegisterVectorCoverage(?, ?, ?, ?, ?, ?, ?)";
  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((name.Len() * 4) + 1);
  strcpy(dummy, name.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((table.Len() * 4) + 1);
  strcpy(dummy, table.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((geometry.Len() * 4) + 1);
  strcpy(dummy, geometry.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((title.Len() * 4) + 1);
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 5, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (isQueryable == false)
    sqlite3_bind_int(stmt, 6, 0);
  else
    sqlite3_bind_int(stmt, 6, 1);
  if (isEditable == false)
    sqlite3_bind_int(stmt, 7, 0);
  else
    sqlite3_bind_int(stmt, 7, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
    }
  sqlite3_finalize(stmt);
  return true;
}

bool MyFrame::DoRegisterSpatialViewCoverage(wxString & name, wxString & view,
                                            wxString & geometry,
                                            wxString & title,
                                            wxString & abstract,
                                            bool isQueryable, bool isEditable)
{
//
// attempting to register a Vector Coverage - SpatialView
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql =
    "SELECT SE_RegisterSpatialViewCoverage(?, ?, ?, ?, ?, ?, ?)";
  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((name.Len() * 4) + 1);
  strcpy(dummy, name.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((view.Len() * 4) + 1);
  strcpy(dummy, view.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((geometry.Len() * 4) + 1);
  strcpy(dummy, geometry.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((title.Len() * 4) + 1);
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 5, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (isQueryable == false)
    sqlite3_bind_int(stmt, 6, 0);
  else
    sqlite3_bind_int(stmt, 6, 1);
  if (isEditable == false)
    sqlite3_bind_int(stmt, 7, 0);
  else
    sqlite3_bind_int(stmt, 7, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
    }
  sqlite3_finalize(stmt);
  return true;
}

bool MyFrame::DoRegisterVirtualShapeCoverage(wxString & name, wxString & table,
                                             wxString & geometry,
                                             wxString & title,
                                             wxString & abstract,
                                             bool isQueryable)
{
//
// attempting to register a Vector Coverage - VirtualShape
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql = "SELECT SE_RegisterVirtualShapeCoverage(?, ?, ?, ?, ?, ?)";
  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
................................................................................
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 5, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (isQueryable == false)
    sqlite3_bind_int(stmt, 6, 0);
  else
    sqlite3_bind_int(stmt, 6, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
    }
  sqlite3_finalize(stmt);
  return true;
}

bool MyFrame::DoRegisterTopoGeoCoverage(wxString & name, wxString & topology,
                                        wxString & title, wxString & abstract,
                                        bool isQueryable, bool isEditable)
{
//
// attempting to register a TopoGeo Coverage
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql = "SELECT SE_RegisterTopoGeoCoverage(?, ?, ?, ?, ?, ?)";
  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((name.Len() * 4) + 1);
  strcpy(dummy, name.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((topology.Len() * 4) + 1);
  strcpy(dummy, topology.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((title.Len() * 4) + 1);
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (isQueryable == false)
    sqlite3_bind_int(stmt, 5, 0);
  else
    sqlite3_bind_int(stmt, 5, 1);
  if (isEditable == false)
    sqlite3_bind_int(stmt, 6, 0);
  else
    sqlite3_bind_int(stmt, 6, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
    }
  sqlite3_finalize(stmt);
  return true;
}

CandidateTopoNetCoveragesList::~CandidateTopoNetCoveragesList()
{
// destructor
  CandidateTopoNetCoverage *pC;
  CandidateTopoNetCoverage *pCn;
  pC = First;
  while (pC != NULL)
    {
      pCn = pC->GetNext();
      delete pC;
      pC = pCn;
    }
}

void CandidateTopoNetCoveragesList::Add(wxString & network, int srid,
                                        wxString & dimensions)
{
// inserting a new candidate TopoNet Coverage
  CandidateTopoNetCoverage *pC =
    new CandidateTopoNetCoverage(network, srid, dimensions);
  if (First == NULL)
    First = pC;
  if (Last != NULL)
    Last->SetNext(pC);
  Last = pC;
}

void CandidateTopoNetCoveragesList::MarkVectorCoverage(wxString & network)
{
// marking an already registered TopoNet Coverage
  CandidateTopoNetCoverage *pC;
  pC = First;
  while (pC != NULL)
    {
      if (pC->GetNetworkName().CmpNoCase(network) == 0)
        {
          pC->MarkVectorCoverage();
          break;
        }
      pC = pC->GetNext();
    }
}

CandidateTopoNetCoveragesList *MyFrame::FindUnregisteredTopoNetCoverages()
{
// will retrieve all not yet registered Topology-Networks
  CandidateTopoNetCoveragesList *list = new CandidateTopoNetCoveragesList();
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  const char *sql;

// retrieving all entries from NETWORKS
  sql = "SELECT network_name, srid, has_z FROM networks ORDER BY network_name";
  int ret = sqlite3_get_table(SqliteHandle, sql, &results,
                              &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString topology = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          int srid = atoi(value);
          wxString dimensions = wxT("2D");
          value = results[(i * columns) + 2];
          if (atoi(value))
            dimensions = wxT("3D");
          list->Add(topology, srid, dimensions);
        }
    }
  sqlite3_free_table(results);

// marking any already registered Vector Coverage
  sql = "SELECT network_name FROM vector_coverages "
    "WHERE network_name IS NOT NULL";
  ret = sqlite3_get_table(SqliteHandle, sql, &results,
                          &rows, &columns, &errMsg);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return list;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          wxString topology = wxString::FromUTF8(value);
          list->MarkVectorCoverage(topology);
        }
    }
  sqlite3_free_table(results);
  return list;
}

bool MyFrame::DoRegisterTopoNetCoverage(wxString & name, wxString & network,
                                        wxString & title, wxString & abstract,
                                        bool isQueryable, bool isEditable)
{
//
// attempting to register a TopoNet Coverage
//
  char *dummy;
  sqlite3_stmt *stmt = NULL;
  const char *sql = "SELECT SE_RegisterTopoNetCoverage(?, ?, ?, ?, ?, ?)";
  int ret = sqlite3_prepare_v2(SqliteHandle, sql, strlen(sql),
                               &stmt, NULL);
  if (ret != SQLITE_OK)
    return false;

  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((name.Len() * 4) + 1);
  strcpy(dummy, name.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((network.Len() * 4) + 1);
  strcpy(dummy, network.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((title.Len() * 4) + 1);
  strcpy(dummy, title.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((abstract.Len() * 4) + 1);
  strcpy(dummy, abstract.ToUTF8());
  sqlite3_bind_text(stmt, 4, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (isQueryable == false)
    sqlite3_bind_int(stmt, 5, 0);
  else
    sqlite3_bind_int(stmt, 5, 1);
  if (isEditable == false)
    sqlite3_bind_int(stmt, 6, 0);
  else
    sqlite3_bind_int(stmt, 6, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      sqlite3_finalize(stmt);
      return false;
................................................................................

bool VectorCoverageStylesDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorCoverageStyles(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................
bool VectorRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredVectorCoverages();
  if (wxDialog::Create(parent, wxID_ANY, wxT("Register SpatialTable Coverage"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
................................................................................
// centers the dialog window
  Centre();
  int count = 0;
  CandidateVectorCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true
          && pC->IsTopoGeo() != true && pC->IsTopoNet() != true)
        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
................................................................................
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT
                                         ("Candidate SpatialTable Coverages"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateVectorCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true
          && pC->IsTopoGeo() != true && pC->IsTopoNet() != true)
        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 4, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("f_table_name"));
  GridCtrl->SetColLabelValue(1, wxT("f_geometry_column"));
  GridCtrl->SetColLabelValue(2, wxT("SRID"));
................................................................................
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true && pC->IsRasterCoverage() != true
          && pC->IsTopoGeo() != true && pC->IsTopoNet() != true)
        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetTableName());
          GridCtrl->SetCellValue(count, 1, pC->GetGeometryColumn());
          sprintf(dummy, "%d", pC->GetSrid());
................................................................................
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fifth row: queryable / editable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  wxRadioBox *editableBox = new wxRadioBox(this, ID_VECTOR_EDITABLE,
                                           wxT("Is &Editable"),
                                           wxDefaultPosition,
                                           wxDefaultSize, 2,
                                           yesno, 1,
                                           wxRA_SPECIFY_ROWS);
  radioSizer->Add(editableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  editableBox->SetSelection(1);

// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
................................................................................
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxRadioBox *editableBox = (wxRadioBox *) FindWindow(ID_VECTOR_EDITABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
................................................................................
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  if (editableBox->GetSelection() == 1)
    Editable = true;
  else
    Editable = false;
  wxDialog::EndModal(wxID_OK);
}

bool SpatialViewRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredSpatialViewCoverages();
  if (wxDialog::Create(parent, wxID_ANY, wxT("Register SpatialView Coverage"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  CandidateSpatialViewCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
      wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
      nameCtrl->Enable(false);
      wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
      titleCtrl->Enable(false);
      wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
      absCtrl->Enable(false);
      wxMessageBox(wxT
                   ("There are no possible Candidates to be eventually registered"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
    }
  return true;
}

void SpatialViewRegisterDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT("Candidate SpatialView Coverages"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateSpatialViewCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 4, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("view_name"));
  GridCtrl->SetColLabelValue(1, wxT("view_geometry"));
  GridCtrl->SetColLabelValue(2, wxT("SRID"));
  GridCtrl->SetColLabelValue(3, wxT("GeometryType"));
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true)
        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetViewName());
          GridCtrl->SetCellValue(count, 1, pC->GetViewGeometry());
          sprintf(dummy, "%d", pC->GetSrid());
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetCellValue(count, 2, cell);
          GridCtrl->SetCellAlignment(count, 2, wxALIGN_RIGHT, wxALIGN_CENTRE);
          GridCtrl->SetCellValue(count, 3, pC->GetGeometryType());
          count++;
        }
      pC = pC->GetNext();
    }
  GridCtrl->SetRowLabelSize(wxGRID_AUTOSIZE);
  GridCtrl->AutoSize();
  GridCtrl->EnableEditing(false);
  gridSizer->Add(GridCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_VECTOR_COVERAGE, wxT(""),
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_VECTOR_TITLE, wxT(""),
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fifth row: queryable / editable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  wxRadioBox *editableBox = new wxRadioBox(this, ID_VECTOR_EDITABLE,
                                           wxT("Is &Editable"),
                                           wxDefaultPosition,
                                           wxDefaultSize, 2,
                                           yesno, 1,
                                           wxRA_SPECIFY_ROWS);
  radioSizer->Add(editableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  editableBox->SetSelection(1);

// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & SpatialViewRegisterDialog::OnOk);
}

void SpatialViewRegisterDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxRadioBox *editableBox = (wxRadioBox *) FindWindow(ID_VECTOR_EDITABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  int selCount = 0;
  for (int i = 0; i < GridCtrl->GetNumberRows(); i++)
    {
      if (GridCtrl->IsInSelection(i, 0) == true)
        {
          ViewName = GridCtrl->GetCellValue(i, 0);
          ViewGeometry = GridCtrl->GetCellValue(i, 1);
          selCount++;
        }
    }
  if (selCount < 1)
    {
      wxMessageBox(wxT("You must select a Candidate to be registered !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (selCount > 1)
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  if (editableBox->GetSelection() == 1)
    Editable = true;
  else
    Editable = false;
  wxDialog::EndModal(wxID_OK);
}

bool VirtualShapeRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredVirtualShapeCoverages();
  if (wxDialog::Create(parent, wxID_ANY, wxT("Register VirtualShape Coverage"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  CandidateVirtualShapeCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
      wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
      nameCtrl->Enable(false);
      wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
      titleCtrl->Enable(false);
      wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
      absCtrl->Enable(false);
      wxMessageBox(wxT
                   ("There are no possible Candidates to be eventually registered"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
    }
  return true;
}

void VirtualShapeRegisterDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT
                                         ("Candidate VirtualShape Coverages"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateVirtualShapeCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 4, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("virt_name"));
  GridCtrl->SetColLabelValue(1, wxT("virt_geometry"));
  GridCtrl->SetColLabelValue(2, wxT("SRID"));
  GridCtrl->SetColLabelValue(3, wxT("GeometryType"));
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true)
        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetVirtName());
          GridCtrl->SetCellValue(count, 1, pC->GetVirtGeometry());
          sprintf(dummy, "%d", pC->GetSrid());
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetCellValue(count, 2, cell);
          GridCtrl->SetCellAlignment(count, 2, wxALIGN_RIGHT, wxALIGN_CENTRE);
          GridCtrl->SetCellValue(count, 3, pC->GetGeometryType());
          count++;
        }
      pC = pC->GetNext();
    }
  GridCtrl->SetRowLabelSize(wxGRID_AUTOSIZE);
  GridCtrl->AutoSize();
  GridCtrl->EnableEditing(false);
  gridSizer->Add(GridCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_VECTOR_COVERAGE, wxT(""),
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_VECTOR_TITLE, wxT(""),
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fifth row: queryable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);

// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & VirtualShapeRegisterDialog::OnOk);
}

void VirtualShapeRegisterDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  int selCount = 0;
  for (int i = 0; i < GridCtrl->GetNumberRows(); i++)
    {
      if (GridCtrl->IsInSelection(i, 0) == true)
        {
          VirtName = GridCtrl->GetCellValue(i, 0);
          VirtGeometry = GridCtrl->GetCellValue(i, 1);
          selCount++;
        }
    }
  if (selCount < 1)
    {
      wxMessageBox(wxT("You must select a Candidate to be registered !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (selCount > 1)
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  wxDialog::EndModal(wxID_OK);
}

bool TopoGeoRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredTopoGeoCoverages();
  if (wxDialog::Create(parent, wxID_ANY,
                       wxT("Register Topology-Geometry Coverage")) == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  CandidateTopoGeoCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
      wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
      nameCtrl->Enable(false);
      wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
      titleCtrl->Enable(false);
      wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
      absCtrl->Enable(false);
      wxMessageBox(wxT
                   ("There are no possible Candidates to be eventually registered"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
    }
  return true;
}

void TopoGeoRegisterDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT
                                         ("Candidate Topology-Geometry Coverages"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateTopoGeoCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 4, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("topology_name"));
  GridCtrl->SetColLabelValue(1, wxT("SRID"));
  GridCtrl->SetColLabelValue(2, wxT("Dimensions"));
  GridCtrl->SetColLabelValue(3, wxT("Tolerance"));
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true)
        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetTopologyName());
          sprintf(dummy, "%d", pC->GetSrid());
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetCellValue(count, 1, cell);
          GridCtrl->SetCellAlignment(count, 1, wxALIGN_RIGHT);
          GridCtrl->SetCellValue(count, 2, pC->GetDimensions());
          sprintf(dummy, "%1.9f", pC->GetTolerance());
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetCellValue(count, 3, cell);
          GridCtrl->SetCellAlignment(count, 3, wxALIGN_RIGHT);
          count++;
        }
      pC = pC->GetNext();
    }
  GridCtrl->SetRowLabelSize(wxGRID_AUTOSIZE);
  GridCtrl->AutoSize();
  GridCtrl->EnableEditing(false);
  gridSizer->Add(GridCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_VECTOR_COVERAGE, wxT(""),
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_VECTOR_TITLE, wxT(""),
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fifth row: queryable / editable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  wxRadioBox *editableBox = new wxRadioBox(this, ID_VECTOR_EDITABLE,
                                           wxT("Is &Editable"),
                                           wxDefaultPosition,
                                           wxDefaultSize, 2,
                                           yesno, 1,
                                           wxRA_SPECIFY_ROWS);
  radioSizer->Add(editableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  editableBox->SetSelection(1);

// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & TopoGeoRegisterDialog::OnOk);
}

void TopoGeoRegisterDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxRadioBox *editableBox = (wxRadioBox *) FindWindow(ID_VECTOR_EDITABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  int selCount = 0;
  for (int i = 0; i < GridCtrl->GetNumberRows(); i++)
    {
      if (GridCtrl->IsInSelection(i, 0) == true)
        {
          TopologyName = GridCtrl->GetCellValue(i, 0);
          selCount++;
        }
    }
  if (selCount < 1)
    {
      wxMessageBox(wxT("You must select a Candidate to be registered !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (selCount > 1)
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  if (editableBox->GetSelection() == 1)
    Editable = true;
  else
    Editable = false;
  wxDialog::EndModal(wxID_OK);
}

bool TopoNetRegisterDialog::Create(MyFrame * parent)
{
//
// creating the dialog
//
  MainFrame = parent;
  List = MainFrame->FindUnregisteredTopoNetCoverages();
  if (wxDialog::Create(parent, wxID_ANY,
                       wxT("Register Topology-Network Coverage")) == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  CandidateTopoNetCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  if (count == 0)
    {
      wxButton *ok = (wxButton *) FindWindow(wxID_OK);
      ok->Enable(false);
      wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
      nameCtrl->Enable(false);
      wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
      titleCtrl->Enable(false);
      wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
      absCtrl->Enable(false);
      wxMessageBox(wxT
                   ("There are no possible Candidates to be eventually registered"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
    }
  return true;
}

void TopoNetRegisterDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// a GRID to show results
  wxBoxSizer *gridBoxSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(gridBoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *gridBox = new wxStaticBox(this, wxID_STATIC,
                                         wxT
                                         ("Candidate Topology-Network Coverages"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *GridSizer = new wxStaticBoxSizer(gridBox, wxVERTICAL);
  gridBoxSizer->Add(GridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
  wxBoxSizer *gridSizer = new wxBoxSizer(wxHORIZONTAL);
  GridSizer->Add(gridSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  GridCtrl =
    new wxGrid(this, ID_VECTOR_GRID, wxDefaultPosition, wxSize(640, 200));
  int count = 0;
  CandidateTopoNetCoverage *pC = List->GetFirst();
  while (pC)
    {
      // counting how many lines are there
      if (pC->IsVectorCoverage() != true)
        count++;
      pC = pC->GetNext();
    }
  GridCtrl->CreateGrid(count, 3, wxGrid::wxGridSelectRows);
  GridCtrl->SetColLabelValue(0, wxT("network_name"));
  GridCtrl->SetColLabelValue(1, wxT("SRID"));
  GridCtrl->SetColLabelValue(2, wxT("Dimensions"));
  count = 0;
  char dummy[1024];
  wxString cell;
  pC = List->GetFirst();
  while (pC)
    {
      // feeding grid rows
      if (pC->IsVectorCoverage() != true)
        {
          sprintf(dummy, "%d", count + 1);
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetRowLabelValue(count, cell);
          GridCtrl->SetCellValue(count, 0, pC->GetNetworkName());
          sprintf(dummy, "%d", pC->GetSrid());
          cell = wxString::FromUTF8(dummy);
          GridCtrl->SetCellValue(count, 1, cell);
          GridCtrl->SetCellAlignment(count, 1, wxALIGN_RIGHT);
          GridCtrl->SetCellValue(count, 2, pC->GetDimensions());
          count++;
        }
      pC = pC->GetNext();
    }
  GridCtrl->SetRowLabelSize(wxGRID_AUTOSIZE);
  GridCtrl->AutoSize();
  GridCtrl->EnableEditing(false);
  gridSizer->Add(GridCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_VECTOR_COVERAGE, wxT(""),
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_VECTOR_TITLE, wxT(""),
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, wxT(""),
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fifth row: queryable / editable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  queryableBox->SetSelection(1);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  wxRadioBox *editableBox = new wxRadioBox(this, ID_VECTOR_EDITABLE,
                                           wxT("Is &Editable"),
                                           wxDefaultPosition,
                                           wxDefaultSize, 2,
                                           yesno, 1,
                                           wxRA_SPECIFY_ROWS);
  radioSizer->Add(editableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  editableBox->SetSelection(1);

// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&Register"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & TopoNetRegisterDialog::OnOk);
}

void TopoNetRegisterDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxRadioBox *editableBox = (wxRadioBox *) FindWindow(ID_VECTOR_EDITABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  int selCount = 0;
  for (int i = 0; i < GridCtrl->GetNumberRows(); i++)
    {
      if (GridCtrl->IsInSelection(i, 0) == true)
        {
          NetworkName = GridCtrl->GetCellValue(i, 0);
          selCount++;
        }
    }
  if (selCount < 1)
    {
      wxMessageBox(wxT("You must select a Candidate to be registered !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (selCount > 1)
    {
      wxString msg =
        wxT("You must select just a single Candidate to be registered !!!\n");
      msg += wxT("Multiple selection is not supported");
      wxMessageBox(msg, wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    Queryable = true;
  else
    Queryable = false;
  if (editableBox->GetSelection() == 1)
    Editable = true;
  else
    Editable = false;
  wxDialog::EndModal(wxID_OK);
}

bool VectorInfosDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  if (DoReadCoverage() == false)
    return false;
  if (wxDialog::Create(parent, wxID_ANY, wxT("Edit Vector Coverage Infos"))
      == false)
    return false;
// populates individual controls
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  int count = 0;
  return true;
}

void VectorInfosDialog::CreateControls()
{
//
// creating individual control and setting initial values
//
  wxBoxSizer *topSizer = new wxBoxSizer(wxVERTICAL);
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// first row: the Coverage Name
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(nameSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *nameLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Coverage Name:"));
  nameSizer->Add(nameLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *nameCtrl = new wxTextCtrl(this, ID_VECTOR_COVERAGE, CoverageName,
                                        wxDefaultPosition, wxSize(550, 22));
  nameSizer->Add(nameCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// second row: the Coverage Title
  wxBoxSizer *titleSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(titleSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *titleLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Title:"));
  titleSizer->Add(titleLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *titleCtrl = new wxTextCtrl(this, ID_VECTOR_TITLE, Title,
                                         wxDefaultPosition, wxSize(550, 22));
  titleSizer->Add(titleCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// third row: the Coverage Abstract
  wxBoxSizer *absSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(absSizer, 0, wxALIGN_RIGHT | wxALL, 0);
  wxStaticText *absLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Abstract:"));
  absSizer->Add(absLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *abstractCtrl = new wxTextCtrl(this, ID_VECTOR_ABSTRACT, Abstract,
                                            wxDefaultPosition, wxSize(550, 60),
                                            wxTE_MULTILINE);
  absSizer->Add(abstractCtrl, 0, wxALIGN_RIGHT | wxALL, 5);
// fourth row: queryable / editable
  wxBoxSizer *radioSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(radioSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString yesno[2];
  yesno[0] = wxT("&No");
  yesno[1] = wxT("&Yes");
  wxRadioBox *queryableBox = new wxRadioBox(this, ID_VECTOR_QUERYABLE,
                                            wxT("Is &Queryable"),
                                            wxDefaultPosition,
                                            wxDefaultSize, 2,
                                            yesno, 1,
                                            wxRA_SPECIFY_ROWS);
  radioSizer->Add(queryableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  if (IsQueryable == false)
    queryableBox->SetSelection(0);
  else
    queryableBox->SetSelection(1);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  radioSizer->AddSpacer(25);
  wxRadioBox *editableBox = new wxRadioBox(this, ID_VECTOR_EDITABLE,
                                           wxT("Is &Editable"),
                                           wxDefaultPosition,
                                           wxDefaultSize, 2,
                                           yesno, 1,
                                           wxRA_SPECIFY_ROWS);
  radioSizer->Add(editableBox, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  if (IsEditable == false)
    editableBox->SetSelection(0);
  else
    editableBox->SetSelection(1);
// buttons
  wxBoxSizer *btnBox = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(btnBox, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxButton *ok = new wxButton(this, wxID_OK, wxT("&OK"));
  btnBox->Add(ok, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxButton *cancel = new wxButton(this, wxID_CANCEL, wxT("&Cancel"));
  btnBox->Add(cancel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// appends event handler for OK button
  Connect(wxID_OK, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & VectorInfosDialog::OnOk);
}

bool VectorInfosDialog::DoReadCoverage()
{
// will retrieve to read the given Coverage definition
  int i;
  char **results;
  int rows;
  int columns;
  char *errMsg = NULL;
  char *value;
  char *sql;
  char cvg[1024];
  int count = 0;

  wxCharBuffer buffer = CoverageName.ToUTF8();
  sprintf(cvg, "%s", buffer.data());
  sql =
    sqlite3_mprintf
    ("SELECT title, abstract, is_queryable, is_editable "
     "FROM vector_coverages WHERE Lower(coverage_name) = Lower(%Q)", cvg);
  int ret = sqlite3_get_table(MainFrame->GetSqlite(), sql, &results,
                              &rows, &columns, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  if (rows < 1)
    ;
  else
    {
      for (i = 1; i <= rows; i++)
        {
          value = results[(i * columns) + 0];
          Title = wxString::FromUTF8(value);
          value = results[(i * columns) + 1];
          Abstract = wxString::FromUTF8(value);
          value = results[(i * columns) + 2];
          if (atoi(value) == 0)
            IsQueryable = false;
          else
            IsQueryable = true;
          value = results[(i * columns) + 3];
          if (atoi(value) == 0)
            IsEditable = false;
          else
            IsEditable = true;
          count++;
        }
    }
  sqlite3_free_table(results);
  if (count == 1)
    return true;
  return false;
}

void VectorInfosDialog::DoUpdateCoverage()
{
// will retrieve to update the given Coverage definition
  int ret;
  sqlite3_stmt *stmt = NULL;
  char *dummy;
  const char *sql = "SELECT SE_SetVectorCoverageInfos(?, ?, ?, ?, ?)";
  ret =
    sqlite3_prepare_v2(MainFrame->GetSqlite(), sql, strlen(sql), &stmt, NULL);
  if (ret != SQLITE_OK)
    {
      const char *msg = sqlite3_errmsg(MainFrame->GetSqlite());
      wxMessageBox(wxT("ERROR - SetVectorCoverageInfos: ") +
                   wxString::FromUTF8(msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      return;
    }
  sqlite3_reset(stmt);
  sqlite3_clear_bindings(stmt);
  dummy = (char *) malloc((CoverageName.Len() * 4) + 1);
  strcpy(dummy, CoverageName.ToUTF8());
  sqlite3_bind_text(stmt, 1, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((Title.Len() * 4) + 1);
  strcpy(dummy, Title.ToUTF8());
  sqlite3_bind_text(stmt, 2, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  dummy = (char *) malloc((Abstract.Len() * 4) + 1);
  strcpy(dummy, Abstract.ToUTF8());
  sqlite3_bind_text(stmt, 3, dummy, -1, SQLITE_TRANSIENT);
  free(dummy);
  if (IsQueryable == false)
    sqlite3_bind_int(stmt, 4, 0);
  else
    sqlite3_bind_int(stmt, 4, 1);
  if (IsEditable == false)
    sqlite3_bind_int(stmt, 5, 0);
  else
    sqlite3_bind_int(stmt, 5, 1);
  ret = sqlite3_step(stmt);
  if (ret == SQLITE_DONE || ret == SQLITE_ROW)
    ;
  else
    {
      const char *msg = sqlite3_errmsg(MainFrame->GetSqlite());
      wxMessageBox(wxT("ERROR - SetVectorCoverageInfos: ") +
                   wxString::FromUTF8(msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
    }
  sqlite3_finalize(stmt);
}

void VectorInfosDialog::OnOk(wxCommandEvent & WXUNUSED(event))
{
//
// all done: 
//
  wxTextCtrl *nameCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_COVERAGE);
  wxTextCtrl *titleCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_TITLE);
  wxTextCtrl *absCtrl = (wxTextCtrl *) FindWindow(ID_VECTOR_ABSTRACT);
  wxRadioBox *queryableBox = (wxRadioBox *) FindWindow(ID_VECTOR_QUERYABLE);
  wxRadioBox *editableBox = (wxRadioBox *) FindWindow(ID_VECTOR_EDITABLE);
  wxString str = nameCtrl->GetValue().Trim();
  CoverageName = str.Trim(false);
  if (CoverageName.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Coverage Name !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = titleCtrl->GetValue().Trim();
  Title = str.Trim(false);
  if (Title.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Title !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  str = absCtrl->GetValue().Trim();
  Abstract = str.Trim(false);
  if (Abstract.Len() == 0)
    {
      wxMessageBox(wxT("You must specify some Abstract !!!"),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
      return;
    }
  if (queryableBox->GetSelection() == 1)
    IsQueryable = true;
  else
    IsQueryable = false;
  if (editableBox->GetSelection() == 1)
    IsEditable = true;
  else
    IsEditable = false;
  DoUpdateCoverage();
  wxDialog::EndModal(wxID_OK);
}

bool ReloadVectorStyleDialog::Create(MyFrame * parent, wxString & path)
{
//
// creating the dialog
................................................................................

bool VectorSRIDsDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorAlternativeSRIDs(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................

bool VectorKeywordsDialog::Create(MyFrame * parent, wxString & coverage)
{
//
// creating the dialog
//
  MainFrame = parent;
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  int pos = coverage.Find(wxT(" [SRID="));
  if (pos != wxNOT_FOUND)
    CoverageName = coverage.Left(pos);
  else
    CoverageName = coverage;
  List = MainFrame->FindVectorKeywords(CoverageName);
  if (wxDialog::Create(parent, wxID_ANY,
................................................................................
      path = params->GetPathByIndex(i);
      params->SetCurrentPath(path);
      report = wxT("Loading and Validating: ") + path;
      evt_start.SetString(report);
      params->GetDlg()->GetEventHandler()->AddPendingEvent(evt_start);
      clock_start = clock();
      wxString abstract;
      if (params->GetMainFrame()->
          ValidateExternalGraphicResource(path.ToUTF8(), &blob, &blob_size,

                                          abstract) == true)
        {
          wxFileName fn(path);
          wxString xlink_href =
            wxT("http://www.utopia.gov/") + fn.GetFullName();
          wxString filename = fn.GetFullName();
          wxString title = fn.GetName();
          if (params->GetDlg()->
              RegisterExternalGraphic(stmt, xlink_href.ToUTF8(), title.ToUTF8(),

                                      abstract.ToUTF8(), filename.ToUTF8(),

                                      blob, blob_size) != true)
            {
              params->SetError();
              goto error;
            }
          clock_end = clock();
          seconds =
            (double) (clock_end - clock_start) / (double) CLOCKS_PER_SEC;

Changes to TableTree.cpp.

66
67
68
69
70
71
72



73
74
75
76
77
78
79
..
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
...
117
118
119
120
121
122
123



124
125
126
127
128
129
130
...
144
145
146
147
148
149
150



151
152
153
154
155
156
157
158
159
160
161
162
163










164
165
166
167
168
169
170
...
325
326
327
328
329
330
331


332
333
334
335
336
337
338
339


340
341
342
343
344
345
346
...
349
350
351
352
353
354
355









356
357
358
359
360
361








362
363
364
365
366
367
368
...
553
554
555
556
557
558
559


560
561
562
563
564
565
566
...
733
734
735
736
737
738
739


















740
741
742
743
744


745
746
747
748
749
750
751
...
809
810
811
812
813
814
815












































816
817
818
819
820
821
822
....
1524
1525
1526
1527
1528
1529
1530








1531








1532
1533
1534
1535
1536
1537
1538
....
1554
1555
1556
1557
1558
1559
1560


























1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
....
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
....
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748


























































1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
....
1775
1776
1777
1778
1779
1780
1781




1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792

1793



1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804




1805
1806
1807
1808
1809
1810
1811
....
1823
1824
1825
1826
1827
1828
1829

1830


1831
1832

1833
1834
1835
1836
1837
1838
1839
....
2494
2495
2496
2497
2498
2499
2500
2501
2502
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
....
4281
4282
4283
4284
4285
4286
4287







4288
4289
4290
4291
4292
4293
4294
....
8025
8026
8027
8028
8029
8030
8031











8032
8033
8034
8035
8036
8037
8038
8039

8040
8041
8042
8043
8044
8045
8046
8047


8048

8049
8050
8051
8052
8053
8054
8055
8056
8057
8058














































































































































8059
8060
8061
8062
8063
8064
8065
....
8070
8071
8072
8073
8074
8075
8076







8077
8078
8079
8080
8081
8082
8083
....
8554
8555
8556
8557
8558
8559
8560











8561
8562
8563
8564
8565
8566
8567
8568
8569
8570
8571
8572
8573
8574
8575
8576
....
8611
8612
8613
8614
8615
8616
8617

8618
8619
8620
8621
8622
8623
8624
8625
8626
8627
8628
8629
8630
....
8650
8651
8652
8653
8654
8655
8656
8657


























































































































8658
8659
8660
8661
#include "icons/topo_net.xpm"
#include "icons/attach.xpm"
#include "icons/checkgeom.xpm"
#include "icons/sanegeom.xpm"
#include "icons/coverage.xpm"
#include "icons/coverage_tiles.xpm"
#include "icons/vector.xpm"



#include "icons/clone.xpm"
#include "icons/wms.xpm"

MyTableTree::MyTableTree(MyFrame * parent, wxWindowID id):wxTreeCtrl(parent, id)
{
//
// constructor: TREE control to show DB objects
................................................................................
  RootVectorCoverages = AppendItem(Root, wxT("Vector Coverages"));
  RootWMS = AppendItem(Root, wxT("Registered WMS layers"));
  RootMetadata = AppendItem(Root, wxT("Metadata"));
  RootInternal = AppendItem(Root, wxT("Internal Data"));
  RootSpatialIndex = AppendItem(Root, wxT("Spatial Index"));
// setting up icons 
  Images = new wxImageList(16, 16, true);
  wxIcon icons[27];
  icons[0] = wxIcon(db_xpm);
  icons[1] = wxIcon(table_xpm);
  icons[2] = wxIcon(pkey_xpm);
  icons[3] = wxIcon(column_xpm);
  icons[4] = wxIcon(index_xpm);
  icons[5] = wxIcon(trigger_xpm);
  icons[6] = wxIcon(geometry_xpm);
................................................................................
  icons[20] = wxIcon(topo_geo_xpm);
  icons[21] = wxIcon(attach_xpm);
  icons[22] = wxIcon(coverage_xpm);
  icons[23] = wxIcon(coverage_tiles_xpm);
  icons[24] = wxIcon(vector_xpm);
  icons[25] = wxIcon(topo_net_xpm);
  icons[26] = wxIcon(wms_xpm);



  Images->Add(icons[0]);
  Images->Add(icons[1]);
  Images->Add(icons[2]);
  Images->Add(icons[3]);
  Images->Add(icons[4]);
  Images->Add(icons[5]);
  Images->Add(icons[6]);
................................................................................
  Images->Add(icons[20]);
  Images->Add(icons[21]);
  Images->Add(icons[22]);
  Images->Add(icons[23]);
  Images->Add(icons[24]);
  Images->Add(icons[25]);
  Images->Add(icons[26]);



  SetImageList(Images);
  SetItemImage(Root, 0);
  SetItemImage(RootUserData, 17);
  SetItemImage(RootTopologies, 20);
  SetItemImage(RootNetworks, 25);
  SetItemImage(RootRasterCoverages, 22);
  SetItemImage(RootVectorCoverages, 24);
  SetItemImage(RootWMS, 26);
  SetItemImage(RootStyling, 17);
  SetItemImage(RootIsoMetadata, 17);
  SetItemImage(RootMetadata, 17);
  SetItemImage(RootInternal, 17);
  SetItemImage(RootSpatialIndex, 17);










// setting up event handlers 
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_ITEM_COLLAPSED,
          (wxObjectEventFunction) & MyTableTree::OnItemCollapsed);
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_ITEM_EXPANDING,
          (wxObjectEventFunction) & MyTableTree::OnItemExpanding);
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_SEL_CHANGED,
          (wxObjectEventFunction) & MyTableTree::OnSelChanged);
................................................................................
          (wxObjectEventFunction) & MyTableTree::OnCmdPyramidizeMonolithic);
  Connect(Tree_DePyramidize, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdDePyramidize);
  Connect(Tree_RasterDrop, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterDrop);
  Connect(Tree_UpdateRasterExtent, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateRasterExtent);


  Connect(Tree_Raster_SRIDs, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterSRIDs);
  Connect(Tree_Raster_Keywords, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterKeywords);
  Connect(Tree_UpdateRasterExtentAll, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateRasterExtentAll);
  Connect(Tree_VectorUnregister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorUnregister);


  Connect(Tree_UpdateVectorExtent, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateVectorExtent);
  Connect(Tree_Vector_SRIDs, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorSRIDs);
  Connect(Tree_Vector_Keywords, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorKeywords);
  Connect(Tree_UpdateVectorExtentAll, wxEVT_COMMAND_MENU_SELECTED,
................................................................................
          (wxObjectEventFunction) & MyTableTree::OnCmdSldSeRasterStyles);
  Connect(Tree_SldSeVectorStyles, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdSldSeVectorStyles);
  Connect(Tree_CreateRasterCoverage, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCreateRasterCoverage);
  Connect(Tree_VectorRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnRegisterVectorCoverage);









  Connect(Tree_RegisterWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRegisterWmsLayer);
  Connect(Tree_UnregisterWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUnregisterWmsLayer);
  Connect(Tree_ConfigureWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdConfigureWmsLayer);








}

MyTableTree::~MyTableTree()
{
  delete Images;
}

................................................................................
    return RootMetadata;
  if (tableName == wxT("vector_layers"))
    return RootMetadata;
  if (tableName == wxT("topologies"))
    return RootMetadata;
  if (tableName == wxT("networks"))
    return RootMetadata;



  if (tableName == wxT("sqlite_stat1"))
    return RootInternal;
  if (tableName == wxT("sqlite_stat3"))
    return RootInternal;
  if (tableName == wxT("sqlite_sequence"))
    return RootInternal;
................................................................................
    return nodes->GetRootMetadata();
  if (tableName == wxT("geom_cols_ref_sys"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("geometry_columns_time"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("spatialite_history"))
    return nodes->GetRootMetadata();


















  if (tableName == wxT("vector_layers"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("topologies"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("networks"))


    return nodes->GetRootMetadata();

  if (tableName == wxT("sqlite_stat1"))
    return nodes->GetRootInternal();
  if (tableName == wxT("sqlite_stat3"))
    return nodes->GetRootInternal();
  if (tableName == wxT("sqlite_sequence"))
................................................................................
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_getmap"))
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_settings"))
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_ref_sys"))
    return nodes->GetRootWMS();













































  if (tableName == wxT("SpatialIndex"))
    return nodes->GetRootSpatialIndex();
  if (tableName == wxT("KNN"))
    return nodes->GetRootSpatialIndex();
  if (MainFrame->IsSpatialIndex(nodes->GetDbAlias(), tableName) == true)
    return nodes->GetRootSpatialIndex();
................................................................................
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_VectorRegister,








                       wxT("Register New &Vector Coverage"));








      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_UpdateVectorExtentAll,
                       wxT("Update Vector &Coverages Extent"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
................................................................................
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_ConfigureWmsLayer,
                       wxT("Configure &WMS Layer"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;


























    }
  if (item == RootStyling)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();

      wxMenu *externalMenu = new wxMenu();
      menuItem =
        new wxMenuItem(externalMenu, Tree_RegisterExternalGraphic,
                       wxT("&Register New External Graphic"));
      externalMenu->Append(menuItem);
      if (MainFrame->IsSecurityLevelRelaxed() != true)
        menuItem->Enable(false);
................................................................................
        new wxMenuItem(vectorSymbolizerMenu, Tree_SimpleTextSymbolizer,
                       wxT("Simple &Text Symbolizer"));
      vectorSymbolizerMenu->Append(menuItem);
      toolsMenu->AppendSubMenu(vectorSymbolizerMenu,
                               wxT("VectorS&ymbolizer tools"));
      menu.AppendSubMenu(toolsMenu, wxT("SLD/SE &Tools"));
      menu.AppendSeparator();

      menuItem =
        new wxMenuItem(&menu, Tree_UpdateLayerStatisticsAll,
                       wxT("Update Layer &Statistics"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (item == Root || item == RootUserData || item == RootTopologies
      || item == RootNetworks || item == RootIsoMetadata || item == RootMetadata
      || item == RootInternal || item == RootSpatialIndex)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_QueryViewComposer,
................................................................................
      menuItem =
        new wxMenuItem(&menu, Tree_UpdateLayerStatisticsAll,
                       wxT("Update Layer &Statistics"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
    if (GetItemParent(item) == RootWMS)
    {
  MyObject *obj = (MyObject *) GetItemData(item);
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      if (obj->IsAttached() == true)
        {
          wxString title =
            wxT("Table: ") + obj->GetDbAlias() + wxT(".") + obj->GetName();
          menu.SetTitle(title);
      } else
        {
          wxString title = wxT("Table: ") + obj->GetName();
          menu.SetTitle(title);
	  }
          menu.AppendSeparator();
          menuItem = new wxMenuItem(&menu, Tree_Select, wxT("&Query table"));
          menu.Append(menuItem);
          menuItem = new wxMenuItem(&menu, Tree_Show, wxT("&Show columns"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_ShowSql, wxT("&Show CREATE statement"));
          menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
	}
  MyObject *obj = (MyObject *) GetItemData(item);
  if (obj == NULL)
    {


























































      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      if (GetItemImage(event.GetItem()) == 22)
        {
          // this is a Raster Coverage
          menuItem =
            new wxMenuItem(&menu, Tree_ImportRaster,
                           wxT("Import &Raster file(s)"));
          menu.Append(menuItem);
          if (MainFrame->IsSecurityLevelRelaxed() != true)
................................................................................
                           wxT("&Drop Raster Coverage"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_UpdateRasterExtent,
                           wxT("Update Raster &Coverage Extent"));
          menu.Append(menuItem);
          menu.AppendSeparator();




          menuItem =
            new wxMenuItem(&menu, Tree_SldSeRasterStyles,
                           wxT("Supported SLD/SE Raster &Styles"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Raster_SRIDs, wxT("&Alternative SRIDs"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Raster_Keywords, wxT("&Keywords"));
          menu.Append(menuItem);
          CurrentRasterCoverageName = GetItemText(event.GetItem());

      } else if (GetItemImage(event.GetItem()) == 24)



        {
          // this is a Vector Coverage
          menuItem =
            new wxMenuItem(&menu, Tree_VectorUnregister,
                           wxT("&Unregister Vector Coverage"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_UpdateVectorExtent,
                           wxT("Update Vector &Coverage Extent"));
          menu.Append(menuItem);
          menu.AppendSeparator();




          menuItem =
            new wxMenuItem(&menu, Tree_SldSeVectorStyles,
                           wxT("Supported SLD/SE Vector &Styles"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Vector_SRIDs, wxT("&Alternative SRIDs"));
          menu.Append(menuItem);
................................................................................
          menu.AppendSeparator();
          menuItem =
            new wxMenuItem(&menu, Tree_NewTable, wxT("Create New &Table"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_NewView, wxT("Create New &View"));
          menu.Append(menuItem);

        }


      PopupMenu(&menu, pt);
      return;

    }
  switch (obj->GetType())
    {
      case MY_VTABLE:
      case MY_TABLE:
      case MY_TILE_DATA:
        table = true;
................................................................................
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Show, wxT("&Show trigger"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Drop, wxT("&Drop trigger"));
      menu.Append(menuItem);
    }
  if (attached_db == true)
    {
      wxString title = wxT("Attached DB: ") + obj->GetName();
      menu.SetTitle(title);
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Detach, wxT("&Detach Database"));
      menu.Append(menuItem);
    }
  PopupMenu(&menu, pt);
}

void MyTableTree::OnCmdQueryViewComposer(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - query/view composer invoked
................................................................................
//
// menu event - Updating Vector Coverage Extent
//
  wxString coverage = CurrentVectorCoverageName;
  int pos = CurrentVectorCoverageName.Find('[', true);
  if (pos != wxNOT_FOUND)
    coverage = CurrentVectorCoverageName.Left(pos - 1);







  char *xcov = new char[strlen(coverage.ToUTF8()) + 1];
  strcpy(xcov, coverage.ToUTF8());
  char *xsql =
    sqlite3_mprintf("SELECT SE_UpdateVectorCoverageExtent(%Q, 1)", xcov);
  delete[]xcov;
  wxString sql = wxString::FromUTF8(xsql);
  sqlite3_free(xsql);
................................................................................
       &mixed_resolutions) == false)
    return;
  dlg.Create(MainFrame, coverage, title, abstract, sample, pixel, compression);
  dlg.ShowModal();
  // appending a delayed event so to really update the Tree
  AddPendingEvent(evt);
}












void MyTableTree::OnRegisterVectorCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Vector Coverage
//
  VectorRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);

  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString table = dlg.GetTableName();
      wxString geometry = dlg.GetGeometryColumn();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();


      if (MainFrame->DoRegisterVectorCoverage(name, table, geometry, title,

                                              abstract) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("Vector Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);














































































































































        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::OnCmdVectorUnregister(wxCommandEvent & WXUNUSED(event))
................................................................................
  VectorUnregisterDialog dlg;
  wxString title;
  wxString abstract;
  wxString type;
  int srid;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  wxString coverage = CurrentVectorCoverageName;







  int pos = CurrentRasterCoverageName.Find('[', true);
  if (pos != wxNOT_FOUND)
    coverage = CurrentRasterCoverageName.Left(pos - 1);
  if (MainFrame->DoGetVectorCoverageInfos
      (coverage, title, abstract, type, &srid) == false)
    return;
  dlg.Create(MainFrame, coverage, title, abstract, type);
................................................................................
//
// menu event - Handling Vector Coverage SLD/SE styles
//
  VectorCoverageStylesDialog dlg;
  dlg.Create(MainFrame, CurrentVectorCoverageName);
  dlg.ShowModal();
}












void MyTableTree::OnCmdVectorSRIDs(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Vector Coverage alternative SRIDs
//
  VectorSRIDsDialog dlg;
  dlg.Create(MainFrame, CurrentVectorCoverageName);
  dlg.ShowModal();
}

void MyTableTree::OnCmdVectorKeywords(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Vector Coverage Keywords
//
................................................................................
      bool MD5 = dlg.IsMD5();
      bool Summary = dlg.IsSummary();
      int RedBand = dlg.GetRedBand();
      int GreenBand = dlg.GetGreenBand();
      int BlueBand = dlg.GetBlueBand();
      int NIRband = dlg.GetNIRband();
      bool AutoNDVI = dlg.IsAutoNDVI();

      if (MainFrame->CreateRasterCoverage
          (CoverageName, Title, Abstract, SampleType, PixelType, NumBands,
           Compression, Quality, TileWidth, TileHeight, NotGeoreferenced, Srid,
           HorzResolution, VertResolution, NoData, StrictResolution,
           MixedResolutions, InputPaths, MD5, Summary, RedBand, GreenBand,
           BlueBand, NIRband, AutoNDVI) == true)
        {
          wxMessageBox(wxT("Raster Coverage ") + CoverageName +
                       wxT(" successfully created"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
          wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_Refresh);
          OnCmdRefresh(evt);
        }
................................................................................
void MyTableTree::OnCmdConfigureWmsLayer(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - configuring an existing WMS layer
//
  MainFrame->DoConfigureWMS();
}



























































































































sqlite3 *MyTableTree::GetSQLiteHandle()
{
  return MainFrame->GetSqlite();
}







>
>
>







 







|







 







>
>
>







 







>
>
>













>
>
>
>
>
>
>
>
>
>







 







>
>








>
>







 







>
>
>
>
>
>
>
>
>






>
>
>
>
>
>
>
>







 







>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>





>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
|
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







<







 







<







|
|
|







 







|

|












|
|
|
|
|
|
|
|
|


|

|

>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>




|







 







>
>
>
>











>
|
>
>
>











>
>
>
>







 







>

>
>
|
|
>







 







<
<
<
<
<
<
<
<







 







>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>




|



>








>
>

>
|









>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>







 







>
>
>
>
>
>
>







 







>
>
>
>
>
>
>
>
>
>
>







|
|







 







>





|







 








>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>




66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
..
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
...
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
...
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
...
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
...
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
...
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
...
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
...
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
....
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
....
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715

1716
1717
1718
1719
1720
1721
1722
....
1826
1827
1828
1829
1830
1831
1832

1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
....
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
....
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
....
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
....
2714
2715
2716
2717
2718
2719
2720








2721
2722
2723
2724
2725
2726
2727
....
4493
4494
4495
4496
4497
4498
4499
4500
4501
4502
4503
4504
4505
4506
4507
4508
4509
4510
4511
4512
4513
....
8244
8245
8246
8247
8248
8249
8250
8251
8252
8253
8254
8255
8256
8257
8258
8259
8260
8261
8262
8263
8264
8265
8266
8267
8268
8269
8270
8271
8272
8273
8274
8275
8276
8277
8278
8279
8280
8281
8282
8283
8284
8285
8286
8287
8288
8289
8290
8291
8292
8293
8294
8295
8296
8297
8298
8299
8300
8301
8302
8303
8304
8305
8306
8307
8308
8309
8310
8311
8312
8313
8314
8315
8316
8317
8318
8319
8320
8321
8322
8323
8324
8325
8326
8327
8328
8329
8330
8331
8332
8333
8334
8335
8336
8337
8338
8339
8340
8341
8342
8343
8344
8345
8346
8347
8348
8349
8350
8351
8352
8353
8354
8355
8356
8357
8358
8359
8360
8361
8362
8363
8364
8365
8366
8367
8368
8369
8370
8371
8372
8373
8374
8375
8376
8377
8378
8379
8380
8381
8382
8383
8384
8385
8386
8387
8388
8389
8390
8391
8392
8393
8394
8395
8396
8397
8398
8399
8400
8401
8402
8403
8404
8405
8406
8407
8408
8409
8410
8411
8412
8413
8414
8415
8416
8417
8418
8419
8420
8421
8422
8423
8424
8425
8426
8427
8428
8429
8430
8431
8432
8433
8434
8435
8436
8437
8438
8439
8440
8441
....
8446
8447
8448
8449
8450
8451
8452
8453
8454
8455
8456
8457
8458
8459
8460
8461
8462
8463
8464
8465
8466
....
8937
8938
8939
8940
8941
8942
8943
8944
8945
8946
8947
8948
8949
8950
8951
8952
8953
8954
8955
8956
8957
8958
8959
8960
8961
8962
8963
8964
8965
8966
8967
8968
8969
8970
....
9005
9006
9007
9008
9009
9010
9011
9012
9013
9014
9015
9016
9017
9018
9019
9020
9021
9022
9023
9024
9025
....
9045
9046
9047
9048
9049
9050
9051
9052
9053
9054
9055
9056
9057
9058
9059
9060
9061
9062
9063
9064
9065
9066
9067
9068
9069
9070
9071
9072
9073
9074
9075
9076
9077
9078
9079
9080
9081
9082
9083
9084
9085
9086
9087
9088
9089
9090
9091
9092
9093
9094
9095
9096
9097
9098
9099
9100
9101
9102
9103
9104
9105
9106
9107
9108
9109
9110
9111
9112
9113
9114
9115
9116
9117
9118
9119
9120
9121
9122
9123
9124
9125
9126
9127
9128
9129
9130
9131
9132
9133
9134
9135
9136
9137
9138
9139
9140
9141
9142
9143
9144
9145
9146
9147
9148
9149
9150
9151
9152
9153
9154
9155
9156
9157
9158
9159
9160
9161
9162
9163
9164
9165
9166
9167
9168
9169
9170
9171
9172
9173
9174
9175
9176
9177
9178
#include "icons/topo_net.xpm"
#include "icons/attach.xpm"
#include "icons/checkgeom.xpm"
#include "icons/sanegeom.xpm"
#include "icons/coverage.xpm"
#include "icons/coverage_tiles.xpm"
#include "icons/vector.xpm"
#include "icons/linestrings_on.xpm"
#include "icons/points_on.xpm"
#include "icons/polygons_on.xpm"
#include "icons/clone.xpm"
#include "icons/wms.xpm"

MyTableTree::MyTableTree(MyFrame * parent, wxWindowID id):wxTreeCtrl(parent, id)
{
//
// constructor: TREE control to show DB objects
................................................................................
  RootVectorCoverages = AppendItem(Root, wxT("Vector Coverages"));
  RootWMS = AppendItem(Root, wxT("Registered WMS layers"));
  RootMetadata = AppendItem(Root, wxT("Metadata"));
  RootInternal = AppendItem(Root, wxT("Internal Data"));
  RootSpatialIndex = AppendItem(Root, wxT("Spatial Index"));
// setting up icons 
  Images = new wxImageList(16, 16, true);
  wxIcon icons[30];
  icons[0] = wxIcon(db_xpm);
  icons[1] = wxIcon(table_xpm);
  icons[2] = wxIcon(pkey_xpm);
  icons[3] = wxIcon(column_xpm);
  icons[4] = wxIcon(index_xpm);
  icons[5] = wxIcon(trigger_xpm);
  icons[6] = wxIcon(geometry_xpm);
................................................................................
  icons[20] = wxIcon(topo_geo_xpm);
  icons[21] = wxIcon(attach_xpm);
  icons[22] = wxIcon(coverage_xpm);
  icons[23] = wxIcon(coverage_tiles_xpm);
  icons[24] = wxIcon(vector_xpm);
  icons[25] = wxIcon(topo_net_xpm);
  icons[26] = wxIcon(wms_xpm);
  icons[27] = wxIcon(points_on_xpm);
  icons[28] = wxIcon(linestrings_on_xpm);
  icons[29] = wxIcon(polygons_on_xpm);
  Images->Add(icons[0]);
  Images->Add(icons[1]);
  Images->Add(icons[2]);
  Images->Add(icons[3]);
  Images->Add(icons[4]);
  Images->Add(icons[5]);
  Images->Add(icons[6]);
................................................................................
  Images->Add(icons[20]);
  Images->Add(icons[21]);
  Images->Add(icons[22]);
  Images->Add(icons[23]);
  Images->Add(icons[24]);
  Images->Add(icons[25]);
  Images->Add(icons[26]);
  Images->Add(icons[27]);
  Images->Add(icons[28]);
  Images->Add(icons[29]);
  SetImageList(Images);
  SetItemImage(Root, 0);
  SetItemImage(RootUserData, 17);
  SetItemImage(RootTopologies, 20);
  SetItemImage(RootNetworks, 25);
  SetItemImage(RootRasterCoverages, 22);
  SetItemImage(RootVectorCoverages, 24);
  SetItemImage(RootWMS, 26);
  SetItemImage(RootStyling, 17);
  SetItemImage(RootIsoMetadata, 17);
  SetItemImage(RootMetadata, 17);
  SetItemImage(RootInternal, 17);
  SetItemImage(RootSpatialIndex, 17);
  SetItemData(RootUserData, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootTopologies, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootNetworks, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootRasterCoverages, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootVectorCoverages, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootWMS, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootStyling, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootMetadata, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootInternal, (wxTreeItemData *) (new MyObject(false)));
  SetItemData(RootSpatialIndex, (wxTreeItemData *) (new MyObject(false)));
// setting up event handlers 
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_ITEM_COLLAPSED,
          (wxObjectEventFunction) & MyTableTree::OnItemCollapsed);
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_ITEM_EXPANDING,
          (wxObjectEventFunction) & MyTableTree::OnItemExpanding);
  Connect(wxID_ANY, wxEVT_COMMAND_TREE_SEL_CHANGED,
          (wxObjectEventFunction) & MyTableTree::OnSelChanged);
................................................................................
          (wxObjectEventFunction) & MyTableTree::OnCmdPyramidizeMonolithic);
  Connect(Tree_DePyramidize, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdDePyramidize);
  Connect(Tree_RasterDrop, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterDrop);
  Connect(Tree_UpdateRasterExtent, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateRasterExtent);
  Connect(Tree_RasterInfos, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterInfos);
  Connect(Tree_Raster_SRIDs, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterSRIDs);
  Connect(Tree_Raster_Keywords, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRasterKeywords);
  Connect(Tree_UpdateRasterExtentAll, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateRasterExtentAll);
  Connect(Tree_VectorUnregister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorUnregister);
  Connect(Tree_VectorInfos, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorInfos);
  Connect(Tree_UpdateVectorExtent, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUpdateVectorExtent);
  Connect(Tree_Vector_SRIDs, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorSRIDs);
  Connect(Tree_Vector_Keywords, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdVectorKeywords);
  Connect(Tree_UpdateVectorExtentAll, wxEVT_COMMAND_MENU_SELECTED,
................................................................................
          (wxObjectEventFunction) & MyTableTree::OnCmdSldSeRasterStyles);
  Connect(Tree_SldSeVectorStyles, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdSldSeVectorStyles);
  Connect(Tree_CreateRasterCoverage, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCreateRasterCoverage);
  Connect(Tree_VectorRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnRegisterVectorCoverage);
  Connect(Tree_SpatialViewRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnRegisterSpatialViewCoverage);
  Connect(Tree_VirtualShapeRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) &
          MyTableTree::OnRegisterVirtualShapeCoverage);
  Connect(Tree_TopoGeoRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnRegisterTopoGeoCoverage);
  Connect(Tree_TopoNetRegister, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnRegisterTopoNetCoverage);
  Connect(Tree_RegisterWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdRegisterWmsLayer);
  Connect(Tree_UnregisterWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdUnregisterWmsLayer);
  Connect(Tree_ConfigureWmsLayer, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdConfigureWmsLayer);
  Connect(Tree_CreateTopoGeo, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdCreateTopoGeo);
  Connect(Tree_DropTopoGeo, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdDropTopoGeo);
  Connect(Tree_CreateTopoNet, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdCreateTopoNet);
  Connect(Tree_DropTopoNet, wxEVT_COMMAND_MENU_SELECTED,
          (wxObjectEventFunction) & MyTableTree::OnCmdDropTopoNet);
}

MyTableTree::~MyTableTree()
{
  delete Images;
}

................................................................................
    return RootMetadata;
  if (tableName == wxT("vector_layers"))
    return RootMetadata;
  if (tableName == wxT("topologies"))
    return RootMetadata;
  if (tableName == wxT("networks"))
    return RootMetadata;
  if (tableName == wxT("data_licenses"))
    return RootMetadata;

  if (tableName == wxT("sqlite_stat1"))
    return RootInternal;
  if (tableName == wxT("sqlite_stat3"))
    return RootInternal;
  if (tableName == wxT("sqlite_sequence"))
    return RootInternal;
................................................................................
    return nodes->GetRootMetadata();
  if (tableName == wxT("geom_cols_ref_sys"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("geometry_columns_time"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("spatialite_history"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("raster_coverages"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("raster_coverages_srid"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("raster_coverages_keyword"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("raster_coverages_ref_sys"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_coverages"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_coverages_srid"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_coverages_keyword"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_coverages_ref_sys"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_layers"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("vector_layers"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("topologies"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("networks"))
    return nodes->GetRootMetadata();
  if (tableName == wxT("data_licenses"))
    return nodes->GetRootMetadata();

  if (tableName == wxT("sqlite_stat1"))
    return nodes->GetRootInternal();
  if (tableName == wxT("sqlite_stat3"))
    return nodes->GetRootInternal();
  if (tableName == wxT("sqlite_sequence"))
................................................................................
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_getmap"))
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_settings"))
    return nodes->GetRootWMS();
  if (tableName == wxT("wms_ref_sys"))
    return nodes->GetRootWMS();

  if (tableName == wxT("SE_external_graphics"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_fonts"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_external_graphics_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_fonts_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_raster_styles"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_raster_styled_layers"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_raster_styles_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_raster_styled_layers_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_vector_styles"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_vector_styled_layers"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_vector_styles_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_vector_styled_layers_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_styled_groups"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_styled_group_refs"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_styled_group_styles"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_styled_groups_view"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_group_styles"))
    return nodes->GetRootStyling();
  if (tableName == wxT("SE_group_styles_view"))
    return nodes->GetRootStyling();

  if (tableName == wxT("ISO_metadata"))
    return nodes->GetRootIsoMetadata();
  if (tableName == wxT("ISO_metadata_reference"))
    return nodes->GetRootIsoMetadata();
  if (tableName == wxT("ISO_metadata_view"))
    return nodes->GetRootIsoMetadata();

  if (tableName == wxT("SpatialIndex"))
    return nodes->GetRootSpatialIndex();
  if (tableName == wxT("KNN"))
    return nodes->GetRootSpatialIndex();
  if (MainFrame->IsSpatialIndex(nodes->GetDbAlias(), tableName) == true)
    return nodes->GetRootSpatialIndex();
................................................................................
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_VectorRegister,
                       wxT("Register New &SpatialTable Coverage"));
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_SpatialViewRegister,
                       wxT("Register New &SpatialView Coverage"));
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_VirtualShapeRegister,
                       wxT("Register New &VirtualShape Coverage"));
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_TopoGeoRegister,
                       wxT("Register New Topology-&Geometry Coverage"));
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_TopoNetRegister,
                       wxT("Register New Topology-&Network Coverage"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_UpdateVectorExtentAll,
                       wxT("Update Vector &Coverages Extent"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
................................................................................
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_ConfigureWmsLayer,
                       wxT("Configure &WMS Layer"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (item == RootTopologies)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_CreateTopoGeo,
                       wxT("Create New &Topology-Geometry"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (item == RootNetworks)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_CreateTopoNet,
                       wxT("Create New &Topology-Network"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (item == RootStyling)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();

      wxMenu *externalMenu = new wxMenu();
      menuItem =
        new wxMenuItem(externalMenu, Tree_RegisterExternalGraphic,
                       wxT("&Register New External Graphic"));
      externalMenu->Append(menuItem);
      if (MainFrame->IsSecurityLevelRelaxed() != true)
        menuItem->Enable(false);
................................................................................
        new wxMenuItem(vectorSymbolizerMenu, Tree_SimpleTextSymbolizer,
                       wxT("Simple &Text Symbolizer"));
      vectorSymbolizerMenu->Append(menuItem);
      toolsMenu->AppendSubMenu(vectorSymbolizerMenu,
                               wxT("VectorS&ymbolizer tools"));
      menu.AppendSubMenu(toolsMenu, wxT("SLD/SE &Tools"));
      menu.AppendSeparator();

      menuItem =
        new wxMenuItem(&menu, Tree_UpdateLayerStatisticsAll,
                       wxT("Update Layer &Statistics"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (item == Root || item == RootUserData || item == RootIsoMetadata
      || item == RootMetadata || item == RootInternal
      || item == RootSpatialIndex)
    {
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem =
        new wxMenuItem(&menu, Tree_QueryViewComposer,
................................................................................
      menuItem =
        new wxMenuItem(&menu, Tree_UpdateLayerStatisticsAll,
                       wxT("Update Layer &Statistics"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  if (GetItemParent(item) == RootWMS)
    {
      MyObject *obj = (MyObject *) GetItemData(item);
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      if (obj->IsAttached() == true)
        {
          wxString title =
            wxT("Table: ") + obj->GetDbAlias() + wxT(".") + obj->GetName();
          menu.SetTitle(title);
      } else
        {
          wxString title = wxT("Table: ") + obj->GetName();
          menu.SetTitle(title);
        }
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Select, wxT("&Query table"));
      menu.Append(menuItem);
      menuItem = new wxMenuItem(&menu, Tree_Show, wxT("&Show columns"));
      menu.Append(menuItem);
      menuItem =
        new wxMenuItem(&menu, Tree_ShowSql, wxT("&Show CREATE statement"));
      menu.Append(menuItem);
      PopupMenu(&menu, pt);
      return;
    }
  MyObject *obj = (MyObject *) GetItemData(item);
  if (obj != NULL)
    {
      if (obj->GetType() == MY_TOPO_GEO || obj->GetType() == MY_TOPO_NET)
        {
          if (obj->IsAttached() == true)
            {
              CurrentItem = wxTreeItemId();
              menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
              menu.Append(menuItem);
              PopupMenu(&menu, pt);
              return;
            }
          if (obj->GetType() == MY_TOPO_GEO)
            {
              CurrentItem = item;
              menuItem =
                new wxMenuItem(&menu, Tree_DropTopoGeo,
                               wxT("&Drop Topology-Geometry"));
              menu.Append(menuItem);
              PopupMenu(&menu, pt);
              return;
            }
          if (obj->GetType() == MY_TOPO_NET)
            {
              CurrentItem = item;
              menuItem =
                new wxMenuItem(&menu, Tree_DropTopoNet,
                               wxT("&Drop Topology-Network"));
              menu.Append(menuItem);
              PopupMenu(&menu, pt);
              return;
            }
        }
    }
  bool attachedRoot = false;
  int type = MY_UNDEFINED;
  if (obj != NULL)
    {
      attachedRoot = obj->IsRootAttached();
      type = obj->GetType();
    }
  if (attachedRoot == true)
    {
      if (type == MY_ATTACHED)
        {
          CurrentItem = item;
          menuItem =
            new wxMenuItem(&menu, Tree_Detach, wxT("&Detach Database"));
          menu.Append(menuItem);
      } else
        {
          CurrentItem = wxTreeItemId();
          menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
          menu.Append(menuItem);
        }
      PopupMenu(&menu, pt);
      return;
  } else
    {
      bool stop = true;
      CurrentItem = wxTreeItemId();
      menuItem = new wxMenuItem(&menu, Tree_Refresh, wxT("&Refresh"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      if (GetItemImage(event.GetItem()) == 22 && attachedRoot == false)
        {
          // this is a Raster Coverage
          menuItem =
            new wxMenuItem(&menu, Tree_ImportRaster,
                           wxT("Import &Raster file(s)"));
          menu.Append(menuItem);
          if (MainFrame->IsSecurityLevelRelaxed() != true)
................................................................................
                           wxT("&Drop Raster Coverage"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_UpdateRasterExtent,
                           wxT("Update Raster &Coverage Extent"));
          menu.Append(menuItem);
          menu.AppendSeparator();
          menuItem =
            new wxMenuItem(&menu, Tree_RasterInfos,
                           wxT("&Edit Raster Coverage Infos"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_SldSeRasterStyles,
                           wxT("Supported SLD/SE Raster &Styles"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Raster_SRIDs, wxT("&Alternative SRIDs"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Raster_Keywords, wxT("&Keywords"));
          menu.Append(menuItem);
          CurrentRasterCoverageName = GetItemText(event.GetItem());
      } else
        if ((GetItemImage(event.GetItem()) == 24
             || GetItemImage(event.GetItem()) == 27
             || GetItemImage(event.GetItem()) == 28
             || GetItemImage(event.GetItem()) == 29) && attachedRoot == false)
        {
          // this is a Vector Coverage
          menuItem =
            new wxMenuItem(&menu, Tree_VectorUnregister,
                           wxT("&Unregister Vector Coverage"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_UpdateVectorExtent,
                           wxT("Update Vector &Coverage Extent"));
          menu.Append(menuItem);
          menu.AppendSeparator();
          menuItem =
            new wxMenuItem(&menu, Tree_VectorInfos,
                           wxT("&Edit Vector Coverage Infos"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_SldSeVectorStyles,
                           wxT("Supported SLD/SE Vector &Styles"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_Vector_SRIDs, wxT("&Alternative SRIDs"));
          menu.Append(menuItem);
................................................................................
          menu.AppendSeparator();
          menuItem =
            new wxMenuItem(&menu, Tree_NewTable, wxT("Create New &Table"));
          menu.Append(menuItem);
          menuItem =
            new wxMenuItem(&menu, Tree_NewView, wxT("Create New &View"));
          menu.Append(menuItem);
          stop = false;
        }
      if (stop)
        {
          PopupMenu(&menu, pt);
          return;
        }
    }
  switch (obj->GetType())
    {
      case MY_VTABLE:
      case MY_TABLE:
      case MY_TILE_DATA:
        table = true;
................................................................................
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Show, wxT("&Show trigger"));
      menu.Append(menuItem);
      menu.AppendSeparator();
      menuItem = new wxMenuItem(&menu, Tree_Drop, wxT("&Drop trigger"));
      menu.Append(menuItem);
    }








  PopupMenu(&menu, pt);
}

void MyTableTree::OnCmdQueryViewComposer(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - query/view composer invoked
................................................................................
//
// menu event - Updating Vector Coverage Extent
//
  wxString coverage = CurrentVectorCoverageName;
  int pos = CurrentVectorCoverageName.Find('[', true);
  if (pos != wxNOT_FOUND)
    coverage = CurrentVectorCoverageName.Left(pos - 1);
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  char *xcov = new char[strlen(coverage.ToUTF8()) + 1];
  strcpy(xcov, coverage.ToUTF8());
  char *xsql =
    sqlite3_mprintf("SELECT SE_UpdateVectorCoverageExtent(%Q, 1)", xcov);
  delete[]xcov;
  wxString sql = wxString::FromUTF8(xsql);
  sqlite3_free(xsql);
................................................................................
       &mixed_resolutions) == false)
    return;
  dlg.Create(MainFrame, coverage, title, abstract, sample, pixel, compression);
  dlg.ShowModal();
  // appending a delayed event so to really update the Tree
  AddPendingEvent(evt);
}

void MyTableTree::OnCmdRasterInfos(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Raster Coverage Infos
//
  MainFrame->DoCreateStylingTables();
  RasterInfosDialog dlg;
  dlg.Create(MainFrame, CurrentRasterCoverageName);
  dlg.ShowModal();
}

void MyTableTree::OnRegisterVectorCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Vector Coverage - SpatialTable
//
  VectorRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  MainFrame->DoCreateStylingTables();
  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString table = dlg.GetTableName();
      wxString geometry = dlg.GetGeometryColumn();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();
      bool isQueryable = dlg.IsQueryable();
      bool isEditable = dlg.IsEditable();
      if (MainFrame->DoRegisterVectorCoverage(name, table, geometry, title,
                                              abstract, isQueryable,
                                              isEditable) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("Vector Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::
OnRegisterSpatialViewCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Vector Coverage - SpatialView
//
  SpatialViewRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  MainFrame->DoCreateStylingTables();
  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString view = dlg.GetViewName();
      wxString geometry = dlg.GetViewGeometry();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();
      bool isQueryable = dlg.IsQueryable();
      bool isEditable = dlg.IsEditable();
      if (MainFrame->DoRegisterSpatialViewCoverage(name, view, geometry, title,
                                                   abstract, isQueryable,
                                                   isEditable) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("Vector Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::
OnRegisterVirtualShapeCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Vector Coverage - VirtualShape
//
  VirtualShapeRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  MainFrame->DoCreateStylingTables();
  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString table = dlg.GetVirtName();
      wxString geometry = dlg.GetVirtGeometry();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();
      bool isQueryable = dlg.IsQueryable();
      if (MainFrame->DoRegisterVirtualShapeCoverage
          (name, table, geometry, title, abstract, isQueryable) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("Vector Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::OnRegisterTopoGeoCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Topology-Geometry Coverage
//
  TopoGeoRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  MainFrame->DoCreateStylingTables();
  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString topology = dlg.GetTopologyName();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();
      bool isQueryable = dlg.IsQueryable();
      bool isEditable = dlg.IsEditable();
      if (MainFrame->DoRegisterTopoGeoCoverage(name, topology, title,
                                               abstract, isQueryable,
                                               isEditable) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("topoGeo Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::OnRegisterTopoNetCoverage(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Register Topology-Network Coverage
//
  TopoNetRegisterDialog dlg;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  MainFrame->DoCreateStylingTables();
  dlg.Create(MainFrame);
  if (dlg.ShowModal() == wxID_OK)
    {
      wxString name = dlg.GetCoverageName();
      wxString network = dlg.GetNetworkName();
      wxString title = dlg.GetTitle();
      wxString abstract = dlg.GetAbstract();
      bool isQueryable = dlg.IsQueryable();
      bool isEditable = dlg.IsEditable();
      if (MainFrame->DoRegisterTopoNetCoverage(name, network, title,
                                               abstract, isQueryable,
                                               isEditable) != true)
        {
          wxMessageBox(wxT("Sorry, some error fatal occurred."),
                       wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
          return;
      } else
        {
          wxMessageBox(wxT("topoNet Coverage \"") + name +
                       wxT("\" successfully registered"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
        }
      // appending a delayed event so to really update the Tree
      AddPendingEvent(evt);
    }
}

void MyTableTree::OnCmdVectorUnregister(wxCommandEvent & WXUNUSED(event))
................................................................................
  VectorUnregisterDialog dlg;
  wxString title;
  wxString abstract;
  wxString type;
  int srid;
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  wxString coverage = CurrentVectorCoverageName;
  wxString clean;
  if (coverage.StartsWith(wxT("table."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("view."), &clean))
    coverage = clean;
  else if (coverage.StartsWith(wxT("shp."), &clean))
    coverage = clean;
  int pos = CurrentRasterCoverageName.Find('[', true);
  if (pos != wxNOT_FOUND)
    coverage = CurrentRasterCoverageName.Left(pos - 1);
  if (MainFrame->DoGetVectorCoverageInfos
      (coverage, title, abstract, type, &srid) == false)
    return;
  dlg.Create(MainFrame, coverage, title, abstract, type);
................................................................................
//
// menu event - Handling Vector Coverage SLD/SE styles
//
  VectorCoverageStylesDialog dlg;
  dlg.Create(MainFrame, CurrentVectorCoverageName);
  dlg.ShowModal();
}

void MyTableTree::OnCmdVectorInfos(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Vector Coverage Infos
//
  MainFrame->DoCreateStylingTables();
  VectorInfosDialog dlg;
  dlg.Create(MainFrame, CurrentVectorCoverageName);
  dlg.ShowModal();
}

void MyTableTree::OnCmdVectorSRIDs(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Vector Coverage alternative SRIDs
//
  VectorSRIDsDialog dlg;
  if (dlg.Create(MainFrame, CurrentVectorCoverageName) == true)
    dlg.ShowModal();
}

void MyTableTree::OnCmdVectorKeywords(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - Handling Vector Coverage Keywords
//
................................................................................
      bool MD5 = dlg.IsMD5();
      bool Summary = dlg.IsSummary();
      int RedBand = dlg.GetRedBand();
      int GreenBand = dlg.GetGreenBand();
      int BlueBand = dlg.GetBlueBand();
      int NIRband = dlg.GetNIRband();
      bool AutoNDVI = dlg.IsAutoNDVI();
      bool isQueryable = dlg.IsQueryable();
      if (MainFrame->CreateRasterCoverage
          (CoverageName, Title, Abstract, SampleType, PixelType, NumBands,
           Compression, Quality, TileWidth, TileHeight, NotGeoreferenced, Srid,
           HorzResolution, VertResolution, NoData, StrictResolution,
           MixedResolutions, InputPaths, MD5, Summary, RedBand, GreenBand,
           BlueBand, NIRband, AutoNDVI, isQueryable) == true)
        {
          wxMessageBox(wxT("Raster Coverage ") + CoverageName +
                       wxT(" successfully created"), wxT("spatialite_gui"),
                       wxOK | wxICON_INFORMATION, this);
          wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_Refresh);
          OnCmdRefresh(evt);
        }
................................................................................
void MyTableTree::OnCmdConfigureWmsLayer(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - configuring an existing WMS layer
//
  MainFrame->DoConfigureWMS();
}

void MyTableTree::OnCmdCreateTopoGeo(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - creating a new Topology-Geometry
//
  MainFrame->DoCreateTopoGeo();
}

void MyTableTree::OnCmdCreateTopoNet(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - creating a new Topology-Network
//
  MainFrame->DoCreateTopoNet();
}

void MyTableTree::OnCmdDropTopoGeo(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - dropping a Topology-Geometry
//
  wxString msg;
  char *errMsg = NULL;
  int ret;
  sqlite3 *sqlite = MainFrame->GetSqlite();
  MyObject *obj = (MyObject *) GetItemData(CurrentItem);
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  if (obj == NULL)
    return;
  if (obj->GetType() == MY_TOPO_GEO)
    {
      msg = wxT("Do you really intend to drop the Topology-Geometry named: ");
      msg += obj->GetName();
      msg += wxT("\n[and any other related object] ?");
    }
  wxMessageDialog confirm(this, msg, wxT("Confirming DROP"),
                          wxOK | wxCANCEL | wxICON_QUESTION);
  ret = confirm.ShowModal();
  if (ret != wxID_OK)
    return;
  ::wxBeginBusyCursor();
  char *name = (char *) malloc((obj->GetName().Len() * 4) + 1);
  strcpy(name, obj->GetName().ToUTF8());
  char *sql = sqlite3_mprintf("SELECT DropTopology(%Q)", name);
  free(name);
  ret = sqlite3_exec(sqlite, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      ::wxEndBusyCursor();
      goto err;
    }
  ::wxEndBusyCursor();
  wxMessageBox(wxT("Topology-Geometry '") + obj->GetName() +
               wxT("' was successfully removed"), wxT("spatialite_gui"),
               wxOK | wxICON_INFORMATION, this);
  // appending a delayed event so to really update the Tree
  AddPendingEvent(evt);
  return;
err:
  ::wxEndBusyCursor();
  wxMessageBox(wxT("Error: unable to remove Topology-Geometry '") +
               obj->GetName() + wxT("'"), wxT("spatialite_gui"),
               wxOK | wxICON_WARNING, this);
}

void MyTableTree::OnCmdDropTopoNet(wxCommandEvent & WXUNUSED(event))
{
//
// menu event - dropping a Topology-Network
//
  wxString msg;
  char *errMsg = NULL;
  int ret;
  sqlite3 *sqlite = MainFrame->GetSqlite();
  MyObject *obj = (MyObject *) GetItemData(CurrentItem);
  wxCommandEvent evt(wxEVT_COMMAND_MENU_SELECTED, Tree_RefreshDeferred);
  if (obj == NULL)
    return;
  if (obj->GetType() == MY_TOPO_NET)
    {
      msg = wxT("Do you really intend to drop the Topology-Network named: ");
      msg += obj->GetName();
      msg += wxT("\n[and any other related object] ?");
    }
  wxMessageDialog confirm(this, msg, wxT("Confirming DROP"),
                          wxOK | wxCANCEL | wxICON_QUESTION);
  ret = confirm.ShowModal();
  if (ret != wxID_OK)
    return;
  ::wxBeginBusyCursor();
  char *name = (char *) malloc((obj->GetName().Len() * 4) + 1);
  strcpy(name, obj->GetName().ToUTF8());
  char *sql = sqlite3_mprintf("SELECT DropNetwork(%Q)", name);
  free(name);
  ret = sqlite3_exec(sqlite, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("SQLite SQL error: ") + wxString::FromUTF8(errMsg),
                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      ::wxEndBusyCursor();
      goto err;
    }
  ::wxEndBusyCursor();
  wxMessageBox(wxT("Topology-Network '") + obj->GetName() +
               wxT("' was successfully removed"), wxT("spatialite_gui"),
               wxOK | wxICON_INFORMATION, this);
  // appending a delayed event so to really update the Tree
  AddPendingEvent(evt);
  return;
err:
  ::wxEndBusyCursor();
  wxMessageBox(wxT("Error: unable to remove Topology-Network '") +
               obj->GetName() + wxT("'"), wxT("spatialite_gui"),
               wxOK | wxICON_WARNING, this);
}

sqlite3 *MyTableTree::GetSQLiteHandle()
{
  return MainFrame->GetSqlite();
}

Changes to VectorSymbolizers2.cpp.

5142
5143
5144
5145
5146
5147
5148
5149
5150
5151
5152
5153
5154
5155
5156
5157
  rl2_graph_set_brush(ctx, 255, 255, 255, 0);
  rl2_graph_draw_rectangle(ctx, -1, -1, 501, 301);

// setting up the Font
  char facename[1024];
  strcpy(facename, FontFamily.ToUTF8());
  rl2GraphicsFontPtr font = rl2_search_TrueType_font(MainFrame->GetSqlite(),
                                                     MainFrame->
                                                     GetRL2PrivateData(),
                                                     facename,
                                                     FontSize);
  double aleph = 255.0 * FillOpacity;
  if (aleph < 0.0)
    aleph = 0.0;
  if (aleph > 255.0)
    aleph = 255.0;







|
|







5142
5143
5144
5145
5146
5147
5148
5149
5150
5151
5152
5153
5154
5155
5156
5157
  rl2_graph_set_brush(ctx, 255, 255, 255, 0);
  rl2_graph_draw_rectangle(ctx, -1, -1, 501, 301);

// setting up the Font
  char facename[1024];
  strcpy(facename, FontFamily.ToUTF8());
  rl2GraphicsFontPtr font = rl2_search_TrueType_font(MainFrame->GetSqlite(),
                                                     MainFrame->GetRL2PrivateData
                                                     (),
                                                     facename,
                                                     FontSize);
  double aleph = 255.0 * FillOpacity;
  if (aleph < 0.0)
    aleph = 0.0;
  if (aleph > 255.0)
    aleph = 255.0;

Changes to WmsDialog.cpp.

1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
....
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
....
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
....
1569
1570
1571
1572
1573
1574
1575
1576

1577
1578
1579
1580
1581
1582
1583
....
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
....
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
....
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712

1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723

1724
1725

1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
....
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920

1921


1922


1923


1924


1925


1926


1927


1928


1929


1930

1931

1932

1933

1934

1935

1936

1937

1938

1939

1940

1941

1942

1943
1944
1945

1946


1947


1948


1949


1950


1951


1952


1953


1954


1955

1956

1957

1958

1959

1960

1961

1962

1963

1964

1965

1966

1967

1968
1969
1970
1971
1972

1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028

2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135

2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177

2178
2179






































2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214

2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
....
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384

2385
2386
2387
2388
2389
2390
2391
....
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588

2589

2590
2591
2592
2593
2594
2595
2596

2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619


2620

2621
2622
2623
2624
2625
2626
2627

2628
2629
2630
2631
2632
2633
2634
2635
2636
2637
2638
2639
2640
2641
2642
2643
2644
2645
2646
2647
2648
2649
2650
2651
2652
....
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666
2667
2668
2669

2670
2671
2672
2673
2674
2675
2676
2677
2678

2679
2680
2681
2682
2683
2684
2685
2686

2687

2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700
2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712


2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
2731

2732
2733
2734
2735
2736
2737
2738
2739

2740
2741
2742
2743



2744
2745
2746
2747
2748
2749
2750



2751
2752
2753
2754
2755
2756
2757

2758
2759
2760
2761
2762
2763
2764
2765
2766

2767
2768
2769
2770
2771
2772
2773
2774

2775

2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
....
2810
2811
2812
2813
2814
2815
2816
2817
2818
2819
2820
2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
....
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842
2843
2844
2845
2846
2847
....
2945
2946
2947
2948
2949
2950
2951

2952
2953
2954
2955
2956
2957

2958
2959
2960
2961
2962
2963
2964
2965
2966
2967
2968
2969
2970
2971
2972
2973
2974
2975
2976
2977
2978
2979
2980
....
3091
3092
3093
3094
3095
3096
3097
3098
3099
3100
3101
3102
3103
3104
3105
3106
3107
3108
3109
3110
3111
3112
3113
3114
3115
3116
3117
3118
3119
3120
3121
3122
3123
3124
3125
3126
3127
3128
3129
3130
3131
3132
3133
3134
3135
3136
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// the registered WMS GetMap List
  PopulateList();
  wxBoxSizer *listSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(listSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  WmsLayers = new wxGrid(this, ID_WMS_LIST, wxPoint(5, 5), wxSize(700, 300));
  WmsLayers->CreateGrid(Count, 2);
  WmsLayers->EnableEditing(false);
  WmsLayers->SetColLabelValue(0, wxT("Layer Name"));
  WmsLayers->SetColLabelValue(1, wxT("GetMap URL"));
  for (int i = 0; i < Count; i++)
  {
      WmsLayers->SetCellValue(i, 0, *(ListLayer + i));
      WmsLayers->SetCellValue(i, 1, *(ListUrl + i));
  }
  delete [] ListUrl;
  delete[]ListLayer;
  ListUrl = NULL;
  ListLayer = NULL;
  WmsLayers->SetRowLabelSize(wxGRID_AUTOSIZE);
  WmsLayers->AutoSize();
  WmsLayers->SetSize(700, 300);
  listSizer->Add(WmsLayers, 0, wxALIGN_RIGHT | wxALL, 5);
// selected WMS datasource group box
  wxBoxSizer *kkSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(kkSizer, 0, wxALIGN_TOP | wxALL, 5);
  wxStaticBox *dsBox = new wxStaticBox(this, wxID_STATIC,
                                       wxT("WMS GetMap URL"),
                                       wxDefaultPosition,
................................................................................
// the Layer Name
  wxBoxSizer *layerSizer = new wxBoxSizer(wxHORIZONTAL);
  dsBoxSizer->Add(layerSizer, 0, wxALIGN_LEFT | wxALL, 5);
  wxStaticText *layerLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Layer Name:"));
  layerSizer->Add(layerLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxTextCtrl *layerCtrl = new wxTextCtrl(this, ID_WMS_LAYER, wxT(""),
                                       wxDefaultPosition, wxSize(200, 22),
                                       wxTE_READONLY);
  layerSizer->Add(layerCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// Title / Abstract panel
  wxBoxSizer *title0BoxSizer = new wxBoxSizer(wxHORIZONTAL);
  dsBoxSizer->Add(title0BoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *titleBox = new wxStaticBox(this, wxID_ANY,
                                          wxT("Layer Title"),
                                          wxDefaultPosition,
................................................................................
// GetMap URL selection changed
//
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;
  
  WmsLayers->Show(false);
  WmsLayers->ClearSelection();
  WmsLayers->SelectRow(CurrentEvtRow);
  WmsLayers->Show(true);
  LayerName = WmsLayers->GetCellValue(CurrentEvtRow, 0);
  URL = WmsLayers->GetCellValue(CurrentEvtRow, 1);

................................................................................
  layerCtrl->SetValue(LayerName);
  wxButton *okBtn = (wxButton *) FindWindow(wxID_OK);
  okBtn->Enable(true);

// preparing the SQL query
  sql =
    sqlite3_mprintf
    ("SELECT title, abstract FROM wms_getmap WHERE url = %Q AND layer_name = %Q", url, layer);

  free(url);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;
................................................................................
  MainFrame = parent;
  Url = url;
  LayerName = layer;
  if (wxDialog::Create(parent, wxID_ANY, wxT("WMS Layer configuration")) ==
      false)
    return false;
// populates individual controls
	LoadData();
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  return true;
................................................................................
  kkSizer->Add(lyrBox0Sizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
// Second row: Layer name
  wxBoxSizer *lyrBoxSizer = new wxBoxSizer(wxVERTICAL);
  lyrBox0Sizer->Add(lyrBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxBoxSizer *urlSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(urlSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *urlBox = new wxStaticBox(this, wxID_ANY,
                                         wxT("WMS GetMap URL"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *urlBoxSizer = new wxStaticBoxSizer(urlBox, wxHORIZONTAL);
  urlSizer->Add(urlBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *urlCtrl = new wxTextCtrl(this, ID_WMS_URL, Url,
                                        wxDefaultPosition, wxSize(700, 22),
                                        wxTE_READONLY);
  urlBoxSizer->Add(urlCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(nameSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *nameBox = new wxStaticBox(this, wxID_ANY,
                                         wxT("Layer Name"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
................................................................................
                                        wxDefaultPosition, wxDefaultSize);
  if (SwapXY == 0)
    swapCtrl->SetValue(false);
  else
    swapCtrl->SetValue(true);
  swapBoxSizer->Add(swapCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxStaticBox *bgColorBox = new wxStaticBox(this, wxID_ANY,
                                         wxT("Background Color"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
  wxBoxSizer *bgColorBoxSizer = new wxStaticBoxSizer(bgColorBox, wxHORIZONTAL);
  nameSizer->Add(bgColorBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxCheckBox *enableBgColorCtrl = new wxCheckBox(this, ID_WMS_ENABLE_BGCOLOR,
                                        wxT("Enable"),
                                        wxDefaultPosition, wxDefaultSize);

  if (BgColor == NULL)
  {
	  BgColorEnabled = false;
    enableBgColorCtrl->SetValue(false);
}
  else
  {
	  BgColorEnabled = true;
    enableBgColorCtrl->SetValue(true);
}
  bgColorBoxSizer->Add(enableBgColorCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);

  wxBitmap bgColorBmp;
  GetButtonBitmap(NULL, bgColorBmp);

  wxBitmapButton *bgColorCtrl = new wxBitmapButton(this, ID_WMS_BGCOLOR, bgColorBmp);
  if (BgColorEnabled)
  bgColorCtrl->Enable(false);
  else
  bgColorCtrl->Enable(true);
  bgColorBoxSizer->Add(bgColorCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// First row: WMS options
  wxBoxSizer *wmsSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(wmsSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString ver[4];
  ver[0] = wxT("WMS &1.0.0");
  ver[1] = wxT("WMS &1.1.0");
................................................................................
  Connect(wxID_CANCEL, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & WmsConfigDialog::OnQuit);
}

unsigned char WmsConfigDialog::ParseHex(const char *byte)
{
// parsing an Hex Byte
	unsigned char value = 0;
	switch (byte[0])
	{

		case '0': value = 16 * 0; break;


		case '1': value = 16 * 1; break;


		case '2': value = 16 * 2; break;


		case '3': value = 16 * 3; break;


		case '4': value = 16 * 4; break;


		case '5': value = 16 * 5; break;


		case '6': value = 16 * 6; break;


		case '7': value = 16 * 7; break;


		case '8': value = 16 * 8; break;


		case '9': value = 16 * 9; break;

		case 'A':

		case 'a': value = 16 * 10; break;

		case 'B':

		case 'b': value = 16 * 11; break;

		case 'C':

		case 'c': value = 16 * 12; break;

		case 'D':

		case 'd': value = 16 * 13; break;

		case 'E':

		case 'e': value = 16 * 14; break;

		case 'F':

		case 'f': value = 16 * 15; break;

	};
	switch (byte[1])
	{

		case '0': value += 16 * 0; break;


		case '1': value += 16 * 1; break;


		case '2': value += 16 * 2; break;


		case '3': value += 16 * 3; break;


		case '4': value += 16 * 4; break;


		case '5': value += 16 * 5; break;


		case '6': value += 16 * 6; break;


		case '7': value += 16 * 7; break;


		case '8': value += 16 * 8; break;


		case '9': value += 16 * 9; break;

		case 'A':

		case 'a': value += 16 * 10; break;

		case 'B':

		case 'b': value += 16 * 11; break;

		case 'C':

		case 'c': value += 16 * 12; break;

		case 'D':

		case 'd': value += 16 * 13; break;

		case 'E':

		case 'e': value += 16 * 14; break;

		case 'F':

		case 'f': value += 16 * 15; break;

	};
	return value;
}

void WmsConfigDialog::ParseBgColor(const char *color, unsigned char *red, unsigned char *green, unsigned char *blue)

{
// parsing an Hex RGB color
char byte[2];
		*red = 0x80;
		*green = 0x80;
		*blue = 0x80;
	if (color == NULL)
		return;
	if (strlen(color) != 6)
	return;
	
	byte[0] = *(color+0);
	byte[1] = *(color+1);
	*red = ParseHex(byte);
	byte[0] = *(color+2);
	byte[1] = *(color+3);
	*green = ParseHex(byte);
	byte[0] = *(color+4);
	byte[1] = *(color+5);
	*blue = ParseHex(byte);
}

void WmsConfigDialog::GetButtonBitmap(const char *bgcolor, wxBitmap & bmp)
{
// creating a Bitmap representing some Color
	unsigned char red;
	unsigned char green;
	unsigned char blue;
	ParseBgColor(bgcolor, &red, &green, &blue);
	wxColour color = wxColour(red, green, blue);
  bmp = wxBitmap(64, 24);
  wxMemoryDC *dc = new wxMemoryDC(bmp);
  if (bgcolor == NULL)
  dc->SetBrush(*wxTRANSPARENT_BRUSH);
  else
  dc->SetBrush(wxBrush(color));
  dc->DrawRectangle(-1, -1, 66, 26);
  delete dc;
}

void WmsConfigDialog::LoadData()
{
// loading the current configuration
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

      char *url = (char *) malloc((Url.Len() * 4) + 1);
      strcpy(url, Url.ToUTF8());
      char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
      strcpy(layer, LayerName.ToUTF8());
      sql = sqlite3_mprintf("SELECT version, srs, format, style, is_queryable, "
      "transparent, flip_axes, tiled, tile_width, tile_height, bgcolor "
      "FROM wms_getmap WHERE url = %Q AND layer_name = %Q", url, layer);

      free(url);
      free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
  {
	  Version = NULL;
	  RefSys = NULL;
	  ImageFormat = NULL;
	  Style = NULL;
	  Queryable = 0;
	  Opaque = 0;
	  SwapXY = 0;
	  Tiled = 0;
	  TileWidth = 0;
	  TileHeight = 0;
	  BgColor = NULL;
    return;
}

  for (int i = 1; i <= rows; i++)
    {
      // fetching data
      int len;
      const char *version = results[(i * columns) + 0];
      const char *ref_sys = results[(i * columns) + 1];
      const char *format = results[(i * columns) + 2];
      const char *style = results[(i * columns) + 3];
      Queryable = atoi(results[(i * columns) + 4]);
      if (atoi(results[(i * columns) + 5]) == 0)
      Opaque = 1;
      else
      Opaque = 0;
      if (atoi(results[(i * columns) + 6]) == 0)
      SwapXY = 0;
      else
      SwapXY = 1;
      if (atoi(results[(i * columns) + 7]) == 0)
      Tiled = 0;
      else
      Tiled = 1;
      TileWidth = atoi(results[(i * columns) + 8]);
      TileHeight = atoi(results[(i * columns) + 9]);
      const char *bgcolor = results[(i * columns) + 10];
      if (version == NULL)
      Version = NULL;
      else
      {
		  len = strlen(version);
		  Version = (char *)malloc(len+1);
		  strcpy(Version, version);
	  }
      if (ref_sys == NULL)
      RefSys = NULL;
      else
      {
		  len = strlen(ref_sys);
		  RefSys = (char *)malloc(len+1);
		  strcpy(RefSys, ref_sys);
	  }
      if (format == NULL)
      ImageFormat = NULL;
      else
      {
		  len = strlen(format);
		  ImageFormat = (char *)malloc(len+1);
		  strcpy(ImageFormat, format);
	  }
      if (style == NULL)
      Style = NULL;
      else
      {
		  len = strlen(style);
		  Style = (char *)malloc(len+1);
		  strcpy(Style, style);
	  }
      if (bgcolor == NULL)
      BgColor = NULL;
      else
      {
		  len = strlen(bgcolor);
		  BgColor = (char *)malloc(len+1);
		  strcpy(BgColor, bgcolor);
	  }
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::FindMaxVersion()
{
// identifying the Max WMS Version
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;
	  MaxVersion = NULL;

      char *url = (char *) malloc((Url.Len() * 4) + 1);
      strcpy(url, Url.ToUTF8());
      char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
      strcpy(layer, LayerName.ToUTF8());
	sql = sqlite3_mprintf("SELECT Max(s.value) FROM wms_getmap AS m "
	"JOIN wms_settings AS s ON (s.parent_id = m.id) "
	"WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'version'", url, layer);

      free(url);
      free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
      // fetching data
      int len;
      const char *version = results[(i * columns) + 0];
      if (version == NULL)
      MaxVersion = NULL;
      else
      {
		  len = strlen(version);
		  MaxVersion = (char *)malloc(len+1);
		  strcpy(MaxVersion, version);
	  }
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateRefSys(wxComboBox *crsList)
{
// populating the RefSys List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

      char *url = (char *) malloc((Url.Len() * 4) + 1);
      strcpy(url, Url.ToUTF8());
      char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
      strcpy(layer, LayerName.ToUTF8());
	sql = sqlite3_mprintf("SELECT s.srs FROM wms_getmap AS m "
	"JOIN wms_ref_sys AS s ON (s.parent_id = m.id) "
	"WHERE m.url = %Q AND m.layer_name = %Q ORDER BY s.id", url, layer);

      free(url);
      free(layer);






































  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
		// populating the list
      const char *crs = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(crs);
      crsList->Append(str);
      if (strcmp(RefSys, crs) == 0)
        crsList->SetSelection(i-1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateStyles(wxComboBox *stlList)
{
// populating the Styles List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

      char *url = (char *) malloc((Url.Len() * 4) + 1);
      strcpy(url, Url.ToUTF8());
      char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
      strcpy(layer, LayerName.ToUTF8());
	sql = sqlite3_mprintf("SELECT s.value FROM wms_getmap AS m "
	"JOIN wms_settings AS s ON (s.parent_id = m.id) "
	"WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'style' ORDER BY s.id", url, layer);

      free(url);
      free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
		// populating the list
      const char *style = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(style);
      stlList->Append(str);
      if (strcmp(Style, style) == 0)
        stlList->SetSelection(i-1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateImageFormats(wxComboBox *fmtList)
{
// populating the Image Formats List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

      char *url = (char *) malloc((Url.Len() * 4) + 1);
      strcpy(url, Url.ToUTF8());
      char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
      strcpy(layer, LayerName.ToUTF8());
	sql = sqlite3_mprintf("SELECT s.value FROM wms_getmap AS m "
	"JOIN wms_settings AS s ON (s.parent_id = m.id) "
	"WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'format' ORDER BY s.id", url, layer);
      free(url);
      free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
		// populating the list
      const char *format = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(format);
      fmtList->Append(str);
      if (strcmp(ImageFormat, format) == 0)
        fmtList->SetSelection(i-1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::OnCrsChanged(wxCommandEvent & WXUNUSED(event))
{
//
................................................................................
}

void WmsConfigDialog::OnBgColorEnabledChanged(wxCommandEvent & WXUNUSED(event))
{
//
// BgColor Enabled selection changed
//
wxBitmapButton *btn = (wxBitmapButton *) FindWindow(ID_WMS_BGCOLOR);
  if (BgColorEnabled == false)
  {
	  BgColor = (char *)malloc(6);
	  memcpy(BgColor, "ffffff", 6);
      wxBitmap bmp;
      GetButtonBitmap(BgColor, bmp);
      btn->SetBitmapLabel(bmp);
    BgColorEnabled = true;
    btn->Enable(true);
}
  else
  {
    BgColorEnabled = false;
    btn->Enable(false);
    if (BgColor != NULL)
    {
		free(BgColor);
		BgColor = NULL;
	}
}
}

void WmsConfigDialog::OnBgColorChanged(wxCommandEvent & WXUNUSED(event))
{
// BgColor selection
  wxColourData initColor;
  int ret;
	unsigned char red;
	unsigned char green;
	unsigned char blue;
	ParseBgColor(BgColor, &red, &green, &blue);
	wxColour color = wxColour(red, green, blue);
  initColor.SetChooseFull(false);
  initColor.SetColour(color);
  wxColourDialog colorDialog(this, &initColor);
  ret = colorDialog.ShowModal();
  if (ret == wxID_OK)
    {
      wxColourData colorData = colorDialog.GetColourData();
      color = colorData.GetColour();
      char byte[3];
      sprintf(byte, "%02x", color.Red());
      memcpy(BgColor, byte, 2);
      sprintf(byte, "%02x", color.Green());
      memcpy(BgColor+2, byte, 2);
      sprintf(byte, "%02x", color.Blue());
      memcpy(BgColor+4, byte, 2);
      wxBitmap bmp;
      GetButtonBitmap(BgColor, bmp);
      wxBitmapButton *bgColorCtrl = (wxBitmapButton *)FindWindow(ID_WMS_BGCOLOR);

      bgColorCtrl->SetBitmapLabel(bmp);
    }
}

void WmsConfigDialog::OnTiledChanged(wxCommandEvent & WXUNUSED(event))
{
//
................................................................................
  sqlite3_exec(SqliteHandle, "SELECT WMS_CreateTables()", NULL, NULL, NULL);
}

bool MyFrame::IsDefinedWmsGetCapabilities(const char *url)
{
// checking if a WMS GetCapabilities already exists
  int ret;
    char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;
  bool exists = false;


	sql = sqlite3_mprintf("SELECT Count(*) FROM wms_getcapabilities WHERE url = %Q", url);

  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns,
                      &err_msg);
  sqlite3_free(sql);
    if (ret != SQLITE_OK)
      {
      wxMessageBox(wxT("Check WMS GetCapabilities SQL error: ") + wxString::FromUTF8(err_msg),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free (err_msg);
	  return false;
      }
    if (rows != 1 || columns != 1)
	  return false;
    if (atoi (*(results + 1)) != 0)
    exists = true;
    sqlite3_free_table (results);
    return exists;
}

bool MyFrame::IsDefinedWmsGetMap(const char *getmap_url, const char *layer_name)
{
// checking if a WMS GetMap already exists
  int ret;
    char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;
  bool exists = false;



	sql = sqlite3_mprintf("SELECT Count(*) FROM wms_getmap WHERE url = %Q AND layer_name = %Q", getmap_url, layer_name);

  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns,
                      &err_msg);
  sqlite3_free(sql);
    if (ret != SQLITE_OK)
      {
      wxMessageBox(wxT("Check WMS GetMap SQL error: ") + wxString::FromUTF8(err_msg),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free (err_msg);
	  return false;
      }
    if (rows != 1 || columns != 1)
	  return false;
    if (atoi (*(results + 1)) != 0)
    exists = true;
    sqlite3_free_table (results);
    return exists;
}

bool MyFrame::RegisterWmsGetCapabilities(const char *url, const char *title,
                                            const char *abstract)
{
// attempting to (re)register a WMS GetCapabilities
  int ret;
    char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;

  if (title == NULL && abstract == NULL)
    sql = sqlite3_mprintf("SELECT WMS_RegisterGetCapabilities(%Q)", url);
................................................................................
      if (abstract == NULL)
        abstract = "";
      sql =
        sqlite3_mprintf("SELECT WMS_RegisterGetCapabilities(%Q, %Q, %Q)", url,
                        title, abstract);
    }
  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns,
                      &err_msg);
  sqlite3_free(sql);
    if (ret != SQLITE_OK)
      {
      wxMessageBox(wxT("WMS_RegisterGetCapabilities SQL error: ") + wxString::FromUTF8(err_msg),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free (err_msg);
	  return false;
      }
    if (rows != 1 || columns != 1)
      {
	  char dummy[80];
	  sprintf (dummy, "(rows=%d columns=%d)",  rows, columns);
      wxMessageBox(wxT("WMS_RegisterGetCapabilities invalid result: ") + wxString::FromUTF8(dummy),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free_table (results);
	  return false;
      }
    if (atoi (*(results + 1)) != 1)
      {
	  char dummy[80];
	  sprintf (dummy, "(%d)",  atoi (*(results + 1)));

      wxMessageBox(wxT("WMS_RegisterGetCapabilities invalid result: ") + wxString::FromUTF8(dummy),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free_table (results);
	  return false;
      }
    sqlite3_free_table (results);
    return true;
}

bool MyFrame::RegisterWmsGetMap(const char *getcapabilities_url,
                                const char *getmap_url, const char *layer_name,
                                const char *title, const char *abstract,
                                const char *version, const char *ref_sys,
                                const char *image_format, const char *style,
                                int transparent, int flip_axes,
                                int is_queryable, int tiled, int cached,
                                int tile_width, int tile_height,
                                const char *bgcolor)
{
// attempting to register a WMS GetMap
  int ret;
    char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;


  
  if (style == NULL)
    style = "";
  if (bgcolor == NULL)
    {
      if (title == NULL && abstract == NULL)
        sql =
          sqlite3_mprintf
          ("SELECT WMS_RegisterGetMap(%Q, %Q, %Q, %Q, %Q, %Q, %Q, %d, %d, %d, %d, %d, %d, %d)",
           getcapabilities_url, getmap_url, layer_name, version, ref_sys,
           image_format, style, transparent, flip_axes, is_queryable, tiled,
           cached, tile_width, tile_height);
      else
        {
          if (title == NULL)
            title = "";
          if (abstract == NULL)
            abstract = "";
          sql =

            sqlite3_mprintf
            ("SELECT WMS_RegisterGetMap(%Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %d, %d, %d, %d, %d, %d, %d)",
             getcapabilities_url, getmap_url, layer_name, title, abstract,
             version, ref_sys, image_format, style, transparent, flip_axes,
             is_queryable, tiled, cached, tile_width, tile_height);
        }
  } else
    {

      if (title == NULL)
        title = "";
      if (abstract == NULL)
        abstract = "";



      sql =
        sqlite3_mprintf
        ("SELECT WMS_RegisterGetMap(%Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %d, %d, %d, %d, %d, %d, %d, %Q)",
         getcapabilities_url, getmap_url, layer_name, title, abstract, version,
         ref_sys, image_format, style, transparent, flip_axes, is_queryable,
         tiled, cached, tile_width, tile_height, bgcolor);
    }



  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns,
                      &err_msg);
  sqlite3_free(sql);
    if (ret != SQLITE_OK)
      {
      wxMessageBox(wxT("WMS_RegisterGetMap SQL error: ") + wxString::FromUTF8(err_msg),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free (err_msg);
	  return false;
      }
    if (rows != 1 || columns != 1)
      {
	  char dummy[80];
	  sprintf (dummy, "(rows=%d columns=%d)",  rows, columns);
      wxMessageBox(wxT("WMS_RegisterGetMap invalid result: ") + wxString::FromUTF8(dummy),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free_table (results);
	  return false;
      }
    if (atoi (*(results + 1)) != 1)
      {
	  char dummy[80];
	  sprintf (dummy, "(%d)",  atoi (*(results + 1)));

      wxMessageBox(wxT("WMS_RegisterGetMap invalid result: ") + wxString::FromUTF8(dummy),

                   wxT("spatialite_gui"), wxOK | wxICON_ERROR, this);
	  sqlite3_free_table (results);
	  return false;
      }
    sqlite3_free_table (results);
  return true;
}

bool MyFrame::RegisterWmsSetting(const char *url, const char *layer_name,
                                 const char *key, const char *value,
                                 int is_default)
{
................................................................................
{
// attempting to register a WMS GetMap SRS
  char *sql;
  char *errMsg = NULL;
  int ret;
  sql =
    sqlite3_mprintf
    ("SELECT WMS_RegisterSRS(%Q, %Q, %Q, %1.8f, %1.8f, %1.8f, %1.8f, %d)", url,
     layer_name, ref_sys, minx, miny, maxx, maxy, is_default);
  ret = sqlite3_exec(SqliteHandle, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("Register WMS GetMap SRS error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  return true;
}
................................................................................

bool MyFrame::UnRegisterWmsGetMap(const char *url, const char *layer_name)
{
// attempting to unregister a WMS GetMap
  char *sql;
  char *errMsg = NULL;
  int ret;
  sql =
    sqlite3_mprintf
    ("SELECT WMS_UnRegisterGetMap(%Q, %Q)", url, layer_name);
  ret = sqlite3_exec(SqliteHandle, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("UnRegister WMS GetMap error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
................................................................................
      const char *layerName = dlg.GetName();
      const char *title = dlg.GetTitle();
      const char *abstract = dlg.GetAbstract();
      const char *version = dlg.GetVersion();
      const char *style = dlg.GetStyleName();
      const char *imageFormat = dlg.GetFormat();
      const char *refSys = dlg.GetCRS();

      int flipAxes = dlg.IsSwapXY();
      int isQueryable = dlg.IsQueryable();

      CreateWmsTables();
      if (IsDefinedWmsGetMap(getMapUrl, layerName) == true)
      {

      wxMessageBox(wxT("WMS_RegisterGetMap: already registered WMS layer: "),
                   wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
	  return;
	  }
      if (IsDefinedWmsGetCapabilities(url) == false)
      {
		if (!RegisterWmsGetCapabilities(url, serviceTitle, serviceAbstract))
        {
          free(url);
          return;
        }
		}
      if (!RegisterWmsGetMap
          (url, getMapUrl, layerName, title, abstract, version, refSys,
           imageFormat, style, transparent, flipAxes, isQueryable, tiled, 0,
           tileWidth, tileHeight, NULL))
        {
          free(url);
          return;
        }
      free(url);

      if (strcmp(version, "1.3.0") == 0)
................................................................................
      strcpy(url, urlStr.ToUTF8());
      wxString layerStr = dlg.GetLayerName();
      char *layer = (char *) malloc((layerStr.Len() * 4) + 1);
      strcpy(layer, layerStr.ToUTF8());
      UnRegisterWmsGetMap(url, layer);
      free(url);
      free(layer);
	}
}

void MyFrame::DoConfigureWMS()
{
//
// configuring an existing WMS Layer
//
  WmsLayerDialog dlg;
  dlg.Create(this);
  int ret = dlg.ShowModal();
  if (ret != wxID_OK)
  return;
  
  WmsConfigDialog dlg2;
  dlg2.Create(this, dlg.GetURL(), dlg.GetLayerName());
  ret = dlg2.ShowModal();
  if (ret == wxID_OK)
  {
  int transparent = 1;
  if (dlg2.IsOpaque())
  transparent = 0;
  int flip_axes = dlg2.IsSwapXY();
  int tiled = dlg2.IsTiled();
  int tile_width = dlg2.GetTileWidth();
  int tile_height = dlg2.GetTileHeight();
  const char *bgcolor = dlg2.GetBgColor();
// WMS_SetGetMapOptions(Text url, Text layer_name, Int transparent,
//                      Int flip_axes, Int is_queryable, Int tiled, 
//                      Int cached, Int tile_width, Int tile_height,
//                      Text bgcolor)
  }
}

WmsCatalogTree::WmsCatalogTree(WmsDialog * parent, wxSize sz, wxWindowID id):wxTreeCtrl(parent, id, wxDefaultPosition,
           sz)
{
//
// constructor: TREE control to manage Map Layers







|





|


|
|





|







 







|
|







 







|







 







|
>







 







|







 







|
|
|



|
|







 







|
|
|



|
|
>

|
|
|
<
|
|
|
|
|
|
>


>
|

|

|







 







|
|
|
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
|
|
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
>
|
|


|
>


|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|





|
|
|
|
|



|

|













|
|
|
|
|
|
|
>
|
|





|
|
|
|
|
|
|
|
|
|
|
|
|
|











|

|

|

|

|

|




|

|
|
|
|
|

|

|
|
|
|
|

|

|
|
|
|
|

|

|
|
|
|
|

|

|
|
|
|
|












|

|
|
|
|
|
|
|
>
|
|













|

|
|
|
|
|




|








|
|
|
|
|
|
|
>
|
|
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>









|
|
|
|
|
|




|

|






|
|
|
|
|
|
|
>
|
|









|
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<
<




|







 







|

|
|
|



|
|
<
|
|
|
|
|
|
|
|
|
|







|
|
|
|
|












|

|


|
>







 







|






>
|
>

|
<

|
|
|
>
|
|
|
|
|
|
|

|
|






|






>
>
|
>

|
<

|
|
|
>
|
|
|
|
|
|
|

|
|



|



|







 







|
<

|
|
|
>
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
|
|
<
>
|
>
|
|
|
|
|
|










|



|




>
>
|


<
<
<
<
<
<
<
<
<
<
<
|
|
|
|
<
>
|
<
<
<
<
<
|
<
>
|
<
<
<
>
>
>
|
|
|
|
|
|
<
>
>
>

|
<

|
|
|
>
|
|
|
|
|
|
|
|
|
>
|
|
|
|
|
|
|
<
>
|
>
|
|
|
|
|







 







|
|




|







 







<
<
|







 







>





|
>
|
|
|
|

|
|
|
|
|
|
|



|







 







|











|
|




|
|
|
|
|
|
|
|
|




|







1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
....
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
....
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
....
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
....
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
....
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
....
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718

1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
....
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101
2102
2103
2104
2105
2106
2107
2108
2109
2110
2111
2112
2113
2114
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125
2126
2127
2128
2129
2130
2131
2132
2133
2134
2135
2136
2137
2138
2139
2140
2141
2142
2143
2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
2163
2164
2165
2166
2167
2168
2169
2170
2171
2172
2173
2174
2175
2176
2177
2178
2179
2180
2181
2182
2183
2184
2185
2186
2187
2188
2189
2190
2191
2192
2193
2194
2195
2196
2197
2198
2199
2200
2201
2202
2203
2204
2205
2206
2207
2208
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233
2234
2235
2236
2237
2238
2239
2240
2241
2242
2243
2244
2245
2246
2247
2248
2249
2250
2251
2252
2253
2254
2255
2256
2257
2258
2259
2260
2261
2262
2263
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276
2277
2278
2279
2280
2281
2282
2283
2284
2285
2286
2287
2288
2289
2290
2291
2292
2293
2294
2295
2296
2297
2298
2299
2300
2301
2302
2303
2304
2305
2306
2307
2308
2309
2310
2311
2312
2313
2314
2315
2316
2317
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336





































2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
....
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409
2410
2411
2412
2413
2414
2415
2416

2417
2418
2419
2420
2421
2422
2423
2424
2425
2426
2427
2428
2429
2430
2431
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
....
2648
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664
2665
2666

2667
2668
2669
2670
2671
2672
2673
2674
2675
2676
2677
2678
2679
2680
2681
2682
2683
2684
2685
2686
2687
2688
2689
2690
2691
2692
2693
2694
2695
2696
2697
2698
2699
2700

2701
2702
2703
2704
2705
2706
2707
2708
2709
2710
2711
2712
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727
2728
2729
2730
....
2735
2736
2737
2738
2739
2740
2741
2742

2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2760
2761
2762
2763
2764

2765
2766
2767
2768
2769
2770
2771
2772
2773
2774
2775
2776
2777
2778
2779
2780
2781
2782
2783
2784
2785
2786
2787
2788
2789
2790
2791
2792
2793
2794
2795
2796
2797











2798
2799
2800
2801

2802
2803





2804

2805
2806



2807
2808
2809
2810
2811
2812
2813
2814
2815

2816
2817
2818
2819
2820

2821
2822
2823
2824
2825
2826
2827
2828
2829
2830
2831
2832
2833
2834
2835
2836
2837
2838
2839
2840
2841
2842

2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
....
2880
2881
2882
2883
2884
2885
2886
2887
2888
2889
2890
2891
2892
2893
2894
2895
2896
2897
2898
2899
2900
....
2901
2902
2903
2904
2905
2906
2907


2908
2909
2910
2911
2912
2913
2914
2915
....
3013
3014
3015
3016
3017
3018
3019
3020
3021
3022
3023
3024
3025
3026
3027
3028
3029
3030
3031
3032
3033
3034
3035
3036
3037
3038
3039
3040
3041
3042
3043
3044
3045
3046
3047
3048
3049
3050
....
3161
3162
3163
3164
3165
3166
3167
3168
3169
3170
3171
3172
3173
3174
3175
3176
3177
3178
3179
3180
3181
3182
3183
3184
3185
3186
3187
3188
3189
3190
3191
3192
3193
3194
3195
3196
3197
3198
3199
3200
3201
3202
3203
3204
3205
3206
  this->SetSizer(topSizer);
  wxBoxSizer *boxSizer = new wxBoxSizer(wxVERTICAL);
  topSizer->Add(boxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 5);
// the registered WMS GetMap List
  PopulateList();
  wxBoxSizer *listSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(listSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  WmsLayers = new wxGrid(this, ID_WMS_LIST, wxPoint(5, 5), wxSize(700, 200));
  WmsLayers->CreateGrid(Count, 2);
  WmsLayers->EnableEditing(false);
  WmsLayers->SetColLabelValue(0, wxT("Layer Name"));
  WmsLayers->SetColLabelValue(1, wxT("GetMap URL"));
  for (int i = 0; i < Count; i++)
    {
      WmsLayers->SetCellValue(i, 0, *(ListLayer + i));
      WmsLayers->SetCellValue(i, 1, *(ListUrl + i));
    }
  delete[]ListUrl;
  delete[]ListLayer;
  ListUrl = NULL;
  ListLayer = NULL;
  WmsLayers->SetRowLabelSize(wxGRID_AUTOSIZE);
  WmsLayers->AutoSize();
  WmsLayers->SetSize(700, 200);
  listSizer->Add(WmsLayers, 0, wxALIGN_RIGHT | wxALL, 5);
// selected WMS datasource group box
  wxBoxSizer *kkSizer = new wxBoxSizer(wxHORIZONTAL);
  boxSizer->Add(kkSizer, 0, wxALIGN_TOP | wxALL, 5);
  wxStaticBox *dsBox = new wxStaticBox(this, wxID_STATIC,
                                       wxT("WMS GetMap URL"),
                                       wxDefaultPosition,
................................................................................
// the Layer Name
  wxBoxSizer *layerSizer = new wxBoxSizer(wxHORIZONTAL);
  dsBoxSizer->Add(layerSizer, 0, wxALIGN_LEFT | wxALL, 5);
  wxStaticText *layerLabel =
    new wxStaticText(this, wxID_STATIC, wxT("&Layer Name:"));
  layerSizer->Add(layerLabel, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxTextCtrl *layerCtrl = new wxTextCtrl(this, ID_WMS_LAYER, wxT(""),
                                         wxDefaultPosition, wxSize(200, 22),
                                         wxTE_READONLY);
  layerSizer->Add(layerCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// Title / Abstract panel
  wxBoxSizer *title0BoxSizer = new wxBoxSizer(wxHORIZONTAL);
  dsBoxSizer->Add(title0BoxSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxStaticBox *titleBox = new wxStaticBox(this, wxID_ANY,
                                          wxT("Layer Title"),
                                          wxDefaultPosition,
................................................................................
// GetMap URL selection changed
//
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

  WmsLayers->Show(false);
  WmsLayers->ClearSelection();
  WmsLayers->SelectRow(CurrentEvtRow);
  WmsLayers->Show(true);
  LayerName = WmsLayers->GetCellValue(CurrentEvtRow, 0);
  URL = WmsLayers->GetCellValue(CurrentEvtRow, 1);

................................................................................
  layerCtrl->SetValue(LayerName);
  wxButton *okBtn = (wxButton *) FindWindow(wxID_OK);
  okBtn->Enable(true);

// preparing the SQL query
  sql =
    sqlite3_mprintf
    ("SELECT title, abstract FROM wms_getmap WHERE url = %Q AND layer_name = %Q",
     url, layer);
  free(url);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;
................................................................................
  MainFrame = parent;
  Url = url;
  LayerName = layer;
  if (wxDialog::Create(parent, wxID_ANY, wxT("WMS Layer configuration")) ==
      false)
    return false;
// populates individual controls
  LoadData();
  CreateControls();
// sets dialog sizer
  GetSizer()->Fit(this);
  GetSizer()->SetSizeHints(this);
// centers the dialog window
  Centre();
  return true;
................................................................................
  kkSizer->Add(lyrBox0Sizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
// Second row: Layer name
  wxBoxSizer *lyrBoxSizer = new wxBoxSizer(wxVERTICAL);
  lyrBox0Sizer->Add(lyrBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxBoxSizer *urlSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(urlSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *urlBox = new wxStaticBox(this, wxID_ANY,
                                        wxT("WMS GetMap URL"),
                                        wxDefaultPosition,
                                        wxDefaultSize);
  wxBoxSizer *urlBoxSizer = new wxStaticBoxSizer(urlBox, wxHORIZONTAL);
  urlSizer->Add(urlBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxTextCtrl *urlCtrl = new wxTextCtrl(this, ID_WMS_URL, Url,
                                       wxDefaultPosition, wxSize(700, 22),
                                       wxTE_READONLY);
  urlBoxSizer->Add(urlCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxBoxSizer *nameSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(nameSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 0);
  wxStaticBox *nameBox = new wxStaticBox(this, wxID_ANY,
                                         wxT("Layer Name"),
                                         wxDefaultPosition,
                                         wxDefaultSize);
................................................................................
                                        wxDefaultPosition, wxDefaultSize);
  if (SwapXY == 0)
    swapCtrl->SetValue(false);
  else
    swapCtrl->SetValue(true);
  swapBoxSizer->Add(swapCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxStaticBox *bgColorBox = new wxStaticBox(this, wxID_ANY,
                                            wxT("Background Color"),
                                            wxDefaultPosition,
                                            wxDefaultSize);
  wxBoxSizer *bgColorBoxSizer = new wxStaticBoxSizer(bgColorBox, wxHORIZONTAL);
  nameSizer->Add(bgColorBoxSizer, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
  wxCheckBox *enableBgColorCtrl = new wxCheckBox(this, ID_WMS_ENABLE_BGCOLOR,
                                                 wxT("Enable"),
                                                 wxDefaultPosition,
                                                 wxDefaultSize);
  if (BgColor == NULL)
    {
      BgColorEnabled = false;
      enableBgColorCtrl->SetValue(false);

  } else
    {
      BgColorEnabled = true;
      enableBgColorCtrl->SetValue(true);
    }
  bgColorBoxSizer->Add(enableBgColorCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL,
                       5);
  wxBitmap bgColorBmp;
  GetButtonBitmap(NULL, bgColorBmp);
  wxBitmapButton *bgColorCtrl =
    new wxBitmapButton(this, ID_WMS_BGCOLOR, bgColorBmp);
  if (BgColorEnabled)
    bgColorCtrl->Enable(false);
  else
    bgColorCtrl->Enable(true);
  bgColorBoxSizer->Add(bgColorCtrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
// First row: WMS options
  wxBoxSizer *wmsSizer = new wxBoxSizer(wxHORIZONTAL);
  lyrBoxSizer->Add(wmsSizer, 0, wxALIGN_CENTER_HORIZONTAL | wxALL, 0);
  wxString ver[4];
  ver[0] = wxT("WMS &1.0.0");
  ver[1] = wxT("WMS &1.1.0");
................................................................................
  Connect(wxID_CANCEL, wxEVT_COMMAND_BUTTON_CLICKED,
          (wxObjectEventFunction) & WmsConfigDialog::OnQuit);
}

unsigned char WmsConfigDialog::ParseHex(const char *byte)
{
// parsing an Hex Byte
  unsigned char value = 0;
  switch (byte[0])
    {
      case '0':
        value = 16 * 0;
        break;
      case '1':
        value = 16 * 1;
        break;
      case '2':
        value = 16 * 2;
        break;
      case '3':
        value = 16 * 3;
        break;
      case '4':
        value = 16 * 4;
        break;
      case '5':
        value = 16 * 5;
        break;
      case '6':
        value = 16 * 6;
        break;
      case '7':
        value = 16 * 7;
        break;
      case '8':
        value = 16 * 8;
        break;
      case '9':
        value = 16 * 9;
        break;
      case 'A':
      case 'a':
        value = 16 * 10;
        break;
      case 'B':
      case 'b':
        value = 16 * 11;
        break;
      case 'C':
      case 'c':
        value = 16 * 12;
        break;
      case 'D':
      case 'd':
        value = 16 * 13;
        break;
      case 'E':
      case 'e':
        value = 16 * 14;
        break;
      case 'F':
      case 'f':
        value = 16 * 15;
        break;
    };
  switch (byte[1])
    {
      case '0':
        value += 16 * 0;
        break;
      case '1':
        value += 16 * 1;
        break;
      case '2':
        value += 16 * 2;
        break;
      case '3':
        value += 16 * 3;
        break;
      case '4':
        value += 16 * 4;
        break;
      case '5':
        value += 16 * 5;
        break;
      case '6':
        value += 16 * 6;
        break;
      case '7':
        value += 16 * 7;
        break;
      case '8':
        value += 16 * 8;
        break;
      case '9':
        value += 16 * 9;
        break;
      case 'A':
      case 'a':
        value += 16 * 10;
        break;
      case 'B':
      case 'b':
        value += 16 * 11;
        break;
      case 'C':
      case 'c':
        value += 16 * 12;
        break;
      case 'D':
      case 'd':
        value += 16 * 13;
        break;
      case 'E':
      case 'e':
        value += 16 * 14;
        break;
      case 'F':
      case 'f':
        value += 16 * 15;
        break;
    };
  return value;
}

void WmsConfigDialog::ParseBgColor(const char *color, unsigned char *red,
                                   unsigned char *green, unsigned char *blue)
{
// parsing an Hex RGB color
  char byte[2];
  *red = 0x80;
  *green = 0x80;
  *blue = 0x80;
  if (color == NULL)
    return;
  if (strlen(color) != 6)
    return;

  byte[0] = *(color + 0);
  byte[1] = *(color + 1);
  *red = ParseHex(byte);
  byte[0] = *(color + 2);
  byte[1] = *(color + 3);
  *green = ParseHex(byte);
  byte[0] = *(color + 4);
  byte[1] = *(color + 5);
  *blue = ParseHex(byte);
}

void WmsConfigDialog::GetButtonBitmap(const char *bgcolor, wxBitmap & bmp)
{
// creating a Bitmap representing some Color
  unsigned char red;
  unsigned char green;
  unsigned char blue;
  ParseBgColor(bgcolor, &red, &green, &blue);
  wxColour color = wxColour(red, green, blue);
  bmp = wxBitmap(64, 24);
  wxMemoryDC *dc = new wxMemoryDC(bmp);
  if (bgcolor == NULL)
    dc->SetBrush(*wxTRANSPARENT_BRUSH);
  else
    dc->SetBrush(wxBrush(color));
  dc->DrawRectangle(-1, -1, 66, 26);
  delete dc;
}

void WmsConfigDialog::LoadData()
{
// loading the current configuration
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

  char *url = (char *) malloc((Url.Len() * 4) + 1);
  strcpy(url, Url.ToUTF8());
  char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
  strcpy(layer, LayerName.ToUTF8());
  sql = sqlite3_mprintf("SELECT version, srs, format, style, is_queryable, "
                        "transparent, flip_axes, tiled, tile_width, tile_height, bgcolor "
                        "FROM wms_getmap WHERE url = %Q AND layer_name = %Q",
                        url, layer);
  free(url);
  free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      Version = NULL;
      RefSys = NULL;
      ImageFormat = NULL;
      Style = NULL;
      Queryable = 0;
      Opaque = 0;
      SwapXY = 0;
      Tiled = 0;
      TileWidth = 0;
      TileHeight = 0;
      BgColor = NULL;
      return;
    }

  for (int i = 1; i <= rows; i++)
    {
      // fetching data
      int len;
      const char *version = results[(i * columns) + 0];
      const char *ref_sys = results[(i * columns) + 1];
      const char *format = results[(i * columns) + 2];
      const char *style = results[(i * columns) + 3];
      Queryable = atoi(results[(i * columns) + 4]);
      if (atoi(results[(i * columns) + 5]) == 0)
        Opaque = 1;
      else
        Opaque = 0;
      if (atoi(results[(i * columns) + 6]) == 0)
        SwapXY = 0;
      else
        SwapXY = 1;
      if (atoi(results[(i * columns) + 7]) == 0)
        Tiled = 0;
      else
        Tiled = 1;
      TileWidth = atoi(results[(i * columns) + 8]);
      TileHeight = atoi(results[(i * columns) + 9]);
      const char *bgcolor = results[(i * columns) + 10];
      if (version == NULL)
        Version = NULL;
      else
        {
          len = strlen(version);
          Version = (char *) malloc(len + 1);
          strcpy(Version, version);
        }
      if (ref_sys == NULL)
        RefSys = NULL;
      else
        {
          len = strlen(ref_sys);
          RefSys = (char *) malloc(len + 1);
          strcpy(RefSys, ref_sys);
        }
      if (format == NULL)
        ImageFormat = NULL;
      else
        {
          len = strlen(format);
          ImageFormat = (char *) malloc(len + 1);
          strcpy(ImageFormat, format);
        }
      if (style == NULL)
        Style = NULL;
      else
        {
          len = strlen(style);
          Style = (char *) malloc(len + 1);
          strcpy(Style, style);
        }
      if (bgcolor == NULL)
        BgColor = NULL;
      else
        {
          len = strlen(bgcolor);
          BgColor = (char *) malloc(len + 1);
          strcpy(BgColor, bgcolor);
        }
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::FindMaxVersion()
{
// identifying the Max WMS Version
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;
  MaxVersion = NULL;

  char *url = (char *) malloc((Url.Len() * 4) + 1);
  strcpy(url, Url.ToUTF8());
  char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
  strcpy(layer, LayerName.ToUTF8());
  sql = sqlite3_mprintf("SELECT Max(s.value) FROM wms_getmap AS m "
                        "JOIN wms_settings AS s ON (s.parent_id = m.id) "
                        "WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'version'",
                        url, layer);
  free(url);
  free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
      // fetching data
      int len;
      const char *version = results[(i * columns) + 0];
      if (version == NULL)
        MaxVersion = NULL;
      else
        {
          len = strlen(version);
          MaxVersion = (char *) malloc(len + 1);
          strcpy(MaxVersion, version);
        }
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateRefSys(wxComboBox * crsList)
{
// populating the RefSys List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

  char *url = (char *) malloc((Url.Len() * 4) + 1);
  strcpy(url, Url.ToUTF8());
  char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
  strcpy(layer, LayerName.ToUTF8());
  sql = sqlite3_mprintf("SELECT s.srs FROM wms_getmap AS m "
                        "JOIN wms_ref_sys AS s ON (s.parent_id = m.id) "
                        "WHERE m.url = %Q AND m.layer_name = %Q ORDER BY s.id",
                        url, layer);
  free(url);
  free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
      // populating the list
      const char *crs = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(crs);
      crsList->Append(str);
      if (strcmp(RefSys, crs) == 0)
        crsList->SetSelection(i - 1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateStyles(wxComboBox * stlList)
{
// populating the Styles List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

  char *url = (char *) malloc((Url.Len() * 4) + 1);
  strcpy(url, Url.ToUTF8());
  char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
  strcpy(layer, LayerName.ToUTF8());
  sql = sqlite3_mprintf("SELECT s.value FROM wms_getmap AS m "
                        "JOIN wms_settings AS s ON (s.parent_id = m.id) "
                        "WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'style' ORDER BY s.id",
                        url, layer);
  free(url);
  free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
      // populating the list
      const char *style = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(style);
      stlList->Append(str);
      if (strcmp(Style, style) == 0)
        stlList->SetSelection(i - 1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::PopulateImageFormats(wxComboBox * fmtList)
{
// populating the Image Formats List
  int ret;
  char *sql;
  char **results;
  int rows;
  int columns;

  char *url = (char *) malloc((Url.Len() * 4) + 1);
  strcpy(url, Url.ToUTF8());
  char *layer = (char *) malloc((LayerName.Len() * 4) + 1);
  strcpy(layer, LayerName.ToUTF8());
  sql = sqlite3_mprintf("SELECT s.value FROM wms_getmap AS m "
                        "JOIN wms_settings AS s ON (s.parent_id = m.id) "
                        "WHERE m.url = %Q AND m.layer_name = %Q AND s.key = 'format' ORDER BY s.id",
                        url, layer);
  free(url);
  free(layer);
  ret =
    sqlite3_get_table(MainFrame->GetSqlite(), sql, &results, &rows, &columns,
                      NULL);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    return;

  for (int i = 1; i <= rows; i++)
    {
      // populating the list





































      const char *format = results[(i * columns) + 0];
      wxString str = wxString::FromUTF8(format);
      fmtList->Append(str);
      if (strcmp(ImageFormat, format) == 0)
        fmtList->SetSelection(i - 1);
    }
  sqlite3_free_table(results);
}

void WmsConfigDialog::OnCrsChanged(wxCommandEvent & WXUNUSED(event))
{
//
................................................................................
}

void WmsConfigDialog::OnBgColorEnabledChanged(wxCommandEvent & WXUNUSED(event))
{
//
// BgColor Enabled selection changed
//
  wxBitmapButton *btn = (wxBitmapButton *) FindWindow(ID_WMS_BGCOLOR);
  if (BgColorEnabled == false)
    {
      BgColor = (char *) malloc(6);
      memcpy(BgColor, "ffffff", 6);
      wxBitmap bmp;
      GetButtonBitmap(BgColor, bmp);
      btn->SetBitmapLabel(bmp);
      BgColorEnabled = true;
      btn->Enable(true);

  } else
    {
      BgColorEnabled = false;
      btn->Enable(false);
      if (BgColor != NULL)
        {
          free(BgColor);
          BgColor = NULL;
        }
    }
}

void WmsConfigDialog::OnBgColorChanged(wxCommandEvent & WXUNUSED(event))
{
// BgColor selection
  wxColourData initColor;
  int ret;
  unsigned char red;
  unsigned char green;
  unsigned char blue;
  ParseBgColor(BgColor, &red, &green, &blue);
  wxColour color = wxColour(red, green, blue);
  initColor.SetChooseFull(false);
  initColor.SetColour(color);
  wxColourDialog colorDialog(this, &initColor);
  ret = colorDialog.ShowModal();
  if (ret == wxID_OK)
    {
      wxColourData colorData = colorDialog.GetColourData();
      color = colorData.GetColour();
      char byte[3];
      sprintf(byte, "%02x", color.Red());
      memcpy(BgColor, byte, 2);
      sprintf(byte, "%02x", color.Green());
      memcpy(BgColor + 2, byte, 2);
      sprintf(byte, "%02x", color.Blue());
      memcpy(BgColor + 4, byte, 2);
      wxBitmap bmp;
      GetButtonBitmap(BgColor, bmp);
      wxBitmapButton *bgColorCtrl =
        (wxBitmapButton *) FindWindow(ID_WMS_BGCOLOR);
      bgColorCtrl->SetBitmapLabel(bmp);
    }
}

void WmsConfigDialog::OnTiledChanged(wxCommandEvent & WXUNUSED(event))
{
//
................................................................................
  sqlite3_exec(SqliteHandle, "SELECT WMS_CreateTables()", NULL, NULL, NULL);
}

bool MyFrame::IsDefinedWmsGetCapabilities(const char *url)
{
// checking if a WMS GetCapabilities already exists
  int ret;
  char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;
  bool exists = false;

  sql =
    sqlite3_mprintf("SELECT Count(*) FROM wms_getcapabilities WHERE url = %Q",
                    url);
  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns, &err_msg);

  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("Check WMS GetCapabilities SQL error: ") +
                   wxString::FromUTF8(err_msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(err_msg);
      return false;
    }
  if (rows != 1 || columns != 1)
    return false;
  if (atoi(*(results + 1)) != 0)
    exists = true;
  sqlite3_free_table(results);
  return exists;
}

bool MyFrame::IsDefinedWmsGetMap(const char *getmap_url, const char *layer_name)
{
// checking if a WMS GetMap already exists
  int ret;
  char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;
  bool exists = false;

  sql =
    sqlite3_mprintf
    ("SELECT Count(*) FROM wms_getmap WHERE url = %Q AND layer_name = %Q",
     getmap_url, layer_name);
  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns, &err_msg);

  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("Check WMS GetMap SQL error: ") +
                   wxString::FromUTF8(err_msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(err_msg);
      return false;
    }
  if (rows != 1 || columns != 1)
    return false;
  if (atoi(*(results + 1)) != 0)
    exists = true;
  sqlite3_free_table(results);
  return exists;
}

bool MyFrame::RegisterWmsGetCapabilities(const char *url, const char *title,
                                         const char *abstract)
{
// attempting to (re)register a WMS GetCapabilities
  int ret;
  char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;

  if (title == NULL && abstract == NULL)
    sql = sqlite3_mprintf("SELECT WMS_RegisterGetCapabilities(%Q)", url);
................................................................................
      if (abstract == NULL)
        abstract = "";
      sql =
        sqlite3_mprintf("SELECT WMS_RegisterGetCapabilities(%Q, %Q, %Q)", url,
                        title, abstract);
    }
  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns, &err_msg);

  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("WMS_RegisterGetCapabilities SQL error: ") +
                   wxString::FromUTF8(err_msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(err_msg);
      return false;
    }
  if (rows != 1 || columns != 1)
    {
      char dummy[80];
      sprintf(dummy, "(rows=%d columns=%d)", rows, columns);
      wxMessageBox(wxT("WMS_RegisterGetCapabilities invalid result: ") +
                   wxString::FromUTF8(dummy), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free_table(results);
      return false;
    }
  if (atoi(*(results + 1)) != 1)
    {
      char dummy[80];

      sprintf(dummy, "(%d)", atoi(*(results + 1)));
      wxMessageBox(wxT("WMS_RegisterGetCapabilities invalid result: ") +
                   wxString::FromUTF8(dummy), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free_table(results);
      return false;
    }
  sqlite3_free_table(results);
  return true;
}

bool MyFrame::RegisterWmsGetMap(const char *getcapabilities_url,
                                const char *getmap_url, const char *layer_name,
                                const char *title, const char *abstract,
                                const char *version, const char *ref_sys,
                                const char *image_format, const char *style,
                                int transparent, int flip_axes,
                                int is_queryable, int tiled, int cached,
                                int tile_width, int tile_height,
                                const char *bgcolor, const char *getfeatureinfo)
{
// attempting to register a WMS GetMap
  int ret;
  char *err_msg = NULL;
  char *sql;
  char **results;
  int rows;
  int columns;
  char *xbgcolor;
  char *xgetfeatureinfo;

  if (style == NULL)
    style = "";











  if (title == NULL)
    title = "";
  if (abstract == NULL)
    abstract = "";

  if (bgcolor == NULL)
    xbgcolor = sqlite3_mprintf("NULL");





  else

    xbgcolor = sqlite3_mprintf("%Q", bgcolor);
  if (getfeatureinfo == NULL)



    xgetfeatureinfo = sqlite3_mprintf("NULL");
  else
    xgetfeatureinfo = sqlite3_mprintf("%Q", getfeatureinfo);
  sql =
    sqlite3_mprintf
    ("SELECT WMS_RegisterGetMap(%Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %Q, %d, %d, %d, %d, %d, %d, %s, %d, %s)",
     getcapabilities_url, getmap_url, layer_name, title, abstract,
     version, ref_sys, image_format, style, transparent, flip_axes,
     tiled, cached, tile_width, tile_height, xbgcolor, is_queryable,

     xgetfeatureinfo);
  sqlite3_free(xbgcolor);
  sqlite3_free(xgetfeatureinfo);
  ret =
    sqlite3_get_table(SqliteHandle, sql, &results, &rows, &columns, &err_msg);

  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("WMS_RegisterGetMap SQL error: ") +
                   wxString::FromUTF8(err_msg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(err_msg);
      return false;
    }
  if (rows != 1 || columns != 1)
    {
      char dummy[80];
      sprintf(dummy, "(rows=%d columns=%d)", rows, columns);
      wxMessageBox(wxT("WMS_RegisterGetMap invalid result: ") +
                   wxString::FromUTF8(dummy), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free_table(results);
      return false;
    }
  if (atoi(*(results + 1)) != 1)
    {
      char dummy[80];

      sprintf(dummy, "(%d)", atoi(*(results + 1)));
      wxMessageBox(wxT("WMS_RegisterGetMap invalid result: ") +
                   wxString::FromUTF8(dummy), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free_table(results);
      return false;
    }
  sqlite3_free_table(results);
  return true;
}

bool MyFrame::RegisterWmsSetting(const char *url, const char *layer_name,
                                 const char *key, const char *value,
                                 int is_default)
{
................................................................................
{
// attempting to register a WMS GetMap SRS
  char *sql;
  char *errMsg = NULL;
  int ret;
  sql =
    sqlite3_mprintf
    ("SELECT WMS_RegisterRefSys(%Q, %Q, %Q, %1.8f, %1.8f, %1.8f, %1.8f, %d)",
     url, layer_name, ref_sys, minx, miny, maxx, maxy, is_default);
  ret = sqlite3_exec(SqliteHandle, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("Register WMS GetMap RefSys error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
      sqlite3_free(errMsg);
      return false;
    }
  return true;
}
................................................................................

bool MyFrame::UnRegisterWmsGetMap(const char *url, const char *layer_name)
{
// attempting to unregister a WMS GetMap
  char *sql;
  char *errMsg = NULL;
  int ret;


  sql = sqlite3_mprintf("SELECT WMS_UnRegisterGetMap(%Q, %Q)", url, layer_name);
  ret = sqlite3_exec(SqliteHandle, sql, NULL, NULL, &errMsg);
  sqlite3_free(sql);
  if (ret != SQLITE_OK)
    {
      wxMessageBox(wxT("UnRegister WMS GetMap error: ") +
                   wxString::FromUTF8(errMsg), wxT("spatialite_gui"),
                   wxOK | wxICON_ERROR, this);
................................................................................
      const char *layerName = dlg.GetName();
      const char *title = dlg.GetTitle();
      const char *abstract = dlg.GetAbstract();
      const char *version = dlg.GetVersion();
      const char *style = dlg.GetStyleName();
      const char *imageFormat = dlg.GetFormat();
      const char *refSys = dlg.GetCRS();
      const char *getFeatureInfo = dlg.GetURL_GetFeatureInfo_Get();
      int flipAxes = dlg.IsSwapXY();
      int isQueryable = dlg.IsQueryable();

      CreateWmsTables();
      if (IsDefinedWmsGetMap(getMapUrl, layerName) == true)
        {
          wxMessageBox(wxT
                       ("WMS_RegisterGetMap: already registered WMS layer: "),
                       wxT("spatialite_gui"), wxOK | wxICON_WARNING, this);
          return;
        }
      if (IsDefinedWmsGetCapabilities(url) == false)
        {
          if (!RegisterWmsGetCapabilities(url, serviceTitle, serviceAbstract))
            {
              free(url);
              return;
            }
        }
      if (!RegisterWmsGetMap
          (url, getMapUrl, layerName, title, abstract, version, refSys,
           imageFormat, style, transparent, flipAxes, isQueryable, tiled, 0,
           tileWidth, tileHeight, NULL, getFeatureInfo))
        {
          free(url);
          return;
        }
      free(url);

      if (strcmp(version, "1.3.0") == 0)
................................................................................
      strcpy(url, urlStr.ToUTF8());
      wxString layerStr = dlg.GetLayerName();
      char *layer = (char *) malloc((layerStr.Len() * 4) + 1);
      strcpy(layer, layerStr.ToUTF8());
      UnRegisterWmsGetMap(url, layer);
      free(url);
      free(layer);
    }
}

void MyFrame::DoConfigureWMS()
{
//
// configuring an existing WMS Layer
//
  WmsLayerDialog dlg;
  dlg.Create(this);
  int ret = dlg.ShowModal();
  if (ret != wxID_OK)
    return;

  WmsConfigDialog dlg2;
  dlg2.Create(this, dlg.GetURL(), dlg.GetLayerName());
  ret = dlg2.ShowModal();
  if (ret == wxID_OK)
    {
      int transparent = 1;
      if (dlg2.IsOpaque())
        transparent = 0;
      int flip_axes = dlg2.IsSwapXY();
      int tiled = dlg2.IsTiled();
      int tile_width = dlg2.GetTileWidth();
      int tile_height = dlg2.GetTileHeight();
      const char *bgcolor = dlg2.GetBgColor();
// WMS_SetGetMapOptions(Text url, Text layer_name, Int transparent,
//                      Int flip_axes, Int is_queryable, Int tiled, 
//                      Int cached, Int tile_width, Int tile_height,
//                      Text bgcolor)
    }
}

WmsCatalogTree::WmsCatalogTree(WmsDialog * parent, wxSize sz, wxWindowID id):wxTreeCtrl(parent, id, wxDefaultPosition,
           sz)
{
//
// constructor: TREE control to manage Map Layers

Changes to aclocal.m4.

16
17
18
19
20
21
22
23
24
25

26
27


28
29
30
31
32

33
34
35
36
37

38
39
40
41


42
43
44
45

46





















47
48







49
50
51
52
53
54
55
..
63
64
65
66
67
68
69
70
71
72
73



74
75
76

77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92


93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

108
109
110
111
112
113
114
115
116
117
118
119
120
121



122
123
124
125
126
127
128
129
130
131
132
133
134
...
174
175
176
177
178
179
180
181
182
183






















184
185


186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205


206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226


227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
  [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],,
[m4_warning([this file was generated for autoconf 2.69.
You have another version of autoconf.  It may work, but is not guaranteed to.
If you have problems, you may need to regenerate the build system entirely.
To do so, use the procedure documented by the package, typically 'autoreconf'.])])

# pkg.m4 - Macros to locate and utilise pkg-config.            -*- Autoconf -*-
# serial 1 (pkg-config-0.24)
# 

# Copyright © 2004 Scott James Remnant <scott@netsplit.com>.
#


# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#

# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# General Public License for more details.
#

# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#


# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
# configuration script generated by Autoconf, you may include it under
# the same distribution terms that you use for the rest of that program.























# PKG_PROG_PKG_CONFIG([MIN-VERSION])
# ----------------------------------







AC_DEFUN([PKG_PROG_PKG_CONFIG],
[m4_pattern_forbid([^_?PKG_[A-Z_]+$])
m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$])
m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$])
AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility])
AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path])
AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path])
................................................................................
	if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
		AC_MSG_RESULT([yes])
	else
		AC_MSG_RESULT([no])
		PKG_CONFIG=""
	fi
fi[]dnl
])# PKG_PROG_PKG_CONFIG

# PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
#



# Check to see whether a particular set of modules exists.  Similar
# to PKG_CHECK_MODULES(), but does not set variables or print errors.
#

# Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG])
# only at the first occurence in configure.ac, so if the first place
# it's called might be skipped (such as if it is within an "if", you
# have to call PKG_CHECK_EXISTS manually
# --------------------------------------------------------------
AC_DEFUN([PKG_CHECK_EXISTS],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
if test -n "$PKG_CONFIG" && \
    AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then
  m4_default([$2], [:])
m4_ifvaln([$3], [else
  $3])dnl
fi])

# _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES])
# ---------------------------------------------


m4_define([_PKG_CONFIG],
[if test -n "$$1"; then
    pkg_cv_[]$1="$$1"
 elif test -n "$PKG_CONFIG"; then
    PKG_CHECK_EXISTS([$3],
                     [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null`
		      test "x$?" != "x0" && pkg_failed=yes ],
		     [pkg_failed=yes])
 else
    pkg_failed=untried
fi[]dnl
])# _PKG_CONFIG

# _PKG_SHORT_ERRORS_SUPPORTED
# -----------------------------

AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])
if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
        _pkg_short_errors_supported=yes
else
        _pkg_short_errors_supported=no
fi[]dnl
])# _PKG_SHORT_ERRORS_SUPPORTED


# PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
# [ACTION-IF-NOT-FOUND])
#
#



# Note that if there is a possibility the first call to
# PKG_CHECK_MODULES might not happen, you should be sure to include an
# explicit call to PKG_PROG_PKG_CONFIG in your configure.ac
#
#
# --------------------------------------------------------------
AC_DEFUN([PKG_CHECK_MODULES],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl
AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl

pkg_failed=no
AC_MSG_CHECKING([for $1])
................................................................................
        ])
else
	$1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS
	$1[]_LIBS=$pkg_cv_[]$1[]_LIBS
        AC_MSG_RESULT([yes])
	$3
fi[]dnl
])# PKG_CHECK_MODULES
























# PKG_INSTALLDIR(DIRECTORY)
# -------------------------


# Substitutes the variable pkgconfigdir as the location where a module
# should install pkg-config .pc files. By default the directory is
# $libdir/pkgconfig, but the default can be changed by passing
# DIRECTORY. The user can override through the --with-pkgconfigdir
# parameter.
AC_DEFUN([PKG_INSTALLDIR],
[m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])])
m4_pushdef([pkg_description],
    [pkg-config installation directory @<:@]pkg_default[@:>@])
AC_ARG_WITH([pkgconfigdir],
    [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],,
    [with_pkgconfigdir=]pkg_default)
AC_SUBST([pkgconfigdir], [$with_pkgconfigdir])
m4_popdef([pkg_default])
m4_popdef([pkg_description])
]) dnl PKG_INSTALLDIR


# PKG_NOARCH_INSTALLDIR(DIRECTORY)
# -------------------------


# Substitutes the variable noarch_pkgconfigdir as the location where a
# module should install arch-independent pkg-config .pc files. By
# default the directory is $datadir/pkgconfig, but the default can be
# changed by passing DIRECTORY. The user can override through the
# --with-noarch-pkgconfigdir parameter.
AC_DEFUN([PKG_NOARCH_INSTALLDIR],
[m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])])
m4_pushdef([pkg_description],
    [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@])
AC_ARG_WITH([noarch-pkgconfigdir],
    [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],,
    [with_noarch_pkgconfigdir=]pkg_default)
AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir])
m4_popdef([pkg_default])
m4_popdef([pkg_description])
]) dnl PKG_NOARCH_INSTALLDIR


# PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE,
# [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
# -------------------------------------------


# Retrieves the value of the pkg-config variable for the given module.
AC_DEFUN([PKG_CHECK_VAR],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl

_PKG_CONFIG([$1], [variable="][$3]["], [$2])
AS_VAR_COPY([$1], [pkg_cv_][$1])

AS_VAR_IF([$1], [""], [$5], [$4])dnl
])# PKG_CHECK_VAR

# Copyright (C) 2002-2014 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.








|
|
<
>
|
<
>
>
|
|
|
|
<
>
|
|
|
|
<
>
|
|
|
<
>
>
|
|
|
|
>

>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
|
>
>
>
>
>
>
>







 







|

|
<
>
>
>
|
|
<
>
|
|
|
|
<









|
|
>
>











|

|
|
>







|


|
|
<
<
>
>
>
|
|
|
<
<
<







 







|


>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
|
>
>
|
|
|
|
|










|


|
|
>
>
|
|
|
|
|










|


|
|
|
>
>
|








|







16
17
18
19
20
21
22
23
24

25
26

27
28
29
30
31
32

33
34
35
36
37

38
39
40
41

42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
..
94
95
96
97
98
99
100
101
102
103

104
105
106
107
108

109
110
111
112
113

114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154


155
156
157
158
159
160



161
162
163
164
165
166
167
...
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
  [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],,
[m4_warning([this file was generated for autoconf 2.69.
You have another version of autoconf.  It may work, but is not guaranteed to.
If you have problems, you may need to regenerate the build system entirely.
To do so, use the procedure documented by the package, typically 'autoreconf'.])])

dnl pkg.m4 - Macros to locate and utilise pkg-config.   -*- Autoconf -*-
dnl serial 11 (pkg-config-0.29.1)

dnl
dnl Copyright © 2004 Scott James Remnant <scott@netsplit.com>.

dnl Copyright © 2012-2015 Dan Nicholson <dbn.lists@gmail.com>
dnl
dnl This program is free software; you can redistribute it and/or modify
dnl it under the terms of the GNU General Public License as published by
dnl the Free Software Foundation; either version 2 of the License, or
dnl (at your option) any later version.

dnl
dnl This program is distributed in the hope that it will be useful, but
dnl WITHOUT ANY WARRANTY; without even the implied warranty of
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
dnl General Public License for more details.

dnl
dnl You should have received a copy of the GNU General Public License
dnl along with this program; if not, write to the Free Software
dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA

dnl 02111-1307, USA.
dnl
dnl As a special exception to the GNU General Public License, if you
dnl distribute this file as part of a program that contains a
dnl configuration script generated by Autoconf, you may include it under
dnl the same distribution terms that you use for the rest of that
dnl program.

dnl PKG_PREREQ(MIN-VERSION)
dnl -----------------------
dnl Since: 0.29
dnl
dnl Verify that the version of the pkg-config macros are at least
dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's
dnl installed version of pkg-config, this checks the developer's version
dnl of pkg.m4 when generating configure.
dnl
dnl To ensure that this macro is defined, also add:
dnl m4_ifndef([PKG_PREREQ],
dnl     [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])])
dnl
dnl See the "Since" comment for each macro you use to see what version
dnl of the macros you require.
m4_defun([PKG_PREREQ],
[m4_define([PKG_MACROS_VERSION], [0.29.1])
m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1,
    [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])])
])dnl PKG_PREREQ

dnl PKG_PROG_PKG_CONFIG([MIN-VERSION])
dnl ----------------------------------
dnl Since: 0.16
dnl
dnl Search for the pkg-config tool and set the PKG_CONFIG variable to
dnl first found in the path. Checks that the version of pkg-config found
dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is
dnl used since that's the first version where most current features of
dnl pkg-config existed.
AC_DEFUN([PKG_PROG_PKG_CONFIG],
[m4_pattern_forbid([^_?PKG_[A-Z_]+$])
m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$])
m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$])
AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility])
AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path])
AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path])
................................................................................
	if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
		AC_MSG_RESULT([yes])
	else
		AC_MSG_RESULT([no])
		PKG_CONFIG=""
	fi
fi[]dnl
])dnl PKG_PROG_PKG_CONFIG

dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])

dnl -------------------------------------------------------------------
dnl Since: 0.18
dnl
dnl Check to see whether a particular set of modules exists. Similar to
dnl PKG_CHECK_MODULES(), but does not set variables or print errors.

dnl
dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG])
dnl only at the first occurence in configure.ac, so if the first place
dnl it's called might be skipped (such as if it is within an "if", you
dnl have to call PKG_CHECK_EXISTS manually

AC_DEFUN([PKG_CHECK_EXISTS],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
if test -n "$PKG_CONFIG" && \
    AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then
  m4_default([$2], [:])
m4_ifvaln([$3], [else
  $3])dnl
fi])

dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES])
dnl ---------------------------------------------
dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting
dnl pkg_failed based on the result.
m4_define([_PKG_CONFIG],
[if test -n "$$1"; then
    pkg_cv_[]$1="$$1"
 elif test -n "$PKG_CONFIG"; then
    PKG_CHECK_EXISTS([$3],
                     [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null`
		      test "x$?" != "x0" && pkg_failed=yes ],
		     [pkg_failed=yes])
 else
    pkg_failed=untried
fi[]dnl
])dnl _PKG_CONFIG

dnl _PKG_SHORT_ERRORS_SUPPORTED
dnl ---------------------------
dnl Internal check to see if pkg-config supports short errors.
AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])
if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
        _pkg_short_errors_supported=yes
else
        _pkg_short_errors_supported=no
fi[]dnl
])dnl _PKG_SHORT_ERRORS_SUPPORTED


dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
dnl   [ACTION-IF-NOT-FOUND])


dnl --------------------------------------------------------------
dnl Since: 0.4.0
dnl
dnl Note that if there is a possibility the first call to
dnl PKG_CHECK_MODULES might not happen, you should be sure to include an
dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac



AC_DEFUN([PKG_CHECK_MODULES],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl
AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl

pkg_failed=no
AC_MSG_CHECKING([for $1])
................................................................................
        ])
else
	$1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS
	$1[]_LIBS=$pkg_cv_[]$1[]_LIBS
        AC_MSG_RESULT([yes])
	$3
fi[]dnl
])dnl PKG_CHECK_MODULES


dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
dnl   [ACTION-IF-NOT-FOUND])
dnl ---------------------------------------------------------------------
dnl Since: 0.29
dnl
dnl Checks for existence of MODULES and gathers its build flags with
dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags
dnl and VARIABLE-PREFIX_LIBS from --libs.
dnl
dnl Note that if there is a possibility the first call to
dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to
dnl include an explicit call to PKG_PROG_PKG_CONFIG in your
dnl configure.ac.
AC_DEFUN([PKG_CHECK_MODULES_STATIC],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
_save_PKG_CONFIG=$PKG_CONFIG
PKG_CONFIG="$PKG_CONFIG --static"
PKG_CHECK_MODULES($@)
PKG_CONFIG=$_save_PKG_CONFIG[]dnl
])dnl PKG_CHECK_MODULES_STATIC


dnl PKG_INSTALLDIR([DIRECTORY])
dnl -------------------------
dnl Since: 0.27
dnl
dnl Substitutes the variable pkgconfigdir as the location where a module
dnl should install pkg-config .pc files. By default the directory is
dnl $libdir/pkgconfig, but the default can be changed by passing
dnl DIRECTORY. The user can override through the --with-pkgconfigdir
dnl parameter.
AC_DEFUN([PKG_INSTALLDIR],
[m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])])
m4_pushdef([pkg_description],
    [pkg-config installation directory @<:@]pkg_default[@:>@])
AC_ARG_WITH([pkgconfigdir],
    [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],,
    [with_pkgconfigdir=]pkg_default)
AC_SUBST([pkgconfigdir], [$with_pkgconfigdir])
m4_popdef([pkg_default])
m4_popdef([pkg_description])
])dnl PKG_INSTALLDIR


dnl PKG_NOARCH_INSTALLDIR([DIRECTORY])
dnl --------------------------------
dnl Since: 0.27
dnl
dnl Substitutes the variable noarch_pkgconfigdir as the location where a
dnl module should install arch-independent pkg-config .pc files. By
dnl default the directory is $datadir/pkgconfig, but the default can be
dnl changed by passing DIRECTORY. The user can override through the
dnl --with-noarch-pkgconfigdir parameter.
AC_DEFUN([PKG_NOARCH_INSTALLDIR],
[m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])])
m4_pushdef([pkg_description],
    [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@])
AC_ARG_WITH([noarch-pkgconfigdir],
    [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],,
    [with_noarch_pkgconfigdir=]pkg_default)
AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir])
m4_popdef([pkg_default])
m4_popdef([pkg_description])
])dnl PKG_NOARCH_INSTALLDIR


dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE,
dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
dnl -------------------------------------------
dnl Since: 0.28
dnl
dnl Retrieves the value of the pkg-config variable for the given module.
AC_DEFUN([PKG_CHECK_VAR],
[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl

_PKG_CONFIG([$1], [variable="][$3]["], [$2])
AS_VAR_COPY([$1], [pkg_cv_][$1])

AS_VAR_IF([$1], [""], [$5], [$4])dnl
])dnl PKG_CHECK_VAR

# Copyright (C) 2002-2014 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.

Changes to icons/Makefile.am.

12
13
14
15
16
17
18
19






	sql_script.xpm srids.xpm statistics.xpm tables.xpm table.xpm \
	topo_geo.xpm topo_net.xpm tmp_table.xpm tmp_view.xpm trigger.xpm \
	vacuum.xpm view.xpm virtdbf.xpm virtshp.xpm virttxt.xpm virtxl.xpm \
	vtable.xpm attach.xpm sql_log.xpm db_status.xpm loadxml.xpm \
	checkgeom.xpm sanegeom.xpm wfs.xpm wms.xpm dxf.xpm connect_ro.xpm \
	coverage.xpm coverage_tiles.xpm security_relaxed.xpm layer.xpm \
	security_lock.xpm security_rdonly.xpm vector.xpm sql_erase.xpm \
	clone.xpm gps_pics.xpm filter.xpm AttributionDisclaimer.txt













|
>
>
>
>
>
>
12
13
14
15
16
17
18
19
20
21
22
23
24
25
	sql_script.xpm srids.xpm statistics.xpm tables.xpm table.xpm \
	topo_geo.xpm topo_net.xpm tmp_table.xpm tmp_view.xpm trigger.xpm \
	vacuum.xpm view.xpm virtdbf.xpm virtshp.xpm virttxt.xpm virtxl.xpm \
	vtable.xpm attach.xpm sql_log.xpm db_status.xpm loadxml.xpm \
	checkgeom.xpm sanegeom.xpm wfs.xpm wms.xpm dxf.xpm connect_ro.xpm \
	coverage.xpm coverage_tiles.xpm security_relaxed.xpm layer.xpm \
	security_lock.xpm security_rdonly.xpm vector.xpm sql_erase.xpm \
	clone.xpm gps_pics.xpm filter.xpm AttributionDisclaimer.txt \
	icon_map.xpm crosshair.xpm wms_off.xpm vector_off.xpm \
	coverage_off.xpm center.xpm identify.xpm zoom_in.xpm zoom_out.xpm \
	user_scale.xpm pan.xpm printer.xpm 	map_root.xpm map_go.xpm \
	map_edit.xpm map_add.xpm linestrings_on.xpm linestrings_off.xpm \
	points_on.xpm points_off.xpm polygons_on.xpm polygons_off.xpm \
	topo_geo_off.xpm topo_net_off.xpm

Changes to icons/Makefile.in.

277
278
279
280
281
282
283
284






285
286
287
288
289
290
291
	sql_script.xpm srids.xpm statistics.xpm tables.xpm table.xpm \
	topo_geo.xpm topo_net.xpm tmp_table.xpm tmp_view.xpm trigger.xpm \
	vacuum.xpm view.xpm virtdbf.xpm virtshp.xpm virttxt.xpm virtxl.xpm \
	vtable.xpm attach.xpm sql_log.xpm db_status.xpm loadxml.xpm \
	checkgeom.xpm sanegeom.xpm wfs.xpm wms.xpm dxf.xpm connect_ro.xpm \
	coverage.xpm coverage_tiles.xpm security_relaxed.xpm layer.xpm \
	security_lock.xpm security_rdonly.xpm vector.xpm sql_erase.xpm \
	clone.xpm gps_pics.xpm filter.xpm AttributionDisclaimer.txt







all: all-am

.SUFFIXES:
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am  $(am__configure_deps)
	@for dep in $?; do \
	  case '$(am__configure_deps)' in \







|
>
>
>
>
>
>







277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
	sql_script.xpm srids.xpm statistics.xpm tables.xpm table.xpm \
	topo_geo.xpm topo_net.xpm tmp_table.xpm tmp_view.xpm trigger.xpm \
	vacuum.xpm view.xpm virtdbf.xpm virtshp.xpm virttxt.xpm virtxl.xpm \
	vtable.xpm attach.xpm sql_log.xpm db_status.xpm loadxml.xpm \
	checkgeom.xpm sanegeom.xpm wfs.xpm wms.xpm dxf.xpm connect_ro.xpm \
	coverage.xpm coverage_tiles.xpm security_relaxed.xpm layer.xpm \
	security_lock.xpm security_rdonly.xpm vector.xpm sql_erase.xpm \
	clone.xpm gps_pics.xpm filter.xpm AttributionDisclaimer.txt \
	icon_map.xpm crosshair.xpm wms_off.xpm vector_off.xpm \
	coverage_off.xpm center.xpm identify.xpm zoom_in.xpm zoom_out.xpm \
	user_scale.xpm pan.xpm printer.xpm 	map_root.xpm map_go.xpm \
	map_edit.xpm map_add.xpm linestrings_on.xpm linestrings_off.xpm \
	points_on.xpm points_off.xpm polygons_on.xpm polygons_off.xpm \
	topo_geo_off.xpm topo_net_off.xpm

all: all-am

.SUFFIXES:
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am  $(am__configure_deps)
	@for dep in $?; do \
	  case '$(am__configure_deps)' in \

Added icons/center.xpm.







































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/* XPM */
static const char * center_xpm[] = {
"16 16 96 2",
"  	c None",
". 	c #74C768",
"+ 	c #73C667",
"@ 	c #72C566",
"# 	c #71C365",
"$ 	c #66B65C",
"% 	c #64B45B",
"& 	c #62B259",
"* 	c #60AF58",
"= 	c #5EAD56",
"- 	c #A9D8A1",
"; 	c #A7D69E",
"> 	c #67B45F",
", 	c #94C88D",
"' 	c #95C98E",
") 	c #5CAA54",
"! 	c #A5D69D",
"~ 	c #9BD192",
"{ 	c #87CA7E",
"] 	c #6EC063",
"^ 	c #62B159",
"/ 	c #7EBD76",
"( 	c #86C07E",
"_ 	c #90C58A",
": 	c #5AA852",
"< 	c #72C466",
"[ 	c #75C56B",
"} 	c #8CCC83",
"| 	c #A4D39B",
"1 	c #84C77B",
"2 	c #6BBC60",
"3 	c #61B159",
"4 	c #7DBD75",
"5 	c #93C78C",
"6 	c #73B66D",
"7 	c #59A752",
"8 	c #57A550",
"9 	c #70C365",
"0 	c #6DBF63",
"a 	c #89C980",
"b 	c #82C479",
"c 	c #69B95F",
"d 	c #5FAE57",
"e 	c #75B86E",
"f 	c #73B56C",
"g 	c #55A24E",
"h 	c #6ABB60",
"i 	c #68B95E",
"j 	c #5BA953",
"k 	c #5DAC55",
"l 	c #509C4A",
"m 	c #4E9948",
"n 	c #63B35A",
"o 	c #73B66C",
"p 	c #71B46A",
"q 	c #4F9B4A",
"r 	c #64A75F",
"s 	c #67A862",
"t 	c #4A9545",
"u 	c #479143",
"v 	c #61B058",
"w 	c #8AC084",
"x 	c #74B56E",
"y 	c #57A450",
"z 	c #4D9948",
"A 	c #61A55D",
"B 	c #79B375",
"C 	c #63A45F",
"D 	c #4C9447",
"E 	c #458F41",
"F 	c #5FAD56",
"G 	c #8AC083",
"H 	c #7AB773",
"I 	c #73B46C",
"J 	c #499445",
"K 	c #5EA05A",
"L 	c #64A65E",
"M 	c #70AD6C",
"N 	c #448D40",
"O 	c #5CAB54",
"P 	c #89BF83",
"Q 	c #83BB7D",
"R 	c #5BA654",
"S 	c #469042",
"T 	c #71AD6D",
"U 	c #73AE6E",
"V 	c #428C3F",
"W 	c #5AA853",
"X 	c #58A651",
"Y 	c #56A34F",
"Z 	c #54A14E",
"` 	c #529F4C",
" .	c #458E41",
"..	c #438D40",
"+.	c #428B3F",
"@.	c #418A3E",
". . + @ #             $ % & * = ",
". - ; #                 > , ' ) ",
"+ ! ~ { ]             ^ / ( _ : ",
"< [ } | 1 2         3 4 5 6 7 8 ",
"9   0 a b c         d e f 7   g ",
"      h i             j 7       ",
"                                ",
"                                ",
"                                ",
"                                ",
"      d k             l m       ",
"n   d o p 7         q r s t   u ",
"v d o w x y         z A B C D E ",
"F G H I y             J K L M N ",
"O P Q R                 S T U V ",
"W X Y Z `             S  ...+.@."};

Added icons/coverage_off.xpm.



































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/* XPM */
static const char * coverage_off_xpm[] = {
"16 16 62 1",
" 	g None",
".	g #B1B1B1",
"+	g #AFAFAF",
"@	g #A9A9A9",
"#	g #A4A4A4",
"$	g #A8A8A8",
"%	g #ADADAD",
"&	g #B0B0B0",
"*	g #ECECEC",
"=	g #F4F4F4",
"-	g #F5F5F5",
";	g #F2F2F2",
">	g #EEEEEE",
",	g #ABABAB",
"'	g #F3F3F3",
")	g #AEAEAE",
"!	g #BFBFBF",
"~	g #C3C3C3",
"{	g #C1C1C1",
"]	g #B4B4B4",
"^	g #929292",
"/	g #979797",
"(	g #999999",
"_	g #F1F1F1",
":	g #A5A5A5",
"<	g #B2B2B2",
"[	g #BEBEBE",
"}	g #C2C2C2",
"|	g #BABABA",
"1	g #B6B6B6",
"2	g #B8B8B8",
"3	g #909090",
"4	g #9B9B9B",
"5	g #EFEFEF",
"6	g #B7B7B7",
"7	g #B3B3B3",
"8	g #878787",
"9	g #9E9E9E",
"0	g #B5B5B5",
"a	g #A7A7A7",
"b	g #ACACAC",
"c	g #858585",
"d	g #A0A0A0",
"e	g #AAAAAA",
"f	g #A1A1A1",
"g	g #8E8E8E",
"h	g #A3A3A3",
"i	g #EDEDED",
"j	g #9F9F9F",
"k	g #9C9C9C",
"l	g #898989",
"m	g #9D9D9D",
"n	g #A6A6A6",
"o	g #7D7D7D",
"p	g #7F7F7F",
"q	g #F0F0F0",
"r	g #959595",
"s	g #8A8A8A",
"t	g #D4D4D4",
"u	g #CDCDCD",
"v	g #C5C5C5",
"w	g #D2D2D2",
"                ",
" .+@#########$% ",
" &*=--------;>, ",
" @'.)@!~{]^/(_@ ",
" :-<%[}|12%345@ ",
" :-]@}67+%.895@ ",
" :=0a[<b@abcd>@ ",
" :'1e]<@:@fghi@ ",
" :;2.j#b@klmni@ ",
" #_|2)o8cpf,@i@ ",
" #q(/ro:#sl8ci@ ",
" h_tttuv<wttt*$ ",
" #_tttttttttt*$ ",
" @5'=''';;;;'>, ",
" %b@$$$$$$$$$,% ",
"                "};

Added icons/crosshair.xpm.













































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/* XPM */
static const char * crosshair_xpm[] = {
"16 16 3 1",
" 	c None",
".	c #FFFFFF",
"+	c #000000",
"+.             +",
" +.           +.",
"  +.         +. ",
"   +.       +.  ",
"    +.     +.   ",
"     +.   +.    ",
"      +. +.     ",
"       .+.      ",
"      .+.       ",
"     .+ .+      ",
"    .+   .+     ",
"   .+     .+    ",
"  .+       .+   ",
" .+         .+  ",
".+           .+ ",
"+             .+"};

Added icons/icon_map.xpm.

























































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/* XPM */
static const char * icon_map_xpm[] = {
"32 32 9 1",
" 	c None",
".	c #645F31",
"+	c #6E4914",
"@	c #5CAF57",
"#	c #689164",
"$	c #8B5F22",
"%	c #888782",
"&	c #9D9C9A",
"*	c #C2C1BF",
"                             *  ",
"                            *** ",
"                          &**** ",
"                         &&**** ",
"                        &&***** ",
"                       &&&***** ",
"                       &&&***** ",
"                      &&&&******",
"                      &&&&******",
"                #####&&&&&&*****",
"              #######&&&&&***** ",
"             #####@#&&&&&&***** ",
"            ####@@@##@@##*****  ",
"            ##@@@@@@@@@@@&****  ",
"           ###@@@@@@@@@@@#***   ",
"           #@@@@@@@@@@@@@@&**   ",
"          .#@@@@@@@@@@@@@@#*    ",
"        .+.#@@@@@@@@@@@@@@#.+.  ",
"       +++##@@@@@@@@@@@@@@@#+++ ",
"      +++ ###@@@@@@@@@@@@@@# ++ ",
"      +++ ###@@@@@@@@@@@@@## +++",
"      +++ ###@@@@@@@@@@@@@#  ++$",
"      ++++##@@@@@@@@@@@@@@# ++$$",
"       $++.##@@@@@@@@@@@@##++$$ ",
"        $$++.#@@@@@@@@@##.++$$  ",
"         $$$++++......+++$$$$   ",
"        %%%+$$$$$$$$+$$$$$$     ",
"       %&%%&&%..+$$$$+..        ",
"      %%%&&****########         ",
"     %%%&&&&*&*                 ",
"  &&  %&&*&&                    ",
"        &                       "};

Added icons/identify.xpm.





























































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
/* XPM */
static const char * identify_xpm[] = {
"16 16 139 2",
"  	c None",
". 	c #C0D8F7",
"+ 	c #BED7F6",
"@ 	c #BCD5F4",
"# 	c #B9D3F3",
"$ 	c #BDD6F5",
"% 	c #DCE9F9",
"& 	c #DDE8F6",
"* 	c #DAE5F3",
"= 	c #DCE7F5",
"- 	c #D6E4F5",
"; 	c #ACC8EB",
"> 	c #B8D2F2",
", 	c #DFEAF7",
"' 	c #D0DEEE",
") 	c #A7C1E3",
"! 	c #89AED8",
"~ 	c #86ACD7",
"{ 	c #9CBBDD",
"] 	c #C7D6EB",
"^ 	c #D9E6F3",
"/ 	c #9FBEE3",
"( 	c #B3CEEF",
"_ 	c #DDE9F6",
": 	c #C6D8EC",
"< 	c #81ACD7",
"[ 	c #9ABBDC",
"} 	c #E3ECF6",
"| 	c #E2ECF5",
"1 	c #AEC8E4",
"2 	c #7BA7D2",
"3 	c #BACEE6",
"4 	c #D5E2F1",
"5 	c #91B3DB",
"6 	c #D4E3F4",
"7 	c #CDDCEF",
"8 	c #7EA8D5",
"9 	c #77A0D0",
"0 	c #F5F8FB",
"a 	c #F5F8FC",
"b 	c #81A8D1",
"c 	c #7BA4CF",
"d 	c #C3D5EA",
"e 	c #C2D4EA",
"f 	c #A3C1E6",
"g 	c #D9E5F3",
"h 	c #9EBBDF",
"i 	c #75A0CF",
"j 	c #729ECD",
"k 	c #E3EBF5",
"l 	c #B4CBE4",
"m 	c #BFD3E7",
"n 	c #F6F8FB",
"o 	c #BFD3E5",
"p 	c #6B98C4",
"q 	c #91B4D6",
"r 	c #D2E0EE",
"s 	c #789ECC",
"t 	c #99B9E0",
"u 	c #DAE5F2",
"v 	c #7EA6D1",
"w 	c #719DCC",
"x 	c #6C9AC7",
"y 	c #6B98C5",
"z 	c #B6CCE2",
"A 	c #EEF3F8",
"B 	c #E8EEF6",
"C 	c #A1BDD9",
"D 	c #6894C2",
"E 	c #719BC5",
"F 	c #D6E2F0",
"G 	c #6C95C5",
"H 	c #8FB0D9",
"I 	c #D9E4F2",
"J 	c #7AA5D1",
"K 	c #6B99C5",
"L 	c #6A97C4",
"M 	c #6996C4",
"N 	c #F2F6FA",
"O 	c #E1EAF3",
"P 	c #6D95C2",
"Q 	c #658FBE",
"R 	c #648FBE",
"S 	c #6D95C0",
"T 	c #D5E3EF",
"U 	c #618CBF",
"V 	c #84A7D3",
"W 	c #D3E1EF",
"X 	c #95B5D9",
"Y 	c #6C98C7",
"Z 	c #6995C3",
"` 	c #6793C1",
" .	c #6690BF",
"..	c #638BBB",
"+.	c #638AB9",
"@.	c #628AB8",
"#.	c #86A7CB",
"$.	c #CCDCEA",
"%.	c #5783B8",
"&.	c #B9CCE4",
"*.	c #C5D6EA",
"=.	c #7199C7",
"-.	c #ECF1F7",
";.	c #EAF0F6",
">.	c #5F89B7",
",.	c #6389B5",
"'.	c #BBCEE2",
").	c #A6BDD9",
"!.	c #6A92C3",
"~.	c #C9D8EA",
"{.	c #BACDE3",
"].	c #6B94C0",
"^.	c #628CBA",
"/.	c #94B0CF",
"(.	c #6187B2",
"_.	c #AAC0DA",
":.	c #C0D1E4",
"<.	c #4675AE",
"[.	c #5B87BB",
"}.	c #C4D5E7",
"|.	c #BFD2E5",
"1.	c #85A6C9",
"2.	c #678EB8",
"3.	c #658AB6",
"4.	c #80A1C5",
"5.	c #BACCE0",
"6.	c #BED0E3",
"7.	c #4070AB",
"8.	c #4E7CB3",
"9.	c #A3BBD7",
"0.	c #CADAE9",
"a.	c #D1E0EC",
"b.	c #C8D8E8",
"c.	c #9CB5D3",
"d.	c #3A6CA7",
"e.	c #3F70AA",
"f.	c #3C6DA8",
"g.	c #3A6BA7",
"h.	c #3769A5",
"                                ",
"            . + @ #             ",
"        $ % & * * = - ;         ",
"      > , ' ) ! ~ { ] ^ /       ",
"    ( _ : < [ } | 1 2 3 4 5     ",
"    6 7 8 9 0 a a 0 b c d e     ",
"  f g h i j k l m n o p q r s   ",
"  t u v w x y z A B C D E F G   ",
"  H I J K L M N O P Q R S T U   ",
"  V W X Y Z `  . ...+.@.#.$.%.  ",
"    &.*.=. . .-.;.>.>.,.'.).    ",
"    !.~.{.].^././.>.(._.:.<.    ",
"      [.}.|.1.2.3.4.5.6.7.      ",
"        8.9.0.a.a.b.c.d.        ",
"            e.f.g.h.            ",
"                                "};

Added icons/linestrings_off.xpm.













































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/* XPM */
static const char * linestrings_off_xpm[] = {
"16 16 3 1",
" 	c None",
".	c #5A5A5A",
"+	c #6E6E6E",
"                ",
"             .+ ",
"             .+ ",
"             .+ ",
"             .+ ",
"            .+  ",
"    .+      .+  ",
"   .+ .+    .+  ",
"   .+  .+   .+  ",
"  .+    .+ .+   ",
"  .+     .+.+   ",
" .+       .+    ",
" .+             ",
" .+             ",
" .+             ",
"                "};

Added icons/linestrings_on.xpm.













































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/* XPM */
static const char * linestrings_on_xpm[] = {
"16 16 3 1",
" 	c None",
".	c #0000FF",
"+	c #0080FF",
"                ",
"             .+ ",
"             .+ ",
"             .+ ",
"             .+ ",
"            .+  ",
"    .+      .+  ",
"   .+ .+    .+  ",
"   .+  .+   .+  ",
"  .+    .+ .+   ",
"  .+     .+.+   ",
" .+       .+    ",
" .+             ",
" .+             ",
" .+             ",
"                "};

Added icons/map_add.xpm.



























































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
/* XPM */
static const char * map_add_xpm[] = {
"16 16 202 2",
"  	c None",
". 	c #4A5449",
"+ 	c #5D6A5C",
"@ 	c #606D5F",
"# 	c #616D5F",
"$ 	c #616D60",
"% 	c #626D60",
"& 	c #636D60",
"* 	c #5F6A5E",
"= 	c #4B544A",
"- 	c #FBFCFB",
"; 	c #FCFEFC",
"> 	c #F8FCF7",
", 	c #F8FCF8",
"' 	c #F9FCF7",
") 	c #EEF7EC",
"! 	c #EEF7ED",
"~ 	c #EDF6EF",
"{ 	c #ECF4EE",
"] 	c #EBF4EB",
"^ 	c #F9F99D",
"/ 	c #EDB46C",
"( 	c #FE7162",
"_ 	c #E9E780",
": 	c #F4F48C",
"< 	c #CDCD52",
"[ 	c #A4C2EC",
"} 	c #8AADDD",
"| 	c #97BAEB",
"1 	c #80A7DD",
"2 	c #83ABE2",
"3 	c #75A0DA",
"4 	c #D4EAD9",
"5 	c #646E61",
"6 	c #EAEA8A",
"7 	c #DEDD72",
"8 	c #F06556",
"9 	c #DF9F56",
"0 	c #E8E873",
"a 	c #C1C146",
"b 	c #A5BBBB",
"c 	c #83A4D0",
"d 	c #8EB0DE",
"e 	c #7A9ED1",
"f 	c #7AA2D6",
"g 	c #7198CF",
"h 	c #D5EBD7",
"i 	c #646E62",
"j 	c #F9F99F",
"k 	c #EAE985",
"l 	c #FAD384",
"m 	c #F05A52",
"n 	c #F7F287",
"o 	c #D7DA60",
"p 	c #CAD598",
"q 	c #9CB7E0",
"r 	c #A9C7ED",
"s 	c #94B3E0",
"t 	c #98B8E6",
"u 	c #8CAEDE",
"v 	c #D6ECD7",
"w 	c #646E63",
"x 	c #EAEA90",
"y 	c #DEDD78",
"z 	c #EAE981",
"A 	c #E26B4E",
"B 	c #EE9D63",
"C 	c #D7D75E",
"D 	c #C9CB5B",
"E 	c #97B0D4",
"F 	c #9FBAE2",
"G 	c #8FACD6",
"H 	c #91B0DB",
"I 	c #86A7D4",
"J 	c #D7EDD6",
"K 	c #F9F9A6",
"L 	c #EAE98B",
"M 	c #FAF899",
"N 	c #EBD378",
"O 	c #FF6B65",
"P 	c #EADC77",
"Q 	c #DEDF70",
"R 	c #B5C5C1",
"S 	c #BAD1F1",
"T 	c #A9C1E5",
"U 	c #AEC7EA",
"V 	c #A1BDE4",
"W 	c #646F63",
"X 	c #F1F19F",
"Y 	c #DFDD81",
"Z 	c #EBEA8A",
"` 	c #DEDE75",
" .	c #EE9165",
"..	c #E27E55",
"+.	c #DDDC68",
"@.	c #B7BF77",
"#.	c #B2C8E5",
"$.	c #A3BADA",
"%.	c #A6BCDE",
"&.	c #9FB7D9",
"*.	c #D8EDD6",
"=.	c #646F64",
"-.	c #FAFAAF",
";.	c #EBEB94",
">.	c #FAF9A2",
",.	c #F3ED95",
"'.	c #EB5F59",
").	c #E6D987",
"!.	c #D1D25C",
"~.	c #C9DBDC",
"{.	c #CDD4AC",
"].	c #D4DA97",
"^.	c #CED177",
"/.	c #DBEFD4",
"(.	c #656F64",
"_.	c #EDEBA4",
":.	c #DFDF8D",
"<.	c #EBEB97",
"[.	c #B7CF72",
"}.	c #99CA74",
"|.	c #B08356",
"1.	c #D77860",
"2.	c #B6C351",
"3.	c #9FB575",
"4.	c #729758",
"5.	c #668E4F",
"6.	c #608542",
"7.	c #95AF7E",
"8.	c #666F64",
"9.	c #636E61",
"0.	c #F9FCF8",
"a.	c #FBFBBC",
"b.	c #DFE79D",
"c.	c #BBE193",
"d.	c #97C977",
"e.	c #A9DA89",
"f.	c #98C675",
"g.	c #F37C71",
"h.	c #8A9E5E",
"i.	c #81AB61",
"j.	c #B4D495",
"k.	c #D0E6BA",
"l.	c #8FBB6A",
"m.	c #578F2D",
"n.	c #4C6D3B",
"o.	c #F8FBF7",
"p.	c #C4DE9B",
"q.	c #93C373",
"r.	c #9FCF80",
"s.	c #8FC16F",
"t.	c #9DCE7E",
"u.	c #8CBF6E",
"v.	c #BBA470",
"w.	c #618644",
"x.	c #B1D390",
"y.	c #B1D692",
"z.	c #FFFFFF",
"A.	c #8CBC65",
"B.	c #8FBC67",
"C.	c #386B1B",
"D.	c #AFDB96",
"E.	c #9AC97F",
"F.	c #AAD88F",
"G.	c #97C87A",
"H.	c #A9D68A",
"I.	c #ACA25F",
"J.	c #D78855",
"K.	c #4C7B31",
"L.	c #B6D49C",
"M.	c #B2D295",
"N.	c #376B19",
"O.	c #EFF8EE",
"P.	c #BCDBA4",
"Q.	c #A6CA8C",
"R.	c #B1D598",
"S.	c #A1C986",
"T.	c #C0AD74",
"U.	c #C68756",
"V.	c #B6C283",
"W.	c #3D6E1E",
"X.	c #8BBA62",
"Y.	c #87BA60",
"Z.	c #87B960",
"`.	c #396B1B",
" +	c #606A5F",
".+	c #ECF5EB",
"++	c #D7EDD4",
"@+	c #D7EED4",
"#+	c #D8EED4",
"$+	c #D8EED5",
"%+	c #D9EED5",
"&+	c #DAEFD6",
"*+	c #86AB74",
"=+	c #538C28",
"-+	c #8DBA64",
";+	c #4B6B39",
">+	c #4C544B",
",+	c #616A5F",
"'+	c #4D6D3C",
")+	c #396B1D",
"!+	c #4C6B3B",
"~+	c #4E554C",
". + @ @ @ @ # # # # $ % % & * = ",
"+ - ; > > > , ' , , ) ! ~ { ] * ",
"@ > ^ / ( _ : < [ } | 1 2 3 4 5 ",
"@ > 6 7 8 9 0 a b c d e f g h i ",
"# > j k l m n o p q r s t u v w ",
"# , x y z A B C D E F G H I J w ",
"# , K L M N O P Q R S T U V J W ",
"$ , X Y Z `  ...+.@.#.$.%.&.*.=.",
"% , -.;.>.Z ,.'.).!.~.{.].^./.(.",
"& , _.:.<.[.}.|.1.2.3.4.5.6.7.8.",
"9.0.a.b.c.d.e.f.g.h.i.j.k.l.m.n.",
"9.o.p.q.r.s.t.u.v.w.x.y.z.A.B.C.",
"5 ) D.E.F.G.H.I.J.K.L.z.z.z.M.N.",
"i O.P.Q.R.S.T.U.V.W.X.Y.z.Z.B.`.",
" +.+++@+#+$+%+%+&+*+=+-+M.-+=+;+",
">+,+W =.(.(.8.8.8.8.'+)+N.)+!+~+"};

Added icons/map_edit.xpm.

















































































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
/* XPM */
static const char * map_edit_xpm[] = {
"16 16 213 2",
"  	c None",
". 	c #4A5449",
"+ 	c #5D6A5C",
"@ 	c #606D5F",
"# 	c #616D5F",
"$ 	c #616D60",
"% 	c #626D60",
"& 	c #636D60",
"* 	c #5F6A5E",
"= 	c #4B544A",
"- 	c #FBFCFB",
"; 	c #FCFEFC",
"> 	c #F8FCF7",
", 	c #F8FCF8",
"' 	c #F9FCF7",
") 	c #EEF7EC",
"! 	c #EEF7ED",
"~ 	c #EDF6EF",
"{ 	c #ECF4EE",
"] 	c #EBF4EB",
"^ 	c #F9F99D",
"/ 	c #EDB46C",
"( 	c #FE7162",
"_ 	c #E9E780",
": 	c #F4F48C",
"< 	c #CDCD52",
"[ 	c #A4C2EC",
"} 	c #8AADDD",
"| 	c #97BAEB",
"1 	c #80A7DD",
"2 	c #83ABE2",
"3 	c #75A0DA",
"4 	c #D4EAD9",
"5 	c #646E61",
"6 	c #EAEA8A",
"7 	c #DEDD72",
"8 	c #F06556",
"9 	c #DF9F56",
"0 	c #E8E873",
"a 	c #C1C146",
"b 	c #A5BBBB",
"c 	c #83A4D0",
"d 	c #8EB0DE",
"e 	c #7A9ED1",
"f 	c #7AA2D6",
"g 	c #7198CF",
"h 	c #D5EBD7",
"i 	c #646E62",
"j 	c #F9F99F",
"k 	c #EAE985",
"l 	c #FAD384",
"m 	c #F05A52",
"n 	c #F7F287",
"o 	c #D7DA60",
"p 	c #CAD598",
"q 	c #9CB7E0",
"r 	c #A9C7ED",
"s 	c #94B3E0",
"t 	c #98B8E6",
"u 	c #8CAEDE",
"v 	c #D6ECD7",
"w 	c #646E63",
"x 	c #EAEA90",
"y 	c #DEDD78",
"z 	c #EAE981",
"A 	c #E26B4E",
"B 	c #EE9D63",
"C 	c #D7D75E",
"D 	c #C9CB5B",
"E 	c #97B0D4",
"F 	c #9FBAE2",
"G 	c #A9ADA1",
"H 	c #D8A558",
"I 	c #DBB185",
"J 	c #D09D46",
"K 	c #8C7C4E",
"L 	c #F9F9A6",
"M 	c #EAE98B",
"N 	c #FAF899",
"O 	c #EBD378",
"P 	c #FF6B65",
"Q 	c #EADC77",
"R 	c #DEDF70",
"S 	c #B5C5C1",
"T 	c #C8C8A8",
"U 	c #E7BE77",
"V 	c #F0D2B4",
"W 	c #FFF3E5",
"X 	c #EFD2AC",
"Y 	c #BE894A",
"Z 	c #F1F19F",
"` 	c #DFDD81",
" .	c #EBEA8A",
"..	c #DEDE75",
"+.	c #EE9165",
"@.	c #E27E55",
"#.	c #DDDC68",
"$.	c #C5BC5B",
"%.	c #EDD580",
"&.	c #F9E3B2",
"*.	c #E7C08B",
"=.	c #F6D3AE",
"-.	c #FCE0C4",
";.	c #D09D66",
">.	c #FAFAAF",
",.	c #EBEB94",
"'.	c #FAF9A2",
").	c #F3ED95",
"!.	c #EB5F59",
"~.	c #E5CF6B",
"{.	c #EED47C",
"].	c #FDF6C4",
"^.	c #F6DD6C",
"/.	c #EDCA6D",
"(.	c #D7A363",
"_.	c #D3A166",
":.	c #747461",
"<.	c #EDEBA4",
"[.	c #DFDF8D",
"}.	c #EBEB97",
"|.	c #B7CF72",
"1.	c #99CA74",
"2.	c #BD9047",
"3.	c #EED379",
"4.	c #FDF7C7",
"5.	c #F5DC5F",
"6.	c #F7E25B",
"7.	c #F2D67A",
"8.	c #DF9943",
"9.	c #D9D4B1",
"0.	c #666F64",
"a.	c #636E61",
"b.	c #F9FCF8",
"c.	c #FBFBBC",
"d.	c #DFE79D",
"e.	c #BBE193",
"f.	c #97C977",
"g.	c #AEBD63",
"h.	c #E7CB77",
"i.	c #F5DC5E",
"j.	c #F7E15A",
"k.	c #F1D47B",
"l.	c #DD9543",
"m.	c #C39B58",
"n.	c #DBE9D0",
"o.	c #F8FBF7",
"p.	c #C4DE9B",
"q.	c #93C373",
"r.	c #9FCF80",
"s.	c #9CAD53",
"t.	c #D5B973",
"u.	c #FDF6C2",
"v.	c #F7DF63",
"w.	c #F8E25D",
"x.	c #F0D379",
"y.	c #DA9543",
"z.	c #A4B86C",
"A.	c #8FC374",
"B.	c #DAEFD7",
"C.	c #AFDB96",
"D.	c #9AC97F",
"E.	c #A5AD63",
"F.	c #D5B67A",
"G.	c #D1B790",
"H.	c #E4C955",
"I.	c #F5DF5B",
"J.	c #EDD078",
"K.	c #D99646",
"L.	c #A1C176",
"M.	c #A0D087",
"N.	c #9ACA80",
"O.	c #DAEED6",
"P.	c #EFF8EE",
"Q.	c #BCDBA4",
"R.	c #A6CA8C",
"S.	c #AA8943",
"T.	c #FFF2E0",
"U.	c #D89A54",
"V.	c #BE7A1A",
"W.	c #C59849",
"X.	c #BF863B",
"Y.	c #E77460",
"Z.	c #A3C581",
"`.	c #A6D08C",
" +	c #A0CA85",
".+	c #D7E9D2",
"++	c #676F64",
"@+	c #606A5F",
"#+	c #ECF5EB",
"$+	c #D7EDD4",
"%+	c #D7EED4",
"&+	c #84672E",
"*+	c #F9C794",
"=+	c #F9C991",
"-+	c #C98541",
";+	c #AC6B25",
">+	c #D4D9B7",
",+	c #ECE2D4",
"'+	c #D6E5CF",
")+	c #D9EDD5",
"!+	c #DCEFD8",
"~+	c #636C61",
"{+	c #4C544B",
"]+	c #616A5F",
"^+	c #646F63",
"/+	c #646F64",
"(+	c #563F14",
"_+	c #865F29",
":+	c #BC8849",
"<+	c #A7864A",
"[+	c #70705D",
"}+	c #677064",
"|+	c #4E554C",
". + @ @ @ @ # # # # $ % % & * = ",
"+ - ; > > > , ' , , ) ! ~ { ] * ",
"@ > ^ / ( _ : < [ } | 1 2 3 4 5 ",
"@ > 6 7 8 9 0 a b c d e f g h i ",
"# > j k l m n o p q r s t u v w ",
"# , x y z A B C D E F G H I J K ",
"# , L M N O P Q R S T U V W X Y ",
"$ , Z `  ...+.@.#.$.%.&.*.=.-.;.",
"% , >.,.'. .).!.~.{.].^./.(._.:.",
"& , <.[.}.|.1.2.3.4.5.6.7.8.9.0.",
"a.b.c.d.e.f.g.h.4.i.j.k.l.m.n.0.",
"a.o.p.q.r.s.t.u.v.w.x.y.z.A.B.0.",
"5 ) C.D.E.F.G.H.I.J.K.L.M.N.O.0.",
"i P.Q.R.S.T.U.V.W.X.Y.Z.`. +.+++",
"@+#+$+%+&+*+=+-+;+>+,+'+)+!+)+~+",
"{+]+^+/+(+_+:+<+[+0.0.++++}+~+|+"};

Added icons/map_go.xpm.







































































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
/* XPM */
static const char * map_go_xpm[] = {
"16 16 208 2",
"  	c None",
". 	c #4A5449",
"+ 	c #5D6A5C",
"@ 	c #606D5F",
"# 	c #616D5F",
"$ 	c #616D60",
"% 	c #626D60",
"& 	c #636D60",
"* 	c #5F6A5E",
"= 	c #4B544A",
"- 	c #FBFCFB",
"; 	c #FCFEFC",
"> 	c #F8FCF7",
", 	c #F8FCF8",
"' 	c #F9FCF7",
") 	c #EEF7EC",
"! 	c #EEF7ED",
"~ 	c #EDF6EF",
"{ 	c #ECF4EE",
"] 	c #EBF4EB",
"^ 	c #F9F99D",
"/ 	c #EDB46C",
"( 	c #FE7162",
"_ 	c #E9E780",
": 	c #F4F48C",
"< 	c #CDCD52",
"[ 	c #A4C2EC",
"} 	c #8AADDD",
"| 	c #97BAEB",
"1 	c #80A7DD",
"2 	c #83ABE2",
"3 	c #75A0DA",
"4 	c #D4EAD9",
"5 	c #646E61",
"6 	c #EAEA8A",
"7 	c #DEDD72",
"8 	c #F06556",
"9 	c #DF9F56",
"0 	c #E8E873",
"a 	c #C1C146",
"b 	c #A5BBBB",
"c 	c #83A4D0",
"d 	c #8EB0DE",
"e 	c #7A9ED1",
"f 	c #7AA2D6",
"g 	c #7198CF",
"h 	c #D5EBD7",
"i 	c #646E62",
"j 	c #F9F99F",
"k 	c #EAE985",
"l 	c #FAD384",
"m 	c #F05A52",
"n 	c #F7F287",
"o 	c #D7DA60",
"p 	c #CAD598",
"q 	c #9CB7E0",
"r 	c #A9C7ED",
"s 	c #94B3E0",
"t 	c #98B8E6",
"u 	c #8CAEDE",
"v 	c #D6ECD7",
"w 	c #646E63",
"x 	c #EAEA90",
"y 	c #DEDD78",
"z 	c #EAE981",
"A 	c #E26B4E",
"B 	c #EE9D63",
"C 	c #D7D75E",
"D 	c #C9CB5B",
"E 	c #97B0D4",
"F 	c #9FBAE2",
"G 	c #8FACD6",
"H 	c #91B0DB",
"I 	c #86A7D4",
"J 	c #D7EDD6",
"K 	c #F9F9A6",
"L 	c #EAE98B",
"M 	c #FAF899",
"N 	c #EBD378",
"O 	c #FF6B65",
"P 	c #EADC77",
"Q 	c #DEDF70",
"R 	c #B5C5C1",
"S 	c #BAD1F1",
"T 	c #A9C1E5",
"U 	c #AEC7EA",
"V 	c #A1BDE4",
"W 	c #646F63",
"X 	c #F1F19F",
"Y 	c #DFDD81",
"Z 	c #EBEA8A",
"` 	c #DEDE75",
" .	c #EE9165",
"..	c #E27E55",
"+.	c #DDDC68",
"@.	c #B7BF77",
"#.	c #6EA43E",
"$.	c #659F31",
"%.	c #A3BBD8",
"&.	c #9FB7D9",
"*.	c #D8EDD6",
"=.	c #646F64",
"-.	c #FAFAAF",
";.	c #EBEB94",
">.	c #FAF9A2",
",.	c #F3ED95",
"'.	c #EB5F59",
").	c #E6D987",
"!.	c #D1D25C",
"~.	c #67A138",
"{.	c #81B35A",
"].	c #579828",
"^.	c #CACF74",
"/.	c #DBEFD4",
"(.	c #656F64",
"_.	c #EDEBA4",
":.	c #DFDF8D",
"<.	c #EBEB97",
"[.	c #B7CF72",
"}.	c #6FA53D",
"|.	c #6EA337",
"1.	c #68A133",
"2.	c #629D2F",
"3.	c #7CAF55",
"4.	c #AACB91",
"5.	c #74AB4F",
"6.	c #468F18",
"7.	c #D5E0C1",
"8.	c #666F64",
"9.	c #636E61",
"0.	c #F9FCF8",
"a.	c #FBFBBC",
"b.	c #DFE79D",
"c.	c #BBE193",
"d.	c #97C977",
"e.	c #6BA337",
"f.	c #B0CE96",
"g.	c #ADCD94",
"h.	c #A8CB90",
"i.	c #90BC74",
"j.	c #A1C78A",
"k.	c #68A546",
"l.	c #368809",
"m.	c #63705E",
"n.	c #F8FBF7",
"o.	c #C4DE9B",
"p.	c #93C373",
"q.	c #9FCF80",
"r.	c #8FC16F",
"s.	c #639F31",
"t.	c #8EBA6F",
"u.	c #89B86B",
"v.	c #85B666",
"w.	c #80B361",
"x.	c #82B567",
"y.	c #98C283",
"z.	c #5CA03C",
"A.	c #267F01",
"B.	c #AFDB96",
"C.	c #9AC97F",
"D.	c #AAD88F",
"E.	c #97C87A",
"F.	c #5B9B29",
"G.	c #A9CA90",
"H.	c #A5C88D",
"I.	c #A1C68A",
"J.	c #9EC588",
"K.	c #85B66A",
"L.	c #97C282",
"M.	c #66A548",
"N.	c #308612",
"O.	c #587151",
"P.	c #EFF8EE",
"Q.	c #BCDBA4",
"R.	c #A6CA8C",
"S.	c #B1D598",
"T.	c #A1C986",
"U.	c #519721",
"V.	c #49911B",
"W.	c #438F15",
"X.	c #3B8B0F",
"Y.	c #5E9F3A",
"Z.	c #96C180",
"`.	c #62A346",
" +	c #2B840D",
".+	c #B8D7AF",
"++	c #676F64",
"@+	c #606A5F",
"#+	c #ECF5EB",
"$+	c #D7EDD4",
"%+	c #D7EED4",
"&+	c #D8EED4",
"*+	c #D8EED5",
"=+	c #D9EED5",
"-+	c #DAEFD6",
";+	c #338709",
">+	c #5FA143",
",+	c #338717",
"'+	c #BEDDB7",
")+	c #D9EDD5",
"!+	c #636C61",
"~+	c #4C544B",
"{+	c #616A5F",
"]+	c #247C04",
"^+	c #1E7B03",
"/+	c #5C7057",
"(+	c #677064",
"_+	c #4E554C",
". + @ @ @ @ # # # # $ % % & * = ",
"+ - ; > > > , ' , , ) ! ~ { ] * ",
"@ > ^ / ( _ : < [ } | 1 2 3 4 5 ",
"@ > 6 7 8 9 0 a b c d e f g h i ",
"# > j k l m n o p q r s t u v w ",
"# , x y z A B C D E F G H I J w ",
"# , K L M N O P Q R S T U V J W ",
"$ , X Y Z `  ...+.@.#.$.%.&.*.=.",
"% , -.;.>.Z ,.'.).!.~.{.].^./.(.",
"& , _.:.<.[.}.|.1.2.3.4.5.6.7.8.",
"9.0.a.b.c.d.e.f.g.4.h.i.j.k.l.m.",
"9.n.o.p.q.r.s.g.t.u.v.w.x.y.z.A.",
"5 ) B.C.D.E.F.G.H.I.J.K.L.M.N.O.",
"i P.Q.R.S.T.U.V.W.X.Y.Z.`. +.+++",
"@+#+$+%+&+*+=+=+-+-+;+>+,+'+)+!+",
"~+{+W =.(.(.8.8.8.8.]+^+/+(+!+_+"};

Added icons/map_root.xpm.





























































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
/* XPM */
static const char * map_root_xpm[] = {
"16 16 203 2",
"  	c None",
". 	c #4A5449",
"+ 	c #5D6A5C",
"@ 	c #606D5F",
"# 	c #616D5F",
"$ 	c #616D60",
"% 	c #626D60",
"& 	c #636D60",
"* 	c #5F6A5E",
"= 	c #4B544A",
"- 	c #FBFCFB",
"; 	c #FCFEFC",
"> 	c #F8FCF7",
", 	c #F8FCF8",
"' 	c #F9FCF7",
") 	c #EEF7EC",
"! 	c #EEF7ED",
"~ 	c #EDF6EF",
"{ 	c #ECF4EE",
"] 	c #EBF4EB",
"^ 	c #F9F99D",
"/ 	c #EDB46C",
"( 	c #FE7162",
"_ 	c #E9E780",
": 	c #F4F48C",
"< 	c #CDCD52",
"[ 	c #A4C2EC",
"} 	c #8AADDD",
"| 	c #97BAEB",
"1 	c #80A7DD",
"2 	c #83ABE2",
"3 	c #75A0DA",
"4 	c #D4EAD9",
"5 	c #646E61",
"6 	c #EAEA8A",
"7 	c #DEDD72",
"8 	c #F06556",
"9 	c #DF9F56",
"0 	c #E8E873",
"a 	c #C1C146",
"b 	c #A5BBBB",
"c 	c #83A4D0",
"d 	c #8EB0DE",
"e 	c #7A9ED1",
"f 	c #7AA2D6",
"g 	c #7198CF",
"h 	c #D5EBD7",
"i 	c #646E62",
"j 	c #F9F99F",
"k 	c #EAE985",
"l 	c #FAD384",
"m 	c #F05A52",
"n 	c #F7F287",
"o 	c #D7DA60",
"p 	c #CAD598",
"q 	c #9CB7E0",
"r 	c #A9C7ED",
"s 	c #94B3E0",
"t 	c #98B8E6",
"u 	c #8CAEDE",
"v 	c #D6ECD7",
"w 	c #646E63",
"x 	c #EAEA90",
"y 	c #DEDD78",
"z 	c #EAE981",
"A 	c #E26B4E",
"B 	c #EE9D63",
"C 	c #D7D75E",
"D 	c #C9CB5B",
"E 	c #97B0D4",
"F 	c #9FBAE2",
"G 	c #8FACD6",
"H 	c #91B0DB",
"I 	c #86A7D4",
"J 	c #D7EDD6",
"K 	c #F9F9A6",
"L 	c #EAE98B",
"M 	c #FAF899",
"N 	c #EBD378",
"O 	c #FF6B65",
"P 	c #EADC77",
"Q 	c #DEDF70",
"R 	c #B5C5C1",
"S 	c #BAD1F1",
"T 	c #A9C1E5",
"U 	c #AEC7EA",
"V 	c #A1BDE4",
"W 	c #646F63",
"X 	c #F1F19F",
"Y 	c #DFDD81",
"Z 	c #EBEA8A",
"` 	c #DEDE75",
" .	c #EE9165",
"..	c #E27E55",
"+.	c #DDDC68",
"@.	c #B7BF77",
"#.	c #B2C8E5",
"$.	c #A3BADA",
"%.	c #A6BCDE",
"&.	c #9FB7D9",
"*.	c #D8EDD6",
"=.	c #646F64",
"-.	c #FAFAAF",
";.	c #EBEB94",
">.	c #FAF9A2",
",.	c #F3ED95",
"'.	c #EB5F59",
").	c #E6D987",
"!.	c #D1D25C",
"~.	c #C9DBDC",
"{.	c #CDD4AC",
"].	c #D4DA97",
"^.	c #CED177",
"/.	c #DBEFD4",
"(.	c #656F64",
"_.	c #EDEBA4",
":.	c #DFDF8D",
"<.	c #EBEB97",
"[.	c #B7CF72",
"}.	c #99CA74",
"|.	c #B08356",
"1.	c #D77860",
"2.	c #B6C351",
"3.	c #CDD590",
"4.	c #C6C650",
"5.	c #DDD07E",
"6.	c #DB9964",
"7.	c #DCE4CA",
"8.	c #666F64",
"9.	c #636E61",
"0.	c #F9FCF8",
"a.	c #FBFBBC",
"b.	c #DFE79D",
"c.	c #BBE193",
"d.	c #97C977",
"e.	c #A9DA89",
"f.	c #98C675",
"g.	c #F37C71",
"h.	c #ADAE6B",
"i.	c #DDE182",
"j.	c #E1A758",
"k.	c #E68C56",
"l.	c #BD9F61",
"m.	c #DBE9D0",
"n.	c #F8FBF7",
"o.	c #C4DE9B",
"p.	c #93C373",
"q.	c #9FCF80",
"r.	c #8FC16F",
"s.	c #9DCE7E",
"t.	c #8CBF6E",
"u.	c #BBA470",
"v.	c #DA5848",
"w.	c #D17C4C",
"x.	c #B68D51",
"y.	c #9DBE73",
"z.	c #8FC374",
"A.	c #DAEFD7",
"B.	c #AFDB96",
"C.	c #9AC97F",
"D.	c #AAD88F",
"E.	c #97C87A",
"F.	c #A9D68A",
"G.	c #ACA25F",
"H.	c #D78855",
"I.	c #E05D48",
"J.	c #C9A879",
"K.	c #99C97F",
"L.	c #A0D087",
"M.	c #9ACA80",
"N.	c #DAEED6",
"O.	c #EFF8EE",
"P.	c #BCDBA4",
"Q.	c #A6CA8C",
"R.	c #B1D598",
"S.	c #A1C986",
"T.	c #C0AD74",
"U.	c #C68756",
"V.	c #B6C283",
"W.	c #AFAC77",
"X.	c #EB7069",
"Y.	c #A3C581",
"Z.	c #A6D08C",
"`.	c #A0CA85",
" +	c #D7E9D2",
".+	c #676F64",
"++	c #606A5F",
"@+	c #ECF5EB",
"#+	c #D7EDD4",
"$+	c #D7EED4",
"%+	c #D8EED4",
"&+	c #D8EED5",
"*+	c #D9EED5",
"=+	c #DAEFD6",
"-+	c #ECE2D4",
";+	c #D6E5CF",
">+	c #D9EDD5",
",+	c #DCEFD8",
"'+	c #636C61",
")+	c #4C544B",
"!+	c #616A5F",
"~+	c #677064",
"{+	c #4E554C",
". + @ @ @ @ # # # # $ % % & * = ",
"+ - ; > > > , ' , , ) ! ~ { ] * ",
"@ > ^ / ( _ : < [ } | 1 2 3 4 5 ",
"@ > 6 7 8 9 0 a b c d e f g h i ",
"# > j k l m n o p q r s t u v w ",
"# , x y z A B C D E F G H I J w ",
"# , K L M N O P Q R S T U V J W ",
"$ , X Y Z `  ...+.@.#.$.%.&.*.=.",
"% , -.;.>.Z ,.'.).!.~.{.].^./.(.",
"& , _.:.<.[.}.|.1.2.3.4.5.6.7.8.",
"9.0.a.b.c.d.e.f.g.h.i.j.k.l.m.8.",
"9.n.o.p.q.r.s.t.u.v.w.x.y.z.A.8.",
"5 ) B.C.D.E.F.G.H.I.J.K.L.M.N.8.",
"i O.P.Q.R.S.T.U.V.W.X.Y.Z.`. +.+",
"++@+#+$+%+&+*+*+=+=+-+;+>+,+>+'+",
")+!+W =.(.(.8.8.8.8.8..+.+~+'+{+"};

Added icons/pan.xpm.

























































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
/* XPM */
static const char * pan_xpm[] = {
"16 16 9 1",
" 	c None",
".	c #FFFFFF",
"+	c #000000",
"@	c #FFFFFF",
"#	c #FFFFFF",
"$	c #FFFFFF",
"%	c #FFFFFF",
"&	c #FFFFFF",
"*	c #FFFFFF",
"                ",
"      +++       ",
"    +++.+       ",
"    +.+.+++     ",
"  +++.+.+.+     ",
"  +.+.+.+.+     ",
"  +.+.+.+.+     ",
"  +....++++++   ",
"  +...+.....+   ",
"  +....++++.+   ",
"  +.........+   ",
"   +.......++   ",
"    +.....+     ",
"    +.....+     ",
"    +++++++     ",
"                "};

Added icons/points_off.xpm.

















































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* XPM */
static const char * points_off_xpm[] = {
"16 16 5 1",
" 	c None",
".	c #A0A0A0",
"+	c #808080",
"@	c #D0D0D=",
"#	c #C0C0C0",
"                ",
"  ..            ",
" .@+#      ..   ",
" .++#     .@+#  ",
"  ##      .++#  ",
"           ##   ",
"                ",
"       ..       ",
"      .@+#      ",
"      .++#      ",
"       ##       ",
"  ..            ",
" .@+#           ",
" .++#           ",
"  ##            ",
"                "};

Added icons/points_on.xpm.

















































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* XPM */
static const char * points_on_xpm[] = {
"16 16 5 1",
" 	c None",
".	c #FF0000",
"+	c #FF8000",
"@	c #FFD0D0",
"#	c #C00000",
"                ",
"  ..            ",
" .@+#      ..   ",
" .++#     .@+#  ",
"  ##      .++#  ",
"           ##   ",
"                ",
"       ..       ",
"      .@+#      ",
"      .++#      ",
"       ##       ",
"  ..            ",
" .@+#           ",
" .++#           ",
"  ##            ",
"                "};

Added icons/polygons_off.xpm.

















































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* XPM */
static const char * polygons_off_xpm[] = {
"16 16 5 1",
" 	c None",
".	c #808080",
"+	c #D0D0D0",
"@	c #C0C0C0",
"#	c #E0E0E0",
"                ",
"         ...    ",
"    .....@@@.   ",
"   .@@@@@@@@.   ",
" ..@@+++++###.  ",
" .@@++++++###.  ",
" .@@@@++++##.   ",
"  ...@@+++##.   ",
"     .@@++#.    ",
"      .@@###.   ",
"  .   .@@####.  ",
" .+.  .@@###.   ",
" .@+. .@@##.    ",
"  ..   .@..     ",
"        .       ",
"                "};

Added icons/polygons_on.xpm.

















































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* XPM */
static const char * polygons_on_xpm[] = {
"16 16 5 1",
" 	c None",
".	c #8080C0",
"+	c #FFD080",
"@	c #FFFFC0",
"#	c #E0E080",
"                ",
"         ...    ",
"    .....@@@.   ",
"   .@@@@@@@@.   ",
" ..@@+++++###.  ",
" .@@++++++###.  ",
" .@@@@++++##.   ",
"  ...@@+++##.   ",
"     .@@++#.    ",
"      .@@###.   ",
"  .   .@@####.  ",
" .+.  .@@###.   ",
" .@+. .@@##.    ",
"  ..   .@..     ",
"        .       ",
"                "};

Added icons/printer.xpm.

















































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
/* XPM */
static const char * printer_xpm[] = {
"16 16 133 2",
"  	c None",
". 	c #4D8BC8",
"+ 	c #4F8CC8",
"@ 	c #4F8DC8",
"# 	c #4F8CC9",
"$ 	c #4C89C5",
"% 	c #3B76C4",
"& 	c #4986C4",
"* 	c #ECF2F7",
"= 	c #EEF4F8",
"- 	c #EDF3F8",
"; 	c #ECF2F8",
"> 	c #D7E6F2",
", 	c #7DB2E2",
"' 	c #6391DA",
") 	c #4C89C6",
"! 	c #F1F5F9",
"~ 	c #CDE3FC",
"{ 	c #CDE3FB",
"] 	c #C8E0F9",
"^ 	c #C2DCF8",
"/ 	c #F8FBFD",
"( 	c #CDE6FC",
"_ 	c #84B6E2",
": 	c #4279BF",
"< 	c #4B89C6",
"[ 	c #CFE3FC",
"} 	c #CFE4FC",
"| 	c #CAE1FA",
"1 	c #C4DDF9",
"2 	c #DFE9F4",
"3 	c #E9EFF5",
"4 	c #457EC2",
"5 	c #4B89C5",
"6 	c #F0F4F9",
"7 	c #D3E6FC",
"8 	c #D3E7FD",
"9 	c #C8E0FA",
"0 	c #BBD6F5",
"a 	c #B5D4F3",
"b 	c #F0F4F8",
"c 	c #4682C3",
"d 	c #818181",
"e 	c #EFF4F9",
"f 	c #D7E7FE",
"g 	c #D5E7FD",
"h 	c #D2E6FC",
"i 	c #CCE1FB",
"j 	c #BDDAF6",
"k 	c #EFF4FA",
"l 	c #4883C4",
"m 	c #595959",
"n 	c #9A9A9A",
"o 	c #CCCCCC",
"p 	c #4E8BC7",
"q 	c #EDF4F9",
"r 	c #D8E8FE",
"s 	c #D7E8FE",
"t 	c #D3E5FD",
"u 	c #D1E4FC",
"v 	c #C7E0FA",
"w 	c #C3DDF9",
"x 	c #EDF4FA",
"y 	c #4A85C7",
"z 	c #C3C3C3",
"A 	c #747474",
"B 	c #D2D2D2",
"C 	c #E8E8E8",
"D 	c #7D7D7D",
"E 	c #C4C4C4",
"F 	c #565656",
"G 	c #FCFCFC",
"H 	c #CBCBCB",
"I 	c #F2F2F2",
"J 	c #C6C6C6",
"K 	c #707070",
"L 	c #7E7E7E",
"M 	c #F9F9F9",
"N 	c #ABABAB",
"O 	c #DFDFDF",
"P 	c #A3A3A3",
"Q 	c #616161",
"R 	c #7A7A7A",
"S 	c #D7D7D7",
"T 	c #979797",
"U 	c #D8D8D8",
"V 	c #BFBFBF",
"W 	c #8E8E8E",
"X 	c #3F3F3F",
"Y 	c #757575",
"Z 	c #BBBBBB",
"` 	c #8D8D8D",
" .	c #D4D4D4",
"..	c #B9B9B9",
"+.	c #D3D3D3",
"@.	c #838383",
"#.	c #2A2A2A",
"$.	c #B5B5B5",
"%.	c #959595",
"&.	c #797979",
"*.	c #6E6E6E",
"=.	c #525252",
"-.	c #434343",
";.	c #424242",
">.	c #252525",
",.	c #6A6A6A",
"'.	c #A7A7A7",
").	c #AAACAF",
"!.	c #BDC0C5",
"~.	c #A8AAAD",
"{.	c #2C2C2C",
"].	c #9B9B9B",
"^.	c #232323",
"/.	c #636363",
"(.	c #5D5D5D",
"_.	c #585858",
":.	c #6195C7",
"<.	c #F6F7F9",
"[.	c #ECF1F9",
"}.	c #EBF1F9",
"|.	c #E9F0F8",
"1.	c #E6EDF7",
"2.	c #E1EAF4",
"3.	c #DEE8F2",
"4.	c #F6F8FA",
"5.	c #6194C7",
"6.	c #242424",
"7.	c #6195C8",
"8.	c #6598CA",
"9.	c #6597CA",
"0.	c #6497CA",
"a.	c #6497C9",
"b.	c #6194C8",
"        . + + @ # $ %           ",
"      & * = - - ; > , '         ",
"      ) ! ~ { ] ^ / ( _ :       ",
"      < ! [ } | 1 2 * 3 4       ",
"      5 6 7 8 { 9 0 a b c       ",
"    d $ e f g h i ^ j k l m     ",
"  n o p q r s t u v w x y z A   ",
"d B C D D D D D D D D D D C E F ",
"d G G H I I I I I I I I J G G K ",
"L M M N O H H H H H H O P M M Q ",
"R S S T U V V V V V V S W S S X ",
"Y Z Z `  .............+.@.Z Z #.",
"K $.$.%.d d &.*.Q =.-.;.*.$.$.>.",
",.'.$.d ).!.!.!.!.!.!.~.{.$.].^.",
"/.(._.:.<.[.}.|.1.2.3.4.5.6.^.  ",
"      7.8.9.9.9.0.a.a.8.b.      "};

Added icons/topo_geo_off.xpm.











































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/* XPM */
static const char * topo_geo_off_xpm[] = {
"16 16 98 2",
"  	c None",
". 	c #5F5F5F",
"+ 	c #606060",
"@ 	c #636363",
"# 	c #676767",
"$ 	c #6D6D6D",
"% 	c #717171",
"& 	c #767676",
"* 	c #777777",
"= 	c #797979",
"- 	c #808080",
"; 	c #828282",
"> 	c #858585",
", 	c #898989",
"' 	c #8A8A8A",
") 	c #8B8B8B",
"! 	c #8C8C8C",
"~ 	c #8D8D8D",
"{ 	c #8E8E8E",
"] 	c #8F8F8F",
"^ 	c #909090",
"/ 	c #919191",
"( 	c #929292",
"_ 	c #959595",
": 	c #969696",
"< 	c #979797",
"[ 	c #989898",
"} 	c #999999",
"| 	c #9A9A9A",
"1 	c #9B9B9B",
"2 	c #9D9D9D",
"3 	c #9E9E9E",
"4 	c #A1A1A1",
"5 	c #A2A2A2",
"6 	c #A3A3A3",
"7 	c #A5A5A5",
"8 	c #A6A6A6",
"9 	c #A8A8A8",
"0 	c #A9A9A9",
"a 	c #AAAAAA",
"b 	c #ABABAB",
"c 	c #ACACAC",
"d 	c #ADADAD",
"e 	c #AEAEAE",
"f 	c #B1B1B1",
"g 	c #B3B3B3",
"h 	c #B4B4B4",
"i 	c #B5B5B5",
"j 	c #B8B8B8",
"k 	c #BABABA",
"l 	c #BBBBBB",
"m 	c #BCBCBC",
"n 	c #BDBDBD",
"o 	c #BEBEBE",
"p 	c #BFBFBF",
"q 	c #C0C0C0",
"r 	c #C1C1C1",
"s 	c #C2C2C2",
"t 	c #C3C3C3",
"u 	c #C4C4C4",
"v 	c #C5C5C5",
"w 	c #C7C7C7",
"x 	c #CBCBCB",
"y 	c #CCCCCC",
"z 	c #CDCDCD",
"A 	c #CECECE",
"B 	c #CFCFCF",
"C 	c #D1D1D1",
"D 	c #D2D2D2",
"E 	c #D3D3D3",
"F 	c #D5D5D5",
"G 	c #D6D6D6",
"H 	c #D7D7D7",
"I 	c #D8D8D8",
"J 	c #DADADA",
"K 	c #DDDDDD",
"L 	c #DEDEDE",
"M 	c #DFDFDF",
"N 	c #E0E0E0",
"O 	c #E1E1E1",
"P 	c #E3E3E3",
"Q 	c #E4E4E4",
"R 	c #E7E7E7",
"S 	c #E8E8E8",
"T 	c #E9E9E9",
"U 	c #DADADA",
"V 	c #DBDBDB",
"W 	c #DCDCDC",
"X 	c #DEDEDE",
"Y 	c #E0E0E0",
"Z 	c #E1E1E1",
"` 	c #E2E2E2",
" .	c #E3E3E3",
"..	c #E5E5E5",
"+.	c #EBEBEB",
"@.	c #ECECEC",
"#.	c #EDEDED",
"$.	c #EFEFEF",
"          s g 5 5 g s           ",
"          0 $.$.$.$.0           ",
"  s g 5 5 f G #.@.E f 5 5 g s   ",
"  0 $.$.$.N c C C b N $.$.$.0   ",
"e e F #.#.w i 6 6 i w @.+.D e 2 ",
"c I z A C c $.$.$.$.c C y r o 1 ",
"b  .T K L s J #.#.J t H l l B | ",
"a  .Z X O w x C C y / ) o q A } ",
"0  .Y W U Q J I u l ! 5 ; n x [ ",
"8 ..` R Q M ( ^ ~ , 3 q } * v _ ",
"7 o P Z R K ] u s q p d l / $ / ",
"    4 r S V ' s b 9 8 5 7 i ' @ ",
"      3 2 v > p m k j 8 h / +   ",
"          1 - = & % ' g { +     ",
"              < :   # ! .       ",
"                    + .         "};

Added icons/topo_net_off.xpm.





















































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* XPM */
static const char * topo_net_off_xpm[] = {
"16 16 103 2",
"  	c None",
". 	c #414141",
"+ 	c #444444",
"@ 	c #464646",
"# 	c #474747",
"$ 	c #4A4A4A",
"% 	c #4C4C4C",
"& 	c #4D4D4D",
"* 	c #515151",
"= 	c #525252",
"- 	c #535353",
"; 	c #646464",
"> 	c #656565",
", 	c #666666",
"' 	c #676767",
") 	c #686868",
"! 	c #6B6B6B",
"~ 	c #717171",
"{ 	c #737373",
"] 	c #787878",
"^ 	c #797979",
"/ 	c #7A7A7A",
"( 	c #7E7E7E",
"_ 	c #828282",
": 	c #838383",
"< 	c #848484",
"[ 	c #858585",
"} 	c #898989",
"| 	c #8B8B8B",
"1 	c #8C8C8C",
"2 	c #8D8D8D",
"3 	c #919191",
"4 	c #929292",
"5 	c #939393",
"6 	c #959595",
"7 	c #979797",
"8 	c #989898",
"9 	c #999999",
"0 	c #9A9A9A",
"a 	c #9B9B9B",
"b 	c #9D9D9D",
"c 	c #9E9E9E",
"d 	c #A1A1A1",
"e 	c #A2A2A2",
"f 	c #A3A3A3",
"g 	c #A5A5A5",
"h 	c #A6A6A6",
"i 	c #A9A9A9",
"j 	c #AAAAAA",
"k 	c #ABABAB",
"l 	c #ACACAC",
"m 	c #ADADAD",
"n 	c #AEAEAE",
"o 	c #AFAFAF",
"p 	c #B1B1B1",
"q 	c #B3B3B3",
"r 	c #B5B5B5",
"s 	c #BABABA",
"t 	c #BBBBBB",
"u 	c #BDBDBD",
"v 	c #BEBEBE",
"w 	c #C0C0C0",
"x 	c #C1C1C1",
"y 	c #C2C2C2",
"z 	c #C3C3C3",
"A 	c #C4C4C4",
"B 	c #C7C7C7",
"C 	c #CBCBCB",
"D 	c #CCCCCC",
"E 	c #CDCDCD",
"F 	c #CECECE",
"G 	c #CFCFCF",
"H 	c #D1D1D1",
"I 	c #D2D2D2",
"J 	c #D3D3D3",
"K 	c #D5D5D5",
"L 	c #D6D6D6",
"M 	c #D7D7D7",
"N 	c #D8D8D8",
"O 	c #DADADA",
"P 	c #DDDDDD",
"Q 	c #DEDEDE",
"R 	c #E0E0E0",
"S 	c #E1E1E1",
"T 	c #E3E3E3",
"U 	c #E4E4E4",
"V 	c #E5E5E5",
"W 	c #E7E7E7",
"X 	c #E8E8E8",
"Y 	c #E9E9E9",
"Z 	c #DADADA",
"` 	c #DCDCDC",
" .	c #DDDDDD",
"..	c #DEDEDE",
"+.	c #E0E0E0",
"@.	c #E1E1E1",
"#.	c #E2E2E2",
"$.	c #E3E3E3",
"%.	c #E5E5E5",
"&.	c #EBEBEB",
"*.	c #ECECEC",
"=.	c #EDEDED",
"-.	c #EFEFEF",
"          y q e e q y           ",
"          i -.-.-.-.i           ",
"  y q e e p L =.*.J p e e q y   ",
"  i -.-.-.R l H H k R -.-.-.i   ",
"n n K =.=.B r f f r B *.&.I n b ",
"l N E F H l -.-.-.-.l H D x v a ",
"k $.Y P Q y O =.=.O z M t t G 0 ",
"j $.@...S B C H H D p t w w F 9 ",
"i $.+.` Z U O N A t v y z w C 8 ",
"h %.#.W P i | c < o s [ c } b 3 ",
"g v T  .5 3 X P x } 1 N P A 3 ) ",
"    d 6 / I ( & > 4 ^ > % ) A { ",
"      - : I V # u F y m .   A _ ",
"        ) I , + @ * * @ . = A ' ",
"        & 2 j n 7 ~ ] 7 n j 2 & ",
"          $ ; ! !     ! ! ; $   "};

Added icons/user_scale.xpm.































































































































































































































































































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
/* XPM */
static const char * user_scale_xpm[] = {
"16 16 204 2",
"  	c None",
". 	c #4A5449",
"+ 	c #5D6A5C",
"@ 	c #606D5F",
"# 	c #616D5F",
"$ 	c #616D60",
"% 	c #626D60",
"& 	c #636D60",
"* 	c #5F6A5E",
"= 	c #4B544A",
"- 	c #FBFCFB",
"; 	c #FCFEFC",
"> 	c #F8FCF7",
", 	c #F8FCF8",
"' 	c #F9FCF7",
") 	c #EEF7EC",
"! 	c #EEF7ED",
"~ 	c #EDF6EF",
"{ 	c #ECF4EE",
"] 	c #EBF4EB",
"^ 	c #F9F99D",
"/ 	c #EDB46C",
"( 	c #FE7162",
"_ 	c #E9E780",
": 	c #F4F48C",
"< 	c #CDCD52",
"[ 	c #A4C2EC",
"} 	c #8AADDD",
"| 	c #97BAEB",
"1 	c #80A7DD",
"2 	c #83ABE2",
"3 	c #75A0DA",
"4 	c #D4EAD9",
"5 	c #646E61",
"6 	c #EAEA8A",
"7 	c #DEDD72",
"8 	c #F06556",
"9 	c #DF9F56",
"0 	c #E8E873",
"a 	c #C1C146",
"b 	c #A5BBBB",
"c 	c #83A4D0",
"d 	c #8EB0DE",
"e 	c #7A9ED1",
"f 	c #7AA2D6",
"g 	c #7198CF",
"h 	c #D5EBD7",
"i 	c #646E62",
"j 	c #F9F99F",
"k 	c #EAE985",
"l 	c #FAD384",
"m 	c #F05A52",
"n 	c #F7F287",
"o 	c #D7DA60",
"p 	c #CAD598",
"q 	c #9CB7E0",
"r 	c #A9C7ED",
"s 	c #94B3E0",
"t 	c #98B8E6",
"u 	c #8CAEDE",
"v 	c #D6ECD7",
"w 	c #646E63",
"x 	c #EAEA90",
"y 	c #DEDD78",
"z 	c #EAE981",
"A 	c #E26B4E",
"B 	c #EE9D63",
"C 	c #D7D75E",
"D 	c #C9CB5B",
"E 	c #97B0D4",
"F 	c #9FBAE2",
"G 	c #8FACD6",
"H 	c #91B0DB",
"I 	c #86A7D4",
"J 	c #D7EDD6",
"K 	c #F9F9A6",
"L 	c #EAE98B",
"M 	c #FAF899",
"N 	c #EBD378",
"O 	c #FF6B65",
"P 	c #EADC77",
"Q 	c #DEDF70",
"R 	c #B5C5C1",
"S 	c #BAD1F1",
"T 	c #A9C1E5",
"U 	c #AEC7EA",
"V 	c #A1BDE4",
"W 	c #646F63",
"X 	c #F1F19F",
"Y 	c #DFDD81",
"Z 	c #EBEA8A",
"` 	c #DEDE75",
" .	c #EE9165",
"..	c #E17E55",
"+.	c #A0AF9F",
"@.	c #97AEBF",
"#.	c #8FABC9",
"$.	c #95AFCD",
"%.	c #98ABBE",
"&.	c #9FB4D2",
"*.	c #D8EDD6",
"=.	c #646F64",
"-.	c #FAFAAF",
";.	c #EBEB94",
">.	c #FAF9A2",
",.	c #F3ED95",
"'.	c #A4919B",
").	c #ABC3DD",
"!.	c #DAE6F4",
"~.	c #DFECF8",
"{.	c #C9DDF2",
"].	c #B2C9E3",
"^.	c #9BA9A4",
"/.	c #DBEFD4",
"(.	c #656F64",
"_.	c #EDEBA4",
":.	c #DFDF8D",
"<.	c #EBEB97",
"[.	c #B7CF72",
"}.	c #99CA74",
"|.	c #95AECA",
"1.	c #D5E3F2",
"2.	c #CAE0F6",
"3.	c #C6DEF5",
"4.	c #C5DEF5",
"5.	c #D2E5F7",
"6.	c #94AAC5",
"7.	c #DCE4CA",
"8.	c #666F64",
"9.	c #636E61",
"0.	c #F9FCF8",
"a.	c #FBFBBC",
"b.	c #DFE79D",
"c.	c #BBE193",
"d.	c #97C977",
"e.	c #A9DA89",
"f.	c #8DA9C8",
"g.	c #DCEAF8",
"h.	c #C6DDF4",
"i.	c #C4DCF4",
"j.	c #BDD8F3",
"k.	c #CDE2F8",
"l.	c #93ADCC",
"m.	c #DBE9D0",
"n.	c #F8FBF7",
"o.	c #C4DE9B",
"p.	c #93C373",
"q.	c #9FCF80",
"r.	c #8FC16F",
"s.	c #9DCE7E",
"t.	c #94ACC9",
"u.	c #D4E3F3",
"v.	c #C1DAF4",
"w.	c #CCE3F8",
"x.	c #8BA4C4",
"y.	c #DAEFD7",
"z.	c #AFDB96",
"A.	c #9AC97F",
"B.	c #AAD88F",
"C.	c #97C87A",
"D.	c #A9D68A",
"E.	c #929D99",
"F.	c #BCCDE2",
"G.	c #CCE0F5",
"H.	c #C7E0F7",
"I.	c #CBE2F8",
"J.	c #B3D1F3",
"K.	c #8F99A7",
"L.	c #BEBA9A",
"M.	c #EFF8EE",
"N.	c #BCDBA4",
"O.	c #A6CA8C",
"P.	c #B1D598",
"Q.	c #A1C986",
"R.	c #C0AD74",
"S.	c #B9855E",
"T.	c #98AA99",
"U.	c #94ACC7",
"V.	c #96AFCD",
"W.	c #8CA8C8",
"X.	c #8E99AB",
"Y.	c #CBB196",
"Z.	c #B68B5A",
"`.	c #6E644D",
" +	c #606A5F",
".+	c #ECF5EB",
"++	c #D7EDD4",
"@+	c #D7EED4",
"#+	c #D8EED4",
"$+	c #D8EED5",
"%+	c #D9EED5",
"&+	c #DAEFD6",
"*+	c #ECE2D4",
"=+	c #D6E5CF",
"-+	c #BAB698",
";+	c #B78F60",
">+	c #D4B18C",
",+	c #996F3F",
"'+	c #4C544B",
")+	c #616A5F",
"!+	c #676F64",
"~+	c #6D654B",
"{+	c #9E7748",
"]+	c #966F41",
". + @ @ @ @ # # # # $ % % & * = ",
"+ - ; > > > , ' , , ) ! ~ { ] * ",
"@ > ^ / ( _ : < [ } | 1 2 3 4 5 ",
"@ > 6 7 8 9 0 a b c d e f g h i ",
"# > j k l m n o p q r s t u v w ",
"# , x y z A B C D E F G H I J w ",
"# , K L M N O P Q R S T U V J W ",
"$ , X Y Z `  ...+.@.#.$.%.&.*.=.",
"% , -.;.>.Z ,.'.).!.~.{.].^./.(.",
"& , _.:.<.[.}.|.1.2.3.4.5.6.7.8.",
"9.0.a.b.c.d.e.f.g.h.i.j.k.l.m.8.",
"9.n.o.p.q.r.s.t.u.v.j.j.w.x.y.8.",
"5 ) z.A.B.C.D.E.F.G.H.I.J.K.L.8.",
"i M.N.O.P.Q.R.S.T.U.V.W.X.Y.Z.`.",
" +.+++@+#+$+%+%+&+&+*+=+-+;+>+,+",
"'+)+W =.(.(.8.8.8.8.8.!+!+~+{+]+"};

Added icons/vector_off.xpm.





























































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* XPM */
static const char * vector_off_xpm[] = {
"16 16 91 1",
" 	g None",
".	g #B3B3B3",
"+	g #B1B1B1",
"@	g #B4B4B4",
"#	g #B2B2B2",
"$	g #D5D5D5",
"%	g #CDCDCD",
"&	g #ADADAD",
"*	g #ACACAC",
"=	g #CFCFCF",
"-	g #F8F8F8",
";	g #F6F6F6",
">	g #DEDEDE",
",	g #E4E4E4",
"'	g #C1C1C1",
")	g #A6A6A6",
"!	g #B5B5B5",
"~	g #C6C6C6",
"{	g #EEEEEE",
"]	g #FEFEFE",
"^	g #FDFDFD",
"/	g #B0B0B0",
"(	g #D8D8D8",
"_	g #E2E2E2",
":	g #D7D7D7",
"<	g #A0A0A0",
"[	g #B7B7B7",
"}	g #D9D9D9",
"|	g #EBEBEB",
"1	g #DFDFDF",
"2	g #CACACA",
"3	g #C4C4C4",
"4	g #B9B9B9",
"5	g #BBBBBB",
"6	g #D1D1D1",
"7	g #DDDDDD",
"8	g #CCCCCC",
"9	g #AAAAAA",
"0	g #999999",
"a	g #ECECEC",
"b	g #D3D3D3",
"c	g #EDEDED",
"d	g #F5F5F5",
"e	g #E0E0E0",
"f	g #E5E5E5",
"g	g #DCDCDC",
"h	g #979797",
"i	g #F7F7F7",
"j	g #F3F3F3",
"k	g #D2D2D2",
"l	g #EAEAEA",
"m	g #C0C0C0",
"n	g #D6D6D6",
"o	g #949494",
"p	g #F4F4F4",
"q	g #CBCBCB",
"r	g #B8B8B8",
"s	g #DBDBDB",
"t	g #BFBFBF",
"u	g #BDBDBD",
"v	g #929292",
"w	g #AEAEAE",
"x	g #F2F2F2",
"y	g #F0F0F0",
"z	g #C3C3C3",
"A	g #C5C5C5",
"B	g #BEBEBE",
"C	g #909090",
"D	g #E8E8E8",
"E	g #DADADA",
"F	g #AFAFAF",
"G	g #C9C9C9",
"H	g #8D8D8D",
"I	g #FAFAFA",
"J	g #EFEFEF",
"K	g #B6B6B6",
"L	g #A5A5A5",
"M	g #C8C8C8",
"N	g #8B8B8B",
"O	g #A7A7A7",
"P	g #E6E6E6",
"Q	g #8A8A8A",
"R	g #C2C2C2",
"S	g #E1E1E1",
"T	g #9E9E9E",
"U	g #9C9C9C",
"V	g #D0D0D0",
"W	g #8C8C8C",
"X	g #959595",
"Y	g #939393",
"Z	g #8F8F8F",
"       .+       ",
"     @#$%&*     ",
"    @=-;>,')    ",
"  !~{]^{/(_:!<  ",
"[!}|12345(67,890",
"@-ab%'.0cd|e:fgh",
"#ijf6kk!fl_(m[no",
"+;pja:qrs>~rtukv",
"w;pxya7zAB3B[!%C",
"*;jyclDE~zB[F*GH",
"9I;J|Df_AuK&L5MN",
"OtP;{P,_'[w@24hQ",
"  <R{xDS5@%ATQ  ",
"   U0~jJbV9WQ   ",
"     XY=5XN     ",
"       ZH       "};

Added icons/wms_off.xpm.





























































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/* XPM */
static const char * wms_off_xpm[] = {
"16 16 59 1",
" 	g None",
".	g #CBCBCB",
"+	g #C9C9C9",
"@	g #C7C7C7",
"#	g #C5C5C5",
"$	g #C3C3C3",
"%	g #D2D2D2",
"&	g #D8D8D8",
"*	g #D9D9D9",
"=	g #CFCFCF",
"-	g #CACACA",
";	g #BABABA",
">	g #D1D1D1",
",	g #D6D6D6",
"'	g #C2C2C2",
")	g #BDBDBD",
"!	g #BBBBBB",
"~	g #BEBEBE",
"{	g #C8C8C8",
"]	g #BCBCBC",
"^	g #ACACAC",
"/	g #AEAEAE",
"(	g #B2B2B2",
"_	g #A3A3A3",
":	g #B8B8B8",
"<	g #B3B3B3",
"[	g #B1B1B1",
"}	g #A5A5A5",
"|	g #9D9D9D",
"1	g #C6C6C6",
"2	g #CECECE",
"3	g #B9B9B9",
"4	g #C1C1C1",
"5	g #B6B6B6",
"6	g #B5B5B5",
"7	g #B7B7B7",
"8	g #A9A9A9",
"9	g #989898",
"0	g #D0D0D0",
"a	g #B4B4B4",
"b	g #C0C0C0",
"c	g #979797",
"d	g #909090",
"e	g #919191",
"f	g #C4C4C4",
"g	g #949494",
"h	g #ABABAB",
"i	g #E1E1E1",
"j	g #AAAAAA",
"k	g #9B9B9B",
"l	g #A2A2A2",
"m	g #EDEDED",
"n	g #ECECEC",
"o	g #999999",
"p	g #8F8F8F",
"q	g #878787",
"r	g #7F7F7F",
"s	g #787878",
"t	g #717171",
"     .+.@#$     ",
"    +%&*&=-;    ",
"  .>,-'$)!~{]^  ",
" +%>#      /;(_ ",
" +>$  ;:<[  }:| ",
"12{  345678  }^9",
"$0] ab/  _(| c<d",
"]0: [(    }9 ead",
"32( 88 f] 9g d6e",
"[;h   f&ij   eke",
"      ]<jl      ",
"     ]<mnop     ",
"     <jlopq     ",
"    <jl  qrs    ",
"    j     st    ",
"   j            "};

Added icons/zoom_in.xpm.















































































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/* XPM */
static const char * zoom_in_xpm[] = {
"16 16 84 1",
" 	c None",
".	c #CEA75E",
"+	c #CEA761",
"@	c #CFA864",
"#	c #CEA662",
"$	c #CCA15D",
"%	c #C89C57",
"&	c #CFA861",
"*	c #CEA65E",
"=	c #C79A57",
"-	c #C79757",
";	c #CDA45B",
">	c #C39150",
",	c #C39153",
"'	c #CDA65E",
")	c #CDA55E",
"!	c #C18E4F",
"~	c #BD894C",
"{	c #CEA660",
"]	c #BE894D",
"^	c #CFA762",
"/	c #67B65C",
"(	c #61B057",
"_	c #5CA852",
":	c #BE8A4F",
"<	c #CDA561",
"[	c #5FAD56",
"}	c #A6D59D",
"|	c #539E4B",
"1	c #BD864C",
"2	c #C99F5B",
"3	c #63B259",
"4	c #5EAB54",
"5	c #76B76D",
"6	c #9ED195",
"7	c #6BAC63",
"8	c #448B3D",
"9	c #3E8337",
"0	c #C69956",
"a	c #C69655",
"b	c #9FD297",
"c	c #9ACF92",
"d	c #86C57D",
"e	c #90CA88",
"f	c #8BC683",
"g	c #357930",
"h	c #C49555",
"i	c #C18F4F",
"j	c #4D9645",
"k	c #65A75E",
"l	c #8BC785",
"m	c #5A9B53",
"n	c #33762E",
"o	c #2E6F29",
"p	c #C28F50",
"q	c #BE8A4D",
"r	c #82C27D",
"s	c #32742C",
"t	c #E3CC99",
"u	c #DEC48D",
"v	c #BC834F",
"w	c #BC854A",
"x	c #BC864C",
"y	c #BC844B",
"z	c #30712B",
"A	c #2A6B26",
"B	c #E8D5A3",
"C	c #E9D7A5",
"D	c #DABB80",
"E	c #AB643D",
"F	c #C18E58",
"G	c #DFC58F",
"H	c #E7D3A0",
"I	c #E0C793",
"J	c #C99B61",
"K	c #874828",
"L	c #BC8451",
"M	c #D7B57D",
"N	c #D6B57F",
"O	c #C39156",
"P	c #AB6737",
"Q	c #A55C33",
"R	c #B98048",
"S	c #AB6437",
"                ",
"   .+@#$%       ",
"  &*    =-      ",
" &;      >,     ",
"')        !~    ",
"{          ]    ",
"^      /(_ :    ",
"<      [}| 1    ",
"2    3456789    ",
"0a   _bcdefg    ",
" hi  |jklmno    ",
"  pq   9rstuv   ",
"   wx1ygzABCDE  ",
"         FGHIJK ",
"          LMNOP ",
"           QRS  "};

Added icons/zoom_out.xpm.



























































































































































































>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/* XPM */
static const char * zoom_out_xpm[] = {
"16 16 74 1",
" 	c None",
".	c #CEA75E",
"+	c #CEA761",
"@	c #CFA864",
"#	c #CEA662",
"$	c #CCA15D",
"%	c #C89C57",
"&	c #CFA861",
"*	c #CEA65E",
"=	c #C79A57",
"-	c #C79757",
";	c #CDA45B",
">	c #C39150",
",	c #C39153",
"'	c #CDA65E",
")	c #CDA55E",
"!	c #C18E4F",
"~	c #BD894C",
"{	c #CEA660",
"]	c #BE894D",
"^	c #CFA762",
"/	c #BE8A4F",
"(	c #CDA561",
"_	c #BD864C",
":	c #C99F5B",
"<	c #FE7874",
"[	c #FC6F6D",
"}	c #FA6362",
"|	c #F75456",
"1	c #F44548",
"2	c #F1353A",
"3	c #EE262E",
"4	c #C69956",
"5	c #C69655",
"6	c #F8C8BF",
"7	c #F7C0B7",
"8	c #F6B6AE",
"9	c #F4ABA4",
"0	c #F3A09B",
"a	c #EC1A23",
"b	c #C49555",
"c	c #C18F4F",
"d	c #EA111C",
"e	c #C28F50",
"f	c #BE8A4D",
"g	c #C18C52",
"h	c #D6B479",
"i	c #E3CC99",
"j	c #DEC48D",
"k	c #BC834F",
"l	c #BC854A",
"m	c #BC864C",
"n	c #BC844B",
"o	c #B77E47",
"p	c #BB814C",
"q	c #DBBF87",
"r	c #E8D5A3",
"s	c #E9D7A5",
"t	c #DABB80",
"u	c #AB643D",
"v	c #C18E58",
"w	c #DFC58F",
"x	c #E7D3A0",
"y	c #E0C793",
"z	c #C99B61",
"A	c #874828",
"B	c #BC8451",
"C	c #D7B57D",
"D	c #D6B57F",
"E	c #C39156",
"F	c #AB6737",
"G	c #A55C33",
"H	c #B98048",
"I	c #AB6437",
"                ",
"   .+@#$%       ",
"  &*    =-      ",
" &;      >,     ",
"')        !~    ",
"{          ]    ",
"^          /    ",
"(          _    ",
":    <[}|123    ",
"45   [67890a    ",
" bc  }|123ad    ",
"  ef    ghijk   ",
"   lm_nopqrstu  ",
"         vwxyzA ",
"          BCDEF ",
"           GHI  "};