X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/108d13f833e9daeff4ea1552e2e1bee1e0ed8c22..73c30a3b33f7bcddf85b7a44216b8caed7e1cd29:/font.plp?ds=inline diff --git a/font.plp b/font.plp index cc07c05..d4d7deb 100644 --- a/font.plp +++ b/font.plp @@ -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); |