[BACK]Return to cvsweb.cgi CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / cvsweb

Diff for /cvsweb/cvsweb.cgi between version 1.1.1.10 and 1.1.1.11

version 1.1.1.10, 2000/10/07 07:50:18 version 1.1.1.11, 2000/10/20 15:54:58
Line 43 
Line 43 
 # SUCH DAMAGE.  # SUCH DAMAGE.
 #  #
 # $zId: cvsweb.cgi,v 1.103 2000/09/20 17:02:29 jumager Exp $  # $zId: cvsweb.cgi,v 1.103 2000/09/20 17:02:29 jumager Exp $
 # $kId: cvsweb.cgi,v 1.33 2000/10/07 07:44:12 knu Exp $  # $kId: cvsweb.cgi,v 1.37 2000/10/20 15:46:01 knu Exp $
 #  #
 ###  ###
   
Line 52  use strict;
Line 52  use strict;
 use vars qw (  use vars qw (
     $config $allow_version_select $verbose      $config $allow_version_select $verbose
     %CVSROOT %CVSROOTdescr %MIRRORS %DEFAULTVALUE %ICONS %MTYPES      %CVSROOT %CVSROOTdescr %MIRRORS %DEFAULTVALUE %ICONS %MTYPES
       @DIFFTYPES %DIFFTYPES @LOGSORTKEYS %LOGSORTKEYS
     %alltags @tabcolors %fileinfo %tags @branchnames %nameprinted      %alltags @tabcolors %fileinfo %tags @branchnames %nameprinted
     %symrev %revsym @allrevisions %date %author @revdisplayorder      %symrev %revsym @allrevisions %date %author @revdisplayorder
     @revisions %state %difflines %log %branchpoint @revorder      @revisions %state %difflines %log %branchpoint @revorder
Line 59  use vars qw (
Line 60  use vars qw (
     $checkoutMagic $doCheckout $scriptname $scriptwhere      $checkoutMagic $doCheckout $scriptname $scriptwhere
     $where $pathinfo $Browser $nofilelinks $maycompress @stickyvars      $where $pathinfo $Browser $nofilelinks $maycompress @stickyvars
     %funcline_regexp $is_mod_perl      %funcline_regexp $is_mod_perl
     $is_lynx $is_w3m $is_msie $is_mozilla3 $is_textbased      $is_links $is_lynx $is_w3m $is_msie $is_mozilla3 $is_textbased
     %input $query $barequery $sortby $bydate $byrev $byauthor      %input $query $barequery $sortby $bydate $byrev $byauthor
     $bylog $byfile $hr_default $logsort $cvstree $cvsroot      $bylog $byfile $defaultDiffType $logsort $cvstree $cvsroot
     $mimetype $defaultTextPlain $defaultViewable $allow_compress      $mimetype $defaultTextPlain $defaultViewable $allow_compress
     $GZIPBIN $backicon $diricon $fileicon $fullname $newname      $GZIPBIN $backicon $diricon $fileicon $fullname $newname
     $cvstreedefault $body_tag $body_tag_for_src      $cvstreedefault $body_tag $body_tag_for_src
Line 74  use vars qw (
Line 75  use vars qw (
     $difffontsize $inputTextSize $mime_types $allow_annotate      $difffontsize $inputTextSize $mime_types $allow_annotate
     $allow_markup $use_java_script $open_extern_window      $allow_markup $use_java_script $open_extern_window
     $extern_window_width $extern_window_height $edit_option_form      $extern_window_width $extern_window_height $edit_option_form
     $checkout_magic $show_subdir_lastmod $show_log_in_markup $v      $show_subdir_lastmod $show_log_in_markup $v
     $navigationHeaderColor $tableBorderColor $markupLogColor      $navigationHeaderColor $tableBorderColor $markupLogColor
     $tabstop $state $annTable $sel $curbranch @HideModules      $tabstop $state $annTable $sel $curbranch @HideModules
     $module $use_descriptions %descriptions @mytz $dwhere $moddate      $module $use_descriptions %descriptions @mytz $dwhere $moddate
Line 83  use vars qw (
Line 84  use vars qw (
 );  );
   
 sub printDiffSelect($);  sub printDiffSelect($);
   sub printDiffLinks($$);
   sub printLogSortSelect($);
 sub findLastModifiedSubdirs(@);  sub findLastModifiedSubdirs(@);
   sub htmlify_sub(&$);
 sub htmlify($;$);  sub htmlify($;$);
 sub spacedHtmlText($;$);  sub spacedHtmlText($;$);
 sub link($$);  sub link($$);
Line 116  sub download_url($$;$);
Line 120  sub download_url($$;$);
 sub download_link($$$;$);  sub download_link($$$;$);
 sub toggleQuery($$);  sub toggleQuery($$);
 sub urlencode($);  sub urlencode($);
   sub htmlquote($);
   sub htmlunquote($);
 sub http_header(;$);  sub http_header(;$);
 sub html_header($);  sub html_header($);
 sub html_footer();  sub html_footer();
Line 156  $diffcolorChange = $diffcolorAdd = $diffcolorDarkChang
Line 162  $diffcolorChange = $diffcolorAdd = $diffcolorDarkChang
 $difffontsize = $inputTextSize = $mime_types = $allow_annotate =  $difffontsize = $inputTextSize = $mime_types = $allow_annotate =
 $allow_markup = $use_java_script = $open_extern_window =  $allow_markup = $use_java_script = $open_extern_window =
 $extern_window_width = $extern_window_height = $edit_option_form =  $extern_window_width = $extern_window_height = $edit_option_form =
 $checkout_magic = $show_subdir_lastmod = $show_log_in_markup = $v =  $show_subdir_lastmod = $show_log_in_markup = $v =
 $navigationHeaderColor = $tableBorderColor = $markupLogColor =  $navigationHeaderColor = $tableBorderColor = $markupLogColor =
 $tabstop = $use_moddate = $moddate = $gzip_open = undef;  $tabstop = $use_moddate = $moddate = $gzip_open = undef;
   
 $LOG_FILESEPARATOR = q/^={77}$/;  $LOG_FILESEPARATOR = q/^={77}$/;
 $LOG_REVSEPARATOR = q/^-{28}$/;  $LOG_REVSEPARATOR = q/^-{28}$/;
   
   @DIFFTYPES = qw(h H u c s);
   @DIFFTYPES{@DIFFTYPES} = (
                             {
                              'descr'   => 'colored',
                              'opts'    => [ '-u' ],
                              'colored' => 1,
                             },
                             {
                              'descr'   => 'long colored',
                              'opts'    => [ '--unified=15' ],
                              'colored' => 1,
                             },
                             {
                              'descr'   => 'unified',
                              'opts'    => [ '-u' ],
                              'colored' => 0,
                             },
                             {
                              'descr'   => 'context',
                              'opts'    => [ '-c' ],
                              'colored' => 0,
                             },
                             {
                              'descr'   => 'side by side',
                              'opts'    => [ '--side-by-side', '--width=164' ],
                              'colored' => 0,
                             },
                            );
   
   @LOGSORTKEYS = qw(cvs date rev);
   @LOGSORTKEYS{@LOGSORTKEYS} = (
                                 {
                                  'descr' => 'Not sorted',
                                 },
                                 {
                                  'descr' => 'Commit date',
                                 },
                                 {
                                  'descr' => 'Revision',
                                 },
                                );
   
   
 ##### End of configuration variables #####  ##### End of configuration variables #####
   
 use Time::Local;  use Time::Local;
Line 196  $is_mod_perl = defined($ENV{MOD_PERL});
Line 245  $is_mod_perl = defined($ENV{MOD_PERL});
 # per file, so disable the link at the icon  # per file, so disable the link at the icon
 # in this case:  # in this case:
 $Browser = $ENV{HTTP_USER_AGENT};  $Browser = $ENV{HTTP_USER_AGENT};
   $is_links = ($Browser =~ m`^Links `);
 $is_lynx = ($Browser =~ m`^Lynx/`i);  $is_lynx = ($Browser =~ m`^Lynx/`i);
 $is_w3m = ($Browser =~ m`^w3m/`i);  $is_w3m = ($Browser =~ m`^w3m/`i);
 $is_msie = ($Browser =~ m`MSIE`);  $is_msie = ($Browser =~ m`MSIE`);
 $is_mozilla3 = ($Browser =~ m`^Mozilla/[3-9]`);  $is_mozilla3 = ($Browser =~ m`^Mozilla/[3-9]`);
   
 $is_textbased = ($is_lynx || $is_w3m);  $is_textbased = ($is_links || $is_lynx || $is_w3m);
   
 $nofilelinks = $is_textbased;  $nofilelinks = $is_textbased;
   
Line 293  foreach (@stickyvars) {
Line 343  foreach (@stickyvars) {
 }  }
 # is there any query ?  # is there any query ?
 if (@barequery) {  if (@barequery) {
     $barequery = join('&', @barequery);      $barequery = join('&', @barequery);
     $query = "?$barequery";      $query = "?$barequery";
     $barequery = "&$barequery";      $barequery = "&$barequery";
 }  }
 else {  else {
     $query = "";      $query = "";
Line 325  else {
Line 375  else {
     $byfile = 1;      $byfile = 1;
 }  }
   
 $hr_default = $input{'f'} eq 'h';  $defaultDiffType = $input{'f'};
   
 $logsort = $input{'logsort'};  $logsort = $input{'logsort'};
   
Line 353  foreach $k (keys %ICONS) {
Line 403  foreach $k (keys %ICONS) {
     no strict 'refs';      no strict 'refs';
     my ($itxt,$ipath,$iwidth,$iheight) = @{$ICONS{$k}};      my ($itxt,$ipath,$iwidth,$iheight) = @{$ICONS{$k}};
     if ($ipath) {      if ($ipath) {
         ${"${k}icon"} = "<IMG SRC=\"$ipath\" ALT=\"$itxt\" BORDER=\"0\" WIDTH=\"$iwidth\" HEIGHT=\"$iheight\">";          ${"${k}icon"} = sprintf('<IMG SRC="%s" ALT="%s" BORDER="0" WIDTH="%d" HEIGHT="%d">',
                                   htmlquote($ipath), htmlquote($itxt), $iwidth, $iheight)
     }      }
     else {      else {
         ${"${k}icon"} = $itxt;          ${"${k}icon"} = $itxt;
Line 479  elsif (-d $fullname) {
Line 530  elsif (-d $fullname) {
             }              }
             print "<table  width=\"100%\" border=0 cellspacing=1 cellpadding=$tablepadding>\n";              print "<table  width=\"100%\" border=0 cellspacing=1 cellpadding=$tablepadding>\n";
             $infocols++;              $infocols++;
             print "<tr><th align=left bgcolor=\"" . (($byfile) ?              printf '<tr><th align=left bgcolor="%s">',
                                                    $columnHeaderColorSorted :                $byfile ? $columnHeaderColorSorted : $columnHeaderColorDefault;
                                                    $columnHeaderColorDefault) . "\">";              if ($byfile) {
             print "<a href=\"./" . &toggleQuery("sortby","file") .                  print 'File';
                 "#dirlist\">" if (!$byfile);              } else {
             print "File";                  print &link('File', sprintf('./%s#dirlist',
             print "</a>" if (!$byfile);                                              &toggleQuery("sortby", "file")));
               }
             print "</th>";              print "</th>";
             # do not display the other column-headers, if we do not have any files              # do not display the other column-headers, if we do not have any files
             # with revision information:              # with revision information:
             if (scalar(%fileinfo)) {              if (scalar(%fileinfo)) {
                 $infocols++;                  $infocols++;
                 print "<th align=left bgcolor=\"" . (($byrev) ?                  printf '<th align=left bgcolor="%s">',
                                                    $columnHeaderColorSorted :                    $byrev ? $columnHeaderColorSorted : $columnHeaderColorDefault;
                                                    $columnHeaderColorDefault) . "\">";                  if ($byrev) {
                 print "<a href=\"./" . &toggleQuery ("sortby","rev") .                      print 'Rev.';
                     "#dirlist\">" if (!$byrev);                  } else {
                 print "Rev.";                      print &link('Rev.', sprintf('./%s#dirlist',
                 print "</a>" if (!$byrev);                                                  &toggleQuery("sortby", "rev")));
                   }
                 print "</th>";                  print "</th>";
                 $infocols++;                  $infocols++;
                 print "<th align=left bgcolor=\"" . (($bydate) ?                  printf '<th align=left bgcolor="%s">',
                                                    $columnHeaderColorSorted :                    $bydate ? $columnHeaderColorSorted : $columnHeaderColorDefault;
                                                    $columnHeaderColorDefault) . "\">";                  if ($bydate) {
                 print "<a href=\"./" . &toggleQuery ("sortby","date") .                      print 'Age';
                     "#dirlist\">" if (!$bydate);                  } else {
                 print "Age";                      print &link('Age', sprintf('./%s#dirlist',
                 print "</a>" if (!$bydate);                                                 &toggleQuery("sortby", "date")));
                   }
                 print "</th>";                  print "</th>";
                 if ($show_author) {                  if ($show_author) {
                     $infocols++;                      $infocols++;
                     print "<th align=left bgcolor=\"" . (($byauthor) ?                      printf '<th align=left bgcolor="%s">',
                                                    $columnHeaderColorSorted :                        $byauthor ? $columnHeaderColorSorted : $columnHeaderColorDefault;
                                                    $columnHeaderColorDefault) . "\">";                      if ($byauthor) {
                     print "<a href=\"./" . &toggleQuery ("sortby","author") .                          print 'Author';
                             "#dirlist\">" if (!$byauthor);                      } else {
                     print "Author";                          print &link('Author', sprintf('./%s#dirlist',
                     print "</a>" if (!$byauthor);                                                        &toggleQuery("sortby", "author")));
                       }
                     print "</th>";                      print "</th>";
                 }                  }
                 $infocols++;                  $infocols++;
                 print "<th align=left bgcolor=\"" . (($bylog) ?                  printf '<th align=left bgcolor="%s">',
                                                $columnHeaderColorSorted :                    $bylog ? $columnHeaderColorSorted : $columnHeaderColorDefault;
                                                $columnHeaderColorDefault) . "\">";                  if ($bylog) {
                 print "<a href=\"./", toggleQuery("sortby","log"), "#dirlist\">" if (!$bylog);                      print 'Last log entry';
                 print "Last log entry";                  } else {
                 print "</a>" if (!$bylog);                      print &link('Last log entry', sprintf('./%s#dirlist',
                                                             &toggleQuery("sortby", "log")));
                   }
                 print "</th>";                  print "</th>";
             }              }
             elsif ($use_descriptions) {              elsif ($use_descriptions) {
                 print "<th align=left bgcolor=\"". $columnHeaderColorDefault . "\">";                  printf '<th align=left bgcolor="%s">', $columnHeaderColorDefault;
                 print "Description";                  print "Description";
                 $infocols++;                  $infocols++;
             }              }
Line 554  elsif (-d $fullname) {
Line 611  elsif (-d $fullname) {
             closedir($dh);              closedir($dh);
         }          }
   
         my $hideAtticToggleLink = "<a href=\"./" .          my $hideAtticToggleLink = $input{'hideattic'} ? '' :
                 &toggleQuery ("hideattic") .            &link('[Hide]', sprintf('./%s#dirlist',
                 "#dirlist\">[Hide]</a>" if (!$input{'hideattic'});                                    &toggleQuery ("hideattic")));
   
         # Sort without the Attic/ pathname.          # Sort without the Attic/ pathname.
         # place directories first          # place directories first
Line 594  elsif (-d $fullname) {
Line 651  elsif (-d $fullname) {
                 next if ($_ eq '..' && $where eq '/');                  next if ($_ eq '..' && $where eq '/');
                 my ($rev,$date,$log,$author,$filename) = @{$fileinfo{$_}}                  my ($rev,$date,$log,$author,$filename) = @{$fileinfo{$_}}
                     if (defined($fileinfo{$_}));                      if (defined($fileinfo{$_}));
                 print "<tr bgcolor=\"" . @tabcolors[$dirrow%2] . "\"><td>" if ($dirtable);                  printf '<tr bgcolor="%s"><td>', $tabcolors[$dirrow % 2] if $dirtable;
                 if ($_ eq '..') {                  if ($_ eq '..') {
                     $url = "../" . $query;                      $url = "../$query";
                     if ($nofilelinks) {                      if ($nofilelinks) {
                         print $backicon;                          print $backicon;
                     }                      }
                     else {                      else {
                         print &link($backicon,$url);                          print &link($backicon, $url);
                     }                      }
                     print " ", &link("Previous Directory",$url);                      print " ", &link("Previous Directory", $url);
                 }                  }
                 else {                  else {
                     $url = urlencode($_) . '/' . $query;                      $url = urlencode($_) . "/$query";
                     print "<A NAME=\"$_\"></A>";                      print "<A NAME=\"$_\"></A>";
                     if ($nofilelinks) {                      if ($nofilelinks) {
                         print $diricon;                          print $diricon;
                     }                      }
                     else {                      else {
                         print &link($diricon,$url);                          print &link($diricon, $url);
                     }                      }
                     print " ", &link($_ . "/", $url), $attic;                      print " ", &link("$_/", $url), $attic;
                     if ($_ eq "Attic") {                      if ($_ eq "Attic") {
                         print "&nbsp; <a href=\"./" .                          print "&nbsp; ";
                             &toggleQuery ("hideattic") .                          print &link("[Don't hide]", sprintf('./%s#dirlist',
                                 "#dirlist\">[Don't hide]</a>";                                                              &toggleQuery ("hideattic")));
                     }                      }
                 }                  }
                 # Show last change in dir                  # Show last change in dir
                 if ($filename) {                  if ($filename) {
                     print "</td><td>&nbsp;</td><td>&nbsp;" if ($dirtable);                      print "</td><td>&nbsp;</td><td>&nbsp;" if ($dirtable);
                     if ($date) {                      if ($date) {
                         print " <i>" . readableTime(time() - $date,0) . "</i>";                          print " <i>", readableTime(time() - $date,0), "</i>";
                     }                      }
                     if ($show_author) {                      if ($show_author) {
                         print "</td><td>&nbsp;" if ($dirtable);                          print "</td><td>&nbsp;" if ($dirtable);
Line 636  elsif (-d $fullname) {
Line 693  elsif (-d $fullname) {
                     print "$filename/$rev";                      print "$filename/$rev";
                     print "<BR>" if ($dirtable);                      print "<BR>" if ($dirtable);
                     if ($log) {                      if ($log) {
                         print "&nbsp;<font size=-1>"                          print "&nbsp;<font size=-1>",
                             . &htmlify(substr($log,0,$shortLogLen));                            &htmlify(substr($log,0,$shortLogLen));
                         if (length $log > 80) {                          if (length $log > 80) {
                             print "...";                              print "...";
                         }                          }
Line 647  elsif (-d $fullname) {
Line 704  elsif (-d $fullname) {
                 else {                  else {
                     my ($dwhere) = ($where ne "/" ? $where : "") . $_;                      my ($dwhere) = ($where ne "/" ? $where : "") . $_;
                     if ($use_descriptions && defined $descriptions{$dwhere}) {                      if ($use_descriptions && defined $descriptions{$dwhere}) {
                         print "<TD COLSPAN=" . ($infocols-1) . ">&nbsp;" if $dirtable;                          print "<TD COLSPAN=", ($infocols-1), ">&nbsp;" if $dirtable;
                         print $descriptions{$dwhere};                          print $descriptions{$dwhere};
                     } elsif ($dirtable && $infocols > 1) {                      } elsif ($dirtable && $infocols > 1) {
                         # close the row with the appropriate number of                          # close the row with the appropriate number of
Line 678  elsif (-d $fullname) {
Line 735  elsif (-d $fullname) {
                 next if (!defined($fileinfo{$_}));                  next if (!defined($fileinfo{$_}));
                 ($rev,$date,$log,$author) = @{$fileinfo{$_}};                  ($rev,$date,$log,$author) = @{$fileinfo{$_}};
                 $filesfound++;                  $filesfound++;
                 print "<tr bgcolor=\"" . @tabcolors[$dirrow%2] . "\"><td>" if ($dirtable);                  printf '<tr bgcolor="%s"><td>', $tabcolors[$dirrow % 2] if $dirtable;
                 print "<A NAME=\"$_\"></A>";                  print "<A NAME=\"$_\"></A>";
                 if ($nofilelinks) {                  if ($nofilelinks) {
                     print $fileicon;                      print $fileicon;
Line 689  elsif (-d $fullname) {
Line 746  elsif (-d $fullname) {
                 print " ", &link($_, $url), $attic;                  print " ", &link($_, $url), $attic;
                 print "</td><td>&nbsp;" if ($dirtable);                  print "</td><td>&nbsp;" if ($dirtable);
                 download_link($fileurl,                  download_link($fileurl,
                         $rev, $rev,                                $rev, $rev,
                         $defaultViewable ? "text/x-cvsweb-markup" : undef);                                $defaultViewable ? "text/x-cvsweb-markup" : undef);
                 print "</td><td>&nbsp;" if ($dirtable);                  print "</td><td>&nbsp;" if ($dirtable);
                 if ($date) {                  if ($date) {
                     print " <i>" . readableTime(time() - $date,0) . "</i>";                      print " <i>", readableTime(time() - $date,0), "</i>";
                 }                  }
                 if ($show_author) {                  if ($show_author) {
                     print "</td><td>&nbsp;" if ($dirtable);                      print "</td><td>&nbsp;" if ($dirtable);
Line 701  elsif (-d $fullname) {
Line 758  elsif (-d $fullname) {
                 }                  }
                 print "</td><td>&nbsp;" if ($dirtable);                  print "</td><td>&nbsp;" if ($dirtable);
                 if ($log) {                  if ($log) {
                     print " <font size=-1>" . &htmlify(substr($log,0,$shortLogLen));                      print " <font size=-1>", &htmlify(substr($log,0,$shortLogLen));
                     if (length $log > 80) {                      if (length $log > 80) {
                         print "...";                          print "...";
                     }                      }
Line 716  elsif (-d $fullname) {
Line 773  elsif (-d $fullname) {
         if ($dirtable && defined($tableBorderColor)) {          if ($dirtable && defined($tableBorderColor)) {
             print "</td></tr></table>";              print "</td></tr></table>";
         }          }
         print "". ($dirtable == 1) ? "</table>" : "</menu>" . "\n";          print( $dirtable == 1 ? "</table>\n" : "</menu>\n" );
   
         if ($filesexists && !$filesfound) {          if ($filesexists && !$filesfound) {
             print "<P><B>NOTE:</B> There are $filesexists files, but none matches the current tag ($input{only_with_tag})\n";              print "<P><B>NOTE:</B> There are $filesexists files, but none matches the current tag ($input{only_with_tag})\n";
Line 774  elsif (-d $fullname) {
Line 831  elsif (-d $fullname) {
             print "<OPTION",$byrev ? " SELECTED" : ""," VALUE=rev>Revision";              print "<OPTION",$byrev ? " SELECTED" : ""," VALUE=rev>Revision";
             print "<OPTION",$bylog ? " SELECTED" : ""," VALUE=log>Log message";              print "<OPTION",$bylog ? " SELECTED" : ""," VALUE=log>Log message";
             print "</SELECT></td>";              print "</SELECT></td>";
             print "<td>revisions by: \n";              print "<td>Sort log by: ";
             print "<SELECT NAME=logsort>\n";              printLogSortSelect(0);
             print "<OPTION VALUE=cvs",$logsort eq "cvs" ? " SELECTED" : "", ">Not sorted";              print "</td></tr>";
             print "<OPTION VALUE=date",$logsort eq "date" ? " SELECTED" : "", ">Commit date";  
             print "<OPTION VALUE=rev",$logsort eq "rev" ? " SELECTED" : "", ">Revision";  
             print "</SELECT></td></tr>";  
             print "<tr><td>Diff format: ";              print "<tr><td>Diff format: ";
             printDiffSelect(0);              printDiffSelect(0);
             print "</td>";              print "</td>";
Line 873  gzipclose();
Line 927  gzipclose();
   
 sub printDiffSelect($) {  sub printDiffSelect($) {
     my ($use_java_script) = @_;      my ($use_java_script) = @_;
     my ($f) = $input{'f'};      my $f = $input{'f'};
     print "<SELECT NAME=\"f\"";  
     print " onchange=\"submit()\"" if ($use_java_script);      print '<SELECT NAME="f"';
     print ">\n";      print ' onchange="submit()"' if $use_java_script;
     print "<OPTION VALUE=h",$f eq "h" ? " SELECTED" : "", ">Colored Diff";      print '>';
     print "<OPTION VALUE=H",$f eq "H" ? " SELECTED" : "", ">Long Colored Diff";  
     print "<OPTION VALUE=u",$f eq "u" ? " SELECTED" : "", ">Unidiff";      local $_;
     print "<OPTION VALUE=c",$f eq "c" ? " SELECTED" : "", ">Context Diff";      for (@DIFFTYPES) {
     print "<OPTION VALUE=s",$f eq "s" ? " SELECTED" : "", ">Side by Side";          printf('<OPTION VALUE="%s"%s>%s',
                  $_,
                  $f eq $_ ? ' SELECTED' : '',
                  "\u$DIFFTYPES{$_}{'descr'}"
                 );
       }
   
     print "</SELECT>";      print "</SELECT>";
 }  }
   
   sub printLogSortSelect($) {
       my ($use_java_script) = @_;
   
       print '<SELECT NAME="logsort"';
       print ' onchange="submit()"' if $use_java_script;
       print '>';
   
       local $_;
       for (@LOGSORTKEYS) {
           printf('<OPTION VALUE="%s"%s>%s',
                  $_,
                  $logsort eq $_ ? ' SELECTED' : '',
                  "\u$LOGSORTKEYS{$_}{'descr'}"
                 );
       }
   
       print "</SELECT>";
   }
   
 sub findLastModifiedSubdirs(@) {  sub findLastModifiedSubdirs(@) {
     my (@dirs) = @_;      my (@dirs) = @_;
     my ($dirname, @files);      my ($dirname, @files);
Line 919  sub findLastModifiedSubdirs(@) {
Line 998  sub findLastModifiedSubdirs(@) {
     return @files;      return @files;
 }  }
   
   sub htmlify_sub(&$) {
       (my $proc, local $_) = @_;
       local @_ = split(m`(<a [^>]+>[^<]*</a>)`i);
       my ($linked, $result);
   
       while (($_, $linked) = splice(@_, 0, 2)) {
           &$proc();
           $result .= $_;
           $result .= $linked;
       }
   
       $result;
   }
   
 sub htmlify($;$) {  sub htmlify($;$) {
         my($string, $extra) = @_;      (local $_, my $extra) = @_;
   
         # Special Characters; RFC 1866      $_ = htmlquote($_);
         $string =~ s/&/&amp;/g;  
         $string =~ s/\"/&quot;/g;  
         $string =~ s/</&lt;/g;  
         $string =~ s/>/&gt;/g;  
   
         # get URL's as link ..      # get URL's as link
         $string =~ s`(http|ftp|https)(://[-a-zA-Z0-9%.~:_/]+)([?&]([-a-zA-Z0-9%.~:_]+)=([-a-zA-Z0-9%.~:_])+)*`<A HREF="$1$2$3">$1$2$3</A>`g;    # `      s{
         # get e-mails as link        (http|ftp|https)://\S+
         $string =~ s`([-a-zA-Z0-9_.]+@([-a-zA-Z0-9]+\.)+[A-Za-z]{2,4})`<A HREF="mailto:$1">$1</A>`g;    # `       }{
            &link($&, htmlunquote($&))
        }egx;
   
         if ($extra) {      # get e-mails as link
             # get PR #'s as link ..      $_ = htmlify_sub {
             if (defined($prcgi)) {          s<
                 1 while $string =~ s`\b(pr[:#]?\s*(?:#?\d+[,\s]\s*)*#?)(\d+)\b`$1 . &link($2, sprintf($prcgi, $2))`ie; # `;            [\w+=\-.!]+@[\w\-]+(\.[\w\-]+)+
                 $string =~ s`\b${prcategories}/(\d+)\b`&link($&, sprintf($prcgi, $1))`igeo;     # `;              ><
             }                &link($&, "mailto:$&")
                   >egix;
       } $_;
   
             # get manpage specs as link ..      if ($extra) {
             if (defined($mancgi)) {          # get PR #'s as link: "PR#nnnn" "PR: nnnn, ..." "PR nnnn, ..." "bin/nnnn"
                 $string =~ s`\b([a-zA-Z]\w+)(?:\(([0-9n])\)\B|\.([0-9n])\b)`&link($&, sprintf($mancgi, $2 ne '' ? $2 : $3, $1))`ge; # `x;          if (defined($prcgi)) {
             }              my $prev;
   
               do {
                   $prev = $_;
   
                   $_ = htmlify_sub {
                       s{
                         (\bPR[:\#]?\s*
                          (?:
                           \#?
                           \d+[,\s]\s*
                          )*
                          \#?)
                         (\d+)\b
                        }{
                            $1 . &link($2, sprintf($prcgi, $2)) . $3
                        }egix;
                   } $_;
               } while ($_ ne $prev);
   
               $_ = htmlify_sub {
                   s{
                     (\b$prcategories/(\d+)\b)
                    }{
                        &link($1, sprintf($prcgi, $2)) . $3
                    }egox;
               } $_;
         }          }
   
         return $string;          # get manpage specs as link: "foo.1" "foo(1)"
           if (defined($mancgi)) {
               $_ = htmlify_sub {
                   s{
                     (\b([a-zA-Z][\w_.]+)
                      (?:
                       \( ([0-9n]) \)\B
                       |
                       \.([0-9n])\b
                      )
                     )
                    }{
                        &link($1, sprintf($mancgi, $3 ne '' ? $3 : $4, $2)) . $5
                    }egx;
               } $_;
           }
       }
   
       $_;
 }  }
   
 sub spacedHtmlText($;$) {  sub spacedHtmlText($;$) {
Line 982  sub spacedHtmlText($;$) {
Line 1119  sub spacedHtmlText($;$) {
 sub link($$) {  sub link($$) {
         my($name, $where) = @_;          my($name, $where) = @_;
   
         return "<A HREF=\"$where\">$name</A>";          sprintf '<A HREF="%s">%s</A>', htmlquote($where), $name;
 }  }
   
 sub revcmp($$) {  sub revcmp($$) {
Line 1030  sub redirect($) {
Line 1167  sub redirect($) {
                 print "Location: $url\r\n";                  print "Location: $url\r\n";
         }          }
         html_header("Moved");          html_header("Moved");
         print "This document is located <A HREF=$url>here</A>.\n";          print "This document is located ", &link('here', $url), "\n";
         print &html_footer;          print &html_footer;
         exit(1);          exit(1);
 }  }
Line 1056  sub safeglob($) {
Line 1193  sub safeglob($) {
                 $glob =~ s/{([^}]+)}/($t = $1) =~ s-,-|-g; "($t)"/eg;                  $glob =~ s/{([^}]+)}/($t = $1) =~ s-,-|-g; "($t)"/eg;
                 foreach (readdir($dh)) {                  foreach (readdir($dh)) {
                         if (/^${glob}$/) {                          if (/^${glob}$/) {
                                 push(@results, $dirname . "/" .$_);                                  push(@results, "$dirname/" .$_);
                         }                          }
                 }                  }
         }          }
Line 1255  sub doAnnotate($$) {
Line 1392  sub doAnnotate($$) {
             }              }
             else {              else {
                 $revprint = sprintf('%-8s', $lrev);                  $revprint = sprintf('%-8s', $lrev);
                 $revprint =~ s`\S+`<a href="${scriptwhere}${barequery}#rev$1">$&</A>`;  # `                  $revprint =~ s`\S+`&link($&, "$scriptwhere$query#rev$&")`e;     # `
                 $oldLusr = '';                  $oldLusr = '';
             }              }
             if ($lusr eq $oldLusr) {              if ($lusr eq $oldLusr) {
Line 1286  sub doAnnotate($$) {
Line 1423  sub doAnnotate($$) {
             # CVS command line client.  But for simplicity, we don't.              # CVS command line client.  But for simplicity, we don't.
         }          }
         elsif ($words[0] eq "error") {          elsif ($words[0] eq "error") {
             fatal ("500 Internal Error", "Error occured during annotate: <b>$_</b>");              fatal("500 Internal Error", "Error occured during annotate: <b>$_</b>");
         }          }
     }      }
     if ($annTable) {      if ($annTable) {
Line 1403  sub cvswebMarkup($$$) {
Line 1540  sub cvswebMarkup($$$) {
     print "<HR noshade>";      print "<HR noshade>";
     print "<table width=\"100%\"><tr><td bgcolor=\"$markupLogColor\">";      print "<table width=\"100%\"><tr><td bgcolor=\"$markupLogColor\">";
     print "File: ", &clickablePath($where, 1);      print "File: ", &clickablePath($where, 1);
     print "&nbsp;";      print "&nbsp;(";
     &download_link(urlencode($fileurl), $revision, "(download)");      &download_link($fileurl, $revision, "download");
       print ")";
     if (!$defaultTextPlain) {      if (!$defaultTextPlain) {
         print "&nbsp;";          print "&nbsp;(";
         &download_link(urlencode($fileurl), $revision, "(as text)",          &download_link($fileurl, $revision, "as text",
                "text/plain");                 "text/plain");
           print ")";
     }      }
     print "<BR>\n";      print "<BR>\n";
     if ($show_log_in_markup) {      if ($show_log_in_markup) {
Line 1424  sub cvswebMarkup($$$) {
Line 1563  sub cvswebMarkup($$$) {
     my $url = download_url($fileurl, $revision, $mimetype);      my $url = download_url($fileurl, $revision, $mimetype);
     print "<HR noshade>";      print "<HR noshade>";
     if ($mimetype =~ /^image/) {      if ($mimetype =~ /^image/) {
         print "<IMG SRC=\"$url$barequery\"><BR>";          printf '<IMG SRC="%s"><BR>', htmlquote("$url$barequery");
     }      }
     elsif ($mimetype =~ m%^application/pdf%) {      elsif ($mimetype =~ m%^application/pdf%) {
         print "<EMBED SRC=\"$url$barequery\" WIDTH=\"100%\"><BR>";          printf '<EMBED SRC="%s" WIDTH="100%"><BR>', htmlquote("$url$barequery");
     }      }
     else {      else {
         print "<PRE>";          print "<PRE>";
Line 1458  sub viewable($) {
Line 1597  sub viewable($) {
 sub doDiff($$$$$$) {  sub doDiff($$$$$$) {
         my($fullname, $r1, $tr1, $r2, $tr2, $f) = @_;          my($fullname, $r1, $tr1, $r2, $tr2, $f) = @_;
         my $fh = do {local(*FH);};          my $fh = do {local(*FH);};
         my ($rev1, $rev2, $sym1, $sym2, @difftype, $diffname, $f1, $f2);          my ($rev1, $rev2, $sym1, $sym2, $f1, $f2);
   
         if ($r1 =~ /([^:]+)(:(.+))?/) {          if ($r1 =~ /([^:]+)(:(.+))?/) {
             $rev1 = $1;              $rev1 = $1;
Line 1492  sub doDiff($$$$$$) {
Line 1631  sub doDiff($$$$$$) {
             ($rev1, $sym1) = ($rev2, $sym2);              ($rev1, $sym1) = ($rev2, $sym2);
             ($rev2, $sym2) = ($tmp1, $tmp2);              ($rev2, $sym2) = ($tmp1, $tmp2);
         }          }
         my $human_readable = 0;          my $difftype = $DIFFTYPES{$f};
         if ($f eq 'c') {  
             @difftype = qw{-c};          if (!$difftype) {
             $diffname = "Context diff";  
         }  
         elsif ($f eq 's') {  
             @difftype = qw{--side-by-side --width=164};  
             $diffname = "Side by Side";  
         }  
         elsif ($f eq 'H') {  
             $human_readable = 1;  
             @difftype = qw{--unified=15};  
             $diffname = "Long Human readable";  
         }  
         elsif ($f eq 'h') {  
             @difftype =qw{-u};  
             $human_readable = 1;  
             $diffname = "Human readable";  
         }  
         elsif ($f eq 'u') {  
             @difftype = qw{-u};  
             $diffname = "Unidiff";  
         }  
         else {  
             fatal ("400 Bad arguments", "Diff format $f not understood");              fatal ("400 Bad arguments", "Diff format $f not understood");
         }          }
   
           my @difftype       = @{$difftype->{'opts'}};
           my $human_readable = $difftype->{'colored'};
   
         # apply special options          # apply special options
         if ($showfunc) {          if ($showfunc) {
             push @difftype, '-p' if $f =~ /^[cHhu]$/;              push @difftype, '-p' if $f ne 's';
   
             my($re1, $re2);              my($re1, $re2);
   
Line 1583  sub doDiff($$$$$$) {
Line 1704  sub doDiff($$$$$$) {
                 s|$cvsroot/||o;                  s|$cvsroot/||o;
                 if ($sym1) {                  if ($sym1) {
                     chop;                      chop;
                     $_ .= " " . $sym1 . "\n";                      $_ .= " $sym1\n";
                 }                  }
             }              }
             elsif (m|^$f2 $cvsroot|o) {              elsif (m|^$f2 $cvsroot|o) {
                 s|$cvsroot/||o;                  s|$cvsroot/||o;
                 if ($sym2) {                  if ($sym2) {
                     chop;                      chop;
                     $_ .= " " . $sym2 . "\n";                      $_ .= " $sym2\n";
                 }                  }
             }              }
             print $_;              print $_;
Line 1712  again:
Line 1833  again:
                 # End of a log entry.                  # End of a log entry.
                 my $revbranch;                  my $revbranch;
                 ($revbranch = $rev) =~ s/\.\d+$//;                  ($revbranch = $rev) =~ s/\.\d+$//;
                 print "$filename $rev Wanted: $revwanted "                  print "$filename $rev Wanted: $revwanted ",
                     . "Revbranch: $revbranch Branch: $branch "                    "Revbranch: $revbranch Branch: $branch ",
                     . "Branchpoint: $branchpoint\n" if ($verbose);                      "Branchpoint: $branchpoint\n" if ($verbose);
                 if (!defined($revwanted) && defined($branch)                  if (!defined($revwanted) && defined($branch)
                     && $branch eq $revbranch || !defined($tag)) {                      && $branch eq $revbranch || !defined($tag)) {
                     print "File revision $rev found for branch $branch\n"                      print "File revision $rev found for branch $branch\n"
Line 1752  again:
Line 1873  again:
                 next;                  next;
             }              }
             else {              else {
                 $log = $log . $_;                  $log .= $_;
             }              }
         }          }
         if (/$LOG_FILESEPARATOR/o) {          if (/$LOG_FILESEPARATOR/o) {
Line 1995  sub readLog($;$) {
Line 2116  sub readLog($;$) {
   
 }  }
   
   sub printDiffLinks($$) {
       my($text, $url) = @_;
       my @extra;
   
       local $_;
       for ($DIFFTYPES{$defaultDiffType}{'colored'} ? qw(u) : qw(h)) {
           my $f = $_ eq $defaultDiffType ? '' : $_;
   
           push @extra, &link(lc $DIFFTYPES{$_}{'descr'}, "$url&f=$f");
       }
   
       print &link($text, $url), ' (', join(', ', @extra), ')';
   }
   
 sub printLog($;$) {  sub printLog($;$) {
         my ($link, $br, $brp);          my ($link, $br, $brp);
         ($_,$link) = @_;          ($_,$link) = @_;
Line 2023  sub printLog($;$) {
Line 2158  sub printLog($;$) {
             }              }
             print "\n Revision ";              print "\n Revision ";
             &download_link($fileurl, $_, $_,              &download_link($fileurl, $_, $_,
                 $defaultViewable ? "text/x-cvsweb-markup" : undef);                             $defaultViewable ? "text/x-cvsweb-markup" : undef);
             if ($defaultViewable) {              if ($defaultViewable) {
                 print " / ";                  print " / (";
                 &download_link($fileurl, $_, "(download)", $mimetype);                  &download_link($fileurl, $_, "download", $mimetype);
                   print ")";
             }              }
             if (not $defaultTextPlain) {              if (not $defaultTextPlain) {
                 print " / ";                  print " / (";
                 &download_link($fileurl, $_, "(as text)",                  &download_link($fileurl, $_, "as text", "text/plain");
                            "text/plain");                  print ")";
             }              }
             if (!$defaultViewable) {              if (!$defaultViewable) {
                 print " / ";                  print " / (";
                 &download_link($fileurl, $_, "(view)", "text/x-cvsweb-markup");                  &download_link($fileurl, $_, "view", "text/x-cvsweb-markup");
                   print ")";
             }              }
             if ($allow_annotate) {              if ($allow_annotate) {
                 print " - <a href=\"" . $scriptname . "/" . urlencode($where) . "?annotate=$_$barequery\">";                  print " - ";
                 print "annotate</a>";                  print &link('annotate',
                               sprintf('%s/%s?annotate=%s%s',
                                       $scriptname,
                                       urlencode($where),
                                       $_,
                                       $barequery));
             }              }
             # Plus a select link if enabled, and this version isn't selected              # Plus a select link if enabled, and this version isn't selected
             if ($allow_version_select) {              if ($allow_version_select) {
                 if ((!defined($input{"r1"}) || $input{"r1"} ne $_)) {                  if ((!defined($input{"r1"}) || $input{"r1"} ne $_)) {
                     print " - <A HREF=\"${scriptwhere}?r1=$_$barequery" .                      print " - ";
                         "\">[select for diffs]</A>\n";                      print &link('[select for diffs]',
                                   sprintf('%s?r1=%s%s',
                                           $scriptwhere,
                                           $_,
                                           $barequery));
                 }                  }
                 else {                  else {
                     print " - <b>[selected]</b>";                      print " - <b>[selected]</b>";
Line 2060  sub printLog($;$) {
Line 2206  sub printLog($;$) {
         }          }
         if (defined @mytz) {          if (defined @mytz) {
             my ($est) = $mytz[(localtime($date{$_}))[8]];              my ($est) = $mytz[(localtime($date{$_}))[8]];
             print ", <i>" . scalar localtime($date{$_}) . " $est</i> (";              print ", <i>", scalar localtime($date{$_}), " $est</i> (";
         } else {          } else {
             print ", <i>" . scalar gmtime($date{$_}) . " UTC</i> (";              print ", <i>", scalar gmtime($date{$_}), " UTC</i> (";
         }          }
         print readableTime(time() - $date{$_},1) . " ago)";          print readableTime(time() - $date{$_},1), " ago)";
         print " by ";          print " by ";
         print "<i>" . $author{$_} . "</i>\n";          print "<i>", $author{$_}, "</i>\n";
         print "<BR>Branch: <b>",$link?link_tags($revsym{$br}):$revsym{$br},"</b>\n"          print "<BR>Branch: <b>",$link?link_tags($revsym{$br}):$revsym{$br},"</b>\n"
             if ($revsym{$br});              if ($revsym{$br});
         print "<BR>CVS Tags: <b>",$link?link_tags($revsym{$_}):$revsym{$_},"</b>"          print "<BR>CVS Tags: <b>",$link?link_tags($revsym{$_}):$revsym{$_},"</b>"
Line 2100  sub printLog($;$) {
Line 2246  sub printLog($;$) {
             # Offer diff to previous revision              # Offer diff to previous revision
             if ($prev) {              if ($prev) {
                 $diffrev{$prev} = 1;                  $diffrev{$prev} = 1;
                 print " to previous <A HREF=\"${scriptwhere}.diff?r1=$prev";  
                 print "&amp;r2=$_" . $barequery . "\">$prev</A>\n";                  my $url = sprintf('%s.diff?r1=%s&r2=%s%s',
                 if (!$hr_default) { # offer a human readable version if not default                                    $scriptwhere,
                     print "(<A HREF=\"${scriptwhere}.diff?r1=$prev";                                    $prev,
                     print "&amp;r2=$_" . $barequery . "&amp;f=h\">colored</A>)\n";                                    $_,
                 }                                    $barequery);
   
                   print " to previous ";
                   printDiffLinks($prev, $url);
             }              }
             #              #
             # Plus, if it's on a branch, and it's not a vendor branch,              # Plus, if it's on a branch, and it's not a vendor branch,
             # offer a diff with the branch point.              # offer a diff with the branch point.
             if ($revsym{$brp} && !/^1\.1\.1\.\d+$/ && !defined($diffrev{$brp})) {              if ($revsym{$brp} && !/^1\.1\.1\.\d+$/ && !defined($diffrev{$brp})) {
                 print " to branchpoint <A HREF=\"${scriptwhere}.diff?r1=$brp";                  my $url = sprintf('%s.diff?r1=%s&r2=%s%s',
                 print "&amp;r2=$_" . $barequery . "\">$brp</A>\n";                                    $scriptwhere,
                 if (!$hr_default) { # offer a human readable version if not default                                    $brp,
                 print "(<A HREF=\"${scriptwhere}.diff?r1=$brp";                                    $_,
                 print "&amp;r2=$_" . $barequery . "&amp;f=h\">colored</A>)\n";                                    $barequery);
                 }  
                   print " to branchpoint ";
                   printDiffLinks($brp, $url);
             }              }
             #              #
             # Plus, if it's on a branch, and it's not a vendor branch,              # Plus, if it's on a branch, and it's not a vendor branch,
Line 2141  sub printLog($;$) {
Line 2292  sub printLog($;$) {
                 }                  }
                 if (!defined($diffrev{$nextmain})) {                  if (!defined($diffrev{$nextmain})) {
                     $diffrev{$nextmain} = 1;                      $diffrev{$nextmain} = 1;
                     print " next main <A HREF=\"${scriptwhere}.diff?r1=$nextmain";  
                     print "&amp;r2=$_" . $barequery .                      my $url = sprintf('%s.diff?r1=%s&r2=%s%s',
                         "\">$nextmain</A>\n";                                        $scriptwhere,
                     if (!$hr_default) { # offer a human readable version if not default                                        $nextmain,
                         print "(<A HREF=\"${scriptwhere}.diff?r1=$nextmain";                                        $_,
                         print "&amp;r2=$_" . $barequery .                                        $barequery);
                             "&amp;f=h\">colored</A>)\n";  
                     }                      print " next main ";
                       printDiffLinks($nextmain, $url);
                 }                  }
             }              }
             # Plus if user has selected only r1, then present a link              # Plus if user has selected only r1, then present a link
             # to make a diff to that revision              # to make a diff to that revision
             if (defined($input{"r1"}) && !defined($diffrev{$input{"r1"}})) {              if (defined($input{"r1"}) && !defined($diffrev{$input{"r1"}})) {
                 $diffrev{$input{"r1"}} = 1;                  $diffrev{$input{"r1"}} = 1;
                 print " to selected <A HREF=\"${scriptwhere}.diff?"  
                         . "r1=$input{'r1'}&amp;r2=$_" . $barequery  
                         . "\">$input{'r1'}</A>\n";  
                 if (!$hr_default) { # offer a human readable version if not default  
                     print "(<A HREF=\"${scriptwhere}.diff?r1=$input{'r1'}";  
                     print "&amp;r2=$_" . $barequery .  
                         "&amp;f=h\">colored</A>)\n";  
   
                 }                  my $url = sprintf('%s.diff?r1=%s&r2=%s%s',
                                     $scriptwhere,
                                     $input{'r1'},
                                     $_,
                                     $barequery);
   
                   print " to selected ";
                   printDiffLinks($input{'r1'}, $url);
             }              }
         }          }
         print "<PRE>\n";          print "<PRE>\n";
Line 2182  sub doLog($) {
Line 2334  sub doLog($) {
         ($filename = $where) =~ s|^.*/||;          ($filename = $where) =~ s|^.*/||;
         $backurl = $scriptname . "/" . urlencode($upwhere) . $query;          $backurl = $scriptname . "/" . urlencode($upwhere) . $query;
         print &link($backicon, "$backurl#$filename"),          print &link($backicon, "$backurl#$filename"),
               " <b>Up to ", &clickablePath($upwhere, 1), "</b><p>\n";            " <b>Up to ", &clickablePath($upwhere, 1), "</b><p>\n";
         print <<EOF;          print &link('Request diff between arbitrary revisions', '#diff');
 <A HREF="#diff">Request diff between arbitrary revisions</A>          print '<HR NOSHADE>';
 <HR NOSHADE>  
 EOF  
         if ($curbranch) {          if ($curbranch) {
             print "Default branch: ", ($revsym{$curbranch} || $curbranch);              print "Default branch: ", ($revsym{$curbranch} || $curbranch);
         }          }
Line 2214  EOF
Line 2365  EOF
         print "</A><P>\n";          print "</A><P>\n";
         print "<FORM METHOD=\"GET\" ACTION=\"${scriptwhere}.diff\" NAME=\"diff_select\">\n";          print "<FORM METHOD=\"GET\" ACTION=\"${scriptwhere}.diff\" NAME=\"diff_select\">\n";
         foreach (@stickyvars) {          foreach (@stickyvars) {
             print "<INPUT TYPE=HIDDEN NAME=\"$_\" VALUE=\"$input{$_}\">\n"              printf('<INPUT TYPE=HIDDEN NAME="%s" VALUE="%s">',  $_, $input{$_})
                 if (defined($input{$_})                  if (defined($input{$_})
                     && ((!defined($DEFAULTVALUE{$_})                      && ((!defined($DEFAULTVALUE{$_})
                          || $input{$_} ne $DEFAULTVALUE{$_})                           || $input{$_} ne $DEFAULTVALUE{$_})
Line 2244  EOF
Line 2395  EOF
         print "<HR noshade>\n";          print "<HR noshade>\n";
         print "<TABLE>";          print "<TABLE>";
         print "<FORM METHOD=\"GET\" ACTION=\"$scriptwhere\">\n";          print "<FORM METHOD=\"GET\" ACTION=\"$scriptwhere\">\n";
         print "<TR><TD align=right>Preferred Diff type:</TD>";          print "<TR><TD align=right>Preferred Diff type:</TD>";
         print "<TD>";          print "<TD>";
         printDiffSelect($use_java_script);          printDiffSelect($use_java_script);
         print "</TD><TD></TD></TR>\n";          print "</TD><TD></TD></TR>\n";
         if (@branchnames) {          if (@branchnames) {
Line 2280  EOF
Line 2431  EOF
         print "<TR><TD align=right>";          print "<TR><TD align=right>";
         print "<A name=logsort></A>\n";          print "<A name=logsort></A>\n";
         print "Sort log by:</TD>";          print "Sort log by:</TD>";
         print "<TD><SELECT NAME=\"logsort\"";          print "<TD>";
         print " onchange=\"submit()\"" if ($use_java_script);          printLogSortSelect($use_java_script);
         print ">\n";          print "</TD>";
         print "<OPTION VALUE=cvs",$logsort eq "cvs" ? " SELECTED" : "", ">Not sorted";  
         print "<OPTION VALUE=date",$logsort eq "date" ? " SELECTED" : "", ">Commit date";  
         print "<OPTION VALUE=rev",$logsort eq "rev" ? " SELECTED" : "", ">Revision";  
         print "</SELECT></TD>";  
         print "<TD><INPUT TYPE=SUBMIT VALUE=\"  Set  \"></TD>";          print "<TD><INPUT TYPE=SUBMIT VALUE=\"  Set  \"></TD>";
         print "</FORM>\n";          print "</FORM>\n";
         print "</TR></TABLE>";          print "</TR></TABLE>";
Line 2356  sub human_readable_diff($){
Line 2503  sub human_readable_diff($){
     $date2 = $r2d;      $date2 = $r2d;
   }    }
   
   print "<h3 align=center>Diff for /$where_nd between version $rev1 and $rev2</h3>\n";    print "<h3 align=center>Diff for /$where_nd between version $rev1 and $rev2</h3>\n",
       "<table border=0 cellspacing=0 cellpadding=0 width=\"100%\">\n",
   print "<table border=0 cellspacing=0 cellpadding=0 width=\"100%\">\n";        "<tr bgcolor=\"#ffffff\">\n",
   print "<tr bgcolor=\"#ffffff\">\n";          "<th width=\"50%\" valign=TOP>",
   print "<th width=\"50%\" valign=TOP>";            "version $rev1";
   print "version $rev1";  
   print ", $date1" if (defined($date1));    print ", $date1" if (defined($date1));
   print "<br>Tag: $sym1\n" if ($sym1);    print "<br>Tag: $sym1\n" if ($sym1);
   print "</th>\n";    print "</th>\n",
   print "<th width=\"50%\" valign=TOP>";      "<th width=\"50%\" valign=TOP>",
   print "version $rev2";        "version $rev2";
   print ", $date2" if (defined($date2));    print ", $date2" if (defined($date2));
   print "<br>Tag: $sym2\n" if ($sym1);    print "<br>Tag: $sym2\n" if ($sym1);
   print "</th>\n";    print "</th>\n";
Line 2491  sub navigateHeader($$$$$) {
Line 2637  sub navigateHeader($$$$$) {
     $swhere = urlencode($filename) if ($swhere eq "");      $swhere = urlencode($filename) if ($swhere eq "");
     print "<\!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\">";      print "<\!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\">";
     print "<HTML>\n<HEAD>\n";      print "<HTML>\n<HEAD>\n";
     print '<!-- CVSweb $zRevision: 1.103 $  $kRevision: 1.33 $ -->';      print '<!-- CVSweb $zRevision: 1.103 $  $kRevision: 1.37 $ -->';
     print "\n<TITLE>$path$filename - $title - $rev</TITLE></HEAD>\n";      print "\n<TITLE>$path$filename - $title - $rev</TITLE></HEAD>\n";
     print  "$body_tag_for_src\n";      print  "$body_tag_for_src\n";
     print "<table width=\"100%\" border=0 cellspacing=0 cellpadding=1 bgcolor=\"$navigationHeaderColor\">";      print "<table width=\"100%\" border=0 cellspacing=0 cellpadding=1 bgcolor=\"$navigationHeaderColor\">";
     print "<tr valign=bottom><td>";      print "<tr valign=bottom><td>";
     print  "<a href=\"$swhere$query#rev$rev\">$backicon";      print &link($backicon, "$swhere$query#rev$rev");
     print "</a> <b>Return to ", &link("$filename","$swhere$query#rev$rev")," CVS log";      print "</a> <b>Return to ", &link("$filename","$swhere$query#rev$rev")," CVS log";
     print "</b> $fileicon</td>";      print "</b> $fileicon</td>";
   
Line 2507  sub navigateHeader($$$$$) {
Line 2653  sub navigateHeader($$$$$) {
 sub plural_write($$) {  sub plural_write($$) {
     my ($num,$text) = @_;      my ($num,$text) = @_;
     if ($num != 1) {      if ($num != 1) {
         $text = $text . "s";          $text .= "s";
     }      }
     if ($num > 0) {      if ($num > 0) {
         return $num . " " . $text;          return join(' ', $num, $text);
     }      }
     else {      else {
         return "";          return "";
Line 2554  sub readableTime($$) {
Line 2700  sub readableTime($$) {
         my $resttime = plural_write(int ($rest / $break),          my $resttime = plural_write(int ($rest / $break),
                                 $desc{$break});                                  $desc{$break});
         if ($resttime) {          if ($resttime) {
             $retval = $retval . ", " . $resttime;              $retval .= ", $resttime";
         }          }
     }      }
   
Line 2578  sub clickablePath($$) {
Line 2724  sub clickablePath($$) {
         $retval = "[$cvstree]";          $retval = "[$cvstree]";
     }      }
     else {      else {
         $retval = $retval . " <a href=\"${scriptname}/${query}#dirlist\">[$cvstree]</a>";          $retval .= ' ' . &link("[$cvstree]", sprintf('%s/%s#dirlist',
                                                        $scriptname,
                                                        $query));
         my $wherepath = '';          my $wherepath = '';
         my ($lastslash) = $pathname =~ m|/$|;          my ($lastslash) = $pathname =~ m|/$|;
         foreach (split(/\//, $pathname)) {          foreach (split(/\//, $pathname)) {
             $retval = $retval . " / ";              $retval .= " / ";
             $wherepath = $wherepath . '/' . $_;              $wherepath .= "/$_";
             my ($last) = "$wherepath/" eq "/$pathname"              my ($last) = "$wherepath/" eq "/$pathname"
                 || $wherepath eq "/$pathname";                  || $wherepath eq "/$pathname";
             if ($clickLast || !$last) {              if ($clickLast || !$last) {
                 $retval = $retval . "<a href=\"${scriptname}"                  $retval .= &link($_, join('',
                     . urlencode($wherepath)                                            $scriptname,
                     . (!$last || $lastslash ? '/' : '')                                            urlencode($wherepath),
                     . ${query}                                            (!$last || $lastslash ? '/' : ''),
                     . (!$last || $lastslash ? "#dirlist" : "")                                            $query,
                     . "\">$_</a>";                                            (!$last || $lastslash ? "#dirlist" : "")));
             }              }
             else { # do not make a link to the current dir              else { # do not make a link to the current dir
                 $retval = $retval .  $_;                  $retval .= $_;
             }              }
         }          }
     }      }
Line 2627  sub chooseCVSRoot() {
Line 2775  sub chooseCVSRoot() {
         foreach $k (@foo) {          foreach $k (@foo) {
             print "<option value=\"$k\"";              print "<option value=\"$k\"";
             print " selected" if ($k eq $cvstree);              print " selected" if ($k eq $cvstree);
             print ">" . ($CVSROOTdescr{$k} ? $CVSROOTdescr{$k} :              print ">", ($CVSROOTdescr{$k} ? $CVSROOTdescr{$k} : $k), "</option>\n";
                         $k). "</option>\n";  
         }          }
         print "</select>\n</td>";          print "</select>\n</td>";
         print "<td><input type=submit value=\"Go\"></td>";          print "<td><input type=submit value=\"Go\"></td>";
Line 2652  sub chooseMirror() {
Line 2799  sub chooseMirror() {
         print "\nThis cvsweb is mirrored in:\n";          print "\nThis cvsweb is mirrored in:\n";
         foreach $mirror (keys %MIRRORS) {          foreach $mirror (keys %MIRRORS) {
             print ", " if ($moremirrors);              print ", " if ($moremirrors);
             print qq(<a href="$MIRRORS{$mirror}">$mirror</A>\n);              print &link(htmlquote($mirror),$MIRRORS{$mirror});
             $moremirrors = 1;              $moremirrors = 1;
         }          }
         print "<p>\n";          print "<p>\n";
Line 2695  sub download_url($$;$) {
Line 2842  sub download_url($$;$) {
   
     $revision =~ s/\b0\.//;      $revision =~ s/\b0\.//;
   
     if (defined($checkout_magic)      if (defined($checkoutMagic)
         && (!defined($mimetype) || $mimetype ne "text/x-cvsweb-markup")) {          && (!defined($mimetype) || $mimetype ne "text/x-cvsweb-markup")) {
         my ($path);          my $path = $where;
         ($path = $where) =~ s|/[^/]*$|/|;          $path =~ s|/[^/]*$|/|;
         $url = "$scriptname/$checkoutMagic/${path}$url";          $url = "$scriptname/$checkoutMagic/${path}$url";
     }      }
     $url .= "?rev=$revision";      $url .= "?rev=$revision";
     $url .= "&amp;content-type=$mimetype" if (defined($mimetype));      $url .= '&content-type=' . urlencode($mimetype) if (defined($mimetype));
   
     return $url;      $url;
 }  }
   
 # Presents a link to download the  # Presents a link to download the
 # selected revision  # selected revision
 sub download_link($$$;$) {  sub download_link($$$;$) {
     my ($url,$revision,$textlink,$mimetype) = @_;      my ($url, $revision, $textlink, $mimetype) = @_;
     my ($fullurl) = download_url($url,$revision,$mimetype);      my ($fullurl) = download_url($url, $revision, $mimetype);
     my ($paren) = $textlink =~ /^\(/;  
     $textlink =~ s/^\(// if ($paren);      printf '<A HREF="%s"', htmlquote("$fullurl$barequery");
     $textlink =~ s/\)$// if ($paren);  
     print "(" if ($paren);  
     print "<A HREF=\"$fullurl";  
     print $barequery;  
     print "\"";  
     if ($open_extern_window && (!defined($mimetype) || $mimetype ne "text/x-cvsweb-markup")) {      if ($open_extern_window && (!defined($mimetype) || $mimetype ne "text/x-cvsweb-markup")) {
         print " target=\"cvs_checkout\"";          print ' target="cvs_checkout"';
         # we should have          # we should have
         #   'if (document.cvswin==null) document.cvswin=window.open(...'          #   'if (document.cvswin==null) document.cvswin=window.open(...'
         # in order to allow the user to resize the window; otherwise          # in order to allow the user to resize the window; otherwise
Line 2739  sub download_link($$$;$) {
Line 2882  sub download_link($$$;$) {
         # currently, the best way is to comment out the size parameters          # currently, the best way is to comment out the size parameters
         # ($extern_window...) in cvsweb.conf.          # ($extern_window...) in cvsweb.conf.
         if ($use_java_script) {          if ($use_java_script) {
             print " onClick=\"window.open('$fullurl','cvs_checkout',";              my @attr = qw(resizeable scrollbars);
             print "'resizeable,scrollbars";  
             print ",status,toolbar" if (defined($mimetype)              push @attr, qw(status toolbar)
                 && $mimetype eq "text/html");                if (defined($mimetype) && $mimetype eq "text/html");
             print ",width=$extern_window_width" if (defined($extern_window_width));  
             print ",height=$extern_window_height" if (defined($extern_window_height));              push @attr, "width=$extern_window_width"
             print"');\"";                if (defined($extern_window_width));
   
               push @attr, "height=$extern_window_height"
                 if (defined($extern_window_height));
   
               printf q` onClick="window.open('%s','cvs_checkout','%s');"`,
                 htmlquote($fullurl), join(',', @attr);
         }          }
     }      }
     print "><b>$textlink</b></A>";      print "><b>$textlink</b></A>";
     print ")" if ($paren);  
 }  }
   
 # Returns a Query string with the  # Returns a Query string with the
Line 2771  sub toggleQuery($$) {
Line 2919  sub toggleQuery($$) {
         my ($value) = defined($vars{$var}) ? $vars{$var} : "";          my ($value) = defined($vars{$var}) ? $vars{$var} : "";
         my ($default) = defined($DEFAULTVALUE{$var}) ? $DEFAULTVALUE{$var} : "";          my ($default) = defined($DEFAULTVALUE{$var}) ? $DEFAULTVALUE{$var} : "";
         if ($value ne $default) {          if ($value ne $default) {
             $newquery .= "&amp;" if ($newquery ne "");              $newquery .= "&" if ($newquery ne "");
             $newquery .= urlencode($var) . "=" . urlencode($value);              $newquery .= urlencode($var) . "=" . urlencode($value);
         }          }
     }      }
Line 2782  sub toggleQuery($$) {
Line 2930  sub toggleQuery($$) {
 }  }
   
 sub urlencode($) {  sub urlencode($) {
     my ($in) = @_;      local($_) = @_;
     my ($out);  
     ($out = $in) =~ s/([\000-+{-\377])/sprintf("%%%02x", ord($1))/ge;      s/[\000-+{-\377]/sprintf("%%%02x", ord($&))/ge;
     return $out;  
   
          $_;
 }  }
   
   sub htmlquote($) {
       local($_) = @_;
   
       # Special Characters; RFC 1866
       s/&/&amp;/g;
       s/\"/&quot;/g;
       s/</&lt;/g;
       s/>/&gt;/g;
   
       $_;
   }
   
   sub htmlunquote($) {
       local($_) = @_;
   
       # Special Characters; RFC 1866
       s/&quot;/\"/g;
       s/&lt;/</g;
       s/&gt;/>/g;
       s/&amp;/&/g;
   
       $_;
   }
   
 sub http_header(;$) {  sub http_header(;$) {
     my $content_type = shift || "text/html";      my $content_type = shift || "text/html";
     if (defined($moddate)) {      if (defined($moddate)) {
Line 2795  sub http_header(;$) {
Line 2969  sub http_header(;$) {
             Apache->request->header_out("Last-Modified" => scalar gmtime($moddate) . " GMT");              Apache->request->header_out("Last-Modified" => scalar gmtime($moddate) . " GMT");
         }          }
         else {          else {
             print "Last-Modified: " . scalar gmtime($moddate) . " GMT\r\n";              print "Last-Modified: ", scalar gmtime($moddate), " GMT\r\n";
         }          }
     }      }
     if ($is_mod_perl) {      if ($is_mod_perl) {
Line 2846  sub http_header(;$) {
Line 3020  sub http_header(;$) {
   
 sub html_header($) {  sub html_header($) {
     my ($title) = @_;      my ($title) = @_;
     my $version = '$zRevision: 1.103 $  $kRevision: 1.33 $'; #'      my $version = '$zRevision: 1.103 $  $kRevision: 1.37 $'; #'
     http_header();      http_header();
     print <<EOH;      print <<EOH;
 <!doctype html public "-//W3C//DTD HTML 4.0 Transitional//EN"  <!doctype html public "-//W3C//DTD HTML 4.0 Transitional//EN"
Line 2874  sub link_tags($) {
Line 3048  sub link_tags($) {
   
     foreach my $sym (split(", ", $tags)) {      foreach my $sym (split(", ", $tags)) {
         $ret .= ",\n" if ($ret ne "");          $ret .= ",\n" if ($ret ne "");
         $ret .= "<A HREF=\"$fileurl"          $ret .= &link($sym, $fileurl . toggleQuery('only_with_tag',$sym));
                 . toggleQuery('only_with_tag',$sym) . "\">$sym</A>";  
     }      }
     return $ret."\n";      return "$ret\n";
 }  }
   
 #  #

Legend:
Removed from v.1.1.1.10  
changed lines
  Added in v.1.1.1.11

CVSweb