From 4cce1d87166e6ef02bfa09304164b27d63ffd129 Mon Sep 17 00:00:00 2001 From: Fini Jastrow Date: Wed, 12 Oct 2022 17:43:26 +0200 Subject: [PATCH] font-patcher: Fix new ScaleGlyph (for codepoint F000) [why] First the new ScaleGlyph has been introduced with commit e5768e925 font-patcher: Redesign ScaleGlyph parameter and afterwards it has been enhanced to avoid rounding errors with commit 983226a70 font-patcher: Fix scaleGlyph related rounding error The later commit uses a function that explicitely says it will destroy the glyph at a specific location, AFTER we already patched in one glyph (namely F000). It does not look too bad, bad that glyph is not correctly rescaled or translated. Only that glyph is affected because only Font Awesome uses the new ScaleGlyph capabilities, and only the first glyph of a set is affected. [how] The ScaleGlyph calculations need to be done before the final glyph is patched in. It is shifted some lines up. Usually that glyph is not existing in the to-be-patched font, so we create a dummy first. Also need to correct distinction between 'unicode in symbol font' and 'unicode in to-be-patched font', as this would bite us in cases where we move the symbol's codepoint. Signed-off-by: Fini Jastrow --- font-patcher | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/font-patcher b/font-patcher index 8fe31d458..36a8af530 100755 --- a/font-patcher +++ b/font-patcher @@ -988,6 +988,9 @@ class font_patcher: if currentSourceFontGlyph in self.sourceFont: self.sourceFont[currentSourceFontGlyph].removePosSub("*") + # This will destroy any content currently in currentSourceFontGlyph, so do it first + scale_glyph_data = self.get_glyph_scale(sym_glyph.encoding, scaleGlyph, symbolFont, currentSourceFontGlyph) if scaleGlyph else None + # Select and copy symbol from its encoding point # We need to do this select after the careful check, this way we don't # reset our selection before starting the next loop @@ -1015,7 +1018,7 @@ class font_patcher: scale_ratio_x = False if scaleGlyph: # We want to preserve the relative size of each glyph in a glyph group - scale_ratio_x = self.get_glyph_scale(sym_glyph.unicode, scaleGlyph, symbolFont) + scale_ratio_x = scale_glyph_data if scale_ratio_x is False: # In the remaining cases, each glyph is sized independently to each other scale_ratio_x = self.get_scale_factor(sym_dim) @@ -1187,13 +1190,15 @@ class font_patcher: sym_dim = get_multiglyph_boundingBox([ symbolFont[g] if g in symbolFont else None for g in group ], destGlyph) scaleGlyph['scales'].append(self.get_scale_factor(sym_dim)) - def get_glyph_scale(self, unicode_value, scaleGlyph, symbolFont): + def get_glyph_scale(self, symbol_unicode, scaleGlyph, symbolFont, dest_unicode): """ Determines whether or not to use scaled glyphs for glyphs in passed glyph_list """ - # Potentially destorys the contents of self.sourceFont[unicode_value] + # Potentially destorys the contents of self.sourceFont[dest_unicode] if not 'scales' in scaleGlyph: - self.prepareScaleGlyph(scaleGlyph, symbolFont, self.sourceFont[unicode_value]) + if not dest_unicode in self.sourceFont: + self.sourceFont.createChar(dest_unicode) + self.prepareScaleGlyph(scaleGlyph, symbolFont, self.sourceFont[dest_unicode]) for glyph_list, scale in zip(scaleGlyph['GlyphsToScale'], scaleGlyph['scales']): - if unicode_value in glyph_list: + if symbol_unicode in glyph_list: return scale return False