--- loncom/homework/hint.pm 2003/04/08 02:21:13 1.39 +++ loncom/homework/hint.pm 2003/06/24 20:41:56 1.45 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # implements the tags that control the hints # -# $Id: hint.pm,v 1.39 2003/04/08 02:21:13 albertel Exp $ +# $Id: hint.pm,v 1.45 2003/06/24 20:41:56 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -50,18 +50,10 @@ sub start_hintgroup { my $hinttries=&Apache::lonnet::EXT("resource.$id.hinttries"); if ( $hinttries eq '') { $hinttries = 1; } &Apache::lonxml::debug("found :$id:$numtries:$hinttries:"); - if ($Apache::lonhomework::type ne 'exam') { - if ( $numtries < $hinttries ) { - $skiptoend='1'; - } else { - $result='
'; - } - } else { - &Apache::lonxml::startredirection; - } - if ($skiptoend) { + if ( $numtries < $hinttries ) { &Apache::lonxml::get_all_text("/hintgroup",$parser); } + &Apache::lonxml::startredirection; } elsif ($target eq 'tex') { $result .= '\keephidden{'; } @@ -80,12 +72,11 @@ sub end_hintgroup { my $hinttries=&Apache::lonnet::EXT("resource.$id.hinttries"); if ( $hinttries eq '') { $hinttries = 1; } &Apache::lonxml::debug("found :$id:$numtries:$hinttries:"); - if ($Apache::lonhomework::type ne 'exam') { - if ( $numtries >= $hinttries ) { - $result='
'; - } - } else { - &Apache::lonxml::endredirection; + my $hinttext=&Apache::lonxml::endredirection; + if ($Apache::lonhomework::type ne 'exam' && + $numtries >= $hinttries && $hinttext =~/\S/) { + $result='
'. + $hinttext.'
'; } } elsif ($target eq 'edit') { $result.=&Apache::edit::end_table(); @@ -111,7 +102,9 @@ sub start_numericalhint { $result.=&Apache::edit::text_arg('Format:','format',$token,4). &Apache::loncommon::help_open_topic('Numerical_Response_Format'); } elsif ($token->[1] eq 'stringhint') { - $result.=&Apache::edit::select_arg('Type:','type',['cs','ci','mc'],$token); + $result.=&Apache::edit::select_arg('Type:','type', + [['cs','Case Sensitive'],['ci','Case Insensitive'], + ['mc','Case Insensitive, Any Order']],$token); } elsif ($token->[1] eq 'formulahint') { $result.=&Apache::edit::text_arg('Sample Points:','samples',$token,40); } @@ -167,7 +160,16 @@ sub end_numericalhint { $expression.= ';my $'. #' $key.'="'.$Apache::inputtags::params{$key}.'"'; } + if ($$tagstack[-1] eq 'formulahint') { + $expression.=';my $type="fml";'; + } elsif ($$tagstack[-1] eq 'numericalhint') { + $expression.=';my $type="float";'; + } $expression.="');"; + 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); &Apache::lonxml::debug("$expression:result:$result:$Apache::lonxml::curdepth"); my ($awards) = split /:/ , $result; @@ -357,13 +359,25 @@ sub end_radiobuttonhint { my $response = $Apache::lonhomework::history{ "resource.$part_id.submission"}; ($response)=&Apache::lonnet::str2hash($response); - if ($answer[0] eq 'foil' && $response eq $answer[1]) { - push (@Apache::hint::which,$name); + &Apache::lonxml::debug("response is $response"); + + if ($answer[0] eq 'foil') { + shift(@answer); + foreach my $answer (@answer) { + if ($response eq $answer) { + push (@Apache::hint::which,$name); + last; + } + } } elsif ($answer[0] eq 'concept') { - if (ref($Apache::hint::radiobutton{"$part_id.concept.".$answer[1]})) { - my @names=@{ $Apache::hint::radiobutton{"$part_id.concept.".$answer[1]} }; - if (grep(/^\Q$response\E$/,@names)) { - push(@Apache::hint::which,$name); + shift(@answer); + foreach my $answer (@answer) { + if (ref($Apache::hint::radiobutton{"$part_id.concept.".$answer})) { + my @names=@{ $Apache::hint::radiobutton{"$part_id.concept.".$answer} }; + if (grep(/^\Q$response\E$/,@names)) { + push(@Apache::hint::which,$name); + last; + } } } }