[GRASS-SVN] r32664 - grass/trunk/gui/wxpython/gui_modules
svn_grass at osgeo.org
svn_grass at osgeo.org
Sun Aug 10 08:44:14 EDT 2008
Author: martinl
Date: 2008-08-10 08:44:13 -0400 (Sun, 10 Aug 2008)
New Revision: 32664
Modified:
grass/trunk/gui/wxpython/gui_modules/utils.py
grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py
Log:
wxGUI: check all mapsets in search patch when given layer name is not qualified
(merge from devbr6, r32663)
Modified: grass/trunk/gui/wxpython/gui_modules/utils.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/utils.py 2008-08-10 10:39:01 UTC (rev 32663)
+++ grass/trunk/gui/wxpython/gui_modules/utils.py 2008-08-10 12:44:13 UTC (rev 32664)
@@ -17,6 +17,8 @@
import os
import sys
+import grass
+
import globalvar
import gcmd
import grassenv
@@ -57,12 +59,16 @@
except:
return None
-def GetLayerNameFromCmd(dcmd, fullyQualified=False, param=None):
+def GetLayerNameFromCmd(dcmd, fullyQualified=False, param=None,
+ layerType=None):
"""Get map name from GRASS command
@param dcmd GRASS command (given as list)
@param fullyQualified change map name to be fully qualified
@param force parameter otherwise 'input'/'map'
+ @param update change map name in command
+ @param layerType check also layer type ('raster', 'vector', '3d-raster', ...)
+
@return map name
@return '' if no map name found in command
"""
@@ -94,10 +100,23 @@
if idx < len(dcmd):
mapname = dcmd[idx].split('=')[1]
if fullyQualified and '@' not in mapname:
- dcmd[idx] = dcmd[idx].split('=')[0] + '=' + \
- mapname + '@' + grassenv.GetGRASSVariable('MAPSET')
- mapname = dcmd[idx].split('=')[1]
-
+ if layerType in ('raster', 'vector', '3d-raster'):
+ try:
+ if layerType == 'raster':
+ findType = 'cell'
+ else:
+ findType = layerType
+ result = grass.find_file(mapname, element=findType)
+ except AttributeError, e: # not found
+ return ''
+ if result:
+ mapname = result['fullname']
+ else:
+ mapname += '@' + grassenv.GetGRASSVariable('MAPSET')
+ else:
+ mapname += '@' + grassenv.GetGRASSVariable('MAPSET')
+ dcmd[idx] = dcmd[idx].split('=')[0] + '=' + mapname
+
return mapname
def GetValidLayerName(name):
Modified: grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py 2008-08-10 10:39:01 UTC (rev 32663)
+++ grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py 2008-08-10 12:44:13 UTC (rev 32664)
@@ -1131,8 +1131,18 @@
# set layer text to map name
if dcmd:
- opacity = int(self.GetPyData(layer)[0]['maplayer'].GetOpacity(float=True) * 100)
- mapname = utils.GetLayerNameFromCmd(dcmd, fullyQualified=True)
+ mapLayer = self.GetPyData(layer)[0]['maplayer']
+ opacity = int(mapLayer.GetOpacity(float=True) * 100)
+ mapname = utils.GetLayerNameFromCmd(dcmd, layerType=mapLayer.type,
+ fullyQualified=True)
+ if not mapname:
+ wx.MessageBox(parent=self,
+ message=_("Map <%s> not found.") % utils.GetLayerNameFromCmd(dcmd),
+ caption=_("Error"),
+ style=wx.OK | wx.ICON_ERROR | wx.CENTRE)
+
+ return
+
self.SetItemText(layer, mapname + ' (opacity: ' + str(opacity) + '%)')
# update layer data
@@ -1142,12 +1152,9 @@
self.GetPyData(layer)[0]['cmd'] = dcmd
self.GetPyData(layer)[0]['propwin'] = propwin
- # check layer as active
- # self.CheckItem(layer, checked=True)
-
# change parameters for item in layers list in render.Map
self.ChangeLayer(layer)
-
+
if self.mapdisplay.toolbars['nviz'] and dcmd:
# update nviz session
mapLayer = self.GetPyData(layer)[0]['maplayer']
More information about the grass-commit
mailing list