X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/f63a57e71a3aed6fe5e80ca979186e3bd6c7eb6b..a6bf5822695c1e3608f1692398d47e28a9623a79:/source.plp?ds=inline diff --git a/source.plp b/source.plp index a813db4..81b3408 100644 --- a/source.plp +++ b/source.plp @@ -1,98 +1,149 @@ <(common.inc.plp)><: - our $VERSION = 'v1.0'; - my $source = $ENV{PATH_INFO}; - $source =~ s{^/}{}; +my $source = $Request; +my $incname = qr{ [a-z][/a-z0-9_.-]* \.(?:plp?|css|js|txt) }x; -:> - +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->indent->space_after->canonical; -
- -Project code distributed under the AGPL. Please contribute back.
"; - print ''; + print decode_utf8(ReadFile($cachefile)); + say ''; + exit; + } + -e or mkdir for $cachefile =~ s{[^/]+\z}{}r; # dirname + open my $cache, '>', $cachefile + or Alert("Could not save cache", "Opening $cachefile failed: $!");; - if (eval { require Text::VimColor and Text::VimColor->VERSION(0.12) }) { + if (my $hl = eval { + $size < 32_768 or die 'large files take too long to parse'; + require Text::VimColor; + Text::VimColor->VERSION(0.12) + or die 'early versions are buggy under FastCGI'; delete $Text::VimColor::SYNTAX_TYPE{Underlined}; + return Text::VimColor->new( + file => $path, + vim_options => [@Text::VimColor::VIM_OPTIONS, + '+:set enc=utf-8', + '+:let perl_sub_signatures=1', + ], + )->marked; + }) { my %TYPETAG = ( Statement => 'strong', Error => 'em', Todo => 'em', + PreProc => 'strong', ); - 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; + say ''; } else { - print "'; + foreach (@{$hl}) { + my ($type, $contents) = @{$_}; + $contents = decode_utf8($contents); + my $tag = $type && ($TYPETAG{$type} || 'span'); + my $line = Text::VimColor::_xml_escape($contents); + + # link other page sources, stylesheets, and javascript + $line =~ s{ ^(['"]?) \K ($incname) (?=\1$) }{ showlink($2, "/source/$2") }xe + if !$type || $type eq 'Constant'; + # link relative page locations in html output + $line =~ s{ ^(")\K (/\w{2,}) (?= (?:/\w+)* \1$) }{ showlink($2, "/source$2.plp") }xe + if $type && $type eq 'Constant'; + # link perl module names (Xx::Xx...) + $line =~ s{ ^\s* \K ([A-Z]\w+(?:::\w+)+) (?![^;\s]) }{ showlink($1, "/source/$1") }xe + if !$type; + # link generator scripts (by tools/...) + $line =~ s{ ^.*? by\ \K (tools/\S+) }{ showlink($1, "/source/$1") }xe + if $type && $type eq 'Comment'; + + $line = qq(<$tag class="sy-\l$type">$line$tag>) if $tag; + print $line; + print {$cache} $line if $cache; } - print "\n"; + say '
\n", EscapeHTML(ReadFile($source)), "\n"; + say '
'; + print EscapeHTML(decode_utf8(ReadFile($path))); + say ''; } + + say ''; } -:> - - - +