[GRASS-SVN] r44491 - in grass/trunk: gui/wxpython/gui_modules
lib/python
svn_grass at osgeo.org
svn_grass at osgeo.org
Mon Nov 29 16:07:25 EST 2010
Author: martinl
Date: 2010-11-29 13:07:25 -0800 (Mon, 29 Nov 2010)
New Revision: 44491
Modified:
grass/trunk/gui/wxpython/gui_modules/gdialogs.py
grass/trunk/lib/python/core.py
Log:
pythonlib: define mlist()
(merge r44489 from devbr6)
Modified: grass/trunk/gui/wxpython/gui_modules/gdialogs.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/gdialogs.py 2010-11-29 21:06:54 UTC (rev 44490)
+++ grass/trunk/gui/wxpython/gui_modules/gdialogs.py 2010-11-29 21:07:25 UTC (rev 44491)
@@ -829,11 +829,7 @@
@param type layer type ('raster' or 'vector')
@param mapset mapset name
"""
- try:
- self.map_layers = grass.mlist_grouped(type=type, mapset=mapset)[mapset]
- except KeyError:
- self.map_layers = []
-
+ self.map_layers = grass.mlist(type = type, mapset = mapset)
self.layers.Set(self.map_layers)
# check all items by default
Modified: grass/trunk/lib/python/core.py
===================================================================
--- grass/trunk/lib/python/core.py 2010-11-29 21:06:54 UTC (rev 44490)
+++ grass/trunk/lib/python/core.py 2010-11-29 21:07:25 UTC (rev 44491)
@@ -613,40 +613,6 @@
return result
-def mlist_grouped(type, pattern = None):
- """!List of elements grouped by mapsets.
-
- Returns the output from running g.mlist, as a dictionary where the
- keys are mapset names and the values are lists of maps in that
- mapset. Example:
-
- @code
- >>> grass.mlist_grouped('rast', pattern='r*')['PERMANENT']
- ['railroads', 'roads', 'rstrct.areas', 'rushmore']
- @endcode
-
- @param type element type (rast, vect, rast3d, region, ...)
- @param pattern pattern string
-
- @return directory of mapsets/elements
- """
- result = {}
- mapset_element = None
- for line in read_command("g.mlist", flags="m",
- type = type, pattern = pattern).splitlines():
- try:
- map, mapset_element = line.split('@')
- except ValueError:
- print >> sys.stderr, "Invalid element '%s'" % line
- continue
-
- if result.has_key(mapset_element):
- result[mapset_element].append(map)
- else:
- result[mapset_element] = [map, ]
-
- return result
-
def _concat(xs):
result = []
for x in xs:
@@ -688,6 +654,60 @@
"""
return ["%s@%s" % pair for pair in list_pairs(type)]
+# interface to g.mlist
+
+def mlist(type, pattern = None, mapset = None):
+ """!List of elements
+
+ @param type element type (rast, vect, rast3d, region, ...)
+ @param pattern pattern string
+ @param mapset mapset name (if not given use search path)
+
+ @return list of elements
+ """
+ result = list()
+ for line in read_command("g.mlist",
+ type = type,
+ pattern = pattern,
+ mapset = mapset).splitlines():
+ result.append(line.strip())
+
+ return result
+
+def mlist_grouped(type, pattern = None):
+ """!List of elements grouped by mapsets.
+
+ Returns the output from running g.mlist, as a dictionary where the
+ keys are mapset names and the values are lists of maps in that
+ mapset. Example:
+
+ @code
+ >>> grass.mlist_grouped('rast', pattern='r*')['PERMANENT']
+ ['railroads', 'roads', 'rstrct.areas', 'rushmore']
+ @endcode
+
+ @param type element type (rast, vect, rast3d, region, ...)
+ @param pattern pattern string
+
+ @return directory of mapsets/elements
+ """
+ result = dict()
+ mapset_element = None
+ for line in read_command("g.mlist", flags = "m",
+ type = type, pattern = pattern).splitlines():
+ try:
+ map, mapset_element = line.split('@')
+ except ValueError:
+ warning(_("Invalid element '%s'") % line)
+ continue
+
+ if result.has_key(mapset_element):
+ result[mapset_element].append(map)
+ else:
+ result[mapset_element] = [map, ]
+
+ return result
+
# color parsing
named_colors = {
More information about the grass-commit
mailing list