summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--pkgtools/pkgchk/Makefile9
-rw-r--r--pkgtools/pkgchk/files/pkgchk.811
-rwxr-xr-xpkgtools/pkgchk/files/pkgchk.sh37
3 files changed, 44 insertions, 13 deletions
diff --git a/pkgtools/pkgchk/Makefile b/pkgtools/pkgchk/Makefile
index acddc457b86..95e6317c091 100644
--- a/pkgtools/pkgchk/Makefile
+++ b/pkgtools/pkgchk/Makefile
@@ -1,6 +1,6 @@
-# $NetBSD: Makefile,v 1.29 2002/04/01 20:20:05 abs Exp $
+# $NetBSD: Makefile,v 1.30 2002/06/09 14:43:39 tron Exp $
-DISTNAME= pkgchk-1.28
+DISTNAME= pkgchk-1.29
CATEGORIES= pkgtools
MASTER_SITES= # empty
DISTFILES= # empty
@@ -14,8 +14,9 @@ NO_CHECKSUM= YES
WRKSRC= ${WRKDIR}
do-build:
- ${SED} -e 's#@MAKE@#${MAKE}#g' ${FILESDIR}/pkgchk.sh \
- >${WRKSRC}/pkgchk.sh
+ ${SED} -e 's#@MAKE@#${MAKE}#g' \
+ -e 's#@MAKECONF@#${MAKECONF}#g' \
+ ${FILESDIR}/pkgchk.sh >${WRKSRC}/pkgchk.sh
do-install:
${INSTALL_SCRIPT} ${WRKSRC}/pkgchk.sh ${PREFIX}/sbin/pkg_chk
diff --git a/pkgtools/pkgchk/files/pkgchk.8 b/pkgtools/pkgchk/files/pkgchk.8
index 3ad826e7f99..e4978fe0e59 100644
--- a/pkgtools/pkgchk/files/pkgchk.8
+++ b/pkgtools/pkgchk/files/pkgchk.8
@@ -1,4 +1,4 @@
-.\" $NetBSD: pkgchk.8,v 1.12 2002/03/17 22:47:40 abs Exp $
+.\" $NetBSD: pkgchk.8,v 1.13 2002/06/09 14:43:39 tron Exp $
.\"
.\" Copyright (c) 2001 by David Brownlee (abs@netbsd.org)
.\" Absolutely no warranty.
@@ -150,9 +150,18 @@ uses the following environment variables.
.Bl -tag -width xxxx
.It Ev PKGSRCDIR
Base of pkgsrc tree. If not set in environment then read from
+.Pa ${MAKECONF}
+or
.Pa /etc/mk.conf .
Defaults to
.Pa /usr/pkgsrc
+.It Ev PKG_DBDIR
+pkgsrc database directory. If not set in environment then read from
+.Pa ${MAKECONF}
+or
+.Pa /etc/mk.conf .
+Defaults to
+.Pa /var/db/pkg
.It Ev PACKAGES
Location of binary packages. If not set in environment then read from
.Pa /etc/mk.conf .
diff --git a/pkgtools/pkgchk/files/pkgchk.sh b/pkgtools/pkgchk/files/pkgchk.sh
index fcd5905c955..ac127b1b615 100755
--- a/pkgtools/pkgchk/files/pkgchk.sh
+++ b/pkgtools/pkgchk/files/pkgchk.sh
@@ -1,6 +1,6 @@
#!/bin/sh -e
#
-# $Id: pkgchk.sh,v 1.31 2002/04/01 20:20:05 abs Exp $
+# $Id: pkgchk.sh,v 1.32 2002/06/09 14:43:39 tron Exp $
#
# TODO: Handle updates with dependencies via binary packages
@@ -28,7 +28,7 @@ check_packages_installed()
echo "Unable to extract PKGNAME for $pkgdir"
exit 1
fi
- if [ ! -d /var/db/pkg/$PKGNAME ];then
+ if [ ! -d $PKG_DBDIR/$PKGNAME ];then
echo_n "$PKGNAME: "
pkg=`echo $PKGNAME | sed 's/-[0-9].*//'`
pkginstalled=`sh -c "${PKG_INFO} -e $pkg" || true`
@@ -48,7 +48,7 @@ check_packages_installed()
else
if [ -n "$opt_B" ];then
current_build_ver=`get_build_ver`
- installed_build_ver=`sed "s|^[^:]*/[^:]*:||" /var/db/pkg/$PKGNAME/+BUILD_VERSION`
+ installed_build_ver=`sed "s|^[^:]*/[^:]*:||" $PKG_DBDIR/$PKGNAME/+BUILD_VERSION`
if [ x"$current_build_ver" != x"$installed_build_ver" ];then
echo "$PKGNAME: build version information mismatch"
MISMATCH_TODO="$MISMATCH_TODO $PKGNAME"
@@ -84,7 +84,9 @@ extract_variables()
#
if [ -z "$PKGSRCDIR" ];then
- if [ -f /etc/mk.conf ] ;then
+ if [ -f $MAKECONF ];then
+ eval `printf 'BSD_PKG_MK=1\nx:\n\t@echo PKGSRCDIR=${PKGSRCDIR}\n' | ${MAKE} -f - -f $MAKECONF x`
+ elif [ -f /etc/mk.conf ];then
eval `printf 'BSD_PKG_MK=1\nx:\n\t@echo PKGSRCDIR=${PKGSRCDIR}\n' | ${MAKE} -f - -f /etc/mk.conf x`
fi
if [ -z "$PKGSRCDIR" ];then
@@ -96,6 +98,24 @@ extract_variables()
exit 1;
fi
+ # Establish PKG_DBDIR
+ #
+
+ if [ -z "$PKG_DBDIR" ];then
+ if [ -f $MAKECONF ];then
+ eval `printf 'BSD_PKG_MK=1\nx:\n\t@echo PKG_DBDIR=${PKG_DBDIR}\n' | ${MAKE} -f - -f $MAKECONF x`
+ elif [ -f /etc/mk.conf ];then
+ eval `printf 'BSD_PKG_MK=1\nx:\n\t@echo PKG_DBDIR=${PKG_DBDIR}\n' | ${MAKE} -f - -f /etc/mk.conf x`
+ fi
+ if [ -z "$PKG_DBDIR" ];then
+ PKG_DBDIR=/var/db/pkg
+ fi
+ fi
+ if [ ! -d $PKG_DBDIR ];then
+ echo "Unable to locate PKG_DBDIR '$PKG_DBDIR'"
+ exit 1;
+ fi
+
# Now we have PKGSRCDIR, use it to determine PACKAGES, and PKGCHK_CONF
# as well as AWK, GREP, SED, PKGCHK_TAGS and PKGCHK_NOTAGS
#
@@ -159,7 +179,7 @@ pkg_install()
PKGDIR=$2
INSTALL=$3
- if [ -d /var/db/pkg/$PKGNAME ];then
+ if [ -d $PKG_DBDIR/$PKGNAME ];then
echo "$PKGNAME installed in previous stage"
elif [ -n "$opt_b" -a -f $PACKAGES/All/$PKGNAME.tgz ] ; then
if [ $INSTALL = Update ];then
@@ -175,7 +195,7 @@ pkg_install()
run_cmd "cd $PKGSRCDIR/$PKGDIR && ${MAKE} update"
fi
- if [ -z "$opt_n" -a ! -d /var/db/pkg/$PKGNAME ];then
+ if [ -z "$opt_n" -a ! -d $PKG_DBDIR/$PKGNAME ];then
FAIL=1
fi
@@ -294,6 +314,7 @@ on hostname and type, see pkg_chk(8).
fi
test -n "$MAKE" || MAKE="@MAKE@"
+test -n "$MAKECONF" || MAKECONF="@MAKECONF@"
# grabbed from GNU configure
if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then
@@ -423,8 +444,8 @@ if [ -n "$UPDATE_TODO" ];then
set -- $UPDATE_TODO
while [ $# != 0 ]; do
PKGNAME=`echo $1 | sed 's/-[0-9].*//'`
- if [ -f /var/db/pkg/$PKGNAME-[0-9]*/+REQUIRED_BY ];then
- LIST="$LIST$1|$2|`cat /var/db/pkg/$PKGNAME-[0-9]*/+REQUIRED_BY | xargs echo`\n"
+ if [ -f $PKG_DBDIR/$PKGNAME-[0-9]*/+REQUIRED_BY ];then
+ LIST="$LIST$1|$2|`cat $PKG_DBDIR/$PKGNAME-[0-9]*/+REQUIRED_BY | xargs echo`\n"
else
LIST="$LIST$1|$2\n"
fi