git.shiar.nl
/
sheet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
latin: dynamic sample of user input
[sheet.git]
/
source.plp
diff --git
a/source.plp
b/source.plp
index 7b0ebec82552e55bb6a09bef911ea6c50c6cff0d..56193fb95853a7a47a5ab98e18203fdfa9d82ffc 100644
(file)
--- a/
source.plp
+++ b/
source.plp
@@
-1,7
+1,6
@@
<(common.inc.plp)><:
<(common.inc.plp)><:
-my $source = $ENV{PATH_INFO};
-$source =~ s{^/}{};
+my $source = $Request;
if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) {
# convert perl include to json construct
if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) {
# convert perl include to json construct
@@
-28,7
+27,7
@@
if ($source =~ s{(?<=\Q.inc.pl\E)/jsonp?$}{} and -r $source) {
Html({
title => "$source source code",
Html({
title => "$source source code",
- version => '
v
1.1',
+ version => '1.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."
description => !$source ? 'Index of source files for this site.' : [
"Source code of the $source file at this site,",
"with syntax highlighted and references linked."
@@
-39,21
+38,21
@@
Html({
stylesheet => [qw'light dark mono red'],
});
stylesheet => [qw'light dark mono red'],
});
-
print "\n"
;
+
say ''
;
if (not $source) {
print "<h1>Source files</h1>";
print "<p>Project code distributed under the AGPL. Please contribute back.</p>";
if (not $source) {
print "<h1>Source files</h1>";
print "<p>Project code distributed under the AGPL. Please contribute back.</p>";
-
print '<ul>'."\n"
;
+
say '<ul>'
;
for (glob '*.plp') {
chomp;
for (glob '*.plp') {
chomp;
-
printf '<li><a href="/source/%s">%1$s</a></li>'."\n"
, EscapeHTML($_);
+
say sprintf '<li><a href="/source/%s">%1$s</a></li>'
, EscapeHTML($_);
}
}
-
print "</ul>\n
\n";
+
say "</ul>
\n";
}
else {
}
else {
-
print "<h1>Source of $source</h1>\n
";
+
say "<h1>Source of $source</h1>
";
if ($source =~ m{(?:/|^)\.}) {
die "File request not permitted\n";
if ($source =~ m{(?:/|^)\.}) {
die "File request not permitted\n";
@@
-68,7
+67,6
@@
else {
}
-r $source or die "Requested file not found\n";
}
-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 = (
if (eval { require Text::VimColor and Text::VimColor->VERSION(0.12) }) {
delete $Text::VimColor::SYNTAX_TYPE{Underlined};
my %TYPETAG = (
@@
-82,29
+80,38
@@
else {
vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'],
);
my $parsed = $hl->marked;
vim_options => [@Text::VimColor::VIM_OPTIONS, '+:set enc=utf-8'],
);
my $parsed = $hl->marked;
-
print "<pre>\n"
;
+
say '<pre>'
;
foreach (@$parsed) {
foreach (@$parsed) {
- my $tag = $_->[0] && ($TYPETAG{ $_->[0] } || 'span');
+ my ($type, $contents) = @{$_};
+ $contents = decode_utf8($contents);
+ my $tag = $type && ($TYPETAG{$type} || 'span');
my $arg = '';
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$)}{}) {
+ # link other page sources, stylesheets, and javascript
printf '%s<a href="%s">%s</a>', $1, "/source/$2", $2;
}
printf '%s<a href="%s">%s</a>', $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])//) {
+ # link perl module names (Xx::Xx...)
printf '%s<a href="%s">%s</a>', $1, "/source/$2", $2;
}
printf '%s<a href="%s">%s</a>', $1, "/source/$2", $2;
}
- print Text::VimColor::_xml_escape(Encode::decode_utf8($_->[1]));
+ if ($type && $type eq 'Comment'
+ and $contents =~ s{^(.*? by )(tools/\S+)}{}) {
+ # link generator scripts (by tools/...)
+ printf '%s<a href="%s">%s</a>', $1, "/source/$2", $2;
+ }
+ print Text::VimColor::_xml_escape($contents);
print "</$tag>" if $tag;
}
print "</$tag>" if $tag;
}
-
print "</pre>\n"
;
+
say '</pre>'
;
}
else {
}
else {
-
print "<pre>\n"
;
- print EscapeHTML(
Encode::
decode_utf8(ReadFile($source)));
-
print "</pre>\n"
;
+
say '<pre>'
;
+ print EscapeHTML(decode_utf8(ReadFile($source)));
+
say '</pre>'
;
}
}
-
print "\n"
;
+
say ''
;
}
}