Diff for /loncom/xml/londefdef.pm between versions 1.50 and 1.52

version 1.50, 2002/04/04 19:20:33 version 1.52, 2002/04/08 15:17:01
Line 50  use Apache::lonxml; Line 50  use Apache::lonxml;
   
 BEGIN {  BEGIN {
   
     &Apache::lonxml::register('Apache::londefdef',('m','html','head','map','select','option','input','textarea','form','meta','title','body','center','b','strong','dt','h1','h2','h3','h4','h5','h6','cite','i','address','dd','dl','dir','ol','ul','menu','dfn','kbd','tt','code','em','q','p','br','big','small','basefont','font','s','sub','strike','sup','hr','a','li','u','output','param','applet','img','embed','allow','frameset','pre','insert','externallink','table'));      &Apache::lonxml::register('Apache::londefdef',('m','html','head','map','select','option','input','textarea','form','meta','title','body','center','b','strong','dt','h1','h2','h3','h4','h5','h6','cite','i','address','dd','dl','dir','ol','ul','menu','dfn','kbd','tt','code','em','q','p','br','big','small','basefont','font','s','sub','strike','sup','hr','a','li','u','output','param','applet','img','embed','allow','frameset','pre','insert','externallink','table','tr','td'));
   
 }  }
   
Line 1265  EDITBUTTON Line 1265  EDITBUTTON
               $currentstring = $token->[4];                     $currentstring = $token->[4];     
     } elsif ($target eq 'tex') {      } elsif ($target eq 'tex') {
  my $border = &Apache::lonxml::get_param('border',$parstack,$safeeval);   my $border = &Apache::lonxml::get_param('border',$parstack,$safeeval);
  my $tabletext=&Apache::lonxml::get_all_text("/table",$$parser[$#$parser]);  
  my %mystyle;  
  $tabletext = &Apache::lonxml::xmlparse('tex',$tabletext,'',%mystyle);         
  unless (defined $border) { $border = 0; }   unless (defined $border) { $border = 0; }
  my $hinc = '';   if ($border) { 
                 my $vinc = '';         $Apache::londefdef::table{'hinc'} = '\hline '; 
  my $vvinc = '';      $Apache::londefdef::table{'vinc'} = '&'; 
  if ($border) { $hinc = '\hline '; $vinc =  '&'; $vvinc =  '|';}      $Apache::londefdef::table{'vvinc'} = '|';
  my @raws = ();  
  my @columns = ();  
  my $counter_columns;  
 #serch row  
  $_ = $tabletext;  
  while (m/<tr\s*([^>]*)>/) {  
     push @raws,$1;  
                     $tabletext =~ s/<tr\s*([^>]*)>/$hinc/;  
 #serch and convert column  
     my $boundary = index($tabletext,'</tr>',0);  
     my $textchunk = substr($tabletext,0,$boundary);   
     $_ = $textchunk;  
     $counter_columns = 0;  
     while (m/<td\s*([^>]*)>/) {  
  push @columns,$1;  
  $counter_columns++;  
  $textchunk =~ s/<\/td>\s*<td\s*([^>]*)>/$vinc/;  
  $textchunk =~ s/<td\s*([^>]*)>//;  
  $textchunk =~ s/<\/td>//;  
  $_ = $textchunk;  
     }  
     substr($tabletext,0,$boundary) = $textchunk;  
 #convert row  
     $tabletext =~ s/<\/tr>/\\\\/;  
     $_ = $tabletext;  
  }  
  my $default_value = '';  
  if ($raws[1] eq 'left') {  
     $default_value = 'l';  
  } elsif ($raws[1] eq 'center') {  
     $default_value = 'c';  
  } elsif ($raws[1] eq 'right') {  
     $default_value = 'r';  
  } else {   } else {
      $default_value = 'c';      $Apache::londefdef::table{'hinc'} = ''; 
       $Apache::londefdef::table{'vinc'} = ''; 
       $Apache::londefdef::table{'vvinc'} = '';
  }   }
  my $header_of_table = '{'.$vvinc;      } 
      return $currentstring;
    }
           sub end_table {
       my ($target,$token) = @_;
               my $currentstring = '';
               if ($target eq 'web') {
                 $currentstring = $token->[2];     
       } elsif ($target eq 'tex') {
    my $output = '';
    my $header_of_table = '{'.$Apache::londefdef::table{'vvinc'};
  my $in;   my $in;
  for ($in=0;$in<=$counter_columns;$in++) {   for ($in=0;$in<$Apache::londefdef::table{'counter_columns'};$in++) {
     if ($columns[$in] eq 'left') {      $header_of_table .= @{ $Apache::londefdef::table{'columns'} }[$in].$Apache::londefdef::table{'vvinc'};
  $header_of_table .= 'l'.$vvinc;      $output .=  $Apache::londefdef::table{'rowdata'}[$in];
     } elsif ($columns[$in] eq 'center') {      chop $output;
  $header_of_table .= 'c'.$vvinc;      $output .= ' \\\\ ';
     } elsif ($columns[$in] eq 'right') {  
  $header_of_table .= 'r'.$vvinc;  
     } else {  
        $header_of_table .= $default_value.$vvinc;  
     }  
  }   }
  $header_of_table .= '}';   $header_of_table .= '}';
  $currentstring .= '\begin{tabular}'.$header_of_table.$tabletext.$hinc.'\end{tabular}';   $currentstring .= '\begin{tabular}'.$header_of_table.$output.$Apache::londefdef::table{'hinc'}.'\end{tabular}';
       }
      return $currentstring;
    }
   #-- <tr> tag
           sub start_tr {
       my ($target,$token,$tagstack,$parstack,$parser,$safeeval) = @_;
               my $currentstring = '';
               if ($target eq 'web') {
                 $currentstring = $token->[4];     
       } elsif ($target eq 'tex') {
    if (substr(&Apache::lonxml::get_param('align',$parstack,$safeeval),0,1) ne '') {
       push @ {$Apache::londefdef::table{'rows'} }, substr(&Apache::lonxml::get_param('align',$parstack,$safeeval),0,1);
    } else {
       push @ {$Apache::londefdef::table{'rows'} }, 'c';
    }
    push ( @{ $Apache::londefdef::table{'rowdata'} }, $Apache::londefdef::table{'hinc'});
    $Apache::londefdef::table{'counter_columns'} = 0;
   
     }       } 
    return $currentstring;     return $currentstring;
    }        
           sub end_tr {
       my ($target,$token) = @_;
               my $currentstring = '';
               if ($target eq 'web') {
    $currentstring = $token->[2];     
       } elsif ($target eq 'tex') {
       }
      return $currentstring;
  }   }
         sub end_table {  #-- <td> tag
           sub start_td {
       my ($target,$token,$tagstack,$parstack,$parser,$safeeval) = @_;
               my $currentstring = '';
               if ($target eq 'web') {
                 $currentstring = $token->[4];     
       } elsif ($target eq 'tex') {
    my $what_to_push = substr(&Apache::lonxml::get_param('align',$parstack,$safeeval),0,1);
    if ($what_to_push eq '') {
       $what_to_push = substr($Apache::londefdef::table{'rows'}[0],0,1);;
    }
       push @{ $Apache::londefdef::table{'columns'} }, $what_to_push;
    $Apache::londefdef::table{'counter_columns'}++;
    &Apache::lonxml::startredirection();
   ;
       } 
      return $currentstring;
    }        
           sub end_td {
     my ($target,$token) = @_;      my ($target,$token) = @_;
             my $currentstring = '';              my $currentstring = '';
             if ($target eq 'web') {              if ($target eq 'web') {
               $currentstring = $token->[2];        $currentstring = $token->[2];     
       } elsif ($target eq 'tex') {
    my $current_row = $#{ $Apache::londedef::table{'rows'} };
    my $data=&Apache::lonxml::endredirection();
    @{ $Apache::londefdef::table{'rowdata'} }[$current_row] .= $data.' '.$Apache::londefdef::table{'vinc'};
     }      }
    return $currentstring;     return $currentstring;
  }   }

Removed from v.1.50  
changed lines
  Added in v.1.52


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