X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/108d13f833e9daeff4ea1552e2e1bee1e0ed8c22..94fea8c0e6ba8cea67d69dd0e49142811bba1611:/source.plp?ds=sidebyside 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 '
'; - 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 "$tag>" if $tag; @@ -109,7 +116,7 @@ else { } else { say ''; - print EscapeHTML(Encode::decode_utf8(ReadFile($source))); + print EscapeHTML(decode_utf8(ReadFile($source))); say ''; }