git.shiar.nl
/
sheet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
vi: specific version and extension classes
[sheet.git]
/
chars.plp
diff --git
a/chars.plp
b/chars.plp
index b25c5e2ccb96aad30abf34c7d08f2252ef19daa3..bea56cfe3973afd29e3202819bc1408bcc8874b5 100644
(file)
--- a/
chars.plp
+++ b/
chars.plp
@@
-2,18
+2,27
@@
Html({
title => 'character support sheet',
Html({
title => 'character support sheet',
- version => '1.
0
',
+ version => '1.
1
',
keywords => [qw'
unicode glyph char character reference common ipa symbol sign mark table digraph
'],
stylesheet => [qw'light dark mono circus red'],
keywords => [qw'
unicode glyph char character reference common ipa symbol sign mark table digraph
'],
stylesheet => [qw'light dark mono circus red'],
- data => [qw( unicode-cover.inc.pl ttfsupport unicode-char.inc.pl )],
+ data => [qw( data/unicode-cover.inc.pl data/font data/unicode-char.inc.pl )],
+ raw => <<'EOT',
+<style>
+ tbody tr:hover th {
+ font-size: 300%;
+ min-width: 1.2em;
+ border-width: 1px;
+ }
+</style>
+EOT
});
use Shiar_Sheet::FormatChar;
my $glyphs = Shiar_Sheet::FormatChar->new;
});
use Shiar_Sheet::FormatChar;
my $glyphs = Shiar_Sheet::FormatChar->new;
-my $groupinfo = do 'unicode-cover.inc.pl' or die $@ || $!;
+my $groupinfo = do '
data/
unicode-cover.inc.pl' or die $@ || $!;
my @ossel = @{ $groupinfo->{osdefault} };
my @fontlist = map { $_->{file} }
my @ossel = @{ $groupinfo->{osdefault} };
my @fontlist = map { $_->{file} }
@@
-21,7
+30,7
@@
my @fontlist = map { $_->{file} }
my %font;
for my $fontid (@fontlist) {
my %font;
for my $fontid (@fontlist) {
- my ($fontmeta, @fontrange) = do "
ttfsuppor
t/$fontid.inc.pl";
+ my ($fontmeta, @fontrange) = do "
data/fon
t/$fontid.inc.pl";
$fontmeta or next;
$font{$fontid} = {
(map { (-$_ => $fontmeta->{$_}) } keys %{$fontmeta}),
$fontmeta or next;
$font{$fontid} = {
(map { (-$_ => $fontmeta->{$_}) } keys %{$fontmeta}),
@@
-33,8
+42,7
@@
for my $fontid (@fontlist) {
my ($title, $parent) = ('Character overview');
my $query = eval {
my ($title, $parent) = ('Character overview');
my $query = eval {
- for ($ENV{PATH_INFO} || ()) {
- s{^/}{};
+ for ($Request || ()) {
return $_ if m{^[0-9 +-]+$};
my ($cat, $name) = split m{/}, $_, 2 or die "invalid query\n";
return $_ if m{^[0-9 +-]+$};
my ($cat, $name) = split m{/}, $_, 2 or die "invalid query\n";
@@
-54,8
+62,7
@@
my $query = eval {
say "<h1>$title</h1>";
if (!$query) {
say "<h1>$title</h1>";
if (!$query) {
- say "<p>Unicode group not specified: $@</p>";
- exit;
+ Abort(["Unicode group not found", $@], '404 no matches');
};
for ($parent || 'Unicode range') {
};
for ($parent || 'Unicode range') {
@@
-74,15
+81,16
@@
for ($parent || 'Unicode range') {
my @chars;
for (map { split /[^\d-]/ } $query) {
my @range = split /-/, $_, 2;
my @chars;
for (map { split /[^\d-]/ } $query) {
my @range = split /-/, $_, 2;
- m/^[0-9]+$/ or die "Invalid code point $_ in query $query\n" for @range;
+ m/^[0-9]+$/ or Abort("Invalid code point $_ in query $query", 400)
+ for @range;
push @chars, chr $_ for $range[0] .. ($range[1] // $range[0]);
}
push @chars, chr $_ for $range[0] .. ($range[1] // $range[0]);
}
-@chars or
die "No match for query $query\n"
;
+@chars or
Abort("No match for query $query", '404 no results')
;
-@chars <= 1500 or
die sprintf
(
-
'Too many matches (%d) for query %s'."\n"
,
- scalar @chars, $query,
+@chars <= 1500 or
Abort
(
+
sprintf('Too many matches (%d) for query', scalar @chars)
,
+ '403 not allowed', $query
);
# output character list
);
# output character list