[GRASS-SVN] r38825 - grass-addons/general/g.extension
svn_grass at osgeo.org
svn_grass at osgeo.org
Fri Aug 21 13:15:28 EDT 2009
Author: neteler
Date: 2009-08-21 13:15:28 -0400 (Fri, 21 Aug 2009)
New Revision: 38825
Modified:
grass-addons/general/g.extension/g.extension
Log:
added curl support; exit with error if installdir not writable; check if wget/curl and make present (upon suggestions from Hamish)
Modified: grass-addons/general/g.extension/g.extension
===================================================================
--- grass-addons/general/g.extension/g.extension 2009-08-21 17:14:27 UTC (rev 38824)
+++ grass-addons/general/g.extension/g.extension 2009-08-21 17:15:28 UTC (rev 38825)
@@ -94,6 +94,26 @@
exit 1
fi
+# check if we have the make program
+if [ ! -x "`which make`" ] ; then
+ echo "ERROR: 'make' program required. Please install first." 1>&2
+ exit 1
+fi
+
+# check if we have wget or curl
+if [ ! -x "`which wget`" ] ; then
+ if [ ! -x "`which curl`" ] ; then
+ g.message -e "Either 'wget' or 'curl' is required, please install one first"
+ exit 1
+ else
+ g.message -v "Using CURL for downloading data."
+ USE_CURL=1
+ fi
+else
+ g.message -v "Using WGET for downloading data."
+ USE_WGET=1
+fi
+
expand_module_class_name()
{
# $1: module class
@@ -109,14 +129,14 @@
echo "misc"
elif [ "$1" = "ps" ] ; then
echo "postscript"
- elif [ "$1" = "p" ] ; then
- echo "paint"
+# elif [ "$1" = "p" ] ; then
+# echo "paint"
elif [ "$1" = "r" ] ; then
echo "raster"
elif [ "$1" = "r3" ] ; then
echo "raster3D"
- elif [ "$1" = "s" ] ; then
- echo "sites"
+# elif [ "$1" = "s" ] ; then
+# echo "sites"
elif [ "$1" = "v" ] ; then
echo "vector"
else
@@ -134,9 +154,13 @@
g.message message="Fetching list of modules from GRASS-Addons SVN (be patient)..."
for d in d db g i m ps p r r3 v ; do
MODCLASS=`expand_module_class_name $d`
- cd $TMPDIR
+ cd "$TMPDIR"
rm -f index.html
- wget $SVNURL_ADDONS/$MODCLASS > /dev/null 2> /dev/null
+ if [ "$USE_WGET" ] ; then
+ wget -nv $SVNURL_ADDONS/$MODCLASS
+ else
+ curl -silent --location $SVNURL_ADDONS/$MODCLASS -o index.html
+ fi
grep '<li>' index.html 2> /dev/null | grep -v '\.\.' | cut -d'"' -f2 | sed 's+/$++g' >> list.txt
rm -f index.html
done
@@ -146,9 +170,9 @@
##
cleanup(){
- cd ${TMPDIR}
- rm -rf ${TMPDIR}/${MODULE}
- rmdir "$TMPDIR"
+ if [ ! -z "${TMPDIR}" ] ; then
+ rm -rf "${TMPDIR}"
+ fi
}
if [ $GIS_FLAG_l -eq 1 ] ; then
@@ -164,51 +188,48 @@
cd ${TMPDIR}
-g.message message="Fetching ${MODULE} from GRASS-Addons SVN (be patient)..."
+g.message message="Fetching <$MODULE> from GRASS-Addons SVN (be patient)..."
svn co ${SVNURL_ADDONS}/${MODULECLASS}/${MODULE}
if [ $? -ne 0 ] ; then
- g.message -e message="GRASS Addon ${MODULE} not found in repository"
+ g.message -e message="GRASS Addon ${MODULE} not found in repository or no network connection or another problem"
exit 1
+fi
+
+cd ${TMPDIR}/${MODULE}
+g.message message="Compiling ${MODULE}..."
+make MODULE_TOPDIR=${GISBASE}
+if [ $? -ne 0 ] ; then
+ g.message -e message="Compilation failed, sorry. Please check above error messages."
+ cleanup
+ exit 1
else
- cd ${TMPDIR}/${MODULE}
- g.message message="Compiling ${MODULE}..."
- make MODULE_TOPDIR=${GISBASE}
+ g.message message="Installing ${MODULE}..."
+ # can we write? Install dir present?
+ if test ! -d ${MYINST_DIR} ; then
+ mkdir -p ${MYINST_DIR}/bin
+ mkdir -p ${MYINST_DIR}/docs/html
+ mkdir -p ${MYINST_DIR}/man/man1
+ fi
+ touch "${MYINST_DIR}/`basename $0`.$$"
if [ $? -ne 0 ] ; then
- g.message -e message="Compilation failed, sorry. Please check above error messages."
- cleanup
+ g.message -e message="Cannot write to <${MYINST_DIR}>, installation failed"
exit 1
else
- g.message message="Installing ${MODULE}..."
- # can we write? Install dir present?
- if test ! -d ${MYINST_DIR} ; then
- mkdir -p ${MYINST_DIR}/bin
- mkdir -p ${MYINST_DIR}/docs/html
- mkdir -p ${MYINST_DIR}/man/man1
+ rm -f ${MYINST_DIR}/`basename $0`.$$
+ if test -f ${MYINST_DIR}/bin/${MODULE} ; then
+ rm -f ${MYINST_DIR}/bin/${MODULE}
fi
- touch ${MYINST_DIR}/`basename $0`.$$
+ make MODULE_TOPDIR=${GISBASE} INST_DIR=${MYINST_DIR}
if [ $? -ne 0 ] ; then
- rm -f ${MYINST_DIR}/`basename $0`.$$
- if test -f ${MYINST_DIR}/bin/${MODULE} ; then
- rm -f ${MYINST_DIR}/bin/${MODULE}
- fi
- make MODULE_TOPDIR=${GISBASE} INST_DIR=${MYINST_DIR}
- else
- rm -f ${MYINST_DIR}/`basename $0`.$$
- if test -f ${MYINST_DIR}/bin/${MODULE} ; then
- rm -f ${MYINST_DIR}/bin/${MODULE}
- fi
- make MODULE_TOPDIR=${GISBASE} INST_DIR=${MYINST_DIR}
- fi
- if [ $? -ne 0 ] ; then
g.message -e message="Installation failed, sorry. Please check above error messages."
cleanup
exit 1
fi
fi
-
- cleanup
fi
+cleanup
+
g.message message="Installation of <${MODULE}> in <${MYINST_DIR}> successfully finished."
exit 0
More information about the grass-commit
mailing list