Annotation of loncom/homework/hint.pm, revision 1.19

1.1       albertel    1: package Apache::hinttags; 
                      2: 
                      3: use strict;
                      4: use Apache::lonnet;
1.6       albertel    5: use capa;
1.1       albertel    6: 
                      7: sub BEGIN {
1.15      albertel    8:   &Apache::lonxml::register('Apache::hinttags',('hintgroup','hintpart','numericalhint'));
1.1       albertel    9: }
                     10: 
1.2       albertel   11: 
1.15      albertel   12: @Apache::hint::which=();
1.1       albertel   13: sub start_hintgroup {
1.15      albertel   14:   my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
                     15:   my $skiptoend='0';
                     16:   my $result;
                     17:   
                     18:   if ($target eq 'web') {
                     19:     my $id=$Apache::inputtags::part;
                     20:     my $numtries=$Apache::lonhomework::history{"resource.$id.tries"};
                     21:     if ( $numtries eq '') { $numtries = 0; }
                     22:     my $hinttries=&Apache::lonnet::EXT("resource.$id.hinttries");
                     23:     if ( $hinttries eq '') { $hinttries = 1; }
                     24:     &Apache::lonxml::debug("found :$id:$numtries:$hinttries:");
                     25:     if ( $numtries < $hinttries ) {
                     26:       $skiptoend='1';
                     27:     } else {
                     28:       if ($target eq 'web') {$result='<table bgcolor="#dddddd"><tr><td>';}
1.9       albertel   29:     }
1.15      albertel   30:   }
                     31:   if ($skiptoend) {
                     32:     &Apache::lonxml::get_all_text("/hintgroup",$$parser[$#$parser]);
                     33:   }
                     34:   @Apache::hint::which=();
                     35:   return $result;
1.1       albertel   36: }
                     37: 
                     38: sub end_hintgroup {
1.15      albertel   39:   my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
                     40:   my $result;
1.19    ! albertel   41:   
1.15      albertel   42:   if ($target eq 'web') {
                     43:     my $id=$Apache::inputtags::part;
                     44:     my $numtries=$Apache::lonhomework::history{"resource.$id.tries"};
                     45:     if ( $numtries eq '') { $numtries = 0; }
                     46:     my $hinttries=&Apache::lonnet::EXT("resource.$id.hinttries");
                     47:     if ( $hinttries eq '') { $hinttries = 1; }
                     48:     &Apache::lonxml::debug("found :$id:$numtries:$hinttries:");
1.19    ! albertel   49:     if ( $numtries >= $hinttries ) {
        !            50:       $result='</td></tr></table>';
        !            51:     }
1.15      albertel   52:   }
1.19    ! albertel   53:   @Apache::hint::which=();
1.15      albertel   54:   return $result;
1.3       albertel   55: }
                     56: 
                     57: sub start_numericalhint {
1.16      albertel   58:   my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
1.15      albertel   59:   #do everything in end, so intervening <responseparams> work
1.16      albertel   60:   &Apache::response::start_hintresponse($parstack,$safeeval);
1.15      albertel   61:   return '';
1.3       albertel   62: }
                     63: 
                     64: sub end_numericalhint {
1.15      albertel   65:   my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
                     66:   my $result;
                     67:   if ($target eq 'web') {
                     68:     $safeeval->share_from('capa',['&caparesponse_capa_check_answer']);
                     69:     my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval);
1.18      albertel   70:     &Apache::response::setup_params('numericalhint');
                     71:     my $partid=$Apache::inputtags::part;
                     72:     my $id=$Apache::inputtags::response['-1'];
                     73:     #id submissions occured under
                     74:     my $submitid=$Apache::inputtags::response['-2'];
                     75:     my $response = $Apache::lonhomework::history{
                     76: 			    "resource.$partid.$submitid.submission"};
1.15      albertel   77:     &Apache::lonxml::debug("hintgroup is using $response<br />\n");
1.18      albertel   78:     #build safe space expression
1.15      albertel   79:     my $expression="&caparesponse_check_list('".$response."','".
1.18      albertel   80:       $$parstack[$#$parstack];
                     81:     #need to get all possible parms
                     82:     foreach my $key (keys(%Apache::inputtags::params)) {
                     83:       $expression.= ';my $'. #'
                     84: 	$key.'="'.$Apache::inputtags::params{$key}.'"';
                     85:     }
                     86:     $expression.="');";
1.15      albertel   87:     $result = &Apache::run::run($expression,$safeeval);
                     88:     &Apache::lonxml::debug("$expression:result:$result:$Apache::lonxml::curdepth");
                     89:     my ($awards) = split /:/ , $result;
                     90:     my ($ad) = &Apache::inputtags::finalizeawards(split /,/ , $awards);
                     91:     if ($ad eq 'EXACT_ANS' || $ad eq 'APPROX_ANS') { push (@Apache::hint::which,$name); }
                     92:     $result='';
1.17      albertel   93:   } elsif ($target eq 'meta') {
                     94:     $result=&Apache::response::meta_package_write('numericalhint');
1.15      albertel   95:   }
1.16      albertel   96:   &Apache::response::end_hintresponse();
1.15      albertel   97:   return $result;
1.1       albertel   98: }
                     99: 
1.2       albertel  100: # a part shows if it is on, if no specific parts are on, then default shows
1.1       albertel  101: sub start_hintpart {
1.15      albertel  102:   my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_;
                    103: 
                    104:   my $show ='0';
                    105: 
                    106:   if ($target eq 'web') {
                    107:     my $on= &Apache::lonxml::get_param('on',$parstack,$safeeval);
                    108:     &Apache::lonxml::debug("hintpart sees $on and ,$#Apache::hint::which");
                    109:     if ( $on eq 'default' && $#Apache::hint::which == '-1') {
                    110:       $show=1;
                    111:     } else {
                    112:       my $which;
                    113:       foreach $which (@Apache::hint::which) { if ($which eq $on) { $show = 1; last } }
                    114:     }
                    115:     if (!$show) {
                    116:       &Apache::lonxml::get_all_text("/hintpart",$$parser[$#$parser]);
1.1       albertel  117:     }
1.15      albertel  118:   } elsif ($target eq 'grade') {
                    119:     &Apache::lonxml::get_all_text("/hintpart",$$parser[$#$parser]);
                    120:   }
                    121:   return '';
1.1       albertel  122: }
                    123: 
                    124: sub end_hintpart {
1.11      albertel  125:   return '';
1.1       albertel  126: }
                    127: 
                    128: 1;
                    129: __END__

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