diff options
-rw-r--r-- | pkgtools/pkglint/Makefile | 4 | ||||
-rwxr-xr-x | pkgtools/pkglint/files/lintpkgsrc.pl | 337 |
2 files changed, 187 insertions, 154 deletions
diff --git a/pkgtools/pkglint/Makefile b/pkgtools/pkglint/Makefile index 2c178c15777..224da5ef791 100644 --- a/pkgtools/pkglint/Makefile +++ b/pkgtools/pkglint/Makefile @@ -1,7 +1,7 @@ -# $NetBSD: Makefile,v 1.22 1999/12/07 21:33:56 hubertf Exp $ +# $NetBSD: Makefile,v 1.23 1999/12/16 11:59:13 abs Exp $ # -DISTNAME= pkglint-1.81 +DISTNAME= pkglint-1.82 CATEGORIES= pkgtools devel MASTER_SITES= # empty DISTFILES= # empty diff --git a/pkgtools/pkglint/files/lintpkgsrc.pl b/pkgtools/pkglint/files/lintpkgsrc.pl index e789ab7a2cd..08a1e01a35d 100755 --- a/pkgtools/pkglint/files/lintpkgsrc.pl +++ b/pkgtools/pkglint/files/lintpkgsrc.pl @@ -1,6 +1,6 @@ #!/usr/bin/env perl -# $NetBSD: lintpkgsrc.pl,v 1.7 1999/11/12 13:18:03 abs Exp $ +# $NetBSD: lintpkgsrc.pl,v 1.8 1999/12/16 11:59:14 abs Exp $ # (Somewhat quickly) Written by David Brownlee <abs@netbsd.org>. # Caveats: @@ -10,41 +10,41 @@ # The 'invalid distfiles' code picks up a couple of false positives in # fastcap (which does strange things anyway). -require 'getopts.pl'; -$^W=1; +$^W = 1; use strict; +use Getopt::Std; use File::Find; -use vars qw($opt_P $opt_d $opt_h $opt_i $opt_l $opt_m $opt_o $opt_p $opt_r); -my(%pkg2dir,@oldprebuiltpackages); +my($pkgsrcdir, %pkgver2dir, %pkg2ver, %opt, @oldprebuiltpackages); -$ENV{PATH}.=':/usr/sbin'; +$ENV{PATH} .= ':/usr/sbin'; -if (! &Getopts('P:dhilmopr') || $opt_h || - ! ( defined($opt_d) || defined($opt_i) || defined($opt_l) || - defined($opt_m) || defined($opt_o) || defined($opt_p) || - defined($opt_r) )) +if (! &getopts('P:dhilmopr', \%opt) || $opt{'h'} || + ! ( defined($opt{'d'}) || defined($opt{'i'}) || defined($opt{'l'}) || + defined($opt{'m'}) || defined($opt{'o'}) || defined($opt{'p'}) || + defined($opt{'r'}) )) { &usage_and_exit; } -$|=1; +$| = 1; # main { - my($pkgsrcdir,$pkglint_flags); + my($pkglint_flags); - $pkglint_flags='-a -b -c -v'; - if ($opt_P) - { $pkgsrcdir=$opt_P; } # Check /etc/mk.conf for PKGSRCDIR + $pkglint_flags = '-a -b -c -v'; + if ($opt{'P'}) + { $pkgsrcdir = $opt{'P'}; } # Check /etc/mk.conf for PKGSRCDIR else - { $pkgsrcdir=&set_pkgsrcdir; } # Check /etc/mk.conf for PKGSRCDIR + { $pkgsrcdir = &set_pkgsrcdir; } # Check /etc/mk.conf for PKGSRCDIR - if ($opt_r && !$opt_o && !$opt_m && !$opt_p) - { $opt_o=$opt_m=$opt_p=1; } - if ($opt_o || $opt_m) + if ($opt{'r'} && !$opt{'o'} && !$opt{'m'} && !$opt{'p'}) + { $opt{'o'} = $opt{'m'} = $opt{'p'} = 1; } + if ($opt{'o'} || $opt{'m'}) { my(@baddist); - @baddist=&scan_pkgsrc_distfiles_vs_md5($pkgsrcdir,$opt_o,$opt_m); - if ($opt_r) + @baddist = &scan_pkgsrc_distfiles_vs_md5($pkgsrcdir, $opt{'o'}, + $opt{'m'}); + if ($opt{'r'}) { &safe_chdir("$pkgsrcdir/distfiles"); &verbose("Unlinking 'bad' distfiles\n"); @@ -53,12 +53,12 @@ $|=1; } } - if ($opt_p) + if ($opt{'p'}) { - if (!%pkg2dir) - { %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir); } - find(\&check_prebuilt_packages,"$pkgsrcdir/packages"); - if ($opt_r) + if (!%pkgver2dir) + { &scan_pkgsrc_makefiles($pkgsrcdir); } + find(\&check_prebuilt_packages, "$pkgsrcdir/packages"); + if ($opt{'r'}) { &verbose("Unlinking 'old' prebuiltpackages\n"); foreach (@oldprebuiltpackages) @@ -66,20 +66,23 @@ $|=1; } } - if ($opt_d) - { %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir,1); } - if ($opt_i) + if ($opt{'d'}) + { &scan_pkgsrc_makefiles($pkgsrcdir, 1); } + if ($opt{'i'}) { - my(@pkgs,$pkg); + my(@pkgs, $pkg); - @pkgs=&list_installed_packages; - if (!%pkg2dir) - { %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir); } + @pkgs = &list_installed_packages; + if (!%pkgver2dir) + { &scan_pkgsrc_makefiles($pkgsrcdir); } foreach $pkg ( @pkgs ) - { &list_possible_versions($pkg); } + { + if ( $_ = &invalid_version($pkg) ) + { print $_; } + } } - if ($opt_l) - { &pkglint_all_pkgsrc($pkgsrcdir,$pkglint_flags); } + if ($opt{'l'}) + { &pkglint_all_pkgsrc($pkgsrcdir, $pkglint_flags); } } exit; @@ -87,41 +90,40 @@ sub check_prebuilt_packages { if (/(.*)\.tgz$/) { - if (!defined($pkg2dir{$1})) + if (!defined($pkgver2dir{$1})) { print "$File::Find::dir/$_\n"; - push(@oldprebuiltpackages,"$File::Find::dir/$_"); + push(@oldprebuiltpackages, "$File::Find::dir/$_"); } } } sub fail - { print STDERR @_,"\n"; exit(3); } + { print STDERR @_, "\n"; exit(3); } -# Given a package, strip version and report possible matches +# Determine if a packake version is current. If not, report correct version +# if possible # -sub list_possible_versions +sub invalid_version { - my($pkg)=@_; - my($pkgname,@maybe,$fail,$len); + my($pkg) = @_; + my($pkgname, @maybe, $fail, $len); - if (!defined($pkg2dir{$pkg})) + if (!defined($pkgver2dir{$pkg})) { - $pkgname=$pkg; - $pkgname =~ s/-[^-]+$/-/; - $len=length($pkgname); - foreach ( sort keys %pkg2dir ) + # Handle wildcard package versions + if ( $pkg =~ /((.*)-(\d.*|))\*$/ ) # (package)-(ver)* { - if (substr($_,0,$len) eq $pkgname && substr($_,$len,1) =~ /[0-9]/) - { push(@maybe,$_); } + if (defined($pkg2ver{$2}) && + substr($pkg2ver{$2}, 0, length($1)) eq $1) + { return(undef); } } - $_="Unknown package: '$pkg'"; - if( @maybe ) - { $_.=" (Maybe @maybe)"; } + $pkgname = $pkg; + $pkgname =~ s/-[\d*].*$//; + if (defined($pkg2ver{$pkgname})) + { $fail = "Incorrect version: '$pkg' ($pkg2ver{$pkgname})\n"; } else - { $_.=" ($pkgname)"; } - print "$_\n"; - $fail=1; + { $fail = "Unknown: '$pkg' ($pkgname)\n"; } } $fail; } @@ -130,27 +132,27 @@ sub list_possible_versions # sub listdir { - my($base,$dir)=@_; - my($thisdir,$entry); - my(@list,@thislist); + my($base, $dir) = @_; + my($thisdir, $entry); + my(@list, @thislist); - $thisdir=$base; + $thisdir = $base; if (defined($dir)) { - $thisdir.="/$dir"; - $dir.='/'; + $thisdir .= "/$dir"; + $dir .= '/'; } else - { $dir=''; } - opendir(DIR,$thisdir) || &fail("Unable to opendir($thisdir): $!"); - @thislist=grep(substr($_,0,1) ne '.' && $_ ne 'CVS',readdir(DIR)); + { $dir = ''; } + opendir(DIR, $thisdir) || &fail("Unable to opendir($thisdir): $!"); + @thislist = grep(substr($_, 0, 1) ne '.' && $_ ne 'CVS', readdir(DIR)); closedir(DIR); foreach $entry (@thislist) { if (-d "$thisdir/$entry") - { push(@list,&listdir($base,"$dir$entry")); } + { push(@list, &listdir($base, "$dir$entry")); } else - { push(@list,"$dir$entry"); } + { push(@list, "$dir$entry"); } } @list; } @@ -161,9 +163,9 @@ sub list_installed_packages { my(@pkgs); - open(PKG_INFO,'pkg_info -a|') || &fail("Unable to run pkg_info: $!"); + open(PKG_INFO, 'pkg_info -a|') || &fail("Unable to run pkg_info: $!"); while ( <PKG_INFO> ) - { push(@pkgs,(split)[0]); } + { push(@pkgs, (split)[0]); } close(PKG_INFO); @pkgs; } @@ -172,11 +174,11 @@ sub list_installed_packages # sub list_pkgsrc_categories { - my($pkgsrcdir)=@_; + my($pkgsrcdir) = @_; my(@categories); - opendir(BASE,$pkgsrcdir) || die("Unable to opendir($pkgsrcdir): $!"); - @categories=grep(substr($_,0,1) ne '.' && -f "$pkgsrcdir/$_/Makefile", + opendir(BASE, $pkgsrcdir) || die("Unable to opendir($pkgsrcdir): $!"); + @categories = grep(substr($_, 0, 1) ne '.' && -f "$pkgsrcdir/$_/Makefile", readdir(BASE)); closedir(BASE); @categories; @@ -187,52 +189,73 @@ sub list_pkgsrc_categories # sub parse_makefile { - my($file)=@_; - my($pkgname,%vars); - my($key,$plus,$value); + my($file) = @_; + my($pkgname, %vars); + my($key, $plus, $value, @data); - if (open(FILE,$file)) + if (! open(FILE, $file)) + { return(undef); } + @data = <FILE>; + close(FILE); + + while( $_ = shift(@data) ) { - while( <FILE> ) + s/#.*//; + if ( m#^\.include "([^"]+)"# ) { - s/#.*//; - if (/^\s*(\w+)(\+?)=\s+(\S*)/) + $_ = $1; + if (! m#/mk/#) { - $key=$1; - $plus=$2; - $value=$3; - if ($plus) - { $vars{$key}.="\n$value"; } + my($newfile) = ($file); + + $newfile =~ s#[^/]+$#$_#; # Use old file to + # determine path to new + if (!open(FILE, $newfile)) + { &verbose("Unable to open '$newfile': $!\n"); } else - { $vars{$key}=$value; } - } + { + unshift(@data, <FILE>); + close(FILE); + } + } + next; } - foreach $key ( keys %vars, keys %vars) + + if (/^\s*(\w+)([+?]?)=\s*(\S*)/) { - foreach $value ( keys %vars ) + $key = $1; + $plus = $2; + $value = $3; + if ($plus eq '+') + { $vars{$key} .= "\n$value"; } + elsif ($plus ne '?' || !defined($vars{$key}) ) + { $vars{$key} = $value; } + } + } + foreach $key ( keys %vars, keys %vars) + { + foreach $value ( keys %vars ) + { + if ($vars{$key} =~ m#\${(\w+):S/([^/]+)/([^/]*)/}#) { - if ($vars{$key} =~ m#\${(\w+):S/(\w+)/(\w+)/}#) - { - my($var,$from,$to)=($1,$2,$3); + my($var, $from, $to) = ($1, $2, $3); - if (defined($vars{$var})) - { - $_=$vars{$var}; - s/$from/$to/; - $vars{$key} =~ s#\${$var:S/$from/$to/}#$_#; - } + if (defined($vars{$var})) + { + $_ = $vars{$var}; + s/$from/$to/; + $vars{$key} =~ s#\${$var:S/$from/$to/}#$_#; } - $vars{$key} =~ s/\$\{$value\}/$vars{$value}/g; } + $vars{$key} =~ s/\$\{$value\}/$vars{$value}/g; } - close(FILE); } if (defined($vars{'PKGNAME'})) - { $pkgname=$vars{'PKGNAME'}; } + { $pkgname = $vars{'PKGNAME'}; } elsif (defined($vars{'DISTNAME'})) - { $pkgname=$vars{'DISTNAME'}; } + { $pkgname = $vars{'DISTNAME'}; } if (defined($pkgname)) - { return($pkgname,%vars); } + { return($pkgname, %vars); } else { return(undef); } } @@ -241,32 +264,32 @@ sub parse_makefile # sub pkglint_all_pkgsrc { - my($pkgsrcdir,$pkglint_flags)=@_; - my($cat,$pkg,@categories,@output); + my($pkgsrcdir, $pkglint_flags) = @_; + my($cat, $pkg, @categories, @output); - @categories=&list_pkgsrc_categories($pkgsrcdir); + @categories = &list_pkgsrc_categories($pkgsrcdir); foreach $cat ( sort @categories ) { &safe_chdir("$pkgsrcdir/$cat"); - if (! opendir(CAT,'.')) + if (! opendir(CAT, '.')) { die("Unable to opendir($pkgsrcdir/$cat): $!"); } - foreach $pkg ( grep(substr($_,0,1) ne '.',readdir(CAT) ) ) + foreach $pkg ( grep(substr($_, 0, 1) ne '.', readdir(CAT) ) ) { if (-f "$pkg/Makefile") { - if (!open(PKGLINT,"pkglint $pkglint_flags $pkg|")) + if (!open(PKGLINT, "pkglint $pkglint_flags $pkg|")) { &fail("Unable to run pkglint: $!"); } - @output=grep(!/^OK:/ && + @output = grep(!/^OK:/ && !/^WARN: be sure to cleanup .* work before/ && !/^WARN: is it a new port/ && !/^\d+ fatal errors and \d+ warnings found/ - ,<PKGLINT> ); + , <PKGLINT> ); close(PKGLINT); if (@output) { print "===> $cat/$pkg\n", "pkglint $pkglint_flags $pkg\n", - @output,"\n"; + @output, "\n"; } } } @@ -278,7 +301,7 @@ sub pkglint_all_pkgsrc # sub safe_chdir { - my($dir)=@_; + my($dir) = @_; if (! chdir($dir)) { &fail("Unable to chdir($dir): $!"); } @@ -288,74 +311,84 @@ sub safe_chdir # sub scan_pkgsrc_makefiles { - my($pkgsrcdir,$check_depends)=@_; - my($cat,@categories,$pkg,$pkgname); - my(%pkg2dir,%depends); + my($pkgsrcdir, $check_depends) = @_; + my($cat, @categories, $pkg, $pkgname); + my(%depends); - @categories=&list_pkgsrc_categories($pkgsrcdir); + @categories = &list_pkgsrc_categories($pkgsrcdir); &verbose("Scanning pkgsrc Makefiles: ".'_'x@categories."\b"x@categories); + # foreach $cat ( 'misc' ) # XXX foreach $cat ( sort @categories ) { - if (! opendir(CAT,"$pkgsrcdir/$cat")) + if (! opendir(CAT, "$pkgsrcdir/$cat")) { die("Unable to opendir($pkgsrcdir/$cat): $!"); } - foreach $pkg ( grep(substr($_,0,1) ne '.',readdir(CAT) ) ) + foreach $pkg ( grep(substr($_, 0, 1) ne '.', readdir(CAT) ) ) + # foreach $pkg ( 'staroffice' ) # XXX { my(%vars); - ($pkgname,%vars)=&parse_makefile("$pkgsrcdir/$cat/$pkg/Makefile"); + ($pkgname, %vars) = + &parse_makefile("$pkgsrcdir/$cat/$pkg/Makefile"); if ($pkgname) { - $pkg2dir{$pkgname}="$cat/$pkg"; + if ( $pkgname =~ /\$/ ) + { print "\rBogus: $pkgname $cat/$pkg\n"; } + else + { + $_ = $pkgname; + s/-\d.*//; + $pkg2ver{$_} = $pkgname; + } + $pkgver2dir{$pkgname} = "$cat/$pkg"; if (defined($vars{'DEPENDS'})) - { $depends{$pkgname}=$vars{'DEPENDS'}; } + { $depends{$pkgname} = $vars{'DEPENDS'}; } } } close(CAT); &verbose('.'); } - &verbose(' (',scalar(keys %pkg2dir)," packages)\n"); + &verbose(' (', scalar(keys %pkgver2dir), " packages)\n"); if ($check_depends) { foreach $pkg ( sort keys %depends ) { - my($err); - foreach (split("\n",$depends{$pkg})) + my($err, $msg); + foreach (split("\n", $depends{$pkg})) { s/:.*// || next; - if (!defined($pkg2dir{$_})) + if (($msg = &invalid_version($_)) ) { if (!defined($err)) - { print "DEPENDS errors for $pkg2dir{$pkg}:\n"; } - $err=1; - print "\t"; - &list_possible_versions($_); + { print "DEPENDS errors for $pkgver2dir{$pkg}:\n"; } + $err = 1; + print "\t$msg"; } } } } - %pkg2dir; + %pkgver2dir; } # Extract all md5 entries, then verify contents of distfiles # sub scan_pkgsrc_distfiles_vs_md5 { - my($pkgsrcdir,$check_unref,$check_md5)=@_; - my($cat,@categories,$pkg); - my(%distfiles,%md5,@distwarn,$file,$numpkg); - my(@distfiles,@bad_distfiles); + my($pkgsrcdir, $check_unref, $check_md5) = @_; + my($cat, @categories, $pkg); + my(%distfiles, %md5, @distwarn, $file, $numpkg); + my(@distfiles, @bad_distfiles); - @categories=&list_pkgsrc_categories($pkgsrcdir); + @categories = &list_pkgsrc_categories($pkgsrcdir); &verbose("Scanning pkgsrc md5s: ".'_'x@categories."\b"x@categories); - $numpkg=0; + $numpkg = 0; foreach $cat ( sort @categories ) { - if (! opendir(CAT,"$pkgsrcdir/$cat")) + if (! opendir(CAT, "$pkgsrcdir/$cat")) { die("Unable to opendir($pkgsrcdir/$cat): $!"); } - foreach $pkg ( grep(substr($_,0,1) ne '.',readdir(CAT) ) ) + foreach $pkg ( grep(substr($_, 0, 1) ne '.', readdir(CAT) ) ) { - if (open(MD5,"$pkgsrcdir/$cat/$pkg/files/md5")) + if (open(MD5, "$pkgsrcdir/$cat/$pkg/files/md5")) { ++$numpkg; while( <MD5> ) @@ -364,12 +397,12 @@ sub scan_pkgsrc_distfiles_vs_md5 { if (!defined($distfiles{$1})) { - $distfiles{$1}="$cat/$pkg"; - $md5{$1}=$2; + $distfiles{$1} = "$cat/$pkg"; + $md5{$1} = $2; } elsif( $md5{$1} ne $2 ) { - push(@distwarn,"md5 mismatch between '$1' in ". + push(@distwarn, "md5 mismatch between '$1' in ". "$cat/$pkg and $distfiles{$1}\n"); } } @@ -385,32 +418,32 @@ sub scan_pkgsrc_distfiles_vs_md5 foreach $file (&listdir("$pkgsrcdir/distfiles")) { if (!defined($distfiles{$file})) - { push(@bad_distfiles,$file); } + { push(@bad_distfiles, $file); } else - { push(@distfiles,$file); } + { push(@distfiles, $file); } } if ($check_unref && @bad_distfiles) { &verbose(scalar(@bad_distfiles), " unreferenced file(s) in '$pkgsrcdir/distfiles':\n"); - print join("\n",sort @bad_distfiles),"\n"; + print join("\n", sort @bad_distfiles), "\n"; } if ($check_md5) { if (@distwarn) { &verbose(@distwarn); } &verbose("md5 mismatches\n"); - @distfiles=sort @distfiles; + @distfiles = sort @distfiles; &safe_chdir("$pkgsrcdir/distfiles"); - open(MD5,"md5 @distfiles|") || &fail("Unable to run md5: $!"); + open(MD5, "md5 @distfiles|") || &fail("Unable to run md5: $!"); while (<MD5>) { if (m/^MD5 \(([^\)]+)\) = (\S+)/) { if ($md5{$1} ne 'IGNORE' && $md5{$1} ne $2) { - print $1,"\n"; - push(@bad_distfiles,$1); + print $1, "\n"; + push(@bad_distfiles, $1); } } } @@ -423,13 +456,13 @@ sub set_pkgsrcdir # Parse /etc/mk.conf (if present) for PKGSRCDIR { my($pkgsrcdir); - $pkgsrcdir='/usr/pkgsrc'; - if (open(MK_CONF,'/etc/mk.conf')) + $pkgsrcdir = '/usr/pkgsrc'; + if (open(MK_CONF, '/etc/mk.conf')) { while (<MK_CONF>) { if( /PKGSRCDIR\s*=\s*(\S+)/ ) - { $pkgsrcdir=$1; last; } + { $pkgsrcdir = $1; last; } } close(MK_CONF); } |