my ($name, $email); # Name & email of maintainer
if ($html) {
- print "<div class=\"package\"><pre>";
- print "<a name=\"$p\"><strong>Package:</strong></a> " . &wwwname($p);
+ print "<div class=\"package\"><pre>";
+ print "<a name=\"$p\"><strong>Package:</strong></a> " . scanlib::wwwname($p);
print " ($scanlib::section{$p}).\n";
print "<strong>Maintainer:</strong> ";
if (defined($scanlib::maintainer{$p})) {
- $_ = $scanlib::maintainer{$p};
- ($name,$email) = m/(.*) <([^>]*)>/;
+ if ($scanlib::maintainer{$p} =~ /(.*) <([^>]*)>/) {
+ ($name,$email) = ($1,$2);
+ } elsif ($scanlib::maintainer{$p} =~ /<(.*) \((.*)\)>/) {
+ ($name,$email) = ($1,$2);
+ } elsif ($scanlib::maintainer{$p} =~ /<(.*)>/) {
+ $name = $email = $1;
+ }
print "$name <<a href=\"http://bugs.debian.org/$email\">$email</A>>\n";
} else {
print "unknown\n";
&PrintPackageHeader($p);
print $scanlib::comments{$p};
}
- for $nr (sort split(/ /, $scanlib::packagelist{$p})) {
+ for $nr (sort @{$scanlib::packagelist{$p}}) {
next if (defined $bugcfg::exclude{$nr});
if (! $header) {
$header = 1;
print "<strike>" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
print "<em class=\"worry\">" if $worry;
($sect=$nr) =~ s/([0-9]{2}).*/$1/;
- print "<A NAME=\"$nr\"></A> " . &wwwnumber($nr) . ' ' .
- htmlsanit($scanlib::bugs{$nr}) . "\n";
+ print "<A NAME=\"$nr\"></A> " . scanlib::wwwnumber($nr) . ' ' .
+ scanlib::htmlsanit($scanlib::bugs{$nr}) . "\n";
print "</em>" if $worry;
print "</strike>" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
} else {
sub MakeStatistics() {
- my $bugcount; # Total number of bugs so far
- my $count; # Number of bugs for this package
- my $remtotal; # Total number of bugs for packages marked REMOVE
- my $patchtotal; # Total number of bugs marked patch
- my $pendingtotal; # Total number of bugs marked pending
- my $ignoretotal; # Total number of bugs marked ignore
- my $nottestingtotal; # Total number of bugs on packages not in testing
- my $worrytotal; # Total number of bugs we're actually worried about
- my $p; # Index variable
+ my $bugcount=0; # Total number of bugs so far
+ my $remtotal=0; # Total number of bugs for packages marked REMOVE
+ my $patchtotal=0; # Total number of bugs marked patch
+ my $pendingtotal=0; # Total number of bugs marked pending
+ my $ignoretotal=0; # Total number of bugs marked ignore
+ my $nottestingtotal=0; # Total number of bugs on packages not in testing
+ my $worrytotal=0; # Total number of bugs we're actually worried about
my %list; # List of bugnumber associated with package
- $bugcount=0;
for my $p (sort keys %scanlib::packagelist) {
+ my $count = 0; # Number of bugs for this package
+
next if (defined $scanlib::exclude{$p});
- $count=0;
- for my $nr (split(/ /, $scanlib::packagelist{$p})) {
+ for my $nr (@{$scanlib::packagelist{$p}}) {
$pendingtotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*P/);
$patchtotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*\+/);
$ignoretotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*I/);
}
-sub FilterPackages() {
+sub FilterPackages($) {
my $filter = shift; # Distribution we want to keep
for my $p (sort keys %scanlib::packagelist) {
sub FilterBugs() {
for my $p (sort keys %scanlib::packagelist) {
- $scanlib::packagelist{$p} = join(' ', grep { check_worry($scanlib::bugs{$_}) } split / /, $scanlib::packagelist{$p});
- delete $scanlib::packagelist{$p} if ($scanlib::packagelist{$p} eq '');
+ $scanlib::packagelist{$p} = [ grep { scanlib::check_worry($scanlib::bugs{$_}) } @{$scanlib::packagelist{$p}} ];
+ delete $scanlib::packagelist{$p} if (scalar @{$scanlib::packagelist{$p}} == 0);
}
}
-my ($opt_h,$opt_V,$opt_S,$opt_C,$opt_H,$opt_d,$opt_t,$opt_s,$opt_l);
+our ($opt_h,$opt_V,$opt_S,$opt_C,$opt_H,$opt_d,$opt_t,$opt_s,$opt_l);
getopts('VhHlstd:S:C:');
ShowUsage if ($opt_h);
scanlib::readstatus($statusfile);
scanlib::readcomments($commentsfile);
-scanlib::readNMUstatus($NMUfile);
+# scanlib::readNMUstatus($NMUfile);
-&FilterPackages($opt_d) if ($opt_d);
-&FilterBugs() if ($opt_t);
+FilterPackages($opt_d) if ($opt_d);
+FilterBugs() if ($opt_t);
MakeStatistics if ($opt_s);
if ($opt_l) {
- MakeBuglist
+ MakeBuglist();
}
exit 0;