X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/e98b059d1f6bbd6ac8ca06de152959536e4b98b0..5c6226f7284e7b0ce87825f4a90d083d03f94388:/source.plp diff --git a/source.plp b/source.plp index db3a400..f476ee8 100644 --- a/source.plp +++ b/source.plp @@ -1,33 +1,45 @@ -<: -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; +} - - -sheet page source code -<: - my %styles = map {$_ => $_} qw(dark mono red); - our $style = exists $get{style} && $styles{$get{style}} || 'light'; - printf(qq{\n}, - $_ eq $style ? 'stylesheet' : 'alternate stylesheet', "/$_.css", $_ - ) for keys %styles; -:> - +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'], +}); - -<: - -my $source = $ENV{PATH_INFO}; -$source =~ s{^/}{}; +print "\n"; if (not $source) { print "

Source files

"; @@ -36,7 +48,7 @@ if (not $source) { print '\n\n"; } @@ -48,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; @@ -56,43 +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] 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 "" if $tag;
 		}
-		print Text::VimColor::_xml_escape($_->[1]);
-		print "" if $tag;
+		print "
\n"; } - print "
\n"; + else { + require Encode; + print "
\n";
+		print EscapeHTML(Encode::decode_utf8(ReadFile($source)));
+		print "
\n"; + } + + print "\n"; } -:> - -