X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/e98b059d1f6bbd6ac8ca06de152959536e4b98b0..c7399071b5121ddded1209d9978a6f044f4e5ecc:/source.plp diff --git a/source.plp b/source.plp index db3a400..56193fb 100644 --- a/source.plp +++ b/source.plp @@ -1,54 +1,65 @@ -<: -use utf8; -use strict; -use warnings; +<(common.inc.plp)><: -our $VERSION = 'v1.0'; +my $source = $Request; -$header{content_type} = "text/html; charset=utf-8"; +if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) { + # convert perl include to json construct + checkmodified($source); + eval { + my $data = do $source or die $@ || $! || 'read error'; + require JSON; + my $converter = JSON->new; + $converter->utf8->indent->space_after->canonical; -:> - - -
- -Project code distributed under the AGPL. Please contribute back.
"; - print '\n"; - foreach (@$parsed) { - my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || 'span'); - my $arg = ''; - print "<$tag$arg class=\"sy-\l$_->[0]\">" if $tag; - if ($_->[0] eq 'Constant' - and $_->[1] =~ s{^(['"])(/?[a-z0-9_.]+\.(?:plp?|css|js))(?=\1$)}{}) { - printf '%s%s', $1, "/source/$2", $2; - } - if (!$_->[0] and $_->[1] =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { - printf '%s%s', $1, "/source/$2", $2; + my $hl = Text::VimColor->new( + file => $source, + vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'], + ); + my $parsed = $hl->marked; + say '\n"; + else { + say ''; + foreach (@$parsed) { + my ($type, $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$)}{}) { + # link other page sources, stylesheets, and javascript + printf '%s%s', $1, "/source/$2", $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; + } + if ($type && $type eq 'Comment' + and $contents =~ s{^(.*? by )(tools/\S+)}{}) { + # link generator scripts (by tools/...) + printf '%s%s', $1, "/source/$2", $2; + } + print Text::VimColor::_xml_escape($contents); + print "$tag>" if $tag; } - print Text::VimColor::_xml_escape($_->[1]); - print "$tag>" if $tag; + say ''; } - print "
'; + print EscapeHTML(decode_utf8(ReadFile($source))); + say ''; + } + + say ''; } -:> - -