diff options
Diffstat (limited to 'pkgtools')
-rw-r--r-- | pkgtools/pkgchk/Makefile | 32 | ||||
-rw-r--r-- | pkgtools/pkgchk/files/pkgchk.8 | 8 | ||||
-rwxr-xr-x | pkgtools/pkgchk/files/pkgchk.sh | 101 | ||||
-rw-r--r-- | pkgtools/pkgchk/pkg/PLIST | 6 |
4 files changed, 110 insertions, 37 deletions
diff --git a/pkgtools/pkgchk/Makefile b/pkgtools/pkgchk/Makefile index 44e5e46bc66..efbf27d09ec 100644 --- a/pkgtools/pkgchk/Makefile +++ b/pkgtools/pkgchk/Makefile @@ -1,24 +1,24 @@ -# $NetBSD: Makefile,v 1.7 2001/07/09 23:15:56 abs Exp $ -# +# $NetBSD: Makefile,v 1.8 2001/07/31 17:32:06 tron Exp $ -DISTNAME= pkgchk-1.06 -CATEGORIES= pkgtools -MASTER_SITES= # empty -DISTFILES= # empty +DISTNAME= pkgchk-1.07 +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 +MAINTAINER= abs@netbsd.org +HOMEPAGE= ftp://ftp.netbsd.org/pub/NetBSD/packages/pkgsrc/Packages.txt +COMMENT= Check installed package versions against pkgsrc EXTRACT_ONLY= # empty -NO_WRKSUBDIR= yes -NO_CHECKSUM= yes -NO_PATCH= yes -NO_CONFIGURE= yes -NO_BUILD= yes +NO_CHECKSUM= YES +WRKSRC= ${WRKDIR} + +do-build: + ${SED} -e 's#@MAKE@#${MAKE}#g' ${FILESDIR}/pkgchk.sh \ + >${WRKSRC}/pkgchk.sh do-install: - ${INSTALL_SCRIPT} ${FILESDIR}/pkgchk.sh ${PREFIX}/sbin/pkgchk - ${INSTALL_MAN} ${FILESDIR}/pkgchk.8 ${PREFIX}/man/man8/pkgchk.8 + ${INSTALL_SCRIPT} ${WRKSRC}/pkgchk.sh ${PREFIX}/sbin/pkg_chk + ${INSTALL_MAN} ${FILESDIR}/pkgchk.8 ${PREFIX}/man/man8/pkg_chk.8 .include "../../mk/bsd.pkg.mk" diff --git a/pkgtools/pkgchk/files/pkgchk.8 b/pkgtools/pkgchk/files/pkgchk.8 index 46089c0aa1e..377cb218b3d 100644 --- a/pkgtools/pkgchk/files/pkgchk.8 +++ b/pkgtools/pkgchk/files/pkgchk.8 @@ -1,4 +1,4 @@ -.\" $NetBSD: pkgchk.8,v 1.3 2001/07/07 12:17:35 abs Exp $ +.\" $NetBSD: pkgchk.8,v 1.4 2001/07/31 17:32:07 tron 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 abhinsv +.Op Fl abchinsuvB .Op Fl D Ar tags .Op Fl U Ar tags .Sh DESCRIPTION @@ -27,6 +27,8 @@ will skip dependent packages to reduce unnecessary rebuilding. .Pp .Sy Options .Bl -tag -width xxxxxxxx +.It Fl B +Check the "Build version" (see option -b of pkg_info(1)) of packages. .It Fl D Ar tags Add the comma separated list of tags to those checked when parsing pkgchk.conf. @@ -50,6 +52,8 @@ is set in then .Nm will automatically generate binary packages for later reuse. +.It Fl c +Check versions of packages specified in pkgchk.conf. .It Fl h Brief help. .It Fl i diff --git a/pkgtools/pkgchk/files/pkgchk.sh b/pkgtools/pkgchk/files/pkgchk.sh index e57be2b0eaa..b5fc36707d9 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.7 2001/07/09 23:15:56 abs Exp $ +# $Id: pkgchk.sh,v 1.8 2001/07/31 17:32:07 tron Exp $ # # TODO: Handle and as well as or tags (eg: i386+x11) # TODO: Order updates based on DEPENDENCIES. @@ -13,7 +13,7 @@ extract_variables() if [ -z "$PKGSRCDIR" ];then if [ -f /etc/mk.conf ] ;then - eval `printf 'BSD_PKG_MK=1\nall:\n\t@echo PKGSRCDIR=${PKGSRCDIR}\n' | make -f - -f /etc/mk.conf` + eval `printf 'BSD_PKG_MK=1\nall:\n\t@echo PKGSRCDIR=${PKGSRCDIR}\n' | ${MAKE} -f - -f /etc/mk.conf` fi if [ -z "$PKGSRCDIR" ];then PKGSRCDIR=/usr/pkgsrc @@ -29,7 +29,7 @@ extract_variables() eval `printf 'CATEGORIES=x\nDISTNAME=x\nall:\n @echo PACKAGES=${PACKAGES} @echo PKGCHK_CONF=${PKGCHK_CONF} - ' | (cd $PKGSRCDIR ; make -f - -f $PKGSRCDIR/mk/bsd.prefs.mk)` + ' | (cd $PKGSRCDIR ; ${MAKE} -f - -f $PKGSRCDIR/mk/bsd.prefs.mk)` if [ -z "$PACKAGES" ];then PACKAGES=$PKGSRCDIR/packages @@ -66,18 +66,51 @@ pkg_install() echo "make update for $PKGNAME" cd $PKGSRCDIR/$PKGDIR if [ -z "$opt_n" ];then - make update + ${MAKE} update fi fi } -args=`getopt D:IU:abchinsuv $*` + +get_build_version() + { + FILESDIR=`${MAKE} show-var VARNAME=FILESDIR` + PKGDIR=`${MAKE} show-var VARNAME=PKGDIR` + DISTINFO_FILE=`${MAKE} show-var VARNAME=DISTINFO_FILE` + PATCHDIR=`${MAKE} show-var VARNAME=PATCHDIR` + files="" + for f in `pwd`/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 + ${GREP} '\$NetBSD' $files | ${SED} -e "s|^${real_pkgsrcdir}/||" + } + +args=`getopt BD:U:abchinsuv $*` if [ $? != 0 ]; then opt_h=1 fi set -- $args while [ $# != 0 ]; do case "$1" in + -B ) opt_B=1 ;; -D ) opt_D="$2" ; shift;; -U ) opt_U="$2" ; shift;; -a ) opt_a=1 ; opt_c=1 ;; @@ -106,6 +139,7 @@ fi if [ -n "$opt_h" -o $# != 1 ];then echo 'Usage: pkgchk [opts] + -B Check the "Build version" of packages -D tags Comma separated list of additional pkgchk.conf tags to set -U tags Comma separated list of pkgchk.conf tags to unset -a Add all missing packages (implies -c) @@ -126,10 +160,34 @@ on hostname and type, see pkgchk(8). exit 1 fi +test -n "$MAKE" || MAKE="@MAKE@" + +# grabbeb 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 + extract_variables +cd $PKGSRCDIR +real_pkgsrcdir=`pwd` + +cd pkgtools/pkgchk +AWK=`${MAKE} show-var VARNAME=AWK` +GREP=`${MAKE} show-var VARNAME=GREP` +SED=`${MAKE} show-var VARNAME=SED` + + if [ -n "$opt_i" ];then - PKGDIRLIST=`pkg_info -B \* | awk '/PKGPATH= /{print $2}'` + PKGDIRLIST=`pkg_info -B \* | ${AWK} '/PKGPATH= /{print $2}'` fi if [ -n "$opt_c" ];then @@ -141,7 +199,7 @@ if [ -n "$opt_c" ];then # Determine list of tags # - TAGS="`hostname -s`,`hostname`,`uname -srm | awk '{print $1"-"$2"-"$3","$1"-"$2","$1"-"$3","$1","$2","$3}'`" + TAGS="`hostname | sed -e 's,\..*,,'`,`uname -srm | ${AWK} '{print $1"-"$2"-"$3","$1"-"$2","$1"-"$3","$1","$2","$3}'`" if [ -f /usr/X11R6/lib/libX11.so -o /usr/X11R6/lib/libX11.a ];then TAGS="$TAGS,x11" fi @@ -155,7 +213,7 @@ if [ -n "$opt_c" ];then # Extract list of valid pkgdirs # - PKGDIRLIST="$PKGDIRLIST "`awk -v setlist=$TAGS -v unsetlist=$opt_U ' + PKGDIRLIST="$PKGDIRLIST "`${AWK} -v setlist=$TAGS -v unsetlist=$opt_U ' BEGIN { split(setlist, tmp, ","); for (tag in tmp) @@ -203,33 +261,44 @@ for pkgdir in $PKGDIRLIST ; do fi cd $PKGSRCDIR/$pkgdir # Use 'make x' rather than 'make all' to avoid potential licence errors - pkgname=`printf 'x:\n\t@echo ${PKGNAME}\n'|make -f - -f Makefile x` || true + pkgname=`printf 'x:\n\t@echo ${PKGNAME}\n'|${MAKE} -f - -f Makefile x` || true if [ -z "$pkgname" ]; then echo "Unable to extract PKGNAME for $pkgdir" exit 1 fi if [ ! -d /var/db/pkg/$pkgname ];then - echo -n "$pkgname: " + echo $ac_n "$pkgname: $ac_c" pkg=`echo $pkgname | sed 's/-[0-9].*//'` pkginstalled=`pkg_info -e $pkg || true` INSTALL= if [ -n "$pkginstalled" ];then - echo -n "version mismatch - $pkginstalled" + echo $ac_n "version mismatch - $pkginstalled$ac_c" if [ -n "$opt_u" ]; then UPDATE_TODO="$UPDATE_TODO $pkgname $pkgdir" fi else - echo -n "missing" + echo $ac_n "missing$ac_c" 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)" + echo $ac_n " (binary package available)$ac_c" fi echo - elif [ -n "$opt_v" ];then - echo "$pkgname: OK" + else + if [ -n "$opt_B" ];then + current_build_version=`get_build_version` + installed_build_version=`cat /var/db/pkg/$pkgname/+BUILD_VERSION` + if [ x"$current_build_version" != x"$installed_build_version" ];then + echo "$pkgname: build version information mismatch" + # 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 @@ -251,7 +320,7 @@ if [ -n "$UPDATE_TODO" ];then # drop any packages whose 'parents' are also to be updated # - UPDATE_TODO=`printf "$LIST" | awk -F '|' ' + UPDATE_TODO=`printf "$LIST" | ${AWK} -F '|' ' { pkg2dir[$1] = $2 split($3, deplist, " ") diff --git a/pkgtools/pkgchk/pkg/PLIST b/pkgtools/pkgchk/pkg/PLIST index 2af38e2d43e..d21f633b196 100644 --- a/pkgtools/pkgchk/pkg/PLIST +++ b/pkgtools/pkgchk/pkg/PLIST @@ -1,3 +1,3 @@ -@comment $NetBSD: PLIST,v 1.1.1.1 2001/07/02 14:12:30 abs Exp $ -sbin/pkgchk -man/man8/pkgchk.8 +@comment $NetBSD: PLIST,v 1.2 2001/07/31 17:32:08 tron Exp $ +sbin/pkg_chk +man/man8/pkg_chk.8 |