X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/108d13f833e9daeff4ea1552e2e1bee1e0ed8c22..cd726ba1120253b6387e1a558f36ba78f3cd8cbd:/source.plp diff --git a/source.plp b/source.plp index 38af1fa..ef730a4 100644 --- a/source.plp +++ b/source.plp @@ -1,6 +1,7 @@ <(common.inc.plp)><: my $source = $Request; +my $incname = qr{ [a-z][/a-z0-9_.-]* \.(?:plp?|css|js|txt) }x; if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) { # convert perl include to json construct @@ -36,6 +37,7 @@ Html({ sheet cheat source code perl plp html agpl '], stylesheet => [qw'light dark mono red'], + data => [$source =~ m{\A($incname)\z}], }); say ''; @@ -47,12 +49,13 @@ if (not $source) { say '\n"; } else { - say "

Source of $source

"; + my $href = showlink($source, $source =~ m{\A (\w+) \.plp \z}x && "/$1"); + say "

Source of $href

"; if ($source =~ m{(?:/|^)\.}) { die "File request not permitted\n"; @@ -66,41 +69,45 @@ else { } } -r $source or die "Requested file not found\n"; + my $size = (stat $source)->[7]; - require Encode; - if (eval { require Text::VimColor and Text::VimColor->VERSION(0.12) }) { + if (my $hl = eval { + $size < 32_768 or die 'large files take too long to parse'; + require Text::VimColor; + Text::VimColor->VERSION(0.12) + or die 'early versions are buggy under FastCGI'; delete $Text::VimColor::SYNTAX_TYPE{Underlined}; + return Text::VimColor->new( + file => $source, + vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'], + )->marked; + }) { my %TYPETAG = ( Statement => 'strong', Error => 'em', Todo => 'em', ); - my $hl = Text::VimColor->new( - file => $source, - vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'], - ); - my $parsed = $hl->marked; say '
';
-		foreach (@$parsed) {
+		foreach (@{$hl}) {
 			my ($type, $contents) = @{$_};
-			$contents = Encode::decode_utf8($contents);
+			$contents = decode_utf8($contents);
 			my $tag = $type && ($TYPETAG{$type} || 'span');
 			my $arg = '';
 			print "<$tag$arg class=\"sy-\l$type\">" if $tag;
 			if (!$type || $type eq 'Constant'
-			and $contents =~ s{^(['"]?)(/?[a-z0-9_.]+\.(?:plp?|css|js))(?=\1$)}{}) {
+			and $contents =~ s{^(['"]?)($incname)(?=\1$)}{}) {
 				# link other page sources, stylesheets, and javascript
-				printf '%s%s', $1, "/source/$2", $2;
+				print $1 . showlink($2, "/source/$2");
 			}
 			if (!$type and $contents =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) {
 				# link perl module names (Xx::Xx...)
-				printf '%s%s', $1, "/source/$2", $2;
+				print $1 . showlink($2, "/source/$2");
 			}
 			if ($type && $type eq 'Comment'
 			and $contents =~ s{^(.*? by )(tools/\S+)}{}) {
 				# link generator scripts (by tools/...)
-				printf '%s%s', $1, "/source/$2", $2;
+				print $1 . showlink($2, "/source/$2");
 			}
 			print Text::VimColor::_xml_escape($contents);
 			print "" if $tag;
@@ -109,7 +116,7 @@ else {
 	}
 	else {
 		say '
';
-		print EscapeHTML(Encode::decode_utf8(ReadFile($source)));
+		print EscapeHTML(decode_utf8(ReadFile($source)));
 		say '
'; }