[GRASS-SVN] r38258 - in grass/trunk/gui/wxpython: . gui_modules xml

svn_grass at osgeo.org svn_grass at osgeo.org
Sun Jul 5 12:39:03 EDT 2009


Author: martinl
Date: 2009-07-05 12:39:03 -0400 (Sun, 05 Jul 2009)
New Revision: 38258

Modified:
   grass/trunk/gui/wxpython/gui_modules/globalvar.py
   grass/trunk/gui/wxpython/gui_modules/mapdisp.py
   grass/trunk/gui/wxpython/gui_modules/preferences.py
   grass/trunk/gui/wxpython/gui_modules/workspace.py
   grass/trunk/gui/wxpython/wxgui.py
   grass/trunk/gui/wxpython/xml/grass-gxw.dtd
Log:
wxGUI: projection statusbar info checkbox moved to the mapdisplay
status and stored in workspace file


Modified: grass/trunk/gui/wxpython/gui_modules/globalvar.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/globalvar.py	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/gui_modules/globalvar.py	2009-07-05 16:39:03 UTC (rev 38258)
@@ -99,7 +99,8 @@
                               _("Display mode"),
                               _("Display geometry"),
                               _("Map scale"),
-                              _("Go to")]
+                              _("Go to"),
+                              _("Projection"),]
 
 """!File name extension binaries/scripts"""
 if subprocess.mswindows:

Modified: grass/trunk/gui/wxpython/gui_modules/mapdisp.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/mapdisp.py	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/gui_modules/mapdisp.py	2009-07-05 16:39:03 UTC (rev 38258)
@@ -207,6 +207,16 @@
         self.statusbarWin['goto'].Hide()
         self.statusbar.Bind(wx.EVT_TEXT_ENTER, self.OnGoTo, self.statusbarWin['goto'])
 
+        # projection
+        self.statusbarWin['projection'] = wx.CheckBox(parent=self.statusbar, id=wx.ID_ANY,
+                                                      label=_("Use defined projection"))
+        self.statusbarWin['projection'].SetValue(False)
+        self.statusbarWin['projection'].SetToolTip(wx.ToolTip (_("Reproject coordinates displayed "
+                                                                 "in the statusbar. Projection can be "
+                                                                 "defined in GUI preferences dialog "
+                                                                 "(tab 'Display')")))
+        self.statusbarWin['projection'].Hide()
+        
         # mask
         self.statusbarWin['mask'] = wx.StaticText(parent = self.statusbar, id = wx.ID_ANY,
                                                   label = '')
@@ -549,22 +559,24 @@
                 self.statusbar.SetStatusText("%.2f, %.2f (seg: %.2f; tot: %.2f)" % \
                                                  (e, n, distance_seg, distance_tot), 0)
             else:
-                if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
-                        UserSettings.Get(group='display', key='projection', subkey='proj4'):
-                    proj, coord  = utils.ReprojectCoordinates(coord = (e, n),
-                                                              projOut = UserSettings.Get(group='display',
-                                                                                         key='projection',
-                                                                                         subkey='proj4'),
-                                                              flags = 'd')
+                if self.statusbarWin['projection'].IsChecked():
+                    if not UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                        self.statusbar.SetStatusText(_("Projection not defined (check the settings)"), 0)
+                    else:
+                        proj, coord  = utils.ReprojectCoordinates(coord = (e, n),
+                                                                  projOut = UserSettings.Get(group='display',
+                                                                                             key='projection',
+                                                                                             subkey='proj4'),
+                                                                  flags = 'd')
                     
-                    if coord:
-                        e, n = coord
-                        if proj in ('ll', 'latlong', 'longlat'):
-                            self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
+                        if coord:
+                            e, n = coord
+                            if proj in ('ll', 'latlong', 'longlat'):
+                                self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
+                            else:
+                                self.statusbar.SetStatusText("%.2f; %.2f" % (e, n), 0)
                         else:
-                            self.statusbar.SetStatusText("%.2f; %.2f" % (e, n), 0)
-                    else:
-                        self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
+                            self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
                 else:
                     if self.Map.projinfo['proj'] == 'll':
                         self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
@@ -790,29 +802,31 @@
         Go to position
         """
         try:
-            if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
-                    UserSettings.Get(group='display', key='projection', subkey='proj4'):
-                # reproject values
-                projIn = UserSettings.Get(group='display',
-                                          key='projection',
-                                          subkey='proj4')
-                projOut = gcmd.RunCommand('g.proj',
-                                          flags = 'jf',
-                                          read = True)
-                proj = projIn.split(' ')[0].split('=')[1]
-                if proj in ('ll', 'latlong', 'longlat'):
-                    e, n = self.statusbarWin['goto'].GetValue().split(';')
-                    e, n = utils.DMS2Deg(e, n)
-                    proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
-                                                              projIn = projIn,
-                                                              projOut = projOut, flags = 'd')
-                    e, n = coord1
+            if self.statusbarWin['projection'].IsChecked():
+                if not UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                    self.statusbar.SetStatusText(_("Projection not defined (check the settings)"), 0)
                 else:
-                    e, n = map(float, self.statusbarWin['goto'].GetValue().split(';'))
-                    proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
-                                                              projIn = projIn,
-                                                              projOut = projOut, flags = 'd')
-                    e, n = coord1
+                    # reproject values
+                    projIn = UserSettings.Get(group='display',
+                                              key='projection',
+                                              subkey='proj4')
+                    projOut = gcmd.RunCommand('g.proj',
+                                              flags = 'jf',
+                                              read = True)
+                    proj = projIn.split(' ')[0].split('=')[1]
+                    if proj in ('ll', 'latlong', 'longlat'):
+                        e, n = self.statusbarWin['goto'].GetValue().split(';')
+                        e, n = utils.DMS2Deg(e, n)
+                        proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
+                                                                  projIn = projIn,
+                                                                  projOut = projOut, flags = 'd')
+                        e, n = coord1
+                    else:
+                        e, n = map(float, self.statusbarWin['goto'].GetValue().split(';'))
+                        proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
+                                                                  projIn = projIn,
+                                                                  projOut = projOut, flags = 'd')
+                        e, n = coord1
             else:
                 if self.Map.projinfo['proj'] == 'll':
                     e, n = self.statusbarWin['goto'].GetValue().split(';')
@@ -820,9 +834,11 @@
                     e, n = map(float, self.statusbarWin['goto'].GetValue().split(';'))
                     
             region = self.Map.GetCurrentRegion()
-            if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
-                    UserSettings.Get(group='display', key='projection', subkey='proj4'):
-                region['center_easting'], region['center_northing'] = e, n
+            if self.statusbarWin['projection'].IsChecked():
+                if not UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                    self.statusbar.SetStatusText(_("Projection not defined (check the settings)"), 0)
+                else:
+                    region['center_easting'], region['center_northing'] = e, n
             else:
                 if self.Map.projinfo['proj'] == 'll':
                     region['center_easting'], region['center_northing'] = utils.DMS2Deg(e, n)
@@ -863,6 +879,7 @@
         self.statusbarWin['resolution'].Hide()
         self.statusbarWin['mapscale'].Hide()
         self.statusbarWin['goto'].Hide()
+        self.statusbarWin['projection'].Hide()
         self.mapScaleValue = self.ppm = None
 
         if self.statusbarWin['toggle'].GetSelection() == 0: # Coordinates
@@ -877,45 +894,47 @@
             else:
                 region = self.Map.GetRegion() # computation region
 
-            if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
-                    UserSettings.Get(group='display', key='projection', subkey='proj4'):
-                projOut = UserSettings.Get(group='display',
-                                           key='projection',
-                                           subkey='proj4')
-                proj, coord1 = utils.ReprojectCoordinates(coord = (region["w"], region["s"]),
+            if self.statusbarWin['projection'].IsChecked():
+                if not UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                    self.statusbar.SetStatusText(_("Projection not defined (check the settings)"), 0)
+                else:
+                    projOut = UserSettings.Get(group='display',
+                                               key='projection',
+                                               subkey='proj4')
+                    proj, coord1 = utils.ReprojectCoordinates(coord = (region["w"], region["s"]),
+                                                              projOut = projOut, flags = 'd')
+                    proj, coord2 = utils.ReprojectCoordinates(coord = (region["e"], region["n"]),
                                                           projOut = projOut, flags = 'd')
-                proj, coord2 = utils.ReprojectCoordinates(coord = (region["e"], region["n"]),
-                                                          projOut = projOut, flags = 'd')
-                if sel == 2:
-                    proj, coord3 = utils.ReprojectCoordinates(coord = (0.0, 0.0),
-                                                              projOut = projOut, flags = 'd')
-                    proj, coord4 = utils.ReprojectCoordinates(coord = (region["ewres"], region["nsres"]),
-                                                              projOut = projOut, flags = 'd')
-                if coord1 and coord2:
-                    if proj in ('ll', 'latlong', 'longlat'):
-                        w, s = utils.Deg2DMS(coord1[0], coord1[1], string = False)
-                        e, n = utils.Deg2DMS(coord2[0], coord2[1], string = False)
-                        if sel == 1:
-                            self.statusbar.SetStatusText("%s - %s, %s - %s" %
+                    if sel == 2:
+                        proj, coord3 = utils.ReprojectCoordinates(coord = (0.0, 0.0),
+                                                                  projOut = projOut, flags = 'd')
+                        proj, coord4 = utils.ReprojectCoordinates(coord = (region["ewres"], region["nsres"]),
+                                                                  projOut = projOut, flags = 'd')
+                    if coord1 and coord2:
+                        if proj in ('ll', 'latlong', 'longlat'):
+                            w, s = utils.Deg2DMS(coord1[0], coord1[1], string = False)
+                            e, n = utils.Deg2DMS(coord2[0], coord2[1], string = False)
+                            if sel == 1:
+                                self.statusbar.SetStatusText("%s - %s, %s - %s" %
+                                                             (w, e, s, n), 0)
+                            else:
+                                ewres, nsres = utils.Deg2DMS(abs(coord3[0]) - abs(coord4[0]),
+                                                             abs(coord3[1]) - abs(coord4[1]),
+                                                             string = False, hemisphere = False)
+                                self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
+                                                             (w, e, s, n, ewres, nsres), 0)
+                        else:
+                            w, s = coord1
+                            e, n = coord2
+                            if sel == 1:
+                                self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
                                                          (w, e, s, n), 0)
-                        else:
-                            ewres, nsres = utils.Deg2DMS(abs(coord3[0]) - abs(coord4[0]),
-                                                         abs(coord3[1]) - abs(coord4[1]),
-                                                         string = False, hemisphere = False)
-                            self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
-                                                         (w, e, s, n, ewres, nsres), 0)
+                            else:
+                                ewres, nsres = coord3
+                                self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f (%.2f, %.2f)" %
+                                                             (w, e, s, n, ewres, nsres), 0)
                     else:
-                        w, s = coord1
-                        e, n = coord2
-                        if sel == 1:
-                            self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
-                                                         (w, e, s, n), 0)
-                        else:
-                            ewres, nsres = coord3
-                            self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f (%.2f, %.2f)" %
-                                                         (w, e, s, n, ewres, nsres), 0)
-                else:
-                    self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
+                        self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
             else:
                 if self.Map.projinfo['proj'] == 'll':
                     w, s = utils.Deg2DMS(region["w"], region["s"],
@@ -1014,23 +1033,25 @@
         elif self.statusbarWin['toggle'].GetSelection() == 7: # go to
             self.statusbar.SetStatusText("")
             region = self.Map.GetCurrentRegion()
-            if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
-                        UserSettings.Get(group='display', key='projection', subkey='proj4'):
-                proj, coord  = utils.ReprojectCoordinates(coord = (region['center_easting'],
-                                                                   region['center_northing']),
-                                                          projOut = UserSettings.Get(group='display',
-                                                                                     key='projection',
-                                                                                     subkey='proj4'),
-                                                          flags = 'd')
-                if coord:
-                    if proj in ('ll', 'latlong', 'longlat'):
-                        self.statusbarWin['goto'].SetValue("%s" % utils.Deg2DMS(coord[0],
+            if self.statusbarWin['projection'].IsChecked():
+                if not UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                    self.statusbar.SetStatusText(_("Projection not defined (check the settings)"), 0)
+                else:
+                    proj, coord  = utils.ReprojectCoordinates(coord = (region['center_easting'],
+                                                                       region['center_northing']),
+                                                              projOut = UserSettings.Get(group='display',
+                                                                                         key='projection',
+                                                                                         subkey='proj4'),
+                                                              flags = 'd')
+                    if coord:
+                        if proj in ('ll', 'latlong', 'longlat'):
+                            self.statusbarWin['goto'].SetValue("%s" % utils.Deg2DMS(coord[0],
                                                                                 coord[1]))
+                        else:
+                            self.statusbarWin['goto'].SetValue("%.2f; %.2f" % (coord[0],
+                                                                           coord[1]))
                     else:
-                        self.statusbarWin['goto'].SetValue("%.2f; %.2f" % (coord[0],
-                                                                           coord[1]))
-                else:
-                    self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
+                        self.statusbar.SetStatusText(_("Error in projection (check the settings)"), 0)
             else:
                 if self.Map.projinfo['proj'] == 'll':
                     self.statusbarWin['goto'].SetValue("%s" % utils.Deg2DMS(region['center_easting'], 
@@ -1043,6 +1064,13 @@
             # disable long help
             self.StatusbarEnableLongHelp(False)
         
+        elif self.statusbarWin['toggle'].GetSelection() == 8: # projection
+            self.statusbar.SetStatusText("")
+            self.statusbarWin['projection'].Show()
+            
+            # disable long help
+            self.StatusbarEnableLongHelp(False)
+            
         else:
             self.statusbar.SetStatusText("", 1)
 
@@ -1059,6 +1087,7 @@
                    (0, self.statusbarWin['resolution']),
                    (0, self.statusbarWin['mapscale']),
                    (0, self.statusbarWin['progress']),
+                   (0, self.statusbarWin['projection']),
                    (1, self.statusbarWin['toggle']),
                    (2, self.statusbarWin['mask']),
                    (3, self.statusbarWin['render'])]
@@ -1868,16 +1897,17 @@
         zoommenu.Destroy()
 
     def SetProperties(self, render=False, mode=0, showCompExtent=False,
-                      constrainRes=False):
+                      constrainRes=False, projection=False):
         """!Set properies of map display window"""
         self.statusbarWin['render'].SetValue(render)
         self.statusbarWin['toggle'].SetSelection(mode)
         self.StatusbarUpdate()
         self.statusbarWin['region'].SetValue(showCompExtent)
         self.statusbarWin['resolution'].SetValue(constrainRes)
+        self.statusbarWin['projection'].SetValue(projection)
         if showCompExtent:
             self.MapWindow.regionCoords = []
-
+        
     def IsStandalone(self):
         """!Check if Map display is standalone"""
         if self._layerManager:

Modified: grass/trunk/gui/wxpython/gui_modules/preferences.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/preferences.py	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/gui_modules/preferences.py	2009-07-05 16:39:03 UTC (rev 38258)
@@ -114,7 +114,6 @@
                     'color' : (255, 255, 255, 255),
                     },
                 'projection' : {
-                    'enabled' : False,
                     'proj4'   : '',
                     'epsg'    : '',
                     },
@@ -1134,17 +1133,17 @@
         gridSizer.AddGrowableCol(1)
 
         row = 0
-        useProj = wx.CheckBox(parent=panel, id=wx.ID_ANY,
-                              label=_("Use defined projection"),
-                              name="IsChecked")
-        useProj.SetValue(self.settings.Get(group='display', key='projection', subkey='enabled'))
-        self.winId['display:projection:enabled'] = useProj.GetId()
+        # useProj = wx.CheckBox(parent=panel, id=wx.ID_ANY,
+        # label=_("Use defined projection"),
+        #                       name="IsChecked")
+        # useProj.SetValue(self.settings.Get(group='display', key='projection', subkey='enabled'))
+        # self.winId['display:projection:enabled'] = useProj.GetId()
+        #
+        # gridSizer.Add(item=useProj,
+        #              pos=(row, 0), span=(1, 3))
 
-        gridSizer.Add(item=useProj,
-                      pos=(row, 0), span=(1, 3))
-
         # epsg
-        row += 1
+        #row += 1
         label = wx.StaticText(parent=panel, id=wx.ID_ANY,
                               label=_("EPSG code:"))
         epsgCode = wx.ComboBox(parent=panel, id=wx.ID_ANY,
@@ -1187,10 +1186,6 @@
                              label=_("&Load EPSG codes"))
         self.winId['display:projection:projFile'] = projFile.GetId()
         
-        if not useProj.IsChecked():
-            projString.Enable(False)
-            epsgCode.Enable(False)
-
         gridSizer.Add(item=label,
                       pos=(row, 0),
                       flag = wx.ALIGN_CENTER_VERTICAL)
@@ -1210,7 +1205,6 @@
         epsgLoad.Bind(wx.EVT_BUTTON, self.OnLoadEpsgCodes)
         epsgCode.Bind(wx.EVT_COMBOBOX, self.OnSetEpsgCode)
         epsgCode.Bind(wx.EVT_TEXT_ENTER, self.OnSetEpsgCode)
-        useProj.Bind(wx.EVT_CHECKBOX, self.OnSetProj)
         
         return panel
 
@@ -1601,17 +1595,7 @@
             list.SetSelection(0)
             code = int(list.GetStringSelection())
             win.SetValue(self.epsgCodeDict[code][1])
-        
-    def OnSetProj(self, event):
-        """!Enable mapdisplay window statusbar projection"""
-        checked = event.IsChecked()
-
-        winCode = self.FindWindowById(self.winId['display:projection:epsg'])
-        winString = self.FindWindowById(self.winId['display:projection:proj4'])
-        
-        winCode.Enable(checked)
-        winString.Enable(checked)
-        
+    
     def OnSetEpsgCode(self, event):
         """!EPSG code selected"""
         winCode = self.FindWindowById(event.GetId())

Modified: grass/trunk/gui/wxpython/gui_modules/workspace.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/workspace.py	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/gui_modules/workspace.py	2009-07-05 16:39:03 UTC (rev 38258)
@@ -133,6 +133,15 @@
             else:
                 extent = None
             
+            # projection
+            node_projection = display.find('projection')
+            if node_projection is not None:
+                projection = { 'enabled' : True,
+                               'epsg' : node_projection.get('epsg', ''),
+                               'proj' : self.__getNodeText(node_projection, 'value') }
+            else:
+                projection = { 'enabled' : False }
+            
             self.displays.append( {
                     "render"         : bool(int(display.get('render', "0"))),
                     "mode"           : int(display.get('mode', 0)),
@@ -140,7 +149,8 @@
                     "pos"            : pos,
                     "size"           : size,
                     "extent"         : extent,
-                    "constrainRes"   : bool(int(display.get('constrainRes', "0"))) } )
+                    "constrainRes"   : bool(int(display.get('constrainRes', "0"))),
+                    "projection"     : projection, } )
             
             # process all layers/groups in the display
             self.__processLayers(display)
@@ -695,6 +705,21 @@
                                                     region['e'],
                                                     region['n']
                                                     ))
+            # projection statusbar info
+            if mapTree.mapdisplay.statusbarWin['projection'].IsChecked() and \
+                    UserSettings.Get(group='display', key='projection', subkey='proj4'):
+                self.indent += 4
+                file.write('%s<projection' % (' ' * self.indent))
+                epsg = UserSettings.Get(group='display', key='projection', subkey='epsg')
+                if epsg:
+                    file.write(' epsg="%s"' % epsg)
+                file.write('>\n')
+                proj = UserSettings.Get(group='display', key='projection', subkey='proj4')
+                self.indent += 4 
+                file.write('%s<value>%s</value>\n' % (' ' * self.indent, proj))
+                self.indent -= 4
+                file.write('%s</projection>\n' % (' ' * self.indent))
+                self.indent -= 4
             
             # list of layers
             item = mapTree.GetFirstChild(mapTree.root)[0]

Modified: grass/trunk/gui/wxpython/wxgui.py
===================================================================
--- grass/trunk/gui/wxpython/wxgui.py	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/wxgui.py	2009-07-05 16:39:03 UTC (rev 38258)
@@ -638,7 +638,16 @@
             mapdisplay[-1].SetProperties(render=display['render'],
                                          mode=display['mode'],
                                          showCompExtent=display['showCompExtent'],
-                                         constrainRes=display['constrainRes'])
+                                         constrainRes=display['constrainRes'],
+                                         projection=display['projection']['enabled'])
+
+            if display['projection']['enabled']:
+                if display['projection']['epsg']:
+                    UserSettings.Set(group = 'display', key = 'projection', subkey = 'epsg',
+                                     value = display['projection']['epsg'])
+                    if display['projection']['proj']:
+                        UserSettings.Set(group = 'display', key = 'projection', subkey = 'proj4',
+                                         value = display['projection']['proj'])
             
             # set position and size of map display
             if UserSettings.Get(group='workspace', key='posDisplay', subkey='enabled') is False:

Modified: grass/trunk/gui/wxpython/xml/grass-gxw.dtd
===================================================================
--- grass/trunk/gui/wxpython/xml/grass-gxw.dtd	2009-07-05 15:27:18 UTC (rev 38257)
+++ grass/trunk/gui/wxpython/xml/grass-gxw.dtd	2009-07-05 16:39:03 UTC (rev 38258)
@@ -30,7 +30,7 @@
 
         render, mode and showCompExtent (added 2004/08)
 -->
-<!ELEMENT display ((group|layer)*)>
+<!ELEMENT display (projection?, (group|layer)*)>
 <!ATTLIST display  render	   (0 | 1) #IMPLIED>
 <!ATTLIST display  mode            (0 | 1 | 2 | 3 | 4 | 5 | 6) #IMPLIED>
 <!ATTLIST display  showCompExtent  (0 | 1) #IMPLIED>
@@ -39,6 +39,11 @@
 <!ATTLIST display  dim             CDATA   #IMPLIED>
 <!ATTLIST display  extent          CDATA   #IMPLIED>
 
+<!-- projection (statusbar coordinates)
+-->
+<!ELEMENT projection   (value?)>
+<!ATTLIST projection   epsg	CDATA   #IMPLIED>
+
 <!--    group of map layers
 -->
 <!ELEMENT group (layer*)>



More information about the grass-commit mailing list