Diff for /loncom/homework/lonhomework.pm between versions 1.64 and 1.72

version 1.64, 2001/12/04 14:51:19 version 1.72, 2002/02/28 01:18:47
Line 34  use strict; Line 34  use strict;
 use Apache::style;  use Apache::style;
 use Apache::lonxml;  use Apache::lonxml;
 use Apache::lonnet;  use Apache::lonnet;
   use Apache::lonplot;
 use Apache::inputtags;  use Apache::inputtags;
 use Apache::structuretags;  use Apache::structuretags;
 use Apache::randomlabel;  use Apache::randomlabel;
Line 43  use Apache::outputtags; Line 44  use Apache::outputtags;
 use Apache::Constants qw(:common);  use Apache::Constants qw(:common);
 #use Time::HiRes qw( gettimeofday tv_interval );  #use Time::HiRes qw( gettimeofday tv_interval );
   
 sub BEGIN {  BEGIN {
   &Apache::lonxml::register_insert();    &Apache::lonxml::register_insert();
 }  }
   
 sub get_target {  sub get_target {
   if ( $ENV{'request.state'} eq "published") {    if ( $ENV{'request.state'} eq "published") {
       if ( defined($ENV{'form.grade_target'}) 
    && ($Apache::lonhomework::viewgrades == 'F' )) {
         return ($ENV{'form.grade_target'});
       }
     if ( defined($ENV{'form.submitted'})) {      if ( defined($ENV{'form.submitted'})) {
       return ('grade', 'web');        return ('grade', 'web');
     } else {      } else {
Line 203  sub setupheader { Line 208  sub setupheader {
   } else {    } else {
     $request->content_type('text/html');      $request->content_type('text/html');
   }    }
   if (!$Apache::lonxml::debug) { &Apache::loncommon::no_cache($request); }    if (!$Apache::lonxml::debug && ($ENV{'REQUEST_METHOD'} eq 'GET')) {
       &Apache::loncommon::no_cache($request);
     }
   $request->send_http_header;    $request->send_http_header;
   return OK if $request->header_only;    return OK if $request->header_only;
   return ''    return ''
Line 211  sub setupheader { Line 218  sub setupheader {
   
 sub handle_save_or_undo {  sub handle_save_or_undo {
   my ($request,$problem,$result) = @_;    my ($request,$problem,$result) = @_;
   my $fileout = &Apache::lonnet::filelocation("",$request->uri);    my $file    = &Apache::lonnet::filelocation("",$request->uri);
   my $filesave=$fileout.".bak";    my $filebak =$file.".bak";
     my $filetmp =$file.".tmp";
   my $error=0;    my $error=0;
   
   if ($ENV{'form.Undo'} eq 'undo') {    if ($ENV{'form.Undo'} eq 'undo') {
     if (copy($filesave,$fileout)) {      my $error=0;
       $request->print("<b>Undid changes, Copied $filesave to $fileout<br /></b>");      if (!copy($file,$filetmp)) { $error=1; }
       if ((!$error) && (!copy($filebak,$file))) { $error=1; }
       if ((!$error) && (!move($filetmp,$filebak))) { $error=1; }
       if (!$error) {
         $request->print("<p><b>Undid changes, Switched $filebak and $file</b></p>");
     } else {      } else {
       $request->print("<font color=\"red\" size=\"+1\"><b>Unable to undo, unable to copy $filesave to $fileout<br /></b></font>");        $request->print("<p><font color=\"red\" size=\"+1\"><b>Unable to undo, unable to switch $filebak and $file</b></font></p>");
       $error=1;        $error=1;
     }      }
   } else {    } else {
     my $fs=Apache::File->new(">$filesave");      my $fs=Apache::File->new(">$filebak");
     if (defined($fs)) {      if (defined($fs)) {
       print $fs $$problem;        print $fs $$problem;
       $request->print("<b>Making Backup to $filesave</b><br />");        $request->print("<b>Making Backup to $filebak</b><br />");
     } else {      } else {
       $request->print("<font color=\"red\" size=\"+1\"><b>Unable to make backup $filesave</b></font>");        $request->print("<font color=\"red\" size=\"+1\"><b>Unable to make backup $filebak</b></font>");
       $error=2;        $error=2;
     }      }
     my $fh=Apache::File->new(">$fileout");      my $fh=Apache::File->new(">$file");
     if (defined($fh)) {      if (defined($fh)) {
       print $fh $$result;        print $fh $$result;
       $request->print("<b>Saving Modifications to $fileout</b><br />");        $request->print("<b>Saving Modifications to $file</b><br />");
     } else {      } else {
       $request->print("<font color=\"red\" size=\"+1\"><b>Unable to write to $fileout</b></font>");        $request->print("<font color=\"red\" size=\"+1\"><b>Unable to write to $file</b></font>");
       $error|=4;        $error|=4;
     }      }
   }    }
Line 279  sub renderpage { Line 291  sub renderpage {
   my ($request,$file) = @_;    my ($request,$file) = @_;
   
   my (@targets) = &get_target();    my (@targets) = &get_target();
     &Apache::lonxml::debug("Running targets ".join(':',@targets));
   foreach my $target (@targets) {    foreach my $target (@targets) {
     #my $t0 = [&gettimeofday()];      #my $t0 = [&gettimeofday()];
     my $problem=&Apache::lonnet::getfile($file);      my $problem=&Apache::lonnet::getfile($file);
Line 307  sub renderpage { Line 320  sub renderpage {
       &Apache::lonxml::error("<b>Unable to find <i>default_homework.lcpm</i></b>");        &Apache::lonxml::error("<b>Unable to find <i>default_homework.lcpm</i></b>");
       $default='';        $default='';
     }      }
       &Apache::lonxml::debug("Should be parsing now");
     $result = &Apache::lonxml::xmlparse($target, $problem,      $result = &Apache::lonxml::xmlparse($target, $problem,
  $default.&setup_vars($target),%mystyle);   $default.&setup_vars($target),%mystyle);
   
Line 345  sub get_template_list { Line 359  sub get_template_list {
 }  }
   
 sub newproblem {  sub newproblem {
   my ($request) = @_;      my ($request) = @_;
       my $extension=$request->uri;
   my $extension=$request->uri;      $extension=~s:^.*\.([\w]+)$:$1:;
   $extension=~s:^.*\.([\w]+)$:$1:;      &Apache::lonxml::debug("Looking for :$extension:");
   &Apache::lonxml::debug("Looking for :$extension:");      if ($ENV{'form.template'}) {
   if ($ENV{'form.template'}) {   use File::Copy;
     use File::Copy;   my $file = &get_template_list($ENV{'form.template'},$extension);
     my $file = &get_template_list($ENV{'form.template'},$extension);   my $dest = &Apache::lonnet::filelocation("",$request->uri);
     my $dest = &Apache::lonnet::filelocation("",$request->uri);   copy($file,$dest);
     copy($file,$dest);   &renderpage($request,$dest);
     &renderpage($request,$file);      } elsif($ENV{'form.newfile'}) {
   } else {   # I don't like hard-coded filenames but for now, this will work.
     my $templatelist=&get_template_list('',$extension);   use File::Copy;
     my $url=$request->uri;   my $templatefilename = 
     my $dest = &Apache::lonnet::filelocation("",$request->uri);      $request->dir_config('lonIncludes').'/templates/blank.problem';
     $request->print(<<ENDNEWPROBLEM);   &Apache::lonxml::debug("$templatefilename");
    my $dest = &Apache::lonnet::filelocation("",$request->uri);
    copy($templatefilename,$dest);
    &renderpage($request,$dest);
       }else {
    my $templatelist=&get_template_list('',$extension);
    my $url=$request->uri;
    my $dest = &Apache::lonnet::filelocation("",$request->uri);
    if (!defined($templatelist)) {
       # We didn't find a template, so just create a blank problem.
       $request->print(<<ENDNEWPROBLEM);
   <body bgcolor="#FFFFFF">
   The requested file $url doesn\'t exist. You can create a new $extension <br />
   <form action="$url" method="POST">
   <input type="submit" name="newfile" value="New $extension"><br />
   </form>
   </body>
   ENDNEWPROBLEM
               return '';
           }
    $request->print(<<ENDNEWPROBLEM);
 <body bgcolor="#FFFFFF">  <body bgcolor="#FFFFFF">
 The request file $url doesn\'t exist. You can create a new $extension <br />  The requested file $url doesn\'t exist. You can create a new $extension <br />
 <form action="$url" method="POST">  <form action="$url" method="POST">
 <input type="submit" value="New $extension"><br />  <input type="submit" value="New $extension"><br />
 <select name="template">  <select name="template">
Line 371  $templatelist Line 405  $templatelist
 </form>  </form>
 </body>  </body>
 ENDNEWPROBLEM  ENDNEWPROBLEM
   }      }
       return '';
   return '';  
 }  }
   
 sub view_or_edit_menu {  sub view_or_edit_menu {
Line 402  sub handler { Line 435  sub handler {
   $Apache::lonhomework::browse= &Apache::lonnet::allowed('bre',$ENV{'request.filename'});    $Apache::lonhomework::browse= &Apache::lonnet::allowed('bre',$ENV{'request.filename'});
   $Apache::lonhomework::viewgrades=&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'});    $Apache::lonhomework::viewgrades=&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'});
   &Apache::lonxml::debug("Permissions:$Apache::lonhomework::browse:$Apache::lonhomework::viewgrades:");    &Apache::lonxml::debug("Permissions:$Apache::lonhomework::browse:$Apache::lonhomework::viewgrades:");
     # some times multiple problemmodes are submitted, need to select
     # the last one
     if ( defined($ENV{'form.problemmode'}) &&
          defined(@{ $ENV{'form.problemmode'} })) {
       &Apache::lonxml::debug("3Problem Modes ".$ENV{'form.problemmode'});
       my $mode=$ENV{'form.problemmode'}->[-1];
       undef $ENV{'form.problemmode'};
       $ENV{'form.problemmode'}=$mode;
     }
   &Apache::lonxml::debug("Problem Mode ".$ENV{'form.problemmode'});    &Apache::lonxml::debug("Problem Mode ".$ENV{'form.problemmode'});
   my $file=&Apache::lonnet::filelocation("",$request->uri);    my $file=&Apache::lonnet::filelocation("",$request->uri);
   

Removed from v.1.64  
changed lines
  Added in v.1.72


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