--- loncom/xml/lonxml.pm 2000/11/01 17:25:36 1.31 +++ loncom/xml/lonxml.pm 2000/11/06 18:42:38 1.35 @@ -2,9 +2,11 @@ # XML Parser Module # # last modified 06/26/00 by Alexander Sakharuk +# 11/6 Gerd Kortemeyer package Apache::lonxml; - +use vars +qw(@pwd $outputstack $redirection $textredirection $on_offimport @extlinks); use strict; use HTML::TokeParser; use Safe; @@ -26,16 +28,20 @@ use Apache::run; use Apache::londefdef; use Apache::scripttag; #================================================== Main subroutine: xmlparse -@Apache::lonxml::pwd=(); -$Apache::lonxml::outputstack = ''; -$Apache::lonxml::redirection = 1; -$Apache::lonxml::textredirection = 1; - +@pwd=(); +$outputstack = ''; +$redirection = 1; +$textredirection = 1; +$on_offimport = 0; +@extlinks=(); sub xmlparse { my ($target,$content_file_string,$safeinit,%style_for_target) = @_; - if ($target eq 'meta') {$Apache::lonxml::textredirection = 0;} + if ($target eq 'meta') + {$Apache::lonxml::textredirection = 0; + $Apache::lonxml::on_offimport = 1; + } my @pars = (); @Apache::lonxml::pwd=(); my $pwd=$ENV{'request.filename'}; @@ -290,13 +296,24 @@ sub parstring { my ($token) = @_; my $temp=''; map { - if ($_=~/\w+/) { + unless ($_=~/\W/) { $temp .= "my \$$_=\"$token->[2]->{$_}\";" } } @{$token->[3]}; return $temp; } +sub writeallows { + my $thisurl='/res/'.&Apache::lonnet::declutter(shift); + my $thisdir=$thisurl; + $thisdir=~s/\/[^\/]+$//; + my %httpref=(); + map { + $httpref{'httpref.'. + &Apache::lonnet::hreflocation($thisdir,$_)}=$thisurl; } @extlinks; + &Apache::lonnet::appenv(%httpref); +} + sub handler { my $request=shift; @@ -332,6 +349,7 @@ sub handler { $request->print(''); $request->print(&Apache::lontexconvert::footer()); + writeallows($request->uri); return 'OK'; }