X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/0aaffaf050bd5ca5ce5b5caf9e8dec1e8a1b7a48..a46b407f9c8f13a890c6349f78d1dd4e0c10c4f1:/source.plp diff --git a/source.plp b/source.plp index de3ad54..469f49e 100644 --- a/source.plp +++ b/source.plp @@ -1,28 +1,45 @@ <(common.inc.plp)><: - our $VERSION = 'v1.0'; - my $source = $ENV{PATH_INFO}; - $source =~ s{^/}{}; +my $source = $ENV{PATH_INFO}; +$source =~ s{^/}{}; -:> - +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; -
- -\n"; foreach (@$parsed) { - my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || 'span'); + my ($type, $contents) = @{$_}; + $contents = Encode::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$)}{}) { + print "<$tag$arg class=\"sy-\l$type\">" if $tag; + if (!$type || $type eq 'Constant' + and $contents =~ 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])//) { + if (!$type and $contents =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { printf '%s%s', $1, "/source/$2", $2; } - print Text::VimColor::_xml_escape($_->[1]); + print Text::VimColor::_xml_escape($contents); print "$tag>" if $tag; } print "\n"; } else { - print "
\n", EscapeHTML(ReadFile($source)), "\n"; + print "
\n"; + print EscapeHTML(Encode::decode_utf8(ReadFile($source))); + print "\n"; } + + print "\n"; } -:> - -