X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=bugreport;h=f9654bbd03aefb2e94070aa96737de20ac731c18;hb=6cc0aae01abb47bb8732c9b07a889e8697a0169e;hp=f6be50a60c198761dde79b126e90981cf1b43048;hpb=e23f39acb49098e01f20a8e6fdc9f68d296b45ed;p=bugscan.git diff --git a/bugreport b/bugreport index f6be50a..f9654bb 100755 --- a/bugreport +++ b/bugreport @@ -45,13 +45,18 @@ sub PrintPackageHeader() { my ($name, $email); # Name & email of maintainer if ($html) { - print "
"; - print "Package: " . &wwwname($p); + print ""; + print "Package: " . scanlib::wwwname($p); print " ($scanlib::section{$p}).\n"; print "Maintainer: "; 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 <$email>\n"; } else { print "unknown\n"; @@ -77,7 +82,7 @@ sub MakeBuglist() { my $header; # Flag if packagename has already been printed my $fontset; # Did we change the font? - for my $p (sort {$a cmp $b} keys %scanlib::packagelist) { + for my $p (sort {$a->[0] <=> $b->[0]} keys %scanlib::packagelist) { next if (defined $bugcfg::exclude{$p}); $header = 0; $fontset = 0; @@ -92,137 +97,3 @@ sub MakeBuglist() { &PrintPackageHeader($p); print $scanlib::comments{$p}; } - for $nr (sort split(/ /, $scanlib::packagelist{$p})) { - next if (defined $bugcfg::exclude{$nr}); - if (! $header) { - $header = 1; - &PrintPackageHeader($p); - } - - if ($html) { - my $worry = scanlib::check_worry($scanlib::bugs{$nr}); - - if ($scanlib::bugs{$nr} =~ m/ \[[^]]*X/) { - print ''; - } elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*P/) { - print ''; - } elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*\+/) { - print ''; - } elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*H/) { - print ''; - } - print "" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/); - print "" if $worry; - ($sect=$nr) =~ s/([0-9]{2}).*/$1/; - print " " . &wwwnumber($nr) . ' ' . - htmlsanit($scanlib::bugs{$nr}) . "\n"; - print "" if $worry; - print "" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/); - } else { - printf(" %-6d %s\n", $nr, $scanlib::bugs{$nr}); - } - print $scanlib::comments{$nr} if (defined($scanlib::comments{$nr})); - print "[FIX] Fixed by package " . $scanlib::NMU{$nr, "source"} . ", version " . $scanlib::NMU{$nr, "version"} . " in Incoming\n" if (defined $scanlib::NMU{$nr}); - print "" if ($html && ($scanlib::bugs{$nr} =~ m/^\[[^]]*[H+P]/ || - $scanlib::bugs{$nr} =~ m/ \[[^]]*X/)); - } - print "" if ($fontset); - if ($header) { - &PrintPackageFooter($p); - } - } -} - - -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 %list; # List of bugnumber associated with package - - $bugcount=0; - for my $p (sort keys %scanlib::packagelist) { - next if (defined $scanlib::exclude{$p}); - $count=0; - for my $nr (split(/ /, $scanlib::packagelist{$p})) { - $pendingtotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*P/); - $patchtotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*\+/); - $ignoretotal++ if ($scanlib::bugs{$nr} =~ m/^\[[^]]*I/); - $nottestingtotal++ if ($scanlib::bugs{$nr} =~ m/ \[[^]]*X/); - $worrytotal++ unless ( - $scanlib::bugs{$nr} =~ m/^\[[^]]*I/ or - $scanlib::bugs{$nr} =~ m/ \[[^]]*X/ or - ($scanlib::bugs{$nr} =~ m/ \[[^]]*[OSUE]/ and $scanlib::bugs{$nr} !~ m/ \[[^]]*T/)); - - if (not defined($scanlib::exclude{$nr})) { - $bugcount++; - $count++; - } - } - $remtotal+=$count if (defined($scanlib::comments{$p}) && $scanlib::comments{$p} =~ m/^\[REMOVE\]/); - } - - if ($html) { - print "Total number of release-critical bugs: $bugcount
\n"; - printf("Number that will disappear after removing packages marked [REMOVE]: %d
\n", $remtotal); - printf("Number that have a patch: %d
\n", $patchtotal); - printf("Number that have a fix prepared and waiting to upload: %d
\n", $pendingtotal); - printf("Number that are being ignored: %d
\n", $ignoretotal); - printf("Number on packages not in testing: %d
\n", $nottestingtotal); - printf("Number concerning the next release (excluding ignored and not-in-testing): %d\n", $worrytotal); - } else { - print "Total number of release-critical bugs: $bugcount\n"; - printf("Number that will disappear after removing packages marked [REMOVE]: %d\n", $remtotal); - printf("Number that have a patch: %d\n", $patchtotal); - printf("Number that have a fix prepared and waiting to upload: %d\n", $pendingtotal); - printf("Number that are being ignored: %d\n", $ignoretotal); - printf("Number on packages not in testing: %d\n", $nottestingtotal); - printf("Number concerning the next release (excluding ignored and not-in-testing): %d\n", $worrytotal); - } -} - - -sub FilterPackages($) { - my $filter = shift; # Distribution we want to keep - - for my $p (sort keys %scanlib::packagelist) { - delete $scanlib::packagelist{$p} unless ($scanlib::section{$p} =~ m/^$filter/); - } -} - -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 ''); - } -} - -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); -ShowVersion if ($opt_V); -$statusfile=$opt_S if ($opt_S); -$commentsfile=$opt_C if ($opt_C); -$html=1 if ($opt_H); - -scanlib::readstatus($statusfile); -scanlib::readcomments($commentsfile); -# scanlib::readNMUstatus($NMUfile); - -FilterPackages($opt_d) if ($opt_d); -FilterBugs() if ($opt_t); - -MakeStatistics if ($opt_s); -if ($opt_l) { - MakeBuglist(); -} - -exit 0; -