Diff for /loncom/interface/lonaboutme.pm between versions 1.48 and 1.59

version 1.48, 2006/08/04 19:42:55 version 1.59, 2006/12/10 08:44:35
Line 37  use Apache::lonfeedback; Line 37  use Apache::lonfeedback;
 use Apache::lonrss();  use Apache::lonrss();
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::lonmsgdisplay();  use Apache::lonmsgdisplay();
   use HTML::Entities();
   
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
Line 49  sub handler { Line 50  sub handler {
  $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));   $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
     }      }
     my (undef,undef,$cdom,$cnum,undef,$action)=split(/\//,$r->uri);      my (undef,undef,$cdom,$cnum,undef,$action)=split(/\//,$r->uri);
       my $is_course;
 # Is this even a user?  # Is this even a user?
     if (&Apache::lonnet::homeserver($cnum,$cdom) eq 'no_host') {      if (&Apache::lonnet::homeserver($cnum,$cdom) eq 'no_host') {
  &Apache::loncommon::simple_error_page($r,'No info',   &Apache::loncommon::simple_error_page($r,'No info',
       'No user information available');        'No user information available');
         return OK;          return OK;
       } else {
           $is_course = &Apache::lonnet::is_course($cdom,$cnum);
     }      }
   
 # --------------------------------------------------------- The syllabus fields  # --------------------------------------------------------- The syllabus fields
     my %syllabusfields=&Apache::lonlocal::texthash(      my %syllabusfields=&Apache::lonlocal::texthash(
        'aaa_contactinfo'   => 'Contact Information',         'aaa_contactinfo'   => 'Contact Information',
Line 68  sub handler { Line 73  sub handler {
   
 # ----------------------------------------------- Available Portfolio file display   # ----------------------------------------------- Available Portfolio file display 
     if (($target ne 'tex') && ($action eq 'portfolio')) {      if (($target ne 'tex') && ($action eq 'portfolio')) {
         &display_portfolio_header($r);          &display_portfolio_header($r,$is_course);
         &display_portfolio_files($r);          &display_portfolio_files($r,$is_course);
         $r->print(&Apache::loncommon::end_page());          $r->print(&Apache::loncommon::end_page());
         return OK;          return OK;
     }      }
   
       if ($is_course) {
           if ($target ne 'tex') {
               my $start_page =
                   &Apache::loncommon::start_page(
                       "Course Information",
                        undef,
                        {'function' => $env{'forcestudent'},
                         'domain'   => $cdom,
                         'force_register' => $env{'forceregister'},});
               $r->print($start_page);
               $r->print('<h2>'.&mt('Group files').'</h2>');
               &print_portfiles_link($r,$is_course);
               $r->print(&Apache::loncommon::end_page());
           }
           return OK;
       }
   
 # --------------------------------------------------------------- Force Student  # --------------------------------------------------------------- Force Student
     my $forcestudent='';      my $forcestudent='';
     if ($env{'form.forcestudent'}) { $forcestudent='student'; };      if ($env{'form.forcestudent'}) { $forcestudent='student'; };
Line 149  sub handler { Line 171  sub handler {
  }   }
     }      }
        if (($allowed) && ($env{'form.storesyl'})) {         if (($allowed) && ($env{'form.storesyl'})) {
    foreach (keys %syllabusfields) {     foreach my $syl_field (keys(%syllabusfields)) {
                my $field=$env{'form.'.$_};                 my $field=$env{'form.'.$syl_field};
                $field=~s/\s+$//s;                 $field=~s/\s+$//s;
                $field=&Apache::lonfeedback::clear_out_html($field,                 $field=&Apache::lonfeedback::clear_out_html($field,
                                                            $env{'user.adv'});                                                             $env{'user.adv'});
        $syllabus{$_}=$field;         $syllabus{$syl_field}=$field;
            }             }
            $syllabus{'uploaded.lastmodified'}=time;             $syllabus{'uploaded.lastmodified'}=time;
            &Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);             &Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);
Line 187  sub handler { Line 209  sub handler {
  '</form><form method="post">');   '</form><form method="post">');
   
        }         }
        foreach (sort keys %syllabusfields) {         foreach my $field (sort(keys(%syllabusfields))) {
           if (($syllabus{$_}) || ($allowed)) {            if (($syllabus{$field}) || ($allowed)) {
               my $message=$syllabus{$_};                my $message=$syllabus{$field};
       &Apache::lonfeedback::newline_to_br(\$message);        &Apache::lonfeedback::newline_to_br(\$message);
               $message                $message
              =~s/(http\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;               =~s/(http\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;
Line 198  sub handler { Line 220  sub handler {
       }        }
       $message=&Apache::lontexconvert::msgtexconverted($message);        $message=&Apache::lontexconvert::msgtexconverted($message);
       if ($target ne 'tex') {        if ($target ne 'tex') {
   $r->print('<h3>'.$syllabusfields{$_}.'</h3><blockquote>'.    $r->print('<h3>'.$syllabusfields{$field}.'</h3><blockquote>'.
                             $message.'</blockquote>');                              $message.'</blockquote>');
       } else {        } else {
      $r->print('\\\\\textbf{'.$syllabusfields{$_}.'}\\\\'.       $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.
        &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\');         &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\');
       }        }
               if ($allowed) {                if ($allowed) {
                  $r->print('<br /><textarea cols="80" rows="6" name="'.$_.'">'.                   $r->print('<br /><textarea cols="80" rows="6" name="'.$field.'">'.
    $syllabus{$_}.     &HTML::Entities::encode($syllabus{$field},'"&<>').
            '</textarea><input type="submit" name="storesyl" value="'.             '</textarea><input type="submit" name="storesyl" value="'.
    &mt('Store').'" />');     &mt('Store').'" />');
       }        }
Line 221  sub handler { Line 243  sub handler {
     }      }
   
     if ($target ne 'tex') {      if ($target ne 'tex') {
         &print_portfiles_link($r);          &print_portfiles_link($r,$is_course);
     }      }
   
     if ($env{'request.course.id'}) {      if ($env{'request.course.id'}) {
Line 260  sub handler { Line 282  sub handler {
 }  }
   
 sub aboutme_info {  sub aboutme_info {
     my ($r) = @_;      my ($r,$is_course) = @_;
     my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);      my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);
     my $name = &Apache::loncommon::plainname($cnum,$cdom);      my $name;
       if (!$is_course) {
           $name = &Apache::loncommon::plainname($cnum,$cdom);
       }
     return ($cdom,$cnum,$name);      return ($cdom,$cnum,$name);
 }  }
   
 sub print_portfiles_link {  sub print_portfiles_link {
     my ($r) = @_;      my ($r,$is_course) = @_;
     my ($cdom,$cnum,$name) = &aboutme_info($r);      my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
     my $filecounts = &portfolio_files($r,'showlink');      my $filecounts = &portfolio_files($r,'showlink',undef,$is_course);
     my $query_string = &build_query_string();      my $query_string = &build_query_string();
     my $output;      my $output;
       my %lt = &Apache::lonlocal::texthash(
                            vpfi => 'Viewable portfolio files',
                            vgpf => 'Viewable group portfolio files',
                            difl => 'Display file listing',
                );                     
     if ($filecounts->{'both'} > 0) {      if ($filecounts->{'both'} > 0) {
         $output = &mt('<h3>Viewable portfolio files</h3>');          $output = '<h3>'.($is_course?$lt{'vgpf'}:$lt{'vpfi'}).'</h3>';
         $output .= '<a href="/adm/'.$cdom.'/'.$cnum.'/aboutme/portfolio'.          $output .= '<a href="/adm/'.$cdom.'/'.$cnum.'/aboutme/portfolio'.
                    $query_string.'">'.&mt('Display file listing').                     $query_string.'">'.$lt{'difl'}.
                    '</a><br /><br />';                     '</a><br /><br />';
         $output .= &mt('A total of [quant,_1,portfolio file] owned by [_2] are available.',$filecounts->{'both'},$name).'<ul>';          if ($filecounts->{'both'} == 1) {
               if ($is_course) {
                   $output .= &mt('One group portfolio file is available.').'<ul>';
               } else {
                   $output .= &mt('One portfolio file owned by [_1] is available.',$name).'<ul>';
               }
           } else {
               if ($is_course) {
                   $output .= &mt('A total of [_1] group portfolio files are available.',$filecounts->{'both'}).'<ul>';
               } else {
                   $output .= &mt('A total of [_1] portfolio files owned by [_2] are available.',$filecounts->{'both'},$name).'<ul>';
               }
           }
         if ($filecounts->{'withoutpass'}) {          if ($filecounts->{'withoutpass'}) {
             $output .= '<li>'.&mt('[quant,_1,file] are publicly accessible.',$filecounts->{'withoutpass'}).'</li>';         $output .= '<li>'.&mt('[quant,_1,file is,files are] publicly accessible.',$filecounts->{'withoutpass'}).'</li>';
         }          }
         if ($filecounts->{'withpass'}) {          if ($filecounts->{'withpass'}) {
             $output .= '<li>'.&mt('[quant,_1,file] require a passphrase for access.',$filecounts->{'withpass'}).'</li>';      $output .= '<li>'.&mt('[quant,_1,file requires,files require] a passphrase for access.',$filecounts->{'withpass'}).'</li>';
         }          }
         $output .= '</ul>';          $output .= '</ul>';
     }      }
Line 321  sub build_query_string { Line 363  sub build_query_string {
 }  }
   
 sub display_portfolio_header {  sub display_portfolio_header {
     my ($r) = @_;      my ($r,$is_course) = @_;
     my ($cdom,$cnum,$name) = &aboutme_info($r);      my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
     my $query_string = &build_query_string();      my $query_string = &build_query_string();
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();
     my $forcestudent='';      my $forcestudent='';
     if ($env{'form.forcestudent'}) { $forcestudent='student'; };      if ($env{'form.forcestudent'}) { $forcestudent='student'; };
     my $output =  
         &Apache::loncommon::start_page('Viewable portfolio files',undef,      my $output;
                                             {'function' => $forcestudent,       if ($is_course) {
           $output = 
               &Apache::loncommon::start_page('Viewable group portfolio files',undef,
                                               {'function' => $forcestudent,
                                                'domain'   => $cdom,});
           $output .= '<h3>'.&mt('Group Portfolio files').'</h3>';
       } else {
           $output  =
               &Apache::loncommon::start_page('Viewable portfolio files',undef,
                                               {'function' => $forcestudent,
                                              'domain'   => $cdom,});                                               'domain'   => $cdom,});
     &Apache::lonhtmlcommon::add_breadcrumb          if (!($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public')) {
         ({href=>"/adm/$cdom/$cnum/aboutme".$query_string,              &Apache::lonhtmlcommon::add_breadcrumb
           text=>"Personal information - $name",                  ({href=>"/adm/$cdom/$cnum/aboutme".$query_string,
           title=>"Go to personal information page for $name"},                    text=>"Personal information - $name",
          {href=>"/adm/$cdom/$cnum/aboutme/portfolio",                    title=>"Go to personal information page for $name"},                 {href=>"/adm/$cdom/$cnum/aboutme/portfolio",
           text=>"Viewable files - $name",                    text=>"Viewable files - $name",
           title=>"Viewable portfolio files for $name"}                    title=>"Viewable portfolio files for $name"}
 );              );
     $output .= &Apache::lonhtmlcommon::breadcrumbs(&mt('Viewable portfolio files.'));              $output .= &Apache::lonhtmlcommon::breadcrumbs(&mt('Viewable portfolio files.'));
     $output .= '<h3>'.&mt('Portfolio files for [_1]',$name).'</h3>';          }
           $output .= '<h3>'.&mt('Portfolio files for [_1]',$name).'</h3>';
       }
     $r->print($output);      $r->print($output);
     return;      return;
 }  }
   
 sub display_portfolio_files {  sub display_portfolio_files {
     my ($r) = @_;      my ($r,$is_course) = @_;
     my ($cdom,$cnum,$name) = &aboutme_info($r);      my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
     my %lt = ( withoutpass => 'passphrase not required',      my %lt = ( withoutpass => 'passphrase not required',
        withpass    => 'passphrase protected',         withpass    => 'passphrase protected',
        both        => 'all access types ',);         both        => 'all access types ',);
Line 366  sub display_portfolio_files { Line 419  sub display_portfolio_files {
         if ($portaccess eq $type) {          if ($portaccess eq $type) {
             $output .= 'selected="selected"';              $output .= 'selected="selected"';
         }          }
         $output .= '>'.&mt($type).'</option>';          $output .= '>'.$lt{$type}.'</option>';
     }      }
     $output .= '</select>'."\n".      $output .= '</select>'."\n".
                '<input type="submit" name="portaccessbutton" value="'.                 '<input type="submit" name="portaccessbutton" value="'.
                &mt('Update display').'" />';                 &mt('Update display').'" />';
     $output .= '</form><br /><br />';      $output .= '</form><br /><br />';
     $r->print($output);      $r->print($output);
     my $filecounts = &portfolio_files($r,'listfiles',\%lt);      my $filecounts = &portfolio_files($r,'listfiles',\%lt,$is_course);
     my $query_string = &build_query_string();      if (!($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public')) {
     $r->print('<br /><br /><a href="/adm/'.$cdom.'/'.$cnum.          my $query_string = &build_query_string();
                '/aboutme'.$query_string.'">'.          $r->print('<br /><br /><a href="/adm/'.$cdom.'/'.$cnum.
                &mt('Information about [_1]',$name).'</a>');                    '/aboutme'.$query_string.'">');
           if ($is_course) {
               $r->print(&mt('Course Information page'));
           } else {
               $r->print(&mt('Information about [_1]',$name));
           }
           $r->print('</a>');
       }
     return;      return;
 }  }
   
 sub portfolio_files {  sub portfolio_files {
     my ($r,$mode,$lt) = @_;      my ($r,$mode,$lt,$is_course) = @_;
     my ($cdom,$cnum,$name) = &aboutme_info($r);      my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
     my $filecounts = {      my $filecounts = {
                        withpass    => 0,                         withpass    => 0,
                        withoutpass => 0,                         withoutpass => 0,
Line 393  sub portfolio_files { Line 453  sub portfolio_files {
  &Apache::lonnet::get_portfile_permissions($cdom,$cnum);   &Apache::lonnet::get_portfile_permissions($cdom,$cnum);
     my %access_controls =       my %access_controls = 
  &Apache::lonnet::get_access_controls($current_permissions);   &Apache::lonnet::get_access_controls($current_permissions);
     my %allfileshash;  
     my $portaccess;      my $portaccess;
     if ($mode eq 'showlink') {      if ($mode eq 'showlink') {
         $portaccess = 'both';          $portaccess = 'both';
Line 404  sub portfolio_files { Line 463  sub portfolio_files {
         }          }
     }      }
   
     foreach my $filename (keys(%access_controls)) {      my $diroutput;
         my $access_status =       if ($is_course) {
             &Apache::lonnet::get_portfolio_access($cdom,$cnum,$filename,undef,          my %files_by_group;
   $access_controls{$filename});          foreach my $filename (sort(keys(%access_controls))) {
               my ($group,$path) = split('/',$filename,2);
               $files_by_group{$group}{$path} = $access_controls{$filename}; 
           }
           foreach my $group (sort(keys(%files_by_group))) {
               my %fileshash;
               my $grpout .= &build_hierarchy($r,$cdom,$cnum,$portaccess,
                                              $is_course,$filecounts,$mode,
                                              $files_by_group{$group},
                                              \%fileshash,$group);
               if ($grpout) {
                   $diroutput .= '<h3>'.$group.'</h3>'.$grpout.'<br />';
               }
           }
       } else {
           my %allfileshash;
           $diroutput = &build_hierarchy($r,$cdom,$cnum,$portaccess,$is_course,
                                         $filecounts,$mode,\%access_controls,
                                         \%allfileshash);
       }
       if ($mode eq 'listfiles') {
           if ($filecounts->{'both'}) {
                $r->print($diroutput);
           } else {
               my $access_text;
               if (ref($lt) eq 'HASH') {
                   $access_text = $lt->{$portaccess};   
               }
               $r->print(&mt('There are no available files of the specified access type: [_1]',$access_text));
           }
       }
       return $filecounts;
   }
   
   { 
       my $count=0;
       sub portfolio_table_start {
    $count=0;
    return '<table class="LC_aboutme_port">';
       }
       sub portfolio_row_start {
    $count++;
    my $class = ($count%2)?'LC_odd_row'
                         :'LC_even_row';
    return '<tr class="'.$class.'">';
       }
   }
   
   sub build_hierarchy {
       my ($r,$cdom,$cnum,$portaccess,$is_course,$filecounts,$mode,$access_info,
           $allfileshash,$group) = @_;
       foreach my $filename (sort(keys(%{$access_info}))) {
           my $access_status =
              &Apache::lonnet::get_portfolio_access($cdom,$cnum,$filename,$group,                                                 $$access_info{$filename});
         if ($portaccess eq 'both') {          if ($portaccess eq 'both') {
             if (($access_status ne 'ok') &&              if (($access_status ne 'ok') &&
                 ($access_status !~  /^[^:]+:guest_/)) {                  ($access_status !~  /^[^:]+:guest_/)) {
Line 425  sub portfolio_files { Line 537  sub portfolio_files {
         if ($mode eq 'listfiles') {          if ($mode eq 'listfiles') {
             $filename =~ s/^\///;              $filename =~ s/^\///;
             my @pathitems = split('/',$filename);              my @pathitems = split('/',$filename);
             my $lasthash = \%allfileshash;              my $lasthash = $allfileshash;
             while (@pathitems > 1) {              while (@pathitems > 1) {
                 my $newlevel = shift(@pathitems);                  my $newlevel = shift(@pathitems);
                 if (!exists($lasthash->{$newlevel})) {                  if (!exists($lasthash->{$newlevel})) {
Line 443  sub portfolio_files { Line 555  sub portfolio_files {
     }      }
     $filecounts->{'both'} =  $filecounts->{'withoutpass'} +      $filecounts->{'both'} =  $filecounts->{'withoutpass'} +
                               $filecounts->{'withpass'};                                $filecounts->{'withpass'};
       my $output;
     if ($mode eq 'listfiles') {      if ($mode eq 'listfiles') {
         my $output;          if ($filecounts->{'both'} > 0) {
         if (keys(%allfileshash) > 0) {  
             $output = &portfolio_table_start();              $output = &portfolio_table_start();
             $output .= &parse_directory($r,0,\%allfileshash);              $output .= &parse_directory($r,0,$allfileshash,'',$is_course,
                                           $group);
             $output .= '</table>';              $output .= '</table>';
         } else {  
             my $access_text;  
             if (ref($lt) eq 'HASH') {  
                 $access_text = $lt->{$portaccess};     
             }  
             $output .= &mt('There are no available files of the specified access type: [_1]',$access_text);  
         }          }
         $r->print($output);  
     }  
     return $filecounts;  
 }  
   
 {   
     my $count=0;  
     sub portfolio_table_start {  
  $count=0;  
  return '<table class="LC_aboutme_port">';  
     }  
     sub portfolio_row_start {  
  $count++;  
  my $class = ($count%2)?'LC_odd_row'  
                       :'LC_even_row';  
  return '<tr class="'.$class.'">';  
     }      }
       return $output;
 }  }
   
 sub parse_directory {  sub parse_directory {
     my ($r,$depth,$currhash) = @_;      my ($r,$depth,$currhash,$path,$is_course,$group) = @_;
     my ($cdom,$cnum,$name) = &aboutme_info($r);      my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
     $depth++;      $depth++;
     my $output;      my $output;
   
       my $portfolio_root = &Apache::portfolio::get_portfolio_root($cdom,$cnum,
                                                                   $group);
       my %dirlist = map {
       ((split('&',$_,2))[0],1)
    } &Apache::lonnet::dirlist($path,$cdom,$cnum,$portfolio_root);
     foreach my $item (sort(keys(%{$currhash}))) {      foreach my $item (sort(keys(%{$currhash}))) {
         $output .= &portfolio_row_start();          $output .= &portfolio_row_start();
         $output .= '<td style="padding-left: '.($depth*25).'px">';          $output .= '<td style="padding-left: '.($depth*25).'px">';
Line 487  sub parse_directory { Line 585  sub parse_directory {
             my $title=&HTML::Entities::encode($item,'<>&"');              my $title=&HTML::Entities::encode($item,'<>&"');
             $output .= '<img src="'.&Apache::loncommon::lonhttpdurl("/adm/lonIcons/navmap.folder.open.gif").'" alt="'.&mt('Folder').' '.$title.'" class="LC_icon" />&nbsp;'.$title;              $output .= '<img src="'.&Apache::loncommon::lonhttpdurl("/adm/lonIcons/navmap.folder.open.gif").'" alt="'.&mt('Folder').' '.$title.'" class="LC_icon" />&nbsp;'.$title;
     $output .= '</td><td></td></tr>';      $output .= '</td><td></td></tr>';
             $output .= &parse_directory($r,$depth,$currhash->{$item});              $output .= &parse_directory($r,$depth,$currhash->{$item},
    $path.'/'.$item,$is_course,$group);
         } else {          } else {
             my $showname;      my $file_name; 
             if ($currhash->{$item} =~ m|/([^/]+)$|) {      if ($currhash->{$item} =~ m|/([^/]+)$|) {
                 $showname = $1;   $file_name = $1;
             } else {      } else {
                 $showname = $currhash->{$item};   $file_name = $currhash->{$item};
       }
       my $have_meta = exists($dirlist{$file_name.'.meta'});
               my $url;
               if ($is_course) {
                   $url = '/uploaded/'.$cdom.'/'.$cnum.'/groups/'.$group.
                          '/portfolio/'.$currhash->{$item};
               } else { 
           $url = '/uploaded/'.$cdom.'/'.$cnum.'/portfolio/'.
          $currhash->{$item};
             }              }
               my $showname;
       if ($have_meta) {
    $showname = &Apache::lonnet::metadata($url,'title');
       }
       if ($showname eq '') {
    $showname = $file_name;
       } else {
    $showname = $file_name.' ('.$showname.')';
       }
   
             $showname=&HTML::Entities::encode($showname,'<>&"');              $showname=&HTML::Entities::encode($showname,'<>&"');
     my $url = '/uploaded/'.$cdom.'/'.$cnum.'/portfolio/'.              $output .= '<a href="'.$url.'">'.
  $currhash->{$item};   '<img alt="" src="'.&Apache::loncommon::icon($currhash->{$item}).'" class="LC_icon" />'.
             $output .= '<img alt="" src="'.&Apache::loncommon::icon($currhash->{$item}).'" class="LC_icon" />&nbsp;<a href="'.$url.'">'.$showname.'</a>';   '&nbsp;'.$showname.'</a>';
     $output.='</td><td><a href="'.$url.'.meta"><img align="right" alt="'.&mt('Catalog Information').'" src="'.      $output.='</td><td>';
       if ($have_meta) {
    $output.= '<a href="'.$url.'.meta"><img alt="'.&mt('Catalog Information').'" src="'.
  &Apache::loncommon::lonhttpdurl('/res/adm/pages/catalog.gif').   &Apache::loncommon::lonhttpdurl('/res/adm/pages/catalog.gif').
  '" /></a>';   '" class="LC_icon" /></a>';
       }
     $output .= '</td></tr>';      $output .= '</td></tr>';
         }          }
     }      }

Removed from v.1.48  
changed lines
  Added in v.1.59


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>