summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--doc/CHANGES3
-rw-r--r--pkgtools/pkglint/Makefile4
-rw-r--r--pkgtools/pkglint/files/pkglint.pl1018
3 files changed, 533 insertions, 492 deletions
diff --git a/doc/CHANGES b/doc/CHANGES
index 5f86af4beb1..dbd28e53857 100644
--- a/doc/CHANGES
+++ b/doc/CHANGES
@@ -1,4 +1,4 @@
-$NetBSD: CHANGES,v 1.6332 2004/06/26 18:49:53 grant Exp $
+$NetBSD: CHANGES,v 1.6333 2004/06/26 18:53:17 hubertf Exp $
Changes to the packages collection and infrastructure in 2004:
@@ -3084,3 +3084,4 @@ Changes to the packages collection and infrastructure in 2004:
Updated mplayer to 1.0pre4nb1 [grant 2004-06-26]
Updated gmplayer to 1.0pre4nb1 [grant 2004-06-26]
Updated mencoder to 1.0pre4nb1 [grant 2004-06-26]
+ Updated pkglint to 3.79 [hubertf 2004-06-26]
diff --git a/pkgtools/pkglint/Makefile b/pkgtools/pkglint/Makefile
index 13ccee911da..1a90842fe61 100644
--- a/pkgtools/pkglint/Makefile
+++ b/pkgtools/pkglint/Makefile
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.191 2004/06/25 19:03:26 hubertf Exp $
+# $NetBSD: Makefile,v 1.192 2004/06/26 18:53:17 hubertf Exp $
#
-DISTNAME= pkglint-3.78
+DISTNAME= pkglint-3.79
CATEGORIES= pkgtools devel
MASTER_SITES= # empty
DISTFILES= # empty
diff --git a/pkgtools/pkglint/files/pkglint.pl b/pkgtools/pkglint/files/pkglint.pl
index 6d0fa731dd3..932ad4f2022 100644
--- a/pkgtools/pkglint/files/pkglint.pl
+++ b/pkgtools/pkglint/files/pkglint.pl
@@ -11,12 +11,12 @@
# 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.107 2004/06/25 19:03:26 hubertf Exp $
+# $NetBSD: pkglint.pl,v 1.108 2004/06/26 18:53:17 hubertf Exp $
#
# This version contains lots of changes necessary for NetBSD packages
# done by Hubert Feyrer <hubertf@netbsd.org>,
-# Thorsten Frueauf <frueauf@netbsd.org>, Thomas Klausner <wiz@netbsd.org>
-# and others.
+# Thorsten Frueauf <frueauf@netbsd.org>, Thomas Klausner <wiz@netbsd.org>,
+# Roland Illig <roland.illig@gmx.de> and others.
#
use Getopt::Std;
@@ -24,73 +24,110 @@ use File::Basename;
use FileHandle;
use Cwd;
-$err = $warn = 0;
-$extrafile = $parenwarn = $committer = 1; # -abc
-$verbose = $newpkg = 0; # -vN
-$showmakefile = 0; # -I
-$contblank = 1;
-$portdir = '.';
-%definesfound = ();
-
-# default settings for NetBSD
-$portsdir = '@PORTSDIR@';
-$rcsidstr = 'NetBSD';
-$localbase = '@PREFIX@';
-
-%opts = ();
-getopts('hINB:qvV', \%opts);
-
-if ($opts{"h"}) {
- ($prog) = ($0 =~ /([^\/]+)$/);
+# Start of configuration area
+my $conf_rcsidstr = 'NetBSD';
+my $conf_portsdir = '@PORTSDIR@';
+my $conf_localbase = '@PREFIX@';
+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 = "."; #
+
+# Global variables that should be eliminated by the next refactoring.
+my %definesfound = ();
+my $errors = 0; # number of errors
+my $warnings = 0; # number of warnings
+
+# == Output of messages to the user ==
+# The log_* routines take the parameters ($file, $lineno, $msg).
+# $file is the file where the message originated or NO_FILE.
+# $lineno is the line number if applicable or NO_LINE_NUMBER.
+# $msg is the text of the message.
+sub NO_FILE();
+sub NO_LINE_NUMBER();
+sub log_error($$$);
+sub log_warning($$$);
+sub log_info($$$);
+sub print_summary_and_exit();
+
+sub checkfile_DESCR($);
+sub checkfile_distinfo($);
+sub checkfile_Makefile($);
+sub checkfile_MESSAGE($);
+sub checkfile_patches_patch($);
+sub checkfile_PLIST($);
+
+sub print_summary_and_exit();
+sub checkperms($);
+sub checkpathname($);
+sub checklastline($);
+sub readmakefile($);
+sub checkextra($$);
+sub checkorder($$@);
+sub checkearlier($@);
+sub abspathname($$);
+sub is_predefined($);
+sub category_check();
+
+sub parse_command_line() {
+ my %opts = ();
+ getopts('hINB:qvV', \%opts);
+ if ($opts{"h"}) {
+ my $prog = basename($0);
print STDERR <<EOF;
usage: $prog [-qvIN] [-B#] [package_directory]
- -q quiet
-v verbose mode
- -V version (@DISTVER@)
+ -V version ($conf_distver)
-I show Makefile (with all included files)
-N writing a new package
- -B# allow # contiguous blank lines (default: $contblank line)
+ -B# allow # contiguous blank lines (default: $opt_contblank line)
EOF
exit 0;
-};
-$quiet = 1 if $opts{"q"};
-$verbose = 1 if $opts{"v"};
-$newpkg = 1 if $opts{"N"};
-$showmakefile = 1 if $opts{"I"};
-$contblank = $opts{"B"} if $opts{"B"};
-
-$portdir = shift || ".";
-
-if ($opts{"V"}) {
- print "@DISTVER@\n";
- exit;
+ }
+ if ($opts{"v"}) { $opt_verbose = 1; }
+ if ($opts{"N"}) { $opt_newpackage = 1; }
+ if ($opts{"I"}) { $opt_dumpmakefile = 1; }
+ if ($opts{"B"}) { $opt_contblank = $opts{"B"}; }
+ if (scalar(@ARGV)) { $opt_packagedir = shift(@ARGV); }
+ if ($opts{"V"}) {
+ print "$conf_distver\n";
+ exit;
+ }
}
+parse_command_line();
-if ($verbose) {
- print "OK: config: portsdir: \"$portsdir\" ".
- "rcsidstr: \"$rcsidstr\" ".
- "localbase: $localbase\n";
-}
+log_info(NO_FILE, NO_LINE_NUMBER, "config: portsdir: \"$conf_portsdir\" ".
+ "rcsidstr: \"$conf_rcsidstr\" ".
+ "localbase: $conf_localbase");
#
# just for safety.
#
-if (! -d $portdir) {
- print STDERR "FATAL: invalid directory $portdir specified.\n";
+if (! -d $opt_packagedir) {
+ print STDERR "FATAL: invalid directory $opt_packagedir specified.\n";
exit 1;
}
-if (-e <$portdir/../Packages.txt>) {
- print "OK: checking category Makefile.\n" if ($verbose);
- &category_check;
- exit 0;
+if (-e <$opt_packagedir/../Packages.txt>) {
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking category Makefile.");
+ category_check();
+ print_summary_and_exit();
}
-if (-e <$portdir/../../Packages.txt>) {
- if ($portdir eq ".") {
+if (-e <$opt_packagedir/../../Packages.txt>) {
+ if ($opt_packagedir eq ".") {
$category = basename(dirname(cwd()));
} else {
- $category = basename(dirname($portdir));
+ $category = basename(dirname($opt_packagedir));
}
}
@@ -136,11 +173,11 @@ EOF
}
# we need to handle the Makefile first to get some variables
-print "OK: checking Makefile.\n" unless $quiet;
-if (! -f "$portdir/Makefile") {
- &perror("FATAL: no Makefile in \"$portdir\".");
+log_info(NO_FILE, NO_LINE_NUMBER, "checking Makefile.");
+if (! -f "$opt_packagedir/Makefile") {
+ log_error(NO_FILE, NO_LINE_NUMBER, "no Makefile in \"$opt_packagedir\".");
} else {
- checkmakefile("Makefile") || &perror("Cannot open the file $i\n");
+ checkfile_Makefile("Makefile") || log_error(NO_FILE, NO_LINE_NUMBER, "Cannot open the file $i\n");
}
@@ -148,474 +185,457 @@ if (! -f "$portdir/Makefile") {
# check for files.
#
@checker = ("$pkgdir/DESCR");
-%checker = ("$pkgdir/DESCR", 'checkdescr');
+%checker = ("$pkgdir/DESCR", \&checkfile_DESCR);
-if ($extrafile) {
- foreach $i ((<$portdir/$filesdir/*>, <$portdir/$pkgdir/*>)) {
+if ($opt_extrafile) {
+ foreach $i ((<$opt_packagedir/$filesdir/*>, <$opt_packagedir/$pkgdir/*>)) {
next if (! -T $i);
next if ($i =~ /distinfo$/);
next if ($i =~ /Makefile$/);
- $i =~ s/^\Q$portdir\E\///;
+ $i =~ s/^\Q$opt_packagedir\E\///;
next if (defined $checker{$i});
if ($i =~ /MESSAGE/) {
unshift(@checker, $i);
- $checker{$i} = 'checkmessage';
+ $checker{$i} = \&checkfile_MESSAGE;
} elsif ($i =~ /PLIST/) {
unshift(@checker, $i);
- $checker{$i} = 'checkplist';
+ $checker{$i} = \&checkfile_PLIST;
} else {
push(@checker, $i);
- $checker{$i} = 'checkpathname';
+ $checker{$i} = \&checkpathname;
}
}
}
-foreach $i (<$portdir/$patchdir/patch-*>) {
+foreach $i (<$opt_packagedir/$patchdir/patch-*>) {
next if (! -T $i);
- $i =~ s/^\Q$portdir\E\///;
+ $i =~ s/^\Q$opt_packagedir\E\///;
next if (defined $checker{$i});
push(@checker, $i);
- $checker{$i} = 'checkpatch';
+ $checker{$i} = \&checkfile_patches_patch;
}
-if (-e <$portdir/$distinfo>) {
+if (-e <$opt_packagedir/$distinfo>) {
$i = "$distinfo";
next if (defined $checker{$i});
push(@checker, $i);
- $checker{$i} = 'checkdistinfo';
+ $checker{$i} = \&checkfile_distinfo;
}
{
# Make sure there's a distinfo if there are patches
$patches=0;
patch:
- foreach $i (<$portdir/$patchdir/patch-*>) {
+ foreach $i (<$opt_packagedir/$patchdir/patch-*>) {
if ( -T "$i" ) {
$patches=1;
last patch;
}
}
- if ($patches && ! -f "$portdir/$distinfo" ) {
- &perror("WARN: no $portdir/$distinfo file. Please run '@MAKE@ makepatchsum'.");
+ if ($patches && ! -f "$opt_packagedir/$distinfo" ) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no $opt_packagedir/$distinfo file. Please run '$conf_make makepatchsum'.");
}
}
foreach $i (@checker) {
- print "OK: checking $i.\n" unless $quiet;
- if (! -f "$portdir/$i") {
- &perror("FATAL: no $i in \"$portdir\".");
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking $i.");
+ if (! -f "$opt_packagedir/$i") {
+ log_error(NO_FILE, NO_LINE_NUMBER, "no $i in \"$opt_packagedir\".");
} else {
- $proc = $checker{$i};
- &$proc($i) || &perror("WARN: Cannot open the file $i\n");
+ $checker{$i}->($i) || log_warning(NO_FILE, NO_LINE_NUMBER, "Cannot open the file $i\n");
if ($i !~ /patches\/patch/) {
&checklastline($i) ||
- &perror("WARN: Cannot open the file $i\n");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "Cannot open the file $i\n");
}
}
}
-if (-e <$portdir/$distinfo> ) {
+if (-e <$opt_packagedir/$distinfo> ) {
if ( $seen_NO_CHECKSUM ) {
- &perror("WARN: NO_CHECKSUM set, but $portdir/$distinfo exists. Please remove it.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "NO_CHECKSUM set, but $opt_packagedir/$distinfo exists. Please remove it.");
}
} else {
if ( ! $seen_NO_CHECKSUM ) {
- &perror("WARN: no $portdir/$distinfo file. Please run '@MAKE@ makesum'.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no $opt_packagedir/$distinfo file. Please run '$conf_make makesum'.");
}
}
-if (-e <$portdir/$filesdir/md5> ) {
- &perror("FATAL: $filesdir/md5 is deprecated -- run '@MAKE@ mdi' to generate distinfo.");
+if (-e <$opt_packagedir/$filesdir/md5> ) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "$filesdir/md5 is deprecated -- run '$conf_make mdi' to generate distinfo.");
}
-if (-e <$portdir/$filesdir/patch-sum> ) {
- &perror("FATAL: $filesdir/patch-sum is deprecated -- run '@MAKE@ mps' to generate distinfo.");
+if (-e <$opt_packagedir/$filesdir/patch-sum> ) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "$filesdir/patch-sum is deprecated -- run '$conf_make mps' to generate distinfo.");
}
if (-e <$pkgdir/COMMENT> ) {
- &perror("FATAL: $pkgdir/COMMENT is deprecated -- please use a COMMENT variable instead.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "$pkgdir/COMMENT is deprecated -- please use a COMMENT variable instead.");
}
-if (-d "$portdir/pkg" ) {
- &perror("FATAL: $portdir/pkg and its contents are deprecated!\n".
- "\tPlease 'mv $portdir/pkg/* $portdir' and 'rmdir $portdir/pkg'.");
+if (-d "$opt_packagedir/pkg" ) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "$opt_packagedir/pkg and its contents are deprecated!\n".
+ "\tPlease 'mv $opt_packagedir/pkg/* $opt_packagedir' and 'rmdir $opt_packagedir/pkg'.");
}
-if (-d "$portdir/scripts" ) {
- &perror("WARN: $portdir/scripts and its contents are deprecated! Please call the script(s)\n".
+if (-d "$opt_packagedir/scripts" ) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$opt_packagedir/scripts and its contents are deprecated! Please call the script(s)\n".
"\texplicitly from the corresponding target(s) in the pkg's Makefile.");
}
-if (! -f "$portdir/$pkgdir/PLIST"
- and ! -f "$portdir/$pkgdir/PLIST-mi"
+if (! -f "$opt_packagedir/$pkgdir/PLIST"
+ and ! -f "$opt_packagedir/$pkgdir/PLIST-mi"
and ! $seen_PLIST_SRC
and ! $seen_NO_PKG_REGISTER ) {
- &perror("WARN: no PLIST or PLIST-mi, and PLIST_SRC and NO_PKG_REGISTER unset.\n Are you sure PLIST handling is ok?");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no PLIST or PLIST-mi, and PLIST_SRC and NO_PKG_REGISTER unset.\n Are you sure PLIST handling is ok?");
}
-if ($committer) {
- if (scalar(@_ = <$portdir/work*/*>) || -d "$portdir/work*") {
- &perror("WARN: be sure to cleanup $portdir/work* ".
+if ($opt_committer) {
+ if (scalar(@_ = <$opt_packagedir/work*/*>) || -d "$opt_packagedir/work*") {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "be sure to cleanup $opt_packagedir/work* ".
"before committing the package.");
}
- if (scalar(@_ = <$portdir/*/*~>) || scalar(@_ = <$portdir/*~>)) {
- &perror("WARN: for safety, be sure to cleanup ".
+ if (scalar(@_ = <$opt_packagedir/*/*~>) || scalar(@_ = <$opt_packagedir/*~>)) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "for safety, be sure to cleanup ".
"emacs backup files before committing the package.");
}
- if (scalar(@_ = <$portdir/*/*.orig>) || scalar(@_ = <$portdir/*.orig>)
- || scalar(@_ = <$portdir/*/*.rej>) || scalar(@_ = <$portdir/*.rej>)) {
- &perror("WARN: for safety, be sure to cleanup ".
+ if (scalar(@_ = <$opt_packagedir/*/*.orig>) || scalar(@_ = <$opt_packagedir/*.orig>)
+ || scalar(@_ = <$opt_packagedir/*/*.rej>) || scalar(@_ = <$opt_packagedir/*.rej>)) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "for safety, be sure to cleanup ".
"patch backup files before committing the package.");
}
}
-if ($err || $warn) {
- print "$err fatal errors and $warn warnings found.\n"
-} else {
- print "looks fine.\n";
-}
-exit $err;
+print_summary_and_exit();
-#
-# DESCR
-#
-sub checkdescr {
+sub checkfile_DESCR($) {
local($file) = @_;
local(%maxchars) = ('DESCR', 80);
local(%maxlines) = ('DESCR', 24);
local(%errmsg) = ('DESCR', "exceeds $maxlines{'DESCR'} ".
"lines, make it shorter if possible");
local($longlines, $linecnt, $tmp) = (0, 0, "");
+ my ($line);
- &checkperms("$portdir/$file");
+ &checkperms("$opt_packagedir/$file");
$shortname = basename($file);
- open(IN, "< $portdir/$file") || return 0;
+ open(IN, "< $opt_packagedir/$file") || return 0;
- while (<IN>) {
+ while (defined($line = <IN>)) {
$linecnt++;
- $longlines++ if ($maxchars{$shortname} < length($_));
- $tmp .= $_;
+ $longlines++ if ($maxchars{$shortname} < length($line));
+ $tmp .= $line;
}
+ close(IN);
+
if ($linecnt > $maxlines{$shortname}) {
- &perror("WARN: $file $errmsg{$shortname} ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $errmsg{$shortname} ".
"(currently $linecnt lines).");
} else {
- print "OK: $file has $linecnt lines.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "$file has $linecnt lines.");
}
if ($longlines > 0) {
- &perror("WARN: $file includes lines that exceed ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file includes lines that exceed ".
"$maxchars{$shortname} characters.");
}
if ($tmp =~ /[\033\200-\377]/) {
- &perror("WARN: $file includes iso-8859-1, or ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file includes iso-8859-1, or ".
"other local characters. $file should be ".
"plain ascii file.");
}
- close(IN);
+ return 1;
}
-#
-# distinfo
-#
-sub checkdistinfo {
+sub checkfile_distinfo($) {
local($file) = @_; # distinfo
local(%indistinfofile);
+ my $line;
- &checkperms("$portdir/$file");
+ checkperms("$opt_packagedir/$file");
- open(SUM,"<$portdir/$file") || return 0;
- $_ = <SUM>;
- if (! /^\$NetBSD(:.*|)\$$/) {
- &perror("FATAL: missing RCS Id in distinfo file: $_");
+ open(SUM,"<$opt_packagedir/$file") || return 0;
+ $line = <SUM>;
+ if ($line !~ /^\$NetBSD(:.*|)\$$/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "missing RCS Id in distinfo file: $_");
}
- while(<SUM>) {
- next if !/^(MD5|SHA1|RMD160) \(([^)]+)\) = (.*)$/;
+ while(defined($line = <SUM>)) {
+ next unless $line =~ /^(MD5|SHA1|RMD160) \(([^)]+)\) = (.*)$/;
$alg=$1;
$patch=$2;
$sum=$3;
# bitch about *~
if ($patch =~ /~$/) {
- &perror("WARN: possible backup file '$patch' in $portdir/$file?");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible backup file '$patch' in $opt_packagedir/$file?");
}
- if (-T "$portdir/$patchdir/$patch") {
- $calcsum=`sed -e '/\$NetBSD.*/d' $portdir/$patchdir/$patch | digest $alg`;
+ if (-T "$opt_packagedir/$patchdir/$patch") {
+ $calcsum=`sed -e '/\$NetBSD.*/d' $opt_packagedir/$patchdir/$patch | digest $alg`;
chomp($calcsum);
if ( "$sum" ne "$calcsum" ) {
- &perror("FATAL: checksum of $patch differs between $portdir/$file and\n"
- ." $portdir/$patchdir/$patch. Rerun '@MAKE@ makepatchsum'.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "checksum of $patch differs between $opt_packagedir/$file and\n"
+ ." $opt_packagedir/$patchdir/$patch. Rerun '$conf_make makepatchsum'.");
}
} elsif ($patch =~ /^patch-[a-z0-9]+$/) {
- &perror("FATAL: patchfile '$patch' is in $file\n"
- ." but not in $portdir/$patchdir/$patch. Rerun '@MAKE@ makepatchsum'.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "patchfile '$patch' is in $file\n"
+ ." but not in $opt_packagedir/$patchdir/$patch. Rerun '$conf_make makepatchsum'.");
}
$indistinfofile{$patch} = 1;
}
close(SUM);
- foreach $patch ( <$portdir/$patchdir/patch-*> ) {
+ foreach $patch ( <$opt_packagedir/$patchdir/patch-*> ) {
$patch =~ /\/([^\/]+)$/;
if (! $indistinfofile{$1}) {
- &perror("FATAL: patchsum of '$1' is in $portdir/$patchdir/$1 but not in\n"
- ." $file. Rerun '@MAKE@ makepatchsum'.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "patchsum of '$1' is in $opt_packagedir/$patchdir/$1 but not in\n"
+ ." $file. Rerun '$conf_make makepatchsum'.");
}
}
return 1;
}
-#
-# MESSAGE
-#
-sub checkmessage {
+sub checkfile_MESSAGE($) {
local($file) = @_;
local($longlines, $lastline, $tmp) = (0, "", "");
+ my ($line);
- &checkperms("$portdir/$file");
+ &checkperms("$opt_packagedir/$file");
$shortname = basename($file);
- open(IN, "< $portdir/$file") || return 0;
+ open(IN, "< $opt_packagedir/$file") || return 0;
- $_ = <IN>;
- if (! /^={75}$/) {
- &perror("WARN: $file should begin with a 75-character ".
+ $line = <IN>;
+ if ($line !~ /^={75}$/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file should begin with a 75-character ".
"double-dashed line.");
}
- $_ = <IN>;
- if (! /^\$NetBSD(:.*|)\$$/) {
- &perror("FATAL: missing RCS Id in MESSAGE file: $file");
+ $line = <IN>;
+ if ($line !~ /^\$NetBSD(:.*|)\$$/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "missing RCS Id in MESSAGE file: $file");
}
- while (<IN>) {
- $longlines++ if (80 < length($_));
- $lastline = $_;
- $tmp .= $_;
+ while (defined($line = <IN>)) {
+ $longlines++ if (80 < length($line));
+ $lastline = $line;
+ $tmp .= $line;
}
if ($lastline !~ /^={75}$/) {
- &perror("WARN: $file should end with a 75-character ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file should end with a 75-character ".
"double-dashed line.");
}
if ($longlines > 0) {
- &perror("WARN: $file includes lines that exceed ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file includes lines that exceed ".
"80 characters.");
}
if ($tmp =~ /[\033\200-\377]/) {
- &perror("WARN: $file includes iso-8859-1, or ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file includes iso-8859-1, or ".
"other local characters. $file should be ".
"plain ascii file.");
}
close(IN);
+ return 1;
}
-#
-# PLIST
-#
-sub checkplist {
+sub checkfile_PLIST($) {
local($file) = @_;
- local($curdir) = ($localbase);
+ local($curdir) = ($conf_localbase);
local($installinfoseen) = 0;
local($rcsidseen) = 0;
local($docseen) = 0;
local($etcseen) = 0;
+ my ($line);
- &checkperms("$portdir/$file");
+ &checkperms("$opt_packagedir/$file");
- open(IN, "< $portdir/$file") || return 0;
- while (<IN>) {
- if ($_ =~ /[ \t]+\n?$/) {
- &perror("WARN: $file $.: whitespace before end ".
+ open(IN, "< $opt_packagedir/$file") || return 0;
+ while (defined($line = <IN>)) {
+ if ($line =~ /[ \t]+\n?$/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: whitespace before end ".
"of line.");
}
# make it easier to handle.
- $_ =~ s/\s+$//;
-
- $_ =~ s/\n$//;
+ $line =~ s/\s+$//;
+ $line =~ s/\n$//;
- if ($_ =~ /<\$ARCH>/) {
- &perror("WARN: $file $.: use of <\$ARCH> ".
+ if ($line =~ /<\$ARCH>/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: use of <\$ARCH> ".
"deprecated, use \${MACHINE_ARCH instead}.");
}
- if ($_ =~ /^\@/) {
- if ($_ =~ /^\@(cwd|cd)[ \t]+(\S+)/) {
+ if ($line =~ /^\@/) {
+ if ($line =~ /^\@(cwd|cd)[ \t]+(\S+)/) {
$curdir = $2;
- } elsif ($_ =~ /^\@unexec[ \t]+rmdir/) {
- &perror("WARN: use \"\@dirrm\" ".
+ } elsif ($line =~ /^\@unexec[ \t]+rmdir/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use \"\@dirrm\" ".
"instead of \"\@unexec rmdir\".");
- } elsif ($_ =~ /^\@(un)?exec[ \t]+(.*\/)?(install-info|\$\{INSTALL_INFO\})/) {
+ } elsif ($line =~ /^\@(un)?exec[ \t]+(.*\/)?(install-info|\$\{INSTALL_INFO\})/) {
$installinfoseen = $.
- } elsif ($_ =~ /^\@(exec|unexec)/) {
- if (/ldconfig/
- && !/\/usr\/bin\/true/) {
- &perror("FATAL: $file $.: ldconfig ".
+ } elsif ($line =~ /^\@(exec|unexec)/) {
+ if ($line =~ /ldconfig/ && $line !~ /\/usr\/bin\/true/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "$file $.: ldconfig ".
"must be used with ".
"\"||/usr/bin/true\".");
}
- } elsif ($_ =~ /^\@(comment)/) {
- $rcsidseen++ if (/\$$rcsidstr[:\$]/);
- } elsif ($_ =~ /^\@(dirrm|option)/) {
+ } elsif ($line =~ /^\@(comment)/) {
+ $rcsidseen++ if ($line =~ /\$$conf_rcsidstr[:\$]/);
+ } elsif ($line =~ /^\@(dirrm|option)/) {
; # no check made
- } elsif ($_ =~ /^\@(mode|owner|group)/) {
- &perror("WARN: \"\@mode/owner/group\" are ".
+ } elsif ($line =~ /^\@(mode|owner|group)/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\"\@mode/owner/group\" are ".
"deprecated, please use chmod/".
"chown/chgrp in the pkg Makefile ".
"and let tar do the rest.");
} else {
- &perror("WARN: $file $.: ".
- "unknown PLIST directive \"$_\"");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: ".
+ "unknown PLIST directive \"$line\"");
}
next;
}
- if ($_ =~ /^\//) {
- &perror("FATAL: $file $.: use of full pathname ".
+ if ($line =~ /^\//) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "$file $.: use of full pathname ".
"disallowed.");
}
- if ($_ =~ /^doc/ and !$docseen) {
- &perror("FATAL: documentation must be installed under ".
+ if ($line =~ /^doc/ and !$docseen) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "documentation must be installed under ".
"share/doc, not doc.");
$docseen = 1;
}
- if ($_ =~ /^etc/ && $_ !~ /^etc\/rc.d/ and !$etcseen) {
- &perror("FATAL: configuration files must not be ".
+ if ($line =~ /^etc/ && $line !~ /^etc\/rc.d/ and !$etcseen) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "configuration files must not be ".
"registered in the PLIST (don't you use the ".
"PKG_SYSCONFDIR framework?)");
$etcseen = 1;
}
- if ($_ =~ /etc\/rc\.d/ and !$etcrcdseen) {
- &perror("FATAL: RCD_SCRIPTS must not be ".
+ if ($line =~ /etc\/rc\.d/ and !$etcrcdseen) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "RCD_SCRIPTS must not be ".
"registered in the PLIST (don't you use the ".
"RCD_SCRIPTS framework?)");
$etcrcdseen = 1;
}
- if ($_ =~ /^info\/dir$/) {
- &perror("FATAL: \"info/dir\" should not be listed in ".
+ if ($line =~ /^info\/dir$/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "\"info/dir\" should not be listed in ".
"$file. use install-info to add/remove ".
"an entry.");
}
- if ($_ =~ /^lib\/locale/) {
- &perror("FATAL: \"lib/locale\" should not be listed ".
+ if ($line =~ /^lib\/locale/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "\"lib/locale\" should not be listed ".
"in $file. Use \${PKGLOCALEDIR}/locale and ".
"set USE_PKGLOCALEDIR instead.");
}
- if ($_ =~ /^share\/locale/) {
- &perror("WARN: use of \"share/locale\" in $file is ".
+ if ($line =~ /^share\/locale/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of \"share/locale\" in $file is ".
"deprecated. Use \${PKGLOCALEDIR}/locale and ".
"set USE_PKGLOCALEDIR instead.");
}
- if ($_ =~ /\${PKGLOCALEDIR}/ && $seen_USE_BUILDLINK2 && ! $seen_USE_PKGLOCALEDIR) {
- &perror("WARN: PLIST contains \${PKGLOCALEDIR}, ".
+ if ($line =~ /\${PKGLOCALEDIR}/ && $seen_USE_BUILDLINK2 && ! $seen_USE_PKGLOCALEDIR) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "PLIST contains \${PKGLOCALEDIR}, ".
"but USE_PKGLOCALEDIR was not found.");
}
- if ($curdir !~ m#^$localbase#
+ if ($curdir !~ m#^$conf_localbase#
&& $curdir !~ m#^/usr/X11R6#) {
- &perror("WARN: $file $.: installing to ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: installing to ".
"directory $curdir discouraged. ".
"could you please avoid it?");
}
- if ("$curdir/$_" =~ m#^$localbase/share/doc#) {
- print "OK: seen installation to share/doc in $file. ".
- "($curdir/$_)\n" if ($verbose);
+ if ("$curdir/$line" =~ m#^$conf_localbase/share/doc#) {
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen installation to share/doc in $file. ".
+ "($curdir/$line)");
$sharedocused++;
}
}
if (!$rcsidseen) {
- &perror("FATAL: RCS tag \"\$$rcsidstr\$\" must be present ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "RCS tag \"\$$conf_rcsidstr\$\" must be present ".
"in $file as \@comment.")
}
if ($installinfoseen) {
- &perror("FATAL: \"\@exec install-info ...\" or \"\@unexec ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "\"\@exec install-info ...\" or \"\@unexec ".
"install-info ...\" is deprecated.");
}
close(IN);
return 1;
}
-sub checkperms {
+sub checkperms($) {
local($file) = @_;
if (-f $file && -x $file) {
- &perror("WARN: \"$file\" is executable.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\"$file\" is executable.");
}
+ return 1;
}
#
# misc files
#
-sub checkpathname {
+sub checkpathname($) {
local($file) = @_;
local($whole);
- &checkperms("$portdir/$file");
+ checkperms("$opt_packagedir/$file");
if ($file =~ /$filesdir\//) {
return 1;
}
- open(IN, "< $portdir/$file") || return 0;
- $whole = '';
- while (<IN>) {
- $whole .= $_;
- }
- &abspathname($whole, $file);
+ open(IN, "< $opt_packagedir/$file") || return 0;
+ { local $/; $whole = <IN>; }
close(IN);
+ abspathname($whole, $file);
+ return 1;
}
-sub checklastline {
+sub checklastline($) {
local($file) = @_;
local($whole);
- open(IN, "< $portdir/$file") || return 0;
- $whole = '';
- while (<IN>) {
- $whole .= $_;
- }
+ open(IN, "< $opt_packagedir/$file") || return 0;
+ { local $/; $whole = <IN>; }
+ close(IN);
if ($whole eq "") {
- &perror("FATAL: $file is empty.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "$file is empty.");
}
else
{
if ($whole !~ /\n$/) {
- &perror("FATAL: the last line of $file has to be ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "the last line of $file has to be ".
"terminated by \\n.");
}
if ($whole =~ /\n([ \t]*\n)+$/) {
- &perror("WARN: $file seems to have unnecessary ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file seems to have unnecessary ".
"blank lines at the bottom.");
}
}
-
- close(IN);
+ return 1;
}
-sub checkpatch {
+sub checkfile_patches_patch($) {
my ($file) = @_;
- my ($rcsidseen, $whole, @lines);
+ my ($rcsidseen, $whole, @lines, $line);
$rcsidseen = 0;
if ($file =~ /.*~$/) {
- &perror("WARN: is $file a backup file? If so, please remove it \n"
- ." and rerun '@MAKE@ makepatchsum'");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "is $file a backup file? If so, please remove it \n"
+ ." and rerun '$conf_make makepatchsum'");
}
- &checkperms("$portdir/$file");
+ &checkperms("$opt_packagedir/$file");
- open(IN, "< $portdir/$file") || return 0;
+ open(IN, "< $opt_packagedir/$file") || return 0;
$whole = '';
- while (<IN>) {
- $rcsidseen++ if /\$$rcsidstr[:\$]/;
- $whole .= $_;
- push(@lines, $_);
+ while (defined($line = <IN>)) {
+ $rcsidseen++ if ($line =~ /\$$conf_rcsidstr[:\$]/);
+ $whole .= $line;
+ push(@lines, $line);
}
- if ($committer && $whole =~ /.\$(Author|Date|Header|Id|Locker|Log|Name|RCSfile|Revision|Source|State|NetBSD)(:.*\$|\$)/) { # XXX
+ if ($opt_committer && $whole =~ /.\$(Author|Date|Header|Id|Locker|Log|Name|RCSfile|Revision|Source|State|NetBSD)(:.*\$|\$)/) { # XXX
# RCS ID in very first line is ok, to identify version
# of patch (-> only warn if there's something before the
# actual $RCS_ID$, not on BOF - '.' won't match there)
- &perror("WARN: $file includes possible RCS tag \"\$$1\$\". ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file includes possible RCS tag \"\$$1\$\". ".
"use binary mode (-ko) on commit/import.");
}
if (!$rcsidseen) {
- &perror("FATAL: RCS tag \"\$$rcsidstr\$\" must be present ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "RCS tag \"\$$conf_rcsidstr\$\" must be present ".
"in patch $file.")
}
close(IN);
@@ -638,14 +658,14 @@ sub checkpatch {
$files_in_patch++;
$patch_state = "";
} else {
- &perror("WARN: $i:$.: unknown patch format (might be an internal error)");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$i:$.: unknown patch format (might be an internal error)");
}
} elsif ($patch_state eq "-") {
if ($line_type eq "+") {
$files_in_patch++;
$patch_state = "";
} else {
- &perror("WARN: $i:$.: unknown patch format (might be an internal error)");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$i:$.: unknown patch format (might be an internal error)");
}
} elsif ($patch_state eq "") {
$patch_state = $line_type;
@@ -653,46 +673,46 @@ sub checkpatch {
#printf("%s:%d: state=(%s), line=(%s)\n", $i, $., $patch_state, $line_type);
}
if ($files_in_patch > 1) {
- &perror("WARN: patch `$i' contains patches for more than one file, namely $files_in_patch");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "patch `$i' contains patches for more than one file, namely $files_in_patch");
} elsif ($files_in_patch == 0) {
- &perror("WARN: patch `$i' contains no patch");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "patch `$i' contains no patch");
}
return 1;
}
-sub readmakefile {
+sub readmakefile($) {
local ($file) = @_;
local $contents = "";
local $includefile;
local $dirname;
local $savedln;
local $level;
- local $_;
my $handle = new FileHandle;
+ my $line;
$savedln = $.;
$. = 0;
open($handle, "< $file") || return 0;
- print("OK: reading Makefile '$file'\n") if ($verbose);
- while (<$handle>) {
- if ($_ =~ /[ \t]+\n?$/ && !/^#/) {
- &perror("WARN: $file $.: whitespace before ".
+ log_info($file, NO_LINE_NUMBER, "called readmakefile");
+ while (defined($line = <$handle>)) {
+ if ($line =~ /[ \t]+\n?$/ && $line !~ /^#/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: whitespace before ".
"end of line.");
}
- if ($_ =~ /^ /) { # 8 spaces here!
- &perror("WARN: $file $.: use tab (not spaces) to".
+ if ($line =~ /^\040{8}/) {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$file $.: use tab (not spaces) to".
" make indentation.");
}
- if ($_ =~ /^\.\s*if\s+!defined\s*\((\w+)\)/) {
+ if ($line =~ /^\.\s*if\s+!defined\s*\((\w+)\)/) {
if ($definesfound{$1}) {
$level = 1;
- print("OK: omitting contents of !defined($1)\n") if ($verbose);
+ log_info($file, $., "omitting contents of !defined($1)\n");
$contents .= "# omitted inclusion for !defined($1) here\n";
- while (<$handle>) {
- if ($_ =~ /^\.\s*if\s+/) {
+ while (defined($line = <$handle>)) {
+ if ($line =~ /^\.\s*if\s+/) {
$level++;
}
- elsif ($_ =~ /^\.\s*endif\s+/) {
+ elsif ($line =~ /^\.\s*endif\s+/) {
$level--;
}
if ($level eq 0) {
@@ -700,42 +720,42 @@ sub readmakefile {
}
}
if ($level > 0) {
- &perror("WARN: missing .endif.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "missing .endif.");
}
next;
}
else {
- print("OK: defining $1\n") if $verbose;
+ log_info($file, $., "defining $1");
$definesfound{$1} = 1;
}
}
# try to get any included file
- if ($_ =~ /^.include\s+([^\n]+)\n/) {
+ if ($line =~ /^.include\s+([^\n]+)\n/) {
$includefile = $1;
if ($includefile =~ /\"([^\"]+)\"/) {
$includefile = $1;
}
if ($includefile =~ /\/mk\/texinfo\.mk/) {
- &perror("FATAL: do not include $includefile");
+ log_error(NO_FILE, NO_LINE_NUMBER, "do not include $includefile");
}
if ($includefile =~ /\/mk\/bsd/) {
# we don't want to include the whole
# bsd.pkg.mk or bsd.prefs.mk files
- $contents .= $_;
+ $contents .= $line;
} else {
$dirname = dirname($file);
if (-e "$dirname/$includefile") {
- print("OK: including $dirname/$includefile\n") unless $quiet;
+ log_info($file, $., "including $dirname/$includefile");
$contents .= readmakefile("$dirname/$includefile");
}
else {
- &perror("FATAL: can't read $dirname/$includefile");
+ log_error(NO_FILE, NO_LINE_NUMBER, "can't read $dirname/$includefile");
}
}
} else {
# we don't want the include Makefile.common lines
# to be pkglinted
- $contents .= $_;
+ $contents .= $line;
}
}
close($handle);
@@ -744,10 +764,7 @@ sub readmakefile {
return $contents;
}
-#
-# Makefile
-#
-sub checkmakefile {
+sub checkfile_Makefile($) {
local($file) = @_;
local($rawwhole, $whole, $idx, @sections);
local($tmp, $tmp2);
@@ -759,38 +776,37 @@ sub checkmakefile {
local($realwrksrc, $wrksrc, $nowrksubdir) = ('', '', '');
local($includefile);
- &checkperms("$portdir/$file");
+ &checkperms("$opt_packagedir/$file");
$tmp = 0;
- $rawwhole = readmakefile("$portdir/$file");
+ $rawwhole = readmakefile("$opt_packagedir/$file");
if ($rawwhole eq '') {
- &perror("FATAL: can't read $portdir/$file");
+ log_error(NO_FILE, NO_LINE_NUMBER, "can't read $opt_packagedir/$file");
return 0;
}
else {
print("OK: whole Makefile (with all included files):\n".
- "$rawwhole\n") if ($showmakefile);
+ "$rawwhole\n") if ($opt_dumpmakefile);
}
#
# whole file: blank lines.
#
$whole = "\n" . $rawwhole;
- print "OK: checking contiguous blank lines in $file.\n"
- if ($verbose);
- $i = "\n" x ($contblank + 2);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking contiguous blank lines in $file.");
+ $i = "\n" x ($opt_contblank + 2);
if ($whole =~ /$i/) {
- &perror("FATAL: contiguous blank lines (> $contblank lines) found ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "contiguous blank lines (> $opt_contblank lines) found ".
"in $file at line " . int(@_ = split(/\n/, $`)) . ".");
}
#
# whole file: $(VARIABLE)
#
- if ($parenwarn) {
- print "OK: checking for \$(VARIABLE).\n" if ($verbose);
+ if ($opt_parenwarn) {
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for \$(VARIABLE).");
if ($whole =~ /\$\([\w\d]+\)/) {
- &perror("WARN: use \${VARIABLE}, instead of ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use \${VARIABLE}, instead of ".
"\$(VARIABLE).");
}
}
@@ -799,8 +815,8 @@ sub checkmakefile {
# whole file: get FILESDIR, PATCHDIR, PKGDIR, SCRIPTDIR,
# PATCH_SUM_FILE and DIGEST_FILE
#
- print "OK: checking for PATCHDIR, SCRIPTDIR, FILESDIR, PKGDIR,".
- " DIGEST_FILE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for PATCHDIR, SCRIPTDIR, FILESDIR, PKGDIR,".
+ " DIGEST_FILE.");
$filesdir = "files";
$filesdir = $1 if ($whole =~ /\nFILESDIR[+?]?=[ \t]*([^\n]+)\n/);
@@ -814,7 +830,7 @@ sub checkmakefile {
$patchdir =~ s/\${PKGSRCDIR}/..\/../;
$pkgdir = "pkg";
- if (! -d "$portdir/$pkgdir") {
+ if (! -d "$opt_packagedir/$pkgdir") {
$pkgdir = ".";
}
$pkgdir = $1 if ($whole =~ /\nPKGDIR[+?]?=[ \t]*([^\n]+)\n/);
@@ -832,125 +848,125 @@ sub checkmakefile {
$distinfo =~ s/\$\{.CURDIR\}/./;
$distinfo =~ s/\${PKGSRCDIR}/..\/../;
- print("OK: PATCHDIR: $patchdir, SCRIPTDIR: $scriptdir, ".
+ log_info(NO_FILE, NO_LINE_NUMBER, "PATCHDIR: $patchdir, SCRIPTDIR: $scriptdir, ".
"FILESDIR: $filesdir, PKGDIR: $pkgdir, ".
- "DISTINFO: $distinfo\n") if ($verbose);
+ "DISTINFO: $distinfo\n");
#
# whole file: INTERACTIVE_STAGE
#
$whole =~ s/\n#[^\n]*/\n/g;
$whole =~ s/\n\n+/\n/g;
- print "OK: checking INTERACTIVE_STAGE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking INTERACTIVE_STAGE.");
if ($whole =~ /\nINTERACTIVE_STAGE/) {
if ($whole !~ /defined\((BATCH|FOR_CDROM)\)/) {
- &perror("WARN: use of INTERACTIVE_STAGE discouraged. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of INTERACTIVE_STAGE discouraged. ".
"provide batch mode by using BATCH and/or ".
"FOR_CDROM.");
}
}
- print "OK: checking IS_INTERACTIVE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking IS_INTERACTIVE.");
if ($whole =~ /\nIS_INTERACTIVE/) {
- &perror("FATAL: IS_INTERACTIVE is deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "IS_INTERACTIVE is deprecated, ".
"use INTERACTIVE_STAGE instead.");
}
- print "OK: checking for PLIST_SRC.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for PLIST_SRC.");
if ($whole =~ /\nPLIST_SRC/) {
$seen_PLIST_SRC=1;
}
- print "OK: checking for NO_PKG_REGISTER.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for NO_PKG_REGISTER.");
if ($whole =~ /\nNO_PKG_REGISTER/) {
$seen_NO_PKG_REGISTER=1;
}
- print "OK: checking for NO_CHECKSUM.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for NO_CHECKSUM.");
if ($whole =~ /\nNO_CHECKSUM/) {
$seen_NO_CHECKSUM=1;
}
- print "OK: checking USE_PERL usage.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_PERL usage.");
if ($whole =~ /\nUSE_PERL[^5]/) {
- &perror("WARN: USE_PERL found -- you probably mean USE_PERL5.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "USE_PERL found -- you probably mean USE_PERL5.");
}
- print "OK: checking USE_PKGLIBTOOL.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_PKGLIBTOOL.");
if ($whole =~ /\nUSE_PKGLIBTOOL/) {
- &perror("FATAL: USE_PKGLIBTOOL is deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "USE_PKGLIBTOOL is deprecated, ".
"use USE_LIBTOOL instead.");
}
- print "OK: checking for USE_BUILDLINK2.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for USE_BUILDLINK2.");
if ($whole =~ /\nUSE_BUILDLINK2/) {
$seen_USE_BUILDLINK2=1;
}
- print "OK: checking for USE_PKGLOCALEDIR.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for USE_PKGLOCALEDIR.");
if ($whole =~ /\nUSE_PKGLOCALEDIR/) {
$seen_USE_PKGLOCALEDIR=1;
}
- print "OK: checking USE_SSL.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_SSL.");
if ($whole =~ /\nUSE_SSL/) {
- &perror("FATAL: USE_SSL is deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "USE_SSL is deprecated, ".
"use the openssl buildlink2.mk instead.");
}
- print "OK: checking NO_WRKSUBDIR.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking NO_WRKSUBDIR.");
if ($whole =~ /\nNO_WRKSUBDIR/) {
- &perror("FATAL: NO_WRKSUBDIR is deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "NO_WRKSUBDIR is deprecated, ".
"use WRKSRC=\$\{WRKDIR\} instead.");
}
- print "OK: checking MD5_FILE, DIGEST_FILE and PATCH_SUM_FILE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking MD5_FILE, DIGEST_FILE and PATCH_SUM_FILE.");
if ($whole =~ /\n(MD5_FILE)/ or $whole =~ /\n(DIGEST_FILE)/ or
$whole =~ /\n(PATCH_SUM_FILE)/) {
- &perror("FATAL: $1 is deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "$1 is deprecated, ".
"use DISTINFO_FILE instead.");
}
- print "OK: checking MIRROR_DISTFILE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking MIRROR_DISTFILE.");
if ($whole =~ /\nMIRROR_DISTFILE/) {
- &perror("WARN: use of MIRROR_DISTFILE deprecated, ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of MIRROR_DISTFILE deprecated, ".
"use NO_BIN_ON_FTP and/or NO_SRC_ON_FTP instead.");
}
- print "OK: checking NO_CDROM.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking NO_CDROM.");
if ($whole =~ /\nNO_CDROM/) {
- &perror("WARN: use of NO_CDROM discouraged, ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of NO_CDROM discouraged, ".
"use NO_BIN_ON_CDROM and/or NO_SRC_ON_CDROM instead.");
}
- print "OK: checking NO_PACKAGE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking NO_PACKAGE.");
if ($whole =~ /\nNO_PACKAGE/) {
- &perror("WARN: use of NO_PACKAGE to enforce license ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of NO_PACKAGE to enforce license ".
"restrictions is deprecated.");
}
- print "OK: checking NO_PATCH.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking NO_PATCH.");
if ($whole =~ /\nNO_PATCH/) {
- &perror("WARN: use of NO_PATCH deprecated.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of NO_PATCH deprecated.");
}
- print "OK: checking IGNORE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking IGNORE.");
if ($whole =~ /\nIGNORE/) {
- &perror("FATAL: use of IGNORE deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "use of IGNORE deprecated, ".
"use PKG_FAIL_REASON or PKG_SKIP_REASON instead.");
}
- print "OK: checking USE_GMAKE.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking USE_GMAKE.");
if ($whole =~ /\nUSE_GMAKE/) {
- &perror("FATAL: use of USE_GMAKE deprecated, ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "use of USE_GMAKE deprecated, ".
"use USE_GNU_TOOLS+=make instead.");
}
- print "OK: checking for MKDIR.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for MKDIR.");
if ($whole =~ m|\${MKDIR}.*(\${PREFIX}[/0-9a-zA-Z\${}]*)|) {
- &perror("WARN: \${MKDIR} $1: consider using INSTALL_*_DIR");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\${MKDIR} $1: consider using INSTALL_*_DIR");
}
- print "OK: checking for unneeded INSTALL -d.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for unneeded INSTALL -d.");
if ($whole =~ m|\${INSTALL}(.*)\n|) {
$args = $1;
if ($args =~ /-d/) {
if ($args !~ /-[ogm]/) {
- &perror("WARN: \${INSTALL}$args: " .
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\${INSTALL}$args: " .
"consider using INSTALL_*_DIR");
}
}
}
- print "OK: checking for unneeded failure check on directory creation.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking for unneeded failure check on directory creation.");
if ($whole =~ /\n\t-(.*(MKDIR|INSTALL.*-d|INSTALL_.*_DIR).*)/g) {
- &perror("WARN: $1: no need to use '-' before command");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$1: no need to use '-' before command");
}
#
# whole file: direct use of command names
#
- print "OK: checking direct use of command names.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking direct use of command names.");
foreach $i (split(/\s+/, <<EOF)) {
awk basename cat chmod chown chgrp cmp cp cut digest dirname echo egrep false
file find gmake grep gtar gzcat id ident install ldconfig ln md5 mkdir mtree mv
@@ -974,7 +990,7 @@ EOF
$j =~ s/\nCOMMENT[\t ]*=[\t ]*[^\n]*\n/\nCOMMENT=#replaced\n/;
foreach $i (keys %cmdnames) {
if ($j =~ /[ \t\/@]$i[ \t\n;]/) {
- &perror("WARN: possible direct use of command \"$i\" ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible direct use of command \"$i\" ".
"found. Use $cmdnames{$i} instead.");
}
}
@@ -984,21 +1000,21 @@ EOF
#
if ($j =~ /(ldconfig|\$[{(]LDCONFIG[)}])/
&& $j !~ /(\/usr\/bin\/true|\$[{(]TRUE[)}])/) {
- &perror("FATAL: ldconfig must be used with \"||\${TRUE}\".");
+ log_error(NO_FILE, NO_LINE_NUMBER, "ldconfig must be used with \"||\${TRUE}\".");
}
#
# whole file: ${MKDIR} -p
#
if ($j =~ /\${MKDIR}\s+-p/) {
- &perror("WARN: possible use of \"\${MKDIR} -p\" ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible use of \"\${MKDIR} -p\" ".
"found. \${MKDIR} includes \"-p\" by default.");
}
#
# whole file: continuation line in DEPENDS
#
if ($whole =~ /\n(BUILD_|)DEPENDS[^\n]*\\\n/) {
- &perror("WARN: Please don't use continuation lines in".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "Please don't use continuation lines in".
" (BUILD_)DEPENDS, use (BUILD_)DEPENDS+= instead.");
}
@@ -1006,11 +1022,11 @@ EOF
#
if ($whole =~ /\/wip\//
&& $category ne "wip") {
- &perror("FATAL: possible pkgsrc-wip pathname detected.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "possible pkgsrc-wip pathname detected.");
}
if ($whole =~ /etc\/rc\.d/) {
- &perror("WARN: Use RCD_SCRIPTS mechanism to install rc.d ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "Use RCD_SCRIPTS mechanism to install rc.d ".
"scripts automatically to \${RCD_SCRIPTS_EXAMPLEDIR}.");
}
@@ -1033,23 +1049,23 @@ EOF
#
# section 1: comment lines.
#
- print "OK: checking comment section of $file.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking comment section of $file.");
$tmp = $sections[$idx++];
- if ($tmp !~ /#(\s+)\$$rcsidstr([^\$]*)\$/) {
- &perror("FATAL: no \$$rcsidstr\$ line in $file comment ".
+ if ($tmp !~ /#(\s+)\$$conf_rcsidstr([^\$]*)\$/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "no \$$conf_rcsidstr\$ line in $file comment ".
"section.");
} else {
- print "OK: \$$rcsidstr\$ seen in $file.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "\$$conf_rcsidstr\$ seen in $file.");
if ($1 ne ' ') {
- &perror("WARN: please use single whitespace ".
- "right before \$$rcsidstr\$ tag.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "please use single whitespace ".
+ "right before \$$conf_rcsidstr\$ tag.");
}
if ($2 ne '') {
- if ($verbose || $newpkg) { # XXX
- &perror("WARN: ".
- ($newpkg ? 'for new package, '
+ if ($opt_verbose || $opt_newpackage) { # XXX
+ log_warning(NO_FILE, NO_LINE_NUMBER, "".
+ ($opt_newpackage ? 'for new package, '
: 'is it a new package? if so, ').
- "make \$$rcsidstr\$ tag in comment ".
+ "make \$$conf_rcsidstr\$ tag in comment ".
"section empty, to make CVS happy.");
}
}
@@ -1070,8 +1086,7 @@ EOF
#
# section 2: DISTNAME/PKGNAME/...
#
- print "OK: checking first section of $file. (DISTNAME/...)\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking first section of $file. (DISTNAME/...)");
$tmp = $sections[$idx++];
# check the order of items.
@@ -1088,10 +1103,10 @@ EOF
$tmp = "\n" . $tmp;
foreach $i ('DISTNAME', 'CATEGORIES') {
if ($tmp !~ /\n$i=/) {
- &perror("FATAL: $i has to be there.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "$i has to be there.");
}
if ($tmp =~ /\n$i(\?=)/) {
- &perror("FATAL: $i has to be set by \"=\", ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "$i has to be set by \"=\", ".
"not by \"$1\".");
}
}
@@ -1099,40 +1114,37 @@ EOF
# check for pkgsrc-wip remnants in CATEGORIES
if ($tmp =~ /\nCATEGORIES=[ \t]*.*wip.*\n/
&& $category ne "wip") {
- &perror("FATAL: don't forget to remove \"wip\" from CATEGORIES.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "don't forget to remove \"wip\" from CATEGORIES.");
}
# check the URL
if ($tmp =~ /\nMASTER_SITES[+?]?=[ \t]*([^\n]*)\n/
&& $1 !~ /^[ \t]*$/) {
- print "OK: seen MASTER_SITES, sanity checking URLs.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen MASTER_SITES, sanity checking URLs.");
@sites = split(/\s+/, $1);
foreach $i (@sites) {
if ($i =~ m#^\w+://#) {
if ($i !~ m#/$#) {
- &perror("FATAL: URL \"$i\" should ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "URL \"$i\" should ".
"end with \"/\".");
}
if ($i =~ m#://[^/]*:/#) {
- &perror("FATAL: URL \"$i\" contains ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "URL \"$i\" contains ".
"extra \":\".");
}
unless (&is_predefined($i)) {
- print "OK: URL \"$i\" ok.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "URL \"$i\" ok.");
}
} else {
- print "OK: non-URL \"$i\" ok.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "non-URL \"$i\" ok.\n");
}
if ($tmp =~ /\nDYNAMIC_MASTER_SITES[+?]?=/) {
- &perror("WARN: MASTER_SITES and DYNAMIC_MASTER_SITES ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "MASTER_SITES and DYNAMIC_MASTER_SITES ".
"found. Is this ok?");
}
}
} elsif ($tmp !~ /\nDYNAMIC_MASTER_SITES[+?]?=/) {
- &perror("WARN: no MASTER_SITES or DYNAMIC_MASTER_SITES found. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no MASTER_SITES or DYNAMIC_MASTER_SITES found. ".
"Is this ok?");
}
@@ -1145,29 +1157,28 @@ EOF
# check bogus EXTRACT_SUFX.
if ($extractsufx ne '') {
- print "OK: seen EXTRACT_SUFX, checking value.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen EXTRACT_SUFX, checking value.");
if ($distfiles ne '' && ($extractsufx eq '.tar.gz')) {
- &perror("WARN: no need to define EXTRACT_SUFX if ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no need to define EXTRACT_SUFX if ".
"DISTFILES is defined.");
}
if ($extractsufx eq '.tar.gz') {
- &perror("WARN: EXTRACT_SUFX is \".tar.gz.\" ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "EXTRACT_SUFX is \".tar.gz.\" ".
"by default. you don't need to specify it.");
}
} else {
- print "OK: no EXTRACT_SUFX seen, using default value.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "no EXTRACT_SUFX seen, using default value.");
$extractsufx = '.tar.gz';
}
- print "OK: sanity checking PKGNAME.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "sanity checking PKGNAME.");
if ($pkgname ne '' && $pkgname eq $distname) {
- &perror("WARN: PKGNAME is \${DISTNAME} by default, ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "PKGNAME is \${DISTNAME} by default, ".
"you don't need to define PKGNAME.");
}
if ($svrpkgname ne '') {
if (length($svrpkgname) > 5) {
- &perror("FATAL: SVR4_PKGNAME should not be longer ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "SVR4_PKGNAME should not be longer ".
"than 5 characters.");
}
}
@@ -1177,7 +1188,7 @@ EOF
$j = $`;
$k = $1;
if ($j =~ /[0-9]$/) {
- &perror("WARN: is \"$j\" sane as package name ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "is \"$j\" sane as package name ".
"WITHOUT version number? ".
"if not, avoid \"-\" in version number ".
"part of ".
@@ -1190,30 +1201,30 @@ EOF
}
if ($k =~ /^pl[0-9]*$/
|| $k =~ /^[0-9]*[A-Za-z]*[0-9]*(\.[0-9]*[A-Za-z]*[0-9]*)*$/) {
- print "OK: trailing part of PKGNAME\"-$k\" ".
- "looks fine.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "trailing part of PKGNAME\"-$k\" ".
+ "looks fine.");
} else {
- &perror("FATAL: version number part of PKGNAME".
+ log_error(NO_FILE, NO_LINE_NUMBER, "version number part of PKGNAME".
(($pkgname eq '')
? ', which is derived from DISTNAME, '
: ' ').
"looks illegal. You should modify \"-$k\"");
}
} else {
- &perror("FATAL: PKGNAME".
+ log_error(NO_FILE, NO_LINE_NUMBER, "PKGNAME".
(($pkgname eq '')
? ', which is derived from DISTNAME, '
: ' ').
"must come with version number, like \"foobaa-1.0\".");
if ($i =~ /_pl[0-9]*$/
|| $i =~ /_[0-9]*[A-Za-z]?[0-9]*(\.[0-9]*[A-Za-z]?[0-9]*)*$/) {
- &perror("FATAL: you seem to be using underline ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "you seem to be using underline ".
"before version number in PKGNAME. ".
"it has to be hyphen.");
}
}
if ($distname =~ /(nb\d*)/) {
- &perror("WARN: is '$1' really ok on DISTNAME, ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "is '$1' really ok on DISTNAME, ".
"or is it intended for PKGNAME?");
}
@@ -1226,20 +1237,19 @@ EOF
# EXTRACT_SUFX= .tgz
if ($distfiles =~ /^\S+$/) {
$bogusdistfiles++;
- print "OK: seen DISTFILES with single item, checking value.\n"
- if ($verbose);
- &perror("WARN: use of DISTFILES with single file ".
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen DISTFILES with single item, checking value.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "use of DISTFILES with single file ".
"discouraged. distribution filename should be set by ".
"DISTNAME and EXTRACT_SUFX.");
if ($distfiles eq $distname . $extractsufx) {
- &perror("WARN: definition of DISTFILES not necessary. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "definition of DISTFILES not necessary. ".
"DISTFILES is \${DISTNAME}/\${EXTRACT_SUFX} ".
"by default.");
}
# make an advice only in certain cases.
if ($pkgname ne '' && $distfiles =~ /^$pkgname([-\.].+)$/) {
- &perror("WARN: how about \"DISTNAME=$pkgname\"".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "how about \"DISTNAME=$pkgname\"".
(($1 eq '.tar.gz')
? ""
: " and \"EXTRACT_SUFX=$1\"").
@@ -1249,8 +1259,8 @@ EOF
# additional checks for committer.
$i = ($pkgname eq '') ? $distname : $pkgname;
- if ($committer && -f "$portdir/$i.tgz") {
- &perror("WARN: be sure to remove $portdir/$i.tgz ".
+ if ($opt_committer && -f "$opt_packagedir/$i.tgz") {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "be sure to remove $opt_packagedir/$i.tgz ".
"before committing the package.");
}
@@ -1262,8 +1272,7 @@ EOF
#
# section 3: PATCH_SITES/PATCHFILES(optional)
#
- print "OK: checking second section of $file, (PATCH*: optional).\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking second section of $file, (PATCH*: optional).");
$tmp = $sections[$idx];
if ($tmp =~ /(PATCH_SITES|PATCH_SITE_SUBDIR|PATCHFILES|PATCH_DIST_STRIP)/) {
@@ -1272,23 +1281,23 @@ EOF
$tmp = "\n$tmp";
if ($tmp =~ /\n(PATCH_SITES)=/) {
- print "OK: seen PATCH_SITES.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen PATCH_SITES.");
$tmp =~ s/$1[^\n]+\n//;
}
if ($tmp =~ /\n(PATCH_SITE_SUBDIR)=/) {
- print "OK: seen PATCH_SITE_SUBDIR.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen PATCH_SITE_SUBDIR.");
$tmp =~ s/$1[^\n]+\n//;
}
if ($tmp =~ /\n(PATCHFILES)=/) {
- print "OK: seen PATCHFILES.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen PATCHFILES.");
$tmp =~ s/$1[^\n]+\n//;
}
if ($tmp =~ /\n(PATCH_DIST_ARGS)=/) {
- print "OK: seen PATCH_DIST_ARGS.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen PATCH_DIST_ARGS.");
$tmp =~ s/$1[^\n]+\n//;
}
if ($tmp =~ /\n(PATCH_DIST_STRIP)=/) {
- print "OK: seen PATCH_DIST_STRIP.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen PATCH_DIST_STRIP.");
$tmp =~ s/$1[^\n]+\n//;
}
@@ -1304,8 +1313,7 @@ EOF
#
# section 4: MAINTAINER
#
- print "OK: checking third section of $file (MAINTAINER).\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking third section of $file (MAINTAINER).");
$tmp = $sections[$idx++];
# check the order of items.
@@ -1318,12 +1326,12 @@ EOF
# warnings for missing or incorrect HOMEPAGE
$tmp = "\n" . $tmp;
if ($tmp !~ /\nHOMEPAGE[+?]?=[ \t]*([^\n]*)\n/ || $1 =~ /^[ \t]*$/) {
- &perror("WARN: please add HOMEPAGE if the package has one.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "please add HOMEPAGE if the package has one.");
} else {
$i = $1;
if ($i =~ m#^\w+://#) {
if ($i !~ m#^\w+://[^\n/]+/#) {
- &perror("WARN: URL \"$i\" does not ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "URL \"$i\" does not ".
"end with \"/\".");
}
}
@@ -1331,31 +1339,31 @@ EOF
# warnings for missing COMMENT
if ($tmp !~ /\nCOMMENT=\s*(.*)$/) {
- &perror("FATAL: please add a short COMMENT describing the package.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "please add a short COMMENT describing the package.");
}
# and its properties:
$tmp2 = $1;
if ($tmp2 =~ /\.$/i) {
- &perror("WARN: COMMENT should not end with a '.' (period).");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "COMMENT should not end with a '.' (period).");
}
if ($tmp2 =~ /^(a|an) /i) {
- &perror("WARN: COMMENT should not begin with '$1 '.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "COMMENT should not begin with '$1 '.");
}
if ($tmp2 =~ /^[a-z]/) {
- &perror("WARN: COMMENT should start with a capital letter.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "COMMENT should start with a capital letter.");
}
if (length($tmp2) > 70) {
- &perror("WARN: COMMENT should not be longer than 70 characters.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "COMMENT should not be longer than 70 characters.");
}
&checkearlier($tmp, @varnames);
$tmp = "\n" . $tmp;
if ($tmp =~ /\nMAINTAINER=[^@]+\@netbsd.org/) {
- &perror("WARN: \@netbsd.org should be \@NetBSD.org in MAINTAINER.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\@netbsd.org should be \@NetBSD.org in MAINTAINER.");
} elsif ($tmp =~ /\nMAINTAINER=[^\n]+/) {
$tmp =~ s/\nMAINTAINER=[^\n]+//;
} else {
- &perror("FATAL: no MAINTAINER listed in $file.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "no MAINTAINER listed in $file.");
# Why is this fatal? There's a default in bsd.pkg.mk - HF
}
$tmp =~ s/\n\n+/\n/g;
@@ -1367,54 +1375,52 @@ EOF
#
# section 5: *_DEPENDS (may not be there)
#
- print "OK: checking fourth section of $file(*_DEPENDS).\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking fourth section of $file(*_DEPENDS).");
$tmp = $sections[$idx];
@linestocheck = split(/\s+/, <<EOF);
BUILD_USES_MSGFMT BUILD_DEPENDS DEPENDS
EOF
if ($tmp =~ /(DEPENDS_TARGET|FETCH_DEPENDS|LIB_DEPENDS|RUN_DEPENDS).*=/) {
- &perror("WARN: $1 is deprecated, please use DEPENDS.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$1 is deprecated, please use DEPENDS.");
}
if ($tmp =~ /(LIB_|BUILD_|RUN_|FETCH_)?DEPENDS/ or
$tmp =~ /BUILD_USES_MSGFMT/) {
&checkearlier($tmp, @varnames);
if (!defined $ENV{'PORTSDIR'}) {
- $ENV{'PORTSDIR'} = $portsdir;
+ $ENV{'PORTSDIR'} = $conf_portsdir;
}
foreach $i (grep(/^[A-Z_]*DEPENDS[?+]?=/, split(/\n/, $tmp))) {
$i =~ s/^([A-Z_]*DEPENDS)[?+]?=[ \t]*//;
$j = $1;
- print "OK: checking packages listed in $j.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking packages listed in $j.");
foreach $k (split(/\s+/, $i)) {
$l = (split(':', $k))[0];
# check BUILD_USES_MSGFMT
if ($l =~ /^(msgfmt|gettext)$/) {
- &perror("WARN: dependency to $1 ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "dependency to $1 ".
"listed in $j. Consider using".
" BUILD_USES_MSGFMT.");
}
# check USE_PERL5
if ($l =~ /^perl(\.\d+)?$/) {
- &perror("WARN: dependency to perl ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "dependency to perl ".
"listed in $j. Consider using".
" USE_PERL5.");
}
# check USE_GMAKE
if ($l =~ /^(gmake|\${GMAKE})$/) {
- &perror("WARN: dependency to $1 ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "dependency to $1 ".
"listed in $j. Consider using".
" USE_GMAKE.");
}
# check direct dependencies on -dirs packages
if ($l =~ /^([-a-zA-Z0-9]+)-dirs[-><=]+(.*)/) {
- &perror("WARN: dependency to $1-dirs ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "dependency to $1-dirs ".
"listed in $j. Consider using".
" USE_DIRS+=$1-$2.");
}
@@ -1422,13 +1428,12 @@ EOF
# check pkg dir existence
$k = (split(':', $k))[1];
$k =~ s/\${PKGSRCDIR}/$ENV{'PKGSRCDIR'}/;
- if (! -d "$portdir/$k") {
- &perror("WARN: no package directory $k ".
+ if (! -d "$opt_packagedir/$k") {
+ log_warning(NO_FILE, NO_LINE_NUMBER, "no package directory $k ".
"found, even though it is ".
"listed in $j.");
} else {
- print "OK: package directory $k found.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "package directory $k found.");
}
}
}
@@ -1447,7 +1452,7 @@ EOF
#
# Makefile 6: check the rest of file
#
- print "OK: checking the rest of the $file.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking the rest of the $file.");
$tmp = join("\n\n", @sections[$idx .. scalar(@sections)-1]);
$tmp = "\n" . $tmp; # to make the begin-of-line check easier
@@ -1467,7 +1472,7 @@ EOF
# EXTRACT_SUFX=.tgz
# WRKSRC= ${WRKDIR}/package
#
- print "OK: checking WRKSRC.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking WRKSRC.");
$wrksrc = $nowrksubdir = '';
$wrksrc = $1 if ($tmp =~ /\nWRKSRC[+?]?=[ \t]*([^\n]*)\n/);
$nowrksubdir = $1 if ($tmp =~ /\nNO_WRKSUBDIR[+?]?=[ \t]*([^\n]*)\n/);
@@ -1477,13 +1482,12 @@ EOF
} else {
$realwrksrc = $wrksrc ? $wrksrc : '${WRKDIR}';
}
- print "OK: WRKSRC seems to be $realwrksrc.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "WRKSRC seems to be $realwrksrc.");
if ($nowrksubdir eq '') {
- print "OK: no NO_WRKSUBDIR, checking value of WRKSRC.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "no NO_WRKSUBDIR, checking value of WRKSRC.");
if ($wrksrc eq 'work' || $wrksrc =~ /^$[\{\(]WRKDIR[\}\)]/) {
- &perror("WARN: WRKSRC is set to meaningless value ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "WRKSRC is set to meaningless value ".
"\"$1\".".
($nowrksubdir eq ''
? " use \"NO_WRKSUBDIR=yes\" instead."
@@ -1491,19 +1495,18 @@ EOF
}
if ($bogusdistfiles) {
if ($distname ne '' && $wrksrc eq '') {
- &perror("WARN: do not use DISTFILES and DISTNAME ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "do not use DISTFILES and DISTNAME ".
"to control WRKSRC. how about ".
"\"WRKSRC=\${WRKDIR}/$distname\"?");
} else {
- &perror("WARN: DISTFILES/DISTNAME affects WRKSRC. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "DISTFILES/DISTNAME affects WRKSRC. ".
"Use caution when changing them.");
}
}
} else {
- print "OK: seen NO_WRKSUBDIR, checking value of WRKSRC.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen NO_WRKSUBDIR, checking value of WRKSRC.");
if ($wrksrc eq 'work' || $wrksrc =~ /^$[\{\(]WRKDIR[\}\)]/) {
- &perror("WARN: definition of WRKSRC not necessary. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "definition of WRKSRC not necessary. ".
"WRKSRC is \${WRKDIR} by default.");
}
}
@@ -1513,7 +1516,7 @@ EOF
$j = $1;
foreach $k (split(/\s+/, $i)) {
if ($k !~/^".*"$/ && $k =~ /\${/ && $k !~/:Q}/) {
- &perror("WARN: definition of $k in $j. ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "definition of $k in $j. ".
"should use :Q or be quoted.");
}
}
@@ -1521,31 +1524,21 @@ EOF
# check USE_X11 and USE_IMAKE
if ($tmp =~ /\nUSE_IMAKE[?+]?=/ && $tmp =~ /\nUSE_X11[?+]?=/) {
- &perror("WARN: since you already have USE_IMAKE, ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "since you already have USE_IMAKE, ".
"you don't need USE_X11.");
}
# check direct use of important make targets.
if ($tmp =~ /\n(fetch|extract|patch|configure|build|install):/) {
- &perror("FATAL: direct redefinition of make target \"$1\" ".
+ log_error(NO_FILE, NO_LINE_NUMBER, "direct redefinition of make target \"$1\" ".
"discouraged. redefine \"do-$1\" instead.");
}
1;
}
-sub perror {
- local(@msg) = @_;
- if ($msg[0] =~ /^FATAL/) {
- $err++;
- } else {
- $warn++;
- }
- print join("\n", @msg) . "\n";
-}
-
-sub checkextra {
- local($str, $section) = @_;
+sub checkextra($$) {
+ my ($str, $section) = @_;
$str = "\n" . $str if ($str !~ /^\n/);
$str =~ s/\n#[^\n]*/\n/g;
@@ -1555,70 +1548,68 @@ sub checkextra {
return if ($str eq '');
if ($str =~ /^([\w\d]+)/) {
- &perror("WARN: extra item placed in the ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "extra item placed in the ".
"$section section, ".
"for example, \"$1\".");
} else {
- &perror("WARN: extra item placed in the ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "extra item placed in the ".
"$section section.");
}
}
-sub checkorder {
- local($section, $str, @order) = @_;
- local(@items, $i, $j, $k, $invalidorder);
+sub checkorder($$@) {
+ my ($section, $str, @order) = @_;
- print "OK: checking the order of $section section.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking the order of $section section.");
- @items = ();
- foreach $i (split("\n", $tmp)) {
+ my @items = ();
+ foreach my $i (split("\n", $tmp)) {
$i =~ s/[+?]?=.*$//;
push(@items, $i);
}
@items = reverse(@items);
- $j = -1;
- $invalidorder = 0;
+ my $j = -1;
+ my $invalidorder = 0;
while (scalar(@items)) {
- $i = pop(@items);
- $k = 0;
+ my $i = pop(@items);
+ my $k = 0;
while ($k < scalar(@order) && $order[$k] ne $i) {
$k++;
}
if ($order[$k] eq $i) {
if ($k < $j) {
- &perror("FATAL: $i appears out-of-order.");
+ log_error(NO_FILE, NO_LINE_NUMBER, "$i appears out-of-order.");
$invalidorder++;
} else {
- print "OK: seen $i, in order.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "seen $i, in order.");
}
$j = $k;
} else {
- &perror("FATAL: extra item \"$i\" placed in".
+ log_error(NO_FILE, NO_LINE_NUMBER, "extra item \"$i\" placed in".
" the $section section.");
}
}
if ($invalidorder) {
- &perror("FATAL: order must be " . join('/', @order) . '.');
+ log_error(NO_FILE, NO_LINE_NUMBER, "order must be " . join('/', @order) . '.');
} else {
- print "OK: $section section is ordered properly.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "$section section is ordered properly.");
}
}
-sub checkearlier {
+sub checkearlier($@) {
local($str, @varnames) = @_;
local($i);
- print "OK: checking items that have to appear earlier.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking items that have to appear earlier.");
foreach $i (@varnames) {
if ($str =~ /\n$i[?+]?=/) {
- &perror("WARN: \"$i\" has to appear earlier in $file.");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "\"$i\" has to appear earlier in $file.");
}
}
}
-sub abspathname {
+sub abspathname($$) {
local($str, $file) = @_;
local($s, $i, %cmdnames);
local($pre);
@@ -1626,8 +1617,7 @@ sub abspathname {
# ignore parameter string to echo command
$str =~ s/[ \t][\@-]?(echo|\$[\{\(]ECHO[\}\)]|\$[\{\(]ECHO_MSG[\}\)])[ \t]+("(\\'|\\"|[^"])*"|'(\\'|\\"|[^"])*')[ \t]*[;\n]//;
- print "OK: checking direct use of full pathnames in $file.\n"
- if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking direct use of full pathnames in $file.");
foreach $s (split(/\n+/, $str)) {
$i = '';
if ($s =~ /(^|[ \t\@'"-])(\/[\w\d])/) {
@@ -1644,27 +1634,27 @@ sub abspathname {
$i =~ s/\s.*$//;
$i =~ s/['"].*$//;
$i = substr($i, 0, 20) . '...' if (20 < length($i));
- &perror("WARN: possible use of absolute pathname ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible use of absolute pathname ".
"\"$i\", in $file.");
}
}
- print "OK: checking direct use of pathnames, phase 1.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking direct use of pathnames, phase 1.");
%cmdnames = split(/\n|\t+/, <<EOF);
/usr/opt \${PORTSDIR} instead
-$portsdir \${PORTSDIR} instead
-$localbase \${PREFIX} or \${LOCALBASE}, as appropriate
+$conf_portsdir \${PORTSDIR} instead
+$conf_localbase \${PREFIX} or \${LOCALBASE}, as appropriate
/usr/X11 \${PREFIX} or \${X11BASE}, as appropriate
/usr/X11R6 \${PREFIX} or \${X11BASE}, as appropriate
EOF
foreach $i (keys %cmdnames) {
if ($str =~ /$i/) {
- &perror("WARN: possible direct use of \"$&\" ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible direct use of \"$&\" ".
"found in $file. if so, use $cmdnames{$i}.");
}
}
- print "OK: checking direct use of pathnames, phase 2.\n" if ($verbose);
+ log_info(NO_FILE, NO_LINE_NUMBER, "checking direct use of pathnames, phase 2.");
%cmdnames = split(/\n|\t+/, <<EOF);
distfiles \${DISTDIR} instead
pkg \${PKGDIR} instead
@@ -1675,13 +1665,13 @@ work \${WRKDIR} instead
EOF
foreach $i (keys %cmdnames) {
if ($str =~ /(\.\/|\$[\{\(]\.CURDIR[\}\)]\/|[ \t])(\b$i)\//) {
- &perror("WARN: possible direct use of \"$i\" ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "possible direct use of \"$i\" ".
"found in $file. if so, use $cmdnames{$i}.");
}
}
}
-sub is_predefined {
+sub is_predefined($) {
local($url) = @_;
local($site);
local($subdir);
@@ -1689,14 +1679,14 @@ sub is_predefined {
$url =~ /$site/;
$subdir = $';
$subdir =~ s/\/$//;
- &perror("WARN: how about using ".
+ log_warning(NO_FILE, NO_LINE_NUMBER, "how about using ".
"\${MASTER_SITE_$predefined{$site}:=$subdir/} instead of \"$url\?");
- return &TRUE;
+ return 1;
}
- undef;
+ return 0;
}
-sub category_check {
+sub category_check() {
local($file) = "Makefile";
local($first) = 1;
local($lastsub) = "";
@@ -1705,13 +1695,13 @@ sub category_check {
local(@dirlist);
local($i);
- $contents = readmakefile("$portdir/$file") or
- &perror("FATAL: can't read $portdir/$file") and return 0;
- if ($contents !~ /#(\s+)\$$rcsidstr([^\$]*)\$/) {
- &perror("FATAL: no \$$rcsidstr\$ line in $file");
+ $contents = readmakefile("$opt_packagedir/$file") or
+ log_error(NO_FILE, NO_LINE_NUMBER, "can't read $opt_packagedir/$file") and return 0;
+ if ($contents !~ /#(\s+)\$$conf_rcsidstr([^\$]*)\$/) {
+ log_error(NO_FILE, NO_LINE_NUMBER, "no \$$conf_rcsidstr\$ line in $file");
}
if ($contents !~ /COMMENT=\s+\w/) {
- &perror("FATAL: no COMMENT line in $file");
+ log_error(NO_FILE, NO_LINE_NUMBER, "no COMMENT line in $file");
}
# get list of dirs to compare against
@@ -1725,14 +1715,14 @@ sub category_check {
$hash{CVS} = 0;
# remove comments
foreach $n (split "\n", $contents) {
- if ($n =~ /^(#)?SUBDIR(\+*)=\s*(\S+)(\s*#.*|\s*)$/) {
+ if ($n =~ /^(#?)SUBDIR(\+*)=\s*(\S+)(\s*#.*|\s*)$/) {
$sub = $3;
if ($first == 0) {
if ($2 ne "+") {
- &perror("FATAL: use SUBDIR+=, not SUBDIR$2=");
+ log_error(NO_FILE, NO_LINE_NUMBER, "use SUBDIR+=, not SUBDIR$2=");
}
if ($lastsub ge $sub) {
- &perror("FATAL: $sub should come before $lastsub");
+ log_error(NO_FILE, NO_LINE_NUMBER, "$sub should come before $lastsub");
}
}
else {
@@ -1746,19 +1736,69 @@ sub category_check {
$hash{$sub} = -1;
}
if ($1 eq "#" and not $4 =~ /#\s*\w+/) {
- &perror("WARN: $3 commented out without giving a reason");
+ log_warning(NO_FILE, NO_LINE_NUMBER, "$3 commented out without giving a reason");
}
}
}
foreach $i (sort(keys(%hash))) {
if ($hash{$i} gt 0) {
- &perror("FATAL: directory $i not in Makefile");
+ log_error(NO_FILE, NO_LINE_NUMBER, "directory $i not in Makefile");
}
elsif ($hash{$i} lt 0) {
- &perror("FATAL: non-existing directory $i listed in Makefile");
+ log_error(NO_FILE, NO_LINE_NUMBER, "non-existing directory $i listed in Makefile");
}
}
}
-sub TRUE {1;}
+#
+# Output of various log messages
+#
+
+
+sub log_message($$$$)
+{
+ my ($file, $lineno, $type, $message) = @_;
+ if ($file eq NO_FILE) {
+ printf("%s: %s\n", $type, $message);
+ } elsif ($lineno == NO_LINE_NUMBER) {
+ printf("%s: %s: %s\n", $type, $file, $message);
+ } else {
+ printf("%s: %s:%d: %s\n", $type, $file, $lineno, $message);
+ }
+}
+
+sub NO_FILE() { return ""; }
+sub NO_LINE_NUMBER() { return 0; }
+
+sub log_error($$$)
+{
+ my ($file, $lineno, $msg) = @_;
+ log_message($file, $lineno, "FATAL", $msg);
+ $errors++;
+}
+
+sub log_warning($$$)
+{
+ my ($file, $lineno, $msg) = @_;
+ log_message($file, $lineno, "WARN", $msg);
+ $warnings++;
+}
+
+sub log_info($$$)
+{
+ my ($file, $lineno, $msg) = @_;
+ if ($opt_verbose) {
+ log_message($file, $lineno, "OK", $msg);
+ }
+}
+
+sub print_summary_and_exit()
+{
+ if ($errors != 0 || $warnings != 0) {
+ print("$errors errors and $warnings warnings found.\n");
+ } else {
+ print "looks fine.\n";
+ }
+ exit($errors != 0);
+}