version 1.44, 2001/07/09 04:10:30
|
version 1.51, 2001/09/18 02:21:13
|
Line 1
|
Line 1
|
# The LearningOnline Network with CAPA |
# The LearningOnline Network with CAPA |
# <script> definiton |
# <script> definiton |
# 2/21 Guy |
# 2/21 Guy |
|
# 8/20 Gerd Kortemeyer |
|
|
package Apache::scripttag; |
package Apache::scripttag; |
|
|
use strict; |
use strict; |
use Apache::lonnet; |
use Apache::lonnet; |
use Apache::style; |
use Apache::style; |
|
|
|
#Globals |
|
# this used to pass around the standard callsub arguments to a tag func |
|
# so xmlparse can reenter the inner_xmlparse loop. |
|
|
|
@Apache::scripttag::parser_env = (); |
sub BEGIN { |
sub BEGIN { |
&Apache::lonxml::register('Apache::scripttag',('script','scriptlib', |
&Apache::lonxml::register('Apache::scripttag',('script','scriptlib', |
'parserlib','import', |
'parserlib','import', |
Line 17 sub BEGIN {
|
Line 23 sub BEGIN {
|
|
|
sub start_script { |
sub start_script { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
@Apache::scripttag::parser_env = @_; |
my $result=''; |
my $result=''; |
my $type= &Apache::lonxml::get_param('type',$parstack,$safeeval); |
my $type= &Apache::lonxml::get_param('type',$parstack,$safeeval); |
&Apache::lonxml::debug("found type of $type"); |
&Apache::lonxml::debug("found type of $type"); |
Line 24 sub start_script {
|
Line 31 sub start_script {
|
my $bodytext=&Apache::lonxml::get_all_text("/script",$$parser[$#$parser]); |
my $bodytext=&Apache::lonxml::get_all_text("/script",$$parser[$#$parser]); |
if ( $target eq "modified" ) { |
if ( $target eq "modified" ) { |
$result=$token->[4].&Apache::edit::modifiedfield(); |
$result=$token->[4].&Apache::edit::modifiedfield(); |
} elsif ( $target eq "web" || $target eq "grade" ) { |
} elsif ( $target eq "web" || $target eq "grade" || $target eq 'answer') { |
&Apache::run::run($bodytext,$safeeval); |
&Apache::run::run($bodytext,$safeeval); |
} elsif ($target eq "edit" ) { |
} elsif ($target eq "edit" ) { |
#&Apache::run::run($bodytext,$safeeval); |
#&Apache::run::run($bodytext,$safeeval); |
Line 52 sub end_script {
|
Line 59 sub end_script {
|
sub start_display { |
sub start_display { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
|
my $result; |
my $bodytext=&Apache::lonxml::get_all_text("/display",$$parser[$#$parser]); |
my $bodytext=&Apache::lonxml::get_all_text("/display",$$parser[$#$parser]); |
|
|
if ( $target eq "modified" ) { |
if ( $target eq "modified" ) { |
} |
$result=$token->[4].&Apache::edit::modifiedfield(); |
my $result=&Apache::run::run($bodytext,$safeeval); |
} elsif ( $target eq "web" || $target eq "grade" || $target eq 'answer') { |
if ($target eq 'grade' ) { |
$result=&Apache::run::run($bodytext,$safeeval); |
# grade should produce no output |
if ($target eq 'grade' ) { |
$result=''; |
$result=''; # grade should produce no output |
} |
} |
if ($target eq "edit" ) { |
} elsif ($target eq "edit" ) { |
$result = |
#$result = |
"<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
# "<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',40,1); |
#$result.=&Apache::edit::editfield($token->[1],$bodytext,'',40,1); |
|
$result=&Apache::edit::tag_start($target,$token,'Script With Display'); |
|
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',40,1) |
} |
} |
return $result; |
return $result; |
} |
} |
|
|
sub end_display { |
sub end_display { |
return '' |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
if ($target eq 'edit' ) { return &Apache::edit::end_table(); } |
|
return ''; |
} |
} |
|
|
sub start_scriptlib { |
sub start_scriptlib { |
Line 79 sub start_scriptlib {
|
Line 91 sub start_scriptlib {
|
my $result =''; |
my $result =''; |
my $error=''; |
my $error=''; |
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit' || $target eq 'answer') { |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$$parstack[$#$parstack]); |
$$parstack[$#$parstack]); |
Line 99 sub start_scriptlib {
|
Line 111 sub start_scriptlib {
|
} |
} |
if ($target eq "edit" ) { |
if ($target eq "edit" ) { |
$result= |
$result= |
&Apache::edit::tag_start($target,$token). |
&Apache::edit::tag_start($target,$token,'New Script Functions'). |
&Apache::edit::editfield($token->[1],$bodytext,'New Script Functions',40,1). |
&Apache::edit::editfield($token->[1],$bodytext,'',40,1). |
$error; |
$error.'</td></tr>'. |
|
&Apache::edit::end_table(); |
} |
} |
if ($target eq "modified" ) { |
if ($target eq "modified" ) { |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
Line 113 sub start_scriptlib {
|
Line 126 sub start_scriptlib {
|
|
|
sub end_scriptlib { |
sub end_scriptlib { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result=''; |
my @result; |
# if ($target eq "edit" ) { $result=" "; } |
if ($target eq "edit" ) { $result[1]='no'; } |
return $result; |
return @result; |
} |
} |
|
|
sub start_parserlib { |
sub start_parserlib { |
Line 123 sub start_parserlib {
|
Line 136 sub start_parserlib {
|
my $bodytext; |
my $bodytext; |
my $result =""; |
my $result =""; |
my $error=''; |
my $error=''; |
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit' || $target eq 'answer') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit') { |
|
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$$parstack[$#$parstack]); |
$$parstack[$#$parstack]); |
Line 144 sub start_parserlib {
|
Line 156 sub start_parserlib {
|
} |
} |
if ($target eq "edit" ) { |
if ($target eq "edit" ) { |
$result= |
$result= |
&Apache::edit::tag_start($target,$token). |
&Apache::edit::tag_start($target,$token,'New Tag Definitions'). |
&Apache::edit::editfield($token->[1],$bodytext,"New Tag Definitions",40,1). |
&Apache::edit::editfield($token->[1],$bodytext,'',40,1). |
$error; |
$error.'</td></tr>'. |
|
&Apache::edit::end_table(); |
} |
} |
if ($target eq "modified" ) { |
if ($target eq "modified" ) { |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
Line 158 sub start_parserlib {
|
Line 171 sub start_parserlib {
|
|
|
sub end_parserlib { |
sub end_parserlib { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result=''; |
my @result; |
# if ($target eq "edit" ) { |
if ($target eq "edit" ) { $result[1]='no'; } |
# $result=&Apache::edit::tag_end($target,$token); |
return @result; |
# } |
|
return $result; |
|
} |
} |
|
|
sub start_window { |
sub start_window { |
Line 197 sub start_import {
|
Line 208 sub start_import {
|
my $result =""; |
my $result =""; |
|
|
$bodytext=Apache::run::evaluate($bodytext,$safeeval,$$parstack[$#$parstack]); |
$bodytext=Apache::run::evaluate($bodytext,$safeeval,$$parstack[$#$parstack]); |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
|
my $file=&Apache::lonnet::getfile($location); |
|
if ($file == -1) { |
|
&Apache::lonxml::error("<b> Unable to find <i>$bodytext $location</i> for import</b>"); |
|
return ""; |
|
} |
|
|
|
my $dir=$location; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer') { |
$dir=~s:/[^/]*$::; |
# FIXME this probably needs to be smart about construction vs. |
# &Apache::lonxml::debug("directory $dir $location file $file \n<b>END</b>\n"); |
# non construction space. |
&Apache::lonxml::newparser($parser,\$file,$dir); |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
|
my $file=&Apache::lonnet::getfile($location); |
|
if ($file == -1) { |
|
&Apache::lonxml::error("<b> Unable to find <i>$bodytext as $location</i> for import</b>"); |
|
return ""; |
|
} |
|
|
|
my $dir=$location; |
|
$dir=~s:/[^/]*$::; |
|
# &Apache::lonxml::debug("directory $dir $location file $file \n<b>END</b>\n"); |
|
&Apache::lonxml::newparser($parser,\$file,$dir); |
|
} |
if ($target eq "edit" ) { |
if ($target eq "edit" ) { |
|
$result.=&Apache::edit::tag_start($target,$token); |
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',40,1); |
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',40,1); |
$result.="Click<a href=\"/res/$bodytext\">here</a> to edit<br />" |
#FIXME this need to convert $bodytext to be a contruction space reference |
|
#my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
|
#$result.="Click<a href=\"$location\">here</a> to edit<br />" |
} |
} |
return ''; |
if ($target eq 'modified') { |
|
$bodytext=$$parser[$#$parser]->get_text("/import"); |
|
$result=&Apache::edit::modifiedfield($token); |
|
&Apache::lonxml::debug($result); |
|
} |
|
return $result; |
} |
} |
|
|
sub end_import { |
sub end_import { |
} |
return ''; |
|
|
sub start_meta { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
|
my $result = ''; |
|
if ($target ne 'meta') { |
|
$result = &Apache::lonxml::get_all_text("/meta",$$parser[$#$parser]); |
|
$result = ''; |
|
return $result; |
|
} else { |
|
return $result; |
|
} |
|
} |
|
|
|
sub end_meta { |
|
} |
} |
|
|
sub start_storetc { |
sub start_storetc { |
Line 252 sub end_storetc {
|
Line 261 sub end_storetc {
|
|
|
|
|
sub start_physnet { |
sub start_physnet { |
|
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $cbistylefile = &Apache::lonnet::getfile('/home/httpd/res/msu/physnet/cbi.sty'); |
my $bodytext = '/adm/includes/physnet.sty'; |
%$style = (%$style,&Apache::style::styleparser($target,$cbistylefile)); |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
|
my $cbistyletext=&Apache::lonnet::getfile($location); |
|
|
|
%$style = (%$style,&Apache::style::styleparser($target,$cbistyletext)); |
if ( defined($$style{'physnet'}) ) { |
if ( defined($$style{'physnet'}) ) { |
&Apache::lonxml::newparser($parser,$$style{'physnet'}); |
&Apache::lonxml::newparser($parser,\$$style{'physnet'}); |
} |
} |
|
return ""; |
|
} |
|
|
return ''; |
sub end_physnet { |
|
return ''; |
} |
} |
|
|
|
sub xmlparse { |
|
my ($string) = @_; |
|
&Apache::lonxml::debug("Got $string"); |
|
my ($target,$token,$tagstack,$parstack,$oldparser,$safeeval,$style)= |
|
@Apache::scripttag::parser_env; |
|
my @parser; |
|
&Apache::lonxml::newparser(\@parser,\$string); |
|
my $result=&Apache::lonxml::inner_xmlparse($target,$tagstack, |
|
$parstack,\@parser, |
|
$safeeval,$style); |
|
return $result; |
|
} |
|
|
1; |
1; |
__END__ |
__END__ |