--- loncom/homework/default_homework.lcpm 2003/09/25 22:57:01 1.67 +++ loncom/homework/default_homework.lcpm 2004/03/13 00:36:11 1.72 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # used by lonxml::xmlparse() as input variable $safeinit to Apache::run::run() # -# $Id: default_homework.lcpm,v 1.67 2003/09/25 22:57:01 albertel Exp $ +# $Id: default_homework.lcpm,v 1.72 2004/03/13 00:36:11 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -44,7 +44,7 @@ sub caparesponse_check { #not to be used: $ans_fmt my ($type,$tol,$sig,$ans_fmt,$unit,$calc,$samples) = eval $_[2]. - ';return ($type,$tol,$sig,$ans_fmt,$unit,$calc,$samples);'; + ';return ($__LC__type,$__LC__tol,$__LC__sig,$__LC__ans_fmt,$__LC__unit,$__LC__calc,$__LC__samples);'; my $tol_type=''; # gets it's value from whether tol has a % or not done my $sig_lbound=''; #done @@ -55,6 +55,9 @@ sub caparesponse_check { #type's definitons come from capaParser.h my $message=''; #remove leading and trailing whitespace + if (!defined($response)) { + $response=''; + } if ($response=~ /^\s|\s$/) { $response=~ s:^\s+|\s+$::g; $message .="Removed ws now :$response:\n"; @@ -109,11 +112,13 @@ sub caparesponse_check { } if (!defined($sig_ubound)) { $sig_ubound=$sig_lbound; } } + my $reterror=""; my $result = &caparesponse_capa_check_answer($response,$answer,$type, $tol_type,$tol, $sig_lbound,$sig_ubound, $ans_fmt,$unit,$calc,$id_list, - $points,$external::randomseed); + $points,$external::randomseed, + \$reterror); if ($result == '1') { $result='EXACT_ANS'; } elsif ($result == '2') { $result='APPROX_ANS'; } @@ -129,7 +134,7 @@ sub caparesponse_check { elsif ($result =='12') { $result='WANTED_NUMERIC'; } else {$result = "ERROR: Unknown Result:$result:$@:";} - return "$result:\nError $error:\nAnswer $answer:\nResponse $response:\n type-$type|$tol|$tol_type|$sig:$sig_lbound:$sig_ubound|$unit|\n$message$expr"; + return ("$result:\nRetError $reterror:\nError $error:\nAnswer $answer:\nResponse $response:\n type-$type|$tol|$tol_type|$sig:$sig_lbound:$sig_ubound|$unit|\n$message$expr",$reterror); } sub get_array_args { @@ -165,7 +170,8 @@ sub caparesponse_check_list { my $answers=join(':',@list); $result.="Got response :$answers:\n"; my @responselist; - my $type =eval $expr.';return $type;'; + my $type =eval $expr.';return $__LC__type;'; + $result.="Got type :$type:\n"; if ($type ne '' && $#list > 0) { (@responselist)=split /,/,$response; } else { @@ -185,25 +191,29 @@ sub caparesponse_check_list { $unit=~s/\s//; my $i=0; my $awards=''; + my @msgs; for ($i=0; $i<@list;$i++) { + my $msg; $result.="trying answer :$list[$i]:\n"; my $thisanswer=$list[$i]; # $thisanswer=~ s/\\/\\\\/g; # $thisanswer =~ s/\'/\\\'/g; $result.="trying answer :$thisanswer:\n"; if ($unit eq '') { - $aresult=&caparesponse_check($thisanswer,$responselist[$i], - $expr); + ($aresult,$msg)=&caparesponse_check($thisanswer,$responselist[$i], + $expr); } else { - $aresult=&caparesponse_check($thisanswer,$responselist[$i]." $unit", - $expr); + ($aresult,$msg)=&caparesponse_check($thisanswer, + $responselist[$i]." $unit", + $expr); } my ($temp)=split /:/, $aresult; $awards.="$temp,"; $result.=$aresult; + push(@msgs,$msg); } chop $awards; - return "$awards:\n$result"; + return ("$awards:\n$result",@msgs); } sub tex { @@ -498,12 +508,13 @@ sub format { } sub prettyprint { - my ($value,$fmt)=@_; + my ($value,$fmt,$target)=@_; my $result; my $dollarmode; + if (!$target) { $target = $external::target; } if ($fmt =~ /^\$(.*)/) { $fmt=$1; $dollarmode=1; } if ($fmt) { $value=sprintf('%.'.$fmt,$value); } - if ($value =~ /([0-9\.\-\+]+)E([0-9\-\+]+)/ ) { + if ($value =~ /([0-9\.\-\+]+)E([0-9\-\+]+)/i ) { my $frac=$1; if ($dollarmode) { $frac=&dollarformat($frac); } my $exponent=$2; @@ -512,9 +523,9 @@ sub prettyprint { $exponent=~s/^-0*/-/; if ($exponent eq '-') { undef($exponent); } if ($exponent) { - if ($external::target eq 'web') { + if ($target eq 'web') { $result=$frac.'×10'.$exponent.''; - } elsif ($external::target eq 'tex') { + } elsif ($target eq 'tex') { $result='\ensuremath{'.$frac.'\times 10^{'.$exponent.'}}'; } else { $result=$value; @@ -524,13 +535,14 @@ sub prettyprint { } } else { $result=$value; - if ($dollarmode) { $result=&dollarformat($result); } + if ($dollarmode) { $result=&dollarformat($result,$target); } } return $result; } sub dollarformat { - my ($number) = @_; + my ($number,$target) = @_; + if (!$target) { $target = $external::target; } if ($number =~ /\./) { while ($number =~ /([^\.,]+)([^\.,][^\.,][^\.,])([,0-9]*\.[0-9]*$)/) { $number = $1.','.$2.$3; @@ -540,7 +552,7 @@ sub dollarformat { $number = $1.','.$2.$3; } } - if ($external::target eq 'tex') { + if ($target eq 'tex') { $number='\$'.$number; #' stupid emacs } else { $number='$'.$number; #' stupid emacs