diff options
author | Rasmus Andersson <rasmus@notion.se> | 2018-01-08 21:26:09 +0300 |
---|---|---|
committer | Rasmus Andersson <rasmus@notion.se> | 2018-01-08 21:26:09 +0300 |
commit | 76f983adaee6116ce9775d959be6e8bbad334f7d (patch) | |
tree | bd6bc56cac2205d1518c909b0b8a385067adaa0a /misc/pylib | |
parent | 96fb366982ab2b95bc40ed9f93e47da752290ad0 (diff) | |
download | inter-76f983adaee6116ce9775d959be6e8bbad334f7d.tar.xz |
Fixes to font metadata, including addition of some OS/2 panose information
Diffstat (limited to 'misc/pylib')
-rw-r--r-- | misc/pylib/fontbuild/Build.pyx | 10 | ||||
-rw-r--r-- | misc/pylib/fontbuild/instanceNames.py | 26 |
2 files changed, 25 insertions, 11 deletions
diff --git a/misc/pylib/fontbuild/Build.pyx b/misc/pylib/fontbuild/Build.pyx index 2832aa28e..d2629b337 100644 --- a/misc/pylib/fontbuild/Build.pyx +++ b/misc/pylib/fontbuild/Build.pyx @@ -85,10 +85,10 @@ class FontProject: return os.path.join(path, "%s-%s.%s" % (family, style, ext)) def generateFont(self, mix, names, italic=False, swapSuffixes=None, stemWidth=185, - italicMeanYCenter=-825, italicNarrowAmount=1): + italicMeanYCenter=-825, italicNarrowAmount=1, panose=[]): n = names.split("/") - log("---------------------\n%s %s\n----------------------" %(n[0],n[1])) + log("---------------------\n%s, %s\n----------------------" %(n[0],n[1])) if isinstance( mix, Mix): log(">> Mixing masters") @@ -164,7 +164,7 @@ class FontProject: 'license': getcfg('license'), 'licenseURL': getcfg('licenseURL'), 'italicAngle': float(getcfg('italicAngle', '-12')), - }) + }, panose) if not self.compatible: cleanCurves(f) @@ -187,9 +187,9 @@ class FontProject: glyphOrder.append(glyphName) if self.buildOTF: - log(">> Generating OTF file") newFont = OpenFont(ufoName) otfName = self.generateOutputPath(f, "otf") + log(">> Generating OTF file %s" % otfName) saveOTF(newFont, otfName, glyphOrder) def generateTTFs(self): @@ -208,9 +208,9 @@ class FontProject: for font in fonts: fonts_to_quadratic([font], max_err_em=max_err, dump_stats=True, reverse_direction=True) - log(">> Generating TTF files") for font in fonts: ttfName = self.generateOutputPath(font, "ttf") + log(">> Generating TTF file %s" % ttfName) log(os.path.basename(ttfName)) glyphOrder = [n for n in self.glyphOrder if n in font] saveOTF(font, ttfName, glyphOrder, truetype=True) diff --git a/misc/pylib/fontbuild/instanceNames.py b/misc/pylib/fontbuild/instanceNames.py index b93f3a9f0..239af3f78 100644 --- a/misc/pylib/fontbuild/instanceNames.py +++ b/misc/pylib/fontbuild/instanceNames.py @@ -53,7 +53,7 @@ class InstanceNames: else: self.shortfamily = self.longfamily - def setRFNames(self,f, version=1, versionMinor=0): + def setRFNames(self,f, version=1, versionMinor=0, panose={}): f.info.familyName = self.longfamily f.info.styleName = self.longstyle f.info.styleMapFamilyName = self.shortfamily @@ -64,7 +64,7 @@ class InstanceNames: if len(self.copyrightHolderName) > 0: f.info.copyright = "Copyright %s %s" % (self.year, self.copyrightHolderName) f.info.trademark = "%s is a trademark of %s." %(self.longfamily, self.foundry.rstrip('.')) - + if len(self.designer) > 0: f.info.openTypeNameDesigner = self.designer if len(self.designerURL) > 0: @@ -84,14 +84,28 @@ class InstanceNames: # f.info.openTypeNameCompatibleFullName = "" # f.info.openTypeNameSampleText = "" if (self.subfamilyAbbrev != "Rg"): - f.info.openTypeNamePreferredFamilyName = self.longfamily - f.info.openTypeNamePreferredSubfamilyName = self.longstyle + f.info.openTypeNamePreferredFamilyName = self.longfamily + f.info.openTypeNamePreferredSubfamilyName = self.longstyle f.info.openTypeOS2WeightClass = self._getWeightCode(self.weight) f.info.macintoshFONDName = re.sub(' ','',self.longfamily) + " " + re.sub(' ','',self.longstyle) f.info.postscriptFontName = f.info.macintoshFONDName.replace(" ", "-") if self.italic: f.info.italicAngle = self.italicAngle + + if len(panose) > 0: + f.info.openTypeOS2Panose = [ + panose.get('bFamilyType', panose.get('familyType', 0)), + panose.get('bSerifStyle', panose.get('serifStyle', 0)), + panose.get('bWeight', panose.get('weight', 0)), + panose.get('bProportion', panose.get('proportion', 0)), + panose.get('bContrast', panose.get('contrast', 0)), + panose.get('bStrokeVariation', panose.get('strokeVariation', 0)), + panose.get('bArmStyle', panose.get('armStyle', 0)), + panose.get('bLetterform', panose.get('letterform', 0)), + panose.get('bMidline', panose.get('midline', 0)), + panose.get('bXHeight', panose.get('xHeight', 0)), + ] def setFLNames(self,flFont): @@ -220,7 +234,7 @@ def setNames(f,names,foundry="",version="1.0",build=""): i.setFLNames(f) -def setInfoRF(f, names, attrs={}): +def setInfoRF(f, names, attrs={}, panose={}): i = InstanceNames(names) version, versionMinor = (1, 0) for k,v in attrs.iteritems(): @@ -230,4 +244,4 @@ def setInfoRF(f, names, attrs={}): else: version = int(v) setattr(i, k, v) - i.setRFNames(f, version=version, versionMinor=versionMinor) + i.setRFNames(f, version=version, versionMinor=versionMinor, panose=panose) |