diff options
author | Rasmus Andersson <rasmus@notion.se> | 2018-01-19 09:47:59 +0300 |
---|---|---|
committer | Rasmus Andersson <rasmus@notion.se> | 2018-01-19 09:47:59 +0300 |
commit | f7868ac6205e9d3388059179a472365835a8fd9b (patch) | |
tree | a32d4fc48c45e5e958c2e65f9369506b20696634 /misc/pylib/fontbuild/Build.pyx | |
parent | 2ad426b1e7c397ad34dce58c3abcc0e8d60d5112 (diff) | |
download | inter-f7868ac6205e9d3388059179a472365835a8fd9b.tar.xz |
Fix minor bug in fontbuild where certain glyphs composed of multiple shapes would not be expanded & flattened
Diffstat (limited to 'misc/pylib/fontbuild/Build.pyx')
-rw-r--r-- | misc/pylib/fontbuild/Build.pyx | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/misc/pylib/fontbuild/Build.pyx b/misc/pylib/fontbuild/Build.pyx index d2629b337..8e028ef74 100644 --- a/misc/pylib/fontbuild/Build.pyx +++ b/misc/pylib/fontbuild/Build.pyx @@ -61,7 +61,8 @@ class FontProject: self.builddir = "out" self.decompose = self.config.get("glyphs","decompose").split() - self.predecompose = self.config.get("glyphs","predecompose").split() + self.predecompose = set(self.config.get("glyphs","predecompose").split()) + self.predecompose_auto = 1 # unless 0, automatically populate predecompose self.lessItalic = set(self.config.get("glyphs","lessitalic").split()) self.deleteList = set(self.config.get("glyphs","delete").split()) self.noItalic = set(self.config.get("glyphs","noitalic").split()) @@ -128,6 +129,13 @@ class FontProject: for gname in swapList: print gname swapContours(f, gname.replace(swap,""), gname) + + if self.predecompose_auto == 1: + self.predecompose_auto = 2 + for g in self.basefont: + if len(g.components) > 0: + self.predecompose.add(g.name) + for gname in self.predecompose: if f.has_key(gname): decomposeGlyph(f, f[gname]) @@ -273,6 +281,8 @@ def generateGlyphs(f, glyphNames, glyphList={}): def cleanCurves(f): log(">> Removing overlaps") for g in f: + # if len(g.components) > 0: + # decomposeGlyph(f, g) removeGlyphOverlap(g) # log(">> Mitring sharp corners") @@ -293,10 +303,11 @@ def deleteGlyphs(f, deleteList): def removeGlyphOverlap(glyph): """Remove overlaps in contours from a glyph.""" #TODO(jamesgk) verify overlaps exist first, as per library's recommendation - manager = BooleanOperationManager() contours = glyph.contours - glyph.clearContours() - manager.union(contours, glyph.getPointPen()) + if len(contours) > 1: + manager = BooleanOperationManager() + glyph.clearContours() + manager.union(contours, glyph.getPointPen()) def saveOTF(font, destFile, glyphOrder, truetype=False): |