X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/55c75a0c53862083d5d3c52b6ef6e6efa2864c7e..193d10e6034b48611e9ce97d07bcfdf0eef08a65:/source.plp diff --git a/source.plp b/source.plp index aad6898..f476ee8 100644 --- a/source.plp +++ b/source.plp @@ -1,88 +1,110 @@ -<: -use utf8; -use strict; -use warnings; +<(common.inc.plp)><: -our $VERSION = 'v1.0'; +my $source = $ENV{PATH_INFO}; +$source =~ s{^/}{}; -$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; -:> - + $header{content_type} = 'application/json'; + $header{content_type} = 'text/plain' if exists $get{debug}; + print $_, '(' for $get{callback} // (); + print $converter->encode($data); + print ')' for $get{callback} // (); + return 1; + } or do { + $header{status} = '500 File unavailable'; + $header{content_type} = 'text/plain'; + print "Conversion failed: $@"; + }; + exit; +} -
- -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=\"syn$_->[0]\">" if $tag; - if ($_->[0] eq 'Constant' and $_->[1] =~ s/^(')([a-z0-9_.]+\.plp?)(?=\1$)//) { - printf '%s%s', $1, "/source/$2", $2; + if (eval { require Text::VimColor and Text::VimColor->VERSION(0.12) }) { + delete $Text::VimColor::SYNTAX_TYPE{Underlined}; + my %TYPETAG = ( + Statement => 'strong', + Error => 'em', + Todo => 'em', + ); + + my $hl = Text::VimColor->new( + file => $source, + vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'], + ); + my $parsed = $hl->marked; + print "\n"; -:> - -\n"; + foreach (@$parsed) { + my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || '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; + } + if (!$_->[0] and $_->[1] =~ s/^(\s*)([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { + printf '%s%s', $1, "/source/$2", $2; + } + print Text::VimColor::_xml_escape($_->[1]); + print "$tag>" if $tag; + } + print "\n"; } - if (!$_->[0] and $_->[1] =~ s/^([A-Z]\w+(?:::\w+)+)(?![^;\s])//) { - printf '%s', "/source/$1", $1; + else { + require Encode; + print "\n"; + print EscapeHTML(Encode::decode_utf8(ReadFile($source))); + print "\n"; } - print Text::VimColor::_xml_escape($_->[1]); - print "$tag>" if $tag; + + print "\n"; } -print "