summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
authorwiz <wiz>2004-03-27 00:02:34 +0000
committerwiz <wiz>2004-03-27 00:02:34 +0000
commit353f00885179b217ede0e43f0ff7a1013962a108 (patch)
treedbf3b5b160b7f4bd600422e7571740c6914d0e46 /pkgtools
parentc988932673421f9d4c4d936f6d9cafa2631a544f (diff)
downloadpkgsrc-353f00885179b217ede0e43f0ff7a1013962a108.tar.gz
Re-import pkgtools/pkgchk as pkg_chk so that program name, PKGNAME,
and directory path match. Addresses PR 23679.
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkg_chk/DESCR5
-rw-r--r--pkgtools/pkg_chk/Makefile32
-rw-r--r--pkgtools/pkg_chk/PLIST3
-rw-r--r--pkgtools/pkg_chk/files/pkg_chk.8302
-rwxr-xr-xpkgtools/pkg_chk/files/pkg_chk.sh593
5 files changed, 935 insertions, 0 deletions
diff --git a/pkgtools/pkg_chk/DESCR b/pkgtools/pkg_chk/DESCR
new file mode 100644
index 00000000000..24d588aa43a
--- /dev/null
+++ b/pkgtools/pkg_chk/DESCR
@@ -0,0 +1,5 @@
+pkgchk verifies that the versions of installed packages matches those in
+pkgsrc, optionally adding missing or updating mismatched packages.
+
+It can verify all installed packages, or check against a set of packages
+based on the hostname, architecture, and other characteristics.
diff --git a/pkgtools/pkg_chk/Makefile b/pkgtools/pkg_chk/Makefile
new file mode 100644
index 00000000000..97bd25ab76d
--- /dev/null
+++ b/pkgtools/pkg_chk/Makefile
@@ -0,0 +1,32 @@
+# $NetBSD: Makefile,v 1.1.1.1 2004/03/27 00:02:34 wiz Exp $
+
+DISTNAME= pkg_chk-1.45
+CATEGORIES= pkgtools
+MASTER_SITES= # empty
+DISTFILES= # empty
+
+MAINTAINER= abs@NetBSD.org
+HOMEPAGE= ftp://ftp.NetBSD.org/pub/NetBSD/packages/pkgsrc/Packages.txt
+COMMENT= Check installed package versions against pkgsrc
+
+WRKSRC= ${WRKDIR}
+EXTRACT_ONLY= # empty
+USE_LANGUAGES= # empty
+NO_CHECKSUM= YES
+
+CONFLICTS= pkgchk-[0-9]*
+
+.include "../../mk/bsd.prefs.mk"
+
+MAKECONF?= /etc/mk.conf
+
+do-build:
+ ${SED} -e 's#@MAKE@#${MAKE}#g' \
+ -e 's#@MAKECONF@#${MAKECONF}#g' \
+ ${FILESDIR}/pkg_chk.sh >${WRKSRC}/pkg_chk.sh
+
+do-install:
+ ${INSTALL_SCRIPT} ${WRKSRC}/pkg_chk.sh ${PREFIX}/sbin/pkg_chk
+ ${INSTALL_MAN} ${FILESDIR}/pkg_chk.8 ${PREFIX}/man/man8/pkg_chk.8
+
+.include "../../mk/bsd.pkg.mk"
diff --git a/pkgtools/pkg_chk/PLIST b/pkgtools/pkg_chk/PLIST
new file mode 100644
index 00000000000..63217bab0b7
--- /dev/null
+++ b/pkgtools/pkg_chk/PLIST
@@ -0,0 +1,3 @@
+@comment $NetBSD: PLIST,v 1.1.1.1 2004/03/27 00:02:34 wiz Exp $
+sbin/pkg_chk
+man/man8/pkg_chk.8
diff --git a/pkgtools/pkg_chk/files/pkg_chk.8 b/pkgtools/pkg_chk/files/pkg_chk.8
new file mode 100644
index 00000000000..96442ee38bc
--- /dev/null
+++ b/pkgtools/pkg_chk/files/pkg_chk.8
@@ -0,0 +1,302 @@
+.\" $NetBSD: pkg_chk.8,v 1.1.1.1 2004/03/27 00:02:37 wiz Exp $
+.\"
+.\" Copyright (c) 2001 by David Brownlee (abs@netbsd.org)
+.\" Absolutely no warranty.
+.\"
+.Dd October 4, 2003
+.Dt PKGCHK 1
+.Sh NAME
+.Nm pkg_chk
+.Nd check, and optionally update, installed packages
+.Sh SYNOPSIS
+.Nm
+.Op Fl aBbcfhiklnrsuv
+.Op Fl C Ar conf
+.Op Fl D Ar tags
+.Op Fl L Ar file
+.Op Fl U Ar tags
+.Sh DESCRIPTION
+.Nm
+verifies that the versions of installed packages matches those in
+pkgsrc, optionally adding missing or updating mismatched packages.
+.Pp
+It can verify all installed packages, or check against a set of packages
+based on the hostname, architecture, and other characteristics.
+.Pp
+When updating packages that depend on each other
+.Nm
+will skip dependent packages to reduce unnecessary rebuilding.
+.Pp
+.Sy Options
+.Bl -tag -width xxxxxxxx
+.It Fl a
+Automatically add any missing packages.
+If a binary package exists in
+.Ev ${PACKAGES}
+it will be used in preference to building from source, unless the
+.Fl b
+or
+.Fl s
+options are given.
+.It Fl B
+Check the "Build version" (see option -b of pkg_info(1)) of packages.
+.It Fl b
+Limit additions or updates to using binary packages.
+If DEPENDS_TARGET=package is set in
+.Pa /etc/mk.conf ,
+then
+.Nm
+will automatically generate binary packages for later reuse.
+.It Fl C Ar conf
+Use the
+.Pa pkgchk.conf
+file
+.Sq Ar conf .
+.It Fl c
+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
+.Pa pkgchk.conf .
+Also includes
+.Ev PKGCHK_TAGS .
+.It Fl f
+Fetch all missing/mismatched packages found.
+Can be used with
+.Fl a
+or
+.Fl u
+to perform the fetch before any building, or with
+.Fl c
+or
+.Fl i
+to just fetch missing/mismatches packages.
+.It Fl g
+Generate an initial
+.Pa pkgchk.conf
+file based upon the packages installed on the host machine.
+.It Fl h
+Brief help.
+.It Fl i
+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
+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
+Recursively delete any mismatched packages found.
+Use with care, this does not record which packages were installed
+for later update.
+.It Fl s
+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
+.Pa pkgchk.conf .
+Also includes
+.Ev PKGCHK_NOTAGS .
+Package directories can also be skipped by listing them under
+.Fl U
+.It Fl u
+Automatically update any missing packages.
+If a binary package exists in PACKAGES it will be used in preference
+to building from source, unless the
+.Fl b
+or
+.Fl s
+options are given.
+.Pp
+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
+.Pa pkgchk.conf ,
+and all packages checked.
+.El
+.Sh FILE FORMAT
+Each non comment line in
+.Pa pkgchk.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:
+.Bl -bullet
+.It
+If a matched tag starts with a hyphen
+.Sq - ,
+the package is always excluded.
+.It
+Otherwise if any tags match the package will be included.
+.It
+A line without any tags matches all machines.
+.It
+An asterisk
+.Em *
+matches any tag.
+.It
+Tags cannot contain a hypen
+.Sq -
+or plus
+.Sq + .
+.It
+Tags separated by spaces are treated as
+.Dq or .
+.Dq taga tagb
+means if
+.Em tag_a
+or
+.Em tag_b
+match the current machine.
+.It
+Tags separated by a plus are treated as
+.Dq and .
+.Dq taga+tagb
+means if
+.Em tag_a
+and
+.Em tag_b
+match the current machine.
+.El
+.Pp
+The default set of tags used to determine which packages to match
+in
+.Pa pkgchk.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
+.Pa /usr/X11R6/lib/libX11.so
+or
+.Pa /usr/X11R6/lib/libX11.a
+is present,
+.Em x11
+is added to the list of tags.
+Tags should not contain the - or + characters.
+To see tags for the current machine, run
+.Nm
+with the
+.Fl v
+option.
+.Sh ENVIRONMENT
+.Nm
+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 .
+Defaults to
+.Pa ${PKGSRCDIR}/packages .
+.Pp
+Unless in a completely homogeneous environment (every machine running
+exactly the same OS version and architecture) setting
+.Ev ${PACKAGES}
+in
+.Pa /etc/mk.conf
+to a value such as
+.Bd -literal
+${PKGSRCDIR}/packages/${LOWER_OPSYS}-${OS_VERSION}-${MACHINE_ARCH}
+.Ed
+.Pp
+is strongly recommended.
+If
+.Em cpuflags
+(devel/cpuflags) is being used to optimally target individual CPU types,
+then
+.Ev ${CPU_DIR}
+should be appended to
+.Ev ${PACKAGES} .
+.It Ev PKGCHK_CONF
+Pathname to pkg_chk configuration file.
+If not set in environment then read from
+.Pa /etc/mk.conf .
+Defaults to
+.Pa ${PKGSRCDIR}/pkgchk.conf .
+.It Ev PKGCHK_TAGS
+Additional tags to add when parsing
+.Pa pkgchk.conf .
+.It Ev PKGCHK_NOTAGS
+Additional tags to unset when parsing
+.Pa pkgchk.conf .
+.El
+.Sh EXAMPLES
+Sample
+.Pa pkgchk.conf
+file:
+.Bd -literal
+# Must install before others
+devel/cpuflags
+pkgtools/xpkgwedge x11
+
+shells/standalone-tcsh *
+wm/pwm x11
+misc/setiathome i386
+print/acroread x11+i386
+www/communicator x11+sparc x11+sparc64
+www/navigator x11+i386
+x11/xlockmore x11 -wopr
+.Ed
+.Sh AUTHORS
+.An David Brownlee
+.Aq abs@netbsd.org ,
+plus much from Stoned Elipot.
+.Sh BUGS
+Updating packages on which other packages depend can currently only be done
+via source (not binary packages).
+.Pp
+If both package
+.Em a
+and package
+.Em b
+are to be updated, and
+.Em a
+depends on
+.Em b ,
+.Nm
+will correctly skip the update of
+.Em a .
+However, if
+.Em a
+depends on
+.Em b
+and
+.Em c ,
+and all three are marked for update,
+.Nm
+will update
+.Em b
+and
+.Em c
+in two separate passes, resulting in unnecessary rebuilding of
+.Em a
+(and potentially other packages).
diff --git a/pkgtools/pkg_chk/files/pkg_chk.sh b/pkgtools/pkg_chk/files/pkg_chk.sh
new file mode 100755
index 00000000000..85689061f7f
--- /dev/null
+++ b/pkgtools/pkg_chk/files/pkg_chk.sh
@@ -0,0 +1,593 @@
+#!/bin/sh -e
+#
+# $Id: pkg_chk.sh,v 1.1.1.1 2004/03/27 00:02:37 wiz Exp $
+#
+# TODO: Handle updates with dependencies via binary packages
+
+PATH=/usr/sbin:/usr/bin:${PATH}
+
+check_packages_installed()
+ {
+ UPDATE_TODO=
+ MISSING_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 $PKG_DBDIR/$PKGNAME ];then
+ echo_n "$PKGNAME: "
+ pkg=`echo $PKGNAME | sed 's/-[0-9].*//'`
+ pkginstalled=`sh -c "${PKG_INFO} -e $pkg" || true`
+ INSTALL=
+ if [ -n "$pkginstalled" ];then
+ echo_n "version mismatch - $pkginstalled"
+ MISMATCH_TODO="$MISMATCH_TODO $pkginstalled"
+ UPDATE_TODO="$UPDATE_TODO $PKGNAME $pkgdir"
+ else
+ echo_n "missing"
+ MISSING_TODO="$MISSING_TODO $PKGNAME $pkgdir"
+ 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=`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"
+ # 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
+ }
+
+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$NEXTCHECK" 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
+ }
+
+extract_make_vars()
+ {
+ MAKEDATA=".PHONY: x\nx:\n";
+ for var in $* ; do
+ MAKEDATA=$MAKEDATA"\t@echo $var=\${$var}\n"
+ done
+ eval `printf "$MAKEDATA" | ${MAKE} -f - -f Makefile x | \
+ sed -e 's/[^=]*=/&"/' -e 's/$/"/'`
+ }
+
+# $1 = name of variable
+# $2 = default value
+extract_mk_dir_var()
+ {
+ if [ -z "`eval echo \\$$1`" ] ; then
+ eval `printf "BSD_PKG_MK=1\n.PHONY: x\nx:\n\t@echo $1="'$'"{$1}\n" | ${MAKE} -f - -f $MAKECONF x`
+ if [ -z "`eval echo \\$$1`" ]; then
+ eval "$1=$2"
+ fi
+ if [ ! -d `eval echo \\$$1` ];then
+ echo "Unable to locate $1 `eval echo \\$$1`"
+ exit 1;
+ fi
+ fi
+ }
+
+extract_variables()
+ {
+ extract_mk_dir_var PKGSRCDIR /usr/pkgsrc
+ extract_mk_dir_var PKG_DBDIR /var/db/pkg
+
+ # Now we have PKGSRCDIR, use it to determine PACKAGES, and PKGCHK_CONF
+ # as well as AWK, GREP, SED, PKGCHK_TAGS and PKGCHK_NOTAGS
+ #
+
+ cd $PKGSRCDIR/pkgtools/pkgchk
+ extract_make_vars AWK GREP SED PACKAGES PKG_INFO PKG_ADD PKG_DELETE \
+ PKGCHK_CONF PKGCHK_TAGS PKGCHK_NOTAGS
+
+ if [ -z "$PACKAGES" ];then
+ PACKAGES=$PKGSRCDIR/packages
+ fi
+
+ if [ -z "$PKGCHK_CONF" ];then
+ PKGCHK_CONF=$PKGSRCDIR/pkgchk.conf
+ fi
+ }
+
+get_build_ver()
+ {
+ files=""
+ for f in Makefile ${FILESDIR}/* ${PKGDIR}/*; do
+ if [ -f $f ];then
+ files="$files $f"
+ fi
+ done
+ if [ -f ${DISTINFO_FILE} ]; then
+ for f in `${AWK} 'NF == 4 && $3 == "=" { gsub("[()]", "", $2); print $2 }' < ${DISTINFO_FILE}`; do
+ if [ -f ${PATCHDIR}/$f ]; then
+ files="$files ${PATCHDIR}/$f";
+ fi;
+ done
+ fi
+ if [ -d ${PATCHDIR} ]; then
+ for f in ${PATCHDIR}/patch-*; do
+ case $f in
+ *.orig|*.rej|*~) ;;
+ ${PATCHDIR}/patch-local-*)
+ files="$files $f" ;;
+ esac
+ done
+ fi
+ cat $files | ${GREP} '\$NetBSD'
+ }
+
+pkg_fetch()
+ {
+ PKGNAME=$1
+ PKGDIR=$2
+
+ run_cmd "cd $PKGSRCDIR/$PKGDIR && ${MAKE} fetch-list | sh"
+ if [ -n "$FAIL" ]; then
+ FAIL_DONE=$FAIL_DONE" "$PKGNAME
+ else
+ FETCH_DONE=$FETCH_DONE" "$PKGNAME
+ fi
+ }
+
+pkg_install()
+ {
+ PKGNAME=$1
+ PKGDIR=$2
+ INSTALL=$3
+
+ 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
+ PKG=`echo $PKGNAME | sed 's/-[0-9].*//'`
+ run_cmd "${PKG_DELETE} $PKG" 1
+ if [ -n "$FAIL" ]; then
+ echo "Can only update packages with dependencies via -s"
+ exit 1
+ fi
+ fi
+ if [ -n "$saved_PKG_PATH" ] ; then
+ export PKG_PATH=$saved_PKG_PATH
+ fi
+ run_cmd "cd $PACKAGES/All && ${PKG_ADD} $PKGNAME.tgz"
+ if [ -n "$saved_PKG_PATH" ] ; then
+ unset PKG_PATH
+ fi
+ elif [ -n "$opt_s" ]; then
+ run_cmd "cd $PKGSRCDIR/$PKGDIR && ${MAKE} update CLEANDEPENDS=yes"
+ fi
+
+ if [ -z "$opt_n" -a ! -d $PKG_DBDIR/$PKGNAME ];then
+ FAIL=1
+ fi
+
+ if [ -n "$FAIL" ]; then
+ FAIL_DONE=$FAIL_DONE" "$PKGNAME
+ elif [ $INSTALL = Update ];then
+ UPDATE_DONE=$UPDATE_DONE" "$PKGNAME
+ else
+ INSTALL_DONE=$INSTALL_DONE" "$PKGNAME
+ fi
+ }
+
+pkg_fetchlist()
+ {
+ PKGLIST=$@
+ echo "[ Fetch...]"
+ while [ $# != 0 ]; do
+ pkg_fetch $1 $2
+ shift ; shift;
+ done
+ }
+
+pkg_installlist()
+ {
+ INSTALL=$1 ; shift
+ echo "[ $INSTALL...]" ;
+ while [ $# != 0 ]; do
+ pkg_install $1 $2 $INSTALL
+ shift ; shift;
+ done
+ }
+
+run_cmd()
+ {
+ FAIL=
+ if [ -n "$2" ]; then
+ FAILOK=$2
+ else
+ FAILOK=$opt_k
+ fi
+ echo $1
+ if [ -z "$opt_n" ];then
+ if [ -n "$opt_L" ] ; then
+ 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 -100 "$opt_L" | egrep -v '^(\*\*\* Error code 1|Stop\.)' |\
+ tail -40
+ fi
+ if [ "$FAILOK" != 1 ]; then
+ exit 1
+ fi
+ fi
+ fi
+ }
+
+args=`getopt BC:D:L:U:abcfghiklnrsuv $*`
+if [ $? != 0 ]; then
+ opt_h=1
+fi
+set -- $args
+while [ $# != 0 ]; do
+ case "$1" in
+ -B ) opt_B=1 ; opt_i=1 ;;
+ -C ) opt_C="$2" ; shift;;
+ -D ) opt_D="$2" ; shift;;
+ -L ) opt_L="$2" ; shift;;
+ -U ) opt_U="$2" ; shift;;
+ -a ) opt_a=1 ; opt_c=1 ;;
+ -b ) opt_b=1 ;;
+ -c ) opt_c=1 ;;
+ -f ) opt_f=1 ;;
+ -g ) opt_g=1 ;;
+ -h ) opt_h=1 ;;
+ -i ) opt_i=1 ;;
+ -k ) opt_k=1 ;;
+ -l ) opt_l=1 ;;
+ -n ) opt_n=1 ;;
+ -r ) opt_r=1 ; opt_i=1 ;;
+ -s ) opt_s=1 ;;
+ -u ) opt_u=1 ; opt_i=1 ;;
+ -v ) opt_v=1 ;;
+ -- ) break ;;
+ esac
+ shift
+done
+
+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_g" -a -z "$opt_i" -a -z "$opt_l" ];then
+ echo "Must specify at least one of -a, -c, -g, -i, -l, or -u";
+ echo
+ opt_h=1;
+fi
+
+if [ -n "$opt_h" -o $# != 1 ];then
+ echo 'Usage: pkg_chk [opts]
+ -B Check the "Build version" of packages (implies -i)
+ -C conf Use pkgchk.conf file 'conf'
+ -D tags Comma separated list of additional pkgchk.conf tags to set
+ -L file Redirect output from commands run into file (should be fullpath)
+ -U tags Comma separated list of pkgchk.conf tags to unset
+ -a Add all missing packages (implies -c)
+ -b Limit installations to binary packages
+ -c Check installed packages against pkgchk.conf
+ -f Perform a 'make fetch' for all required packages
+ -g Generate an initial pkgchk.conf file
+ -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 mismatches (use with care) (implies -i)
+ -s Limit installations to building from source
+ -u Update all mismatched packages (implies -i)
+ -v Verbose
+
+pkg_chk verifies installed packages against pkgsrc.
+The most common usage is 'pkg_chk -i' to check all installed packages.
+For more advanced usage, including defining a set of desired packages based
+on hostname and type, see pkg_chk(8).
+'
+ exit 1
+fi
+
+# Hide PKG_PATH to avoid breakage in 'make' calls
+saved_PKG_PATH=$PKG_PATH
+unset PKG_PATH || true
+
+test -n "$MAKE" || MAKE="@MAKE@"
+test -n "$MAKECONF" || MAKECONF="@MAKECONF@"
+if [ ! -f $MAKECONF ] ; then
+ if [ -f /etc/mk.conf ] ; then
+ MAKECONF=/etc/mk.conf
+ else
+ MAKECONF=/dev/null
+ fi
+fi
+
+# grabbed from GNU configure
+if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then
+ # Stardent Vistra SVR4 grep lacks -e, says ghazi@caip.rutgers.edu.
+ if (echo -n testing; echo 1,2,3) | sed s/-n/xn/ | grep xn >/dev/null; then
+ ac_n= ac_c='
+' ac_t=' '
+ else
+ ac_n=-n ac_c= ac_t=
+ fi
+else
+ ac_n= ac_c='\c' ac_t=
+fi
+
+if [ -n "$opt_L" ] ; then
+ rm -f $opt_L
+fi
+
+extract_variables
+if [ -n "$opt_C" ] ; then
+ PKGCHK_CONF=$opt_C
+fi
+
+cd $PKGSRCDIR
+real_pkgsrcdir=`pwd`
+
+if [ -n "$opt_i" ];then
+ PKGDIRLIST=`sh -c "${PKG_INFO} -B \*" | ${AWK} -F= '/PKGPATH=/{print $2" "}'`
+fi
+
+if [ -n "$opt_g" ]; then
+ if [ -r $PKGCHK_CONF ]; then
+ mv $PKGCHK_CONF ${PKGCHK_CONF}.old
+ fi
+ echo "# Generated automatically at `date`" > $PKGCHK_CONF
+ ${PKG_INFO} -qBa | ${AWK} '/^PKGPATH/ { sub("PKGPATH=[ ]*", ""); print }' >> $PKGCHK_CONF
+fi
+
+if [ -n "$opt_c" -o -n "$opt_l" ];then
+
+ if [ ! -r $PKGCHK_CONF ];then
+ echo "Unable to read PKGCHK_CONF '$PKGCHK_CONF'"
+ exit 1;
+ fi
+
+ # Determine list of tags
+ #
+ TAGS="`hostname | sed -e 's,\..*,,'`,`hostname`,`uname -srm | ${AWK} '{print $1"-"$2"-"$3","$1"-"$2","$1"-"$3","$1","$2","$3}'`"
+ if [ -f /usr/X11R6/lib/libX11.so -o -f /usr/X11R6/lib/libX11.a ];then
+ TAGS="$TAGS,x11"
+ fi
+ if [ -n "$PKGCHK_TAGS" ];then
+ TAGS="$TAGS,$PKGCHK_TAGS"
+ fi
+ if [ -n "$PKGCHK_NOTAGS" ];then
+ if [ -n "$opt_U" ];then
+ opt_U="$opt_U,$PKGCHK_NOTAGS"
+ else
+ opt_U="$PKGCHK_NOTAGS"
+ fi
+ fi
+ if [ -n "$opt_D" ];then
+ TAGS="$TAGS,$opt_D"
+ fi
+ if [ -n "$opt_v" ];then
+ echo "set TAGS=$TAGS"
+ echo "unset TAGS=$opt_U"
+ fi
+
+ # Extract list of valid pkgdirs (skip any 'alreadyset' in $PKGDIRLIST)
+ #
+ PKGDIRLIST="$PKGDIRLIST "`${AWK} -v alreadyset="$PKGDIRLIST" -v setlist=$TAGS -v unsetlist=$opt_U '
+ BEGIN {
+ split(alreadyset, tmp, " ");
+ for (tag in tmp) { skip[tmp[tag]] = 1; }
+
+ split(setlist, tmp, ",");
+ for (tag in tmp) { taglist[tmp[tag]] = 1; }
+
+ split(unsetlist, tmp, ",");
+ for (tag in tmp) { skip[tmp[tag]] = 1; delete taglist[tmp[tag]] }
+
+ taglist["*"] = "*"
+ }
+ function and_expr_with_dict(expr, dict, ary, i, r) {
+ split(expr,ary,/\\+/);
+ r = 1;
+ for (i in ary)
+ if (! (ary[i] in dict))
+ { r = 0; break ;}
+ return r;
+ }
+ {
+ sub("#.*", "");
+ if (skip[$1])
+ { next; }
+ need = 0;
+ for (f = 1 ; f<=NF ; ++f) { # For each word on the line
+ if (sub("^-", "", $f)) { # If it begins with a '-'
+ if ($f ~ /\\+/) { # If it is a ANDed tag expression
+ if (and_expr_with_dict($f, taglist))
+ next; # If it is true, discard
+ } else { # If it is a simple tag
+ if ($f in taglist) # If match, discard
+ next;
+ }
+ } else {
+ if ($f ~ /\\+/) { # If it is a ANDed tag expression
+ if (and_expr_with_dict($f, taglist))
+ need = 1; # If it is true, note needed
+ } else { # If it is a simple tag
+ if ($f in taglist) # If match, note needed
+ need = 1;
+ }
+ }
+ }
+ if (NF == 1 || need)
+ { print $1 }
+ }
+ ' < $PKGCHK_CONF
+ `
+fi
+
+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
+ if [ -n "$opt_a" ] ; then
+ echo "[ Rechecking packages after deletions ]"
+ check_packages_installed $PKGDIRLIST # May need to add more packages
+ fi
+fi
+
+UPDATE_FETCH_TODO="$UPDATE_TODO"
+if [ -n "$UPDATE_TODO" ];then
+ # Generate list including packages which depend on updates
+ #
+ set -- $UPDATE_TODO
+ while [ $# != 0 ]; do
+ PKGNAME=`echo $1 | sed 's/-[0-9].*//'`
+ 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
+ shift ; shift;
+ done
+
+ # drop any packages whose 'parents' are also to be updated
+ #
+ UPDATE_TODO=`printf "$LIST" | ${AWK} -F '|' '
+ {
+ pkg2dir[$1] = $2
+ split($3, deplist, " ")
+ for (pkg in deplist)
+ {
+ dep = deplist[pkg]
+ sub("-[0-9].*", "", dep) # Strip version
+ covered[dep] = 1
+ }
+ }
+ END {
+ for (pkg in pkg2dir)
+ {
+ chk = pkg
+ sub("-[0-9].*", "", chk); # Strip version
+ if (!covered[chk])
+ print pkg" "pkg2dir[pkg]
+ }
+ }
+ '`
+fi
+
+if [ -n "$opt_f" ] ; then
+ pkg_fetchlist $UPDATE_FETCH_TODO
+ pkg_fetchlist $MISSING_TODO
+fi
+if [ -n "$opt_u" ] ; then
+ pkg_installlist Update $UPDATE_TODO
+fi
+if [ -n "$opt_a" ] ; then
+ pkg_installlist Install $MISSING_TODO
+fi
+
+if [ -n "$UPDATE_DONE" ];then
+ echo "Updated:$UPDATE_DONE"
+fi
+if [ -n "$INSTALL_DONE" ];then
+ echo "Installed:$INSTALL_DONE"
+fi
+if [ -n "$FAIL_DONE" ];then
+ echo "Failed:$FAIL_DONE"
+fi