summaryrefslogtreecommitdiffstats
path: root/devel/portlint
diff options
context:
space:
mode:
authormarcus <marcus@FreeBSD.org>2003-10-26 21:27:30 +0000
committermarcus <marcus@FreeBSD.org>2003-10-26 21:27:30 +0000
commitb62a9b514546a0c659e951733021c03941815845 (patch)
tree5606b57e90533e1a08206387edbe93e02dfd22f1 /devel/portlint
parenta7d700aec2b83dcd8209028af8e10120693e2605 (diff)
downloadFreeBSD-ports-b62a9b514546a0c659e951733021c03941815845.zip
FreeBSD-ports-b62a9b514546a0c659e951733021c03941815845.tar.gz
* Add some @unexec checking for plists [1]
* Check for the common typo, NOPORTSDOC [2] * Make sure .CURDIR is the primary category [3] * Check for USE_* macros that are user-settable [4] * Try to be a little more intelligent when checking for macros that need to appear earlier * Ignore make directives when checking for extra items in certain sections PR: 55921 [1] 57751 [2] 58292 [3] 58525 [4] Submitted by: edwin [1] Oliver Eikemeier <eikemeier@fillmore-labs.com> [2] [3] [4]
Diffstat (limited to 'devel/portlint')
-rw-r--r--devel/portlint/Makefile2
-rw-r--r--devel/portlint/src/portlint.pl43
2 files changed, 40 insertions, 5 deletions
diff --git a/devel/portlint/Makefile b/devel/portlint/Makefile
index efab574..7699bd3 100644
--- a/devel/portlint/Makefile
+++ b/devel/portlint/Makefile
@@ -8,7 +8,7 @@
#
PORTNAME= portlint
-PORTVERSION= 2.4.4
+PORTVERSION= 2.4.5
CATEGORIES= devel
MASTER_SITES= # none
DISTFILES= # none
diff --git a/devel/portlint/src/portlint.pl b/devel/portlint/src/portlint.pl
index 5e2c0c1..af650b7 100644
--- a/devel/portlint/src/portlint.pl
+++ b/devel/portlint/src/portlint.pl
@@ -17,7 +17,7 @@
# OpenBSD and NetBSD will be accepted.
#
# $FreeBSD$
-# $Id: portlint.pl,v 1.16 2003/08/16 20:36:50 marcus Exp $
+# $Id: portlint.pl,v 1.18 2003/10/26 21:24:08 marcus Exp $
#
use vars qw/ $opt_a $opt_A $opt_b $opt_c $opt_h $opt_t $opt_v $opt_M $opt_N $opt_B $opt_V /;
@@ -40,7 +40,7 @@ $portdir = '.';
# version variables
my $major = 2;
my $minor = 4;
-my $micro = 4;
+my $micro = 5;
sub l { '[{(]'; }
sub r { '[)}]'; }
@@ -444,9 +444,21 @@ sub checkplist {
if ($_ =~ /^\@/) {
if ($_ =~ /^\@(cwd|cd)[ \t]+(\S+)/) {
$curdir = $2;
+ } elsif ($_ =~ /^\@unexec[ \t]+rm[ \t]/) {
+ if ($_ !~ /%D/) {
+ &perror("WARN: pkg-plist:$. use \"%D\" to specify prefix.");
+ }
+ if ($_ !~ /true$/) {
+ &perror("WARN: pkg-plist:$. add \"2>&1 ".
+ ">/dev/null || true\" ".
+ "to \"\@unexec rm\".");
+ }
} elsif ($_ =~ /^\@unexec[ \t]+rmdir/) {
+ if ($_ !~ /%D/) {
+ &perror("WARN: pkg-plist:$. use \"%D\" to specify prefix.");
+ }
if ($_ !~ /true$/) {
- &perror("WARN: use \"\@dirrm\" ".
+ &perror("WARN: pkg-plist:$. use \"\@dirrm\" ".
"instead of \"\@unexec rmdir\".");
}
} elsif ($_ =~ /^\@exec[ \t]+scrollkeeper-install[ \t]+-q\s+(\S+)\s+.+$/) {
@@ -543,6 +555,9 @@ sub checkplist {
if ($_ =~ /^(\%\%PORTDOCS\%\%)?share\/doc\//) {
&perror("WARN: $file $.: consider using DOCSDIR macro");
+ $sharedocused++;
+ } elsif ($_ =~ /^(\%\%PORTDOCS\%\%)?\%\%DOCSDIR\%\%/) {
+ $sharedocused++;
}
if ($_ =~ /^share\/examples\//) {
@@ -844,6 +859,16 @@ sub checkmakefile {
}
#
+ # whole file: USE_* as a user-settable option
+ #
+ print "OK: checking for USE_* as a user-settable option.\n" if ($verbose);
+ while ($whole =~ /\n\s*\.\s*(?:el)?if[^\n]*?\b(\w*USE_)(\w+)(?\![^\n]*\n#?\.error)/g) {
+ &perror("WARN: is $1$2 a user-settable option? ".
+ "Consider using WITH_$2 instead.")
+ if ($1.$2 ne 'USE_GCC');
+ }
+
+ #
# whole file: NO_CHECKSUM
#
$whole =~ s/\n#[^\n]*/\n/g;
@@ -875,6 +900,9 @@ sub checkmakefile {
}
}
print "OK: checking for use of NOPORTDOCS.\n" if ($verbose);
+ if ($whole =~ /NOPORTSDOC/) {
+ &perror("WARN: NOPORTSDOC found. Do you mean NOPORTDOCS?");
+ }
if ($sharedocused && $whole !~ /defined\(NOPORTDOCS\)/
&& $whole !~ m#(\$[\{\(]PREFIX[\}\)]|$localbase)/share/doc#) {
&perror("WARN: use \".if !defined(NOPORTDOCS)\" to wrap ".
@@ -1119,6 +1147,12 @@ DISTFILES DIST_SUBDIR EXTRACT_ONLY
" if nothing seems apropriate.");
}
+ if ($committer && $makevar{'.CURDIR'} =~ m'/([^/]+)/[^/]+/?$') {
+ if ($cat[0] ne $1) {
+ &perror("FATAL: category \"$1\" must be listed first");
+ }
+ }
+
#MICHAEL: can these three lang cat checks be combined?
# skip the first category specification if it's a language specific one.
if (grep($_ eq $cat[0], @lang_cat)) {
@@ -1728,6 +1762,7 @@ sub checkextra {
$str = "\n" . $str if ($str !~ /^\n/);
$str =~ s/\n#[^\n]*/\n/g;
+ $str =~ s/\n\.[^\n]+/\n/g;
$str =~ s/\n\n+/\n/g;
$str =~ s/^\s+//;
$str =~ s/\s+$//;
@@ -1793,7 +1828,7 @@ sub checkearlier {
print "OK: checking items that has to appear earlier.\n" if ($verbose);
foreach my $i (@varnames) {
- if ($str =~ /\n$i[?+]?=/) {
+ if ($str =~ /\n$i\??=/) {
&perror("WARN: \"$i\" has to appear earlier in $file.");
}
}
OpenPOWER on IntegriCloud