version 1.94, 2003/04/21 17:51:46
|
version 1.110, 2003/09/22 13:04:55
|
Line 79 sub start_numericalresponse {
|
Line 79 sub start_numericalresponse {
|
$result=&Apache::response::meta_package_write('numericalresponse'); |
$result=&Apache::response::meta_package_write('numericalresponse'); |
} elsif ($target eq 'answer' || $target eq 'grade') { |
} elsif ($target eq 'answer' || $target eq 'grade') { |
&Apache::response::reset_params(); |
&Apache::response::reset_params(); |
|
} elsif ($target eq 'web') { |
|
my $partid = $Apache::inputtags::part; |
|
my $hideunit=&Apache::lonnet::EXT('resource.'.$partid.'_'.$id.'.turnoffunit'); |
|
&Apache::lonxml::debug("Got unit $hideunit for $partid $id"); |
|
#no way to enter units, with radio buttons |
|
if (lc($hideunit) eq "yes") { |
|
my $unit=&Apache::lonxml::get_param_var('unit',$parstack, |
|
$safeeval); |
|
if ($unit =~ /\S/) { $result.=" (in $unit) "; } |
|
} |
} |
} |
return $result; |
return $result; |
} |
} |
Line 90 sub end_numericalresponse {
|
Line 100 sub end_numericalresponse {
|
if (!$Apache::lonxml::default_homework_loaded) { |
if (!$Apache::lonxml::default_homework_loaded) { |
&Apache::lonxml::default_homework_load($safeeval); |
&Apache::lonxml::default_homework_load($safeeval); |
} |
} |
if ( $target eq 'grade' && defined $ENV{'form.submitted'}) { |
if ( $target eq 'grade' && defined($ENV{'form.submitted'})) { |
&Apache::response::setup_params($$tagstack[-1]); |
&Apache::response::setup_params($$tagstack[-1]); |
$safeeval->share_from('capa',['&caparesponse_capa_check_answer']); |
$safeeval->share_from('capa',['&caparesponse_capa_check_answer']); |
my $partid = $Apache::inputtags::part; |
my $partid = $Apache::inputtags::part; |
my $id = $Apache::inputtags::response['-1']; |
my $id = $Apache::inputtags::response['-1']; |
my $response = &Apache::response::getresponse(); |
if ($Apache::lonhomework::type eq 'exam' && |
if ( $response =~ /[^\s]/) { |
($$tagstack[-1] eq 'formularesponse' || |
my $ad; |
$$tagstack[-1] eq 'stringresponse')) { |
my %previous = &Apache::response::check_for_previous($response,$partid,$id); |
$increment=&Apache::response::scored_response($partid,$id); |
$Apache::lonhomework::results{"resource.$partid.$id.submission"}=$response; |
} else { |
&Apache::lonxml::debug("submitted a $response<br>\n"); |
my $response = &Apache::response::getresponse(); |
&Apache::lonxml::debug($$parstack[-1] . "\n<br>"); |
if ( $response =~ /[^\s]/) { |
|
my $ad; |
if ($ENV{'form.submitted'} eq 'scantron') { |
my %previous = &Apache::response::check_for_previous($response,$partid,$id); |
my $number_of_bubbles = 8;#default values for number of bubbles |
$Apache::lonhomework::results{"resource.$partid.$id.submission"}=$response; |
my (@formats)=&Apache::lonxml::get_param_var('format', |
&Apache::lonxml::debug("submitted a $response<br>\n"); |
$parstack,$safeeval); |
&Apache::lonxml::debug($$parstack[-1] . "\n<br>"); |
my (@answers)=&Apache::lonxml::get_param_var('answer', |
|
$parstack,$safeeval); |
if ($ENV{'form.submitted'} eq 'scantron') { |
my @values=&make_numerical_bubbles($number_of_bubbles,$target, |
my $number_of_bubbles = 8;#default values for number of bubbles |
$answers[0],$formats[0]); |
my (@formats)=&Apache::lonxml::get_param_var('format', |
$response=$values[$response]; |
$parstack,$safeeval); |
} else { |
my (@answers)=&Apache::lonxml::get_param_var('answer', |
$response =~ s/\\/\\\\/g; |
$parstack,$safeeval); |
$response =~ s/\'/\\\'/g; |
my @values=&make_numerical_bubbles($number_of_bubbles,$target, |
} |
$answers[0],$formats[0]); |
&Apache::lonxml::debug("current $response"); |
$response=$values[$response]; |
my $expression="&caparesponse_check_list('".$response."','". |
} else { |
$$parstack[-1]; |
$response =~ s/\\/\\\\/g; |
#no way to enter units, with radio buttons |
$response =~ s/\'/\\\'/g; |
if ($Apache::lonhomework::type eq 'exam') { |
} |
$expression.=';my $unit=undef;'; |
&Apache::lonxml::debug("current $response"); |
} |
my $expression="&caparesponse_check_list('".$response."','". |
foreach my $key (keys(%Apache::inputtags::params)) { |
$$parstack[-1]; |
$expression.= ';my $'. #' |
my $hideunit=&Apache::lonnet::EXT('resource.'.$partid.'_'.$id.'.turnoffunit'); |
$key.'="'.$Apache::inputtags::params{$key}.'"'; |
#no way to enter units, with radio buttons |
} |
if ($Apache::lonhomework::type eq 'exam' || |
if ($$tagstack[-1] eq 'formularesponse') { |
lc($hideunit) eq "yes") { |
$expression.=';my $type="fml";'; |
$expression.=';my $unit=undef;'; |
} elsif ($$tagstack[-1] eq 'numericalresponse') { |
} |
$expression.=';my $type="float";'; |
foreach my $key (keys(%Apache::inputtags::params)) { |
} |
$expression.= ';my $'. #' |
$expression.="');"; |
$key.'="'.$Apache::inputtags::params{$key}.'"'; |
$result = &Apache::run::run($expression,$safeeval); |
} |
my ($awards) = split /:/ , $result; |
if ($$tagstack[-1] eq 'formularesponse') { |
($ad) = &Apache::inputtags::finalizeawards(split /,/ , $awards); |
$expression.=';my $type="fml";'; |
&Apache::lonxml::debug("$expression"); |
} elsif ($$tagstack[-1] eq 'numericalresponse') { |
&Apache::lonxml::debug("\n<br>result:$result:$Apache::lonxml::curdepth<br>\n"); |
$expression.=';my $type="float";'; |
&Apache::response::handle_previous(\%previous,$ad); |
} |
$Apache::lonhomework::results{"resource.$partid.$id.awarddetail"}=$ad; |
$expression.="');"; |
$result=''; |
my @answer=&Apache::lonxml::get_param_var('answer',$parstack,$safeeval); |
|
&Apache::lonxml::debug('answer is'.join(':',@answer)); |
|
@{$safeeval->varglob('CAPARESPONSE_CHECK_LIST_answer')}=@answer; |
|
|
|
$result = &Apache::run::run($expression,$safeeval); |
|
my ($awards) = split /:/ , $result; |
|
($ad) = &Apache::inputtags::finalizeawards(split /,/ , $awards); |
|
&Apache::lonxml::debug("$expression"); |
|
&Apache::lonxml::debug("\n<br>result:$result:$Apache::lonxml::curdepth<br>\n"); |
|
&Apache::response::handle_previous(\%previous,$ad); |
|
$Apache::lonhomework::results{"resource.$partid.$id.awarddetail"}=$ad; |
|
$result=''; |
|
} |
} |
} |
} elsif ($target eq 'web' || $target eq 'tex') { |
} elsif ($target eq 'web' || $target eq 'tex') { |
my (@answers)=&Apache::lonxml::get_param_var('answer',$parstack, |
my (@answers)=&Apache::lonxml::get_param_var('answer',$parstack, |
$safeeval); |
$safeeval); |
my $award = $Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
my $award = $Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
my $status = $Apache::inputtags::status['-1']; |
my $status = $Apache::inputtags::status['-1']; |
if ($award =~ /^correct/ || $status eq "SHOW_ANSWER" || $ENV{'form.texaward'} eq 'SHOW_ANSWER') { |
if ( ($award =~ /^correct/ |
|
&& lc($Apache::lonhomework::problemstatus) ne 'no') |
|
|| $status eq "SHOW_ANSWER" |
|
|| $ENV{'form.texaward'} eq 'SHOW_ANSWER') { |
my (@formats)=&Apache::lonxml::get_param_var('format',$parstack, |
my (@formats)=&Apache::lonxml::get_param_var('format',$parstack, |
$safeeval); |
$safeeval); |
my $unit=&Apache::lonxml::get_param_var('unit',$parstack, |
my $unit=&Apache::lonxml::get_param_var('unit',$parstack, |
Line 169 sub end_numericalresponse {
|
Line 194 sub end_numericalresponse {
|
} |
} |
my $formatted; |
my $formatted; |
if ((defined($format)) && ($format ne '')) { |
if ((defined($format)) && ($format ne '')) { |
|
$format=~s/e/E/g; |
&Apache::lonxml::debug("formatting with :$format: answer :$answer:"); |
&Apache::lonxml::debug("formatting with :$format: answer :$answer:"); |
$formatted=sprintf('%.'.$format,$answer).','; |
$formatted=sprintf('%.'.$format,$answer).','; |
} else { |
} else { |
Line 222 sub end_numericalresponse {
|
Line 248 sub end_numericalresponse {
|
</textarea></font> <br /><br />'; |
</textarea></font> <br /><br />'; |
} |
} |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
if (defined $unit and $Apache::lonhomework::type eq 'exam') { |
if ((defined $unit) and ($unit=~/\S/) and ($Apache::lonhomework::type eq 'exam')) { |
$result.=' \textit{(in} \verb|'.$unit.'|\textit{)} '; |
$result.=' \textit{(in} \verb|'.$unit.'|\textit{)} '; |
} |
} |
if ($$tagstack[-1] eq 'numericalresponse') { |
if ($$tagstack[-1] eq 'numericalresponse') { |
Line 288 sub end_numericalresponse {
|
Line 314 sub end_numericalresponse {
|
if ($Apache::inputtags::params{'sig'}) { |
if ($Apache::inputtags::params{'sig'}) { |
($sighigh,$siglow)=&get_sigrange($Apache::inputtags::params{'sig'}); |
($sighigh,$siglow)=&get_sigrange($Apache::inputtags::params{'sig'}); |
} |
} |
if ($fmt) { |
if ($fmt && $$tagstack[-1] eq 'numericalresponse') { |
$ans = sprintf('%.'.$fmt,$ans); |
$ans = sprintf('%.'.$fmt,$ans); |
if ($high) { |
if ($high) { |
$high=sprintf('%.'.$fmt,$high); |
$high=sprintf('%.'.$fmt,$high); |
Line 296 sub end_numericalresponse {
|
Line 322 sub end_numericalresponse {
|
} |
} |
} |
} |
if ($target eq 'answer') { |
if ($target eq 'answer') { |
if ($high) { $ans.=' ['.$low.','.$high.']'; } |
if ($high && $$tagstack[-1] eq 'numericalresponse') { $ans.=' ['.$low.','.$high.']'; } |
if ($sighigh) { $ans.= " Sig <i>$siglow - $sighigh</i>"; } |
if ($sighigh && $$tagstack[-1] eq 'numericalresponse') { |
|
if ($ENV{'form.answer_output_mode'} eq 'tex') { |
|
$ans.= " Sig $siglow - $sighigh"; |
|
} else { |
|
$ans.= " Sig <i>$siglow - $sighigh</i>"; |
|
} |
|
} |
$result.=&Apache::response::answer_part($$tagstack[-1],$ans); |
$result.=&Apache::response::answer_part($$tagstack[-1],$ans); |
} elsif ($target eq 'analyze') { |
} elsif ($target eq 'analyze') { |
push (@{ $Apache::lonhomework::analyze{"$part_id.answer"} }, $ans); |
push (@{ $Apache::lonhomework::analyze{"$part_id.answer"} }, $ans); |
Line 307 sub end_numericalresponse {
|
Line 339 sub end_numericalresponse {
|
} |
} |
} |
} |
} |
} |
if ($unit) { |
if (defined($unit) and ($unit ne '') and |
|
$$tagstack[-1] eq 'numericalresponse') { |
if ($target eq 'answer') { |
if ($target eq 'answer') { |
$result.=&Apache::response::answer_part($$tagstack[-1], |
if ($ENV{'form.answer_output_mode'} eq 'tex') { |
"Unit: <b>$unit</b>"); |
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
" Unit: $unit "); |
|
} else { |
|
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
"Unit: <b>$unit</b>"); |
|
} |
} elsif ($target eq 'analyze') { |
} elsif ($target eq 'analyze') { |
push (@{ $Apache::lonhomework::analyze{"$part_id.unit"} }, |
push (@{ $Apache::lonhomework::analyze{"$part_id.unit"} }, $unit); |
$unit); |
|
} |
} |
} |
} |
if ($type || $token->[1] eq 'stringresponse') { |
if ($type || $$tagstack[-1] eq 'stringresponse') { |
my $string='Case Insensitive'; |
my $string='Case Insensitive'; |
if ($type eq 'mc') { |
if ($type eq 'mc') { |
$string='Multiple Choice'; |
$string='Multiple Choice'; |
Line 328 sub end_numericalresponse {
|
Line 365 sub end_numericalresponse {
|
$string='Formula'; |
$string='Formula'; |
} |
} |
if ($target eq 'answer') { |
if ($target eq 'answer') { |
$result.=&Apache::response::answer_part($$tagstack[-1], |
if ($ENV{'form.answer_output_mode'} eq 'tex') { |
'<b>'.$string.'</b>'); |
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
"$string"); |
|
} else { |
|
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
"<b>$string</b>"); |
|
} |
} elsif ($target eq 'analyze') { |
} elsif ($target eq 'analyze') { |
push (@{ $Apache::lonhomework::analyze{"$part_id.type"} }, |
push (@{ $Apache::lonhomework::analyze{"$part_id.str_type"} }, |
$type); |
$type); |
} |
} |
} |
} |
Line 375 sub format_number {
|
Line 417 sub format_number {
|
my ($number,$format,$target)=@_; |
my ($number,$format,$target)=@_; |
my $ans; |
my $ans; |
if ($format ne '') { |
if ($format ne '') { |
|
$format=~s/e/E/g; |
$ans = sprintf('%.'.$format,$number); |
$ans = sprintf('%.'.$format,$number); |
} else { |
} else { |
my $format = ''; |
my $format = ''; |
#What is the number? (integer,decimal,floating point) |
#What is the number? (integer,decimal,floating point) |
if ($number=~/^(\d*\.?\d*)(E|e)(\d*)$/) { |
if ($number=~/^(\d*\.?\d*)(E|e)(\d*)$/) { |
$format = 'e'.$2; |
$format = 'e'.$3; |
} elsif ($number=~/^(\d*)\.(\d*)$/) { |
} elsif ($number=~/^(\d*)\.(\d*)$/) { |
$format = '4f'; |
$format = '4f'; |
} elsif ($number=~/^(\d*)$/) { |
} elsif ($number=~/^(\d*)$/) { |
Line 457 sub start_stringresponse {
|
Line 500 sub start_stringresponse {
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result; |
my $result; |
if ($target eq 'meta') { |
if ($target eq 'meta') { |
|
&Apache::response::start_response($parstack,$safeeval); |
$result=&Apache::response::meta_package_write('stringresponse'); |
$result=&Apache::response::meta_package_write('stringresponse'); |
|
&Apache::response::end_response(); |
} else { |
} else { |
$result.=&start_numericalresponse(@_); |
$result.=&start_numericalresponse(@_); |
} |
} |
Line 472 sub start_formularesponse {
|
Line 517 sub start_formularesponse {
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result; |
my $result; |
if ($target eq 'meta') { |
if ($target eq 'meta') { |
|
&Apache::response::start_response($parstack,$safeeval); |
$result=&Apache::response::meta_package_write('formularesponse'); |
$result=&Apache::response::meta_package_write('formularesponse'); |
|
&Apache::response::end_response(); |
} else { |
} else { |
$result.=&start_numericalresponse(@_); |
$result.=&start_numericalresponse(@_); |
} |
} |