X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/1483a182cba6c2264a19048a9cf5f512afeec694..c133e6ad3027e095811931f3e0d21b818865e0e8:/tools/mkttfinfo diff --git a/tools/mkttfinfo b/tools/mkttfinfo index 72564bf..2523b8f 100755 --- a/tools/mkttfinfo +++ b/tools/mkttfinfo @@ -30,12 +30,19 @@ for ($outfile || ()) { } { - my $ttf = Font::TTF::Font->open($ttfuri) or do { - warn "Cannot open truetype in $ttfuri: $!"; + my $ttf = eval { + if ($ttfuri =~ /\.ttc\z/) { + require Font::TTF::Ttc; + my $collection = Font::TTF::Ttc->open($ttfuri) or die $!; + return $collection->{directs}->[0]; # first sub-font object + } + return Font::TTF::Font->open($ttfuri); + } or do { + warn "Cannot open font file $ttfuri: ", $@ // $!; exit 65; # EX_DATAERR }; - my $ttfname = ($ttfuri =~ m{([^/.]+) (?:[.]ttf)? \z}msx)[0]; + my ($ttfname, @ttfext) = split /\./, ($ttfuri =~ m{([^/]+)\z}ms)[0]; my $ttfmeta = $ttf->{name}->read; my %meta = ( source => abs_path($ttfuri) =~ m{(^/usr/.+ | [^/]+) \z}msx, @@ -54,12 +61,23 @@ for ($outfile || ()) { $meta{abbr} = lc join '', $meta{name} =~ s/ MS$//r =~ m{ (?!Sans) (?{cmap}->find_ms->{val}; - warn scalar keys %$support, " characters read from $ttfname\n" + warn scalar keys %$support, " characters read from $ttfuri\n" if $opt{verbose}; say pp(sort { $a <=> $b } keys %$support); }