summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--pkgtools/pkgchk/Makefile4
-rw-r--r--pkgtools/pkgchk/files/pkgchk.863
-rwxr-xr-xpkgtools/pkgchk/files/pkgchk.sh56
3 files changed, 95 insertions, 28 deletions
diff --git a/pkgtools/pkgchk/Makefile b/pkgtools/pkgchk/Makefile
index 2025304c920..7ef25fcc3e4 100644
--- a/pkgtools/pkgchk/Makefile
+++ b/pkgtools/pkgchk/Makefile
@@ -1,6 +1,6 @@
-# $NetBSD: Makefile,v 1.18 2001/10/01 12:24:00 abs Exp $
+# $NetBSD: Makefile,v 1.19 2001/10/10 09:55:31 abs Exp $
-DISTNAME= pkgchk-1.17
+DISTNAME= pkgchk-1.18
CATEGORIES= pkgtools
MASTER_SITES= # empty
DISTFILES= # empty
diff --git a/pkgtools/pkgchk/files/pkgchk.8 b/pkgtools/pkgchk/files/pkgchk.8
index e4aef21d828..84680ed38bb 100644
--- a/pkgtools/pkgchk/files/pkgchk.8
+++ b/pkgtools/pkgchk/files/pkgchk.8
@@ -1,4 +1,4 @@
-.\" $NetBSD: pkgchk.8,v 1.6 2001/09/27 21:13:46 abs Exp $
+.\" $NetBSD: pkgchk.8,v 1.7 2001/10/10 09:55:32 abs Exp $
.\"
.\" Copyright (c) 2001 by David Brownlee (abs@netbsd.org)
.\" Absolutely no warranty.
@@ -31,10 +31,12 @@ will skip dependent packages to reduce unnecessary rebuilding.
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.
+pkgchk.conf. Also includes
+.Ev PKGCHK_TAGS .
.It Fl U Ar tags
Remove the comma separated list of tags from those checked when
-parsing pkgchk.conf.
+parsing pkgchk.conf. Also includes
+.Ev PKGCHK_NOTAGS .
.It Fl a
Automatically add any missing packages. If a binary package exists
in
@@ -78,18 +80,39 @@ options are given.
Note: If the update fails (particularly when building from source), the system
will be left with missing packaged.
.It Fl v
-Verbose - list the tags set, and all packages checked.
+Verbose - list the tags set when checking pkgchk.conf, and all packages checked.
.El
.Sh FILE FORMAT
.Pp
Each non comment line in pkgsrc.conf should contain a package
directory (such as sysutils/skill) followed by an optional list of
-tags. If a tag starts with a hyphen (-), then any machine matching
-will be excluded, otherwise if any tags match the current machine
-the package will be included. A line with a package directory
-without any tags, or the tag
+tags. Tags are checked against the current machine's set:
+.Bl -bullet
+.It
+If a matched tag starts with a hyphen '-', 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 *
-will match all machines.
+matches any tag.
+.It
+Tags cannot contain a hypen '-' or plus '+'.
+.It
+Tags separated by spaces are treated as 'or'. 'taga tagb' means if
+.Em tag_a
+or
+.Em tag_b
+match the current machine.
+.It
+Tags separated by a plus are treated as 'and'. '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
pkgsrc.conf are equivalent to the output of the following with any spaces
@@ -100,6 +123,7 @@ or
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
@@ -143,9 +167,28 @@ then read from
.Pa /etc/mk.conf .
Defaults to
.Pa ${PKGSRCDIR}/pkgchk.conf .
+.It Ev PKGCHK_TAGS
+Additional tags to add when parsing pkgchk.conf.
+.It Ev PKGCHK_NOTAGS
+Additional tags to unset when parsing pkgchk.conf.
.El
+.Sh EXAMPLES
+Sample 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 AUTHOR
-David Brownlee <abs@netbsd.org>
+David Brownlee <abs@netbsd.org>, plus much from Stoned Elipot.
.Sh CAVEATS
Updating packages on which other packages depend can currently only be done
via source (not binary packages).
diff --git a/pkgtools/pkgchk/files/pkgchk.sh b/pkgtools/pkgchk/files/pkgchk.sh
index 57958389c12..7e7c9e5b3d4 100755
--- a/pkgtools/pkgchk/files/pkgchk.sh
+++ b/pkgtools/pkgchk/files/pkgchk.sh
@@ -1,8 +1,7 @@
#!/bin/sh -e
#
-# $Id: pkgchk.sh,v 1.20 2001/10/01 12:24:00 abs Exp $
+# $Id: pkgchk.sh,v 1.21 2001/10/10 09:55:32 abs Exp $
#
-# TODO: Handle and as well as or tags (eg: i386+x11)
# TODO: Handle updates with dependencies via binary packages
PATH=/usr/sbin:${PATH}
@@ -40,10 +39,11 @@ extract_variables()
fi
# 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 PKGCHK_CONF
+ extract_make_vars AWK GREP SED PACKAGES PKGCHK_CONF PKGCHK_TAGS PKGCHK_NOTAGS
if [ -z "$PACKAGES" ];then
PACKAGES=$PKGSRCDIR/packages
@@ -235,6 +235,16 @@ if [ -n "$opt_c" ];then
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
@@ -257,25 +267,39 @@ if [ -n "$opt_c" ];then
for (tag in tmp) { 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 (alreadyset[$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 in taglist) # If match, discard
- { next; }
- }
- else
- {
- if ($f in taglist) # If match, note needed
- { need = 1; }
- }
+ 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 }
}