Make pkg_tarup invoke pkg_create(1) and pkg_info(1) with their full

paths, so it works even if /usr/sbin is not in user's PATH.

Reported by:	Christopher Masto <chris@netmonger.net>
This commit is contained in:
Akinori MUSHA 2001-08-23 05:25:01 +00:00
parent 11d8fe9121
commit ef76cbbf4c
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=46677
4 changed files with 76 additions and 26 deletions

View file

@ -7,7 +7,7 @@
PORTNAME= pkg_tarup PORTNAME= pkg_tarup
PORTVERSION= 1.2 PORTVERSION= 1.2
PORTREVISION= 2 PORTREVISION= 3
CATEGORIES= misc CATEGORIES= misc
MASTER_SITES= http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/pkgsrc/pkgtools/pkg_tarup/files/ MASTER_SITES= http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/pkgsrc/pkgtools/pkg_tarup/files/
DISTNAME= ${PORTNAME}\?rev=${PORTVERSION}\&content-type=text%2fplain DISTNAME= ${PORTNAME}\?rev=${PORTVERSION}\&content-type=text%2fplain

View file

@ -1,15 +1,17 @@
--- pkg_tarup.orig Sun Jun 10 12:51:53 2001 --- pkg_tarup.orig Thu Aug 23 14:16:01 2001
+++ pkg_tarup Sun Jun 10 12:58:15 2001 +++ pkg_tarup Thu Aug 23 14:18:58 2001
@@ -7,21 +7,26 @@ @@ -7,21 +7,28 @@
# #
PKG_DBDIR=${PKG_DBDIR:-/var/db/pkg} PKG_DBDIR=${PKG_DBDIR:-/var/db/pkg}
-PKGREPOSITORY=${PKGREPOSITORY:-/tmp} -PKGREPOSITORY=${PKGREPOSITORY:-/tmp}
PKG_SUFX=${PKG_SUFX:-tgz} PKG_SUFX=${PKG_SUFX:-tgz}
+PKG_INFO_CMD=/usr/sbin/pkg_info
+PKG_CREATE_CMD=/usr/sbin/pkg_create
+
+# A package file can be very big beyond /tmp's capacity +# A package file can be very big beyond /tmp's capacity
+PKGREPOSITORY=${PKGREPOSITORY:-${TMPDIR:-/var/tmp}} +PKGREPOSITORY=${PKGREPOSITORY:-${TMPDIR:-/var/tmp}}
+
PKG="$1" PKG="$1"
-rPKG="`pkg_info -e \"$PKG\"`" -rPKG="`pkg_info -e \"$PKG\"`"
@ -23,7 +25,7 @@
-PKG=$rPKG -PKG=$rPKG
-echo "Taring up $PKG" -echo "Taring up $PKG"
+if ! pkg_info -e "$PKG" +if ! $PKG_INFO_CMD -e "$PKG"
+then +then
+ echo $PKG is not installed. + echo $PKG is not installed.
+ exit 1 + exit 1
@ -33,7 +35,7 @@
check_and_add() { check_and_add() {
opt="$1" opt="$1"
@@ -40,10 +45,10 @@ @@ -40,10 +47,10 @@
check_and_add -c ${PKG_DBDIR}/${PKG}/+COMMENT check_and_add -c ${PKG_DBDIR}/${PKG}/+COMMENT
check_and_add -d ${PKG_DBDIR}/${PKG}/+DESC check_and_add -d ${PKG_DBDIR}/${PKG}/+DESC
@ -47,7 +49,7 @@
check_and_add -i ${PKG_DBDIR}/${PKG}/+INSTALL check_and_add -i ${PKG_DBDIR}/${PKG}/+INSTALL
check_and_add -k ${PKG_DBDIR}/${PKG}/+DEINSTALL check_and_add -k ${PKG_DBDIR}/${PKG}/+DEINSTALL
check_and_add -r ${PKG_DBDIR}/${PKG}/+REQUIRE check_and_add -r ${PKG_DBDIR}/${PKG}/+REQUIRE
@@ -54,7 +59,8 @@ @@ -54,7 +61,8 @@
sed -n \ sed -n \
-e '/^@comment MD5:/d' \ -e '/^@comment MD5:/d' \
-e '/^@cwd \.$/,$d' \ -e '/^@cwd \.$/,$d' \
@ -57,14 +59,37 @@
<${PKG_DBDIR}/${PKG}/+CONTENTS >$PLIST <${PKG_DBDIR}/${PKG}/+CONTENTS >$PLIST
# Duplicate first @cwd (work around pkg_create "feature" ...) # Duplicate first @cwd (work around pkg_create "feature" ...)
@@ -80,10 +86,8 @@ @@ -64,9 +72,9 @@
sed \
-e "/`cat ${PLIST}.1 | sed 's,/,\\\\/,g'`/r${PLIST}.1" \
<${PLIST} >${PLIST}.2
- mv ${PLIST}.2 ${PLIST}
+ /bin/mv ${PLIST}.2 ${PLIST}
fi
-rm ${PLIST}.1
+/bin/rm ${PLIST}.1
# echo -----
# cat $PLIST
@@ -76,17 +84,15 @@
# Just for kicks ...
# pkg_admin check "${PKG}"
-pkg_create \
+$PKG_CREATE_CMD \
${PKG_ARGS} \ ${PKG_ARGS} \
-v \ -v \
-f ${PLIST} \ -f ${PLIST} \
- -l \ - -l \
-p "`pkg_info -qp ${PKG} | head -1 | awk '{ print $2 }'`" \ - -p "`pkg_info -qp ${PKG} | head -1 | awk '{ print $2 }'`" \
-P "`pkg_info -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \ - -P "`pkg_info -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \
- -C "`pkg_info -qf ${PKG} | grep ^@pkgcfl | awk '{ print $2 }'`" \ - -C "`pkg_info -qf ${PKG} | grep ^@pkgcfl | awk '{ print $2 }'`" \
+ -p "`$PKG_INFO_CMD -qp ${PKG} | head -1 | awk '{ print $2 }'`" \
+ -P "`$PKG_INFO_CMD -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \
${PKGREPOSITORY}/${PKG}.${PKG_SUFX} ${PKGREPOSITORY}/${PKG}.${PKG_SUFX}
rm -f ${PLIST} -rm -f ${PLIST}
+/bin/rm -f ${PLIST}
exit 0

View file

@ -7,7 +7,7 @@
PORTNAME= pkg_tarup PORTNAME= pkg_tarup
PORTVERSION= 1.2 PORTVERSION= 1.2
PORTREVISION= 2 PORTREVISION= 3
CATEGORIES= misc CATEGORIES= misc
MASTER_SITES= http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/pkgsrc/pkgtools/pkg_tarup/files/ MASTER_SITES= http://cvsweb.netbsd.org/bsdweb.cgi/~checkout~/pkgsrc/pkgtools/pkg_tarup/files/
DISTNAME= ${PORTNAME}\?rev=${PORTVERSION}\&content-type=text%2fplain DISTNAME= ${PORTNAME}\?rev=${PORTVERSION}\&content-type=text%2fplain

View file

@ -1,15 +1,17 @@
--- pkg_tarup.orig Sun Jun 10 12:51:53 2001 --- pkg_tarup.orig Thu Aug 23 14:16:01 2001
+++ pkg_tarup Sun Jun 10 12:58:15 2001 +++ pkg_tarup Thu Aug 23 14:18:58 2001
@@ -7,21 +7,26 @@ @@ -7,21 +7,28 @@
# #
PKG_DBDIR=${PKG_DBDIR:-/var/db/pkg} PKG_DBDIR=${PKG_DBDIR:-/var/db/pkg}
-PKGREPOSITORY=${PKGREPOSITORY:-/tmp} -PKGREPOSITORY=${PKGREPOSITORY:-/tmp}
PKG_SUFX=${PKG_SUFX:-tgz} PKG_SUFX=${PKG_SUFX:-tgz}
+PKG_INFO_CMD=/usr/sbin/pkg_info
+PKG_CREATE_CMD=/usr/sbin/pkg_create
+
+# A package file can be very big beyond /tmp's capacity +# A package file can be very big beyond /tmp's capacity
+PKGREPOSITORY=${PKGREPOSITORY:-${TMPDIR:-/var/tmp}} +PKGREPOSITORY=${PKGREPOSITORY:-${TMPDIR:-/var/tmp}}
+
PKG="$1" PKG="$1"
-rPKG="`pkg_info -e \"$PKG\"`" -rPKG="`pkg_info -e \"$PKG\"`"
@ -23,7 +25,7 @@
-PKG=$rPKG -PKG=$rPKG
-echo "Taring up $PKG" -echo "Taring up $PKG"
+if ! pkg_info -e "$PKG" +if ! $PKG_INFO_CMD -e "$PKG"
+then +then
+ echo $PKG is not installed. + echo $PKG is not installed.
+ exit 1 + exit 1
@ -33,7 +35,7 @@
check_and_add() { check_and_add() {
opt="$1" opt="$1"
@@ -40,10 +45,10 @@ @@ -40,10 +47,10 @@
check_and_add -c ${PKG_DBDIR}/${PKG}/+COMMENT check_and_add -c ${PKG_DBDIR}/${PKG}/+COMMENT
check_and_add -d ${PKG_DBDIR}/${PKG}/+DESC check_and_add -d ${PKG_DBDIR}/${PKG}/+DESC
@ -47,7 +49,7 @@
check_and_add -i ${PKG_DBDIR}/${PKG}/+INSTALL check_and_add -i ${PKG_DBDIR}/${PKG}/+INSTALL
check_and_add -k ${PKG_DBDIR}/${PKG}/+DEINSTALL check_and_add -k ${PKG_DBDIR}/${PKG}/+DEINSTALL
check_and_add -r ${PKG_DBDIR}/${PKG}/+REQUIRE check_and_add -r ${PKG_DBDIR}/${PKG}/+REQUIRE
@@ -54,7 +59,8 @@ @@ -54,7 +61,8 @@
sed -n \ sed -n \
-e '/^@comment MD5:/d' \ -e '/^@comment MD5:/d' \
-e '/^@cwd \.$/,$d' \ -e '/^@cwd \.$/,$d' \
@ -57,14 +59,37 @@
<${PKG_DBDIR}/${PKG}/+CONTENTS >$PLIST <${PKG_DBDIR}/${PKG}/+CONTENTS >$PLIST
# Duplicate first @cwd (work around pkg_create "feature" ...) # Duplicate first @cwd (work around pkg_create "feature" ...)
@@ -80,10 +86,8 @@ @@ -64,9 +72,9 @@
sed \
-e "/`cat ${PLIST}.1 | sed 's,/,\\\\/,g'`/r${PLIST}.1" \
<${PLIST} >${PLIST}.2
- mv ${PLIST}.2 ${PLIST}
+ /bin/mv ${PLIST}.2 ${PLIST}
fi
-rm ${PLIST}.1
+/bin/rm ${PLIST}.1
# echo -----
# cat $PLIST
@@ -76,17 +84,15 @@
# Just for kicks ...
# pkg_admin check "${PKG}"
-pkg_create \
+$PKG_CREATE_CMD \
${PKG_ARGS} \ ${PKG_ARGS} \
-v \ -v \
-f ${PLIST} \ -f ${PLIST} \
- -l \ - -l \
-p "`pkg_info -qp ${PKG} | head -1 | awk '{ print $2 }'`" \ - -p "`pkg_info -qp ${PKG} | head -1 | awk '{ print $2 }'`" \
-P "`pkg_info -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \ - -P "`pkg_info -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \
- -C "`pkg_info -qf ${PKG} | grep ^@pkgcfl | awk '{ print $2 }'`" \ - -C "`pkg_info -qf ${PKG} | grep ^@pkgcfl | awk '{ print $2 }'`" \
+ -p "`$PKG_INFO_CMD -qp ${PKG} | head -1 | awk '{ print $2 }'`" \
+ -P "`$PKG_INFO_CMD -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \
${PKGREPOSITORY}/${PKG}.${PKG_SUFX} ${PKGREPOSITORY}/${PKG}.${PKG_SUFX}
rm -f ${PLIST} -rm -f ${PLIST}
+/bin/rm -f ${PLIST}
exit 0