JKQtPlotter/lib/jkqtplotterressources/math_fonts/xits/tools/fontcoverage.py

59 lines
1.7 KiB
Python

import sys
import unicodedata
from fontTools.ttLib import TTFont
# Unicode blocks file from: http://www.unicode.org/Public/UNIDATA/Blocks.txt
blocksfile = open(sys.argv[1], "r")
blocks = [ ]
for line in blocksfile.readlines():
if not (line.startswith("#") or line == "\n"):
start, end = line.split("; ")[0].split("..")
name = line.split("; ")[1].strip()
blocks.append((name, (start, end)))
blocksfile.close()
logfile = open(sys.argv[2], "r")
log = logfile.read()
logfile.close()
for fontfile in sys.argv[3:-1]:
font = TTFont(fontfile)
cmap = font['cmap'].getcmap(3, 10)
if cmap is None:
cmap = font['cmap'].getcmap(3, 1)
found = [ ]
for block in blocks:
t = f = 0
name = block[0]
start, end = int(block[1][0], 16), int(block[1][1], 16)
i = start
while (i <= end):
category = unicodedata.category(chr(i))
if category != "Cc" and category!= "Cn":
if i in cmap.cmap:
f += 1
t += 1
i += 1
if f:
found.append((name, (t,f)))
fullname = font['name'].getName(4, 3, 1)
coverage = []
coverage.append("* %s:" % fullname)
for f in found:
for b in blocks:
if b[0] == f[0]:
name, (total, present) = f
_, (start, end) = b
percent = present / total * 100
coverage.append(" %s (U+%s-%s): %s/%s (%.2f%%)" % (
name, start, end, present, total, percent))
log = log.replace("%%{%s}" % fullname, "\n".join(coverage))
outfile = open(sys.argv[-1], "w")
outfile.write(log)
outfile.close()