[GRASS-SVN] r57795 - grass/branches/releasebranch_6_4/scripts/g.extension

svn_grass at osgeo.org svn_grass at osgeo.org
Sun Sep 22 01:14:59 PDT 2013


Author: hamish
Date: 2013-09-22 01:14:59 -0700 (Sun, 22 Sep 2013)
New Revision: 57795

Modified:
   grass/branches/releasebranch_6_4/scripts/g.extension/g.extension
Log:
more complete backport of sudo & admin permission improvements (merge r56994 from devbr6)

Modified: grass/branches/releasebranch_6_4/scripts/g.extension/g.extension
===================================================================
--- grass/branches/releasebranch_6_4/scripts/g.extension/g.extension	2013-09-22 08:00:55 UTC (rev 57794)
+++ grass/branches/releasebranch_6_4/scripts/g.extension/g.extension	2013-09-22 08:14:59 UTC (rev 57795)
@@ -207,7 +207,16 @@
 fi
 
 
-if [ "$PREFIX" = '$GRASS_ADDON_PATH' ] ; then 
+if [ "$PREFIX" = '$GISBASE' ] || [ $GIS_FLAG_S -eq 1 ] || [ $GIS_FLAG_U -eq 1 ] ; then
+   SYSADMIN=1
+   PREFIX="$GISBASE"
+
+   # just to make later tests happy
+   if [ $GIS_FLAG_S -eq 0 ] && [ $GIS_FLAG_U -eq 1 ] ; then
+      GIS_FLAG_S=1
+   fi
+
+elif [ "$PREFIX" = '$GRASS_ADDON_PATH' ] ; then 
     if [ -z "$GRASS_ADDON_PATH" ] ; then 
 	g.message -w message="GRASS_ADDON_PATH is not defined, installing to ~/.grass6/addons/"
 	ADDON_PATH_EMPTY=true
@@ -222,17 +231,7 @@
     PREFIX="$GRASS_ADDON_PATH1"
 fi
 
-if [ "$PREFIX" = '$GISBASE' ] || [ $GIS_FLAG_S -eq 1 ] || [ $GIS_FLAG_U -eq 1 ] ; then
-   SYSADMIN=1
-   PREFIX="$GISBASE"
 
-   # just to make later tests happy
-   if [ $GIS_FLAG_S -eq 0 ] && [ $GIS_FLAG_U -eq 1 ] ; then
-      GIS_FLAG_S=1
-   fi
-fi
-
-
 if [ -d "$PREFIX" ] ; then
     MYINST_DIR="$PREFIX"
 else
@@ -245,8 +244,8 @@
     MYINST_DIR="$PREFIX"
 fi
 
-if [ ! -w "$PREFIX" -a $SYSADMIN -ne 1 ] ; then
-    g.message -e "'$PREFIX' is not writable (are you logged in as the system administator?)"
+if [ ! -w "$PREFIX" -a "$SYSADMIN" -ne 1 ] ; then
+    g.message -e "'$PREFIX' is not writable (do you have suitable file-system permissions?)"
     exit 1
 fi
 
@@ -267,8 +266,8 @@
 if [ "$GIS_OPT_OPERATION" = "remove" ] ; then
    g.message message="Removing <$MODULE>..."
 
-   if test -f "${MYINST_DIR}/bin/${MODULE}" ; then
-       rm -f "${MYINST_DIR}/bin/${MODULE}"
+   if test -f "$MYINST_DIR/bin/$MODULE" ; then
+       rm -f "$MYINST_DIR/bin/$MODULE"
    fi
    if test -f "$MYINST_DIR/scripts/$MODULE" ; then
        rm -f "$MYINST_DIR/scripts/$MODULE"
@@ -276,12 +275,12 @@
    if test -e "$MYINST_DIR/$MODULE" ; then
        rm -f "$MYINST_DIR/$MODULE"
    fi
-   if test -f "${MYINST_DIR}/docs/html/${MODULE}.html" ; then
-       rm -f "${MYINST_DIR}/docs/html/${MODULE}.html"
+   if test -f "$MYINST_DIR/docs/html/$MODULE.html" ; then
+       rm -f "$MYINST_DIR/docs/html/$MODULE.html"
        #also html/$MODULE*.jpg, html/$MODULE*.png
    fi
-   if test -f "${MYINST_DIR}/man/man1/${MODULE}.1" ; then
-       rm -f "${MYINST_DIR}/man/man1/${MODULE}.1"
+   if test -f "$MYINST_DIR/man/man1/$MODULE.1" ; then
+       rm -f "$MYINST_DIR/man/man1/$MODULE.1"
    fi
    if test -f "$MYINST_DIR/docs/man/man1/$MODULE.1" ; then
        rm -f "$MYINST_DIR/docs/man/man1/$MODULE.1"
@@ -295,7 +294,7 @@
 
 cd "$TMPDIR"
 g.message message="Fetching <$MODULE> from GRASS-Addons SVN (be patient)..."
-svn co "${SVNURL_ADDONS}/${MODULECLASS}/${MODULE}"
+svn co "$SVNURL_ADDONS/$MODULECLASS/$MODULE"
 
 if [ $? -ne 0 ] ; then
    g.message -e message="GRASS Add-on $MODULE not found in repository or no network connection or another problem"
@@ -334,8 +333,8 @@
 export INST_NOW
 
 make MODULE_TOPDIR="$GISBASE" \
-   ARCH_INC="'-I$GISBASE/include' '-I${MYINST_DIR}/include' '-I$TMPDIR/$DIST_DIR/include'" \
-   ARCH_LIBPATH="'-L$GISBASE/lib' '-L${MYINST_DIR}/lib' '-L$TMPDIR/$DIST_DIR/lib'" \
+   ARCH_INC="'-I$GISBASE/include' '-I$MYINST_DIR/include' '-I$TMPDIR/$DIST_DIR/include'" \
+   ARCH_LIBPATH="'-L$GISBASE/lib' '-L$MYINST_DIR/lib' '-L$TMPDIR/$DIST_DIR/lib'" \
    ARCH_LIBDIR="$GISBASE/lib" \
    ARCH_DISTDIR="$TMPDIR/$DIST_DIR" \
    ARCH_BINDIR="$TMPDIR/$DIST_DIR/bin"
@@ -369,12 +368,14 @@
 
    if [ $SYSADMIN -eq 1 ] ; then
       if test -f "$MYINST_DIR/$PROGTYPE/$MODULE" ; then
-         if [ $GIS_FLAG_U -eq 1 ] ; then
+         if [ "$GIS_FLAG_U" -eq 1 ] ; then
             g.message "You may need to enter your password to remove an earlier copy of $MODULE:"
             sudo rm -f "$MYINST_DIR/$PROGTYPE/$MODULE"
          else
-            g.message "You need to enter the root password to remove an earlier copy of $MODULE:"
-            su -c "rm -f \"$MYINST_DIR/$PROGTYPE/$MODULE\""
+            rm -f "$MYINST_DIR/$PROGTYPE/$MODULE"
+	    if [ $? -ne 0 ] ; then
+	       g.message -w "Removal failed. Do you have suitable file-system permissions?"
+	    fi
          fi
       fi
       if [ $GIS_FLAG_U -eq 1 ] ; then
@@ -384,9 +385,10 @@
 	     ARCH_DISTDIR="$TMPDIR/$DIST_DIR" \
 	     INST_DIR="$MYINST_DIR" install
       else
-         g.message "You need to enter the root password to install $MODULE:"
-
-         su -c "make MODULE_TOPDIR=\"$GISBASE\" ARCH_DISTDIR=\"$TMPDIR/$DIST_DIR\" INST_DIR=\"$MYINST_DIR\" install"
+	 make MODULE_TOPDIR="$GISBASE" \
+	   ARCH_DISTDIR="$TMPDIR/$DIST_DIR" \
+	   INST_DIR="$MYINST_DIR" \
+	   install
       fi
    else
       if test -f "$MYINST_DIR/$PROGTYPE/$MODULE" ; then
@@ -394,6 +396,7 @@
          rm -f "$MYINST_DIR/$PROGTYPE/$MODULE"
       fi
 
+       # ? ETC="$MYINST_DIR/etc"
       make MODULE_TOPDIR="$GISBASE" \
            ARCH_DISTDIR="$TMPDIR/$DIST_DIR" \
 	   INST_DIR="$MYINST_DIR" install
@@ -405,6 +408,7 @@
       exit 1
    fi
 
+   # clean up python installs, since PythonScript.make doesn't exist yet
    if [ -e "$MYINST_DIR/$PROGTYPE/$MODULE.py" ] ; then
       # drop the .py from python scripts
       mv "$MYINST_DIR/$PROGTYPE/$MODULE.py" "$MYINST_DIR/$PROGTYPE/$MODULE"



More information about the grass-commit mailing list