Diff for /rat/lonratsrv.pm between versions 1.3 and 1.16

version 1.3, 2000/07/05 21:05:28 version 1.16, 2001/11/29 19:23:49
Line 1 Line 1
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 # Server for RAT Maps  # Server for RAT Maps
 #  #
   # $Id$
   #
   # Copyright Michigan State University Board of Trustees
   #
   # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
   #
   # LON-CAPA is free software; you can redistribute it and/or modify
   # it under the terms of the GNU General Public License as published by
   # the Free Software Foundation; either version 2 of the License, or
   # (at your option) any later version.
   #
   # LON-CAPA is distributed in the hope that it will be useful,
   # but WITHOUT ANY WARRANTY; without even the implied warranty of
   # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   # GNU General Public License for more details.
   #
   # You should have received a copy of the GNU General Public License
   # along with LON-CAPA; if not, write to the Free Software
   # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   #
   # /home/httpd/html/adm/gpl.txt
   #
   # http://www.lon-capa.org/
   #
 # (Edit Handler for RAT Maps  # (Edit Handler for RAT Maps
 # (TeX Content Handler  # (TeX Content Handler
 #  #
 # 05/29/00,05/30 Gerd Kortemeyer)  # 05/29/00,05/30 Gerd Kortemeyer)
 # 7/1 Gerd Kortemeyer)  # 7/1 Gerd Kortemeyer)
 # 7/1,7/3,7/4 Gerd Kortemeyer  # 7/1,7/3,7/4,7/7,7/8,7/10,7/26,10/2 Gerd Kortemeyer
   # 4/30/2001 Scott Harrison
   # 5/3,06/25,07/03,07/04,07/05 Gerd Kortemeyer
   
 package Apache::lonratsrv;  package Apache::lonratsrv;
   
Line 16  use Apache::File; Line 42  use Apache::File;
 use HTML::TokeParser;  use HTML::TokeParser;
   
   
 # ---------------------------------------------------------- Escape Quote Chars  # ------------------------------------------------------------- From RAT to XML
   
 sub qtescape {  sub qtescape {
     my $str=shift;      my $str=shift;
     $str =~ s/([\"\%])/"%".unpack('H2',$1)/eg;      $str=~s/\&\#58\;/\:/g;
       $str=~s/\&\#39\;/\'/g;
       $str=~s/\&\#44\;/\,/g;
       $str=~s/\"/\&\#34\;/g;
     return $str;      return $str;
 }  }
   
 # ----------------------------------------------------- Un-Escape Special Chars  # ------------------------------------------------------------- From XML to RAT
   
 sub unescape {  sub qtunescape {
     my $str=shift;      my $str=shift;
     $str =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;      $str=~s/\:/\&colon\;/g;
       $str=~s/\'/\&\#39\;/g;
       $str=~s/\,/\&\#44\;/g;
       $str=~s/\"/\&\#34\;/g;
     return $str;      return $str;
 }  }
   
Line 74  sub loadmap { Line 106  sub loadmap {
                         $obj[$i]=1;                          $obj[$i]=1;
                     }                      }
                     $outstr.='<:>';                      $outstr.='<:>';
                       $outstr.=qtunescape($token->[2]->{'title'}).":";
                       $outstr.=qtunescape($token->[2]->{'src'}).":";
                       if ($token->[2]->{'external'} eq 'true') {
                           $outstr.='true:';
                       } else {
                           $outstr.='false:';
                       }
                       if ($token->[2]->{'type'}) {
    $outstr.=$token->[2]->{'type'}.':';
                       }  else {
                           $outstr.='normal:';
                       }
                       $outstr.='res';
                 } elsif ($token->[1] eq 'condition') {                  } elsif ($token->[1] eq 'condition') {
 # ------------------------------------------------------------------- Condition  # ------------------------------------------------------------------- Condition
                     $outstr.='<&>objcont';                      $outstr.='<&>objcont';
Line 91  sub loadmap { Line 136  sub loadmap {
                         $obj[$i]=1;                          $obj[$i]=1;
                     }                      }
                     $outstr.='<:>';                      $outstr.='<:>';
                       $outstr.=qtunescape($token->[2]->{'value'}).':';
                       if ($token->[2]->{'type'}) {
    $outstr.=$token->[2]->{'type'}.':';
                       } else {
                           $outstr.='normal:';
                       }
                       $outstr.='cond';
                 } elsif ($token->[1] eq 'link') {                  } elsif ($token->[1] eq 'link') {
 # ----------------------------------------------------------------------- Links  # ----------------------------------------------------------------------- Links
                     $outstr.='<&>objlinks';                      $outstr.='<&>objlinks';
                     if ($graphmode) {  
                         if ($token->[2]->{'index'}) {                          if ($token->[2]->{'index'}) {
                            $errtext.='Error: multiple use of link index '.     if ($links[$token->[2]->{'index'}]) {
                                  $errtext.='Error: multiple use of link index '.
        $token->[2]->{'index'}.'. ';         $token->[2]->{'index'}.'. ';
  $outstr.='<:>'.$token->[2]->{'index'};                             }
                         $links[$token->[2]->{'index'}]=1;     $outstr.='<:>'.$token->[2]->{'index'};
                     } else {                             $links[$token->[2]->{'index'}]=1;
                         my $i=1;                          } else {
                         while (($i<=$#links) && ($links[$i]==1)) { $i++; }                             my $i=1;
                         $outstr.='<:>'.$i;                             while (($i<=$#links) && ($links[$i]==1)) { $i++; }
                         $links[$i]=1;                             $outstr.='<:>'.$i;
     }                             $links[$i]=1;
          }
       
                     $outstr.='<:>'.$token->[2]->{'from'}.                      $outstr.='<:>'.$token->[2]->{'from'}.
                              '<:>'.$token->[2]->{'to'};                               ':'.$token->[2]->{'to'};
                     if ($token->[2]->{'condition'}) {                      if ($token->[2]->{'condition'}) {
  $outstr.='<:>'.$token->[2]->{'condition'};   $outstr.=':'.$token->[2]->{'condition'};
                     } else {                      } else {
   $outstr.='<:>0';    $outstr.=':0';
                    }                      }
   # ------------------------------------------------------------------- Parameter
                   } elsif ($token->[1] eq 'param') {
                       $outstr.='<&>objparms<:>'.$token->[2]->{'to'}.'<:>'.
                               $token->[2]->{'type'}.'___'.$token->[2]->{'name'}
                                                    .'___'.$token->[2]->{'value'};
                 } elsif ($graphmode) {                  } elsif ($graphmode) {
 # --------------------------------------------- All other tags (graphical only)  # --------------------------------------------- All other tags (graphical only)
                     $outstr.='<&>'.$token->[1];                      $outstr.='<&>'.$token->[1];
                     if ($token->[2]->{'index'}) {                      if (defined($token->[2]->{'index'})) {
  $outstr.='<:>'.$token->[2]->{'index'};   $outstr.='<:>'.$token->[2]->{'index'};
                         if ($token->[1] eq 'obj') {                          if ($token->[1] eq 'obj') {
     $obj[$token->[2]->{'index'}]=2;      $obj[$token->[2]->{'index'}]=2;
Line 138  sub loadmap { Line 198  sub loadmap {
   
 sub savemap {  sub savemap {
     my ($fn,$errtext)=@_;      my ($fn,$errtext)=@_;
     if (($fn=~/\.course$/) ||      my %alltypes;
         ($fn=~/\.sequence$/) ||      my %allvalues;
       if (($fn=~/\.sequence$/) ||
         ($fn=~/\.page$/)) {          ($fn=~/\.page$/)) {
   
 # ------------------------------------------------------------- Deal with input  # ------------------------------------------------------------- Deal with input
         my @tags=split(/<&>/,$ENV{'form.output'});          my @tags=split(/<&>/,$ENV{'form.output'});
         my $outstr='';          my $outstr='';
Line 157  sub savemap { Line 219  sub savemap {
                my @comp=split(/:/,$parts[$#parts]);                 my @comp=split(/:/,$parts[$#parts]);
 # --------------------------------------------------------------- Logical input  # --------------------------------------------------------------- Logical input
        if ($comp[$#comp] eq 'res') {         if ($comp[$#comp] eq 'res') {
                    $comp[0]=~s/\&\#(\d+)\;/pack("C",$1)/eg;                     $comp[0]=qtescape($comp[0]);
                    $comp[1]=~s/\&\#(\d+)\;/pack("C",$1)/eg;                     $comp[1]=qtescape($comp[1]);
                    if ($comp[2] eq 'true') {                     if ($comp[2] eq 'true') {
        if ($comp[1]!~/^http\:\/\//) {         if ($comp[1]!~/^http\:\/\//) {
    $comp[1]='http://'.$comp[1];     $comp[1]='http://'.$comp[1];
                        }                         }
                          $comp[1].='" external="true';
                    } else {                     } else {
        if ($comp[1]=~/^http\:\/\//) {         if ($comp[1]=~/^http\:\/\//) {
    $comp[1]=~s/^http\:\/\/[^\/]*\//\//;     $comp[1]=~s/^http\:\/\/[^\/]*\//\//;
                        }                         }
                    }                     }
    $outstr.='<resource id="'.$parts[1].'" src="'     $outstr.='<resource id="'.$parts[1].'" src="'
                           .qtescape($comp[1]).'"';                            .$comp[1].'"';
   
                    if (($comp[3] ne '') && ($comp[3] ne 'normal')) {                     if (($comp[3] ne '') && ($comp[3] ne 'normal')) {
        $outstr.=' type="'.$comp[3].'"';         $outstr.=' type="'.$comp[3].'"';
                    }                     }
                    if ($comp[0] ne '') {                     if ($comp[0] ne '') {
        $outstr.=' title="'.qtescape($comp[0]).'"';         $outstr.=' title="'.$comp[0].'"';
                    }                     }
                    $outstr.="></resource>\n";                     $outstr.="></resource>\n";
                } elsif ($comp[$#comp] eq 'cond') {                 } elsif ($comp[$#comp] eq 'cond') {
Line 196  sub savemap { Line 259  sub savemap {
                }                 }
                $outstr.=' index="'.$parts[1].'"';                 $outstr.=' index="'.$parts[1].'"';
                $outstr.="></link>\n";                 $outstr.="></link>\n";
              } elsif ($parts[0] eq 'objparms') {
                  undef %alltypes;
                  undef %allvalues;
                  map {
                      my ($type,$name,$value)=split(/\_\_\_/,$_);
                      $alltypes{$name}=$type;
                      $allvalues{$name}=$value;
                  } split(/:/,$parts[$#parts]);
                  map {
                      $outstr.='<param to="'.$parts[1].'" type="'
                             .$alltypes{$_}.'" name="'.$_
                             .'" value="'.$allvalues{$_}.'">'
                             ."</param>\n";
                  } keys %allvalues;
            } elsif (($parts[0] ne '') && ($graphdef)) {             } elsif (($parts[0] ne '') && ($graphdef)) {
 # ------------------------------------------------------------- Graphical input  # ------------------------------------------------------------- Graphical input
                $outstr.='<'.$parts[0];                 $outstr.='<'.$parts[0];
Line 253  sub handler { Line 330  sub handler {
 <form name=storage method=post action="$url">  <form name=storage method=post action="$url">
 <input type=hidden name=output value="$outtext">  <input type=hidden name=output value="$outtext">
 </form>  </form>
   <script>
       parent.flag=1;
   </script>
 ENDDOCUMENT  ENDDOCUMENT
     if ($errtext ne '') {      if ($errtext ne '') {
  $r->print(<<ENDSCRIPT);   $r->print(<<ENDSCRIPT);
Line 268  ENDSCRIPT Line 348  ENDSCRIPT
   
 1;  1;
 __END__  __END__
   
   
   
   
   
   
   

Removed from v.1.3  
changed lines
  Added in v.1.16


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