Diff for /loncom/homework/caparesponse/caparesponse.pm between versions 1.243 and 1.246

version 1.243, 2010/12/16 16:01:08 version 1.246, 2011/02/24 23:09:32
Line 1136  sub start_stringresponse { Line 1136  sub start_stringresponse {
     my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
     my $result;      my $result;
     my $id = &Apache::response::start_response($parstack,$safeeval);      my $id = &Apache::response::start_response($parstack,$safeeval);
       undef(%answer);
     if ($target eq 'meta') {      if ($target eq 'meta') {
  $result=&Apache::response::meta_package_write('stringresponse');   $result=&Apache::response::meta_package_write('stringresponse');
     } elsif ($target eq 'edit') {      } elsif ($target eq 'edit') {
Line 1231  sub end_stringresponse { Line 1232  sub end_stringresponse {
  my ($result, @msgs)=&Apache::run::run("&caparesponse_check_list()",$safeeval);   my ($result, @msgs)=&Apache::run::run("&caparesponse_check_list()",$safeeval);
                         if ($$args_ref{'type'} =~ /^c[si]$/) {                          if ($$args_ref{'type'} =~ /^c[si]$/) {
                             $ansstring{$name} = pop(@msgs);                              $ansstring{$name} = pop(@msgs);
                         }  
                         if ($$args_ref{'type'} =~ /^c[si]$/) {  
                             my $control_chars_removed = pop(@msgs);                              my $control_chars_removed = pop(@msgs);
                             my $error = pop(@msgs);                              my $error = pop(@msgs);
                             if (($error ne '') ||                               if (($error ne '') || 
                                 ($control_chars_removed ne '')) {                                  ($control_chars_removed)) {
                                 my ($symb,$courseid,$sdomain,$sname) =                                  my ($symb,$courseid,$sdomain,$sname) =
                                     &Apache::lonnet::whichuser();                                      &Apache::lonnet::whichuser();
                                 if ($control_chars_removed ne '') {                                  if ($control_chars_removed) {
                                     my $showresponse = $response;                                      my $showresponse = $response;
                                     if ($response =~ /[\000-\037]/) {                                      if ($response =~ /[\000-\037]/) {
                                         $response =~ s/[\000-\037]//g;                                          $response =~ s/[\000-\037]//g;
Line 1286  sub end_stringresponse { Line 1285  sub end_stringresponse {
                         $ad='ANONYMOUS_CREDIT';                          $ad='ANONYMOUS_CREDIT';
                     }                      }
                 }                  }
                 unless ($env{'request.state'} eq 'construct') {                  unless (($env{'request.state'} eq 'construct') || 
                     if ($previous{'used'}) {                          ($Apache::lonhomework::type eq 'randomizetry')) {
                         if ($ad ne $previous{'award'} && $previous{'award'} ne '') {                      if (($ad eq 'INCORRECT' || $ad eq 'APPROX_ANS' || $ad eq 'EXACT_ANS')) {
                             &stringresponse_gradechange($part,$id,\%previous,                          if ($previous{'used'}) {
                                                         'cs',$response,$ad,$type);                              if ($ad ne $previous{'award'}) {
                         }                                  if (($previous{'award'} eq 'INCORRECT' || 
                     } elsif ($previous{'usedci'}) {                                       $previous{'award'} eq 'APPROX_ANS' ||
                         if ($ad ne $previous{'awardci'} && $previous{'awardci'} ne '') {                                       $previous{'award'} eq 'EXACT_ANS')) {
                             &stringresponse_gradechange($part,$id,\%previous,                                      &stringresponse_gradechange($part,$id,\%previous,
                                                         'ci',$response,$ad,$type);                                                                  'cs',$response,$ad,$type);
                                   }
                               }
                           } elsif ($previous{'usedci'}) {
                               if ($ad ne $previous{'awardci'}) {
                                   if (($previous{'awardci'} eq 'INCORRECT' || 
                                        $previous{'awardci'} eq 'APPROX_ANS' ||
                                        $previous{'awardci'} eq 'EXACT_ANS')) {
                                       &stringresponse_gradechange($part,$id,\%previous,
                                                                   'ci',$response,$ad,$type);
                                   }
                               }
                         }                          }
                     }                      }
                 }                  }

Removed from v.1.243  
changed lines
  Added in v.1.246


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