X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/98cfbf69d9806fe9cc9e352859da42f60a56a338..24084c2319f2fd4f3b9ce3da6eddca31f935ee51:/source.plp?ds=inline
diff --git a/source.plp b/source.plp
index f713a73..469f49e 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;
@@ -44,6 +68,7 @@ else {
}
-r $source or die "Requested file not found\n";
+ require Encode;
if (eval { require Text::VimColor and Text::VimColor->VERSION(0.12) }) {
delete $Text::VimColor::SYNTAX_TYPE{Underlined};
my %TYPETAG = (
@@ -59,34 +84,29 @@ else {
my $parsed = $hl->marked;
print "\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";
}
-:>
-
-