summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--pkgtools/pkgchk/Makefile4
-rwxr-xr-xpkgtools/pkgchk/files/pkgchk.sh126
2 files changed, 73 insertions, 57 deletions
diff --git a/pkgtools/pkgchk/Makefile b/pkgtools/pkgchk/Makefile
index 6e663a5f201..9f141f56066 100644
--- a/pkgtools/pkgchk/Makefile
+++ b/pkgtools/pkgchk/Makefile
@@ -1,6 +1,6 @@
-# $NetBSD: Makefile,v 1.20 2001/11/21 23:01:56 abs Exp $
+# $NetBSD: Makefile,v 1.21 2001/11/28 11:39:44 abs Exp $
-DISTNAME= pkgchk-1.19
+DISTNAME= pkgchk-1.20
CATEGORIES= pkgtools
MASTER_SITES= # empty
DISTFILES= # empty
diff --git a/pkgtools/pkgchk/files/pkgchk.sh b/pkgtools/pkgchk/files/pkgchk.sh
index f5d5035809a..c8b0af58f7c 100755
--- a/pkgtools/pkgchk/files/pkgchk.sh
+++ b/pkgtools/pkgchk/files/pkgchk.sh
@@ -1,11 +1,72 @@
#!/bin/sh -e
#
-# $Id: pkgchk.sh,v 1.22 2001/11/21 23:01:56 abs Exp $
+# $Id: pkgchk.sh,v 1.23 2001/11/28 11:39:44 abs Exp $
#
# TODO: Handle updates with dependencies via binary packages
PATH=/usr/sbin:${PATH}
+check_packages_installed()
+ {
+ UPDATE_TODO=
+ INSTALL_TODO=
+ MISMATCH_TODO=
+
+ for pkgdir in $* ; do
+
+ if [ ! -f $PKGSRCDIR/$pkgdir/Makefile ];then
+ echo "WARNING: No $pkgdir/Makefile - package moved or obsolete?"
+ continue
+ fi
+ cd $PKGSRCDIR/$pkgdir
+ if [ -n "$opt_B" ];then
+ extract_make_vars PKGNAME FILESDIR PKGDIR DISTINFO_FILE PATCHDIR
+ else
+ extract_make_vars PKGNAME
+ fi
+ if [ -z "$PKGNAME" ]; then
+ echo "Unable to extract PKGNAME for $pkgdir"
+ exit 1
+ fi
+ if [ ! -d /var/db/pkg/$PKGNAME ];then
+ echo_n "$PKGNAME: "
+ pkg=`echo $PKGNAME | sed 's/-[0-9].*//'`
+ pkginstalled=`pkg_info -e $pkg || true`
+ INSTALL=
+ if [ -n "$pkginstalled" ];then
+ echo_n "version mismatch - $pkginstalled"
+ MISMATCH_TODO="$MISMATCH_TODO $pkginstalled"
+ if [ -n "$opt_u" ]; then
+ UPDATE_TODO="$UPDATE_TODO $PKGNAME $pkgdir"
+ fi
+ else
+ echo_n "missing"
+ if [ -n "$opt_a" ] ; then
+ INSTALL_TODO="$INSTALL_TODO $PKGNAME $pkgdir"
+ fi
+ fi
+ if [ -f $PACKAGES/All/$PKGNAME.tgz ] ;then
+ echo_n " (binary package available)"
+ fi
+ echo
+ else
+ if [ -n "$opt_B" ];then
+ current_build_ver=`get_build_ver`
+ installed_build_ver=`cat /var/db/pkg/$PKGNAME/+BUILD_VERSION | sed "s:^${real_pkgsrcdir}/::"`
+ if [ x"$current_build_ver" != x"$installed_build_ver" ];then
+ echo "$PKGNAME: build version information mismatch"
+ MISMATCH_TODO="$MISMATCH_TODO $PKGNAME"
+ # should we mark this pkg to be updated if -u is given ??
+ elif [ -n "$opt_v" ];then
+ echo "$PKGNAME: OK"
+ fi
+ elif [ -n "$opt_v" ];then
+ echo "$PKGNAME: OK"
+ fi
+ fi
+ done
+ }
+
echo_n()
{
echo $ac_n "$*"$ac_c
@@ -54,9 +115,8 @@ extract_variables()
fi
}
-get_build_version()
+get_build_ver()
{
- extract_make_vars FILESDIR PKGDIR DISTINFO_FILE PATCHDIR
files=""
for f in `pwd`/Makefile ${FILESDIR}/* ${PKGDIR}/*; do
if [ -f $f ];then
@@ -307,62 +367,18 @@ if [ -n "$opt_c" ];then
`
fi
-# Check packages are installed
+# Check $PKGDIRLIST packages are installed and correct version
#
-for pkgdir in $PKGDIRLIST ; do
+check_packages_installed $PKGDIRLIST
- if [ ! -f $PKGSRCDIR/$pkgdir/Makefile ];then
- echo "WARNING: No $pkgdir/Makefile - package moved or obsolete?"
- continue
- fi
- cd $PKGSRCDIR/$pkgdir
- # Use 'make x' rather than 'make all' to avoid potential licence errors
- extract_make_vars PKGNAME
- if [ -z "$PKGNAME" ]; then
- echo "Unable to extract PKGNAME for $pkgdir"
- exit 1
+if [ -n "$opt_r" -a -n "$MISMATCH_TODO" ]; then
+ run_cmd "pkg_delete -r $MISMATCH_TODO"
+ if [ -n "$opt_a" ] ; then
+ echo "[ Rechecking packages after deletions ]"
+ check_packages_installed $PKGDIRLIST # May need to add more packages
fi
- if [ ! -d /var/db/pkg/$PKGNAME ];then
- echo_n "$PKGNAME: "
- pkg=`echo $PKGNAME | sed 's/-[0-9].*//'`
- pkginstalled=`pkg_info -e $pkg || true`
- INSTALL=
- if [ -n "$pkginstalled" ];then
- echo_n "version mismatch - $pkginstalled"
- mismatch="$mismatch $pkginstalled"
- if [ -n "$opt_u" ]; then
- UPDATE_TODO="$UPDATE_TODO $PKGNAME $pkgdir"
- fi
- else
- echo_n "missing"
- if [ -n "$opt_a" ] ; then
- INSTALL_TODO="$INSTALL_TODO $PKGNAME $pkgdir"
- fi
- fi
- if [ -f $PACKAGES/All/$PKGNAME.tgz ] ;then
- echo_n " (binary package available)"
- fi
- echo
- else
- if [ -n "$opt_B" ];then
- current_build_version=`get_build_version`
- installed_build_version=`cat /var/db/pkg/$PKGNAME/+BUILD_VERSION | sed "s:^${real_pkgsrcdir}/::"`
- if [ x"$current_build_version" != x"$installed_build_version" ];then
- echo "$PKGNAME: build version information mismatch"
- mismatch="$mismatch $PKGNAME"
- # should we mark this pkg to be updated if -u is given ??
- elif [ -n "$opt_v" ];then
- echo "$PKGNAME: OK"
- fi
- elif [ -n "$opt_v" ];then
- echo "$PKGNAME: OK"
- fi
- fi
-done
-
-if [ -n "$opt_r" -a -n "$mismatch" ]; then
- run_cmd "pkg_delete -r $mismatch"
fi
+
if [ -n "$UPDATE_TODO" ];then
echo "[ Update... ]"