summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkgchk/Makefile4
-rw-r--r--pkgtools/pkgchk/files/pkgchk.849
-rwxr-xr-xpkgtools/pkgchk/files/pkgchk.sh90
3 files changed, 118 insertions, 25 deletions
diff --git a/pkgtools/pkgchk/Makefile b/pkgtools/pkgchk/Makefile
index a9cdcfe9384..872a31b0818 100644
--- a/pkgtools/pkgchk/Makefile
+++ b/pkgtools/pkgchk/Makefile
@@ -1,6 +1,6 @@
-# $NetBSD: Makefile,v 1.45 2003/09/16 14:36:08 abs Exp $
+# $NetBSD: Makefile,v 1.46 2003/10/01 11:25:02 abs Exp $
-DISTNAME= pkgchk-1.41
+DISTNAME= pkgchk-1.42
WRKSRC= ${WRKDIR}
CATEGORIES= pkgtools
MASTER_SITES= # empty
diff --git a/pkgtools/pkgchk/files/pkgchk.8 b/pkgtools/pkgchk/files/pkgchk.8
index 165d6bd5df8..6c9bc1033af 100644
--- a/pkgtools/pkgchk/files/pkgchk.8
+++ b/pkgtools/pkgchk/files/pkgchk.8
@@ -1,4 +1,4 @@
-.\" $NetBSD: pkgchk.8,v 1.16 2003/09/16 14:45:53 wiz Exp $
+.\" $NetBSD: pkgchk.8,v 1.17 2003/10/01 11:25:02 abs Exp $
.\"
.\" Copyright (c) 2001 by David Brownlee (abs@netbsd.org)
.\" Absolutely no warranty.
@@ -10,7 +10,7 @@
.Nd check, and optionally update, installed packages
.Sh SYNOPSIS
.Nm
-.Op Fl aBbcfhiknrsuv
+.Op Fl aBbcfhiklnrsuv
.Op Fl C Ar conf
.Op Fl D Ar tags
.Op Fl L Ar file
@@ -48,13 +48,16 @@ then
.Nm
will automatically generate binary packages for later reuse.
.It Fl C Ar conf
-Use the pkgchk.conf file
+Use the
+.Pa pkgchk.conf
+file
.Sq Ar conf .
.It Fl c
-Check versions of packages specified in pkgchk.conf.
+Check versions of packages specified in
+.Pa pkgchk.conf .
.It Fl D Ar tags
Add the comma separated list of tags to those checked when parsing
-pkgchk.conf.
+.Pa pkgchk.conf .
Also includes
.Ev PKGCHK_TAGS .
.It Fl f
@@ -71,7 +74,8 @@ to just fetch missing/mismatches packages.
.It Fl h
Brief help.
.It Fl i
-Check versions of installed packages, ignoring pkgchk.conf.
+Check versions of installed packages, ignoring
+.Pa pkgchk.conf .
.It Fl k
Continue with further packages if errors are encountered.
.It Fl L Ar file
@@ -79,6 +83,14 @@ Redirect the output for all commands run into the logfile
.Pa file .
Should be specified as a full pathname.
On any error the tail end of the logfile will be displayed.
+.It Fl l
+List the filename for all binary packages (including the exact dependencies
+against which each package was built) based on
+.Pa pkgchk.conf .
+Will abort if a binary package is missing.
+This can be used (in conjunction with -U and -D) to determine what
+packages would need to be copied to a remote machine to ensure it
+was completely up to date.
.It Fl n
Display actions that would be taken, but do not change anything.
.It Fl r
@@ -89,7 +101,8 @@ for later update.
Limit additions or updates to building from source.
.It Fl U Ar tags
Remove the comma separated list of tags from those checked when
-parsing pkgchk.conf.
+parsing
+.Pa pkgchk.conf .
Also includes
.Ev PKGCHK_NOTAGS .
Package directories can also be skipped by listing them under
@@ -106,10 +119,14 @@ options are given.
Note: If the update fails (particularly when building from source), the system
will be left with missing packages.
.It Fl v
-Verbose - list the tags set when checking pkgchk.conf, and all packages checked.
+Verbose - list the tags set when checking
+.Pa pkgchk.conf ,
+and all packages checked.
.El
.Sh FILE FORMAT
-Each non comment line in pkgsrc.conf should contain a package
+Each non comment line in
+.Pa pkgsrc.conf
+should contain a package
directory (such as sysutils/skill) followed by an optional list of
tags.
Tags are checked against the current machine's set:
@@ -143,7 +160,9 @@ match the current machine.
.El
.Pp
The default set of tags used to determine which packages to match
-in pkgsrc.conf are equivalent to the output of the following with
+in
+.Pa pkgsrc.conf
+are equivalent to the output of the following with
any spaces converted to hypens (-): hostname -s, hostname, uname
-srm, uname -sr, uname -sm, uname -s, uname -r, uname -m.
If
@@ -211,12 +230,16 @@ If not set in environment then read from
Defaults to
.Pa ${PKGSRCDIR}/pkgchk.conf .
.It Ev PKGCHK_TAGS
-Additional tags to add when parsing pkgchk.conf.
+Additional tags to add when parsing
+.Pa pkgchk.conf .
.It Ev PKGCHK_NOTAGS
-Additional tags to unset when parsing pkgchk.conf.
+Additional tags to unset when parsing
+.Pa pkgchk.conf .
.El
.Sh EXAMPLES
-Sample pkgchk.conf file:
+Sample
+.Pa pkgchk.conf
+file:
.Bd -literal
# Must install before others
devel/cpuflags
diff --git a/pkgtools/pkgchk/files/pkgchk.sh b/pkgtools/pkgchk/files/pkgchk.sh
index 70c4832a45b..9da7b5c1db7 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.44 2003/09/16 14:36:12 abs Exp $
+# $Id: pkgchk.sh,v 1.45 2003/10/01 11:25:02 abs Exp $
#
# TODO: Handle updates with dependencies via binary packages
@@ -63,6 +63,69 @@ check_packages_installed()
done
}
+list_packages()
+ {
+ CHECKLIST=' '
+ for pkgdir in $* ; do
+
+ if [ ! -f $PKGSRCDIR/$pkgdir/Makefile ];then
+ echo "WARNING: No $pkgdir/Makefile - package moved or obsolete?"
+ continue
+ fi
+ cd $PKGSRCDIR/$pkgdir
+ extract_make_vars PKGNAME
+ if [ -z "$PKGNAME" ]; then
+ echo "Unable to extract PKGNAME for $pkgdir"
+ exit 1
+ fi
+ if [ ! -f $PACKAGES/All/$PKGNAME.tgz ] ;then
+ echo " ** $PKGNAME - binary package missing"
+ if [ -n "$opt_k" ];then
+ exit 1
+ fi
+ continue
+ fi
+ if [ -n "$opt_v" ];then
+ echo "$PKGNAME.tgz: found"
+ fi
+ CHECKLIST="$CHECKLIST$PKGNAME ";
+ if [ $PKGNAME = 'samba-2.2.8anb4.tgz' ] ; then
+ echo XXX
+ break
+ fi
+ done
+ while [ "$CHECKLIST" != ' ' ]; do
+ PKGLIST="$PKGLIST$CHECKLIST"
+ NEXTCHECK=' '
+ for pkg in $CHECKLIST ; do
+ if [ ! -f $PACKAGES/All/$pkg.tgz ] ; then
+ echo " ** $PKGNAME - binary package (dependency) missing"
+ if [ -n "$opt_k" ];then
+ exit 1
+ fi
+ continue
+ fi
+ for dep in `pkg_info -N $PACKAGES/All/$pkg.tgz | ${SED} '1,/Built using:/d' | ${GREP} ..` ; do
+ case "$PKGLIST" in
+ *\ $dep\ *)
+ if [ -n "$opt_v" ];then
+ echo "Duplicate depend $dep"
+ fi;;
+ *)
+ NEXTCHECK="$NEXTCHECK$dep "
+ if [ -n "$opt_v" ];then
+ echo "Add depend $dep"
+ fi;;
+ esac
+ done
+ done
+ CHECKLIST="$NEXTCHECK"
+ done
+ for pkg in $PKGLIST ; do
+ echo $pkg.tgz
+ done
+ }
+
echo_n()
{
echo $ac_n "$*"$ac_c
@@ -228,14 +291,15 @@ run_cmd()
echo $1
if [ -z "$opt_n" ];then
if [ -n "$opt_L" ] ; then
- sh -c "$1" > "$opt_L" 2>&1 || FAIL=1
+ sh -c "$1" >> "$opt_L" 2>&1 || FAIL=1
else
sh -c "$1" || FAIL=1
fi
if [ -n "$FAIL" ] ; then
echo "** '$1' failed"
if [ -n "$opt_L" ] ; then
- tail -20 "$opt_L"
+ tail -100 "$opt_L" | egrep -v '^(\*\*\* Error code 1|Stop\.)' |\
+ tail -40
fi
if [ "$FAILOK" != 1 ]; then
exit 1
@@ -244,7 +308,7 @@ run_cmd()
fi
}
-args=`getopt BC:D:L:U:abcfhiknrsuv $*`
+args=`getopt BC:D:L:U:abcfhiklnrsuv $*`
if [ $? != 0 ]; then
opt_h=1
fi
@@ -263,6 +327,7 @@ while [ $# != 0 ]; do
-h ) opt_h=1 ;;
-i ) opt_i=1 ;;
-k ) opt_k=1 ;;
+ -l ) opt_l=1 ;;
-n ) opt_n=1 ;;
-r ) opt_r=1 ;;
-s ) opt_s=1 ;;
@@ -277,8 +342,8 @@ if [ -z "$opt_b" -a -z "$opt_s" ];then
opt_b=1; opt_s=1;
fi
-if [ -z "$opt_a" -a -z "$opt_c" -a -z "$opt_i" ];then
- echo "Must specify at least one of -a, -c, -i, or -u";
+if [ -z "$opt_a" -a -z "$opt_c" -a -z "$opt_i" -a -z "$opt_l" ];then
+ echo "Must specify at least one of -a, -c, -i, -l, or -u";
echo
opt_h=1;
fi
@@ -297,6 +362,7 @@ if [ -n "$opt_h" -o $# != 1 ];then
-h This help
-i Check versions of installed packages (not using pkgchk.conf)
-k Continue with further packages if errors are encountered
+ -l List binary packages including dependencies (implies -c)
-n Display actions that would be taken, but do not perform them
-r Recursively remove mismatched files (use with care)
-s Limit installations to building from source
@@ -355,7 +421,7 @@ if [ -n "$opt_i" ];then
fi
-if [ -n "$opt_c" ];then
+if [ -n "$opt_c" -o -n "$opt_l" ];then
if [ ! -r $PKGCHK_CONF ];then
echo "Unable to read PKGCHK_CONF '$PKGCHK_CONF'"
@@ -440,9 +506,13 @@ if [ -n "$opt_c" ];then
`
fi
-# Check $PKGDIRLIST packages are installed and correct version
-#
-check_packages_installed $PKGDIRLIST
+if [ -n "$opt_l" ] ; then
+ list_packages $PKGDIRLIST
+else
+ # Check $PKGDIRLIST packages are installed and correct version
+ #
+ check_packages_installed $PKGDIRLIST
+fi
if [ -n "$opt_r" -a -n "$MISMATCH_TODO" ]; then
run_cmd "${PKG_DELETE} -r $MISMATCH_TODO" 1