X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/0aaffaf050bd5ca5ce5b5caf9e8dec1e8a1b7a48..368b9f0f191ea7186e4dc1d5522a137721861c3d:/source.plp
diff --git a/source.plp b/source.plp
index de3ad54..f476ee8 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;
-
-
-<:= $source :> source code
-">
-
-<:= stylesheet(qw'light dark mono red') :>
-
-
+ $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;
+}
+
+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
";
@@ -43,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;
@@ -82,18 +99,12 @@ else {
print "\n";
}
else {
- print "\n", EscapeHTML(ReadFile($source)), "
\n";
+ require Encode;
+ print "\n";
+ print EscapeHTML(Encode::decode_utf8(ReadFile($source)));
+ print "
\n";
}
+
+ print "\n";
}
-:>
-
-