Diff for /loncom/interface/lonnavmaps.pm between versions 1.9 and 1.10

version 1.9, 2001/01/30 00:35:24 version 1.10, 2001/01/30 19:31:32
Line 9 Line 9
 # 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 Gerd Kortemeyer  # 3/1/1,6/1,17/1,29/1,30/1 Gerd Kortemeyer
   
 package Apache::lonnavmaps;  package Apache::lonnavmaps;
   
Line 23  use GDBM_File; Line 23  use GDBM_File;
 my %hash;  my %hash;
 my @rows;  my @rows;
   
   #
   # These cache hashes need to be independent of user, resource and course
   # (user and course can/should be in the keys)
   #
   
   my %courserdatas;
   my %userrdatas;
   
   #
   # These global hashes are dependent on user, course and resource, 
   # and need to be initialized every time when a sheet is calculated
   #
   my %courseopt;
   my %useropt;
   my %parmhash;
   
   
 # ------------------------------------------------------------------ Euclid gcd  # ------------------------------------------------------------------ Euclid gcd
   
 sub euclid {  sub euclid {
Line 36  sub euclid { Line 53  sub euclid {
     return $b;      return $b;
 }  }
   
   # --------------------------------------------------------------------- Parmval
   
   # -------------------------------------------- Figure out a cascading parameter
   #
   # For this function to work
   #
   # * parmhash needs to be tied
   # * courseopt and useropt need to be initialized for this user and course
   #
   
   sub parmval {
       my ($what,$symb)=@_;
       my $cid=$ENV{'request.course.id'};
       my $csec=$ENV{'request.course.sec'};
       my $uname=$ENV{'user.name'};
       my $udom=$ENV{'user.domain'};
   
       unless ($symb) { return ''; }
       my $result='';
   
       my ($mapname,$id,$fn)=split(/\_\_\_/,$symb);
   
   # ----------------------------------------------------- Cascading lookup scheme
          my $rwhat=$what;
          $what=~s/^parameter\_//;
          $what=~s/\_/\./;
   
          my $symbparm=$symb.'.'.$what;
          my $mapparm=$mapname.'___(all).'.$what;
          my $usercourseprefix=$uname.'_'.$udom.'_'.$cid;
   
          my $seclevel=
               $usercourseprefix.'.['.
    $csec.'].'.$what;
          my $seclevelr=
               $usercourseprefix.'.['.
    $csec.'].'.$symbparm;
          my $seclevelm=
               $usercourseprefix.'.['.
    $csec.'].'.$mapparm;
   
          my $courselevel=
               $usercourseprefix.'.'.$what;
          my $courselevelr=
               $usercourseprefix.'.'.$symbparm;
          my $courselevelm=
               $usercourseprefix.'.'.$mapparm;
   
   # ---------------------------------------------------------- fourth, check user
         
         if ($uname) { 
   
          if ($useropt{$courselevelr}) { return $useropt{$courselevelr}; }
   
          if ($useropt{$courselevelm}) { return $useropt{$courselevelm}; }
   
          if ($useropt{$courselevel}) { return $useropt{$courselevel}; }
   
         }
   
   # --------------------------------------------------------- third, check course
        
          if ($csec) {
    
           if ($courseopt{$seclevelr}) { return $courseopt{$seclevelr}; }
   
           if ($courseopt{$seclevelm}) { return $courseopt{$seclevelm}; }  
   
           if ($courseopt{$seclevel}) { return $courseopt{$seclevel}; }
     
         }
   
          if ($courseopt{$courselevelr}) { return $courseopt{$courselevelr}; }
   
          if ($courseopt{$courselevelm}) { return $courseopt{$courselevelm}; }
   
          if ($courseopt{$courselevel}) { return $courseopt{$courselevel}; }
   
   # ----------------------------------------------------- second, check map parms
   
          my $thisparm=$parmhash{$symbparm};
          if ($thisparm) { return $thisparm; }
   
   # -------------------------------------------------------- first, check default
   
          return &Apache::lonnet::metadata($fn,$rwhat.'.default');
           
   }
   
   
   
 # ------------------------------------------------------------- Find out status  # ------------------------------------------------------------- Find out status
   
 sub astatus {  sub astatus {
Line 43  sub astatus { Line 151  sub astatus {
     my $code=1;      my $code=1;
     my $ctext='';      my $ctext='';
     $rid=~/(\d+)\.(\d+)/;      $rid=~/(\d+)\.(\d+)/;
     my $symb=&Apache::lonnet::escape(      my $symb=&Apache::lonnet::declutter($hash{'map_id_'.$1}).'___'.$2.'___'.
              &Apache::lonnet::declutter($hash{'map_id_'.$1}).'___'.$2.'___'.       &Apache::lonnet::declutter($hash{'src_'.$rid});
      &Apache::lonnet::declutter($hash{'src_'.$rid}));      my $duedate=&parmval('0.duedate',$symb);
       if ($duedate) {
          $ctext.='Due: '.localtime($duedate);
       }
     my $answer=&Apache::lonnet::reply(      my $answer=&Apache::lonnet::reply(
               "restore:$ENV{'user.domain'}:$ENV{'user.name'}:".                "restore:$ENV{'user.domain'}:$ENV{'user.name'}:".
               $ENV{'request.course.id'}.":$symb",                $ENV{'request.course.id'}.':'.
                 &Apache::lonnet::escape($symb),
               "$ENV{'user.home'}");                "$ENV{'user.home'}");
     my %returnhash=();      my %returnhash=();
     map {      map {
Line 66  sub astatus { Line 178  sub astatus {
        map {         map {
            if (($_=~/\.(\w+)\.solved$/) && ($_!~/^\d+\:/)) {             if (($_=~/\.(\w+)\.solved$/) && ($_!~/^\d+\:/)) {
                my $part=$1;                 my $part=$1;
                  if ($ctext) { $ctext.=', '; }
                  if ($part) {
      $ctext.='Part '.$part.': ';
                  }
        if ($returnhash{$_} eq 'correct_by_student') {         if ($returnhash{$_} eq 'correct_by_student') {
                    unless ($code==2) { $code=3; }                     unless ($code==2) { $code=3; }
                    $ctext.='Part '.$part.': solved';                     $ctext.='solved';
                } elsif ($returnhash{$_} eq 'correct_by_override') {                 } elsif ($returnhash{$_} eq 'correct_by_override') {
                    unless ($code==2) { $code=3; }                     unless ($code==2) { $code=3; }
                    $ctext.='Part '.$part.': override';                     $ctext.='override';
                } elsif ($returnhash{$_} eq 'incorrect_attempted') {                 } elsif ($returnhash{$_} eq 'incorrect_attempted') {
                    $code=2;                     $code=2;
                    $ctext.='Part '.$part.': '.                     $ctext.=
                      $returnhash{'resource.'.$part.'.tries'}.' attempt(s)';                       $returnhash{'resource.'.$part.'.tries'}.' attempt(s)';
                } elsif ($returnhash{$_} eq 'incorrect_by_override') {                 } elsif ($returnhash{$_} eq 'incorrect_by_override') {
                    $code=2;                     $code=2;
                    $ctext.='Part '.$part.': override';                     $ctext.='override';
                } elsif ($returnhash{$_} eq 'excused') {                 } elsif ($returnhash{$_} eq 'excused') {
                    unless ($code==2) { $code=3; }                     unless ($code==2) { $code=3; }
                    $ctext.='Part '.$part.': excused';                     $ctext.='excused';
                }                 }
            }             }
        } keys %returnhash;         } keys %returnhash;
Line 204  sub handler { Line 320  sub handler {
   if ($ENV{'request.course.fn'}) {    if ($ENV{'request.course.fn'}) {
       my $fn=$ENV{'request.course.fn'};        my $fn=$ENV{'request.course.fn'};
       if (-e "$fn.db") {        if (-e "$fn.db") {
           if (tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER,0640)) {            if ((tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER,0640)) &&
                (tie(%parmhash,'GDBM_File',
              $ENV{'request.course.fn'}.'_parms.db',&GDBM_READER,0640))) {
 # ------------------------------------------------------------------- Hash tied  # ------------------------------------------------------------------- Hash tied
               my $firstres=$hash{'map_start_/res/'.$ENV{'request.course.uri'}};                my $firstres=$hash{'map_start_/res/'.$ENV{'request.course.uri'}};
               my $lastres=$hash{'map_finish_/res/'.$ENV{'request.course.uri'}};                my $lastres=$hash{'map_finish_/res/'.$ENV{'request.course.uri'}};
               if (($firstres) && ($lastres)) {                if (($firstres) && ($lastres)) {
 # ----------------------------------------------------------------- Render page  # ----------------------------------------------------------------- Render page
   # -------------------------------------------------------------- Set parameters
   
   
   # ---------------------------- initialize coursedata and userdata for this user
       undef %courseopt;
       undef %useropt;
   
       my $uname=$ENV{'user.name'};
       my $udom=$ENV{'user.domain'};
       my $uhome=$ENV{'user.home'};
       my $cid=$ENV{'request.course.id'};
       my $chome=$ENV{'course.'.$cid.'.home'};
       my ($cdom,$cnum)=split(/\_/,$cid);
   
       my $userprefix=$uname.'_'.$udom.'_';
   
       unless ($uhome eq 'no_host') { 
   # -------------------------------------------------------------- Get coursedata
         unless
           ((time-$courserdatas{$cid.'.last_cache'})<240) {
            my $reply=&Apache::lonnet::reply('dump:'.$cdom.':'.$cnum.
                 ':resourcedata',$chome);
            if ($reply!~/^error\:/) {
               $courserdatas{$cid}=$reply;
               $courserdatas{$cid.'.last_cache'}=time;
            }
         }
         map {
            my ($name,$value)=split(/\=/,$_);
            $courseopt{$userprefix.&Apache::lonnet::unescape($name)}=
                       &Apache::lonnet::unescape($value);
         } split(/\&/,$courserdatas{$cid});
   # --------------------------------------------------- Get userdata (if present)
         unless
           ((time-$userrdatas{$uname.'___'.$udom.'.last_cache'})<240) {
            my $reply=
          &Apache::lonnet::reply('dump:'.$udom.':'.$uname.':resourcedata',$uhome);
            if ($reply!~/^error\:/) {
        $userrdatas{$uname.'___'.$udom}=$reply;
        $userrdatas{$uname.'___'.$udom.'.last_cache'}=time;
            }
         }
         map {
            my ($name,$value)=split(/\=/,$_);
            $useropt{$userprefix.&Apache::lonnet::unescape($name)}=
             &Apache::lonnet::unescape($value);
         } split(/\&/,$userrdatas{$uname.'___'.$udom});
       }
   
                   @rows=();                    @rows=();
   
Line 245  sub handler { Line 411  sub handler {
                       $r->send_http_header;                        $r->send_http_header;
                       $r->print('<html><body>Empty Map.</body></html>');                        $r->print('<html><body>Empty Map.</body></html>');
                   } else {                    } else {
   
 # ------------------------------------------------------------------ Build page  # ------------------------------------------------------------------ Build page
   
 # ---------------------------------------------------------------- Send headers  # ---------------------------------------------------------------- Send headers
Line 277  sub handler { Line 444  sub handler {
                                   $add='<th bgcolor="#AAFF55">';                                    $add='<th bgcolor="#AAFF55">';
                                   $adde='</th>';                                    $adde='</th>';
                               }                                }
                               if ($rid=~/^p(\d)\"([\w\: \(\)]*)\"(.+)/) {                                if ($rid=~/^p(\d)\"([\w\: \(\)\,]*)\"(.+)/) {
                                   my $code=$1;                                    my $code=$1;
                                   my $ctext=$2;                                    my $ctext=$2;
                                   $rid=$3;                                    $rid=$3;
                                   $hwk='<font color="#888811"><b>';                                    $hwk='<font color="#888811"><b>';
                                   $hwke='</b></font>';                                    $hwke='</b></font>';
                                     if ($code eq '1') {
                                        $hwke='</b> ('.$ctext.')</font>';
                                     }
                                   if ($code eq '2') {                                    if ($code eq '2') {
                                      $hwk='<font color="#992222"><b>';                                       $hwk='<font color="#992222"><b>';
                                      $hwke='</b> ('.$ctext.')</font>';                                       $hwke='</b> ('.$ctext.')</font>';
Line 315  sub handler { Line 485  sub handler {
                    &Apache::lonnet::logthis("<font color=blue>WARNING: ".                     &Apache::lonnet::logthis("<font color=blue>WARNING: ".
                        "Could not untie coursemap $fn (browse).</font>");                          "Could not untie coursemap $fn (browse).</font>"); 
               }                }
                 unless (untie(%parmhash)) {
                      &Apache::lonnet::logthis("<font color=blue>WARNING: ".
                          "Could not untie parmhash (browse).</font>"); 
                 }
 # -------------------------------------------------------------------- All done  # -------------------------------------------------------------------- All done
       return OK;        return OK;
 # ----------------------------------------------- Errors, hash could no be tied  # ----------------------------------------------- Errors, hash could no be tied

Removed from v.1.9  
changed lines
  Added in v.1.10


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