X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=bugreport;h=8bb3b5835a0b0f0f01fbf3a34436d95e115d7d2d;hp=566e3a7a4e36a8d8fdbf5598b7821bbd49c15ff3;hb=c0db4b9d56c1fbb988dffa9fff9f86d181d8b270;hpb=4927e40eee6dfac4a25bb0646f93c7cd4bae1549 diff --git a/bugreport b/bugreport index 566e3a7..8bb3b58 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; } @@ -47,9 +42,13 @@ sub PrintPackageHeader() { if ($html) { 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} =~ /<(.*) \((.*)\)>/) {
@@ -57,7 +56,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";
 		}
@@ -80,24 +83,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 +116,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,52 +128,45 @@ 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
-	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 (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}));
+			$stabletotal++ if (scanlib::check_worry_stable($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); - 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 next release (excluding ignored and not-in-testing): %d
\n", $worrytotal); + printf("Number concerning the current stable release: %d

\n", $stabletotal); } 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); } } @@ -201,23 +181,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);