--- rat/lonratsrv.pm 2001/04/30 15:44:44 1.8 +++ rat/lonratsrv.pm 2001/07/04 19:59:24 1.14 @@ -8,6 +8,7 @@ # 7/1 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 Gerd Kortemeyer package Apache::lonratsrv; @@ -24,7 +25,7 @@ sub qtescape { $str=~s/\&\#58\;/\:/g; $str=~s/\&\#39\;/\'/g; $str=~s/\&\#44\;/\,/g; - $str=~s/\"/\&\#34\;/g; + $str=~s/\&\#34\;/\"/g; return $str; } @@ -32,7 +33,7 @@ sub qtescape { sub qtunescape { my $str=shift; - $str=~s/\:/\&\#58\;/g; + $str=~s/\:/\&colon\;/g; $str=~s/\'/\&\#39\;/g; $str=~s/\,/\&\#44\;/g; $str=~s/\"/\&\#34\;/g; @@ -83,7 +84,7 @@ sub loadmap { $outstr.='<:>'; $outstr.=qtunescape($token->[2]->{'title'}).":"; $outstr.=qtunescape($token->[2]->{'src'}).":"; - if ($token->[2]->{'src'}=~/\/\//) { + if ($token->[2]->{'external'} eq 'true') { $outstr.='true:'; } else { $outstr.='false:'; @@ -143,6 +144,11 @@ sub loadmap { } else { $outstr.=':0'; } +# ------------------------------------------------------------------- Parameter + } elsif ($token->[1] eq 'param') { + $outstr.='<&>objparms<:>'.$token->[2]->{'to'}.'<:>'. + $token->[2]->{'type'}.'___'.$token->[2]->{'name'} + .'___'.$token->[2]->{'value'}; } elsif ($graphmode) { # --------------------------------------------- All other tags (graphical only) $outstr.='<&>'.$token->[1]; @@ -168,6 +174,8 @@ sub loadmap { sub savemap { my ($fn,$errtext)=@_; + my %alltypes; + my %allvalues; if (($fn=~/\.sequence$/) || ($fn=~/\.page$/)) { @@ -193,6 +201,7 @@ sub savemap { if ($comp[1]!~/^http\:\/\//) { $comp[1]='http://'.$comp[1]; } + $comp[1].='" external="true'; } else { if ($comp[1]=~/^http\:\/\//) { $comp[1]=~s/^http\:\/\/[^\/]*\//\//; @@ -226,6 +235,20 @@ sub savemap { } $outstr.=' index="'.$parts[1].'"'; $outstr.=">\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.='' + ."\n"; + } keys %allvalues; } elsif (($parts[0] ne '') && ($graphdef)) { # ------------------------------------------------------------- Graphical input $outstr.='<'.$parts[0]; @@ -271,11 +294,9 @@ sub handler { my $fn=$r->filename; my $errtext=''; my $outtext=''; - my $onload=''; if ($mode ne 'loadonly') { $errtext=&savemap($fn,$errtext); -# $onload='onLoad="parent.code.srvloaded();"'; } ($outtext,$errtext)=&loadmap($fn,$errtext); @@ -286,7 +307,7 @@ sub handler { ENDDOCUMENT if ($errtext ne '') { @@ -303,10 +324,3 @@ ENDSCRIPT 1; __END__ - - - - - - -