version 1.399, 2006/03/08 22:15:47
|
version 1.406, 2006/04/13 19:00:40
|
Line 204 sub xmlend {
|
Line 204 sub xmlend {
|
$discussion.='<tex>\keephidden{ENDOFPROBLEM}\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}\end{document}</tex>'; |
$discussion.='<tex>\keephidden{ENDOFPROBLEM}\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}\end{document}</tex>'; |
&Apache::lonxml::newparser($parser,\$discussion,''); |
&Apache::lonxml::newparser($parser,\$discussion,''); |
return ''; |
return ''; |
} else { |
|
return $discussion.&Apache::loncommon::endbodytag(); |
|
} |
} |
|
|
|
return $discussion.&Apache::loncommon::end_page(); |
} |
} |
|
|
sub tokeninputfield { |
sub tokeninputfield { |
Line 1038 sub init_counter {
|
Line 1038 sub init_counter {
|
|
|
sub store_counter { |
sub store_counter { |
&Apache::lonnet::appenv(('form.counter' => $Apache::lonxml::counter)); |
&Apache::lonnet::appenv(('form.counter' => $Apache::lonxml::counter)); |
|
$Apache::lonxml::counter_changed=0; |
return ''; |
return ''; |
} |
} |
|
|
{ |
{ |
my $state; |
my $state; |
sub clear_problem_counter { |
sub clear_problem_counter { |
&Apache::lonnet::logthis(" cpc called from ".(join(':',caller(0)))); |
|
undef($state); |
undef($state); |
&Apache::lonnet::delenv('form.counter'); |
&Apache::lonnet::delenv('form.counter'); |
&Apache::lonxml::init_counter(); |
&Apache::lonxml::init_counter(); |
Line 1061 sub store_counter {
|
Line 1061 sub store_counter {
|
&Apache::lonnet::appenv(('form.counter' => $state)); |
&Apache::lonnet::appenv(('form.counter' => $state)); |
} |
} |
} |
} |
|
sub get_problem_counter { |
|
if ($Apache::lonxml::counter_changed) { &store_counter() } |
|
&Apache::lonnet::transfer_profile_to_env(); |
|
return $env{'form.counter'}; |
|
} |
} |
} |
|
|
sub get_all_text { |
sub get_all_text { |
Line 1453 sub handler {
|
Line 1458 sub handler {
|
my $result = ''; |
my $result = ''; |
my $filecontents=&Apache::lonnet::getfile($file); |
my $filecontents=&Apache::lonnet::getfile($file); |
if ($filecontents eq -1) { |
if ($filecontents eq -1) { |
my $bodytag=&Apache::loncommon::bodytag('File Error'); |
my $start_page=&Apache::loncommon::start_page('File Error'); |
|
my $end_page=&Apache::loncommon::end_page('File Error'); |
my $fnf=&mt('File not found'); |
my $fnf=&mt('File not found'); |
$result=(<<ENDNOTFOUND); |
$result=(<<ENDNOTFOUND); |
<html> |
$start_page |
<head> |
|
<title>$fnf</title> |
|
</head> |
|
$bodytag |
|
<b>$fnf: $file</b> |
<b>$fnf: $file</b> |
</body> |
$end_page |
</html> |
|
ENDNOTFOUND |
ENDNOTFOUND |
$filecontents=''; |
$filecontents=''; |
if ($env{'request.state'} ne 'published') { |
if ($env{'request.state'} ne 'published') { |
Line 1501 ENDNOTFOUND
|
Line 1502 ENDNOTFOUND
|
if ($env{'form.editmode'} && (!($env{'form.viewmode'}))) { |
if ($env{'form.editmode'} && (!($env{'form.viewmode'}))) { |
my $displayfile=$request->uri; |
my $displayfile=$request->uri; |
$displayfile=~s/^\/[^\/]*//; |
$displayfile=~s/^\/[^\/]*//; |
my $bodytag='<body bgcolor="#FFFFFF">'; |
my %options = (); |
if ($env{'environment.remote'} eq 'off') { |
if ($env{'environment.remote'} ne 'off') { |
$bodytag=&Apache::loncommon::bodytag(); |
$options{'bgcolor'} = '#FFFFFF'; |
} |
} |
$result='<html>'.$bodytag. |
my $start_page = &Apache::loncommon::start_page(undef,undef, |
|
\%options); |
|
$result=$start_page. |
&Apache::lonxml::message_location().'<h3>'. |
&Apache::lonxml::message_location().'<h3>'. |
$displayfile. |
$displayfile. |
'</h3></body></html>'; |
'</h3>'.&Apache::loncommon::end_page(); |
$result=&inserteditinfo($result,$filecontents,$filetype); |
$result=&inserteditinfo($result,$filecontents,$filetype); |
} |
} |
} |
} |
if ($filetype eq 'html') { writeallows($request->uri); } |
if ($filetype eq 'html') { &writeallows($request->uri); } |
|
|
|
|
&Apache::lonxml::add_messages(\$result); |
&Apache::lonxml::add_messages(\$result); |
Line 1575 sub error {
|
Line 1578 sub error {
|
if ( !$symb ) { |
if ( !$symb ) { |
#public or browsers |
#public or browsers |
$errormsg=&mt("An error occured while processing this resource. The author has been notified."); |
$errormsg=&mt("An error occured while processing this resource. The author has been notified."); |
} |
} |
|
my $msg = join('<br />',@_); |
#notify author |
#notify author |
&Apache::lonmsg::author_res_msg($env{'request.filename'},join('<br />',@_)); |
&Apache::lonmsg::author_res_msg($env{'request.filename'},$msg); |
#notify course |
#notify course |
if ( $symb && $env{'request.course.id'} ) { |
if ( $symb && $env{'request.course.id'} ) { |
my $cnum=$env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum=$env{'course.'.$env{'request.course.id'}.'.num'}; |
Line 1595 sub error {
|
Line 1599 sub error {
|
my $now=time; |
my $now=time; |
if ($now-$lastnotified{$key}>86400) { |
if ($now-$lastnotified{$key}>86400) { |
&Apache::lonmsg::user_normal_msg($user,$domain, |
&Apache::lonmsg::user_normal_msg($user,$domain, |
"Error [$declutter]",join('<br />',@_)); |
"Error [$declutter]",$msg); |
&Apache::lonnet::put('nohist_xmlerrornotifications', |
&Apache::lonnet::put('nohist_xmlerrornotifications', |
{$key => $now}, |
{$key => $now}, |
$cdom,$cnum); |
$cdom,$cnum); |