summaryrefslogtreecommitdiff
path: root/pkgtools
diff options
context:
space:
mode:
authorrillig <rillig@pkgsrc.org>2005-06-24 22:36:59 +0000
committerrillig <rillig@pkgsrc.org>2005-06-24 22:36:59 +0000
commit7b546b206dba7d70ece28e40b29de9388fe66918 (patch)
tree3de74593eaed1828a45090a32f4eca46554a7650 /pkgtools
parenta20a2e1679582b25a5bfa4021aad8a91e5b4cdc9 (diff)
downloadpkgsrc-7b546b206dba7d70ece28e40b29de9388fe66918.tar.gz
Don't warn on empty scripts/ directories, which may occur during CVS
updates. Don't write logging messages for Makefiles that are being read but for Makefiles that are included and for those whose inclusion is skipped. Skip include files that contain Make variables. When checking for direct use of shell commands, don't print the line continuation, that is the trailing white-space and backslash. These changes lead to pkglint-4.18.
Diffstat (limited to 'pkgtools')
-rw-r--r--pkgtools/pkglint/Makefile4
-rw-r--r--pkgtools/pkglint/files/pkglint.pl16
2 files changed, 9 insertions, 11 deletions
diff --git a/pkgtools/pkglint/Makefile b/pkgtools/pkglint/Makefile
index 0760674aa92..6e4621435e2 100644
--- a/pkgtools/pkglint/Makefile
+++ b/pkgtools/pkglint/Makefile
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.242 2005/06/14 03:52:01 rillig Exp $
+# $NetBSD: Makefile,v 1.243 2005/06/24 22:36:59 rillig Exp $
#
-DISTNAME= pkglint-4.17.1
+DISTNAME= pkglint-4.18
CATEGORIES= pkgtools devel
MASTER_SITES= # empty
DISTFILES= # empty
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index 759c49a6c9d..6608c9c5c35 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.193 2005/06/14 03:52:01 rillig Exp $
+# $NetBSD: pkglint.pl,v 1.194 2005/06/24 22:36:59 rillig Exp $
#
# This version contains lots of changes necessary for NetBSD packages
# done by:
@@ -667,7 +667,7 @@ sub check_package() {
if (grep { $_ !~ qr"/CVS$" } <$opt_packagedir/pkg/*>) {
log_error("$opt_packagedir/pkg", NO_LINE_NUMBER, "This directory and its contents are deprecated! Please 'mv $opt_packagedir/pkg/* $opt_packagedir' and 'rmdir $opt_packagedir/pkg'.");
}
- if (-d "$opt_packagedir/scripts") {
+ if (grep { $_ !~ qr"/CVS$" } <$opt_packagedir/scripts/*>) {
log_warning("$opt_packagedir/scripts", NO_LINE_NUMBER, "This directory and its contents are deprecated! Please call the script(s) explicitly from the corresponding target(s) in the pkg's Makefile.");
}
if (! -f "$opt_packagedir/$pkgdir/PLIST"
@@ -1112,8 +1112,6 @@ sub readmakefile($$) {
my $contents = "";
my ($includefile, $dirname, $savedln, $level, $lines);
- log_info($file, NO_LINE_NUMBER, "Reading Makefile.");
-
$lines = load_file($file);
if (!defined ($lines)) {
return false;
@@ -1129,11 +1127,8 @@ sub readmakefile($$) {
}
push(@{$all_lines}, $line);
# try to get any included file
- if ($line->text =~ /^.include\s+([^\n]+)$/) {
+ if ($line->text =~ qr"^\.\s*include\s+\"([-./\w]+)\"$") {
$includefile = $1;
- if ($includefile =~ /\"([^\"]+)\"/) {
- $includefile = $1;
- }
if (exists($seen_Makefile_include{$includefile})) {
$contents .= "### pkglint ### skipped $includefile\n";
next;
@@ -1164,9 +1159,12 @@ sub readmakefile($$) {
if (!-f "$dirname/$includefile") {
$line->log_error("Cannot read $dirname/$includefile.");
} else {
+ $line->log_info("Including $dirname/$includefile");
$contents .= readmakefile("$dirname/$includefile", $all_lines);
}
}
+ } elsif ($line->text =~ qr"^\.\s*include\s+(.*)") {
+ $line->log_info("Skipping include file $1");
} else {
$contents .= $line->text . "\n";
}
@@ -1328,7 +1326,7 @@ sub checklines_direct_tools($) {
} else {
$line->log_warning("Possible direct use of \"${tool}\" in variable ${varname}. Please use \$\{$toolvar{$tool}\} instead.");
}
- } elsif ($text =~ qr"^\t(.*)") {
+ } elsif ($text =~ qr"^\t(.*?)(?:\s*\\)?$") {
my ($shellcmd) = ($1);
# process shell commands
if ($shellcmd =~ $regex_ok_shellcmds) {