--- loncom/interface/lonhelp.pm 2002/07/05 16:12:31 1.1 +++ loncom/interface/lonhelp.pm 2002/07/08 20:47:41 1.2 @@ -56,11 +56,13 @@ $r->print(<LON-CAPA Help + HEADER $r->print($tex); $r->print(< FOOTER @@ -70,8 +72,8 @@ FOOTER # HTML equivalent sub render { - my ($tex) = @_; - tie (my %fragmentLabels, 'GDBM_File', '/home/httpd/html/adm/help/fragmentLabels.gdbm', 0, 0); + my ($tex, $docroot, $serverroot) = @_; + tie (my %fragmentLabels, 'GDBM_File', $docroot . '/adm/help/fragmentLabels.gdbm', 0, 0); # This tells TtH what to do with captions, labels, and other # things @@ -79,16 +81,18 @@ sub render # We process these ourselves because TtH can't handle then without # LaTeX .aux files + # absolute paths for use with help.loncapa.org $tex =~ s| \\ref\{([^}]*)\} - |'\\href{' . + |'\\begin{html}' . + '\\end{html}' |gxe; # Figures leftover without captions $tex =~ s| \\includegraphics(\[[^]]*\])*\{([^}]*)\} - | '\\begin{html}\\end{html}' |gxe; @@ -104,11 +108,13 @@ sub render return $tex; } -# UNCOMMENT FOR HANDLER ONLY sub handler { my $r = shift; + my $docroot = $r->dir_config('lonDocRoot'); + my $serverroot = $ENV{'HTTP_HOST'}; + my $filename = substr ($ENV{'REQUEST_URI'} , rindex($ENV{'REQUEST_URI'}, '/') + 1, -4); @@ -118,10 +124,10 @@ sub handler return 404 if ($filename !~ /\A[-0-9a-zA-z_'',.]+\Z/); - (my $file = Apache::File->new("/home/httpd/html/adm/help/tex/".$filename.'.tex')) + (my $file = Apache::File->new($docroot . "/adm/help/tex/".$filename.'.tex')) or return 404; my $tex = join('', <$file>); - $tex = render($tex); + $tex = render($tex, $docroot, $serverroot); $r->content_type("text/html"); serveTex($tex, $r);