X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/f850d8bca38d6f025cd26b62b6e5504dd4d77ad1..972bfa6b61c2168aac48bd123c8523d195a273b6:/source.plp
diff --git a/source.plp b/source.plp
index 295f9e0..f476ee8 100644
--- a/source.plp
+++ b/source.plp
@@ -1,21 +1,45 @@
<(common.inc.plp)><:
- our $VERSION = 'v1.0';
-:>
-
+my $source = $ENV{PATH_INFO};
+$source =~ s{^/}{};
-
-
-sheet page source code
-<:= stylesheet(qw'light dark mono red') :>
-
+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;
+}
-my $source = $ENV{PATH_INFO};
-$source =~ s{^/}{};
+Html({
+ title => "$source source code",
+ version => 'v1.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."
+ ],
+ keywords => [qw'
+ sheet cheat source code perl plp html agpl
+ '],
+ stylesheet => [qw'light dark mono red'],
+});
+
+print "\n";
if (not $source) {
print "Source files
";
@@ -24,7 +48,7 @@ if (not $source) {
print ''."\n";
for (glob '*.plp') {
chomp;
- printf '- %1$s
'."\n", Entity($_);
+ printf '- %1$s
'."\n", EscapeHTML($_);
}
print "
\n\n";
}
@@ -36,7 +60,7 @@ else {
}
elsif ($source =~ s{::}{/}g or !-e $source) {
$source .= '.pm';
- for (0 .. $#{@INC}) {
+ for (0 .. $#INC) {
-e ($_ = "$INC[$_]/$source") or next;
$source = $_;
last;
@@ -44,45 +68,43 @@ else {
}
-r $source or die "Requested file not found\n";
- require Text::VimColor;
- delete $Text::VimColor::SYNTAX_TYPE{Underlined};
- my %TYPETAG = (
- Statement => 'strong',
- Error => 'em',
- Todo => 'em',
- );
+ 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";
- 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;
+ my $hl = Text::VimColor->new(
+ file => $source,
+ vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'],
+ );
+ my $parsed = $hl->marked;
+ print "\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 Text::VimColor::_xml_escape($_->[1]);
- print "$tag>" if $tag;
+ print "
\n";
}
- print "
\n";
+ else {
+ require Encode;
+ print "\n";
+ print EscapeHTML(Encode::decode_utf8(ReadFile($source)));
+ print "
\n";
+ }
+
+ print "\n";
}
-:>
-
-