X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/84f0630eace132ded7af839105d7e2d096eba5ad..v1.10-46-g4c43bcbed6:/source.plp?ds=sidebyside diff --git a/source.plp b/source.plp index 418a2c1..ef730a4 100644 --- a/source.plp +++ b/source.plp @@ -1,7 +1,7 @@ <(common.inc.plp)><: -my $source = $ENV{PATH_INFO}; -$source =~ s{^/}{}; +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 @@ -28,7 +28,7 @@ if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) { Html({ title => "$source source code", - version => 'v1.1', + version => '1.1', description => !$source ? 'Index of source files for this site.' : [ "Source code of the $source file at this site,", "with syntax highlighted and references linked." @@ -37,23 +37,25 @@ Html({ sheet cheat source code perl plp html agpl '], stylesheet => [qw'light dark mono red'], + data => [$source =~ m{\A($incname)\z}], }); -print "\n"; +say ''; if (not $source) { print "
Project code distributed under the AGPL. Please contribute back.
"; - print '\n"; - foreach (@$parsed) { + say ''; } else { - print "'; + 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 "$tag>" if $tag; } - print "\n"; + say '
\n"; - print EscapeHTML(Encode::decode_utf8(ReadFile($source))); - print "\n"; + say '
'; + print EscapeHTML(decode_utf8(ReadFile($source))); + say ''; } - print "\n"; + say ''; }