Diff for /loncom/homework/structuretags.pm between versions 1.159 and 1.160

version 1.159, 2003/04/03 14:31:58 version 1.160, 2003/04/03 14:53:44
Line 540  sub start_block { Line 540  sub start_block {
   
     my $result;      my $result;
   
     if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||       if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||
  $target eq 'tex' || $target eq 'analyze') {   $target eq 'tex' || $target eq 'analyze') {
  my $code = $token->[2]->{'condition'};   my $code = $token->[2]->{'condition'};
  if ($code) {   if ($code) {
Line 572  sub start_block { Line 572  sub start_block {
   
 sub end_block {  sub end_block {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
     my @result=('','');      my $result;
     if ($target eq "edit" || $target eq 'modified') { @result=('','no'); }      if ($target eq "edit") {
     return (@result);   $result.= &Apache::edit::tag_end($target,$token,'');
       }
       return $result;
 }  }
   
 sub start_while {  sub start_while {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   
     my $code = $token->[2]->{'condition'};      &Apache::lonxml::debug('starting while');
       my $result;
       if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || 
    $target eq 'tex' || $target eq 'analyze') {
    my $code = $token->[2]->{'condition'};
   
     push( @Apache::structuretags::whileconds, $code);    push( @Apache::structuretags::whileconds, $code);
     if (!$Apache::lonxml::default_homework_loaded) {   if (!$Apache::lonxml::default_homework_loaded) {
  &Apache::lonxml::default_homework_load($safeeval);      &Apache::lonxml::default_homework_load($safeeval);
     }   }
     my $result = &Apache::run::run($code,$safeeval);   my $result = &Apache::run::run($code,$safeeval);
     my $bodytext=$$parser[$#$parser]->get_text("/while");   my $bodytext=$$parser[-1]->get_text("/while");
     push( @Apache::structuretags::whilebody, $bodytext);   push( @Apache::structuretags::whilebody, $bodytext);
     if ( $result ) {   if ( $result ) {
  &Apache::lonxml::newparser($parser,\$bodytext);      &Apache::lonxml::newparser($parser,\$bodytext);
    }
       } elsif ($target eq 'edit') {
    $result .=&Apache::edit::tag_start($target,$token);
    $result .=&Apache::edit::text_arg('Test Condition:','condition',
     $token,40);
    $result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row();
       } elsif ($target eq 'modified') {
    my $constructtag=&Apache::edit::get_new_args($token,$parstack,
        $safeeval,'condition');
    if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); }
     }      }
     return "";      return $result;
 }  }
   
 sub end_while {  sub end_while {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
     my $code = pop @Apache::structuretags::whileconds;      &Apache::lonxml::debug('ending while');
     my $bodytext = pop @Apache::structuretags::whilebody;  
     my $result = &Apache::run::run($code,$safeeval);      my $result;
     if ( $result ) {  
  &Apache::lonxml::newparser($parser,\$bodytext);      if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||
    $target eq 'tex' || $target eq 'analyze') {
    my $code = pop(@Apache::structuretags::whileconds);
    my $bodytext = pop(@Apache::structuretags::whilebody);
    my $result = &Apache::run::run($code,$safeeval);
    if ( $result ) {
       &Apache::lonxml::newparser($parser,\$bodytext);
    }
       } elsif ($target eq "edit") {
    $result.= &Apache::edit::tag_end($target,$token,'');
     }      }
     return "";      return $result;
 }  }
   
 # <randomlist show="1">   # <randomlist show="1">
 #  <tag1>..</tag1>  #  <tag1>..</tag1>
 #  <tag2>..</tag2>  #  <tag2>..</tag2>
 #  <tag3>..</tag3>  #  <tag3>..</tag3>
 #  ...   #  ...
 # </randomlist>  # </randomlist>
 sub start_randomlist {  sub start_randomlist {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;

Removed from v.1.159  
changed lines
  Added in v.1.160


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