Update to handle wildcard dependencies
This commit is contained in:
parent
fd61b1c973
commit
2514942eb5
2 changed files with 191 additions and 158 deletions
|
@ -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
|
CATEGORIES= pkgtools devel
|
||||||
MASTER_SITES= # empty
|
MASTER_SITES= # empty
|
||||||
DISTFILES= # empty
|
DISTFILES= # empty
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/env perl
|
#!/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>.
|
# (Somewhat quickly) Written by David Brownlee <abs@netbsd.org>.
|
||||||
# Caveats:
|
# Caveats:
|
||||||
|
@ -10,41 +10,41 @@
|
||||||
# The 'invalid distfiles' code picks up a couple of false positives in
|
# The 'invalid distfiles' code picks up a couple of false positives in
|
||||||
# fastcap (which does strange things anyway).
|
# fastcap (which does strange things anyway).
|
||||||
|
|
||||||
require 'getopts.pl';
|
$^W = 1;
|
||||||
$^W=1;
|
|
||||||
use strict;
|
use strict;
|
||||||
|
use Getopt::Std;
|
||||||
use File::Find;
|
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($pkgsrcdir, %pkgver2dir, %pkg2ver, %opt, @oldprebuiltpackages);
|
||||||
my(%pkg2dir,@oldprebuiltpackages);
|
|
||||||
|
|
||||||
$ENV{PATH}.=':/usr/sbin';
|
$ENV{PATH} .= ':/usr/sbin';
|
||||||
|
|
||||||
if (! &Getopts('P:dhilmopr') || $opt_h ||
|
if (! &getopts('P:dhilmopr', \%opt) || $opt{'h'} ||
|
||||||
! ( defined($opt_d) || defined($opt_i) || defined($opt_l) ||
|
! ( defined($opt{'d'}) || defined($opt{'i'}) || defined($opt{'l'}) ||
|
||||||
defined($opt_m) || defined($opt_o) || defined($opt_p) ||
|
defined($opt{'m'}) || defined($opt{'o'}) || defined($opt{'p'}) ||
|
||||||
defined($opt_r) ))
|
defined($opt{'r'}) ))
|
||||||
{ &usage_and_exit; }
|
{ &usage_and_exit; }
|
||||||
$|=1;
|
$| = 1;
|
||||||
|
|
||||||
|
|
||||||
# main
|
# main
|
||||||
{
|
{
|
||||||
my($pkgsrcdir,$pkglint_flags);
|
my($pkglint_flags);
|
||||||
|
|
||||||
$pkglint_flags='-a -b -c -v';
|
$pkglint_flags = '-a -b -c -v';
|
||||||
if ($opt_P)
|
if ($opt{'P'})
|
||||||
{ $pkgsrcdir=$opt_P; } # Check /etc/mk.conf for PKGSRCDIR
|
{ $pkgsrcdir = $opt{'P'}; } # Check /etc/mk.conf for PKGSRCDIR
|
||||||
else
|
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)
|
if ($opt{'r'} && !$opt{'o'} && !$opt{'m'} && !$opt{'p'})
|
||||||
{ $opt_o=$opt_m=$opt_p=1; }
|
{ $opt{'o'} = $opt{'m'} = $opt{'p'} = 1; }
|
||||||
if ($opt_o || $opt_m)
|
if ($opt{'o'} || $opt{'m'})
|
||||||
{
|
{
|
||||||
my(@baddist);
|
my(@baddist);
|
||||||
|
|
||||||
@baddist=&scan_pkgsrc_distfiles_vs_md5($pkgsrcdir,$opt_o,$opt_m);
|
@baddist = &scan_pkgsrc_distfiles_vs_md5($pkgsrcdir, $opt{'o'},
|
||||||
if ($opt_r)
|
$opt{'m'});
|
||||||
|
if ($opt{'r'})
|
||||||
{
|
{
|
||||||
&safe_chdir("$pkgsrcdir/distfiles");
|
&safe_chdir("$pkgsrcdir/distfiles");
|
||||||
&verbose("Unlinking 'bad' distfiles\n");
|
&verbose("Unlinking 'bad' distfiles\n");
|
||||||
|
@ -53,12 +53,12 @@ $|=1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($opt_p)
|
if ($opt{'p'})
|
||||||
{
|
{
|
||||||
if (!%pkg2dir)
|
if (!%pkgver2dir)
|
||||||
{ %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir); }
|
{ &scan_pkgsrc_makefiles($pkgsrcdir); }
|
||||||
find(\&check_prebuilt_packages,"$pkgsrcdir/packages");
|
find(\&check_prebuilt_packages, "$pkgsrcdir/packages");
|
||||||
if ($opt_r)
|
if ($opt{'r'})
|
||||||
{
|
{
|
||||||
&verbose("Unlinking 'old' prebuiltpackages\n");
|
&verbose("Unlinking 'old' prebuiltpackages\n");
|
||||||
foreach (@oldprebuiltpackages)
|
foreach (@oldprebuiltpackages)
|
||||||
|
@ -66,20 +66,23 @@ $|=1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($opt_d)
|
if ($opt{'d'})
|
||||||
{ %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir,1); }
|
{ &scan_pkgsrc_makefiles($pkgsrcdir, 1); }
|
||||||
if ($opt_i)
|
if ($opt{'i'})
|
||||||
{
|
{
|
||||||
my(@pkgs,$pkg);
|
my(@pkgs, $pkg);
|
||||||
|
|
||||||
@pkgs=&list_installed_packages;
|
@pkgs = &list_installed_packages;
|
||||||
if (!%pkg2dir)
|
if (!%pkgver2dir)
|
||||||
{ %pkg2dir=&scan_pkgsrc_makefiles($pkgsrcdir); }
|
{ &scan_pkgsrc_makefiles($pkgsrcdir); }
|
||||||
foreach $pkg ( @pkgs )
|
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;
|
exit;
|
||||||
|
|
||||||
|
@ -87,41 +90,40 @@ sub check_prebuilt_packages
|
||||||
{
|
{
|
||||||
if (/(.*)\.tgz$/)
|
if (/(.*)\.tgz$/)
|
||||||
{
|
{
|
||||||
if (!defined($pkg2dir{$1}))
|
if (!defined($pkgver2dir{$1}))
|
||||||
{
|
{
|
||||||
print "$File::Find::dir/$_\n";
|
print "$File::Find::dir/$_\n";
|
||||||
push(@oldprebuiltpackages,"$File::Find::dir/$_");
|
push(@oldprebuiltpackages, "$File::Find::dir/$_");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub fail
|
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($pkg) = @_;
|
||||||
my($pkgname,@maybe,$fail,$len);
|
my($pkgname, @maybe, $fail, $len);
|
||||||
|
|
||||||
if (!defined($pkg2dir{$pkg}))
|
if (!defined($pkgver2dir{$pkg}))
|
||||||
{
|
{
|
||||||
$pkgname=$pkg;
|
# Handle wildcard package versions
|
||||||
$pkgname =~ s/-[^-]+$/-/;
|
if ( $pkg =~ /((.*)-(\d.*|))\*$/ ) # (package)-(ver)*
|
||||||
$len=length($pkgname);
|
|
||||||
foreach ( sort keys %pkg2dir )
|
|
||||||
{
|
{
|
||||||
if (substr($_,0,$len) eq $pkgname && substr($_,$len,1) =~ /[0-9]/)
|
if (defined($pkg2ver{$2}) &&
|
||||||
{ push(@maybe,$_); }
|
substr($pkg2ver{$2}, 0, length($1)) eq $1)
|
||||||
|
{ return(undef); }
|
||||||
}
|
}
|
||||||
$_="Unknown package: '$pkg'";
|
$pkgname = $pkg;
|
||||||
if( @maybe )
|
$pkgname =~ s/-[\d*].*$//;
|
||||||
{ $_.=" (Maybe @maybe)"; }
|
if (defined($pkg2ver{$pkgname}))
|
||||||
|
{ $fail = "Incorrect version: '$pkg' ($pkg2ver{$pkgname})\n"; }
|
||||||
else
|
else
|
||||||
{ $_.=" ($pkgname)"; }
|
{ $fail = "Unknown: '$pkg' ($pkgname)\n"; }
|
||||||
print "$_\n";
|
|
||||||
$fail=1;
|
|
||||||
}
|
}
|
||||||
$fail;
|
$fail;
|
||||||
}
|
}
|
||||||
|
@ -130,27 +132,27 @@ sub list_possible_versions
|
||||||
#
|
#
|
||||||
sub listdir
|
sub listdir
|
||||||
{
|
{
|
||||||
my($base,$dir)=@_;
|
my($base, $dir) = @_;
|
||||||
my($thisdir,$entry);
|
my($thisdir, $entry);
|
||||||
my(@list,@thislist);
|
my(@list, @thislist);
|
||||||
|
|
||||||
$thisdir=$base;
|
$thisdir = $base;
|
||||||
if (defined($dir))
|
if (defined($dir))
|
||||||
{
|
{
|
||||||
$thisdir.="/$dir";
|
$thisdir .= "/$dir";
|
||||||
$dir.='/';
|
$dir .= '/';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{ $dir=''; }
|
{ $dir = ''; }
|
||||||
opendir(DIR,$thisdir) || &fail("Unable to opendir($thisdir): $!");
|
opendir(DIR, $thisdir) || &fail("Unable to opendir($thisdir): $!");
|
||||||
@thislist=grep(substr($_,0,1) ne '.' && $_ ne 'CVS',readdir(DIR));
|
@thislist = grep(substr($_, 0, 1) ne '.' && $_ ne 'CVS', readdir(DIR));
|
||||||
closedir(DIR);
|
closedir(DIR);
|
||||||
foreach $entry (@thislist)
|
foreach $entry (@thislist)
|
||||||
{
|
{
|
||||||
if (-d "$thisdir/$entry")
|
if (-d "$thisdir/$entry")
|
||||||
{ push(@list,&listdir($base,"$dir$entry")); }
|
{ push(@list, &listdir($base, "$dir$entry")); }
|
||||||
else
|
else
|
||||||
{ push(@list,"$dir$entry"); }
|
{ push(@list, "$dir$entry"); }
|
||||||
}
|
}
|
||||||
@list;
|
@list;
|
||||||
}
|
}
|
||||||
|
@ -161,9 +163,9 @@ sub list_installed_packages
|
||||||
{
|
{
|
||||||
my(@pkgs);
|
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> )
|
while ( <PKG_INFO> )
|
||||||
{ push(@pkgs,(split)[0]); }
|
{ push(@pkgs, (split)[0]); }
|
||||||
close(PKG_INFO);
|
close(PKG_INFO);
|
||||||
@pkgs;
|
@pkgs;
|
||||||
}
|
}
|
||||||
|
@ -172,11 +174,11 @@ sub list_installed_packages
|
||||||
#
|
#
|
||||||
sub list_pkgsrc_categories
|
sub list_pkgsrc_categories
|
||||||
{
|
{
|
||||||
my($pkgsrcdir)=@_;
|
my($pkgsrcdir) = @_;
|
||||||
my(@categories);
|
my(@categories);
|
||||||
|
|
||||||
opendir(BASE,$pkgsrcdir) || die("Unable to opendir($pkgsrcdir): $!");
|
opendir(BASE, $pkgsrcdir) || die("Unable to opendir($pkgsrcdir): $!");
|
||||||
@categories=grep(substr($_,0,1) ne '.' && -f "$pkgsrcdir/$_/Makefile",
|
@categories = grep(substr($_, 0, 1) ne '.' && -f "$pkgsrcdir/$_/Makefile",
|
||||||
readdir(BASE));
|
readdir(BASE));
|
||||||
closedir(BASE);
|
closedir(BASE);
|
||||||
@categories;
|
@categories;
|
||||||
|
@ -187,37 +189,60 @@ sub list_pkgsrc_categories
|
||||||
#
|
#
|
||||||
sub parse_makefile
|
sub parse_makefile
|
||||||
{
|
{
|
||||||
my($file)=@_;
|
my($file) = @_;
|
||||||
my($pkgname,%vars);
|
my($pkgname, %vars);
|
||||||
my($key,$plus,$value);
|
my($key, $plus, $value, @data);
|
||||||
|
|
||||||
if (open(FILE,$file))
|
if (! open(FILE, $file))
|
||||||
{
|
{ return(undef); }
|
||||||
while( <FILE> )
|
@data = <FILE>;
|
||||||
|
close(FILE);
|
||||||
|
|
||||||
|
while( $_ = shift(@data) )
|
||||||
{
|
{
|
||||||
s/#.*//;
|
s/#.*//;
|
||||||
if (/^\s*(\w+)(\+?)=\s+(\S*)/)
|
if ( m#^\.include "([^"]+)"# )
|
||||||
{
|
{
|
||||||
$key=$1;
|
$_ = $1;
|
||||||
$plus=$2;
|
if (! m#/mk/#)
|
||||||
$value=$3;
|
{
|
||||||
if ($plus)
|
my($newfile) = ($file);
|
||||||
{ $vars{$key}.="\n$value"; }
|
|
||||||
|
$newfile =~ s#[^/]+$#$_#; # Use old file to
|
||||||
|
# determine path to new
|
||||||
|
if (!open(FILE, $newfile))
|
||||||
|
{ &verbose("Unable to open '$newfile': $!\n"); }
|
||||||
else
|
else
|
||||||
{ $vars{$key}=$value; }
|
{
|
||||||
|
unshift(@data, <FILE>);
|
||||||
|
close(FILE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (/^\s*(\w+)([+?]?)=\s*(\S*)/)
|
||||||
|
{
|
||||||
|
$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 $key ( keys %vars, keys %vars)
|
||||||
{
|
{
|
||||||
foreach $value ( keys %vars )
|
foreach $value ( keys %vars )
|
||||||
{
|
{
|
||||||
if ($vars{$key} =~ m#\${(\w+):S/(\w+)/(\w+)/}#)
|
if ($vars{$key} =~ m#\${(\w+):S/([^/]+)/([^/]*)/}#)
|
||||||
{
|
{
|
||||||
my($var,$from,$to)=($1,$2,$3);
|
my($var, $from, $to) = ($1, $2, $3);
|
||||||
|
|
||||||
if (defined($vars{$var}))
|
if (defined($vars{$var}))
|
||||||
{
|
{
|
||||||
$_=$vars{$var};
|
$_ = $vars{$var};
|
||||||
s/$from/$to/;
|
s/$from/$to/;
|
||||||
$vars{$key} =~ s#\${$var:S/$from/$to/}#$_#;
|
$vars{$key} =~ s#\${$var:S/$from/$to/}#$_#;
|
||||||
}
|
}
|
||||||
|
@ -225,14 +250,12 @@ sub parse_makefile
|
||||||
$vars{$key} =~ s/\$\{$value\}/$vars{$value}/g;
|
$vars{$key} =~ s/\$\{$value\}/$vars{$value}/g;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
if (defined($vars{'PKGNAME'}))
|
if (defined($vars{'PKGNAME'}))
|
||||||
{ $pkgname=$vars{'PKGNAME'}; }
|
{ $pkgname = $vars{'PKGNAME'}; }
|
||||||
elsif (defined($vars{'DISTNAME'}))
|
elsif (defined($vars{'DISTNAME'}))
|
||||||
{ $pkgname=$vars{'DISTNAME'}; }
|
{ $pkgname = $vars{'DISTNAME'}; }
|
||||||
if (defined($pkgname))
|
if (defined($pkgname))
|
||||||
{ return($pkgname,%vars); }
|
{ return($pkgname, %vars); }
|
||||||
else
|
else
|
||||||
{ return(undef); }
|
{ return(undef); }
|
||||||
}
|
}
|
||||||
|
@ -241,32 +264,32 @@ sub parse_makefile
|
||||||
#
|
#
|
||||||
sub pkglint_all_pkgsrc
|
sub pkglint_all_pkgsrc
|
||||||
{
|
{
|
||||||
my($pkgsrcdir,$pkglint_flags)=@_;
|
my($pkgsrcdir, $pkglint_flags) = @_;
|
||||||
my($cat,$pkg,@categories,@output);
|
my($cat, $pkg, @categories, @output);
|
||||||
|
|
||||||
@categories=&list_pkgsrc_categories($pkgsrcdir);
|
@categories = &list_pkgsrc_categories($pkgsrcdir);
|
||||||
foreach $cat ( sort @categories )
|
foreach $cat ( sort @categories )
|
||||||
{
|
{
|
||||||
&safe_chdir("$pkgsrcdir/$cat");
|
&safe_chdir("$pkgsrcdir/$cat");
|
||||||
if (! opendir(CAT,'.'))
|
if (! opendir(CAT, '.'))
|
||||||
{ die("Unable to opendir($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 (-f "$pkg/Makefile")
|
if (-f "$pkg/Makefile")
|
||||||
{
|
{
|
||||||
if (!open(PKGLINT,"pkglint $pkglint_flags $pkg|"))
|
if (!open(PKGLINT, "pkglint $pkglint_flags $pkg|"))
|
||||||
{ &fail("Unable to run pkglint: $!"); }
|
{ &fail("Unable to run pkglint: $!"); }
|
||||||
@output=grep(!/^OK:/ &&
|
@output = grep(!/^OK:/ &&
|
||||||
!/^WARN: be sure to cleanup .* work before/ &&
|
!/^WARN: be sure to cleanup .* work before/ &&
|
||||||
!/^WARN: is it a new port/ &&
|
!/^WARN: is it a new port/ &&
|
||||||
!/^\d+ fatal errors and \d+ warnings found/
|
!/^\d+ fatal errors and \d+ warnings found/
|
||||||
,<PKGLINT> );
|
, <PKGLINT> );
|
||||||
close(PKGLINT);
|
close(PKGLINT);
|
||||||
if (@output)
|
if (@output)
|
||||||
{
|
{
|
||||||
print "===> $cat/$pkg\n",
|
print "===> $cat/$pkg\n",
|
||||||
"pkglint $pkglint_flags $pkg\n",
|
"pkglint $pkglint_flags $pkg\n",
|
||||||
@output,"\n";
|
@output, "\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -278,7 +301,7 @@ sub pkglint_all_pkgsrc
|
||||||
#
|
#
|
||||||
sub safe_chdir
|
sub safe_chdir
|
||||||
{
|
{
|
||||||
my($dir)=@_;
|
my($dir) = @_;
|
||||||
|
|
||||||
if (! chdir($dir))
|
if (! chdir($dir))
|
||||||
{ &fail("Unable to chdir($dir): $!"); }
|
{ &fail("Unable to chdir($dir): $!"); }
|
||||||
|
@ -288,74 +311,84 @@ sub safe_chdir
|
||||||
#
|
#
|
||||||
sub scan_pkgsrc_makefiles
|
sub scan_pkgsrc_makefiles
|
||||||
{
|
{
|
||||||
my($pkgsrcdir,$check_depends)=@_;
|
my($pkgsrcdir, $check_depends) = @_;
|
||||||
my($cat,@categories,$pkg,$pkgname);
|
my($cat, @categories, $pkg, $pkgname);
|
||||||
my(%pkg2dir,%depends);
|
my(%depends);
|
||||||
|
|
||||||
@categories=&list_pkgsrc_categories($pkgsrcdir);
|
@categories = &list_pkgsrc_categories($pkgsrcdir);
|
||||||
&verbose("Scanning pkgsrc Makefiles: ".'_'x@categories."\b"x@categories);
|
&verbose("Scanning pkgsrc Makefiles: ".'_'x@categories."\b"x@categories);
|
||||||
|
# foreach $cat ( 'misc' ) # XXX
|
||||||
foreach $cat ( sort @categories )
|
foreach $cat ( sort @categories )
|
||||||
{
|
{
|
||||||
if (! opendir(CAT,"$pkgsrcdir/$cat"))
|
if (! opendir(CAT, "$pkgsrcdir/$cat"))
|
||||||
{ die("Unable to opendir($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);
|
my(%vars);
|
||||||
($pkgname,%vars)=&parse_makefile("$pkgsrcdir/$cat/$pkg/Makefile");
|
($pkgname, %vars) =
|
||||||
|
&parse_makefile("$pkgsrcdir/$cat/$pkg/Makefile");
|
||||||
if ($pkgname)
|
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'}))
|
if (defined($vars{'DEPENDS'}))
|
||||||
{ $depends{$pkgname}=$vars{'DEPENDS'}; }
|
{ $depends{$pkgname} = $vars{'DEPENDS'}; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
close(CAT);
|
close(CAT);
|
||||||
&verbose('.');
|
&verbose('.');
|
||||||
}
|
}
|
||||||
&verbose(' (',scalar(keys %pkg2dir)," packages)\n");
|
&verbose(' (', scalar(keys %pkgver2dir), " packages)\n");
|
||||||
|
|
||||||
if ($check_depends)
|
if ($check_depends)
|
||||||
{
|
{
|
||||||
foreach $pkg ( sort keys %depends )
|
foreach $pkg ( sort keys %depends )
|
||||||
{
|
{
|
||||||
my($err);
|
my($err, $msg);
|
||||||
foreach (split("\n",$depends{$pkg}))
|
foreach (split("\n", $depends{$pkg}))
|
||||||
{
|
{
|
||||||
s/:.*// || next;
|
s/:.*// || next;
|
||||||
if (!defined($pkg2dir{$_}))
|
if (($msg = &invalid_version($_)) )
|
||||||
{
|
{
|
||||||
if (!defined($err))
|
if (!defined($err))
|
||||||
{ print "DEPENDS errors for $pkg2dir{$pkg}:\n"; }
|
{ print "DEPENDS errors for $pkgver2dir{$pkg}:\n"; }
|
||||||
$err=1;
|
$err = 1;
|
||||||
print "\t";
|
print "\t$msg";
|
||||||
&list_possible_versions($_);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
%pkg2dir;
|
%pkgver2dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
# Extract all md5 entries, then verify contents of distfiles
|
# Extract all md5 entries, then verify contents of distfiles
|
||||||
#
|
#
|
||||||
sub scan_pkgsrc_distfiles_vs_md5
|
sub scan_pkgsrc_distfiles_vs_md5
|
||||||
{
|
{
|
||||||
my($pkgsrcdir,$check_unref,$check_md5)=@_;
|
my($pkgsrcdir, $check_unref, $check_md5) = @_;
|
||||||
my($cat,@categories,$pkg);
|
my($cat, @categories, $pkg);
|
||||||
my(%distfiles,%md5,@distwarn,$file,$numpkg);
|
my(%distfiles, %md5, @distwarn, $file, $numpkg);
|
||||||
my(@distfiles,@bad_distfiles);
|
my(@distfiles, @bad_distfiles);
|
||||||
|
|
||||||
@categories=&list_pkgsrc_categories($pkgsrcdir);
|
@categories = &list_pkgsrc_categories($pkgsrcdir);
|
||||||
|
|
||||||
&verbose("Scanning pkgsrc md5s: ".'_'x@categories."\b"x@categories);
|
&verbose("Scanning pkgsrc md5s: ".'_'x@categories."\b"x@categories);
|
||||||
$numpkg=0;
|
$numpkg = 0;
|
||||||
foreach $cat ( sort @categories )
|
foreach $cat ( sort @categories )
|
||||||
{
|
{
|
||||||
if (! opendir(CAT,"$pkgsrcdir/$cat"))
|
if (! opendir(CAT, "$pkgsrcdir/$cat"))
|
||||||
{ die("Unable to opendir($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;
|
++$numpkg;
|
||||||
while( <MD5> )
|
while( <MD5> )
|
||||||
|
@ -364,12 +397,12 @@ sub scan_pkgsrc_distfiles_vs_md5
|
||||||
{
|
{
|
||||||
if (!defined($distfiles{$1}))
|
if (!defined($distfiles{$1}))
|
||||||
{
|
{
|
||||||
$distfiles{$1}="$cat/$pkg";
|
$distfiles{$1} = "$cat/$pkg";
|
||||||
$md5{$1}=$2;
|
$md5{$1} = $2;
|
||||||
}
|
}
|
||||||
elsif( $md5{$1} ne $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");
|
"$cat/$pkg and $distfiles{$1}\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -385,32 +418,32 @@ sub scan_pkgsrc_distfiles_vs_md5
|
||||||
foreach $file (&listdir("$pkgsrcdir/distfiles"))
|
foreach $file (&listdir("$pkgsrcdir/distfiles"))
|
||||||
{
|
{
|
||||||
if (!defined($distfiles{$file}))
|
if (!defined($distfiles{$file}))
|
||||||
{ push(@bad_distfiles,$file); }
|
{ push(@bad_distfiles, $file); }
|
||||||
else
|
else
|
||||||
{ push(@distfiles,$file); }
|
{ push(@distfiles, $file); }
|
||||||
}
|
}
|
||||||
if ($check_unref && @bad_distfiles)
|
if ($check_unref && @bad_distfiles)
|
||||||
{
|
{
|
||||||
&verbose(scalar(@bad_distfiles),
|
&verbose(scalar(@bad_distfiles),
|
||||||
" unreferenced file(s) in '$pkgsrcdir/distfiles':\n");
|
" 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 ($check_md5)
|
||||||
{
|
{
|
||||||
if (@distwarn)
|
if (@distwarn)
|
||||||
{ &verbose(@distwarn); }
|
{ &verbose(@distwarn); }
|
||||||
&verbose("md5 mismatches\n");
|
&verbose("md5 mismatches\n");
|
||||||
@distfiles=sort @distfiles;
|
@distfiles = sort @distfiles;
|
||||||
&safe_chdir("$pkgsrcdir/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>)
|
while (<MD5>)
|
||||||
{
|
{
|
||||||
if (m/^MD5 \(([^\)]+)\) = (\S+)/)
|
if (m/^MD5 \(([^\)]+)\) = (\S+)/)
|
||||||
{
|
{
|
||||||
if ($md5{$1} ne 'IGNORE' && $md5{$1} ne $2)
|
if ($md5{$1} ne 'IGNORE' && $md5{$1} ne $2)
|
||||||
{
|
{
|
||||||
print $1,"\n";
|
print $1, "\n";
|
||||||
push(@bad_distfiles,$1);
|
push(@bad_distfiles, $1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -423,13 +456,13 @@ sub set_pkgsrcdir # Parse /etc/mk.conf (if present) for PKGSRCDIR
|
||||||
{
|
{
|
||||||
my($pkgsrcdir);
|
my($pkgsrcdir);
|
||||||
|
|
||||||
$pkgsrcdir='/usr/pkgsrc';
|
$pkgsrcdir = '/usr/pkgsrc';
|
||||||
if (open(MK_CONF,'/etc/mk.conf'))
|
if (open(MK_CONF, '/etc/mk.conf'))
|
||||||
{
|
{
|
||||||
while (<MK_CONF>)
|
while (<MK_CONF>)
|
||||||
{
|
{
|
||||||
if( /PKGSRCDIR\s*=\s*(\S+)/ )
|
if( /PKGSRCDIR\s*=\s*(\S+)/ )
|
||||||
{ $pkgsrcdir=$1; last; }
|
{ $pkgsrcdir = $1; last; }
|
||||||
}
|
}
|
||||||
close(MK_CONF);
|
close(MK_CONF);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue