--- loncom/homework/lonhomework.pm 2001/05/04 21:20:31 1.42 +++ loncom/homework/lonhomework.pm 2001/08/06 20:33:23 1.52 @@ -14,6 +14,11 @@ use Apache::response; use Apache::hint; use Apache::outputtags; use Apache::Constants qw(:common); +#use Time::HiRes qw( gettimeofday tv_interval ); + +sub BEGIN { + &Apache::lonxml::register_insert(); +} sub get_target { if ( $ENV{'request.state'} eq "published") { @@ -167,11 +172,41 @@ sub setupheader { return '' } +sub handle_save_or_undo { + my ($request,$problem,$result) = @_; + my $fileout = &Apache::lonnet::filelocation("",$request->uri); + my $filesave=$fileout.".bak"; + + if ($ENV{'form.Undo'} eq 'undo') { + if (copy($filesave,$fileout)) { + $request->print("Undid changes, Copied $filesave to $fileout
"); + } else { + $request->print("Unable to undo, unable to copy $filesave to $fileout
"); + } + } else { + my $fs=Apache::File->new(">$filesave"); + if (defined($fs)) { + print $fs $$problem; + $request->print("Making Backup to $filesave
"); + } else { + $request->print("Unable to make backup $filesave"); + } + my $fh=Apache::File->new(">$fileout"); + if (defined($fh)) { + print $fh $$result; + $request->print("Saving Modifications to $fileout
"); + } else { + $request->print("Unable to write to $fileout"); + } + } +} + sub renderpage { my ($request,$file) = @_; my (@targets) = &get_target(); foreach my $target (@targets) { + #my $t0 = [&gettimeofday()]; my $problem=&Apache::lonnet::getfile($file); if ($problem == -1) { &Apache::lonxml::error(" Unable to find $file"); @@ -181,6 +216,7 @@ sub renderpage { my %mystyle; my $result = ''; &Apache::inputtags::initialize_inputtags; + &Apache::edit::initialize_edit; %Apache::lonhomework::results=(); %Apache::lonhomework::history=&Apache::lonnet::restore(); #ignore error conditions @@ -194,7 +230,7 @@ sub renderpage { $request->print("Browsing or ambiguous reference, submissions ignored
"); } } - if ($Apache::lonhomework::viewgrades eq 'F') {&createmenu('grade',$request); } + #if ($Apache::lonhomework::viewgrades eq 'F') {&createmenu('grade',$request); } } if ($target eq 'grade') { &showhash(%Apache::lonhomework::history); } @@ -208,17 +244,13 @@ sub renderpage { #$request->print("Result follows:"); if ($target eq 'modified') { - my $fileout = &Apache::lonnet::filelocation("",$request->uri); - my $filesave=$fileout.".bak"; - - my $fs=Apache::File->new(">$filesave"); - print $fs $problem; - $request->print("Making Backup to $filesave
"); - - my $fh=Apache::File->new(">$fileout"); - print $fh $result; - $request->print("Saving Modifications to $fileout
"); + &handle_save_or_undo($request,\$problem,\$result); } else { + #my $td=&tv_interval($t0); + #if ( $Apache::lonxml::debug) { + #$result =~ s:::; + #$result.="
Spent $td seconds processing target $target\n"; + #} $request->print($result); } #$request->print(":Result ends"); @@ -230,15 +262,17 @@ sub renderpage { &Apache::lonxml::debug("Store return message:". &Apache::lonnet::cstore(\%Apache::lonhomework::results)); } + #my $td=&tv_interval($t0); } } # with no arg it returns a HTML