# %packagelist - map from packagename to bugreports
# %NMU - map with NMU information
-use lib qw(/org/bugs.debian.org/perl/);
+use lib qw(/org/bugs.debian.org/perl);
use LWP::UserAgent;
use Debbugs::MIME qw(decode_rfc1522 encode_rfc1522);
use Debbugs::Packages;
}
}
next if $skip==1;
-
- my $oldstable_tag = grep(/^woody$/, @tags);
- my $stable_tag = grep(/^sarge$/, @tags);
- my $testing_tag = grep(/^etch$/, @tags);
- my $unstable_tag = grep(/^sid$/, @tags);
- my $experimental_tag = grep(/^experimental$/, @tags);
+
+ my %disttags = ();
+ $disttags{'oldstable'} = grep(/^woody$/, @tags);
+ $disttags{'stable'} = grep(/^sarge$/, @tags);
+ $disttags{'testing'} = grep(/^etch$/, @tags);
+ $disttags{'unstable'} = grep(/^sid$/, @tags);
+ $disttags{'experimental'} = grep(/^experimental$/, @tags);
# default according to dondelelcaro 2006-11-11
- if (!$oldstable_tag && !$stable_tag && !$testing_tag && !$unstable_tag && !$experimental_tag) {
- $testing_tag = 1;
- $unstable_tag = 1;
- $experimental_tag = 1;
+ 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 $status_oldstable = get_status($f, $bug, 'oldstable') if ($oldstable_tag);
- my $status_stable = get_status($f, $bug, 'stable') if ($stable_tag);
- my $status_testing = get_status($f, $bug, 'testing') if ($testing_tag);
- my $status_unstable = get_status($f, $bug, 'unstable') if ($unstable_tag);
- my $status_experimental = get_status($f, $bug, 'experimental') if ($experimental_tag);
-
my $relinfo = "";
- $relinfo .= (($oldstable_tag && $status_oldstable eq 'pending') ? "O" : "");
- $relinfo .= (($stable_tag && $status_stable eq 'pending') ? "S" : "");
- $relinfo .= (($testing_tag && $status_testing eq 'pending') ? "T" : "");
- $relinfo .= (($unstable_tag && $status_unstable eq 'pending') ? "U" : "");
- $relinfo .= (($experimental_tag && $status_experimental eq 'pending') ? "E" : "");
+ 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;
+ }
+ }
+
+ 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 $relinfo eq '' and not $premature{$f};
$premature{$f}++ if $relinfo eq '';
# "<A HREF=\"${btsURL}/db/pa/l$name.html\">$name</A>";
}
-my $_version_cache = {};
-sub get_status() {
- my ($bugnr, $bug, $dist) = @_;
-
- my @versions = Debbugs::Status::getversions($bug->{'package'}, $dist, undef);
- my @sourceversions = Debbugs::Status::makesourceversions($bug->{'package'}, undef, @versions);
-
- if (length($bug->{'done'}) and
- (not @sourceversions or not @{$bug->{'fixed_versions'}})) {
- return 'done';
- }
- if (@sourceversions) {
- my $max_buggy = Debbugs::Status::max_buggy(bug => $bugnr,
- sourceversions => \@sourceversions,
- found => $bug->{'found_versions'},
- fixed => $bug->{'fixed_versions'},
- version_cache => $_version_cache,
- package => $bug->{'package'});
- if ($max_buggy eq 'absent' || $max_buggy eq 'fixed') {
- return $max_buggy;
- }
- }
-
- return 'pending';
-}
-
sub check_worry {
my ($status) = @_;
}
return 1;
}
+
+1;