X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=bugreport;h=797e8d2345e49d2cb0719e32b6170e27b3c9eb0e;hp=e06d3c989e8d3c46d37379850430cd3f0c4446c2;hb=4f2ac6d37c700e562e1ac5feb4e99bae28bb7618;hpb=d5a0b74a3ddd8ad47fb594e890dfd0f454627655 diff --git a/bugreport b/bugreport index e06d3c9..797e8d2 100755 --- a/bugreport +++ b/bugreport @@ -6,12 +6,14 @@ use Getopt::Std; require scanlib; require bugcfg; - -$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"; +use strict; +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 @@ -23,13 +25,14 @@ sub ShowVersion() { sub ShowUsage() { print <Package: " . &wwwname($p); - print " ($section{$p}).\n"; + print "
";
+		print "Package: " . &wwwname($p);
+		print " ($scanlib::section{$p}).\n";
 		print "Maintainer: ";
-		if (defined($maintainer{$p})) {
-			$_ = $maintainer{$p};
+		if (defined($scanlib::maintainer{$p})) {
+			$_ = $scanlib::maintainer{$p};
 			($name,$email) = m/(.*) <([^>]*)>/;
 			print "$name <$email>\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() {
+	my $p	= shift;	# Package to print
+
+	if ($html) {
+		print "
\n"; + } +} 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? - - print "
\n" if ($html);
-	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
+	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 $comments{$p}) {
-			if ($html && defined($comments{$p})) {
-				if ($comments{$p} =~ m/^\[REMOVE\]/) {
+		if (defined $scanlib::comments{$p}) {
+			if ($html && defined($scanlib::comments{$p})) {
+				if ($scanlib::comments{$p} =~ m/^\[REMOVE\]/) {
 					$fontset=1;
-					print "";
+					print "";
 				}
 			}
 			$header=1;
 			&PrintPackageHeader($p);
-			print $comments{$p};
+			print $scanlib::comments{$p};
 		}
-		for $nr (sort split(/ /, $packagelist{$p})) {
-			next if (defined $exclude{$nr});
+		for $nr (sort split(/ /, $scanlib::packagelist{$p})) {
+			next if (defined $bugcfg::exclude{$nr});
 			if (! $header) {
 				$header = 1;
 				&PrintPackageHeader($p);
 			}
 
 			if ($html) {
-				if ($bugs{$nr} =~ m/ \[[^]]*X/) {
-					print '';
-				} elsif ($bugs{$nr} =~ m/^\[[^]]*P/) {
-					print '';
-				} elsif ($bugs{$nr} =~ m/^\[[^]]*\+/) {
-					print '';
-				} elsif ($bugs{$nr} =~ m/^\[[^]]*H/) {
-					print '';
+				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 ($bugs{$nr} =~ m/^\[.......I\]/);
+				print "" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
+				print "" if $worry;
 				($sect=$nr) =~ s/([0-9]{2}).*/$1/;
-				print "  " . &wwwnumber($nr) . ' ' .
-					  htmlsanit($bugs{$nr}) . "\n";
-				print "" if ($bugs{$nr} =~ m/^\[.......I\]/);
+				print "  " . &wwwnumber($nr) . ' ' .
+					  htmlsanit($scanlib::bugs{$nr}) . "\n";
+				print "" if $worry;
+				print "" if ($scanlib::bugs{$nr} =~ m/^\[.......I\]/);
 			} else {
-				printf("  %-6d %s\n", $nr, $bugs{$nr});
+				printf("  %-6d %s\n", $nr, $scanlib::bugs{$nr});
 			}
-			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 $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);
 		}
-		print "" if ($fontset);
 	}
-	print "
\n" if ($html); } 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 + 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 $p (sort keys %packagelist) { - next if (defined $exclude{$p}); + for my $p (sort keys %scanlib::packagelist) { + next if (defined $scanlib::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/); + 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 ( - $bugs{$nr} =~ m/^\[[^]]*I/ or - $bugs{$nr} =~ m/ \[[^]]*X/ or - ($bugs{$nr} =~ m/ \[[^]]*[OSUE]/ and $bugs{$nr} !~ m/ \[[^]]*T/)); + $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($exclude{$nr})) { + if (not defined($scanlib::exclude{$nr})) { $bugcount++; $count++; } } - $remtotal+=$count if (defined($comments{$p}) && $comments{$p} =~ m/^\[REMOVE\]/); + $remtotal+=$count if (defined($scanlib::comments{$p}) && $scanlib::comments{$p} =~ m/^\[REMOVE\]/); } if ($html) { @@ -173,25 +189,35 @@ sub MakeStatistics() { sub FilterPackages() { - local($filter) = shift; # Distribution we want to keep + 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} = join(' ', grep { check_worry($scanlib::bugs{$_}) } split / /, $scanlib::packagelist{$p}); + delete $scanlib::packagelist{$p} if ($scanlib::packagelist{$p} eq ''); + } +} + +my ($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); -&readstatus($statusfile); -&readcomments($commentsfile); -&readNMUstatus($NMUfile); +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) {