--- loncom/xml/lontexconvert.pm 2019/02/15 21:21:03 1.112.2.9 +++ loncom/xml/lontexconvert.pm 2013/09/15 23:06:46 1.113 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # TeX Conversion Module # -# $Id: lontexconvert.pm,v 1.112.2.9 2019/02/15 21:21:03 raeburn Exp $ +# $Id: lontexconvert.pm,v 1.113 2013/09/15 23:06:46 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -54,37 +54,17 @@ use IO::Socket::INET; # # Table of substitutions to unicode characters. # - -my %unicode_harpoons = ( - '\rightleftharpoons' => 0x21cc, - ); - my %unicode_translations = ( + '\rightleftharpoons' => 0x21cc, -# Brackets - unicode for browsers/OS which support it. - - '' => 0x23a1, - '' => 0x23a2, - '' => 0x23a3, - '' => 0x23a4, - '' => 0x23a5, - '' => 0x23a6, - -# Parens - unicode for browsers/OS which support it - - '' => 0x239b, - '' => 0x239c, - '' => 0x239d, - '' => 0x239e, - '' => 0x239f, - '' => 0x23a0, - -); - -my %ascii_8bit_translations = ( - -# Brackets - pure 8-bit ascii ugliness for browsers/OS which can't handle unicode +# Brackets - unicode is commented out with pure 8-bit ascii ugliness while we need it. +# '' => 0x23a1, +# '' => 0x23a2, +# '' => 0x23a3, # when unicode catches up with browsers +# '' => 0x23a4, # use these instead of the cheesey brackets below +# '' => 0x23a5, +# '' => 0x23a6 '' => 0x5b, '' => 0x5b, # '[' '' => 0x5b, @@ -92,14 +72,24 @@ my %ascii_8bit_translations = ( '' => 0x5d, '' => 0x5d, -# Parens - pure 8-bit ascii ugliness for browsers/OS which can't handle unicode +# Parens..again the unicode is commented out with the 8-bit ascii ugliness +# turned on until browsers catch up with the unicode world. + +# '' => 0x239b, +# '' => 0x239c, +# '' => 0x239d, +# '' => 0x239e, +# '' => 0x239f, +# '' => 0x23a0 '' => 0x28, '' => 0x28, # '(' '' => 0x28, + '' => 0x29, '' => 0x29, # '(' - '' => 0x29, + '' => 0x29 + ); @@ -181,33 +171,16 @@ sub convert_real { &Apache::lonxml::end_alarm(); # - # Several strings produced by tth require + # Several strings produced by tth require # transliteration -> unicode equivalents to render reliably - # in browsers. %unicode_translations and %unicode_harpoons are tables of - # string->substitution which we now apply. (%ascii_8bit_translations used - # instead for Windows XP and mobile devices. - - my $use_ascii; - if ($env{'browser.os'} eq 'win') { - if (($env{'browser.osversion'}) && ($env{'browser.osversion'} < 6.0)) { - $use_ascii = 1; - } - } - if ($env{'browser.mobile'}) { - $use_ascii = 1; - } + # in browsers. %unicode_translations is a table of + # string->substitution which we now apply: foreach my $pattern (keys(%unicode_translations)) { my $unicode = $unicode_translations{$pattern}; - if ($use_ascii) { - $unicode = $ascii_8bit_translations{$pattern}; - } $xmlstring = &unicode_subst($xmlstring, $pattern, $unicode); } - foreach my $pattern (keys(%unicode_harpoons)) { - $xmlstring = &unicode_subst($xmlstring, $pattern, $unicode_harpoons{$pattern}); - } return ($xmlstring,$errorstring); } @@ -270,19 +243,11 @@ sub displaystyle { sub MathJax_converted { my $texstring=shift; - my ($tag,$startspan,$endspan); - $tag='math/tex;'; - if (&displaystyle($texstring)) { - $tag='math/tex; mode=display'; - $startspan=''; - $endspan=''; - } else { - $startspan=''; - $endspan=''; - } + my $tag='math/tex;'; + if (&displaystyle($texstring)) { $tag='math/tex; mode=display'; } &clean_out_math_mode($texstring); - return &MathJax_header().$startspan. - ''.$endspan; + return &MathJax_header(). + ''; } { @@ -304,42 +269,89 @@ sub MathJax_converted { return ''."\n"; } + #sub MathJax_process { + # my $state = pop(@MathJax_sent_header); + # return '' if !$state; + # return "\n". + # ''."\n"; + #} + #sub MathJax_state { + # my ($level) = @_; + # return $MathJax_sent_header[$level]; + #} +} + + +sub jsMath_converted { + my $texstring=shift; + my $tag='span'; + if (&displaystyle($texstring)) { $tag='div'; } + &clean_out_math_mode($texstring); + return &jsMath_header(). + '<'.$tag.' class="math">'.$$texstring.''; +} + +{ + my @jsMath_sent_header; + sub jsMath_reset { + undef(@jsMath_sent_header); + } + sub jsMath_push { + push(@jsMath_sent_header,0); + } + sub jsMath_header { + if (!@jsMath_sent_header) { + &Apache::lonnet::logthis("mismatched calls of jsMath_header and jsMath_process"); + return ''; + } + return '' if $jsMath_sent_header[-1]; + $jsMath_sent_header[-1]=1; + return + ''."\n". + ''."\n"; + } + sub jsMath_process { + my $state = pop(@jsMath_sent_header); + return '' if !$state; + return "\n". + ''."\n"; + } + sub jsMath_state { + my ($level) = @_; + return $jsMath_sent_header[$level]; + } } sub tex_engine { if (exists($env{'form.texengine'})) { if ($env{'form.texengine'} ne '') { - if (lc($env{'form.texengine'}) eq 'jsmath') { - return 'MathJax'; - } return $env{'form.texengine'}; } } if ($env{'request.course.id'} && exists($env{'course.'.$env{'request.course.id'}.'.texengine'})) { - if (lc($env{'course.'.$env{'request.course.id'}.'.texengine'}) eq 'jsmath') { - return 'MathJax'; - } return $env{'course.'.$env{'request.course.id'}.'.texengine'}; } if (exists($env{'environment.texengine'})) { - if (lc($env{'environment.texengine'}) eq 'jsmath') { - return 'MathJax'; - } return $env{'environment.texengine'}; } - my $dom = $env{'request.role.domain'} || $env{'user.domain'}; - my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); - if ($domdefaults{'texengine'} ne '') { - return $domdefaults{'texengine'}; - } - return $Apache::lonnet::deftex; + return 'tth'; } sub init_math_support { + my ($inherit_jsmath) = @_; &init_tth(); + &Apache::lontexconvert::jsMath_push(); + if (lc(&tex_engine()) eq 'jsmath' || + ($inherit_jsmath && &jsMath_state(-2))) { + return &Apache::lontexconvert::jsMath_header(); + } &Apache::lontexconvert::MathJax_push(); - if (lc(&tex_engine()) eq 'mathjax') { + if (lc(&tex_engine()) eq 'mathjax') { # || + #($inherit_jsmath && &jsMath_state(-2))) { return &Apache::lontexconvert::MathJax_header(); } return; @@ -401,9 +413,9 @@ sub converted { if ($mode =~ /tth/i) { return &tth_converted($string); } elsif ($mode =~ /jsmath/i) { - return &MathJax_converted($string); + return &jsMath_converted($string); } elsif ($mode =~ /mathjax/i) { - return &MathJax_converted($string); + return &MathJax_converted($string); } elsif ($mode =~ /mimetex/i) { return &mimetex_converted($string); } elsif ($mode =~ /raw/i) { @@ -550,7 +562,7 @@ sub postprocess_algebra { # $string =~s/\\fun/ /g; # sqrt(3,4) means the 4 root of 3 - $string =~s/\\sqrt\{([^,]+),([^\}]+)}/\\sqrt[$2]{$1}/gs; + $string =~s/\\sqrt{([^,]+),([^\}]+)}/\\sqrt[$2]{$1}/gs; # log(3,4) means the log base 4 of 3 $string =~s/\\log\\left\((.+?),(.+?)\\right\)/\\log_{$2}\\left($1\\right)/gs; @@ -568,8 +580,6 @@ sub postprocess_algebra { $string =~s/\\lim\\left\((.+?),(.+?),(.+?)\\right\)/\\lim_{$2\\to $3}$1/gs; return $string; } - - 1; __END__ @@ -612,10 +622,14 @@ Header =item displaystyle() +=item jsMath_converted() + =item MathJax_converted() + - Mimics the jsMath functionality =item tex_engine() + =item init_math_support() =item mimetex_valign()