]> git.donarmstrong.com Git - debbugs.git/blobdiff - cgi/pkgreport.cgi
[project @ 2000-11-26 11:52:18 by joy]
[debbugs.git] / cgi / pkgreport.cgi
index 479cf4ae7671889be1b5bbde504f930f4626e581..567bea69e2fe54cbd0c6094801c3fecce649456b 100755 (executable)
@@ -3,39 +3,41 @@
 package debbugs;
 
 use strict;
-use CGI qw/:standard/;
 use POSIX qw(strftime tzset nice);
 
-require '/debian/home/ajt/newajbug/common.pl';
-#require '/usr/lib/debbugs/common.pl';
 #require '/usr/lib/debbugs/errorlib';
+require './common.pl';
 
 require '/etc/debbugs/config';
 require '/etc/debbugs/text';
 
 nice(5);
 
+my %param = readparse();
+
 my ($pkg, $maint, $maintenc, $submitter, $severity, $status);
 
-if (defined ($pkg = param('pkg'))) {
-} elsif (defined ($maint = param('maint'))) {
-} elsif (defined ($maintenc = param('maintenc'))) {
-} elsif (defined ($submitter= param('submitter'))) { 
-} elsif (defined ($severity = param('severity'))) { 
-       $status = param('status') || 'open';
+if (defined ($pkg = $param{'pkg'})) {
+} elsif (defined ($maint = $param{'maint'})) {
+} elsif (defined ($maintenc = $param{'maintenc'})) {
+} elsif (defined ($submitter= $param{'submitter'})) { 
+} elsif (defined ($severity = $param{'severity'})) { 
+       $status = $param{'status'} || 'open';
 } else {
-       $pkg = "ALL";
+       quit("You have to choose something to select by");
 }
 
-my $repeatmerged = (param('repeatmerged') || "yes") eq "yes";
-my $archive = (param('archive') || "no") eq "yes";
+my $repeatmerged = ($param{'repeatmerged'} || "yes") eq "yes";
+my $archive = ($param{'archive'} || "no") eq "yes";
+my $include = $param{'include'} || "";
+my $exclude = $param{'exclude'} || "";
 
 my $Archived = $archive ? "Archived" : "";
 
 my $this = "";
 
 my %indexentry;
-my %maintainer = &getmaintainers();
+my %maintainers = getmaintainers();
 my %strings = ();
 
 $ENV{"TZ"} = 'UTC';
@@ -46,52 +48,68 @@ my $tail_html = $debbugs::gHTMLTail;
 $tail_html = $debbugs::gHTMLTail;
 $tail_html =~ s/SUBSTITUTE_DTIME/$dtime/;
 
-my $tag;
-if (defined $pkg) {
-    $tag = "package $pkg";
-} elsif (defined $maint) {
-    $tag = "maintainer $maint";
-} elsif (defined $maintenc) {
-    $tag = "encoded maintainer $maintenc";
-} elsif (defined $submitter) {
-    $tag = "submitter $submitter";
-} elsif (defined $severity) {
-    $tag = "$status $severity bugs";
-}
-
 set_option("repeatmerged", $repeatmerged);
 set_option("archive", $archive);
+set_option("include", { map {($_,1)} (split /[\s,]+/, $include) })
+       if ($include);
+set_option("exclude", { map {($_,1)} (split /[\s,]+/, $exclude) })
+       if ($exclude);
 
+my $tag;
 my @bugs;
 if (defined $pkg) {
-    @bugs = pkgbugs($pkg);
+  $tag = "package $pkg";
+  #@bugs = pkgbugs($pkg);
+  @bugs = getbugs(sub {my %d=@_; return $pkg eq $d{"pkg"}});
 } elsif (defined $maint) {
-    @bugs = maintbugs($maint);
+  $tag = "maintainer $maint";
+  #@bugs = maintbugs($maint);
+  @bugs = getbugs(sub {my %d=@_; my $me; 
+                      ($me = $maintainers{$d{"pkg"}}||"") =~ s/\s*\(.*\)\s*//;
+                      $me = $1 if ($me =~ m/<(.*)>/);
+                      return $me eq $maint;
+                    })
 } elsif (defined $maintenc) {
-    @bugs = maintencbugs($maintenc);
+  $tag = "encoded maintainer $maintenc";
+  #@bugs = maintencbugs($maintenc);
+  @bugs = getbugs(sub {my %d=@_; 
+                      return maintencoded($maintainers{$d{"pkg"}} || "") 
+                        eq $maintenc
+                      });
 } elsif (defined $submitter) {
-    @bugs = submitterbugs($submitter);
+  $tag = "submitter $submitter";
+  #@bugs = submitterbugs($submitter);
+  @bugs = getbugs(sub {my %d=@_; my $se; 
+                      ($se = $d{"submitter"} || "") =~ s/\s*\(.*\)\s*//;
+                      $se = $1 if ($se =~ m/<(.*)>/);
+                      return $se eq $submitter;
+                    });
 } elsif (defined $severity) {
-    @bugs = severitybugs($status, $severity);
+  $tag = "$status $severity bugs";
+  #@bugs = severitybugs($status, $severity);
+  @bugs = getbugs(sub {my %d=@_;
+                      return ($d{"severity"} eq $severity) 
+                        && ($d{"status"} eq $status);
+                    });
 }
 
 my $result = htmlizebugs(@bugs);
 
-print header;
-print start_html(
-        -TEXT => "#000000",
-        -BGCOLOR=>"#FFFFFF",
-        -LINK => "#0000FF",
-        -VLINK => "#800080",
-        -title => "$debbugs::gProject $Archived $debbugs::gBug report logs: $tag");
+print "Content-Type: text/html\n\n";
 
-print h1("$debbugs::gProject $Archived $debbugs::gBug report logs: $tag");
+print "<HTML><HEAD><TITLE>\n" . 
+    "$debbugs::gProject $Archived $debbugs::gBug report logs: $tag\n" .
+    "</TITLE></HEAD>\n" .
+    '<BODY TEXT="#000000" BGCOLOR="#FFFFFF" LINK="#0000FF" VLINK="#800080">' .
+    "\n";
+print "<H1>" . "$debbugs::gProject $Archived $debbugs::gBug report logs: $tag" .
+      "</H1>\n";
 
 if (defined $pkg) {
-    if (defined $maintainer{$pkg}) {
+    if (defined $maintainers{$pkg}) {
         print "<p>Maintainer for $pkg is <a href=\"" 
-              . mainturl($maintainer{$pkg}) . "\">"
-              . htmlsanit($maintainer{$pkg}) . "</a>.</p>\n";
+              . mainturl($maintainers{$pkg}) . "\">"
+              . htmlsanit($maintainers{$pkg}) . "</a>.</p>\n";
     }
     print "<p>Note that with multi-binary packages there may be other\n";
     print "reports filed under the different binary package names.</p>\n";
@@ -109,7 +127,7 @@ if (defined $pkg) {
 
 print $result;
 
-print hr;
+print "<hr>\n";
 print "$tail_html";
 
-print end_html;
+print "</body></html>\n";