Diff for /loncom/xml/lonxml.pm between versions 1.100 and 1.106

version 1.100, 2001/07/05 15:53:09 version 1.106, 2001/08/07 16:54:14
Line 12 Line 12
 # 6/2,6/3,6/8,6/9 Gerd Kortemeyer  # 6/2,6/3,6/8,6/9 Gerd Kortemeyer
 # 6/12,6/13 H. K. Ng  # 6/12,6/13 H. K. Ng
 # 6/16 Gerd Kortemeyer  # 6/16 Gerd Kortemeyer
   # 7/27 H. K. Ng
   # 8/7 Gerd Kortemeyer
   
 package Apache::lonxml;   package Apache::lonxml; 
 use vars   use vars 
 qw(@pwd @outputstack $redirection $import @extlinks $metamode $evaluate %insertlist @namespace);  qw(@pwd @outputstack $redirection $import @extlinks $metamode $evaluate %insertlist @namespace);
 use strict;  use strict;
 use HTML::TokeParser;  use HTML::TokeParser;
   use HTML::TreeBuilder;
 use Safe;  use Safe;
 use Safe::Hole;  use Safe::Hole;
 use Math::Cephes qw(:trigs :hypers :bessels erf erfc);  use Math::Cephes qw(:trigs :hypers :bessels erf erfc);
Line 92  sub xmlbegin { Line 95  sub xmlbegin {
 }  }
   
 sub xmlend {  sub xmlend {
     return '</html>';      my $discussion='';
       if ($ENV{'request.course.id'}) {
          my $symb=&Apache::lonnet::symbread();
          if ($symb) {
             my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'},
                        $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
        $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
             if ($contrib{'version'}) {
                 $discussion.=
                     '<address><hr /><h2>Course Discussion of Resource</h2>';
                 my $idx;
                 for ($idx=1;$idx<=$contrib{'version'};$idx++) {
                     my $message=$contrib{$idx.':message'};
                     $message=~s/\n/\<br \/\>/g;
     $discussion.='<p><b>'.$contrib{$idx.':sendername'}.' at '.
         $contrib{$idx.':senderdomain'}.'</b> ('.
                         localtime($contrib{$idx.':timestamp'}).
                         '):<blockquote>'.$message.
                         '</blockquote></p>'; 
                 }
                 $discussion.='</address>';
             }
          }
       }
       return $discussion.'</html>';
 }  }
   
 sub fontsettings() {  sub fontsettings() {
Line 107  sub fontsettings() { Line 134  sub fontsettings() {
 sub registerurl {  sub registerurl {
     my $forcereg=shift;      my $forcereg=shift;
     if ($Apache::lonxml::registered) { return ''; }      if ($Apache::lonxml::registered) { return ''; }
       $Apache::lonxml::registered=1;
     if (($ENV{'REQUEST_URI'}!~/^\/(res\/)*adm\//) || ($forcereg)) {      if (($ENV{'REQUEST_URI'}!~/^\/(res\/)*adm\//) || ($forcereg)) {
         my $hwkadd='';          my $hwkadd='';
         if ($ENV{'REQUEST_URI'}=~/\.(problem|exam|quiz|assess|survey|form)$/) {          if ($ENV{'REQUEST_URI'}=~/\.(problem|exam|quiz|assess|survey|form)$/) {
Line 234  sub xmlparse { Line 262  sub xmlparse {
  &setup_globals($target);   &setup_globals($target);
  #&printalltags();   #&printalltags();
  my @pars = ();   my @pars = ();
  @Apache::lonxml::pwd=();  
  my $pwd=$ENV{'request.filename'};   my $pwd=$ENV{'request.filename'};
  $pwd =~ s:/[^/]*$::;   $pwd =~ s:/[^/]*$::;
  &newparser(\@pars,\$content_file_string,$pwd);   &newparser(\@pars,\$content_file_string,$pwd);
  my $currentstring = '';  
  my $finaloutput = '';   
  my $newarg = '';  
  my $result;  
   
  my $safeeval = new Safe;   my $safeeval = new Safe;
  my $safehole = new Safe::Hole;   my $safehole = new Safe::Hole;
Line 253  sub xmlparse { Line 276  sub xmlparse {
  my @stack = ();    my @stack = (); 
  my @parstack = ();   my @parstack = ();
  &initdepth;   &initdepth;
  my $token;  
  while ( $#pars > -1 ) {  
    while ($token = $pars[$#pars]->get_token) {  
      if (($token->[0] eq 'T') || ($token->[0] eq 'C') || ($token->[0] eq 'D') ) {  
        if ($metamode<1) { $result=$token->[1]; }  
      } elsif ($token->[0] eq 'PI') {  
        if ($metamode<1) { $result=$token->[2]; }  
      } elsif ($token->[0] eq 'S') {  
        # add tag to stack      
        push (@stack,$token->[1]);  
        # add parameters list to another stack  
        push (@parstack,&parstring($token));  
        &increasedepth($token);         
        if (exists $style_for_target{$token->[1]}) {  
  if ($Apache::lonxml::redirection) {  
    $Apache::lonxml::outputstack['-1'] .=    
      &recurse($style_for_target{$token->[1]},$target,$safeeval,  
       \%style_for_target,@parstack);  
  } else {  
    $finaloutput .= &recurse($style_for_target{$token->[1]},$target,  
     $safeeval,\%style_for_target,@parstack);  
  }  
        } else {  
  $result = &callsub("start_$token->[1]", $target, $token, \@stack,  
     \@parstack, \@pars, $safeeval, \%style_for_target);  
        }                
      } elsif ($token->[0] eq 'E')  {  
        #clear out any tags that didn't end  
        while ($token->[1] ne $stack[$#stack] && ($#stack > -1)) {  
  &Apache::lonxml::warning("Unbalanced tags in resource $stack['-1']");  
  &end_tag(\@stack,\@parstack,$token);  
        }  
          
        if (exists $style_for_target{'/'."$token->[1]"}) {  
  if ($Apache::lonxml::redirection) {  
    $Apache::lonxml::outputstack['-1'] .=    
      &recurse($style_for_target{'/'."$token->[1]"},  
       $target,$safeeval,\%style_for_target,@parstack);  
  } else {  
    $finaloutput .= &recurse($style_for_target{'/'."$token->[1]"},  
     $target,$safeeval,\%style_for_target,  
     @parstack);  
  }  
   
        } else {  
  $result = &callsub("end_$token->[1]", $target, $token, \@stack,   
     \@parstack, \@pars,$safeeval, \%style_for_target);  
        }  
      } else {  
        &Apache::lonxml::error("Unknown token event :$token->[0]:$token->[1]:");  
      }  
      #evaluate variable refs in result  
      if ($result ne "") {  
        if ( $#parstack > -1 ) {  
  if ($Apache::lonxml::redirection) {  
    $Apache::lonxml::outputstack['-1'] .=   
      &Apache::run::evaluate($result,$safeeval,$parstack[$#parstack]);  
  } else {  
    $finaloutput .= &Apache::run::evaluate($result,$safeeval,  
   $parstack[$#parstack]);  
  }  
        } else {  
  $finaloutput .= &Apache::run::evaluate($result,$safeeval,'');  
        }  
        $result = '';  
      }   
      if ($token->[0] eq 'E') {   
        &end_tag(\@stack,\@parstack,$token);  
      }  
    }  
    pop @pars;  
    pop @Apache::lonxml::pwd;  
  }  
   
 # if ($target eq 'meta') {  
 #   $finaloutput.=&endredirection;  
 # }  
   
   if (($ENV{'QUERY_STRING'}) && ($target eq 'web')) {   my $finaloutput = &inner_xmlparse($target,\@stack,\@parstack,\@pars,
       $finaloutput=&afterburn($finaloutput);     $safeeval,\%style_for_target);
   }  
   
  return $finaloutput;   return $finaloutput;
 }  }
   
   sub htmlclean {
       my $raw=shift;
   
       my $tree = HTML::TreeBuilder->new;
       $tree->ignore_unknown(0);
       
       $tree->parse($raw);
       my %emptyhash=();
   
       my $output= $tree->as_HTML(undef,' ',\%emptyhash), "\n";
        
       $output=~s/\<(br|hr|img)([^\>\/]*)\>/\<$1$2 \/\>/gis;
       $output=~s/\<\/(br|hr|img)\>//gis;
       $output=~s/\<[\/]*(body|head|html)\>//gis;
   
       $tree = $tree->delete;
   
       return $output;
   }
   
   sub inner_xmlparse {
     my ($target,$stack,$parstack,$pars,$safeeval,$style_for_target)=@_;
     &Apache::lonxml::debug('Reentrant parser starting, again?');
     my $finaloutput = '';
     my $result;
     my $token;
     while ( $#$pars > -1 ) {
       while ($token = $$pars['-1']->get_token) {
         if (($token->[0] eq 'T') || ($token->[0] eq 'C') || ($token->[0] eq 'D') ) {
    if ($metamode<1) {
     $result=$token->[1];
    }
         } elsif ($token->[0] eq 'PI') {
    if ($metamode<1) {
     $result=$token->[2];
    }
         } elsif ($token->[0] eq 'S') {
    # add tag to stack    
    push (@$stack,$token->[1]);
    # add parameters list to another stack
    push (@$parstack,&parstring($token));
    &increasedepth($token);       
    if (exists $$style_for_target{$token->[1]}) {
     if ($Apache::lonxml::redirection) {
       $Apache::lonxml::outputstack['-1'] .=  
         &recurse($$style_for_target{$token->[1]},$target,$safeeval,
          $style_for_target,@$parstack);
     } else {
       $finaloutput .= &recurse($$style_for_target{$token->[1]},$target,
        $safeeval,$style_for_target,@$parstack);
     }
    } else {
     $result = &callsub("start_$token->[1]", $target, $token, $stack,
        $parstack, $pars, $safeeval, $style_for_target);
    }              
         } elsif ($token->[0] eq 'E') {
    #clear out any tags that didn't end
    while ($token->[1] ne $$stack['-1'] && ($#$stack > -1)) {
     &Apache::lonxml::warning("Unbalanced tags in resource $$stack['-1']");
     &end_tag($stack,$parstack,$token);
    }
   
    if (exists $$style_for_target{'/'."$token->[1]"}) {
     if ($Apache::lonxml::redirection) {
       $Apache::lonxml::outputstack['-1'] .=  
         &recurse($$style_for_target{'/'."$token->[1]"},
          $target,$safeeval,$style_for_target,@$parstack);
     } else {
       $finaloutput .= &recurse($$style_for_target{'/'."$token->[1]"},
        $target,$safeeval,$style_for_target,
        @$parstack);
     }
       
    } else {
     $result = &callsub("end_$token->[1]", $target, $token, $stack,
        $parstack, $pars,$safeeval, $style_for_target);
    }
         } else {
    &Apache::lonxml::error("Unknown token event :$token->[0]:$token->[1]:");
         }
         #evaluate variable refs in result
         if ($result ne "") {
    if ( $#$parstack > -1 ) {
     if ($Apache::lonxml::redirection) {
       $Apache::lonxml::outputstack['-1'] .= 
         &Apache::run::evaluate($result,$safeeval,$$parstack['-1']);
     } else {
       $finaloutput .= &Apache::run::evaluate($result,$safeeval,
      $$parstack['-1']);
     }
    } else {
     $finaloutput .= &Apache::run::evaluate($result,$safeeval,'');
    }
    $result = '';
         } 
         if ($token->[0] eq 'E') { 
    &end_tag($stack,$parstack,$token);
         }
       }
       pop @$pars;
       pop @Apache::lonxml::pwd;
     }
   
     # if ($target eq 'meta') {
     #   $finaloutput.=&endredirection;
     # }
   
     if (($ENV{'QUERY_STRING'}) && ($target eq 'web')) {
       $finaloutput=&afterburn($finaloutput);
     }
     return $finaloutput;
   }
   
 sub recurse {  sub recurse {
     
   my @innerstack = ();     my @innerstack = (); 
   my @innerparstack = ();    my @innerparstack = ();
   my ($newarg,$target,$safeeval,$style_for_target,@parstack) = @_;    my ($newarg,$target,$safeeval,$style_for_target,@parstack) = @_;
Line 470  sub callsub { Line 526  sub callsub {
 sub setup_globals {  sub setup_globals {
   my ($target)=@_;    my ($target)=@_;
   $Apache::lonxml::registered = 0;    $Apache::lonxml::registered = 0;
     @Apache::lonxml::pwd=();
   if ($target eq 'meta') {    if ($target eq 'meta') {
     $Apache::lonxml::redirection = 0;      $Apache::lonxml::redirection = 0;
     $Apache::lonxml::metamode = 1;      $Apache::lonxml::metamode = 1;
Line 504  sub init_safespace { Line 561  sub init_safespace {
   $safeeval->permit(":base_math");    $safeeval->permit(":base_math");
   $safeeval->permit("sort");    $safeeval->permit("sort");
   $safeeval->deny(":base_io");    $safeeval->deny(":base_io");
     $safehole->wrap(\&Apache::scripttag::xmlparse,$safeeval,'&xmlparse');
   $safehole->wrap(\&Apache::lonnet::EXT,$safeeval,'&EXT');    $safehole->wrap(\&Apache::lonnet::EXT,$safeeval,'&EXT');
       
   $safehole->wrap(\&Math::Cephes::asin,$safeeval,'&asin');    $safehole->wrap(\&Math::Cephes::asin,$safeeval,'&asin');

Removed from v.1.100  
changed lines
  Added in v.1.106


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>