[GRASS-SVN] r47431 - grass/branches/releasebranch_6_4/lib/python
svn_grass at osgeo.org
svn_grass at osgeo.org
Thu Aug 4 08:56:02 EDT 2011
Author: martinl
Date: 2011-08-04 05:56:02 -0700 (Thu, 04 Aug 2011)
New Revision: 47431
Modified:
grass/branches/releasebranch_6_4/lib/python/core.py
Log:
pythonlib: fix list_grouped() to list all mapsets in the search path
remove mlist() - can be replaced by mlist_grouped()
(merge r47427 from trunk)
Modified: grass/branches/releasebranch_6_4/lib/python/core.py
===================================================================
--- grass/branches/releasebranch_6_4/lib/python/core.py 2011-08-04 12:54:03 UTC (rev 47430)
+++ grass/branches/releasebranch_6_4/lib/python/core.py 2011-08-04 12:56:02 UTC (rev 47431)
@@ -618,6 +618,9 @@
dashes_re = re.compile("^----+$")
mapset_re = re.compile("<(.*)>")
result = {}
+ for mapset in mapsets(accessible = True):
+ result[mapset] = []
+
mapset = None
for line in read_command("g.list", type = type).splitlines():
if line == "":
@@ -627,7 +630,6 @@
m = mapset_re.search(line)
if m:
mapset = m.group(1)
- result[mapset] = []
continue
if mapset:
result[mapset].extend(line.split())
@@ -677,24 +679,6 @@
# 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.
@@ -712,20 +696,20 @@
@return directory of mapsets/elements
"""
- result = dict()
- mapset_element = None
+ result = {}
+ for mapset in mapsets(accessible = True):
+ result[mapset] = []
+
+ mapset = None
for line in read_command("g.mlist", flags = "m",
type = type, pattern = pattern).splitlines():
try:
- map, mapset_element = line.split('@')
+ name, mapset = line.split('@')
except ValueError:
warning(_("Invalid element '%s'") % line)
continue
- if mapset_element in result:
- result[mapset_element].append(map)
- else:
- result[mapset_element] = [map, ]
+ result[mapset].append(name)
return result
More information about the grass-commit
mailing list