X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=bugreport;h=75654cc9b5b42eada2fa54cbdd8b5dc7137a2b71;hp=83c8736e03485c2a37324bd4d6fb6a00334008a3;hb=817d5389c87ae35e3dabbcc689d1fd77a339daa2;hpb=2864b55f40b6cb63e0ef04232d869a71155646ef diff --git a/bugreport b/bugreport index 83c8736..75654cc 100755 --- a/bugreport +++ b/bugreport @@ -6,14 +6,12 @@ use Getopt::Std; require scanlib; require bugcfg; +use strict; +use warnings; -$Version = "BugReport 1.4\nCopyright (C) 1998-2002 Wichert Akkerman \n"; -$html = 0; -$statusfile = "status"; -$commentsfile = "comments"; -$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 +my $Version = "BugReport 1.4\nCopyright (C) 1998-2002 Wichert Akkerman \n"; +my $html = 0; +my $statusfile = "status"; sub ShowVersion() { print "$Version\n"; @@ -23,44 +21,57 @@ sub ShowVersion() { sub ShowUsage() { print <
";
-		print "Package: " . &wwwname($p);
-		print " ($section{$p}).\n";
+		print "
";
+		print "Package: " . scanlib::wwwname($p);
+		if (defined($scanlib::section{$p})) {
+			print " ($scanlib::section{$p}).\n";
+		} else {
+			print " (unknown).\n";
+		}
 		print "Maintainer: ";
-		if (defined($maintainer{$p})) {
-			$_ = $maintainer{$p};
-			($name,$email) = m/(.*) <([^>]*)>/;
-			print "$name <$email>\n";
+		if (exists($scanlib::maintainer{$p}) && $scanlib::maintainer{$p} ne '') {
+			if ($scanlib::maintainer{$p} =~ /(.*) <([^>]*)>/) {
+				($name,$email) = ($1,$2);
+			} elsif ($scanlib::maintainer{$p} =~ /<(.*) \((.*)\)>/) {
+				($name,$email) = ($1,$2);
+			} elsif ($scanlib::maintainer{$p} =~ /<(.*)>/) {
+				$name = $email = $1;
+			}
+			if (defined($name)) {
+				print "$name <$email>\n";
+			} else {
+				print "$scanlib::maintainer{$p}\n";
+			}
 		} else {
 			print "unknown\n";
 		}
 	} else {
-		print "\nPackage: $p ($section{$p})\n";
-		print "Maintainer: " . (defined($maintainer{$p}) ? $maintainer{$p} : "unknown") . "\n";
+		print "\nPackage: $p ($scanlib::section{$p})\n";
+		print "Maintainer: " . (defined($scanlib::maintainer{$p}) ? $scanlib::maintainer{$p} : "unknown") . "\n";
 	}
 }
 
 sub PrintPackageFooter() {
-	local($p)	= shift;	# Package to print
+	my $p	= shift;	# Package to print
 
 	if ($html) {
 		print "
\n"; @@ -68,67 +79,46 @@ sub PrintPackageFooter() { } sub MakeBuglist() { - local ($p); # Index variable - local ($nr); # Current bugnumber - local ($sect); # BTS-subsection for bugnumber - local ($header); # Flag if packagename has already been printed - local ($fontset); # Did we change the font? - - for $p (sort {$a cmp $b} keys %packagelist) { - next if (defined $exclude{$p}); + my $p; # Index variable + my $nr; # Current bugnumber + my $sect; # BTS-subsection for bugnumber + my $header; # Flag if packagename has already been printed + + for my $p (sort {$a cmp $b} keys %scanlib::packagelist) { $header = 0; - $fontset = 0; - if (defined $comments{$p}) { - if ($html && defined($comments{$p})) { - if ($comments{$p} =~ m/^\[REMOVE\]/) { - $fontset=1; - print ""; - } - } - $header=1; - &PrintPackageHeader($p); - print $comments{$p}; - } - for $nr (sort split(/ /, $packagelist{$p})) { - next if (defined $exclude{$nr}); + for $nr (sort @{$scanlib::packagelist{$p}}) { if (! $header) { $header = 1; &PrintPackageHeader($p); } if ($html) { - $worry = 1; - if ($bugs{$nr} =~ m/^\[[^]]*I/ or - $bugs{$nr} =~ m/ \[[^]]*X/ or - ($bugs{$nr} =~ m/ \[[^]]*[OSUE]/ and $bugs{$nr} !~ m/ \[[^]]*T/)) { - $worry = 0; - } + my $worry = scanlib::check_worry($scanlib::bugs{$nr}); - if ($bugs{$nr} =~ m/ \[[^]]*X/) { - print ''; - } elsif ($bugs{$nr} =~ m/^\[[^]]*P/) { + if ($scanlib::bugs{$nr}->{'pending'}) { print ''; - } elsif ($bugs{$nr} =~ m/^\[[^]]*\+/) { + } elsif ($scanlib::bugs{$nr}->{'patch'}) { print ''; - } elsif ($bugs{$nr} =~ m/^\[[^]]*H/) { + } elsif ($scanlib::bugs{$nr}->{'help'}) { print ''; } - print "" if ($bugs{$nr} =~ m/^\[.......I\]/); + print "" if ($scanlib::bugs{$nr}->{'sarge-ignore'} || $scanlib::bugs{$nr}->{'etch-ignore'}); print "" if $worry; ($sect=$nr) =~ s/([0-9]{2}).*/$1/; - print " " . &wwwnumber($nr) . ' ' . - htmlsanit($bugs{$nr}) . "\n"; + printf " %s [%s] [%s] %s\n", scanlib::wwwnumber($nr), + scanlib::get_taginfo($scanlib::bugs{$nr}), + scanlib::get_relinfo($scanlib::bugs{$nr}), + scanlib::htmlsanit($scanlib::bugs{$nr}->{'subject'}); print "" if $worry; - print "" if ($bugs{$nr} =~ m/^\[.......I\]/); + print "" if ($scanlib::bugs{$nr}->{'sarge-ignore'} || $scanlib::bugs{$nr}->{'etch-ignore'}); } else { - printf(" %-6d %s\n", $nr, $bugs{$nr}); + printf(" %-6d [%s] [%s] %s\n", $nr, scanlib::get_taginfo($scanlib::bugs{$nr}), + scanlib::get_relinfo($scanlib::bugs{$nr}), $scanlib::bugs{$nr}->{'subject'}); } - print $comments{$nr} if (defined($comments{$nr})); - print "[FIX] Fixed by package " . $NMU{$nr, "source"} . ", version " . $NMU{$nr, "version"} . " in Incoming\n" if (defined $NMU{$nr}); - print "" if ($html && ($bugs{$nr} =~ m/^\[[^]]*[H+P]/ || - $bugs{$nr} =~ m/ \[[^]]*X/)); + print "" if ($html && ($scanlib::bugs{$nr}->{'pending'} || + $scanlib::bugs{$nr}->{'patch'} || + $scanlib::bugs{$nr}->{'help'})); } - print "" if ($fontset); if ($header) { &PrintPackageFooter($p); } @@ -137,83 +127,78 @@ sub MakeBuglist() { sub MakeStatistics() { - local($bugcount); # Total number of bugs so far - local($count); # Number of bugs for this package - local($remtotal); # Total number of bugs for packages marked REMOVE - local($patchtotal); # Total number of bugs marked patch - local($pendingtotal); # Total number of bugs marked pending - local($ignoretotal); # Total number of bugs marked ignore - local($nottestingtotal); # Total number of bugs on packages not in testing - local($worrytotal); # Total number of bugs we're actually worried about - local($p); # Index variable - local(%list); # List of bugnumber associated with package - - $bugcount=0; - for $p (sort keys %packagelist) { - next if (defined $exclude{$p}); - $count=0; - for $nr (split(/ /, $packagelist{$p})) { - $pendingtotal++ if ($bugs{$nr} =~ m/^\[[^]]*P/); - $patchtotal++ if ($bugs{$nr} =~ m/^\[[^]]*\+/); - $ignoretotal++ if ($bugs{$nr} =~ m/^\[[^]]*I/); - $nottestingtotal++ if ($bugs{$nr} =~ m/ \[[^]]*X/); - $worrytotal++ unless ( - $bugs{$nr} =~ m/^\[[^]]*I/ or - $bugs{$nr} =~ m/ \[[^]]*X/ or - ($bugs{$nr} =~ m/ \[[^]]*[OSUE]/ and $bugs{$nr} !~ m/ \[[^]]*T/)); - - if (not defined($exclude{$nr})) { - $bugcount++; - $count++; - } + my $bugcount=0; # Total number of bugs so far + 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 $worrytotal=0; # Total number of bugs we're actually worried about + my $stabletotal=0; # Total number of bugs affecting stable + my %list; # List of bugnumber associated with package + + for my $p (sort keys %scanlib::packagelist) { + my $count = 0; # Number of bugs for this package + + for my $nr (@{$scanlib::packagelist{$p}}) { + $pendingtotal++ if ($scanlib::bugs{$nr}->{'pending'}); + $patchtotal++ if ($scanlib::bugs{$nr}->{'patch'}); + $ignoretotal++ if ($scanlib::bugs{$nr}->{'sarge-ignore'} || $scanlib::bugs{$nr}->{'etch-ignore'}); + $worrytotal++ if (scanlib::check_worry($scanlib::bugs{$nr})); + $stabletotal++ if (scanlib::check_worry_stable($scanlib::bugs{$nr})); + + $bugcount++; + $count++; } - $remtotal+=$count if (defined($comments{$p}) && $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); + printf("Number concerning the current stable release: %d
\n", $stabletotal); + printf("Number concerning the next release: %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); + printf("Number concerning the current stable release: %d\n", $stabletotal); + printf("Number concerning the next release: %d\n", $worrytotal); } } -sub FilterPackages() { - local($filter) = shift; # Distribution we want to keep +sub FilterPackages($) { + my $filter = shift; # Distribution we want to keep - for $p (sort keys %packagelist) { - delete $packagelist{$p} unless ($section{$p} =~ m/^$filter/); + for my $p (sort keys %scanlib::packagelist) { + delete $scanlib::packagelist{$p} unless ($scanlib::section{$p} =~ m/^$filter/); } } -getopts('VhHlsd:S:C:'); +sub FilterBugs() { + for my $p (sort keys %scanlib::packagelist) { + $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_H,$opt_d,$opt_t,$opt_s,$opt_l); + +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); -&readstatus($statusfile); -&readcomments($commentsfile); -&readNMUstatus($NMUfile); +scanlib::readstatus($statusfile); -&FilterPackages($opt_d) if ($opt_d); +FilterPackages($opt_d) if ($opt_d); +FilterBugs() if ($opt_t); MakeStatistics if ($opt_s); if ($opt_l) { - MakeBuglist + MakeBuglist(); } exit 0;