1from __future__ import print_function, division, absolute_import 2from fontTools.misc.py23 import * 3from fontTools.misc.textTools import safeEval 4from . import DefaultTable 5import struct 6 7 8GASP_SYMMETRIC_GRIDFIT = 0x0004 9GASP_SYMMETRIC_SMOOTHING = 0x0008 10GASP_DOGRAY = 0x0002 11GASP_GRIDFIT = 0x0001 12 13class table__g_a_s_p(DefaultTable.DefaultTable): 14 15 def decompile(self, data, ttFont): 16 self.version, numRanges = struct.unpack(">HH", data[:4]) 17 assert 0 <= self.version <= 1, "unknown 'gasp' format: %s" % self.version 18 data = data[4:] 19 self.gaspRange = {} 20 for i in range(numRanges): 21 rangeMaxPPEM, rangeGaspBehavior = struct.unpack(">HH", data[:4]) 22 self.gaspRange[int(rangeMaxPPEM)] = int(rangeGaspBehavior) 23 data = data[4:] 24 assert not data, "too much data" 25 26 def compile(self, ttFont): 27 version = 0 # ignore self.version 28 numRanges = len(self.gaspRange) 29 data = b"" 30 items = sorted(self.gaspRange.items()) 31 for rangeMaxPPEM, rangeGaspBehavior in items: 32 data = data + struct.pack(">HH", rangeMaxPPEM, rangeGaspBehavior) 33 if rangeGaspBehavior & ~(GASP_GRIDFIT | GASP_DOGRAY): 34 version = 1 35 data = struct.pack(">HH", version, numRanges) + data 36 return data 37 38 def toXML(self, writer, ttFont): 39 items = sorted(self.gaspRange.items()) 40 for rangeMaxPPEM, rangeGaspBehavior in items: 41 writer.simpletag("gaspRange", [ 42 ("rangeMaxPPEM", rangeMaxPPEM), 43 ("rangeGaspBehavior", rangeGaspBehavior)]) 44 writer.newline() 45 46 def fromXML(self, name, attrs, content, ttFont): 47 if name != "gaspRange": 48 return 49 if not hasattr(self, "gaspRange"): 50 self.gaspRange = {} 51 self.gaspRange[safeEval(attrs["rangeMaxPPEM"])] = safeEval(attrs["rangeGaspBehavior"]) 52 53