--- loncom/homework/caparesponse/caparesponse.pm 2003/10/15 19:54:45 1.107.2.2
+++ loncom/homework/caparesponse/caparesponse.pm 2003/09/22 20:39:17 1.113
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# caparesponse definition
#
-# $Id: caparesponse.pm,v 1.107.2.2 2003/10/15 19:54:45 albertel Exp $
+# $Id: caparesponse.pm,v 1.113 2003/09/22 20:39:17 sakharuk Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -169,17 +169,15 @@ sub end_numericalresponse {
$safeeval);
my $award = $Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"};
my $status = $Apache::inputtags::status['-1'];
- if ( &Apache::response::show_answer() ) {
+ if ( ($award =~ /^correct/
+ && lc($Apache::lonhomework::problemstatus) ne 'no')
+ || $status eq "SHOW_ANSWER") {
my (@formats)=&Apache::lonxml::get_param_var('format',$parstack,
$safeeval);
my $unit=&Apache::lonxml::get_param_var('unit',$parstack,
$safeeval);
if ($target eq 'web') {
$result="
The correct answer is ";
- } elsif ($target eq 'tex') {
- if ($ENV{'form.texaward'} eq 'SHOW_ANSWER') {
- $result='\vskip 0 mm The correct answer is \\texttt{ ';
- }
}
for (my $i=0; $i <= $#answers; $i++) {
my $answer=$answers[$i];
@@ -191,15 +189,13 @@ sub end_numericalresponse {
}
my $formatted;
if ((defined($format)) && ($format ne '')) {
+ $format=~s/e/E/g;
&Apache::lonxml::debug("formatting with :$format: answer :$answer:");
$formatted=sprintf('%.'.$format,$answer).',';
} else {
&Apache::lonxml::debug("no format answer :$answer:");
$formatted="$answer,";
}
- if ($ENV{'form.texaward'} eq 'SHOW_ANSWER') {
- $result.=$formatted;
- }
if ($target eq 'tex') {
$formatted='';
#$formatted=&Apache::lonxml::latex_special_symbols($formatted);
@@ -209,11 +205,6 @@ sub end_numericalresponse {
chop $result;
if ($target eq 'web') {
$result.=" $unit.
";
- } elsif ($target eq 'tex') {
- if ($ENV{'form.texaward'} eq 'SHOW_ANSWER') {
- $result.=&Apache::lonxml::latex_special_symbols($unit);
- $result.="}. \\vskip 0 mm ";
- }
}
}
if ($Apache::lonhomework::type eq 'exam') {
@@ -231,16 +222,11 @@ sub end_numericalresponse {
if ($$tagstack[-1] eq 'numericalresponse') {
if ($unit=~/\S/) {$result.=' (in '.$unit.')
';}
$result.= '
'.$alphabet[$ind].': '. - $bubble_values[$ind].' | '; + '" value="'.$bubble_values[$ind].'">'. + $alphabet[$ind].': '. + $bubble_values[$ind].''; } $result.='