X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/99b311f69a5e662a19069417dc2a37847722d914..81aefba6ac586eccbe18b4e90efc175e34fff5ad:/font.plp diff --git a/font.plp b/font.plp index a7812d0..d7f3b2e 100644 --- a/font.plp +++ b/font.plp @@ -1,9 +1,11 @@ <(common.inc.plp)><: use 5.014; +my $font = $ENV{PATH_INFO} =~ s{^/}{}r; + Html({ - title => 'character support sheet', - version => 'v1.1', + title => 'font coverage '.($font ? "for $font" : 'sheet'), + version => '1.2', keywords => [qw( unicode font glyph char character support overview cover coverage script block symbol sign mark reference table @@ -12,7 +14,7 @@ Html({ data => [qw( unicode-cover.inc.pl )], }); -if (my $font = $ENV{PATH_INFO} =~ s{^/}{}r) { +if ($font) { my ($fontmeta, @cover) = do "ttfsupport/$font.inc.pl"; $fontmeta or die "Unknown font $font\n"; @@ -31,7 +33,7 @@ if (my $font = $ENV{PATH_INFO} =~ s{^/}{}r) { say "

Font coverage

"; say "

$_

" for EscapeHTML($fontmeta->{name}); - printf("

Version %s released %s contains %d glyphs.

\n", + printf("

Version %s released %s contains %d glyphs.", !!$_->[2] && qq( title="revision $_->[2]"), $_->[1], $_->[0], scalar @cover, @@ -41,9 +43,22 @@ if (my $font = $ENV{PATH_INFO} =~ s{^/}{}r) { EscapeHTML($fontmeta->{version}), $fontmeta->{revision}, ]; - printf "

%s

\n", join('
', map { $_ ? EscapeHTML($_) : () } - $fontmeta->{copyright}, $fontmeta->{license}, - ); + for ($fontmeta->{os}) { + say '
'; + print ucfirst join(' ', + "distributed", + (map { "by $_" } $fontmeta->{oscorp} || "various sources"), + (map { "with $_" } $_ || ()), + ('and published as freeware "Core Web font"') x ($_ eq 'Windows 2000'), + (map { "under a $_ license" } + map { $fontmeta->{license} ? qq($_) : $_ } + $_ && $_ ne 'Android' ? 'proprietary' : 'free', + ), + ); + print '.'; + } + say '

'; + say "

$_

" for EscapeHTML($fontmeta->{copyright}) || (); require Shiar_Sheet::FormatChar; my $glyphs = Shiar_Sheet::FormatChar->new; @@ -56,6 +71,10 @@ if (my $font = $ENV{PATH_INFO} =~ s{^/}{}r) { .glyphs tbody th[!colspan] { text-align: right } .glyphs tbody td { font-family: "$fontmeta->{name}" } .glyphs tbody td:nth-child(18) { border-left-width: 2px } + \@font-face { + font-family: "$fontmeta->{name}"; + src: url(/data/font/$font.ttf); + } EOT say ''; @@ -122,6 +141,8 @@ my @ossel = @{ $cover->{osdefault} }; my @fontlist = map { @{ $cover->{os}->{$_} } } @ossel; my @rows = ( + 'version/11', + 'version/63', 'block/Latin-1 Supplement', 'block/Latin Extended-A', 'block/Latin Extended Additional', @@ -165,8 +186,11 @@ print "" print ''; print ''; print ''; + $name = sprintf 'Unicode v%.1f', $name / 10 if $group eq 'version'; $name = sprintf '%s', EncodeURI("/chars/$group/$name"), EscapeHTML($name) if $row->{count} and $row->{count} < 1280; print '
'; -printf '%s fonts', scalar @{ $cover->{os}->{$_} }, $_ - for @ossel; +for my $os (@ossel) { + my $osfonts = $cover->{os}->{$os}; + my $osfont = $cover->{fonts}->[ $osfonts->[0] ]; # first font + printf '%s', scalar @{$osfonts}, $osfont->{os} || '' +} print '
'; @@ -182,6 +206,7 @@ for (@rows) { my $row = $cover->{$group}->{$name}; print '
', $name;