font: include version in font name hover
[sheet.git] / tools / mkttfinfo
index 3dfd8b75330483fd345ca20e5123875fae361766..c80f5fceb378ab9a75550c422a36b2ab3afbc4de 100755 (executable)
@@ -1,5 +1,5 @@
 #!/usr/bin/env perl
-use 5.010;
+use 5.014;
 use strict;
 use warnings;
 
@@ -30,18 +30,6 @@ for ($outfile || ()) {
        select $output;
 }
 
-my %FONTID = (
-       'Times New Roman' => 'times',
-       'DejaVu Sans'     => 'dv ss',
-       'DejaVu Serif'    => 'dv serif',
-       'DejaVu Sans Mono'=> 'dv mono',
-       'Code2000'        => 'c2k',
-       'GNU Unifont'     => 'guf',
-       'Droid Sans'      => 'droid',
-       'Droid Serif'     => 'droid serif',
-       'Droid Sans Mono' => 'droid mono',
-);
-
 {
        my $ttf = Font::TTF::Font->open($ttfuri)
                or die "Cannot open truetype in $ttfuri: $!";
@@ -51,8 +39,8 @@ my %FONTID = (
        my %meta = (
                source   => $ttfuri =~ m{(^/usr/.+ | [^/]+) \z}msx,
                name     => $ttfmeta->find_name(4) || $ttfname,
-               revision => $ttf->{head}->{fontRevision},
-               version  => scalar $ttfmeta->find_name(5),
+               revision => sprintf('%g', $ttf->{head}->{fontRevision}),
+               version  => $ttfmeta->find_name(5) =~ s/\Aversion //ri =~ s/\s+\z//r,
                copyright=> scalar $ttfmeta->find_name(0),
                license  => $ttfmeta->find_name(14) || undef,
                date     => (map {
@@ -62,7 +50,10 @@ my %FONTID = (
                        }
                } $ttf->{head}->getdate),
        );
-       $meta{id} = $FONTID{ $meta{name} } // lc $ttfname;
+       $meta{abbr} = lc join '', $meta{name} =~ s/ MS$//r =~ m{
+               (?!Sans) (?<! [0-9]) ([[:upper:]0-9])
+       }gx;
+
        say "# automatically generated by $0";
        say '+', pp(\%meta), ',';