summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
authorrillig <rillig>2005-12-06 22:07:35 +0000
committerrillig <rillig>2005-12-06 22:07:35 +0000
commita357f976fc046313b68c38b8878774c76c8a5e1f (patch)
tree47dfaf8b9f6aefb868f552d0002b2e1f3523f73d /pkgtools
parentd165efbc06c9a36b622c2762e94d3ee4e412fe51 (diff)
downloadpkgsrc-a357f976fc046313b68c38b8878774c76c8a5e1f.tar.gz
- Changed the type of PKG_OPTIONS_VAR from Varname to PkgOptionsVar. Added
a check that PKGBASE is not used in PKG_OPTIONS_VAR. - Added some macros to the list of portable CPP macro names.
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkglint/files/makevars.map4
-rw-r--r--pkgtools/pkglint/files/pkglint.pl21
2 files changed, 20 insertions, 5 deletions
diff --git a/pkgtools/pkglint/files/makevars.map b/pkgtools/pkglint/files/makevars.map
index fe1b18b8802..78196e78856 100644
--- a/pkgtools/pkglint/files/makevars.map
+++ b/pkgtools/pkglint/files/makevars.map
@@ -1,4 +1,4 @@
-# $NetBSD: makevars.map,v 1.49 2005/12/02 18:47:58 rillig Exp $
+# $NetBSD: makevars.map,v 1.50 2005/12/06 22:07:35 rillig Exp $
#
# This file contains the guessed type of some variables, according to
@@ -151,7 +151,7 @@ PKG_OPTIONS_NONEMPTY_SETS List
PKG_OPTIONS_OPTIONAL_GROUPS List
PKG_OPTIONS_REQUIRED_GROUPS List
PKG_OPTIONS_SET List
-PKG_OPTIONS_VAR Varname
+PKG_OPTIONS_VAR PkgOptionsVar
PKG_PRESERVE Yes
PKG_SKIP_REASON List+ of ShellWord
PKG_SUFX Userdefined
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index 5abbed5a158..2ae8acc99c8 100644
--- a/pkgtools/pkglint/files/pkglint.pl
+++ b/pkgtools/pkglint/files/pkglint.pl
@@ -11,7 +11,7 @@
# Freely redistributable. Absolutely no warranty.
#
# From Id: portlint.pl,v 1.64 1998/02/28 02:34:05 itojun Exp
-# $NetBSD: pkglint.pl,v 1.427 2005/12/06 17:37:06 rillig Exp $
+# $NetBSD: pkglint.pl,v 1.428 2005/12/06 22:07:35 rillig Exp $
#
# This version contains lots of changes necessary for NetBSD packages
# done by:
@@ -1654,6 +1654,7 @@ sub checkline_mk_shellcmd($$) {
checkline_mk_shelltext($line, $shellcmd);
}
+sub checkline_mk_vartype_basic($$$$$);
sub checkline_mk_vartype_basic($$$$$) {
my ($line, $varname, $type, $value, $comment) = @_;
my ($value_novar);
@@ -1798,6 +1799,16 @@ sub checkline_mk_vartype_basic($$$$$) {
$line->log_warning("\"${value}\" is not a valid package name. A valid package name has the form packagename-version, where version consists only of digits, letters and dots.");
}
+ } elsif ($type eq "PkgOptionsVar") {
+ checkline_mk_vartype_basic($line, $varname, "Varname", $value, $comment);
+ if ($value =~ qr"\$\{PKGBASE[:\}]") {
+ $line->log_error("PKGBASE must not be used in PKG_OPTIONS_VAR.");
+ $line->explain(
+ "PKGBASE is defined in bsd.pkg.mk, which is included as the",
+ "very last file, but PKG_OPTIONS_VAR is evaluated earlier.",
+ "Use \${PKGNAME:C/-[0-9].*//} instead.");
+ }
+
} elsif ($type eq "PkgRevision") {
if ($value !~ qr"^\d+$") {
$line->log_warning("\"${value}\" is not a valid Integer.");
@@ -2767,11 +2778,15 @@ sub checkfile_patches_patch($) {
__mips
__sparc
+ __APPLE__
+ __bsdi__
+ __CYGWIN__
__DragonFly__
- __FreeBSD__
+ __FreeBSD__ __FreeBSD_version
__INTERIX
__linux__
- __NetBSD__
+ __MINGW32__
+ __NetBSD__ __NetBSD_Version_
__OpenBSD__
__SVR4
__sun