Answer for Part:'. + $Apache::inputtags::part. ' | '."\n"; + } + return $result; } -sub start_responseparam { - my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; - my $result=''; - if ($target eq 'meta') { - $result = &meta_parameter_write($token->[2]->{'name'}, - $token->[2]->{'type'}, - $token->[2]->{'default'}, - $token->[2]->{'description'}); - } elsif ($target eq 'edit') { - $result.=&Apache::edit::tag_start($target,$token, - &Apache::lonxml::description($token)); - $result.=&Apache::edit::text_arg('Name:','name',$token). - &Apache::edit::text_arg('Type:','type',$token). - &Apache::edit::text_arg('Description:','description',$token). - &Apache::edit::text_arg('Default:','default',$token). - "'.$answer.' | '; } - } - return $result; + return $result; } -sub end_responseparam { - my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; - if ($target eq 'edit') { return ('','no'); } - return ''; +sub answer_footer { + my ($type) = @_; + my $result; + if ($ENV{'form.answer_output_mode'} eq 'tex') { + $result = ' \end{tabular} \vskip 0 mm '; + } else { + $result = '
Answer for Part:'. - $Apache::inputtags::part. ' | ||
---|---|---|
Answer for Part:'. - $Apache::inputtags::part. ' | '."\n"; - } - return $result; -} +sub repetition { + my $id = $Apache::inputtags::part; + my $weight = &Apache::lonnet::EXT("resource.$id.weight"); + my $repetition = int $weight/9; + if ($weight % 9 != 0) {$repetition++;} + return $repetition; +} + +sub scored_response { + my ($part,$id)=@_; + my $repetition=&repetition(); + my $score=0; + for (my $i=0;$i<$repetition;$i++) { + my $increase=&Apache::response::getresponse($i+1); + if ($increase ne '') { $score+=$increase+1; } + } + my $weight = &Apache::lonnet::EXT("resource.$part.weight"); + my $pcr=$score/$weight; + $Apache::lonhomework::results{"resource.$part.$id.awarded"}=$pcr; + $Apache::lonhomework::results{"resource.$part.$id.awarddetail"}= + 'ASSIGNED_SCORE'; + return $repetition; +} + +sub whichorder { + my ($max,$randomize,$showall,$hash)=@_; + #&Apache::lonxml::debug("man $max randomize $randomize"); + if (!defined(@{ $$hash{'names'} })) { return; } + my @names = @{ $$hash{'names'} }; + my @whichopt =(); + my (%top,@toplist,%bottom,@bottomlist); + if (!($showall || ($randomize eq 'no'))) { + my $current=0; + foreach my $name (@names) { + $current++; + if ($$hash{"$name.location"} eq 'top') { + $top{$name}=$current; + } elsif ($$hash{"$name.location"} eq 'bottom') { + $bottom{$name}=$current; + } + } + } + my $topcount=0; + my $bottomcount=0; + while (((scalar(@whichopt)+$topcount+$bottomcount) < $max || $showall) + && ($#names > -1)) { + #&Apache::lonxml::debug("Have $#whichopt max is $max"); + my $aopt; + if ($showall || ($randomize eq 'no')) { + $aopt=0; + } else { + $aopt=int(&Math::Random::random_uniform() * ($#names+1)); + } + #&Apache::lonxml::debug("From $#whichopt $max $#names elms, picking $aopt"); + $aopt=splice(@names,$aopt,1); + #&Apache::lonxml::debug("Picked $aopt"); + if ($top{$aopt}) { + $toplist[$top{$aopt}]=$aopt; + $topcount++; + } elsif ($bottom{$aopt}) { + $bottomlist[$bottom{$aopt}]=$aopt; + $bottomcount++; + } else { + push (@whichopt,$aopt); + } + } + for (my $i=0;$i<=$#toplist;$i++) { + if ($toplist[$i]) { unshift(@whichopt,$toplist[$i]) } + } + for (my $i=0;$i<=$#bottomlist;$i++) { + if ($bottomlist[$i]) { push(@whichopt,$bottomlist[$i]) } + } -sub answer_part { - my ($type,$answer) = @_; - my $result; - if ($type eq 'optionresponse') { - $result = ''.$answer.' | '; - } else { - $result = ''.$answer.' | '; - } - return $result; + return @whichopt; } -sub answer_footer { - my ($type) = @_; - my $result; - if ($type eq 'optionresponse') { - $result = '