X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/918a888d397a962465dfa834dbd0907ef4b63d4b..v1.10-46-g4c43bcbed6:/source.plp?ds=inline diff --git a/source.plp b/source.plp index f476ee8..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) { - my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || 'span'); + say ''; } else { - require Encode; - print "'; + foreach (@{$hl}) { + my ($type, $contents) = @{$_}; + $contents = decode_utf8($contents); + my $tag = $type && ($TYPETAG{$type} || 'span'); my $arg = ''; - print "<$tag$arg class=\"sy-\l$_->[0]\">" if $tag; - if (!$_->[0] || $_->[0] eq 'Constant' - and $_->[1] =~ s{^(['"]?)(/?[a-z0-9_.]+\.(?:plp?|css|js))(?=\1$)}{}) { - printf '%s%s', $1, "/source/$2", $2; + print "<$tag$arg class=\"sy-\l$type\">" if $tag; + if (!$type || $type eq 'Constant' + and $contents =~ s{^(['"]?)($incname)(?=\1$)}{}) { + # link other page sources, stylesheets, and javascript + print $1 . showlink($2, "/source/$2"); + } + if (!$type and $contents =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { + # link perl module names (Xx::Xx...) + print $1 . showlink($2, "/source/$2"); } - if (!$_->[0] and $_->[1] =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { - printf '%s%s', $1, "/source/$2", $2; + if ($type && $type eq 'Comment' + and $contents =~ s{^(.*? by )(tools/\S+)}{}) { + # link generator scripts (by tools/...) + print $1 . showlink($2, "/source/$2"); } - print Text::VimColor::_xml_escape($_->[1]); + 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 ''; }