[GRASS-SVN] r46058 - grass/branches/releasebranch_6_4/gui/scripts

svn_grass at osgeo.org svn_grass at osgeo.org
Thu Apr 21 04:07:10 EDT 2011


Author: martinl
Date: 2011-04-21 01:07:10 -0700 (Thu, 21 Apr 2011)
New Revision: 46058

Modified:
   grass/branches/releasebranch_6_4/gui/scripts/g.extension.py
Log:
backport g.extension.py from trunk


Modified: grass/branches/releasebranch_6_4/gui/scripts/g.extension.py
===================================================================
--- grass/branches/releasebranch_6_4/gui/scripts/g.extension.py	2011-04-21 08:02:02 UTC (rev 46057)
+++ grass/branches/releasebranch_6_4/gui/scripts/g.extension.py	2011-04-21 08:07:10 UTC (rev 46058)
@@ -20,9 +20,7 @@
 #%module
 #% label: Tool to maintain the extensions in local GRASS installation.
 #% description: Downloads, installs extensions from GRASS Addons SVN repository into local GRASS installation or removes installed extensions.
-#% keywords: general
-#% keywords: installation
-#% keywords: extensions
+#% keywords: general, installation, extensions
 #%end
 
 #%option
@@ -78,7 +76,7 @@
 #%end
 #%flag
 #% key: d
-#% description: Don't delete downloaded source code when installing new extension
+#% description: Download source code and exit
 #%end
 #%flag
 #% key: i
@@ -122,7 +120,7 @@
     
     return c
 
-def list_available_modules(svnurl, full = False, shell = False):
+def list_available_modules():
     mlist = list()
     grass.message(_('Fetching list of modules from GRASS-Addons SVN (be patient)...'))
     pattern = re.compile(r'(<li><a href=".+">)(.+)(</a></li>)', re.IGNORECASE)
@@ -131,14 +129,14 @@
               'p', 'r', 'r3', 's', 'v']
     nprefix = len(prefix)
     for d in prefix:
-        if shell:
+        if flags['g']:
             grass.percent(i, nprefix, 1)
             i += 1
         
         modclass = expand_module_class_name(d)
         grass.verbose(_("Checking for '%s' modules...") % modclass)
         
-        url = '%s/%s' % (svnurl, modclass)
+        url = '%s/%s' % (options['svnurl'], modclass)
         grass.debug("url = %s" % url, debug = 2)
         f = urllib.urlopen(url)
         if not f:
@@ -152,23 +150,23 @@
                 continue
             name = sline.group(2).rstrip('/')
             if name.split('.', 1)[0] == d:
-                print_module_desc(name, url, full, shell)
+                print_module_desc(name, url)
                 mlist.append(name)
     
-    mlist += list_wxgui_extensions(svnurl, full, shell)
+    mlist += list_wxgui_extensions()
     
-    if shell:
+    if flags['g']:
         grass.percent(1, 1, 1)
     
     return mlist
 
-def list_wxgui_extensions(svnurl, full = False, shell = False, print_module = True):
+def list_wxgui_extensions(print_module = True):
     mlist = list()
     grass.debug('Fetching list of wxGUI extensions from GRASS-Addons SVN (be patient)...')
     pattern = re.compile(r'(<li><a href=".+">)(.+)(</a></li>)', re.IGNORECASE)
     grass.verbose(_("Checking for '%s' modules...") % 'gui/wxpython')
     
-    url = '%s/%s' % (svnurl, 'gui/wxpython')
+    url = '%s/%s' % (options['svnurl'], 'gui/wxpython')
     grass.debug("url = %s" % url, debug = 2)
     f = urllib.urlopen(url)
     if not f:
@@ -183,17 +181,17 @@
         name = sline.group(2).rstrip('/')
         if name not in ('..', 'Makefile'):
             if print_module:
-                print_module_desc(name, url, full, shell)
+                print_module_desc(name, url)
             mlist.append(name)
     
     return mlist
 
-def print_module_desc(name, url, full = False, shell = False):
-    if not full and not shell:
+def print_module_desc(name, url):
+    if not flags['f'] and not flags['g']:
         print name
         return
     
-    if shell:
+    if flags['g']:
         print 'name=' + name
     
     # check main.c first
@@ -201,11 +199,11 @@
     if not desc:
         desc = get_module_desc(url + '/' + name + '/main.c', script = False)
     if not desc:
-        if not shell:
+        if not flags['g']:
             print name + '-'
             return
     
-    if shell:
+    if flags['g']:
         print 'description=' + desc.get('description', '')
         print 'keywords=' + ','.join(desc.get('keywords', list()))
     else:
@@ -289,26 +287,26 @@
     else:
         grass.info(_("Path to the source code: '%s'") % tmpdir)
                         
-def install_extension(svnurl, prefix, module, no_install):
+def install_extension():
     gisbase = os.getenv('GISBASE')
     if not gisbase:
         grass.fatal(_('$GISBASE not defined'))
     
-    if grass.find_program(module):
-        grass.warning(_("Extension '%s' already installed. Will be updated...") % module)
+    if grass.find_program(options['extension']):
+        grass.warning(_("Extension '%s' already installed. Will be updated...") % options['extension'])
     
-    gui_list = list_wxgui_extensions(svnurl, print_module = False)
+    gui_list = list_wxgui_extensions(print_module = False)
 
-    if module not in gui_list:
-        classchar = module.split('.', 1)[0]
+    if options['extension'] not in gui_list:
+        classchar = options['extension'].split('.', 1)[0]
         moduleclass = expand_module_class_name(classchar)
-        url = svnurl + '/' + moduleclass + '/' + module
+        url = options['svnurl'] + '/' + moduleclass + '/' + options['extension']
     else:
-        url = svnurl + '/gui/wxpython/' + module
+        url = options['svnurl'] + '/gui/wxpython/' + options['extension']
         if not flags['s']:
             grass.fatal(_("Installation of wxGUI extension requires -%s flag.") % 's')
         
-    grass.message(_("Fetching '%s' from GRASS-Addons SVN (be patient)...") % module)
+    grass.message(_("Fetching '%s' from GRASS-Addons SVN (be patient)...") % options['extension'])
     global tmpdir
     os.chdir(tmpdir)
     if grass.verbosity() == 0:
@@ -318,16 +316,19 @@
     
     if grass.call(['svn', 'checkout',
                    url], stdout = outdev) != 0:
-        grass.fatal(_("GRASS Addons '%s' not found in repository") % module)
+        grass.fatal(_("GRASS Addons '%s' not found in repository") % options['extension'])
+
+    if flags['d']:
+        return
     
-    os.chdir(os.path.join(tmpdir, module))
+    os.chdir(os.path.join(tmpdir, options['extension']))
 
-    grass.message(_("Compiling '%s'...") % module)    
-    if module not in gui_list:
-        bin_dir  = os.path.join(tmpdir, module, 'bin')
-        docs_dir = os.path.join(tmpdir, module, 'docs')
+    grass.message(_("Compiling '%s'...") % options['extension'])    
+    if options['extension'] not in gui_list:
+        bin_dir  = os.path.join(tmpdir, options['extension'], 'bin')
+        docs_dir = os.path.join(tmpdir, options['extension'], 'docs')
         html_dir = os.path.join(docs_dir, 'html')
-        man_dir  = os.path.join(tmpdir, module, 'man')
+        man_dir  = os.path.join(tmpdir, options['extension'], 'man')
         man1_dir = os.path.join(man_dir, 'man1')
         for d in (bin_dir, docs_dir, html_dir, man_dir, man1_dir):
             os.mkdir(d)
@@ -346,35 +347,35 @@
     if ret != 0:
         grass.fatal(_('Compilation failed, sorry. Please check above error messages.'))
     
-    if no_install or module in gui_list:
+    if flags['i'] or options['extension'] in gui_list:
         return
     
-    grass.message(_("Installing '%s'...") % module)
+    grass.message(_("Installing '%s'...") % options['extension'])
     
     ret = grass.call(['make',
                       'MODULE_TOPDIR=%s' % gisbase,
-                      'ARCH_DISTDIR=%s' % os.path.join(tmpdir, module),
-                      'INST_DIR=%s' % prefix,
+                      'ARCH_DISTDIR=%s' % os.path.join(tmpdir, options['extension']),
+                      'INST_DIR=%s' % options['prefix'],
                       'install'],
                      stdout = outdev)
     
     if ret != 0:
         grass.warning(_('Installation failed, sorry. Please check above error messages.'))
     else:
-        grass.message(_("Installation of '%s' successfully finished.") % module)
+        grass.message(_("Installation of '%s' successfully finished.") % options['extension'])
 
-def remove_extension(prefix, module):
+def remove_extension():
     # is module available?
-    if not os.path.exists(os.path.join(prefix, 'bin', module)):
-        grass.fatal(_("Module '%s' not found") % module)
+    if not os.path.exists(os.path.join(options['prefix'], 'bin', options['extension'])):
+        grass.fatal(_("Module '%s' not found") % options['extension'])
     
-    for file in [os.path.join(prefix, 'bin', module),
-                 os.path.join(prefix, 'scripts', module),
-                 os.path.join(prefix, 'docs', 'html', module + '.html')]:
+    for file in [os.path.join(options['prefix'], 'bin', options['extension']),
+                 os.path.join(options['prefix'], 'scripts', options['extension']),
+                 os.path.join(options['prefix'], 'docs', 'html', options['extension'] + '.html')]:
         if os.path.isfile(file):
             os.remove(file)
                     
-    grass.message(_("'%s' successfully uninstalled.") % module)
+    grass.message(_("'%s' successfully uninstalled.") % options['extension'])
 
 def create_dir(path):
     if os.path.isdir(path):
@@ -398,7 +399,7 @@
     
     # list available modules
     if flags['l'] or flags['f'] or flags['g']:
-        list_available_modules(options['svnurl'], full = flags['f'], shell = flags['g'])
+        list_available_modules()
         return 0
     else:
         if not options['extension']:
@@ -424,9 +425,9 @@
             remove_tmpdir = False
     
     if options['operation'] == 'add':
-        install_extension(options['svnurl'], options['prefix'], options['extension'], flags['i'])
+        install_extension()
     else: # remove
-        remove_extension(options['prefix'], options['extension'])
+        remove_extension()
     
     return 0
 



More information about the grass-commit mailing list