--- loncom/homework/structuretags.pm 2003/06/13 14:01:26 1.183
+++ loncom/homework/structuretags.pm 2003/07/17 18:42:13 1.198
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# definition of tags that give a structure to a document
#
-# $Id: structuretags.pm,v 1.183 2003/06/13 14:01:26 albertel Exp $
+# $Id: structuretags.pm,v 1.198 2003/07/17 18:42:13 sakharuk Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -38,7 +38,8 @@ use Apache::File();
use Apache::lonmenu;
BEGIN {
- &Apache::lonxml::register('Apache::structuretags',('block','languageblock','instructorcomment','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext'));
+ &Apache::lonxml::register('Apache::structuretags',('block','languageblock','instructorcomment','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext',
+'simpleeditbutton','definetag'));
}
sub start_web {
@@ -56,12 +57,15 @@ sub end_web {
sub start_tex {
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
- if (!($target eq 'tex' || $target eq 'edit' || $target eq 'modified' ||
+ my $result='';
+ if (!($target eq 'edit' || $target eq 'modified' ||
$target eq 'answer' || $target eq 'grade' || $target eq 'meta' )) {
&Apache::lonxml::debug("tex 1");
my $bodytext=&Apache::lonxml::get_all_text("/tex",$parser);
+ } elsif ($target eq 'tex') {
+ $result=&Apache::lonxml::get_all_text("/tex",$parser);
}
- return '';
+ return $result;;
}
sub end_tex {
@@ -149,15 +153,15 @@ sub setup_rndseed {
}
if ($ENV{'form.resetdata'} eq 'New Problem Variation' ||
$ENV{'form.newrandomization'} eq 'New Randomization') {
- $rndseed=time;
- if ($rndseed eq $ENV{'form.rndseed'}) {
- srand($rndseed);
- $rndseed=int(rand(1000000000));
- }
+ srand(time);
+ $rndseed=int(rand(2100000000));
$ENV{'form.rndseed'}=$rndseed;
delete($ENV{'form.resetdata'});
delete($ENV{'form.newrandomization'});
}
+ if (defined($rndseed) && $rndseed ne int($rndseed)) {
+ $rndseed=join(',',&Math::Random::random_seed_from_phrase($rndseed));
+ }
&Apache::lonxml::debug("Setting rndseed to $rndseed");
&Apache::run::run('$external::randomseed='.$rndseed.';',$safeeval);
}
@@ -266,12 +270,14 @@ ENDCHECKOUT
sub start_problem {
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
- $Apache::lonhomework::parsing_a_problem=1;
- if ( $Apache::inputtags::part ne '' ) {
- &Apache::lonxml::error('Only one problem allowed in a .problem file');
- my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);
+ if ( $Apache::inputtags::part ne '' ||
+ $Apache::lonhomework::parsing_a_problem) {
+ &Apache::lonxml::error('Only one <problem> allowed in a .problem file');
+ #my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser);
return '';
}
+
+ $Apache::lonhomework::parsing_a_problem=1;
#initialize globals
$Apache::inputtags::part='0';
@Apache::inputtags::partlist=('0');
@@ -345,7 +351,7 @@ sub start_problem {
''.
'';
+ value="'.$ENV{'form.username'}.'" />
';
}
($status,$accessmsg) = &Apache::lonhomework::check_access('0');
push (@Apache::inputtags::status,$status);
@@ -388,7 +394,7 @@ sub start_problem {
$body_tag_start \n $form_tag_start".
'';
if ($ENV{'request.state'} eq "construct") {
- $result.= &problem_web_to_edit_header($rndseed);
+ $result.= &problem_web_to_edit_header($ENV{'form.rndseed'});
}
# if we are viewing someone else preserve that info
if (defined $ENV{'form.grade_symb'}) {
@@ -404,7 +410,7 @@ sub start_problem {
}
} elsif ($target eq 'tex') {
my $startminipage = '';
- if ($ENV{'form.problem_split'} ne 'yes') {
+ if (not $ENV{'form.problem_split'}=~/yes/) {
$startminipage = '\begin{minipage}{\textwidth}';
}
my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval);
@@ -502,7 +508,8 @@ sub end_problem {
}
} elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' ||
$status eq 'UNCHECKEDOUT' ) {
- if ($target ne 'tex') {
+ if ($target ne 'tex' &&
+ $ENV{'form.answer_output_mode'} ne 'tex') {
$result.="