version 1.40, 2001/06/02 03:59:59
|
version 1.48, 2001/07/30 22:24:56
|
Line 2
|
Line 2
|
# <script> definiton |
# <script> definiton |
# 2/21 Guy |
# 2/21 Guy |
|
|
package Apache::scripttag; |
package Apache::scripttag; |
|
|
use strict; |
use strict; |
use Apache::lonnet; |
use Apache::lonnet; |
|
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', |
'window','display')); |
'window','display', |
|
'storetc','physnet')); |
} |
} |
|
|
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"); |
if ($type eq "loncapa/perl") { |
if ($type eq "loncapa/perl") { |
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].$bodytext; |
$result=$token->[4].&Apache::edit::modifiedfield(); |
} elsif ( $target eq "web" || $target eq "grade" ) { |
} elsif ( $target eq "web" || $target eq "grade" ) { |
&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); |
$result="<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
#$result="<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',50,5); |
$result=&Apache::edit::tag_start($target,$token,'Script'); |
|
$result.=&Apache::edit::editfield($token->[1],$bodytext,'',50,4); |
} |
} |
} else { |
} else { |
if ($target ne "meta") { $result = $token->[4]; } |
if ($target ne "meta") { $result = $token->[4]; } |
Line 43 sub end_script {
|
Line 51 sub end_script {
|
my $result=''; |
my $result=''; |
#other script blocks need to survive |
#other script blocks need to survive |
if ($type ne "loncapa/perl") { return $token->[2]; } |
if ($type ne "loncapa/perl") { return $token->[2]; } |
|
if ($target eq 'edit' ) { return &Apache::edit::end_table(); } |
return ''; |
return ''; |
} |
} |
|
|
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" ) { |
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 120 sub start_parserlib {
|
Line 134 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') { |
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, |
Line 168 sub start_window {
|
Line 181 sub start_window {
|
if ($target eq 'web') { |
if ($target eq 'web') { |
&Apache::lonxml::startredirection; |
&Apache::lonxml::startredirection; |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
$result = '\footnote{'; |
$result = '\unskip\footnote{'; |
} |
} |
return $result; |
return $result; |
} |
} |
Line 194 sub start_import {
|
Line 207 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') { |
$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 { |
sub start_storetc { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result = ''; |
my $result = ''; |
if ($target ne 'meta') { |
&Apache::lonxml::startredirection; |
$result = &Apache::lonxml::get_all_text("/meta",$$parser[$#$parser]); |
return $result; |
$result = ''; |
} |
return $result; |
|
} else { |
sub end_storetc { |
return $result; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
|
my $result; |
|
my $output=&Apache::lonxml::endredirection; |
|
$output =~ s/\"/\"\;/g; |
|
$result = "{\bf $output.}}\write\tcfile{\protect\tcpc{ $output.}{\the\value{relpage}}}"; |
|
return $result; |
|
} |
|
|
|
|
|
sub start_physnet { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
|
my $bodytext = '/msu/physnet/cbi.sty'; |
|
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'}) ) { |
|
&Apache::lonxml::newparser($parser,\$$style{'physnet'}); |
} |
} |
|
return ""; |
} |
} |
|
|
sub end_meta { |
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; |