font: numbered fonts; os groups in include
[sheet.git] / font.plp
index 2d449f08194d51054c6e08a5191ed096e2602518..98fff40ade1bc140b524e0758380cd64f4d58d0d 100644 (file)
--- a/font.plp
+++ b/font.plp
@@ -26,17 +26,11 @@ use 5.010;
 use Shiar_Sheet::FormatChar;
 my $glyphs = Shiar_Sheet::FormatChar->new;
 
-my %oslist = (
-       win     => [qw( arial ariuni lucidau verdana times courier )],  # microsoft
-       mac     => [qw( helvetica lucida times garamond palatino )],  # apple
-       android => [qw( roboto noto )],  # google
-       oss     => [qw( dvsans c2k unifont opensans )],
-);
-my @ossel = qw( win mac oss android );
-my @fontlist = map { @{ $oslist{$_} } } @ossel;
-
 my $cover = do 'unicode-cover.inc.pl' or die $@ || $!;
 
+my @ossel = @{ $cover->{osdefault} };
+my @fontlist = map { @{ $cover->{os}->{$_} } } @ossel;
+
 my @rows = (
        'block/Latin-1 Supplement',
        'block/Latin Extended-A',
@@ -75,15 +69,18 @@ for my $group ($ENV{PATH_INFO} || ()) {
 
 print '<table class=mapped>';
 print '<col><col>';
-print "<colgroup span=$_>" for map { scalar @{$oslist{$_}} } @ossel;
+print "<colgroup span=$_>"
+       for map { scalar @{ $cover->{os}->{$_} } } @ossel;
 
 print '<thead><tr>';
 print '<th colspan=2>';
-printf '<th colspan=%d>%s fonts', scalar @{ $oslist{$_} }, $_ for @ossel;
+printf '<td colspan=%d>%s fonts', scalar @{ $cover->{os}->{$_} }, $_
+       for @ossel;
 
 print '<tr>';
 print '<th colspan=2>';
-printf '<td>%s', $_ for @fontlist;
+printf '<td title="%s">%s', $_->{name}, $_->{abbr}
+       for @{ $cover->{fonts} }[@fontlist];
 say '</thead>';
 
 for (@rows) {
@@ -92,11 +89,10 @@ for (@rows) {
 
        print '<tr>';
        $name = sprintf '<a href="%s">%s</a>', EncodeURI("/chars/$group/$name"), EscapeHTML($name)
-               if $row->{-count} and $row->{-count} < 1280;
+               if $row->{count} and $row->{count} < 1280;
        print '<th>', $name;
-       print '<td class=right>', $row->{-count};
-       for (@fontlist) {
-               my $count = $row->{$_};
+       print '<td class=right>', $row->{count};
+       for my $count (@{ $row->{support} }[@fontlist]) {
                if (not defined $count) {
                        print '<td class="l0">?';
                        next;
@@ -105,12 +101,12 @@ for (@rows) {
                        print '<td class="l1">✘';
                        next;
                }
-               if ($count == $row->{-count}) {
+               if ($count == $row->{count}) {
                        print '<td class="l5">✔';
                        next;
                }
 
-               my $rel = $count / $row->{-count};
+               my $rel = $count / $row->{count};
                my $class = $rel < .5 ? 2 : $rel < .9 ? 3 : 4;
                printf '<td class="%s">%d%%', "l$class", $rel*100;
        }