Ejemplo n.º 1
0
 def toXML(self, writer, ttFont):
     if self.version == 1:
         format = OS2_format_1
     elif self.version in (2, 3, 4):
         format = OS2_format_2
     else:
         format = OS2_format_0
     formatstring, names, fixes = sstruct.getformat(format)
     for name in names:
         value = getattr(self, name)
         if type(value) == type(0L):
             value = int(value)
         if name == "panose":
             writer.begintag("panose")
             writer.newline()
             value.toXML(writer, ttFont)
             writer.endtag("panose")
         elif name in ("ulUnicodeRange1", "ulUnicodeRange2",
                       "ulUnicodeRange3", "ulUnicodeRange4",
                       "ulCodePageRange1", "ulCodePageRange2"):
             writer.simpletag(name, value=num2binary(value))
         elif name in ("fsType", "fsSelection"):
             writer.simpletag(name, value=num2binary(value, 16))
         elif name == "achVendID":
             writer.simpletag(name, value=repr(value)[1:-1])
         else:
             writer.simpletag(name, value=value)
         writer.newline()
Ejemplo n.º 2
0
	def toXML(self, writer, ttFont):
		if self.version == 1:
			format = OS2_format_1
		elif self.version in (2, 3, 4):
			format = OS2_format_2
		else:
			format = OS2_format_0
		formatstring, names, fixes = sstruct.getformat(format)
		for name in names:
			value = getattr(self, name)
			if type(value) == type(0):
				value = int(value)
			if name=="panose":
				writer.begintag("panose")
				writer.newline()
				value.toXML(writer, ttFont)
				writer.endtag("panose")
			elif name in ("ulUnicodeRange1", "ulUnicodeRange2", 
					"ulUnicodeRange3", "ulUnicodeRange4",
					"ulCodePageRange1", "ulCodePageRange2"):
				writer.simpletag(name, value=num2binary(value))
			elif name in ("fsType", "fsSelection"):
				writer.simpletag(name, value=num2binary(value, 16))
			elif name == "achVendID":
				writer.simpletag(name, value=repr(value)[1:-1])
			else:
				writer.simpletag(name, value=value)
			writer.newline()
Ejemplo n.º 3
0
	def toXML(self, writer, ttFont):
		if self.tableVersion != 0x00005000:
			writer.comment("Most of this table will be recalculated by the compiler")
			writer.newline()
		formatstring, names, fixes = sstruct.getformat(maxpFormat_0_5)
		if self.tableVersion != 0x00005000:
			formatstring, names_1_0, fixes = sstruct.getformat(maxpFormat_1_0_add)
			names = names + names_1_0
		for name in names:
			value = getattr(self, name)
			if type(value) == type(0):
				value=int(value)
			if name == "tableVersion":
				value = hex(value)
			writer.simpletag(name, value=value)
			writer.newline()
Ejemplo n.º 4
0
	def toXML(self, writer, ttFont):
		writer.comment("Most of this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(GPKGFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()

		writer.begintag("GMAPs")
		writer.newline()
		for gmapData in self.GMAPs:
			writer.begintag("hexdata")
			writer.newline()
			writer.dumphex(gmapData)
			writer.endtag("hexdata")
			writer.newline()
		writer.endtag("GMAPs")
		writer.newline()

		writer.begintag("glyphlets")
		writer.newline()
		for glyphletData in self.glyphlets:
			writer.begintag("hexdata")
			writer.newline()
			writer.dumphex(glyphletData)
			writer.endtag("hexdata")
			writer.newline()
		writer.endtag("glyphlets")
		writer.newline()
Ejemplo n.º 5
0
	def toXML(self, writer, ttFont):
		writer.begintag('ebdtComponent', [('name', self.name)])
		writer.newline()
		for componentName in sstruct.getformat(ebdtComponentFormat)[1][1:]:
			writer.simpletag(componentName, value=getattr(self, componentName))
			writer.newline()
		writer.endtag('ebdtComponent')
		writer.newline()
Ejemplo n.º 6
0
 def toXML(self, name, writer, ttFont):
     writer.begintag('sbitLineMetrics', [('direction', name)])
     writer.newline()
     for metricName in sstruct.getformat(sbitLineMetricsFormat)[1]:
         writer.simpletag(metricName, value=getattr(self, metricName))
         writer.newline()
     writer.endtag('sbitLineMetrics')
     writer.newline()
Ejemplo n.º 7
0
	def toXML(self, writer, ttFont):
		formatstring, names, fixes = sstruct.getformat(vheaFormat)
		for name in names:
			value = getattr(self, name)
			if type(value) == type(0):
				value = int(value)
			writer.simpletag(name, value=value)
			writer.newline()
Ejemplo n.º 8
0
 def toXML(self, writer, ttFont):
     writer.begintag('ebdtComponent', [('name', self.name)])
     writer.newline()
     for componentName in sstruct.getformat(ebdtComponentFormat)[1][1:]:
         writer.simpletag(componentName, value=getattr(self, componentName))
         writer.newline()
     writer.endtag('ebdtComponent')
     writer.newline()
Ejemplo n.º 9
0
	def toXML(self, name, writer, ttFont):
		writer.begintag('sbitLineMetrics', [('direction', name)])
		writer.newline()
		for metricName in sstruct.getformat(sbitLineMetricsFormat)[1]:
			writer.simpletag(metricName, value=getattr(self, metricName))
			writer.newline()
		writer.endtag('sbitLineMetrics')
		writer.newline()
Ejemplo n.º 10
0
	def toXML(self, writer, ttFont):
		writer.begintag(self.__class__.__name__)
		writer.newline()
		for metricName in sstruct.getformat(self.__class__.binaryFormat)[1]:
			writer.simpletag(metricName, value=getattr(self, metricName))
			writer.newline()
		writer.endtag(self.__class__.__name__)
		writer.newline()
Ejemplo n.º 11
0
 def toXML(self, writer, ttFont):
     writer.begintag(self.__class__.__name__)
     writer.newline()
     for metricName in sstruct.getformat(self.__class__.binaryFormat)[1]:
         writer.simpletag(metricName, value=getattr(self, metricName))
         writer.newline()
     writer.endtag(self.__class__.__name__)
     writer.newline()
Ejemplo n.º 12
0
 def toXML(self, writer, ttFont):
     formatstring, names, fixes = sstruct.getformat(vheaFormat)
     for name in names:
         value = getattr(self, name)
         if type(value) == type(0L):
             value = int(value)
         writer.simpletag(name, value=value)
         writer.newline()
Ejemplo n.º 13
0
 def toXML(self, writer, ttFont):
     if self.tableVersion != 0x00005000:
         writer.comment(
             "Most of this table will be recalculated by the compiler")
         writer.newline()
     formatstring, names, fixes = sstruct.getformat(maxpFormat_0_5)
     if self.tableVersion != 0x00005000:
         formatstring, names_1_0, fixes = sstruct.getformat(
             maxpFormat_1_0_add)
         names = names + names_1_0
     for name in names:
         value = getattr(self, name)
         if type(value) == type(0):
             value = int(value)
         if name == "tableVersion":
             value = hex(value)
         writer.simpletag(name, value=value)
         writer.newline()
Ejemplo n.º 14
0
	def toXML(self, writer, ttFont):
		writer.comment("Most of this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(SINGFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()
		writer.simpletag("baseGlyphName", value=self.baseGlyphName)
		writer.newline()
Ejemplo n.º 15
0
	def toXML(self, writer, ttFont):
		writer.comment("Lengths and number of entries in this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(METAHeaderFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()
		for glyphRec in self.glyphRecords:
			glyphRec.toXML(writer, ttFont)
Ejemplo n.º 16
0
	def toXML(self, writer, ttFont):
		writer.comment("Lengths and number of entries in this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(METAHeaderFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()
		for glyphRec in self.glyphRecords:
			glyphRec.toXML(writer, ttFont)
Ejemplo n.º 17
0
 def toXML(self, writer, ttFont):
     writer.comment(
         "Most of this table will be recalculated by the compiler")
     writer.newline()
     formatstring, names, fixes = sstruct.getformat(SINGFormat)
     for name in names:
         value = getattr(self, name)
         writer.simpletag(name, value=value)
         writer.newline()
     writer.simpletag("baseGlyphName", value=self.baseGlyphName)
     writer.newline()
Ejemplo n.º 18
0
	def toXML(self, writer, ttFont):
		writer.comment("Most of this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(GMAPFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()
		writer.simpletag("PSFontName", value=self.psFontName)
		writer.newline()
		for gmapRecord in self.gmapRecords:
			gmapRecord.toXML(writer, ttFont)
Ejemplo n.º 19
0
 def toXML(self, writer, ttFont):
     writer.comment(
         "Most of this table will be recalculated by the compiler")
     writer.newline()
     formatstring, names, fixes = sstruct.getformat(GMAPFormat)
     for name in names:
         value = getattr(self, name)
         writer.simpletag(name, value=value)
         writer.newline()
     writer.simpletag("PSFontName", value=self.psFontName)
     writer.newline()
     for gmapRecord in self.gmapRecords:
         gmapRecord.toXML(writer, ttFont)
Ejemplo n.º 20
0
class SbitLineMetrics:
    def toXML(self, name, writer, ttFont):
        writer.begintag('sbitLineMetrics', [('direction', name)])
        writer.newline()
        for metricName in sstruct.getformat(sbitLineMetricsFormat)[1]:
            writer.simpletag(metricName, value=getattr(self, metricName))
            writer.newline()
        writer.endtag('sbitLineMetrics')
        writer.newline()

    def fromXML(self, (name, attrs, content), ttFont):
        metricNames = set(sstruct.getformat(sbitLineMetricsFormat)[1])
        for element in content:
            if type(element) != TupleType:
                continue
            name, attrs, content = element
            if name in metricNames:
                vars(self)[name] = safeEval(attrs['value'])
Ejemplo n.º 21
0
 def toXML(self, writer, ttFont):
     formatstring, names, fixes = sstruct.getformat(postFormat)
     for name in names:
         value = getattr(self, name)
         writer.simpletag(name, value=value)
         writer.newline()
     if hasattr(self, "mapping"):
         writer.begintag("psNames")
         writer.newline()
         writer.comment(
             "This file uses unique glyph names based on the information\n"
             "found in the 'post' table. Since these names might not be unique,\n"
             "we have to invent artificial names in case of clashes. In order to\n"
             "be able to retain the original information, we need a name to\n"
             "ps name mapping for those cases where they differ. That's what\n"
             "you see below.\n")
         writer.newline()
         items = self.mapping.items()
         items.sort()
         for name, psName in items:
             writer.simpletag("psName", name=name, psName=psName)
             writer.newline()
         writer.endtag("psNames")
         writer.newline()
     if hasattr(self, "extraNames"):
         writer.begintag("extraNames")
         writer.newline()
         writer.comment(
             "following are the name that are not taken from the standard Mac glyph order"
         )
         writer.newline()
         for name in self.extraNames:
             writer.simpletag("psName", name=name)
             writer.newline()
         writer.endtag("extraNames")
         writer.newline()
     if hasattr(self, "data"):
         writer.begintag("hexdata")
         writer.newline()
         writer.dumphex(self.data)
         writer.endtag("hexdata")
         writer.newline()
Ejemplo n.º 22
0
	def toXML(self, writer, ttFont):
		writer.comment("Most of this table will be recalculated by the compiler")
		writer.newline()
		formatstring, names, fixes = sstruct.getformat(headFormat)
		for name in names:
			value = getattr(self, name)
			if name in ("created", "modified"):
				try:
					value = time.asctime(time.gmtime(max(0, value + mac_epoch_diff)))
				except ValueError:
					value = time.asctime(time.gmtime(0))
			if name in ("magicNumber", "checkSumAdjustment"):
				if value < 0:
					value = value + 0x100000000
				value = hex(value)
				if value[-1:] == "L":
					value = value[:-1]
			elif name in ("macStyle", "flags"):
				value = num2binary(value, 16)
			writer.simpletag(name, value=value)
			writer.newline()
Ejemplo n.º 23
0
 def toXML(self, writer, ttFont):
     writer.comment("Most of this table will be recalculated by the compiler")
     writer.newline()
     formatstring, names, fixes = sstruct.getformat(headFormat)
     for name in names:
         value = getattr(self, name)
         if name in ("created", "modified"):
             try:
                 value = time.asctime(time.gmtime(max(0, value + mac_epoch_diff)))
             except ValueError:
                 value = time.asctime(time.gmtime(0))
         if name in ("magicNumber", "checkSumAdjustment"):
             if value < 0:
                 value = value + 0x100000000
             value = hex(value)
             if value[-1:] == "L":
                 value = value[:-1]
         elif name in ("macStyle", "flags"):
             value = num2binary(value, 16)
         writer.simpletag(name, value=value)
         writer.newline()
Ejemplo n.º 24
0
class BitmapGlyphMetrics:
    def toXML(self, writer, ttFont):
        writer.begintag(self.__class__.__name__)
        writer.newline()
        for metricName in sstruct.getformat(self.__class__.binaryFormat)[1]:
            writer.simpletag(metricName, value=getattr(self, metricName))
            writer.newline()
        writer.endtag(self.__class__.__name__)
        writer.newline()

    def fromXML(self, (name, attrs, content), ttFont):
        metricNames = set(sstruct.getformat(self.__class__.binaryFormat)[1])
        for element in content:
            if type(element) != TupleType:
                continue
            name, attrs, content = element
            # Make sure this is a metric that is needed by GlyphMetrics.
            if name in metricNames:
                vars(self)[name] = safeEval(attrs['value'])
            else:
                print "Warning: unknown name '%s' being ignored in %s." % name, self.__class__.__name__
Ejemplo n.º 25
0
class EbdtComponent:
    def toXML(self, writer, ttFont):
        writer.begintag('ebdtComponent', [('name', self.name)])
        writer.newline()
        for componentName in sstruct.getformat(ebdtComponentFormat)[1][1:]:
            writer.simpletag(componentName, value=getattr(self, componentName))
            writer.newline()
        writer.endtag('ebdtComponent')
        writer.newline()

    def fromXML(self, (name, attrs, content), ttFont):
        self.name = attrs['name']
        componentNames = set(sstruct.getformat(ebdtComponentFormat)[1][1:])
        for element in content:
            if type(element) != TupleType:
                continue
            name, attrs, content = element
            if name in componentNames:
                vars(self)[name] = safeEval(attrs['value'])
            else:
                print "Warning: unknown name '%s' being ignored by EbdtComponent." % name
Ejemplo n.º 26
0
	def toXML(self, writer, ttFont):
		formatstring, names, fixes = sstruct.getformat(postFormat)
		for name in names:
			value = getattr(self, name)
			writer.simpletag(name, value=value)
			writer.newline()
		if hasattr(self, "mapping"):
			writer.begintag("psNames")
			writer.newline()
			writer.comment("This file uses unique glyph names based on the information\n"
						"found in the 'post' table. Since these names might not be unique,\n"
						"we have to invent artificial names in case of clashes. In order to\n"
						"be able to retain the original information, we need a name to\n"
						"ps name mapping for those cases where they differ. That's what\n"
						"you see below.\n")
			writer.newline()
			items = list(self.mapping.items())
			items.sort()
			for name, psName in items:
				writer.simpletag("psName", name=name, psName=psName)
				writer.newline()
			writer.endtag("psNames")
			writer.newline()
		if hasattr(self, "extraNames"):
			writer.begintag("extraNames")
			writer.newline()
			writer.comment("following are the name that are not taken from the standard Mac glyph order")
			writer.newline()
			for name in self.extraNames:
				writer.simpletag("psName", name=name)
				writer.newline()
			writer.endtag("extraNames")
			writer.newline()
		if hasattr(self, "data"):
			writer.begintag("hexdata")
			writer.newline()
			writer.dumphex(self.data)
			writer.endtag("hexdata")
			writer.newline()
Ejemplo n.º 27
0
 def _getXMLMetricNames(self):
     dataNames = sstruct.getformat(bitmapSizeTableFormatPart1)[1]
     dataNames = dataNames + sstruct.getformat(
         bitmapSizeTableFormatPart2)[1]
     # Skip the first 3 data names because they are byte offsets and counts.
     return dataNames[3:]
Ejemplo n.º 28
0
	def toXML(self, writer, ttFont):
		formatstring, names, fixes = sstruct.getformat(panoseFormat)
		for name in names:
			writer.simpletag(name, value=getattr(self, name))
			writer.newline()
Ejemplo n.º 29
0
	def _getXMLMetricNames(self):
		dataNames = sstruct.getformat(bitmapSizeTableFormatPart1)[1]
		dataNames = dataNames + sstruct.getformat(bitmapSizeTableFormatPart2)[1]
		# Skip the first 3 data names because they are byte offsets and counts.
		return dataNames[3:]
Ejemplo n.º 30
0
 def toXML(self, writer, ttFont):
     formatstring, names, fixes = sstruct.getformat(panoseFormat)
     for name in names:
         writer.simpletag(name, value=getattr(self, name))
         writer.newline()