version 1.5, 2001/07/10 18:15:25
|
version 1.17, 2001/11/28 17:16:16
|
Line 11
|
Line 11
|
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) |
# |
# |
# 3/1/1,6/1,17/1,29/1,30/1 Gerd Kortemeyer) |
# 3/1/1,6/1,17/1,29/1,30/1,31/1 Gerd Kortemeyer) |
# |
|
# 1/31 Gerd Kortemeyer |
|
# |
|
# 7/10/01 Behrouz Minaei |
# 7/10/01 Behrouz Minaei |
|
# 9/8 Gerd Kortemeyer |
|
# 10/18/01, 10/19/01 Behrouz Minaei |
|
# 11/17/01, 11/22/01, 11/24/01 Behrouz Minaei |
|
|
package Apache::lonchart; |
package Apache::lonchart; |
|
|
Line 30 my %hash;
|
Line 30 my %hash;
|
my @cols; |
my @cols; |
my @rowlabels; |
my @rowlabels; |
my @students; |
my @students; |
|
my $r; |
|
|
# ------------------------------------------------------------- Find out status |
# ------------------------------------------------------------- Find out status |
|
|
Line 43 sub ExtractStudentData {
|
Line 44 sub ExtractStudentData {
|
my $Code; |
my $Code; |
my $Tries; |
my $Tries; |
my $Wrongs; |
my $Wrongs; |
|
my %TempHash; |
my $Version; |
my $Version; |
|
my $ProbNo; |
|
my $PrTotal; |
|
my $LatestVersion; |
|
|
|
my $test = $ENV{'request.course.fn'}; |
|
my $comp = '/home/httpd/perl/tmp/minaeibi_msu_12679c3ed543a25msul1'; |
|
|
my $Str=substr($students[$index]. |
my $Str=substr($students[$index]. |
' ',0,14).' ! '. |
' ',0,14).' ! '. |
substr($rowlabels[$index]. |
substr($rowlabels[$index]. |
' ',0,45).' ! '; |
' ',0,45).' ! '; |
|
|
unless ($reply=~/^error\:/) { |
unless ($reply=~/^error\:/) { |
map { |
map { |
my ($name,$value)=split(/\=/,&Apache::lonnet::unescape($_)); |
my ($name,$value)=split(/\=/,&Apache::lonnet::unescape($_)); |
$result{$name}=$value; |
$result{$name}=$value; |
} split(/\&/,$reply); |
} split(/\&/,$reply); |
|
$ProbNo = 0; |
|
$PrTotal = 0; |
|
my $IterationNo = 0; |
foreach $ResId (@cols) { |
foreach $ResId (@cols) { |
if ( !$ResId ) { $Str .= ' ! '; next; } |
if ($IterationNo == 0) {$IterationNo++; next;} |
|
if (!$ResId) { |
|
my $PrNo = sprintf( "%3d", $ProbNo ); |
|
$Str .= ' '.'<font color="#007700">'.$PrNo.'</font> '; |
|
$PrTotal += $ProbNo; |
|
$ProbNo=0; |
|
next; |
|
} |
$ResId=~/(\d+)\.(\d+)/; |
$ResId=~/(\d+)\.(\d+)/; |
|
my $meta=$hash{'src_'.$ResId}; |
|
my $PartNo = 0; |
|
undef %TempHash; |
|
map { |
|
if ($_=~/^stores\_(\d+)\_tries$/) { |
|
my $Part=&Apache::lonnet::metadata($meta,$_.'.part'); |
|
if ( $TempHash{"$Part"} eq '' ) { |
|
$TempHash{"$Part"} = $Part; |
|
$TempHash{$PartNo}=$Part; |
|
$TempHash{"$Part.Code"} = ' '; |
|
$PartNo++; |
|
} |
|
} |
|
} split(/\,/,&Apache::lonnet::metadata($meta,'keys')); |
|
|
my $Prob = &Apache::lonnet::declutter( $hash{'map_id_'.$1} ). |
my $Prob = &Apache::lonnet::declutter( $hash{'map_id_'.$1} ). |
'___'.$2.'___'. |
'___'.$2.'___'. |
&Apache::lonnet::declutter( $hash{'src_'.$ResId} ); |
&Apache::lonnet::declutter( $hash{'src_'.$ResId} ); |
$Code=' '; |
$Code=' '; |
$Tries = 0; |
$Tries = 0; |
$Version = $result{"version:$Prob"}; |
$LatestVersion = $result{"version:$Prob"}; |
if ( $Version ) { |
|
my $vkeys = $result{"$Version:keys:$Prob"}; |
if ( $LatestVersion ) { |
my @keys = split(/:/,$vkeys); |
for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) { |
foreach my $Key (@keys) { |
my $vkeys = $result{"$Version:keys:$Prob"}; |
if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) { |
my @keys = split(/\:/,$vkeys); |
my $Part = $1; |
|
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
foreach my $Key (@keys) { |
my $Val = $result{"$Version:$Prob:$Key"}; |
if (($Key=~/\.(\w+)\.solved$/) && ($Key!~/^\d+\:/)) { |
if ($Val eq 'correct_by_student'){$Code='*';} |
my $Part = $1; |
elsif ($Val eq 'correct_by_override'){$Code = '+';} |
$Tries = $result{"$Version:$Prob:resource.$Part.tries"}; |
elsif ($Val eq 'incorrect_attempted'){$Code = '.';} |
if ($Tries) {$TempHash{"$Part.Tries"}=$Tries;} |
elsif ($Val eq 'incorrect_by_override'){$Code = '-';} |
#my $Val = $result{"$Version:$Prob:$Key"}; |
elsif ($Val eq 'excused'){$Code = 'x';} |
my $Val = $result{"$Version:$Prob:resource.$Part.solved"}; |
|
if ($Val eq 'correct_by_student'){$Code='*';} |
|
elsif ($Val eq 'correct_by_override'){$Code = '+';} |
|
elsif ($Val eq 'incorrect_attempted'){$Code = '.';} |
|
elsif ($Val eq 'incorrect_by_override'){$Code = '-';} |
|
elsif ($Val eq 'excused'){$Code = 'x';} |
|
else {$Code = ' ';} |
|
$TempHash{"$Part.Code"} = $Code; |
|
# if ($test=~/*minaeibi*/) { |
|
$r->print($Key."PartNo =$PartNo "."Tries=$Tries!<br>$Version:$Prob:resource.$Part.tries".' = '.$result{"$Version:$Prob:resource.$Part.tries"}." $Val "."($Code)".'<br>'); |
|
# } |
|
} |
} |
} |
if (($Code eq '*')&&($Tries<10)){$Code=$Tries;} |
|
} |
} |
|
|
|
for ( my $n = 0; $n < $PartNo; $n++ ) { |
|
my $part = $TempHash{$n}; |
|
if ($TempHash{$part.'.Code'} eq '*') { |
|
$ProbNo++; |
|
if ($TempHash{$part.'.Tries'}<10) { |
|
$TempHash{$part.'.Code'}=$Tries; |
|
} |
|
} |
|
$Str .= $TempHash{$part.'.Code'}; |
|
$r->print($n.") Part=".$part." code=$TempHash{$part.'.Code'}<br>"); |
|
} |
} |
} |
$Str .= $Code; |
else {for(my $n=0; $n<$PartNo; $n++) {$Str.=' ';}} |
} |
} |
} |
} |
return $Str; |
my $PrTot = sprintf( "%5d", $PrTotal ); |
|
$Str .= ' '.'<font color="#000088">'.$PrTot.'</font> '; |
|
|
|
return $Str ; |
} |
} |
|
|
#sub astatus { |
|
# my ($rid,$student)=@_; |
|
# my ($uname,$udom)=split(/\:/,$student); |
|
# my $code=' '; |
|
# $rid=~/(\d+)\.(\d+)/; |
|
# my $symb=&Apache::lonnet::declutter($hash{'map_id_'.$1}).'___'.$2.'___'. |
|
# &Apache::lonnet::declutter($hash{'src_'.$rid}); |
|
# my $answer=&Apache::lonnet::reply( |
|
# "restore:$udom:$uname:". |
|
# $ENV{'request.course.id'}.':'. |
|
# &Apache::lonnet::escape($symb), |
|
# &Apache::lonnet::homeserver($uname,$udom)); |
|
# my %returnhash=(); |
|
# map { |
|
# my ($name,$value)=split(/\=/,$_); |
|
# $returnhash{&Apache::lonnet::unescape($name)}= |
|
# &Apache::lonnet::unescape($value); |
|
# } split(/\&/,$answer); |
|
# if ($returnhash{'version'}) { |
|
# my $version; |
|
# for ($version=1;$version<=$returnhash{'version'};$version++) { |
|
# map { |
|
# $returnhash{$_}=$returnhash{$version.':'.$_}; |
|
# } split(/\:/,$returnhash{$version.':keys'}); |
|
# } |
|
# my $totaltries=0; |
|
# map { |
|
# if (($_=~/\.(\w+)\.solved$/) && ($_!~/^\d+\:/)) { |
|
# my $part=$1; |
|
# if ($returnhash{$_} eq 'correct_by_student') { |
|
# unless (($code eq '.') || ($code eq '-')) { $code='*'; } |
|
# $totaltries+=$returnhash{'resource.'.$part.'.tries'}; |
|
# } elsif ($returnhash{$_} eq 'correct_by_override') { |
|
# unless (($code eq '.') || ($code eq '-')) { $code='+'; } |
|
# } elsif ($returnhash{$_} eq 'incorrect_attempted') { |
|
# $code='.'; |
|
# } elsif ($returnhash{$_} eq 'incorrect_by_override') { |
|
# $code='-'; |
|
# } elsif ($returnhash{$_} eq 'excused') { |
|
# unless (($code eq '.') || ($code eq '-')) { $code='x'; } |
|
# } |
|
# } |
|
# } keys %returnhash; |
|
# if (($code eq '*') && ($totaltries<10)) { $code="$totaltries"; } |
|
# } |
|
# return $code; |
|
#} |
|
|
|
# ------------------------------------------------------------ Build page table |
# ------------------------------------------------------------ Build page table |
|
|
Line 141 sub tracetable {
|
Line 151 sub tracetable {
|
my ($rid,$beenhere)=@_; |
my ($rid,$beenhere)=@_; |
unless ($beenhere=~/\&$rid\&/) { |
unless ($beenhere=~/\&$rid\&/) { |
$beenhere.=$rid.'&'; |
$beenhere.=$rid.'&'; |
|
# new ... updating the map according to sequence and page |
if (defined($hash{'is_map_'.$rid})) { |
if (defined($hash{'is_map_'.$rid})) { |
if ($hash{'map_type_'.$hash{'map_pc_'.$hash{'src_'.$rid}}} |
my $cmap=$hash{'map_type_'.$hash{'map_pc_'.$hash{'src_'.$rid}}}; |
eq 'sequence') { |
if ( $cmap eq 'sequence' || $cmap eq 'page' ) { |
$cols[$#cols+1]=0; |
$cols[$#cols+1]=0; |
} |
} |
if ((defined($hash{'map_start_'.$hash{'src_'.$rid}})) && |
if ((defined($hash{'map_start_'.$hash{'src_'.$rid}})) && |
Line 180 sub tracetable {
|
Line 191 sub tracetable {
|
# ================================================================ Main Handler |
# ================================================================ Main Handler |
|
|
sub handler { |
sub handler { |
my $r=shift; |
$r=shift; |
|
|
if (&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'})) { |
if (&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'})) { |
# ------------------------------------------- Set document type for header only |
# ------------------------------------------- Set document type for header only |
Line 221 sub handler {
|
Line 232 sub handler {
|
# ---------------------------------------------------------------- Course title |
# ---------------------------------------------------------------- Course title |
|
|
$r->print('<h1>'. |
$r->print('<h1>'. |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}.'</h1>'); |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}.'</h1><h3>'. |
|
localtime()."</h3><p><pre>1..9: correct by student in 1..9 tries\n". |
|
" *: correct by student in more than 9 tries\n". |
|
" +: correct by override\n". |
|
" -: incorrect by override\n". |
|
" .: incorrect attempted\n". |
|
" : not attempted\n". |
|
" x: excused</pre><p>"); |
|
|
# ------------------------------- This is going to take a while, produce output |
# ------------------------------- This is going to take a while, produce output |
|
|
$r->rflush(); |
$r->rflush(); |
Line 303 sub handler {
|
Line 320 sub handler {
|
$r->print('<p><pre>'); |
$r->print('<p><pre>'); |
my $index; |
my $index; |
for ($index=0;$index<=$#students;$index++) { |
for ($index=0;$index<=$#students;$index++) { |
# $r->print( |
|
# substr($students[$index]. |
|
# ' ',0,14).' ! '. |
|
# substr($rowlabels[$index]. |
|
# ' ',0,45).' ! '); |
|
# map { |
|
# if ($_) { |
|
# $r->print(&astatus($_,$students[$index])); |
|
# } else { |
|
# $r->print(' ! '); |
|
# } |
|
# } @cols; |
|
# $r->print("\n"); |
|
$r->print(&ExtractStudentData($index,$cid).'<br>'); |
$r->print(&ExtractStudentData($index,$cid).'<br>'); |
$r->rflush(); |
$r->rflush(); |
} |
} |