X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=cgi%2Fpkgreport.cgi;h=8736e8c0570a1305c91193d167adf9ba857104d5;hb=e125acea7521eb1fcbc825ff45124f9aaa163bfb;hp=cffc324bc02b0d4a0dc93c8c57d856b03cc11243;hpb=3582e507e1dfe99ba850311ea6aa1c8d0ee73f4f;p=debbugs.git diff --git a/cgi/pkgreport.cgi b/cgi/pkgreport.cgi index cffc324..8736e8c 100755 --- a/cgi/pkgreport.cgi +++ b/cgi/pkgreport.cgi @@ -19,8 +19,8 @@ use POSIX qw(strftime nice); use Debbugs::Config qw(:globals :text :config); use Debbugs::User; use Debbugs::CGI qw(version_url maint_decode); -use Debbugs::Common qw(getparsedaddrs :date make_list getmaintainers); -use Debbugs::Bugs qw(get_bugs bug_filter); +use Debbugs::Common qw(getparsedaddrs :date make_list getmaintainers getpseudodesc); +use Debbugs::Bugs qw(get_bugs bug_filter newest_bug); use Debbugs::Packages qw(getsrcpkgs getpkgsrc get_versions); use Debbugs::Status qw(:status); use Debbugs::CGI qw(:all); @@ -41,7 +41,7 @@ our %param = cgi_parameters(query => $q, single => [qw(ordering archive repeatmerged), qw(bug-rev pend-rev sev-rev), qw(maxdays mindays version), - qw(data which dist), + qw(data which dist newest), ], default => {ordering => 'normal', archive => 0, @@ -85,42 +85,50 @@ unless (defined $ordering) { $ordering = "raw" if $raw_sort; $ordering = 'age' if $age_sort; } -my ($bug_order) = $ordering =~ /(age(?:rev)?)/; +our ($bug_order) = $ordering =~ /(age(?:rev)?)/; $bug_order = '' if not defined $bug_order; my $bug_rev = ($param{'bug-rev'} || "no") eq "yes"; my $pend_rev = ($param{'pend-rev'} || "no") eq "yes"; my $sev_rev = ($param{'sev-rev'} || "no") eq "yes"; -my $pend_exc = $param{'&pend-exc'} || $param{'pend-exc'} || ""; -my $pend_inc = $param{'&pend-inc'} || $param{'pend-inc'} || ""; -my $sev_exc = $param{'&sev-exc'} || $param{'sev-exc'} || ""; -my $sev_inc = $param{'&sev-inc'} || $param{'sev-inc'} || ""; -my $maxdays = ($param{'maxdays'} || -1); -my $mindays = ($param{'mindays'} || 0); -my $version = $param{'version'} || undef; -my $dist = $param{'dist'} || undef; -my $arch = $param{'arch'} || undef; -{ - if (defined $param{'vt'}) { - my $vt = $param{'vt'}; - if ($vt eq "none") { $dist = undef; $arch = undef; $version = undef; } - if ($vt eq "bysuite") { - $version = undef; - $arch = undef if ($arch eq "any"); - } - if ($vt eq "bypkg" || $vt eq "bysrc") { $dist = undef; $arch = undef; } - } - if (defined $param{'includesubj'}) { - my $is = $param{'includesubj'}; - $include .= "," . join(",", map { "subj:$_" } (split /[\s,]+/, $is)); - } - if (defined $param{'excludesubj'}) { - my $es = $param{'excludesubj'}; - $exclude .= "," . join(",", map { "subj:$_" } (split /[\s,]+/, $es)); - } +my @inc_exc_mapping = ({name => 'pending', + incexc => 'include', + key => 'pend-inc', + }, + {name => 'pending', + incexc => 'exclude', + key => 'pend-exc', + }, + {name => 'severity', + incexc => 'include', + key => 'sev-inc', + }, + {name => 'severity', + incexc => 'exclude', + key => 'sev-exc', + }, + {name => 'subject', + incexc => 'include', + key => 'includesubj', + }, + {name => 'subject', + incexc => 'exclude', + key => 'excludesubj', + }, + ); +for my $incexcmap (@inc_exc_mapping) { + push @{$param{$incexcmap->{incexc}}}, map {"$incexcmap->{name}:$_"} + map{split /\s*,\s*/} make_list($param{$incexcmap->{key}}) + if exists $param{$incexcmap->{key}}; + delete $param{$incexcmap->{key}}; } +my $maxdays = ($param{'maxdays'} || -1); +my $mindays = ($param{'mindays'} || 0); +my $version = $param{'version'} || undef; +# XXX Once the options/selection is rewritten, this should go away +my $dist = $param{dist} || undef; our %hidden = map { $_, 1 } qw(status severity classification); our %cats = ( @@ -157,7 +165,7 @@ our %cats = ( ); my @select_key = (qw(submitter maint pkg package src usertag), - qw(status tag maintenc owner severity) + qw(status tag maintenc owner severity newest) ); if (exists $param{which} and exists $param{data}) { @@ -193,15 +201,16 @@ for my $user (map {split /[\s*,\s*]+/} make_list($param{users}||[])) { } if (defined $param{usertag}) { - my %select_ut = (); - my ($u, $t) = split /:/, $param{usertag}, 2; - Debbugs::User::read_usertags(\%select_ut, $u); - unless (defined $t && $t ne "") { - $t = join(",", keys(%select_ut)); - } - - add_user($u); - push @{$param{tag}}, split /,/, $t; + for my $usertag (make_list($param{usertag})) { + my %select_ut = (); + my ($u, $t) = split /:/, $usertag, 2; + Debbugs::User::read_usertags(\%select_ut, $u); + unless (defined $t && $t ne "") { + $t = join(",", keys(%select_ut)); + } + add_user($u); + push @{$param{tag}}, split /,/, $t; + } } my $Archived = $archive ? " Archived" : ""; @@ -295,24 +304,37 @@ while (my ($key,$value) = splice @search_key_order, 0, 2) { for my $entry (make_list($param{$key})) { my $extra = ''; if (exists $param{dist} and ($key eq 'package' or $key eq 'src')) { - my @versions = get_versions(package => $entry, + my %versions = get_versions(package => $entry, (exists $param{dist}?(dist => $param{dist}):()), - (exists $param{arch}?(arch => $param{arch}):()), + (exists $param{arch}?(arch => $param{arch}):(arch => $config{default_architectures})), ($key eq 'src'?(arch => q(source)):()), + no_source_arch => 1, + return_archs => 1, ); - my $verdesc = join(', ',@versions); - $verdesc = 'version'.(@versions>1?'s ':' ').$verdesc; - $extra= " ($verdesc)" if @versions; + my $verdesc; + if (keys %versions > 1) { + $verdesc = 'versions '. join(', ', + map { $_ .' ['.join(', ', + sort @{$versions{$_}} + ).']'; + } keys %versions); + } + else { + $verdesc = 'version '.join(', ', + keys %versions + ); + } + $extra= " ($verdesc)" if keys %versions; } push @entries, $entry.$extra; } push @title,$value.' '.join(' or ', @entries); } -my $title = join(' and ', map {/ or /?"($_)":$_} @title); +my $title = $gBugs.' '.join(' and ', map {/ or /?"($_)":$_} @title); @title = (); # we have to special case the maint="" search, unfortunatly. -if (defined $param{maint} and $param{maint} eq "") { +if (defined $param{maint} and $param{maint} eq "" or ref($param{maint}) and not @{$param{maint}}) { my %maintainers = %{getmaintainers()}; @bugs = get_bugs(function => sub {my %d=@_; @@ -322,20 +344,26 @@ if (defined $param{maint} and $param{maint} eq "") { return 0; } ); - $title = 'in packages with no maintainer'; + $title = $gBugs.' in packages with no maintainer'; +} +elsif (defined $param{newest}) { + my $newest_bug = newest_bug(); + @bugs = ($newest_bug - $param{newest} + 1) .. $newest_bug; + $title = @bugs.' newest '.$gBugs; } else { #yeah for magick! - @bugs = get_bugs(map {exists $param{$_}?($_,$param{$_}):()} - keys %search_keys, 'archive' + @bugs = get_bugs((map {exists $param{$_}?($_,$param{$_}):()} + keys %search_keys, 'archive'), + usertags => \%ut, ); } if (defined $param{version}) { - $title .= " at version $version"; + $title .= " at version $param{version}"; } elsif (defined $param{dist}) { - $title .= " in $dist"; + $title .= " in $param{dist}"; } $title = html_escape($title); @@ -359,7 +387,7 @@ print "\n" . "\n" . '' . "\n"; -print "

" . "$gProject$Archived $gBug report logs: $gBugs $title" . +print "

" . "$gProject$Archived $gBug report logs: $title" . "

\n"; my $showresult = 1; @@ -383,9 +411,17 @@ for my $package (make_list($param{src}||[])) { sub output_package_info{ my ($srcorbin,$package) = @_; + + my %pkgsrc = %{getpkgsrc()}; + my $srcforpkg = $package; + if ($srcorbin eq 'binary') { + $srcforpkg = $pkgsrc{$package}; + defined $srcforpkg or $srcforpkg = $package; + } + my $showpkg = html_escape($package); my $maintainers = getmaintainers(); - my $maint = $maintainers->{$package}; + my $maint = $maintainers->{$srcforpkg}; if (defined $maint) { print '

'; print htmlize_maintlinks(sub { $_[0] == 1 ? "Maintainer for $showpkg is " @@ -396,12 +432,6 @@ sub output_package_info{ } else { print "

No maintainer for $showpkg. Please do not report new bugs against this package.

\n"; } - my %pkgsrc = %{getpkgsrc()}; - my $srcforpkg = $package; - if ($srcorbin eq 'binary') { - $srcforpkg = $pkgsrc{$package}; - defined $srcforpkg or $srcforpkg = $package; - } my @pkgs = getsrcpkgs($srcforpkg); @pkgs = grep( !/^\Q$package\E$/, @pkgs ); if ( @pkgs ) { @@ -412,7 +442,7 @@ sub output_package_info{ print "

You may want to refer to the following individual bug pages:\n"; } #push @pkgs, $src if ( $src && !grep(/^\Q$src\E$/, @pkgs) ); - print join( ", ", map( "$_)) . "\">$_", @pkgs ) ); + print join( ", ", map( "$_,src=>[],newest=>[])) . "\">$_", @pkgs ) ); print ".\n"; } my @references; @@ -427,11 +457,11 @@ sub output_package_info{ } if (defined $gSubscriptionDomain) { my $ptslink = $package ? $srcforpkg : $src; - push @references, "to the Package Tracking System"; + push @references, q(to the Package Tracking System); } # Only output this if the source listing is non-trivial. if ($srcorbin eq 'binary' and $srcforpkg) { - push @references, sprintf "to the source package %s's bug page", html_escape(munge_url($this,src=>$srcforpkg,package=>[])), html_escape($srcforpkg); + push @references, sprintf "to the source package %s's bug page", html_escape(munge_url($this,src=>$srcforpkg,package=>[],newest=>[])), html_escape($srcforpkg); } } if (@references) { @@ -444,9 +474,8 @@ sub output_package_info{ html_escape("http://${debbugs::gWebDomain}/Reporting${debbugs::gHTMLSuffix}"); } if (not $maint and not @bugs) { - print "

There is no record of the " . - ($srcorbin eq 'binary' ? html_escape($package) . " package" - : html_escape($src) . " source package"). + print "

There is no record of the " . html_escape($package) . + ($srcorbin eq 'binary' ? " package" : " source package") . ", and no bugs have been filed against it.

"; $showresult = 0; } @@ -506,12 +535,12 @@ print " [0]); print ""; print " $pkgsane version \n"; } elsif (defined $src) { my $v = html_escape($version) || ""; - my $srcsane = html_escape($src); + my $srcsane = html_escape($src->[0]); print ""; print " $srcsane version \n"; } @@ -542,7 +571,6 @@ print <  - Merged bugs should be