--- loncom/xml/lonxml.pm 2002/07/01 15:29:23 1.179 +++ loncom/xml/lonxml.pm 2002/08/23 19:10:32 1.188 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # XML Parser Module # -# $Id: lonxml.pm,v 1.179 2002/07/01 15:29:23 matthew Exp $ +# $Id: lonxml.pm,v 1.188 2002/08/23 19:10:32 sakharuk Exp $ # # Copyright Michigan State University Board of Trustees # @@ -176,6 +176,7 @@ sub xmlend { unless (($hidden) && (!$seeid)) { my $message=$contrib{$idx.':message'}; $message=~s/\n/\
/g; + $message=&Apache::lontexconvert::msgtexconverted($message); if ($message) { if ($hidden) { $message=''.$message.''; @@ -332,7 +333,8 @@ sub registerurl { my $target = shift; my $result = ''; if ($target eq 'edit') { - $result .="\n"; } @@ -346,7 +348,7 @@ sub registerurl { $Apache::lonxml::registered=1; my $nothing=''; if ($ENV{'browser.type'} eq 'explorer') { $nothing='javascript:void(0);'; } - my $timesync='menu.clock.setTime(1000*'.time.');'; + my $timesync='menu.syncclock(1000*'.time.');'; if (($ENV{'REQUEST_URI'}!~/^\/(res\/)*adm\//) || ($forcereg)) { my $hwkadd=''; if ($ENV{'request.filename'}=~/\.(problem|exam|quiz|assess|survey|form)$/) { @@ -384,7 +386,7 @@ ENDPARM menu.switchbutton (8,1,'eval.gif','evaluate','this','gopost("/adm/evaluate",currentURL)'); menu.switchbutton - (8,2,'fdbk.gif','feedback','on this','gopost("/adm/feedback",currentURL)'); + (8,2,'fdbk.gif','feedback','discuss','gopost("/adm/feedback",currentURL)'); menu.switchbutton (8,3,'prt.gif','prepare','printout','gopost("/adm/printout",currentURL)'); menu.switchbutton @@ -537,6 +539,23 @@ sub htmlclean { return $output; } +sub latex_special_sumbols { + my ($current_token,$stack,$parstack)=@_; + my @temp_array = @$stack; + if ($temp_array[-1] ne 'tt') { + if ($current_token=~m/\^/) {$current_token=~s/\^/\\verb|\^|/g;} + } else { + if ($current_token=~m/\^/) {$current_token=~s/\^/}\\verb|\^|{/g;} + } + if ($current_token=~m/>/) {$current_token=~s/>/\$>\$/g;} + if ($current_token=~m/get_token) { if (($token->[0] eq 'T') || ($token->[0] eq 'C') || ($token->[0] eq 'D') ) { if ($metamode<1) { - $result=$token->[1]; + if ($target eq 'tex') { + $result.=&latex_special_sumbols($token->[1],$stack,$parstack); + } else { + $result.=$token->[1]; + } } } elsif ($token->[0] eq 'PI') { if ($metamode<1) { @@ -933,8 +956,34 @@ sub decreasedepth { #print "
e $Apache::lonxml::depth : $Apache::lonxml::olddepth : $token->[1] : $curdepth\n"; } -sub get_all_text { +sub get_all_text_unbalanced { + my($tag,$pars)= @_; + my $token; + my $result=''; + $tag='<'.$tag.'>'; + while ($token = $$pars[-1]->get_token) { + if (($token->[0] eq 'T')||($token->[0] eq 'C')||($token->[0] eq 'D')) { + $result.=$token->[1]; + } elsif ($token->[0] eq 'PI') { + $result.=$token->[2]; + } elsif ($token->[0] eq 'S') { + $result.=$token->[4]; + } elsif ($token->[0] eq 'E') { + $result.=$token->[2]; + } + if ($result =~ /(.*)$tag(.*)/) { + &Apache::lonxml::debug('Got a winner with leftovers ::'.$2); + &Apache::lonxml::debug('Result is :'.$1); + $result=$1; + my $redo=$tag.$2; + &Apache::lonxml::newparser($pars,\$redo); + last; + } + } + return $result +} +sub get_all_text { my($tag,$pars)= @_; my $depth=0; my $token; @@ -1225,7 +1274,7 @@ ENDNOTFOUND sub debug { if ($Apache::lonxml::debug eq 1) { $|=1; - print("DEBUG:".join('
',@_)."
\n"); + print("DEBUG:".&HTML::Entities::encode($_[0])."
\n"); } }