--- rat/lonpage.pm 2000/10/19 10:09:59 1.14 +++ rat/lonpage.pm 2000/10/31 19:31:42 1.15 @@ -5,7 +5,7 @@ # # 05/29/00,05/30 Gerd Kortemeyer) # 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, -# 10/02,10/10,10/14,10/16,10/18,10/19 Gerd Kortemeyer +# 10/02,10/10,10/14,10/16,10/18,10/19,10/31 Gerd Kortemeyer package Apache::lonpage; @@ -180,6 +180,8 @@ sub handler { my $xmlheader=''; my $xmlbody=''; + my %httpref=(); + # --------------------------------------------- Get SSI output, post parameters for ($i=0;$i<=$#rows;$i++) { @@ -213,6 +215,7 @@ sub handler { my $bodydef=0; my $thisxml=0; my @rlinks=(); + my @alinks=(); if ($output=~/\?xml/) { $isxml=1; $thisxml=1; @@ -230,9 +233,23 @@ sub handler { } elsif ($token->[1] eq 'img') { $rlinks[$#rlinks+1]= $token->[2]->{'src'}; + $alinks[$#alinks+1]= + $token->[2]->{'src'}; } elsif ($token->[1] eq 'embed') { $rlinks[$#rlinks+1]= $token->[2]->{'src'}; + $alinks[$#alinks+1]= + $token->[2]->{'src'}; + } elsif ($token->[1] eq 'applet') { + $alinks[$#alinks+1]= + $token->[2]->{'code'}; + $alinks[$#alinks+1]= + $token->[2]->{'archive'}; + } elsif ($token->[1] eq 'param') { + if ($token->[2]->{'name'} eq 'cabbase') { + $alinks[$#alinks+1]= + $token->[2]->{'value'}; + } } elsif ($token->[1] eq 'base') { $thisdir=$token->[2]->{'href'}; } elsif ($token->[1] eq 'body') { @@ -272,6 +289,11 @@ sub handler { $output=~s/(\"|\'|\=\s*)$_(\"|\'|\s|\>)/$1$newlocation$2/; } } @rlinks; + map { + $httpref{'httpref.'. + &Apache::lonnet::hreflocation($thisdir,$_)}= + $r->uri; + } @alinks; $output=~s/\<\s*applet/\content_type('text/xml');