X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/bba0d5b6fb0b1bbe6b5bb4a84c72de2152d8dfe3..ffd2c45cc0682bbf921ac6eae7e1c144ae24c1e0:/font.plp?ds=sidebyside diff --git a/font.plp b/font.plp index 82aa0c3..d4d7deb 100644 --- a/font.plp +++ b/font.plp @@ -1,6 +1,6 @@ <(common.inc.plp)><: -my $font = $ENV{PATH_INFO} =~ s{^/}{}r; +my $font = $Request; Html({ title => 'font coverage '.($font ? "for $font" : 'sheet'), @@ -17,6 +17,30 @@ if ($font) { my ($fontmeta, @cover) = do "ttfsupport/$font.inc.pl"; $fontmeta or die "Unknown font $font\n"; + my $map = eval { + $get{map} or return; + + my $groupinfo = do 'unicode-cover.inc.pl' or die $@ || $!; + + my ($cat, $name) = split m{/}, $get{map}, 2 or die "invalid map\n"; + if (!$name) { + ($cat, $name) = ('table', $cat); + } + + my $row = $groupinfo->{$cat}->{$name} + or die "unknown character group $cat/$name\n"; + my $query = $row->{query}; + + my @map; + for (map { split /[^\d-]/ } $query) { + my @range = split /-/, $_, 2; + m/^[0-9]+$/ or die "Invalid code point $_ in query $query\n" for @range; + push @map, $_ for $range[0] .. ($range[1] // $range[0]); + } + return \@map; + }; + die $@ if $@; + require Unicode::UCD; my $pagerows = 0x200; @@ -50,7 +74,7 @@ if ($font) { (map { "with $_" } $_ || ()), ('and published as freeware "Core Web font"') x ($_ eq 'Windows 2000'), (map { "under a $_ license" } - map { $fontmeta->{license} ? qq($_) : $_ } + map { $fontmeta->{license} ? qq($_) : $_ } $_ && $_ ne 'Android' ? 'proprietary' : 'free', ), ); @@ -78,21 +102,27 @@ if ($font) { EOT say '
%X', $cp; + } + $lastcp = $cp; + } + } + say sprintf ' |
---|
%X', $cp if $colpos++ % $pagecols == 0; my $info = $glyphs->glyph_info($cp); |