Diff for /loncom/homework/structuretags.pm between versions 1.158 and 1.159

version 1.158, 2003/04/02 20:52:25 version 1.159, 2003/04/03 14:31:58
Line 38  use Apache::File(); Line 38  use Apache::File();
 use Apache::lonmenu;  use Apache::lonmenu;
   
 BEGIN {  BEGIN {
   &Apache::lonxml::register('Apache::structuretags',('block','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext'));      &Apache::lonxml::register('Apache::structuretags',('block','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext'));
 #  &Apache::lonxml::register_insert('problem','',('part','postanswerdate','preduedate'))  
 }  }
   
 sub start_web {  sub start_web {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $bodytext=&Apache::lonxml::get_all_text("/web",$parser);      my $bodytext=&Apache::lonxml::get_all_text("/web",$parser);
   if ($target eq 'web') {      if ($target eq 'web') {
     return $bodytext;   return $bodytext;
   }       }
   return '';      return '';
 }  }
   
 sub end_web {  sub end_web {
Line 56  sub end_web { Line 55  sub end_web {
 }  }
   
 sub start_tex {  sub start_tex {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $bodytext=&Apache::lonxml::get_all_text("/tex",$parser);      my $bodytext=&Apache::lonxml::get_all_text("/tex",$parser);
   if ($target eq 'tex') {      if ($target eq 'tex') {
       return $bodytext.' ';   return $bodytext.' ';
   }      }
   return '';      return '';
 }  }
   
 sub end_tex {  sub end_tex {
Line 69  sub end_tex { Line 68  sub end_tex {
 }  }
   
 sub page_start {  sub page_start {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my %found;      my %found;
   foreach my $taginside ($tagstack) {      foreach my $taginside ($tagstack) {
     foreach my $taglookedfor ('html','body','form') {   foreach my $taglookedfor ('html','body','form') {
       if ($taginside =~ /^$taglookedfor$/i) { $found{$taglookedfor} = 1; }      if ($taginside =~ /^$taglookedfor$/i) {$found{$taglookedfor} = 1;}
     }   }
   }      }
   
   my $result;      my $result;
   my $head_tag_start;      my $head_tag_start;
   if (!defined($found{'html'})) {      if (!defined($found{'html'})) {
     $result=&Apache::londefdef::start_html($target,$token,$tagstack,$parstack,   $result=&Apache::londefdef::start_html($target,$token,$tagstack,
    $parser,$safeeval);         $parstack,$parser,$safeeval);
     $head_tag_start='<head>'.&Apache::lonmenu::registerurl(undef,$target);   $head_tag_start='<head>'.&Apache::lonmenu::registerurl(undef,$target);
   }      }
   my $body_tag_start;      my $body_tag_start;
   if (!defined($found{'body'})) {      if (!defined($found{'body'})) {
     $body_tag_start='<body onLoad="'.&Apache::lonmenu::loadevents().'" '.   $body_tag_start='<body onLoad="'.&Apache::lonmenu::loadevents().'" '.
       'onUnload="'.&Apache::lonmenu::unloadevents().'" ';      'onUnload="'.&Apache::lonmenu::unloadevents().'" ';
     my $background=&Apache::lonxml::get_param('background',$parstack,$safeeval);   my $background=&Apache::lonxml::get_param('background',$parstack,
     if ($background) {    $safeeval);
       $Apache::lonxml::extlinks[$#Apache::lonxml::extlinks+1]=   if ($background) {
  $background;      $Apache::lonxml::extlinks[$#Apache::lonxml::extlinks+1]=
       $body_tag_start.='background="'.$background.'" ';   $background;
     } else {      $body_tag_start.='background="'.$background.'" ';
       my $bgcolor=&Apache::lonxml::get_param('bgcolor',$parstack,$safeeval);   } else {
       if ($bgcolor) {      my $bgcolor=&Apache::lonxml::get_param('bgcolor',$parstack,
  $body_tag_start.='bgcolor="'.$bgcolor.'" ';     $safeeval);
       } else {      if ($bgcolor) {
  $body_tag_start.='bgcolor="#ffffff"';   $body_tag_start.='bgcolor="'.$bgcolor.'" ';
       }      } else {
     }   $body_tag_start.='bgcolor="#ffffff"';
     $body_tag_start.='>'.&Apache::lonmenu::menubuttons(undef,$target,1);      }
     if ($target eq 'web' && $ENV{'request.state'} ne 'construct') {   }
  my ($symb)=&Apache::lonxml::whichuser();   $body_tag_start.='>'.&Apache::lonmenu::menubuttons(undef,$target,1);
  if ($symb eq '') {   if ($target eq 'web' && $ENV{'request.state'} ne 'construct') {
     my $help = &Apache::loncommon::help_open_topic("Ambiguous_Reference");      my ($symb)=&Apache::lonxml::whichuser();
     $help="Browsing or <a href=\"/adm/ambiguous\">ambiguous</a> reference, submissions ignored $help<br />";      if ($symb eq '') {
     $body_tag_start.=$help;   my $help = &Apache::loncommon::help_open_topic("Ambiguous_Reference");
  }   $help="Browsing or <a href=\"/adm/ambiguous\">ambiguous</a> reference, submissions ignored $help<br />";
     }   $body_tag_start.=$help;
   }      }
   my $form_tag_start;   }
   if (!defined($found{'form'})) {      }
     $form_tag_start='<form name="lonhomework" method="POST" action="'.      my $form_tag_start;
       $ENV{'request.uri'}.'">';      if (!defined($found{'form'})) {
   }   $form_tag_start='<form name="lonhomework" method="POST" action="'.
   return ($result,$head_tag_start,$body_tag_start,$form_tag_start);      $ENV{'request.uri'}.'">';
       }
       return ($result,$head_tag_start,$body_tag_start,$form_tag_start);
 }  }
   
 #use Time::HiRes();  #use Time::HiRes();
 sub get_resource_name {  sub get_resource_name {
   my ($parstack,$safeeval)=@_;      my ($parstack,$safeeval)=@_;
   my $name=&Apache::lonnet::gettitle();      my $name=&Apache::lonnet::gettitle();
   if ($name eq '') {      if ($name eq '') {
     $name=&Apache::lonnet::EXT('resource.title');   $name=&Apache::lonnet::EXT('resource.title');
     if ($name eq 'con_lost') { $name = ''; }   if ($name eq 'con_lost') { $name = ''; }
   }      }
   $Apache::lonhomework::name=$name;      $Apache::lonhomework::name=$name;
   return $name;      return $name;
 }  }
   
 sub setup_rndseed {  sub setup_rndseed {
   my ($safeeval)=@_;      my ($safeeval)=@_;
   my $rndseed;      my $rndseed;
   if ($ENV{'request.state'} eq "construct") {      if ($ENV{'request.state'} eq "construct") {
     $rndseed=$ENV{'form.rndseed'};   $rndseed=$ENV{'form.rndseed'};
     if (!$rndseed) {   if (!$rndseed) {
       $rndseed=time;      $rndseed=time;
       $ENV{'form.rndseed'}=$rndseed;      $ENV{'form.rndseed'}=$rndseed;
     }   }
     &Apache::lonxml::debug("Setting rndseed to $rndseed");   &Apache::lonxml::debug("Setting rndseed to $rndseed");
     &Apache::run::run('$external::randomseed='.$rndseed.';',$safeeval);   &Apache::run::run('$external::randomseed='.$rndseed.';',$safeeval);
   }      }
   return $rndseed;      return $rndseed;
 }  }
   
 sub problem_edit_header {  sub problem_edit_header {
   return '<input type="hidden" name="submitted" value="edit" />      return '<input type="hidden" name="submitted" value="edit" />
        <input type="hidden" name="problemmode" value="Edit" />         <input type="hidden" name="problemmode" value="Edit" />
        <input type="submit" name="problemmode" value="Discard Edits and View" />         <input type="submit" name="problemmode" value="Discard Edits and View" />
        <input type="submit" name="problemmode" value="EditXML" />         <input type="submit" name="problemmode" value="EditXML" />
Line 158  sub problem_edit_header { Line 159  sub problem_edit_header {
 }  }
   
 sub problem_edit_footer {  sub problem_edit_footer {
   return '</td></tr></table><br /><input type="submit" name="submit" value="Submit Changes and Edit" />      return '</td></tr></table><br /><input type="submit" name="submit" value="Submit Changes and Edit" />
     <input type="submit" name="submit" value="Submit Changes and View" />';      <input type="submit" name="submit" value="Submit Changes and View" />';
 }  }
   
 sub problem_web_to_edit_header {  sub problem_web_to_edit_header {
   my ($rndseed)=@_;      my ($rndseed)=@_;
   my $result.='<input type="hidden" name="problemmode" value="View" />      my $result.='<input type="hidden" name="problemmode" value="View" />
              <input type="submit" name="problemmode" value="Edit" />               <input type="submit" name="problemmode" value="Edit" />
              <input type="submit" name="problemmode" value="EditXML" />               <input type="submit" name="problemmode" value="EditXML" />
              Random Seed:<input type="text" name="rndseed" width="10" value="'.               Random Seed:<input type="text" name="rndseed" width="10" value="'.
Line 172  sub problem_web_to_edit_header { Line 173  sub problem_web_to_edit_header {
              <input type="submit" name="changerandseed" value="Change" />               <input type="submit" name="changerandseed" value="Change" />
              <input type="submit" name="resetdata" value="Reset Submissions" />               <input type="submit" name="resetdata" value="Reset Submissions" />
              <input type="checkbox" name="showallfoils" ';               <input type="checkbox" name="showallfoils" ';
   if (defined($ENV{'form.showallfoils'})) { $result.='checked="on"'; }      if (defined($ENV{'form.showallfoils'})) { $result.='checked="on"'; }
   $result.= ' />&nbsp;Show&nbsp;All&nbsp;Foils      $result.= ' />&nbsp;Show&nbsp;All&nbsp;Foils
              <hr />';               <hr />';
   my $numtoanalyze=$ENV{'form.numtoanalyze'};      my $numtoanalyze=$ENV{'form.numtoanalyze'};
   if (!$numtoanalyze) { $numtoanalyze=100; }      if (!$numtoanalyze) { $numtoanalyze=100; }
   $result.= '<input type="submit" name="problemmode" value="Answer Distribution" />      $result.= '<input type="submit" name="problemmode" value="Answer Distribution" />
              <input type="text" name="numtoanalyze" value="'.               <input type="text" name="numtoanalyze" value="'.
        $numtoanalyze.'" size="5" /> <hr />';   $numtoanalyze.'" size="5" /> <hr />';
   return $result;      return $result;
 }  }
   
 sub initialize_storage {  sub initialize_storage {
   %Apache::lonhomework::results=();      %Apache::lonhomework::results=();
   my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser();      my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser();
   if ($ENV{'request.state'} eq 'construct') {      if ($ENV{'request.state'} eq 'construct') {
     %Apache::lonhomework::history=   %Apache::lonhomework::history=
       &Apache::lonnet::tmprestore($ENV{'request.uri'},'',$domain,$name);      &Apache::lonnet::tmprestore($ENV{'request.uri'},'',$domain,$name);
    my ($temp)=keys %Apache::lonhomework::history ;
    &Apache::lonxml::debug("Return message of $temp");
       } else {
    %Apache::lonhomework::history=
       &Apache::lonnet::restore($symb,$courseid,$domain,$name);
       }
       #ignore error conditions
     my ($temp)=keys %Apache::lonhomework::history ;      my ($temp)=keys %Apache::lonhomework::history ;
     &Apache::lonxml::debug("Return message of $temp");      if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); }
   } else {  
     %Apache::lonhomework::history=  
       &Apache::lonnet::restore($symb,$courseid,$domain,$name);  
   }  
   #ignore error conditions  
   my ($temp)=keys %Apache::lonhomework::history ;  
   if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); }  
 }  }
   
 # -------------------------------------------------------------finalize_storage  # -------------------------------------------------------------finalize_storage
Line 205  sub initialize_storage { Line 206  sub initialize_storage {
 # checks form.grade_ for specific values, other wises stores  # checks form.grade_ for specific values, other wises stores
 # to the running users environment  # to the running users environment
 sub finalize_storage {  sub finalize_storage {
   my $result;      my $result;
   my ($temp) = keys %Apache::lonhomework::results;      my ($temp) = keys %Apache::lonhomework::results;
   if ( $temp ne '' ) {      if ( $temp ne '' ) {
     my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser();   my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser();
     if ($ENV{'request.state'} eq 'construct') {   if ($ENV{'request.state'} eq 'construct') {
       $result=&Apache::lonnet::tmpstore(\%Apache::lonhomework::results,      $result=&Apache::lonnet::tmpstore(\%Apache::lonhomework::results,
       $ENV{'request.uri'},'',$domain,$name);   $ENV{'request.uri'},'',$domain,$name);
       &Apache::lonxml::debug('Construct Store return message:'.$result);      &Apache::lonxml::debug('Construct Store return message:'.$result);
     } else {   } else {
       $result=&Apache::lonnet::cstore(\%Apache::lonhomework::results,      $result=&Apache::lonnet::cstore(\%Apache::lonhomework::results,
       $symb,$courseid,$domain,$name);      $symb,$courseid,$domain,$name);
       &Apache::lonxml::debug('Store return message:'.$result);      &Apache::lonxml::debug('Store return message:'.$result);
    }
     }      }
   }      return $result;
   return $result;  
 }  }
   
 sub checkout_msg {  sub checkout_msg {
 return (<<ENDCHECKOUT);      return (<<ENDCHECKOUT);
 <h2>The resource needs to be checked out</h2>  <h2>The resource needs to be checked out</h2>
 As a resource gets checked out, a unique timestamped ID is given to it, and a  As a resource gets checked out, a unique timestamped ID is given to it, and a
 permanent record is left in the system.<p />  permanent record is left in the system.<p />
Line 239  ENDCHECKOUT Line 240  ENDCHECKOUT
 }  }
   
 sub start_problem {  sub start_problem {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   
   $Apache::lonhomework::parsing_a_problem=1;      $Apache::lonhomework::parsing_a_problem=1;
   # meta is called from lonpublisher, which doesn't uses the normal      # meta is called from lonpublisher, which doesn't uses the normal
   # lonhomework method of parsing the file which means that inputtags       # lonhomework method of parsing the file which means that inputtags 
   # won't get reset      # won't get reset
   if ( $Apache::inputtags::part ne '' && $target != 'meta' ) {      if ( $Apache::inputtags::part ne '' && $target != 'meta' ) {
     &Apache::lonxml::error('Only one problem allowed in a .problem file');   &Apache::lonxml::error('Only one problem allowed in a .problem file');
     my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);   my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);
     return '';   return '';
   }  
 #intialize globals  
   $Apache::inputtags::part='0';  
   @Apache::inputtags::responselist = ();  
   @Apache::inputtags::previous=();  
   @Apache::inputtags::previous_version=();  
   $Apache::structuretags::printanswer='No';  
   if ($target ne 'analyze') {  
     &initialize_storage();  
     if ($target eq 'web') {  
       &Apache::lonhomework::showhash(%Apache::lonhomework::history);  
     }      }
     $Apache::lonhomework::type=&Apache::lonnet::EXT('resource.0.type');  #intialize globals
     &Apache::lonxml::debug("Found this to be of type :$Apache::lonhomework::type:");      $Apache::inputtags::part='0';
   }      @Apache::inputtags::responselist = ();
   if ($Apache::lonhomework::type eq '') {      @Apache::inputtags::previous=();
     my $uri=$ENV{'request.uri'};      @Apache::inputtags::previous_version=();
     if ($uri=~/\.(\w+)$/) {      $Apache::structuretags::printanswer='No';
       $Apache::lonhomework::type=$1;      if ($target ne 'analyze') {
       &Apache::lonxml::debug("Using type of $1");   &initialize_storage();
     } else {   if ($target eq 'web') {
       $Apache::lonhomework::type='problem';      &Apache::lonhomework::showhash(%Apache::lonhomework::history);
       &Apache::lonxml::debug("Using default type, problem, :$uri:");   }
    $Apache::lonhomework::type=&Apache::lonnet::EXT('resource.0.type');
    &Apache::lonxml::debug("Found this to be of type :$Apache::lonhomework::type:");
       }
       if ($Apache::lonhomework::type eq '') {
    my $uri=$ENV{'request.uri'};
    if ($uri=~/\.(\w+)$/) {
       $Apache::lonhomework::type=$1;
       &Apache::lonxml::debug("Using type of $1");
    } else {
       $Apache::lonhomework::type='problem';
       &Apache::lonxml::debug("Using default type, problem, :$uri:");
    }
     }      }
   }  
   
   #added vars to the scripting enviroment      #added vars to the scripting enviroment
   my $expression='$external::part='.$Apache::inputtags::part.';';      my $expression='$external::part='.$Apache::inputtags::part.';';
   &Apache::run::run($expression,$safeeval);  
   my $status;  
   my $accessmsg;  
   
   #should get back a <html> or the neccesary stuff to start XML/MathML  
   my ($result,$head_tag_start,$body_tag_start,$form_tag_start)=  
     &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);  
   if ($target eq 'tex' and $ENV{'request.symb'} =~ m/\.page_/) { $result = '';}  
   
   if ($target eq 'analyze') { my $rndseed=&setup_rndseed($safeeval); }  
   if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') {  
     #handle exam checkout  
     if ($Apache::lonhomework::type eq 'exam') {  
       my $token=$Apache::lonhomework::history{"resource.0.outtoken"};  
       if (($ENV{'form.doescheckout'}) && (!$token)) {  
  $token=&Apache::lonxml::maketoken();  
  $Apache::lonhomework::history{"resource.0.outtoken"}=$token;  
       }  
       $body_tag_start.=&Apache::lonxml::printtokenheader($target,$token);  
     }  
   
     #handle rand seed in construction space  
     my $rndseed=&setup_rndseed($safeeval);  
     ($status,$accessmsg) = &Apache::lonhomework::check_access('0');  
     push (@Apache::inputtags::status,$status);  
     my $expression='$external::datestatus="'.$status.'";';  
     $expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.0.solved"}.'";';  
     &Apache::run::run($expression,$safeeval);      &Apache::run::run($expression,$safeeval);
     &Apache::lonxml::debug("Got $status");      my $status;
     if (( $status eq 'CLOSED' ) ||      my $accessmsg;
         ( $status eq 'UNCHECKEDOUT') ||  
         ( $status eq 'BANNED') ||      #should get back a <html> or the neccesary stuff to start XML/MathML
         ( $status eq 'UNAVAILABLE')) {      my ($result,$head_tag_start,$body_tag_start,$form_tag_start)=
       my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);   &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);
       if ( $target eq "web" ) {      if ($target eq 'tex' and $ENV{'request.symb'} =~ m/\.page_/) {$result='';}
  $result.= $head_tag_start.'</head>';  
         my $msg=$body_tag_start;      if ($target eq 'analyze') { my $rndseed=&setup_rndseed($safeeval); }
  if ($status eq 'UNAVAILABLE') {      if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||
     $result.='<h1>Unable to determine if this resource is open due to network problems. Please try again later.</h1>';   $target eq 'tex') {
  } else {   #handle exam checkout
     $result.='<h1>Not open to be viewed</h1>';   if ($Apache::lonhomework::type eq 'exam') {
  }      my $token=
         if ($status eq 'CLOSED') {   $Apache::lonhomework::history{"resource.0.outtoken"};
     $msg.='The problem '.$accessmsg;      if (($ENV{'form.doescheckout'}) && (!$token)) {
  } elsif ($status eq 'UNCHECKEDOUT') {   $token=&Apache::lonxml::maketoken();
             $msg.=&checkout_msg;   $Apache::lonhomework::history{"resource.0.outtoken"}=
         }      $token;
  $result.=$msg.'<br />';      }
       } elsif ($target eq 'tex') {      $body_tag_start.=&Apache::lonxml::printtokenheader($target,$token);
   $result.='\begin{document}\noindent \vskip 1 mm  \begin{minipage}{\textwidth}\vskip 0 mm';  
  if ($status eq 'UNAVAILABLE') {  
     $result.='Unable to determine if this resource is open due to network problems. Please try again later.\vskip 0 mm ';  
  } else {  
     $result.="Problem is not open to be viewed. It $accessmsg \\vskip 0 mm ";  
  }  
       }  
     } elsif ($target eq 'web') {  
       my $name= &get_resource_name($parstack,$safeeval);  
       if ($status eq 'CAN_ANSWER') {  
  # create a page header and exit  
  $result.="$head_tag_start<title>$name</title></head>  
               $body_tag_start \n $form_tag_start".  
  '<input type="hidden" name="submitted" value="yes" />';  
  if ($ENV{'request.state'} eq "construct") {  
   $result.= &problem_web_to_edit_header($rndseed);  
  }  
  # if we are viewing someone else preserve that info  
  if (defined $ENV{'form.grade_symb'}) {  
   foreach my $field ('symb','courseid','domain','username') {  
     $result .= '<input type="hidden" name="grade_'.$field.  
       '" value="'.$ENV{"form.grade_$field"}.'" />'."\n";  
   }  
  }  
       } elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER'  
        || $status eq 'CLOSED' || $status eq 'UNAVALAILABLE') {  
  $result.=$head_tag_start.  
   "<title>$name</title></head>\n$body_tag_start\n";  
       }  
     } elsif ($target eq 'tex') {  
  my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval);  
  if ($name eq '') {   
     $name=&Apache::lonnet::EXT('resource.title');  
     if ($name eq 'con_lost') { $name = ''; }  
  }  
  $Apache::lonhomework::name=$name;  
  my $id = $Apache::inputtags::part;  
  my $weight = &Apache::lonnet::EXT("resource.$id.weight");  
  my $allkeys = &Apache::lonnet::metadata($ENV{'request.uri'},'keys');  
  my @allkeys = split /,/,$allkeys;  
         my $allow_print_points = 0;  
  foreach my $partial_key (@allkeys) {  
     if ($partial_key=~m/weight/) {  
  $allow_print_points++;  
     }  
  }  
  my $duedate = &Apache::lonnet::EXT("resource.$id.duedate");   
  $duedate = POSIX::strftime("%c",localtime($duedate));  
  my $temp_file;  
  my $filename = "/home/httpd/prtspool/$ENV{'user.name'}_$ENV{'user.domain'}_printout.due";  
         if (-e $filename) {  
     $temp_file = Apache::File->new($filename);   
  } else {  
     $temp_file = Apache::File->new('>>'.$filename);   
  }   }
  my @due_file_content = <$temp_file>;  
  my $due_file_content = $due_file_content[$#due_file_content];   #handle rand seed in construction space
         chomp $due_file_content;   my $rndseed=&setup_rndseed($safeeval);
  my $name_of_resourse= &get_resource_name($parstack,$safeeval);   ($status,$accessmsg) = &Apache::lonhomework::check_access('0');
         if ($due_file_content ne $duedate) {       push (@Apache::inputtags::status,$status);
  $temp_file = Apache::File->new('>'.$filename);    my $expression='$external::datestatus="'.$status.'";';
     print $temp_file "$duedate\n";       $expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.0.solved"}.'";';
     if (not $ENV{'request.symb'} =~ m/\.page_/) {   &Apache::run::run($expression,$safeeval);
  if(not $duedate=~m/1969/ and $Apache::lonhomework::type ne 'exam') {   &Apache::lonxml::debug("Got $status");
     $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent\textit{Due date: '.$duedate.'} \vskip 1 mm\noindent \begin{minipage}{\textwidth}';   if (( $status eq 'CLOSED' ) ||
       ( $status eq 'UNCHECKEDOUT') ||
       ( $status eq 'BANNED') ||
       ( $status eq 'UNAVAILABLE')) {
       my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);
       if ( $target eq "web" ) {
    $result.= $head_tag_start.'</head>';
    my $msg=$body_tag_start;
    if ($status eq 'UNAVAILABLE') {
       $result.='<h1>Unable to determine if this resource is open due to network problems. Please try again later.</h1>';
  } else {   } else {
     $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm \noindent\begin{minipage}{\textwidth}';      $result.='<h1>Not open to be viewed</h1>';
     if ($Apache::lonhomework::type eq 'exam' and $allow_print_points==1) { $result .= '\fbox{\textit{'.$weight.' pt}}';}   }
    if ($status eq 'CLOSED') {
       $msg.='The problem '.$accessmsg;
    } elsif ($status eq 'UNCHECKEDOUT') {
       $msg.=&checkout_msg;
    }
    $result.=$msg.'<br />';
       } elsif ($target eq 'tex') {
    $result.='\begin{document}\noindent \vskip 1 mm  \begin{minipage}{\textwidth}\vskip 0 mm';
    if ($status eq 'UNAVAILABLE') {
       $result.='Unable to determine if this resource is open due to network problems. Please try again later.\vskip 0 mm ';
    } else {
       $result.="Problem is not open to be viewed. It $accessmsg \\vskip 0 mm ";
    }
       }
    } elsif ($target eq 'web') {
       my $name= &get_resource_name($parstack,$safeeval);
       if ($status eq 'CAN_ANSWER') {
    # create a page header and exit
    $result.="$head_tag_start<title>$name</title></head>
                 $body_tag_start \n $form_tag_start".
     '<input type="hidden" name="submitted" value="yes" />';
    if ($ENV{'request.state'} eq "construct") {
       $result.= &problem_web_to_edit_header($rndseed);
    }
    # if we are viewing someone else preserve that info
    if (defined $ENV{'form.grade_symb'}) {
       foreach my $field ('symb','courseid','domain','username') {
    $result .= '<input type="hidden" name="grade_'.$field.
       '" value="'.$ENV{"form.grade_$field"}.'" />'."\n";
       }
    }
       } elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER'
        || $status eq 'CLOSED' || $status eq 'UNAVALAILABLE') {
    $result.=$head_tag_start.
       "<title>$name</title></head>\n$body_tag_start\n";
       }
    } elsif ($target eq 'tex') {
       my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval);
       if ($name eq '') {
    $name=&Apache::lonnet::EXT('resource.title');
    if ($name eq 'con_lost') { $name = ''; }
       }
       $Apache::lonhomework::name=$name;
       my $id = $Apache::inputtags::part;
       my $weight = &Apache::lonnet::EXT("resource.$id.weight");
       my $allkeys=&Apache::lonnet::metadata($ENV{'request.uri'},'keys');
       my @allkeys = split /,/,$allkeys;
       my $allow_print_points = 0;
       foreach my $partial_key (@allkeys) {
    if ($partial_key=~m/weight/) {
       $allow_print_points++;
  }   }
       }
       my $duedate = &Apache::lonnet::EXT("resource.$id.duedate"); 
       $duedate = POSIX::strftime("%c",localtime($duedate));
       my $temp_file;
       my $filename = "/home/httpd/prtspool/$ENV{'user.name'}_$ENV{'user.domain'}_printout.due";
       if (-e $filename) {
    $temp_file = Apache::File->new($filename);
     } else {      } else {
  $result .= '\vskip 1mm\textit{Due date: '.$duedate.'} \\\\\\\\';   $temp_file = Apache::File->new('>>'.$filename);
     }       }
  } else {      my @due_file_content = <$temp_file>;
     if (not $ENV{'request.symb'} =~ m/\.page_/) {      my $due_file_content = $due_file_content[$#due_file_content];
  $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm\noindent\begin{minipage}{\textwidth}';      chomp $due_file_content;
  if (($Apache::lonhomework::type eq 'exam') and ($allow_print_points==1)) { $result .= '\fbox{\textit{'.$weight.' pt}}';}      my $name_of_resourse= &get_resource_name($parstack,$safeeval);
       if ($due_file_content ne $duedate) {
    $temp_file = Apache::File->new('>'.$filename);
    print $temp_file "$duedate\n";
    if (not $ENV{'request.symb'} =~ m/\.page_/) {
       if(not $duedate=~m/1969/ and $Apache::lonhomework::type ne 'exam') {
    $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent\textit{Due date: '.$duedate.'} \vskip 1 mm\noindent \begin{minipage}{\textwidth}';
       } else {
    $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm \noindent\begin{minipage}{\textwidth}';
    if ($Apache::lonhomework::type eq 'exam' and $allow_print_points==1) { $result .= '\fbox{\textit{'.$weight.' pt}}';}
       }
    } else {
       $result .= '\vskip 1mm\textit{Due date: '.$duedate.'} \\\\\\\\';
    }
     } else {      } else {
  $result .= '\vskip 1mm \\\\\\\\';   if (not $ENV{'request.symb'} =~ m/\.page_/) {
     }       $result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm\noindent\begin{minipage}{\textwidth}';
       if (($Apache::lonhomework::type eq 'exam') and ($allow_print_points==1)) { $result .= '\fbox{\textit{'.$weight.' pt}}';}
    } else {
       $result .= '\vskip 1mm \\\\\\\\';
    }
       }
  }   }
       } elsif ($target eq 'edit') {
    $result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start.
       &problem_edit_header();
    my $temp=&Apache::edit::insertlist($target,$token);
    $result.=$temp;
       } elsif ($target eq 'modified') {
    $result=$token->[4];
    $result.=&Apache::edit::handle_insert();
       } else {
    # page_start returned a starting result, delete it if we don't need it
    $result = '';
     }      }
   } elsif ($target eq 'edit') {      return $result;
     $result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start.  
       &problem_edit_header();  
     my $temp=&Apache::edit::insertlist($target,$token);  
     $result.=$temp;  
   } elsif ($target eq 'modified') {  
     $result=$token->[4];  
     $result.=&Apache::edit::handle_insert();  
   } else {  
     # page_start returned a starting result, delete it if we don't need it  
     $result = '';  
   }  
   return $result;  
 }  }
   
 sub end_problem {  sub end_problem {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result='';      my $result='';
   my $status=$Apache::inputtags::status['-1'];      my $status=$Apache::inputtags::status['-1'];
   if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || $target eq 'tex') {      if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' ||
     if ( $target eq 'grade' && $Apache::inputtags::part eq '0' && $status eq 'CAN_ANSWER' ) {   $target eq 'tex') {
       # if part is zero, no <part>s existed, so we need to the grading   if ( $target eq 'grade' && $Apache::inputtags::part eq '0' &&
       &Apache::inputtags::grade;       $status eq 'CAN_ANSWER' ) {
     } elsif ( ($target eq 'web' || $target eq 'tex') && $Apache::inputtags::part eq '0' &&       # if part is zero, no <part>s existed, so we need to the grading
       $status ne 'UNCHECKEDOUT') {      &Apache::inputtags::grade;
       # if part is zero, no <part>s existed, so we need show the current    } elsif ( ($target eq 'web' || $target eq 'tex') &&
       # grading status    $Apache::inputtags::part eq '0' &&
       my $gradestatus = &Apache::inputtags::gradestatus($Apache::inputtags::part,$target);    $status ne 'UNCHECKEDOUT') {
       $result.= $gradestatus;      # if part is zero, no <part>s existed, so we need show the current
     }      # grading status
     if (      my $gradestatus = &Apache::inputtags::gradestatus($Apache::inputtags::part,$target);
  (($target eq 'web') && ($ENV{'request.state'} ne 'construct')) ||      $result.= $gradestatus;
  ($target eq 'answer') || ($target eq 'tex')   }
        ) {   if (
       if ($status eq 'CAN_ANSWER') {      (($target eq 'web') && ($ENV{'request.state'} ne 'construct')) ||
   if ($target ne 'tex') {      ($target eq 'answer') || ($target eq 'tex')
       $result.="</form></body>\n";     ) {
   }       if ($status eq 'CAN_ANSWER') {
       } elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' ||   if ($target ne 'tex') {
        $status eq 'UNCHECKEDOUT' ) {      $result.="</form></body>\n";
   if ($target ne 'tex') {   }
       $result.="</body>\n";      } elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' ||
   }       $status eq 'UNCHECKEDOUT' ) {
       }   if ($target ne 'tex') {
       if ($target eq 'web') {      $result.="</body>\n";
   $result.=&Apache::lonxml::xmlend();   }
       } elsif ($target eq 'tex') {      }
   $result .= '\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}';      if ($target eq 'web') {
   if (not $ENV{'request.symb'} =~ m/\.page_/) {   $result.=&Apache::lonxml::xmlend();
       $result .= '\end{minipage}\end{document} ';      } elsif ($target eq 'tex') {
   } else {   $result .= '\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}';
       $result .= '';   if (not $ENV{'request.symb'} =~ m/\.page_/) {
   }      $result .= '\end{minipage}\end{document} ';
       }   } else {
     }      $result .= '';
     if ($target eq 'grade') {    }
       &Apache::lonhomework::showhash(%Apache::lonhomework::results);      }
       &finalize_storage();   }
     }   if ($target eq 'grade') {
     if ($target eq 'answer' && ($ENV{'request.state'} eq 'construct') ) {      &Apache::lonhomework::showhash(%Apache::lonhomework::results);
  $result.='</html>'; #normally we get it from xmlend, but in CSTR      &finalize_storage();
                             # we always show answer mode too.   }
     }   if ($target eq 'answer' && ($ENV{'request.state'} eq 'construct') ) {
   } elsif ($target eq 'meta') {      $result.='</html>'; #normally we get it from xmlend, but in CSTR
     if ($Apache::inputtags::part eq '0') {                          # we always show answer mode too.
       $result=&Apache::response::mandatory_part_meta;   }
     }      } elsif ($target eq 'meta') {
   } elsif ($target eq 'edit') {   if ($Apache::inputtags::part eq '0') {
     &Apache::lonxml::debug("in end_problem with $target, edit");      $result=&Apache::response::mandatory_part_meta;
     $result = &problem_edit_footer();   }
   }      } elsif ($target eq 'edit') {
    &Apache::lonxml::debug("in end_problem with $target, edit");
   undef(%Apache::lonhomework::history);   $result = &problem_edit_footer();
   undef(%Apache::lonhomework::results);      }
   undef($Apache::inputtags::part);  
   undef($Apache::lonhomework::parsing_a_problem);  
   
   return $result;      undef(%Apache::lonhomework::history);
       undef(%Apache::lonhomework::results);
       undef($Apache::inputtags::part);
       undef($Apache::lonhomework::parsing_a_problem);
   
       return $result;
 }  }
   
   
 sub start_library {  sub start_library {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my ($result,$head_tag_start,$body_tag_start,$form_tag_start);      my ($result,$head_tag_start,$body_tag_start,$form_tag_start);
   
   if ($target eq 'edit') {      if ($target eq 'edit') {
     ($result,$head_tag_start,$body_tag_start,$form_tag_start)=   ($result,$head_tag_start,$body_tag_start,$form_tag_start)=
       &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);      &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);
     $result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start.   $result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start.
       &problem_edit_header();      &problem_edit_header();
     my $temp=&Apache::edit::insertlist($target,$token);   my $temp=&Apache::edit::insertlist($target,$token);
     $result.=$temp;   $result.=$temp;
   } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
     $result=$token->[4];   $result=$token->[4];
     $result.=&Apache::edit::handle_insert();   $result.=&Apache::edit::handle_insert();
   } elsif ($target eq 'web' && $$tagstack[0] ne 'problem' &&      } elsif ($target eq 'web' && $$tagstack[0] ne 'problem' &&
    $ENV{'request.state'} eq "construct" ) {       $ENV{'request.state'} eq "construct" ) {
     ($result,$head_tag_start,$body_tag_start,$form_tag_start)=   ($result,$head_tag_start,$body_tag_start,$form_tag_start)=
       &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);      &page_start($target,$token,$tagstack,$parstack,$parser,$safeeval);
     my $name=&get_resource_name($parstack,$safeeval);   my $name=&get_resource_name($parstack,$safeeval);
     my $rndseed=&setup_rndseed($safeeval);   my $rndseed=&setup_rndseed($safeeval);
     $result.="$head_tag_start<title>$name</title></head>   $result.="$head_tag_start<title>$name</title></head>
               $body_tag_start \n $form_tag_start".                $body_tag_start \n $form_tag_start".
  '<input type="hidden" name="submitted" value="yes" />';    '<input type="hidden" name="submitted" value="yes" />';
     $result.=&problem_web_to_edit_header($rndseed);   $result.=&problem_web_to_edit_header($rndseed);
   }      }
   return $result;      return $result;
 }  }
   
 sub end_library {  sub end_library {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result='';      my $result='';
   if ($target eq 'edit') {      if ($target eq 'edit') {
     $result=&problem_edit_footer();   $result=&problem_edit_footer();
   } elsif ($target eq 'web' && $$tagstack[0] ne 'problem' &&      } elsif ($target eq 'web' && $$tagstack[0] ne 'problem' &&
    $ENV{'request.state'} eq "construct") {       $ENV{'request.state'} eq "construct") {
     $result.='</form></body>'.&Apache::lonxml::xmlend();   $result.='</form></body>'.&Apache::lonxml::xmlend();
   }      }
   return $result;      return $result;
 }  }
   
 sub start_block {  sub start_block {
Line 535  sub start_block { Line 542  sub start_block {
   
     if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||       if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || 
  $target eq 'tex' || $target eq 'analyze') {   $target eq 'tex' || $target eq 'analyze') {
  my $code = @$parstack[$#$parstack];   my $code = $token->[2]->{'condition'};
  if ($code) {   if ($code) {
     $code =~ s/\"//g;  
     $code .=';return $condition;';  
     if (!$Apache::lonxml::default_homework_loaded) {      if (!$Apache::lonxml::default_homework_loaded) {
  &Apache::lonxml::default_homework_load($safeeval);   &Apache::lonxml::default_homework_load($safeeval);
     }      }
Line 566  sub start_block { Line 571  sub start_block {
 }  }
   
 sub end_block {  sub end_block {
   return '';      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
       my @result=('','');
       if ($target eq "edit" || $target eq 'modified') { @result=('','no'); }
       return (@result);
 }  }
   
 sub start_while {  sub start_while {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   
       my $code = $token->[2]->{'condition'};
   
   my $code = @$parstack[$#$parstack];      push( @Apache::structuretags::whileconds, $code); 
   $code =~ s/\"//g;      if (!$Apache::lonxml::default_homework_loaded) {
   $code .=';return $condition;';   &Apache::lonxml::default_homework_load($safeeval);
       }
   push( @Apache::structuretags::whileconds, $code);       my $result = &Apache::run::run($code,$safeeval);
   if (!$Apache::lonxml::default_homework_loaded) {      my $bodytext=$$parser[$#$parser]->get_text("/while");
       &Apache::lonxml::default_homework_load($safeeval);      push( @Apache::structuretags::whilebody, $bodytext);
   }      if ( $result ) {
   my $result = &Apache::run::run($code,$safeeval);   &Apache::lonxml::newparser($parser,\$bodytext);
   my $bodytext=$$parser[$#$parser]->get_text("/while");      }
   push( @Apache::structuretags::whilebody, $bodytext);      return "";
   if ( $result ) {   
     &Apache::lonxml::newparser($parser,\$bodytext);  
   }  
   return "";  
 }  }
   
 sub end_while {  sub end_while {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $code = pop @Apache::structuretags::whileconds;      my $code = pop @Apache::structuretags::whileconds;
   my $bodytext = pop @Apache::structuretags::whilebody;      my $bodytext = pop @Apache::structuretags::whilebody;
   my $result = &Apache::run::run($code,$safeeval);      my $result = &Apache::run::run($code,$safeeval);
   if ( $result ) {       if ( $result ) {
     &Apache::lonxml::newparser($parser,\$bodytext);   &Apache::lonxml::newparser($parser,\$bodytext);
   }       }
   return "";      return "";
 }  }
   
 # <randomlist show="1">   # <randomlist show="1"> 
Line 607  sub end_while { Line 613  sub end_while {
 #  ...   #  ... 
 # </randomlist>  # </randomlist>
 sub start_randomlist {  sub start_randomlist {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result;      my $result;
   if ($target eq 'answer' || $target eq 'grade' || $target eq 'web' ||      if ($target eq 'answer' || $target eq 'grade' || $target eq 'web' ||
       $target eq 'tex' || $target eq 'analyze') {   $target eq 'tex' || $target eq 'analyze') {
     my $body= &Apache::lonxml::get_all_text("/randomlist",$parser);   my $body= &Apache::lonxml::get_all_text("/randomlist",$parser);
     my $b_parser= HTML::TokeParser->new(\$body);   my $b_parser= HTML::TokeParser->new(\$body);
     my $b_tok;   my $b_tok;
     my @randomlist;   my @randomlist;
     my $list_item;   my $list_item;
     while($b_tok = $b_parser->get_token() ) {   while($b_tok = $b_parser->get_token() ) {
       if($b_tok->[0] eq 'S') { # start tag      if($b_tok->[0] eq 'S') { # start tag
  # get content of the tag until matching end tag   # get content of the tag until matching end tag
  # get all text upto the matching tag   # get all text upto the matching tag
  # and push the content into @randomlist   # and push the content into @randomlist
  $list_item = &Apache::lonxml::get_all_text('/'.$b_tok->[1],$b_parser);   $list_item = &Apache::lonxml::get_all_text('/'.$b_tok->[1],
  $list_item = "$b_tok->[4]"."$list_item"."</$b_tok->[1]>";     $b_parser);
  push(@randomlist,$list_item);   $list_item = "$b_tok->[4]"."$list_item"."</$b_tok->[1]>";
  #  print "<br /><b>START-TAG $b_tok->[1], $b_tok->[4], $list_item</b>";   push(@randomlist,$list_item);
       }   #  print "<br /><b>START-TAG $b_tok->[1], $b_tok->[4],
       if($b_tok->[0] eq 'T') { # text                  #         $list_item</b>";
  # what to do with text in between tags?      }
  #  print "<b>TEXT $b_tok->[1]</b><br />";      if($b_tok->[0] eq 'T') { # text
       }   # what to do with text in between tags?
       # if($b_tok->[0] eq 'E') { # end tag, should not happen   #  print "<b>TEXT $b_tok->[1]</b><br />";
       #  print "<b>END-TAG $b_tok->[1]</b><br />";      }
       # }      # if($b_tok->[0] eq 'E') { # end tag, should not happen
     }      #  print "<b>END-TAG $b_tok->[1]</b><br />";
     my @idx_arr = (0 .. $#randomlist);      # }
     &Apache::structuretags::shuffle(\@idx_arr);   }
     my $bodytext = '';   my @idx_arr = (0 .. $#randomlist);
     my $show=$#randomlist;   &Apache::structuretags::shuffle(\@idx_arr);
     my $showarg=&Apache::lonxml::get_param('show',$parstack,$safeeval);   my $bodytext = '';
     $showarg--;   my $show=$#randomlist;
     if ( ($showarg >= 0) && ($showarg < $show) ) { $show = $showarg; }   my $showarg=&Apache::lonxml::get_param('show',$parstack,$safeeval);
     for(0 .. $show) {   $showarg--;
       $bodytext .= "$randomlist[ $idx_arr[$_] ]";   if ( ($showarg >= 0) && ($showarg < $show) ) { $show = $showarg; }
     }   for(0 .. $show) {
     &Apache::lonxml::newparser($parser,\$bodytext);      $bodytext .= "$randomlist[ $idx_arr[$_] ]";
   } elsif ($target eq 'edit' ) {   }
     $result .= &Apache::edit::tag_start($target,$token);   &Apache::lonxml::newparser($parser,\$bodytext);
     $result .= &Apache::edit::text_arg('Maximum Tags to Show:','show',$token,5);      } elsif ($target eq 'edit' ) {
     $result .= &Apache::edit::end_row().&Apache::edit::start_spanning_row();   $result .=&Apache::edit::tag_start($target,$token);
   } elsif ($target eq 'modified' ) {   $result .=&Apache::edit::text_arg('Maximum Tags to Show:','show',
     my $constructtag=&Apache::edit::get_new_args($token,$parstack,$safeeval,     $token,5);
  'show');   $result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row();
     if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); }      } elsif ($target eq 'modified' ) {
   }   my $constructtag=&Apache::edit::get_new_args($token,$parstack,
   return $result;       $safeeval,'show');
    if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); }
       }
       return $result;
 }  }
   
 sub shuffle {  sub shuffle {
     my $a=shift;      my $a=shift;
     my $i;      my $i;
     if (defined(@$a)) {      if (defined(@$a)) {
       &Apache::response::setrandomnumber();   &Apache::response::setrandomnumber();
       for($i=@$a;--$i;) {   for($i=@$a;--$i;) {
  my $j=int(&Math::Random::random_uniform() * ($i+1));      my $j=int(&Math::Random::random_uniform() * ($i+1));
  next if $i == $j;      next if $i == $j;
  @$a[$i,$j] = @$a[$j,$i];      @$a[$i,$j] = @$a[$j,$i];
       }   }
     }      }
 }  }
   
 sub end_randomlist {  sub end_randomlist {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result;      my $result;
   if ($target eq 'edit' ) {      if ($target eq 'edit' ) {
     $result=&Apache::edit::tag_end($target,$token,'End Randomly Parsed Block');   $result=&Apache::edit::tag_end($target,$token,
   }         'End Randomly Parsed Block');
   return $result;      }
       return $result;
 }  }
   
 sub start_part {  sub start_part {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result='';      my $result='';
   my $id= &Apache::lonxml::get_param('id',$parstack,$safeeval);      my $id= &Apache::lonxml::get_param('id',$parstack,$safeeval);
   if ($id eq '') { $id = $Apache::lonxml::curdepth; }      if ($id eq '') { $id = $Apache::lonxml::curdepth; }
   $Apache::inputtags::part=$id;      $Apache::inputtags::part=$id;
   @Apache::inputtags::responselist = ();      @Apache::inputtags::responselist = ();
   @Apache::inputtags::previous=();      @Apache::inputtags::previous=();
   @Apache::inputtags::previous_version=();      @Apache::inputtags::previous_version=();
   my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part);      my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part);
   
   if ($target eq 'meta') {      if ($target eq 'meta') {
     return &Apache::response::mandatory_part_meta;   return &Apache::response::mandatory_part_meta;
   } elsif ($target eq 'web' || $target eq 'grade' ||      } elsif ($target eq 'web' || $target eq 'grade' ||
    $target eq 'answer' || $target eq 'tex') {       $target eq 'answer' || $target eq 'tex') {
       if ($hidden) {   if ($hidden) {
   my $bodytext=&Apache::lonxml::get_all_text("/part",$parser);      my $bodytext=&Apache::lonxml::get_all_text("/part",$parser);
       } else {   } else {
   my ($status,$accessmsg) = &Apache::lonhomework::check_access($id);      my ($status,$accessmsg) = &Apache::lonhomework::check_access($id);
   push (@Apache::inputtags::status,$status);      push (@Apache::inputtags::status,$status);
   my $expression='$external::datestatus="'.$status.'";';      my $expression='$external::datestatus="'.$status.'";';
   $expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.$id.solved"}.'";';      $expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.$id.solved"}.'";';
   &Apache::run::run($expression,$safeeval);      &Apache::run::run($expression,$safeeval);
   if ( $status eq 'CLOSED' ) {      if ( $status eq 'CLOSED' ) {
       my $bodytext=&Apache::lonxml::get_all_text("/part",$parser);   my $bodytext=&Apache::lonxml::get_all_text("/part",$parser);
       if ( $target eq "web" ) {   if ( $target eq "web" ) {
   $result="<br />Part is not open to be viewed. It $accessmsg<br />";      $result="<br />Part is not open to be viewed. It $accessmsg<br />";
       } elsif ( $target eq 'tex' ) {   } elsif ( $target eq 'tex' ) {
   $result="\\end{minipage}\\vskip 0 mm Part is not open to be viewed. It $accessmsg \\\\\\begin{minipage}{\\textwidth}";      $result="\\end{minipage}\\vskip 0 mm Part is not open to be viewed. It $accessmsg \\\\\\begin{minipage}{\\textwidth}";
       }   }
   } else {      } else {
       if ($target eq 'tex') {   if ($target eq 'tex') {
  $result.='\noindent \end{minipage}\vskip 0 mm \noindent \begin{minipage}{\textwidth}\noindent';      $result.='\noindent \end{minipage}\vskip 0 mm \noindent \begin{minipage}{\textwidth}\noindent';
  my $weight = &Apache::lonnet::EXT("resource.$id.weight");      my $weight = &Apache::lonnet::EXT("resource.$id.weight");
  if ($Apache::lonhomework::type eq 'exam') { $result .= '\fbox{\textit{'.$weight.' pt}}';}      if ($Apache::lonhomework::type eq 'exam') { $result .= '\fbox{\textit{'.$weight.' pt}}';}
       }   }
   }      }
       }   }
   } elsif ($target eq 'edit') {      } elsif ($target eq 'edit') {
       $result.=&Apache::edit::tag_start($target,$token);   $result.=&Apache::edit::tag_start($target,$token);
       $result.=&Apache::edit::text_arg('Part ID:','id',$token).   $result.=&Apache::edit::text_arg('Part ID:','id',$token).
   &Apache::loncommon::help_open_topic("Part_Tag_Edit_Help").      &Apache::loncommon::help_open_topic("Part_Tag_Edit_Help").
       &Apache::edit::end_row().&Apache::edit::start_spanning_row();   &Apache::edit::end_row().&Apache::edit::start_spanning_row();
       } elsif ($target eq 'modified') {
   } elsif ($target eq 'modified') {   my $constructtag=&Apache::edit::get_new_args($token,$parstack,
       my $constructtag=&Apache::edit::get_new_args($token,$parstack,$safeeval,       $safeeval,'id');
    'id');   if ($constructtag) {
       if ($constructtag) {      $result = &Apache::edit::rebuild_tag($token);
   $result = &Apache::edit::rebuild_tag($token);      $result.=&Apache::edit::handle_insert();
   $result.=&Apache::edit::handle_insert();   }
       }      }
   }      return $result;
   return $result;  
 }  }
   
 sub end_part {  sub end_part {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   &Apache::lonxml::debug("in end_part $target ");      &Apache::lonxml::debug("in end_part $target ");
   my $status=$Apache::inputtags::status['-1'];      my $status=$Apache::inputtags::status['-1'];
   my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part);      my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part);
   my $result='';      my $result='';
   if ( $target eq 'meta' ) {      if ( $target eq 'meta' ) {
       $result='';   $result='';
   } elsif ( $target eq 'grade' && $status eq 'CAN_ANSWER' && !$hidden) {      } elsif ( $target eq 'grade' && $status eq 'CAN_ANSWER' && !$hidden) {
     $result=&Apache::inputtags::grade;   $result=&Apache::inputtags::grade;
   } elsif (($target eq 'web' || $target eq 'tex') && !$hidden ) {      } elsif (($target eq 'web' || $target eq 'tex') && !$hidden ) {
     my $gradestatus=&Apache::inputtags::gradestatus($Apache::inputtags::part,   my $gradestatus=&Apache::inputtags::gradestatus($Apache::inputtags::part,
     $target);   $target);
     if ($Apache::lonhomework::type eq 'exam') {$gradestatus='';}   if ($Apache::lonhomework::type eq 'exam') {$gradestatus='';}
     $result=$gradestatus;   $result=$gradestatus;
   }      }
   pop @Apache::inputtags::status;      pop @Apache::inputtags::status;
   $Apache::inputtags::part='';      $Apache::inputtags::part='';
   return $result;      return $result;
 }  }
   
 sub start_preduedate {  sub start_preduedate {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') {      if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') {
     if ($Apache::inputtags::status['-1'] ne 'CAN_ANSWER' &&   if ($Apache::inputtags::status['-1'] ne 'CAN_ANSWER' &&
  $Apache::inputtags::status['-1'] ne 'CANNOT_ANSWER' &&       $Apache::inputtags::status['-1'] ne 'CANNOT_ANSWER' &&
         $Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') {      $Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') {
       &Apache::lonxml::get_all_text("/preduedate",$parser);      &Apache::lonxml::get_all_text("/preduedate",$parser);
    }
     }      }
   }      return '';
   return '';  
 }  }
   
 sub end_preduedate {  sub end_preduedate {
   return '';      return '';
 }  }
   
 sub start_postanswerdate {  sub start_postanswerdate {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   if ($target eq 'web' || $target eq 'grade' || $target eq 'tex') {      if ($target eq 'web' || $target eq 'grade' || $target eq 'tex') {
     if ($Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') {   if ($Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') {
       &Apache::lonxml::get_all_text("/postanswerdate",$parser);      &Apache::lonxml::get_all_text("/postanswerdate",$parser);
     }   }
   } elsif ($target eq 'tex') {      } elsif ($target eq 'tex') {
       return '\vskip 0 mm \noindent';   return '\vskip 0 mm \noindent';
   }      }
   return '';      return '';
 }  }
   
 sub end_postanswerdate {  sub end_postanswerdate {
   return '';      return '';
 }  }
   
 sub start_notsolved {  sub start_notsolved {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') {      if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||
     my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"};   $target eq 'tex') {
     &Apache::lonxml::debug("not solved has :$gradestatus:");   my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"};
     if ($gradestatus =~ /^correct/) {   &Apache::lonxml::debug("not solved has :$gradestatus:");
       &Apache::lonxml::debug("skipping");   if ($gradestatus =~ /^correct/) {
       &Apache::lonxml::get_all_text("/notsolved",$parser);      &Apache::lonxml::debug("skipping");
       &Apache::lonxml::get_all_text("/notsolved",$parser);
    }
     }      }
   }      return '';
   return '';  
 }  }
   
 sub end_notsolved {  sub end_notsolved {
   return '';      return '';
 }  }
   
 sub start_solved {  sub start_solved {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') {      if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' ||
     my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"};   $target eq 'tex') {
     if ($gradestatus !~ /^correct/) {   my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"};
       &Apache::lonxml::get_all_text("/solved",$parser);   if ($gradestatus !~ /^correct/) {
       &Apache::lonxml::get_all_text("/solved",$parser);
    }
     }      }
   }      return '';
   return '';  
 }  }
   
 sub end_solved {  sub end_solved {
   return '';      return '';
 }  }
   
 sub start_startouttext {  sub start_startouttext {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my @result=(''.'');      my @result=(''.'');
   if ($target eq 'edit' || $target eq 'modified' ) { @result=('','no'); }      if ($target eq 'edit' || $target eq 'modified' ) { @result=('','no'); }
   return (@result);      return (@result);
 }  }
   
 sub end_startouttext {  sub end_startouttext {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result='';      my $result='';
   my $text='';      my $text='';
   
   if ($target eq 'edit') {      if ($target eq 'edit') {
     $text=&Apache::lonxml::get_all_text("endouttext",$parser);   $text=&Apache::lonxml::get_all_text("endouttext",$parser);
     $result.=&Apache::edit::start_table($token)."<tr><td>Text Block</td>   $result.=&Apache::edit::start_table($token)."<tr><td>Text Block</td>
 <td>Delete:".  <td>Delete:".
   &Apache::edit::deletelist($target,$token)                   &Apache::edit::deletelist($target,$token)
     ."</td>   ."</td>
 <td>".  <td>".
   &Apache::edit::insertlist($target,$token).                   &Apache::edit::insertlist($target,$token).
     &Apache::edit::end_row().&Apache::edit::start_spanning_row()."\n"   &Apache::edit::end_row().
  .'<table><tr><td>'.                   &Apache::edit::start_spanning_row()."\n"
     &Apache::loncommon::help_open_topic("Greek_Symbols",'Greek Symbols',   .'<table><tr><td>'.
  undef,undef,600)   &Apache::loncommon::help_open_topic("Greek_Symbols",
  .'</td><td>'.       'Greek Symbols',
     &Apache::loncommon::help_open_topic("Other_Symbols",'Other Symbols',       undef,undef,600)
  undef,undef,600)   .'</td><td>'.
  .'</td></tr></table>'.   &Apache::loncommon::help_open_topic("Other_Symbols",
     &Apache::edit::editfield($token->[1],$text,"",80,4);       'Other Symbols',
   }       undef,undef,600)
   if ($target eq 'modified') {   .'</td></tr></table>'.
     $text=&Apache::lonxml::get_all_text("endouttext",$parser);   &Apache::edit::editfield($token->[1],$text,"",80,4);
     $result='<startouttext />'.&Apache::edit::modifiedfield();      }
   }      if ($target eq 'modified') {
   if ($target eq 'tex') {   $text=&Apache::lonxml::get_all_text("endouttext",$parser);
       $result .= '\noindent ';   $result='<startouttext />'.&Apache::edit::modifiedfield();
   }      }
   return $result;      if ($target eq 'tex') {
    $result .= '\noindent ';
       }
       return $result;
 }  }
   
 sub start_endouttext {  sub start_endouttext {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my $result='';      my $result='';
   if ($target eq "edit" ) { $result="</td></tr>".&Apache::edit::end_table()."\n"; }      if ($target eq "edit" ) { $result="</td></tr>".&Apache::edit::end_table()."\n"; }
   if ($target eq "modified") {       if ($target eq "modified") {
      $result='<endouttext />'.   $result='<endouttext />'.
      &Apache::edit::handle_insertafter('startouttext'); }      &Apache::edit::handle_insertafter('startouttext'); }
   return $result;      return $result;
 }  }
   
 sub end_endouttext {  sub end_endouttext {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   my @result=('','');      my @result=('','');
   if ($target eq "edit" || $target eq 'modified') { @result=('','no'); }      if ($target eq "edit" || $target eq 'modified') { @result=('','no'); }
   return (@result);      return (@result);
 }  }
   
 sub delete_startouttext {  sub delete_startouttext {
   my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;      my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
 #  my $text=&Apache::lonxml::get_all_text("endouttext",$parser);      #  my $text=&Apache::lonxml::get_all_text("endouttext",$parser);
   my $text=$$parser['-1']->get_text("/endouttext");      my $text=$$parser['-1']->get_text("/endouttext");
   my $ntoken=$$parser['-1']->get_token();      my $ntoken=$$parser['-1']->get_token();
   &Apache::lonxml::debug("Deleting :$text: and :$ntoken->[0]:$ntoken->[1]:$ntoken->[2]: for startouttext");      &Apache::lonxml::debug("Deleting :$text: and :$ntoken->[0]:$ntoken->[1]:$ntoken->[2]: for startouttext");
   &Apache::lonxml::end_tag($tagstack,$parstack,$ntoken);      &Apache::lonxml::end_tag($tagstack,$parstack,$ntoken);
   # Deleting 2 parallel tag pairs, but we need the numbers later to look like       # Deleting 2 parallel tag pairs, but we need the numbers later to look like
   # they did the last time round      # they did the last time round
   &Apache::lonxml::increasedepth($ntoken);      &Apache::lonxml::increasedepth($ntoken);
   &Apache::lonxml::decreasedepth($ntoken);      &Apache::lonxml::decreasedepth($ntoken);
   return 1;      return 1;
 }  }
   
 1;  1;

Removed from v.1.158  
changed lines
  Added in v.1.159


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