From f291602d62f584128349e17e1fd0163c946189ab Mon Sep 17 00:00:00 2001 From: Mischa POSLAWSKY Date: Sun, 29 Oct 2023 02:39:42 +0200 Subject: [PATCH] source: cache file names without package include paths --- source.plp | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/source.plp b/source.plp index d7d7cb5..b586dbe 100644 --- a/source.plp +++ b/source.plp @@ -65,6 +65,7 @@ else { say "

Source of $href

"; }; + my $path = $source; if ($source =~ m{(?:/|^)\.}) { Abort("File request not permitted", '403 source not allowed'); } @@ -72,15 +73,15 @@ else { $source .= '.pm'; for (0 .. $#INC) { -e ($_ = "$INC[$_]/$source") or next; - $source = $_; + $path = $_; last; } } - -r $source or Abort("Requested file not found", '404 source not found'); - my $size = (stat $source)->[7]; + -r $path or Abort("Requested file not found", '404 source not found'); + my $size = (stat $path)->[7]; my $cachefile = "source/$source.html"; - if (-e $cachefile and (stat $cachefile)->[9] >= (stat $source)->[9]) { + if (-e $cachefile and (stat $cachefile)->[9] >= (stat $path)->[9]) { say '
';
 		print ReadFile($cachefile);
 		say '
'; @@ -97,7 +98,7 @@ else { or die 'early versions are buggy under FastCGI'; delete $Text::VimColor::SYNTAX_TYPE{Underlined}; return Text::VimColor->new( - file => $source, + file => $path, vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'], )->marked; }) { @@ -133,7 +134,7 @@ else { } else { say '
';
-		print EscapeHTML(decode_utf8(ReadFile($source)));
+		print EscapeHTML(decode_utf8(ReadFile($path)));
 		say '
'; } -- 2.30.0