diff options
author | marcus <marcus@FreeBSD.org> | 2004-06-06 09:06:33 +0800 |
---|---|---|
committer | marcus <marcus@FreeBSD.org> | 2004-06-06 09:06:33 +0800 |
commit | d5e78a8dbe9574d77a06655036c186ea68b99ee5 (patch) | |
tree | 013a0fac043ef16fca8253d865b42b200f7fdf88 /ports-mgmt | |
parent | 370a4a418f393599d15b4f00a6372dc970216594 (diff) | |
download | freebsd-ports-gnome-d5e78a8dbe9574d77a06655036c186ea68b99ee5.tar.gz freebsd-ports-gnome-d5e78a8dbe9574d77a06655036c186ea68b99ee5.tar.zst freebsd-ports-gnome-d5e78a8dbe9574d77a06655036c186ea68b99ee5.zip |
Update to 2.6.3.
* Add a generic check for deprecated macros (e.g. the recent autotools batch),
and add USE_MESA to the set [1]
* Only use USE_LIBTOOL_VER for checking .la file installation [1]
* Add a check for USE_LIBLTDL and warn about directly using a libltdl
dependency [1]
* Check distinfo to make sure each file in DISTFILES has SIZE and MD5 entries
if NO_SIZE and NO_CHECKSUM are not defined
Submitted by: krion and tobez [1]
Diffstat (limited to 'ports-mgmt')
-rw-r--r-- | ports-mgmt/portlint/Makefile | 2 | ||||
-rw-r--r-- | ports-mgmt/portlint/src/portlint.pl | 80 |
2 files changed, 57 insertions, 25 deletions
diff --git a/ports-mgmt/portlint/Makefile b/ports-mgmt/portlint/Makefile index 8b6e7523d843..6af05021b29e 100644 --- a/ports-mgmt/portlint/Makefile +++ b/ports-mgmt/portlint/Makefile @@ -8,7 +8,7 @@ # PORTNAME= portlint -PORTVERSION= 2.6.2 +PORTVERSION= 2.6.3 CATEGORIES= devel MASTER_SITES= # none DISTFILES= # none diff --git a/ports-mgmt/portlint/src/portlint.pl b/ports-mgmt/portlint/src/portlint.pl index a552ae3bac4f..d8a149ec7d3c 100644 --- a/ports-mgmt/portlint/src/portlint.pl +++ b/ports-mgmt/portlint/src/portlint.pl @@ -17,7 +17,7 @@ # OpenBSD and NetBSD will be accepted. # # $FreeBSD$ -# $Id: portlint.pl,v 1.47 2004/05/30 19:54:47 marcus Exp $ +# $Id: portlint.pl,v 1.48 2004/06/06 01:04:42 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 = 6; -my $micro = 2; +my $micro = 3; sub l { '[{(]'; } sub r { '[)}]'; } @@ -62,6 +62,7 @@ my $newxdef = 1; my $automan = 1; my $autoinfo = 1; my $use_no_size = 0; +my $use_no_checksum = 0; my $manchapters = '123456789ln'; my $localbase = '/usr/local'; @@ -174,8 +175,8 @@ my @varlist = qw( PKGNAMESUFFIX DISTNAME DISTFILES CATEGORIES MASTERDIR MAINTAINER MASTER_SITES WRKDIR WRKSRC NO_WRKSUBDIR PATCHDIR SCRIPTDIR FILESDIR PKGDIR COMMENT DESCR PLIST PKGCATEGORY PKGINSTALL PKGDEINSTALL - PKGREQ PKGMESSAGE MD5_FILE .CURDIR INSTALLS_SHLIB USE_LIBTOOL - USE_LIBTOOL_VER INDEXFILE PKGORIGIN + PKGREQ PKGMESSAGE MD5_FILE .CURDIR INSTALLS_SHLIB USE_LIBTOOL_VER + INDEXFILE PKGORIGIN ); my $cmd = join(' -V ', "make $makeenv MASTER_SITE_BACKUP=''", @varlist); @@ -500,16 +501,27 @@ exit $err; sub checkdistinfo { my($file) = @_; my($sizefound) = 0; + my(@distinfo) = (); + my(@distfiles) = (); + open(IN, "< $file") || return 0; - while (<IN>) { - if ($_ =~ /^SIZE/) { - $sizefound = 1; - } - } - if (!$sizefound && !$use_no_size) { - &perror("WARN: $file: does not contain SIZE."); - } + @distinfo = <IN>; close(IN); + + @distfiles = split(/\s+/, $makevar{DISTFILES}); + + foreach my $distfile (@distfiles) { + if (!(grep /^SIZE \(([^\)]*\/)?$distfile\)/, @distinfo) && + !$use_no_size) { + &perror("WARN: $file: no SIZE entry found for $distfile."); + } + if (!(grep /^MD5 \(([^\)]*\/)?$distfile\)/, @distinfo) && + !$use_no_checksum) { + &perror("WARN: $file: no MD5 entry found for $distfile."); + } + } + + 1; } # @@ -680,9 +692,8 @@ sub checkplist { "disallowed."); } - if ($_ =~ /\.la$/ && $makevar{USE_LIBTOOL} eq '' && - $makevar{USE_LIBTOOL_VER} eq '') { - &perror("WARN: $file [$.]: installing libtool archives, ". + if ($_ =~ /\.la$/ && $makevar{USE_LIBTOOL_VER} eq '') { + &perror("WARN: $file [$.]: installing libtool archives, ". "please use USE_LIBTOOL_VER in Makefile if possible. ". "See http://www.FreeBSD.org/gnome/docs/portlint.html ". "for a way to completely eliminate .la files."); @@ -957,6 +968,7 @@ sub checkmakefile { my(@mman, @pman); my($pkg_version, $versiondir, $versionfile) = ('', '', ''); my $useindex = 0; + my %deprecated = (); open(IN, "< $file") || return 0; $rawwhole = ''; @@ -1110,6 +1122,7 @@ sub checkmakefile { #$whole =~ s/\n\n+/\n/g; print "OK: checking NO_CHECKSUM.\n" if ($verbose); if ($whole =~ /\nNO_CHECKSUM/) { + $use_no_checksum = 1; my $lineno = &linenumber($`); &perror("FATAL: $file [$lineno]: use of NO_CHECKSUM discouraged. ". "it is intended to be a user variable."); @@ -1180,6 +1193,27 @@ sub checkmakefile { } # + # whole file: check for deprecated commands + # + print "OK: checking for deprecated macros.\n" if $verbose; + %deprecated = ( + USE_LIBTOOL => 'USE_LIBTOOL_VER', + USE_AUTOCONF => 'USE_AUTOHEADER_VER', + USE_AUTOMAKE => 'USE_AUTOMAKE_VER', + WANT_LIBTOOL => 'WANT_LIBTOOL_VER', + WANT_AUTOCONF => 'WANT_AUTOCONF_VER', + WANT_AUTOMAKE => 'WANT_AUTOMAKE_VER', + USE_MESA => 'USE_GL', + ); + + for my $depmacro (keys %deprecated) { + if ($whole =~ /\n($depmacro)[+?:!]?=/) { + &perror("FATAL: $file: $depmacro is ". + "deprecated, use $deprecated{$1} instead"); + } + } + + # # whole file: direct use of command names # my %cmdnames = (); @@ -1339,15 +1373,6 @@ pax perl printf rm rmdir ruby sed sh sort touch tr which xargs xmkmf } # - # whole file: check for deprecated USE_MESA - # - if ($whole =~ /^USE_MESA[?:]?=/m) { - my $lineno = &linenumber($`); - &perror("WARN: $file [$lineno]: USE_MESA is deprecated". - ". use USE_GL instead."); - } - - # # slave port check # my $masterdir = $makevar{MASTERDIR}; @@ -1968,6 +1993,13 @@ FETCH_DEPENDS DEPENDS DEPENDS_TARGET "USE_GETOPT_LONG."); } + # check LIBLTDL + if ($m{'dep'} =~ /^(ltdl\.\d)+$/) { + &perror("WARN: $file: dependency to $1 ". + "listed in $j. consider using ". + "USE_LIBLTDL."); + } + # check backslash in LIB_DEPENDS if ($osname eq 'NetBSD' && $j eq 'LIB_DEPENDS' && $m{'dep'} =~ /\\\\./) { |