X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/98cfbf69d9806fe9cc9e352859da42f60a56a338..5c6226f7284e7b0ce87825f4a90d083d03f94388:/source.plp diff --git a/source.plp b/source.plp index f713a73..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

"; @@ -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; @@ -75,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"; } -:> - -