summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--pkgtools/pkglint/Makefile4
-rwxr-xr-xpkgtools/pkglint/files/lintpkgsrc.pl337
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);
}