X-Git-Url: https://git.donarmstrong.com/?p=bugscan.git;a=blobdiff_plain;f=scanlib.pm;h=ed9fd37dd022f2ccfeb856dbc1f142b0ce60c7e0;hp=4c97a1c690c25d4fbd5f968a0030d9b49af0eddf;hb=c0db4b9d56c1fbb988dffa9fff9f86d181d8b270;hpb=0aeb6434b6fe5991b04fe3922feffa31380f8a80 diff --git a/scanlib.pm b/scanlib.pm index 4c97a1c..ed9fd37 100644 --- a/scanlib.pm +++ b/scanlib.pm @@ -6,13 +6,11 @@ # which was based on an unknown other script. # # Global variables: -# %comments - map from bugnumber to bug description # %premature - list of prematurely closed bugreports # %exclude - list of bugreports to exclude from the report # %maintainer - map from packagename to maintainer # %section - map from packagename to section in the FTP-site # %packagelist - map from packagename to bugreports -# %NMU - map with NMU information use lib qw(/org/bugs.debian.org/perl); use LWP::UserAgent; @@ -26,43 +24,7 @@ use warnings; require bugcfg; package scanlib; -our (%comments,%premature,%exclude,%maintainer,%section,%packagelist,%NMU,%debbugssection,%bugs); - -sub readcomments() { -# Read bug commentary -# It is in paragraph format, with the first line of each paragraph being -# the bug number or package name to which the comment applies. -# Prefix a bug number with a * to force it to be listed even if it's closed. -# (This deals with prematurely closed bugs) - - my $index; # Bug-number for current comment - my $file; # Name of comments-file - - %comments = (); # Initialize our data - %premature = (); - %exclude = (); - $file=shift; - open(C, $file) or die "open $file: $!\n"; - while () { - chomp; - if (m/^\s*$/) { # Check for paragraph-breaks - undef $index; - } elsif (defined $index) { - $comments{$index} .= $_ . "\n"; - } else { - if (s/^\*//) { # Test & remove initial * - $premature{$_} = 1; - } - if (s/\s+EXCLUDE\s*//) { # Test & remove EXCLUDE - $exclude{$_} = 1; - next; - } - $index = $_; - $comments{$index} = ''; # New comment, initialize data - } - } - close(C); -} +our (%premature,%exclude,%maintainer,%section,%packagelist,%debbugssection,%bugs); # Read the list of maintainer @@ -215,46 +177,48 @@ sub scanspooldir() { $disttags{'testing'} = grep(/^etch$/, @tags); $disttags{'unstable'} = grep(/^sid$/, @tags); $disttags{'experimental'} = grep(/^experimental$/, @tags); - + # default according to dondelelcaro 2006-11-11 if (!$disttags{'oldstable'} && !$disttags{'stable'} && !$disttags{'testing'} && !$disttags{'unstable'} && !$disttags{'experimental'}) { $disttags{'testing'} = 1; $disttags{'unstable'} = 1; $disttags{'experimental'} = 1; } - - # only bother to check the versioning status for the distributions indicated by the tags + my $relinfo = ""; - for my $dist qw(oldstable stable testing unstable experimental) { - local $SIG{__WARN__} = sub {}; - - next if (!$disttags{$dist}); - - # only check for the archs we care about - my %svhash = (); - for my $arch qw(alpha amd64 arm hppa i386 ia64 mips mipsel powerpc s390 sparc) { - my @versions = Debbugs::Packages::getversions($bug->{'package'}, $dist, $arch); - my @sourceversions = Debbugs::Packages::makesourceversions($bug->{'package'}, $arch, @versions); - - for my $sv (@sourceversions) { - $svhash{$sv} = 1; - } + if (defined($section{$bug->{'package'}}) && $section{$bug->{'package'}} eq 'pseudo') { + # versioning information makes no sense for pseudo packages, + # just use the tags + for my $dist qw(oldstable stable testing unstable experimental) { + $relinfo .= uc(substr($dist, 0, 1)) if $disttags{$dist}; } - - my @sourceversions = keys %svhash; - my $presence = Debbugs::Status::bug_presence(bug => $f, status => $bug, sourceversions => \@sourceversions); - - # ignore bugs that are absent/fixed in this distribution, include everything - # else (that is, "found" which says that the bug is present, and undef, which - # indicates that no versioning information is present and it's not closed - # unversioned) - if (!defined($presence) || ($presence ne 'absent' && $presence ne 'fixed')) { - $relinfo .= uc(substr($dist, 0, 1)); + next if (length($bug->{'done'})); + } else { + # only bother to check the versioning status for the distributions indicated by the tags + for my $dist qw(oldstable stable testing unstable experimental) { + local $SIG{__WARN__} = sub {}; + + next if (!$disttags{$dist}); + + my $presence = Debbugs::Status::bug_presence( + bug => $f, + status => $bug, + dist => $dist, + arch => \@bugcfg::architectures + ); + + # ignore bugs that are absent/fixed in this distribution, include everything + # else (that is, "found" which says that the bug is present, and undef, which + # indicates that no versioning information is present and it's not closed + # unversioned) + if (!defined($presence) || ($presence ne 'absent' && $presence ne 'fixed')) { + $relinfo .= uc(substr($dist, 0, 1)); + } } + + next if $relinfo eq '' and not $premature{$f}; + $premature{$f}++ if $relinfo eq ''; } - - next if $relinfo eq '' and not $premature{$f}; - $premature{$f}++ if $relinfo eq ''; $taginfo = "["; $taginfo .= ($bug->{'keywords'} =~ /\bpending\b/ ? "P" : " "); @@ -274,14 +238,6 @@ sub scanspooldir() { for my $package (split /[,\s]+/, $bug->{'package'}) { $_= $package; y/A-Z/a-z/; $_= $` if m/[^-+._a-z0-9]/; - if (not defined $section{$_}) { - if (defined $debbugssection{$_}) { - $relinfo .= "X"; - } else { - next; # Skip unavailable packages - } - } - push @{$packagelist{$_}}, $f; } @@ -323,39 +279,6 @@ sub readstatus() { } -sub readNMUstatus() { - my $bug; # Number of current bug - my $source; # Source upload which closes this bug. - my $version; # Version where this bug was closed. - my $flag; # Whether this paragraph has been processed. - my ($field, $value); - - for (split /\n/, LWP::UserAgent->new->request(HTTP::Request->new(GET => shift))->content) { - chomp; - if (m/^$/) { - $NMU{$bug} = 1; - $NMU{$bug, "source"} = $source; - $NMU{$bug, "version"} = $version; -# $comments{$bug} .= "[FIXED] Fixed package $source is in Incoming\n"; - $flag = 0; - } else { - ($field, $value) = split(/: /, $_, 2); - $bug = $value if($field =~ /bug/i); - $source = $value if($field =~ /source/i); - $version = $value if($field =~ /version/i); - $flag = 1; - } - } - if ($flag) { - $NMU{$bug} = 1; - $NMU{$bug, "source"} = $source; - $NMU{$bug, "version"} = $version; -# $comments{$bug} .= "[FIXED] Fixed package $source in in Incoming\n"; - } - close P; -} - - sub urlsanit { my $url = shift; $url =~ s/%/%25/g; @@ -374,12 +297,9 @@ sub htmlsanit { sub wwwnumber() { my $number = shift; # Number of bug to html-ize -# my $section); # Section for the bug "' . htmlsanit($number) . ''; -# ($section=$number) =~ s/([0-9]{2}).*/$1/; -# "$number"; } sub wwwname() { @@ -387,15 +307,22 @@ sub wwwname() { "' . htmlsanit($name) . ''; -# "$name"; } sub check_worry { my ($status) = @_; if ($status =~ m/^\[[^]]*I/ or - $status =~ m/ \[[^]]*X/ or - ($status =~ m/ \[[^]]*[OSUE]/ and $status !~ m/ \[[^]]*T/)) { + $status !~ m/ \[[^]]*T/) { + return 0; + } + return 1; +} + +sub check_worry_stable { + my ($status) = @_; + + if ($status !~ m/ \[[^]]*S/) { return 0; } return 1;