summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeonardo Boshell <leonardop@gentoo.org>2006-01-14 14:02:33 +0000
committerLeonardo Boshell <leonardop@gentoo.org>2006-01-14 14:02:33 +0000
commitb375f4d7b5ef8f7b7383d672e21c32680f1feb18 (patch)
tree6542ca407e5186883202885d30ced54d4ce9b556 /app-text/sgml-common/files
parentTell configure that we do not want josua with permission from dragonheart (diff)
downloadgentoo-2-b375f4d7b5ef8f7b7383d672e21c32680f1feb18.tar.gz
gentoo-2-b375f4d7b5ef8f7b7383d672e21c32680f1feb18.tar.bz2
gentoo-2-b375f4d7b5ef8f7b7383d672e21c32680f1feb18.zip
Support for $ROOT values other than / (bug #114946)
(Portage version: 2.1_pre3-r1)
Diffstat (limited to 'app-text/sgml-common/files')
-rw-r--r--app-text/sgml-common/files/sgml-common-0.6.3-r4-install-catalog.in51
1 files changed, 34 insertions, 17 deletions
diff --git a/app-text/sgml-common/files/sgml-common-0.6.3-r4-install-catalog.in b/app-text/sgml-common/files/sgml-common-0.6.3-r4-install-catalog.in
index 71507a327604..9014d0ebb232 100644
--- a/app-text/sgml-common/files/sgml-common-0.6.3-r4-install-catalog.in
+++ b/app-text/sgml-common/files/sgml-common-0.6.3-r4-install-catalog.in
@@ -3,6 +3,9 @@
# Send any comments to Eric Bischoff <eric@caldera.de>
# This program is under GPL license. See LICENSE file for details.
+# Modified by Gentoo developers to better integrate it to portage.
+# <text-markup@gentoo.org>
+
# Set help message
SGML_HELP_MESSAGE="Usage: `basename $0` [<option>] <action>\n\
where <option> is:\n\
@@ -26,6 +29,11 @@ SGML_ACTION=""
SGML_CENTRALIZED=""
SGML_ORDINARY=""
+# Default ROOT value (usually defined by portage)
+[ -z "$ROOT" ] && ROOT="/"
+[[ $ROOT == */ ]] || ROOT="${ROOT}/"
+
+
# Process options
case $1 in
-d|--delegate) SGML_POINTER="DELEGATE"
@@ -62,6 +70,14 @@ case $1 in
;;
esac
+
+# The arguments to this program should always be relative to $ROOT. Here we
+# declare some extra variables to distingish between the absolute and
+# relative paths.
+SGML_ROOT_CENTRALIZED="${ROOT%/}${SGML_CENTRALIZED}"
+SGML_ROOT_ORDINARY="${ROOT%/}${SGML_ORDINARY}"
+
+
# Check that the super catalog can be created and changed and deleted
if [ ! -w ${ROOT}etc/sgml ]
then
@@ -86,39 +102,39 @@ case $SGML_ACTION in
esac
# Check that the centralized catalog can be created, changed and deleted
-if [ -z "$SGML_CENTRALIZED" ]
+if [ -z "$SGML_ROOT_CENTRALIZED" ]
then
echo -e $SGML_HELP_MESSAGE >&2
exit 1
fi
case $SGML_ACTION in
addition)
- if [ -e $SGML_CENTRALIZED -a ! -w $SGML_CENTRALIZED ]
+ if [ -e "$SGML_ROOT_CENTRALIZED" -a ! -w "$SGML_ROOT_CENTRALIZED" ]
then
- echo "`basename $0`: can not modify \"$SGML_CENTRALIZED\"." >&2
+ echo "`basename $0`: can not modify \"$SGML_ROOT_CENTRALIZED\"." >&2
exit 2
fi
;;
removal)
- if [ ! -w $SGML_CENTRALIZED ]
+ if [ ! -w "$SGML_ROOT_CENTRALIZED" ]
then
- echo "`basename $0`: can not modify \"$SGML_CENTRALIZED\"." >&2
+ echo "`basename $0`: can not modify \"$SGML_ROOT_CENTRALIZED\"." >&2
exit 2
fi
;;
esac
# Check that we have at least one ordinary package to process
-if [ -z "$SGML_ORDINARY" ]
+if [ -z "$SGML_ROOT_ORDINARY" ]
then
echo -e $SGML_HELP_MESSAGE >&2
exit 1
fi
case $SGML_ACTION in
addition)
- if [ ! -s $SGML_ORDINARY ]
+ if [ ! -s $SGML_ROOT_ORDINARY ]
then
- echo "`basename $0`: \"$SGML_ORDINARY\" does not exist or is empty." >&2
+ echo "`basename $0`: \"$SGML_ROOT_ORDINARY\" does not exist or is empty." >&2
exit 2
fi
;;
@@ -128,31 +144,32 @@ esac
case $SGML_ACTION in
addition)
echo "`basename $0`: addition of $SGML_ORDINARY in $SGML_CENTRALIZED"
- if grep -q $SGML_ORDINARY $SGML_CENTRALIZED 2>/dev/null
+ if grep -q $SGML_ORDINARY $SGML_ROOT_CENTRALIZED 2>/dev/null
then
echo "Warning: $SGML_ORDINARY is already installed in the centralized catalog $SGML_CENTRALIZED" >&2
else
- echo "$SGML_POINTER \"$SGML_ORDINARY\"" >> $SGML_CENTRALIZED
+ echo "$SGML_POINTER \"$SGML_ORDINARY\"" >> $SGML_ROOT_CENTRALIZED
fi
grep -q $SGML_CENTRALIZED ${ROOT}etc/sgml/catalog 2>/dev/null
if [ $? -ne 0 ]
then
- echo "`basename $0`: addition of $SGML_CENTRALIZED in ${ROOT}etc/sgml/catalog"
- echo "$SGML_POINTER \"$SGML_CENTRALIZED\"" >> ${ROOT}etc/sgml/catalog
+ echo "`basename $0`: addition of $SGML_CENTRALIZED in ${ROOT}etc/sgml/catalog"
+ echo "$SGML_POINTER \"$SGML_CENTRALIZED\"" >> ${ROOT}etc/sgml/catalog
fi
;;
removal)
echo "`basename $0`: removal of $SGML_ORDINARY from $SGML_CENTRALIZED"
- if grep -q $SGML_ORDINARY $SGML_CENTRALIZED 2>/dev/null
+ if grep -q $SGML_ORDINARY $SGML_ROOT_CENTRALIZED 2>/dev/null
then
- sed -e "\:$SGML_POINTER \"$SGML_ORDINARY\":d" < $SGML_CENTRALIZED > ${SGML_CENTRALIZED}.new
- mv ${SGML_CENTRALIZED}.new $SGML_CENTRALIZED
+ sed -e "\:$SGML_POINTER \"$SGML_ORDINARY\":d" < \
+ $SGML_ROOT_CENTRALIZED > ${SGML_ROOT_CENTRALIZED}.new
+ mv ${SGML_ROOT_CENTRALIZED}.new $SGML_ROOT_CENTRALIZED
else
echo "Warning: $SGML_ORDINARY was not found in the centralized catalog $SGML_CENTRALIZED" >&2
fi
- if [ ! -s $SGML_CENTRALIZED ]
+ if [ ! -s "$SGML_ROOT_CENTRALIZED" ]
then
- rm $SGML_CENTRALIZED
+ rm $SGML_ROOT_CENTRALIZED
echo "`basename $0`: removal of $SGML_CENTRALIZED from ${ROOT}etc/sgml/catalog"
sed -e "\:$SGML_POINTER \"$SGML_CENTRALIZED\":d" < ${ROOT}etc/sgml/catalog > ${ROOT}etc/sgml/catalog.new
mv ${ROOT}etc/sgml/catalog.new ${ROOT}etc/sgml/catalog