summaryrefslogtreecommitdiff
path: root/pkgtools/pkglint
diff options
context:
space:
mode:
authorwiz <wiz@pkgsrc.org>2004-08-08 22:57:04 +0000
committerwiz <wiz@pkgsrc.org>2004-08-08 22:57:04 +0000
commit0e61bc2045e3eb3a80ac60492eada15b0450e637 (patch)
treee8d93ee614be2f35f662e84b9034823f4934c243 /pkgtools/pkglint
parentee09aa9952c0a20668758b7d6ea44cacb298ba1c (diff)
downloadpkgsrc-0e61bc2045e3eb3a80ac60492eada15b0450e637.tar.gz
Apply patch from Roland Illig, in private mail:
- replaced literal "1" and "0" by "true" and "false" where appropriate No functional change, thus no PKGREVISION bump.
Diffstat (limited to 'pkgtools/pkglint')
-rw-r--r--pkgtools/pkglint/files/pkglint.pl155
1 files changed, 92 insertions, 63 deletions
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index 6f36a394a3c..649eb31090d 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.114 2004/07/14 17:43:43 wiz Exp $
+# $NetBSD: pkglint.pl,v 1.115 2004/08/08 22:57:04 wiz Exp $
#
# This version contains lots of changes necessary for NetBSD packages
# done by Hubert Feyrer <hubertf@netbsd.org>,
@@ -19,6 +19,30 @@
# Roland Illig <roland.illig@gmx.de> and others.
#
+#==========================================================================
+# Some comments on the overall structure: The @EXPORT clauses in the pack-
+# ages must be in a BEGIN block, because otherwise the names starting with
+# an uppercase letter are not recognized as subroutines but as file handles.
+#==========================================================================
+
+package PkgLint::Utils;
+#==========================================================================
+# This package is a catch-all for everything that does not fit in any other
+# package. Currently it contains the boolean constants C<false> and C<true>.
+#==========================================================================
+BEGIN {
+ use Exporter;
+ use vars qw(@ISA @EXPORT_OK);
+ @ISA = qw(Exporter);
+ @EXPORT_OK = qw(false true);
+}
+
+use constant {
+ false => 0,
+ true => 1,
+};
+#== End of PkgLint::Utils =================================================
+
use strict;
use Getopt::Std;
@@ -26,6 +50,10 @@ use File::Basename;
use FileHandle;
use Cwd;
+BEGIN {
+ import PkgLint::Utils qw(false true);
+}
+
# Start of configuration area
my $conf_rcsidstr = 'NetBSD';
my $conf_portsdir = '@PORTSDIR@';
@@ -34,15 +62,15 @@ my $conf_distver = '@DISTVER@';
my $conf_make = '@MAKE@';
# End of configuration area
-# Command line options
-my $opt_extrafile = 1; #
-my $opt_parenwarn = 1; #
-my $opt_committer = 1; #
-my $opt_verbose = 0; #
-my $opt_newpackage = 0; #
-my $opt_dumpmakefile = 0; #
-my $opt_contblank = 1; # number of allowed contigoous blank lines
-my $opt_packagedir = "."; #
+# Command Line Options
+my $opt_extrafile = true; # check all files we can find for simple errors
+my $opt_parenwarn = true; # warn about use for $(VAR) instead of ${VAR}
+my $opt_committer = true; # check items especially for package developers
+my $opt_newpackage = false; # consider this package new (uncommitted)
+my $opt_dumpmakefile = false; # dump the Makefile after parsing
+my $opt_contblank = 1; # number of allowed contiguous blank lines
+my $opt_packagedir = "."; # directory to check
+my $opt_verbose = false; # print status messages while processing
# Constants
my $regex_rcsidstr = qr"\$($conf_rcsidstr)(?::[^\$]*|)\$";
@@ -61,11 +89,11 @@ my $scriptdir = "scripts";
my $seen_PKG_REGISTER = undef;
my $category = undef;
my %cmdnames = ();
-my $seen_PLIST_SRC = 0;
-my $seen_NO_PKG_REGISTER = 0;
-my $seen_NO_CHECKSUM = 0;
-my $seen_USE_PKGLOCALEDIR = 0;
-my $seen_USE_BUILDLINK3 = 0;
+my $seen_PLIST_SRC = false;
+my $seen_NO_PKG_REGISTER= false;
+my $seen_NO_CHECKSUM = false;
+my $seen_USE_PKGLOCALEDIR = false;
+my $seen_USE_BUILDLINK3 = false;
my %predefined;
my $pkgname = "";
@@ -117,16 +145,16 @@ usage: $prog [-qvIN] [-B#] [package_directory]
EOF
exit 0;
}
- if ($opts{"v"}) { $opt_verbose = 1; }
- if ($opts{"N"}) { $opt_newpackage = 1; }
- if ($opts{"I"}) { $opt_dumpmakefile = 1; }
+ if ($opts{"v"}) { $opt_verbose = true; }
+ if ($opts{"N"}) { $opt_newpackage = true; }
+ if ($opts{"I"}) { $opt_dumpmakefile = true; }
if ($opts{"B"}) { $opt_contblank = $opts{"B"}; }
if (scalar(@ARGV)) { $opt_packagedir = shift(@ARGV); }
if ($opts{"V"}) {
print "$conf_distver\n";
exit;
}
- return 1;
+ return true;
}
sub main() {
@@ -232,11 +260,11 @@ EOF
}
{
# Make sure there's a distinfo if there are patches
- my $patches=0;
+ my $patches = false;
patch:
foreach my $i (<$opt_packagedir/$patchdir/patch-*>) {
if ( -T "$i" ) {
- $patches=1;
+ $patches = true;
last patch;
}
}
@@ -303,7 +331,7 @@ EOF
"patch backup files before committing the package.");
}
}
- return 1;
+ return true;
} # check_package
#
@@ -336,7 +364,7 @@ sub checkline_length($$) {
if (length($line->[2]) > $maxlength) {
log_warning($line->[0], $line->[1], "Line too long (should be no more than $maxlength characters).");
}
- return 1;
+ return true;
}
sub checkline_valid_characters($$) {
@@ -349,7 +377,7 @@ sub checkline_valid_characters($$) {
log_warning($line->[0], $line->[1],
sprintf("Line contains invalid characters (%s).", join(", ", @chars)));
}
- return 1;
+ return true;
}
sub checkline_trailing_whitespace($) {
@@ -357,7 +385,7 @@ sub checkline_trailing_whitespace($) {
if ($line =~ /\s+$/) {
log_warning($line->[0], $line->[1], "Trailing white space.");
}
- return 1;
+ return true;
}
#
@@ -372,7 +400,7 @@ sub checkfile_DESCR($) {
checkperms($fname);
if (!defined($descr = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "Error while reading.");
- return 0;
+ return false;
}
foreach my $line (@$descr) {
@@ -385,7 +413,7 @@ sub checkfile_DESCR($) {
log_warning($fname, NO_LINE_NUMBER, "File too long (should be no more than $maxlines lines).");
}
- return 1;
+ return true;
}
sub checkfile_distinfo($) {
@@ -396,12 +424,12 @@ sub checkfile_distinfo($) {
checkperms($fname);
if (!defined($distinfo = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "Error while reading.");
- return 0;
+ return false;
}
if (scalar(@$distinfo) == 0) {
log_error($fname, NO_LINE_NUMBER, "May not be empty.");
- return 0;
+ return false;
}
if ($distinfo->[0]->[2] !~ /^$regex_rcsidstr$/) {
@@ -426,7 +454,7 @@ sub checkfile_distinfo($) {
} else {
log_error($line->[0], $line->[1], "$patch does not exist.");
}
- $in_distinfo{$patch} = 1;
+ $in_distinfo{$patch} = true;
}
}
@@ -436,7 +464,7 @@ sub checkfile_distinfo($) {
log_error($fname, NO_LINE_NUMBER, "$patch is not recorded. Rerun '$conf_make makepatchsum'.");
}
}
- return 1;
+ return true;
}
sub checkfile_MESSAGE($) {
@@ -447,12 +475,12 @@ sub checkfile_MESSAGE($) {
checkperms($fname);
if (!defined($message = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "error while reading.");
- return 0;
+ return false;
}
if (scalar(@$message) < 3) {
log_warning($fname, NO_LINE_NUMBER, "file too short.");
- return 0;
+ return false;
}
if ($message->[0]->[2] ne "=" x 75) {
log_warning($message->[0]->[0], $message->[0]->[1], "expected a line of exactly 75 \"=\" characters.");
@@ -468,7 +496,7 @@ sub checkfile_MESSAGE($) {
if ($message->[-1]->[2] ne "=" x 75) {
log_warning($message->[-1]->[0], $message->[-1]->[1], "expected a line of exactly 75 \"=\" characters.");
}
- return 1;
+ return true;
}
sub checkfile_PLIST($) {
@@ -479,7 +507,7 @@ sub checkfile_PLIST($) {
checkperms($fname);
if (!defined($plist = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "error while reading.");
- return 0;
+ return false;
}
$curdir = $conf_localbase;
@@ -569,7 +597,7 @@ sub checkfile_PLIST($) {
if (!$rcsid_seen) {
log_error($file, NO_LINE_NUMBER, "Expected a \@comment \"\$$conf_rcsidstr\$\" line.");
}
- return 1;
+ return true;
}
sub checkperms($) {
@@ -578,7 +606,7 @@ sub checkperms($) {
if (-f $file && -x $file) {
log_warning($file, NO_LINE_NUMBER, "should not be executable.");
}
- return 1;
+ return true;
}
#
@@ -593,15 +621,15 @@ sub checkpathname($) {
if ($file =~ /$filesdir\//) {
# ignore
- return 1;
+ return true;
}
# FIXME: convert to load_file.
- open(IN, "< $opt_packagedir/$file") || return 0;
+ open(IN, "< $opt_packagedir/$file") || return false;
{ local $/; $whole = <IN>; }
close(IN);
abspathname($whole, $file);
- return 1;
+ return true;
}
sub checklastline($) {
@@ -611,7 +639,7 @@ sub checklastline($) {
if (!open(IN, "< $fname")) {
log_error($fname, NO_LINE_NUMBER, "could not open: $!");
- return 0;
+ return false;
}
{ local $/; $whole = <IN>; }
close(IN);
@@ -623,7 +651,7 @@ sub checklastline($) {
} elsif ($whole =~ /\r*\n(?:[ \t]*\r*\n)+$/) {
log_warning($fname, NO_LINE_NUMBER, "perhaps unnecessary blank lines at end of file.");
}
- return 1;
+ return true;
}
# $lines => an array of lines as returned by load_file().
@@ -668,7 +696,7 @@ sub check_for_multiple_patches($) {
} elsif ($files_in_patch == 0) {
log_warning($lines->[0]->[0], NO_LINE_NUMBER, "contains no patch");
}
- return 1;
+ return true;
}
sub checkfile_patches_patch($) {
@@ -683,13 +711,13 @@ sub checkfile_patches_patch($) {
checkperms($fname);
if (!defined($lines = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "Could not load file.");
- return 0;
+ return false;
}
# The first line should contain the RCS Id string
if (scalar(@$lines) == 0) {
log_error($fname, NO_LINE_NUMBER, "Empty patch file.");
- return 0;
+ return false;
} elsif ($lines->[0]->[2] !~ /^$regex_rcsidstr$/) {
log_error($lines->[0]->[0], $lines->[0]->[1], "Expected RCS tag \"\$$conf_rcsidstr\$\" (and nothing more) here.");
}
@@ -701,7 +729,7 @@ sub checkfile_patches_patch($) {
}
check_for_multiple_patches($lines);
- return 1;
+ return true;
}
sub readmakefile($) {
@@ -712,7 +740,7 @@ sub readmakefile($) {
$savedln = $.;
$. = 0;
- open($handle, "< $file") || return 0;
+ open($handle, "< $file") || return false;
log_info($file, NO_LINE_NUMBER, "called readmakefile");
while (defined(my $line = <$handle>)) {
if ($line =~ /[ \t]+\n?$/ && $line !~ /^#/) {
@@ -746,7 +774,7 @@ sub readmakefile($) {
}
else {
log_info($file, $., "defining $1");
- $definesfound{$1} = 1;
+ $definesfound{$1} = true;
}
}
# try to get any included file
@@ -800,7 +828,7 @@ sub checkfile_Makefile($) {
$rawwhole = readmakefile($fname);
if ($rawwhole eq '') {
log_error(NO_FILE, NO_LINE_NUMBER, "can't read $opt_packagedir/$file");
- return 0;
+ return false;
}
else {
print("OK: whole Makefile (with all included files):\n".
@@ -894,15 +922,15 @@ sub checkfile_Makefile($) {
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking for PLIST_SRC.");
if ($whole =~ /\nPLIST_SRC/) {
- $seen_PLIST_SRC=1;
+ $seen_PLIST_SRC = true;
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking for NO_PKG_REGISTER.");
if ($whole =~ /\nNO_PKG_REGISTER/) {
- $seen_NO_PKG_REGISTER=1;
+ $seen_NO_PKG_REGISTER = true;
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking for NO_CHECKSUM.");
if ($whole =~ /\nNO_CHECKSUM/) {
- $seen_NO_CHECKSUM=1;
+ $seen_NO_CHECKSUM = true;
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_PERL usage.");
if ($whole =~ /\nUSE_PERL[^5]/) {
@@ -915,11 +943,11 @@ sub checkfile_Makefile($) {
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking for USE_BUILDLINK3.");
if ($whole =~ /\nUSE_BUILDLINK3/) {
- $seen_USE_BUILDLINK3=1;
+ $seen_USE_BUILDLINK3 = true;
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking for USE_PKGLOCALEDIR.");
if ($whole =~ /\nUSE_PKGLOCALEDIR/) {
- $seen_USE_PKGLOCALEDIR=1;
+ $seen_USE_PKGLOCALEDIR = true;
}
log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_SSL.");
if ($whole =~ /\nUSE_SSL/) {
@@ -1559,7 +1587,7 @@ EOF
"discouraged. redefine \"do-$1\" instead.");
}
- 1;
+ return true;
}
sub checkextra($$) {
@@ -1690,6 +1718,7 @@ EOF
"found in $file. if so, use $cmdnames{$i}.");
}
}
+ return true;
}
sub is_predefined($) {
@@ -1702,9 +1731,9 @@ sub is_predefined($) {
$subdir =~ s/\/$//;
log_warning(NO_FILE, NO_LINE_NUMBER, "how about using ".
"\${MASTER_SITE_$predefined{$site}:=$subdir/} instead of \"$url\?");
- return 1;
+ return true;
}
- return 0;
+ return false;
}
sub category_check() {
@@ -1716,11 +1745,11 @@ sub category_check() {
if (!defined($lines = load_file($fname))) {
log_error($fname, NO_LINE_NUMBER, "error while reading.");
- return 0;
+ return false;
}
if (scalar(@$lines) == 0) {
log_error($file, NO_LINE_NUMBER, "may not be empty.");
- return 0;
+ return false;
}
if ($lines->[0]->[2] =~ qr"^# $regex_rcsidstr$") {
log_info($lines->[0]->[0], $lines->[0]->[1], "RCS Id tag found.");
@@ -1732,7 +1761,7 @@ sub category_check() {
@filesys_subdirs = grep { ($_ = substr($_, 0, -1)) ne "CVS"; } glob("*/");
- my ($first, $last_subdir, $comment_seen) = (1, undef, 0);
+ my ($first, $last_subdir, $comment_seen) = (true, undef, false);
foreach my $line (@$lines) {
if ($line->[2] =~ qr"^(#?)SUBDIR(.*?)=\s*(\S+)\s*(?:#\s*(.*?)\s*|)$") {
my ($comment_flag, $operator, $subdir, $comment) = ($1, $2, $3, $4);
@@ -1742,7 +1771,7 @@ sub category_check() {
}
push(@makefile_subdirs, $subdir);
} elsif ($first) {
- $first = 0;
+ $first = false;
if ($operator ne "" && $operator ne "+") {
log_error($line->[0], $line->[1], "SUBDIR= or SUBDIR+= expected.");
}
@@ -1760,7 +1789,7 @@ sub category_check() {
}
} elsif ($line->[2] =~ qr"^COMMENT\s*=\s*([^#]*?)") {
my ($comment) = ($1);
- $comment_seen = 1;
+ $comment_seen = true;
}
}
@@ -1783,7 +1812,7 @@ sub category_check() {
if (!$comment_seen) {
log_error($file, NO_LINE_NUMBER, "no COMMENT line found.");
}
- return 1;
+ return true;
}
#