version 1.74, 2006/05/18 22:13:50
|
version 1.91, 2008/11/24 17:17:51
|
Line 45 use vars qw($errorstring);
|
Line 45 use vars qw($errorstring);
|
#use Apache::lonxml(); |
#use Apache::lonxml(); |
use Apache::lonlocal; |
use Apache::lonlocal; |
use Apache::lonnet; |
use Apache::lonnet; |
|
use lib '/home/httpd/lib/perl/'; |
|
use LONCAPA; |
|
|
|
|
# ====================================================================== Header |
# ====================================================================== Header |
|
|
Line 76 sub init_tth {
|
Line 79 sub init_tth {
|
|
|
$Apache::lontexconvert::messedup=0; |
$Apache::lontexconvert::messedup=0; |
|
|
# we need this routine because &converted can get called from inside |
|
# of the safespace (through &xmlparse('<m>stuff</m>') which doesn't |
|
# allow the opcode for alarm, so we need to compile this before we get |
|
# into the safe space since opcode checks only occur at compile time |
|
sub convert_real { |
sub convert_real { |
my ($texstring)=@_; |
my ($texstring)=@_; |
my ($xmlstring,$errorstring); |
my ($xmlstring,$errorstring); |
Line 105 sub convert_real {
|
Line 105 sub convert_real {
|
$xmlstring=~s/^\s*\<br clear\=\"all\"/\<br/s; |
$xmlstring=~s/^\s*\<br clear\=\"all\"/\<br/s; |
$xmlstring=~s/^\s*//; |
$xmlstring=~s/^\s*//; |
$xmlstring=~s/\s*$//; |
$xmlstring=~s/\s*$//; |
|
# |
|
# \rightleftharpoons is not converted by tth but maps |
|
# reasonably well to ⇔. If we get many more of these, |
|
# we're going to need to have a translation sub. |
|
# |
|
my $lrharpoon = pack("U", 0x21cc); |
|
$xmlstring=~s/\\rightleftharpoons/$lrharpoon/g; |
|
|
&Apache::lonxml::end_alarm(); |
&Apache::lonxml::end_alarm(); |
return ($xmlstring,$errorstring); |
return ($xmlstring,$errorstring); |
} |
} |
Line 148 ENDCONV
|
Line 156 ENDCONV
|
|
|
sub clean_out_math_mode { |
sub clean_out_math_mode { |
my ($texstring)=@_; |
my ($texstring)=@_; |
$$texstring=~s/(?!\\)\$//g; |
$$texstring=~s/(?<!\\)\$//g; |
$$texstring=~s/\\[\)\(\]\[]//g; |
$$texstring=~s/\\[\)\(\]\[]//g; |
$$texstring=~s/\\ensuremath//g; |
$$texstring=~s/\\ensuremath//g; |
return ''; |
return ''; |
Line 173 sub jsMath_converted {
|
Line 181 sub jsMath_converted {
|
} |
} |
|
|
{ |
{ |
my $jsMath_sent_header; |
my @jsMath_sent_header; |
sub jsMath_reset { |
sub jsMath_reset { |
$jsMath_sent_header=0; |
undef(@jsMath_sent_header); |
|
} |
|
sub jsMath_push { |
|
push(@jsMath_sent_header,0); |
} |
} |
sub jsMath_header { |
sub jsMath_header { |
return '' if $jsMath_sent_header; |
if (!@jsMath_sent_header) { |
$jsMath_sent_header=1; |
&Apache::lonnet::logthis("mismatched calls of jsMath_header and jsMath_process"); |
|
return ''; |
|
} |
|
return '' if $jsMath_sent_header[-1]; |
|
$jsMath_sent_header[-1]=1; |
return |
return |
'<script type="text/javascript"> |
'<script type="text/javascript"> |
function NoFontMessage () {} |
function NoFontMessage () {} |
|
jsMath = {Parser: {prototype: {environments: {\'eqnarray*\' :[\'Array\',null,null,\'rcl\',[5/18,5/18],3,\'D\']}}}}; |
</script>'."\n". |
</script>'."\n". |
'<script type="text/javascript" src="/adm/jsMath/jsMath.js"></script>'."\n"; |
'<script type="text/javascript" src="/adm/jsMath/jsMath.js"></script>'."\n"; |
} |
} |
sub jsMath_process { |
sub jsMath_process { |
return '' if !$jsMath_sent_header; |
my $state = pop(@jsMath_sent_header); |
return '<script type="text/javascript">jsMath.Process()</script>'; |
return '' if !$state; |
|
return "\n". |
|
'<script type="text/javascript">jsMath.Process()</script>'."\n"; |
|
} |
|
sub jsMath_state { |
|
my ($level) = @_; |
|
return $jsMath_sent_header[$level]; |
|
} |
|
} |
|
|
|
sub tex_engine { |
|
if (exists($env{'form.texengine'})) { |
|
if ($env{'form.texengine'} ne '') { |
|
return $env{'form.texengine'}; |
|
} |
|
} |
|
if ($env{'request.course.id'} |
|
&& exists($env{'course.'.$env{'request.course.id'}.'.texengine'})) { |
|
return $env{'course.'.$env{'request.course.id'}.'.texengine'}; |
|
} |
|
if (exists($env{'environment.texengine'})) { |
|
return $env{'environment.texengine'}; |
} |
} |
|
return 'tth'; |
} |
} |
|
|
sub init_math_support { |
sub init_math_support { |
|
my ($inherit_jsmath) = @_; |
&init_tth(); |
&init_tth(); |
&Apache::lontexconvert::jsMath_reset(); |
&Apache::lontexconvert::jsMath_push(); |
if ($env{'environment.texengine'} eq 'jsMath' || |
if (lc(&tex_engine()) eq 'jsmath' || |
$env{'form.texengine'} eq 'jsMath' ) { |
($inherit_jsmath && &jsMath_state(-2))) { |
return &Apache::lontexconvert::jsMath_header(); |
return &Apache::lontexconvert::jsMath_header(); |
} |
} |
return; |
return; |
Line 211 sub mimetex_converted {
|
Line 250 sub mimetex_converted {
|
if ($displaystyle) { |
if ($displaystyle) { |
$$texstring='\\displaystyle \\Large '.$$texstring; |
$$texstring='\\displaystyle \\Large '.$$texstring; |
} |
} |
my $result='<img src="/cgi-bin/mimetex.cgi?'.&Apache::lonnet::escape($$texstring).'" />'; |
my $result='<img src="/cgi-bin/mimetex.cgi?'.&escape($$texstring).'" alt="$'.$$texstring.'$" />'; |
if ($displaystyle) { |
if ($displaystyle) { |
$result='<center>'.$result.'</center>'; |
$result='<center>'.$result.'</center>'; |
} |
} |
Line 220 sub mimetex_converted {
|
Line 259 sub mimetex_converted {
|
|
|
sub converted { |
sub converted { |
my ($string,$mode)=@_; |
my ($string,$mode)=@_; |
if ($mode eq '') { $mode=$env{'environment.texengine'}; } |
if ($mode eq '') { $mode = &tex_engine(); } |
if ($mode =~ /tth/i) { |
if ($mode =~ /tth/i) { |
return &tth_converted($string); |
return &tth_converted($string); |
} elsif ($mode =~ /jsmath/i) { |
} elsif ($mode =~ /jsmath/i) { |
Line 259 sub smiley {
|
Line 298 sub smiley {
|
'\:\-(X|\#)' => 'lipsrsealed', |
'\:\-(X|\#)' => 'lipsrsealed', |
'\:\-S' => 'huh'); |
'\:\-S' => 'huh'); |
my $iconpath=$Apache::lonnet::perlvar{'lonIconsURL'}; |
my $iconpath=$Apache::lonnet::perlvar{'lonIconsURL'}; |
foreach (keys %smileys) { |
foreach my $smiley (keys(%smileys)) { |
$expression=~s/$_/\<img src="$iconpath\/$smileys{$_}.gif" \/\>/gs; |
$expression=~s/$smiley/\<img src="$iconpath\/$smileys{$smiley}.gif" \/\>/gs; |
} |
} |
return $expression; |
return $expression; |
} |
} |
Line 271 sub msgtexconverted {
|
Line 310 sub msgtexconverted {
|
&init_tth(); |
&init_tth(); |
my $outmessage=''; |
my $outmessage=''; |
my $tex=0; |
my $tex=0; |
foreach (split(/(?:\<\;|\<)\/*m\s*(?:\>\;|\>)/i,$message)) { |
foreach my $fragment (split(/(?:\<\;|\<)\/*m\s*(?:\>\;|\>)/i,$message)) { |
if ($tex) { |
if ($tex) { |
if ($email) { |
if ($email) { |
$outmessage.='</pre><tt>'.&to_convert($_).'</tt><pre>'; $tex=0; |
$outmessage.='</pre><tt>'.&to_convert($fragment).'</tt><pre>'; |
|
$tex=0; |
} else { |
} else { |
$outmessage.=&to_convert($_); $tex=0; |
$outmessage.=&to_convert($fragment); |
|
$tex=0; |
} |
} |
} else { |
} else { |
$outmessage.=&smiley($_); $tex=1; |
$outmessage.=&smiley($fragment); |
|
$tex=1; |
} |
} |
} |
} |
$message=$outmessage; $outmessage=''; $tex=0; |
$message=$outmessage; $outmessage=''; $tex=0; |
foreach (split(/(?:\<\;|\<)\/*algebra\s*(?:\>\;|\>)/i,$message)) { |
foreach my $fragment (split(/(?:\<\;|\<)\/*algebra\s*(?:\>\;|\>)/i, |
|
$message)) { |
if ($tex) { |
if ($tex) { |
if ($email) { |
if ($email) { |
$outmessage.='</pre><tt>'.&algebra($_,'web').'</tt><pre>'; $tex=0; |
$outmessage.='</pre><tt>'.&algebra($fragment,'web').'</tt><pre>'; |
|
$tex=0; |
} else { |
} else { |
$outmessage.=&algebra($_,'web'); $tex=0; |
$outmessage.=&algebra($fragment,'web'); |
|
$tex=0; |
} |
} |
} else { |
} else { |
$outmessage.=$_; $tex=1; |
$outmessage.=$fragment; |
|
$tex=1; |
} |
} |
} |
} |
if (wantarray) { |
if (wantarray) { |
Line 304 sub msgtexconverted {
|
Line 350 sub msgtexconverted {
|
sub algebra { |
sub algebra { |
use AlgParser; |
use AlgParser; |
|
|
my ($string,$target,$style)=@_; |
my ($string,$target,$style,$parstack,$safeeval)=@_; |
my $parser = new AlgParserWithImplicitExpand; |
my $parser = new AlgParserWithImplicitExpand; |
$string=&prepare_algebra($string); |
$string=&prepare_algebra($string); |
my $ret = $parser->parse($string); |
my $ret = $parser->parse($string); |
Line 321 sub algebra {
|
Line 367 sub algebra {
|
$latex='\\ensuremath{'.$latex.'}'; |
$latex='\\ensuremath{'.$latex.'}'; |
} |
} |
if ($target eq 'web' || $target eq 'analyze') { |
if ($target eq 'web' || $target eq 'analyze') { |
$result = &converted(\$latex); |
my $display=&Apache::lonxml::get_param('display',$parstack,$safeeval); |
|
$result = &converted(\$latex,$display); |
|
# $result = &converted(\$latex); |
} else { |
} else { |
$result = $latex; |
$result = $latex; |
} |
} |
Line 345 sub postprocess_algebra {
|
Line 393 sub postprocess_algebra {
|
# moodle had these and I don't know why, ignoring them for now |
# moodle had these and I don't know why, ignoring them for now |
# $string =~s/\\fun/ /g; |
# $string =~s/\\fun/ /g; |
|
|
# remove the extra () in the denominator of a \frac |
|
$string =~s/\\frac{(.+?)}{\\left\((.+?)\\right\)}/\\frac{$1}{$2}/gs; |
|
|
|
# sqrt(3,4) means the 4 root of 3 |
# sqrt(3,4) means the 4 root of 3 |
$string =~s/\\sqrt{([^,]+),([^\}]+)}/\\sqrt[$2]{$1}/gs; |
$string =~s/\\sqrt{([^,]+),([^\}]+)}/\\sqrt[$2]{$1}/gs; |
|
|
Line 371 sub postprocess_algebra {
|
Line 416 sub postprocess_algebra {
|
__END__ |
__END__ |
|
|
|
|
|
=pod |
|
|
|
=head1 NAME |
|
|
|
Apache::lontexconvert; |
|
|
|
=head1 SYNOPSIS |
|
|
|
Access to tth/ttm |
|
|
|
This is part of the LearningOnline Network with CAPA project |
|
described at http://www.lon-capa.org. |
|
|
|
|
|
=head1 SUBROUTINES |
|
|
|
=over |
|
|
|
=item init_tth() |
|
|
|
Header |
|
|
|
=item convert_real() |
|
|
|
we need this routine because &converted can get called from inside |
|
of the safespace (through &xmlparse('<m>stuff</m>') which doesn't |
|
allow the opcode for alarm, so we need to compile this before we get |
|
into the safe space since opcode checks only occur at compile time |
|
|
|
=item tth_converted() |
|
|
|
|
|
=item clean_out_math_mode() |
|
|
|
|
|
=item displaystyle() |
|
|
|
|
|
=item jsMath_converted() |
|
|
|
|
|
=item tex_engine() |
|
|
|
|
|
=item init_math_support() |
|
|
|
|
|
=item mimetex_converted() |
|
|
|
|
|
=item converted() |
|
|
|
|
|
=item to_convert() |
|
|
|
message display |
|
|
|
=item smiley() |
|
|
|
??? |
|
|
|
=item msgtexconverted() |
|
|
|
=item algebra() |
|
|
|
=item prepare_algebra() |
|
|
|
=item postprocess_algebra() |
|
|
|
=back |
|
|
|
=cut |
|
|
|
|
|
|