X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=bugreport;h=1686ae88e0ab0ab86dc76b5277d32276d381d64c;hp=566e3a7a4e36a8d8fdbf5598b7821bbd49c15ff3;hb=4ef8564c7e87c67015de727dbf9bd23a51f927d3;hpb=4927e40eee6dfac4a25bb0646f93c7cd4bae1549 diff --git a/bugreport b/bugreport index 566e3a7..1686ae8 100755 --- a/bugreport +++ b/bugreport @@ -12,10 +12,6 @@ use warnings; my $Version = "BugReport 1.4\nCopyright (C) 1998-2002 Wichert Akkerman \n"; my $html = 0; my $statusfile = "status"; -my $commentsfile = "comments"; -my $NMUfile = "/debian/home/doogie/public_html/incoming/bugs_closed"; -$NMUfile = "/debian/home/doogie/chgscan/db/bugs_closed"; # Changed as of request by dark -Joey, 99/11/22 -$NMUfile = "http://auric.debian.org/~doogie/incoming/bugs_closed"; # Changed as of request by dark -Joey, 99/11/22 sub ShowVersion() { print "$Version\n"; @@ -35,7 +31,6 @@ Options: -t show bugs relevant for testing only -d only list these distributions (comma-separated) -S use different statusfile - -C use different commentsfile EOF exit 0; } @@ -80,24 +75,11 @@ sub MakeBuglist() { my $nr; # Current bugnumber my $sect; # BTS-subsection for bugnumber 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) { next if (defined $bugcfg::exclude{$p}); $header = 0; - $fontset = 0; - if (defined $scanlib::comments{$p}) { - if ($html && defined($scanlib::comments{$p})) { - if ($scanlib::comments{$p} =~ m/^\[REMOVE\]/) { - $fontset=1; - print ""; - } - } - $header=1; - &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; @@ -126,12 +108,9 @@ sub MakeBuglist() { } 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); } @@ -141,7 +120,6 @@ sub MakeBuglist() { sub MakeStatistics() { 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 @@ -153,27 +131,22 @@ sub MakeStatistics() { my $count = 0; # Number of bugs for this package next if (defined $scanlib::exclude{$p}); - 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/); $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/)); + $worrytotal++ if (scanlib::check_worry($scanlib::bugs{$nr})); 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); @@ -181,7 +154,6 @@ sub MakeStatistics() { 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); @@ -201,23 +173,20 @@ sub FilterPackages($) { sub FilterBugs() { for my $p (sort keys %scanlib::packagelist) { - $scanlib::packagelist{$p} = join(' ', grep { scanlib::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); } } -our ($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_H,$opt_d,$opt_t,$opt_s,$opt_l); -getopts('VhHlstd:S:C:'); +getopts('VhHlstd:S:'); 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);