X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=bugreport;h=79c325f27c223a0c61a3d4073a5ae65815922de3;hp=1686ae88e0ab0ab86dc76b5277d32276d381d64c;hb=02cc5bba35cc8b9c6ce76a2c1bc7b520187bcaa3;hpb=eeb9193b817dc0b95ce845911c8d9cab4759c8ef diff --git a/bugreport b/bugreport index 1686ae8..79c325f 100755 --- a/bugreport +++ b/bugreport @@ -1,5 +1,5 @@ #!/usr/bin/perl -# vim: ts=4 sw=4 nowrap +# vim: ts=8 sw=8 nowrap # Generate a report of the release-critical bugs for packages @@ -21,13 +21,14 @@ sub ShowVersion() { sub ShowUsage() { print <
";
 		print "Package: " . scanlib::wwwname($p);
-		print " ($scanlib::section{$p}).\n";
+		if (defined($scanlib::section{$p})) {
+			print " ($scanlib::section{$p}).\n";
+		} else {
+			print " (unknown).\n";
+		}
 		print "Maintainer: ";
-		if (defined($scanlib::maintainer{$p})) {
+		if (exists($scanlib::maintainer{$p}) && $scanlib::maintainer{$p} ne '') {
 			if ($scanlib::maintainer{$p} =~ /(.*) <([^>]*)>/) {
 				($name,$email) = ($1,$2);
 			} elsif ($scanlib::maintainer{$p} =~ /<(.*) \((.*)\)>/) {
@@ -52,7 +57,11 @@ sub PrintPackageHeader() {
 			} elsif ($scanlib::maintainer{$p} =~ /<(.*)>/) {
 				$name = $email = $1;
 			}
-			print "$name <$email>\n";
+			if (defined($name)) {
+				print "$name <$email>\n";
+			} else {
+				print "$scanlib::maintainer{$p}\n";
+			}
 		} else {
 			print "unknown\n";
 		}
@@ -77,10 +86,8 @@ sub MakeBuglist() {
 	my $header;		# Flag if packagename has already been printed
 
 	for my $p (sort {$a cmp $b} keys %scanlib::packagelist) {
-		next if (defined $bugcfg::exclude{$p});
 		$header = 0;
 		for $nr (sort @{$scanlib::packagelist{$p}}) {
-			next if (defined $bugcfg::exclude{$nr});
 			if (! $header) {
 				$header = 1;
 				&PrintPackageHeader($p);
@@ -89,27 +96,29 @@ sub MakeBuglist() {
 			if ($html) {
 				my $worry = scanlib::check_worry($scanlib::bugs{$nr});
 			
-				if ($scanlib::bugs{$nr} =~ m/ \[[^]]*X/) {
-					print '';
-				} elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*P/) {
+				if ($scanlib::bugs{$nr}->{'pending'}) {
 					print '';
-				} elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*\+/) {
+				} elsif ($scanlib::bugs{$nr}->{'patch'}) {
 					print '';
-				} elsif ($scanlib::bugs{$nr} =~ m/^\[[^]]*H/) {
+				} elsif ($scanlib::bugs{$nr}->{'help'}) {
 					print '';
 				}
-				print "" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
+				print "" if ($scanlib::bugs{$nr}->{'etch-ignore'} || $scanlib::bugs{$nr}->{'lenny-ignore'});
 				print "" if $worry;
 				($sect=$nr) =~ s/([0-9]{2}).*/$1/;
-				print "  " . scanlib::wwwnumber($nr) . ' ' .
-					  scanlib::htmlsanit($scanlib::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 ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
+				print "" if ($scanlib::bugs{$nr}->{'etch-ignore'} || $scanlib::bugs{$nr}->{'lenny-ignore'});
 			} else {
-				printf("  %-6d %s\n", $nr, $scanlib::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 "" if ($html && ($scanlib::bugs{$nr} =~ m/^\[[^]]*[H+P]/ ||
-			                              $scanlib::bugs{$nr} =~ m/ \[[^]]*X/));
+			print "" if ($html && ($scanlib::bugs{$nr}->{'pending'} ||
+			                              $scanlib::bugs{$nr}->{'patch'} ||
+										  $scanlib::bugs{$nr}->{'help'}));
 		}
 		if ($header) {
 			&PrintPackageFooter($p);
@@ -123,25 +132,22 @@ sub MakeStatistics() {
 	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 $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
 
-		next if (defined $scanlib::exclude{$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/);
+			$pendingtotal++ if ($scanlib::bugs{$nr}->{'pending'});
+			$patchtotal++ if ($scanlib::bugs{$nr}->{'patch'});
+			$ignoretotal++ if ($scanlib::bugs{$nr}->{'etch-ignore'} || $scanlib::bugs{$nr}->{'lenny-ignore'});
 			$worrytotal++ if (scanlib::check_worry($scanlib::bugs{$nr}));
+			$stabletotal++ if (scanlib::check_worry_stable($scanlib::bugs{$nr}));
 
-			if (not defined($scanlib::exclude{$nr})) {
-				$bugcount++;
-				$count++;
-			} 
+			$bugcount++;
+			$count++;
 		}
 	}
 
@@ -150,15 +156,15 @@ sub MakeStatistics() {
 		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 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); } } @@ -178,9 +184,16 @@ sub FilterBugs() { } } -our ($opt_h,$opt_V,$opt_S,$opt_H,$opt_d,$opt_t,$opt_s,$opt_l); +sub FilterBugsStable() { + for my $p (sort keys %scanlib::packagelist) { + $scanlib::packagelist{$p} = [ grep { scanlib::check_worry_stable($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_b,$opt_t,$opt_s,$opt_l); -getopts('VhHlstd:S:'); +getopts('VhHlsbtd:S:'); ShowUsage if ($opt_h); ShowVersion if ($opt_V); $statusfile=$opt_S if ($opt_S); @@ -189,6 +202,7 @@ $html=1 if ($opt_H); scanlib::readstatus($statusfile); FilterPackages($opt_d) if ($opt_d); +FilterBugsStable() if ($opt_b); FilterBugs() if ($opt_t); MakeStatistics if ($opt_s);