summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2015-01-27 05:19:14 +0100
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2015-01-27 05:56:34 +0100
commit2a481c84561d6c8ce37d75cc334f7c149ffb2bb9 (patch)
tree35f33621d69c976a6f362428f2162d0784b3b7fe /tools
parentbuild-sys: unbundle unifont (diff)
downloadsystemd-2a481c84561d6c8ce37d75cc334f7c149ffb2bb9.tar.xz
systemd-2a481c84561d6c8ce37d75cc334f7c149ffb2bb9.zip
compile-unifont: Python 2 compatibility
Under Python 2, sys.stdout.buffer is missing.
Diffstat (limited to 'tools')
-rwxr-xr-xtools/compile-unifont.py41
1 files changed, 22 insertions, 19 deletions
diff --git a/tools/compile-unifont.py b/tools/compile-unifont.py
index 7004b946d2..5464c53e7f 100755
--- a/tools/compile-unifont.py
+++ b/tools/compile-unifont.py
@@ -31,6 +31,9 @@ import struct
# Write "bits" array as binary output.
#
+
+write = getattr(sys.stdout, 'buffer', sys.stdout).write
+
def write_bin_entry(entry):
l = len(entry)
if l != 32 and l != 64:
@@ -39,10 +42,10 @@ def write_bin_entry(entry):
elif l < 64:
entry += "0" * (64 - l)
- sys.stdout.buffer.write(struct.pack('B', int(l / 32))) # width
- sys.stdout.buffer.write(struct.pack('B', 0)) # padding
- sys.stdout.buffer.write(struct.pack('H', 0)) # padding
- sys.stdout.buffer.write(struct.pack('I', 0)) # padding
+ write(struct.pack('B', int(l / 32))) # width
+ write(struct.pack('B', 0)) # padding
+ write(struct.pack('H', 0)) # padding
+ write(struct.pack('I', 0)) # padding
i = 0
for j in range(0, 16):
@@ -53,23 +56,23 @@ def write_bin_entry(entry):
c = int(entry[i:i+2], 16)
i += 2
- sys.stdout.buffer.write(struct.pack('B', c))
+ write(struct.pack('B', c))
def write_bin(bits):
- sys.stdout.buffer.write(struct.pack('B', 0x44)) # ASCII: 'D'
- sys.stdout.buffer.write(struct.pack('B', 0x56)) # ASCII: 'V'
- sys.stdout.buffer.write(struct.pack('B', 0x44)) # ASCII: 'D'
- sys.stdout.buffer.write(struct.pack('B', 0x48)) # ASCII: 'H'
- sys.stdout.buffer.write(struct.pack('B', 0x52)) # ASCII: 'R'
- sys.stdout.buffer.write(struct.pack('B', 0x4d)) # ASCII: 'M'
- sys.stdout.buffer.write(struct.pack('B', 0x55)) # ASCII: 'U'
- sys.stdout.buffer.write(struct.pack('B', 0x46)) # ASCII: 'F'
- sys.stdout.buffer.write(struct.pack('<I', 0)) # compatible-flags
- sys.stdout.buffer.write(struct.pack('<I', 0)) # incompatible-flags
- sys.stdout.buffer.write(struct.pack('<I', 32)) # header-size
- sys.stdout.buffer.write(struct.pack('<H', 8)) # glyph-header-size
- sys.stdout.buffer.write(struct.pack('<H', 2)) # glyph-stride
- sys.stdout.buffer.write(struct.pack('<Q', 32)) # glyph-body-size
+ write(struct.pack('B', 0x44)) # ASCII: 'D'
+ write(struct.pack('B', 0x56)) # ASCII: 'V'
+ write(struct.pack('B', 0x44)) # ASCII: 'D'
+ write(struct.pack('B', 0x48)) # ASCII: 'H'
+ write(struct.pack('B', 0x52)) # ASCII: 'R'
+ write(struct.pack('B', 0x4d)) # ASCII: 'M'
+ write(struct.pack('B', 0x55)) # ASCII: 'U'
+ write(struct.pack('B', 0x46)) # ASCII: 'F'
+ write(struct.pack('<I', 0)) # compatible-flags
+ write(struct.pack('<I', 0)) # incompatible-flags
+ write(struct.pack('<I', 32)) # header-size
+ write(struct.pack('<H', 8)) # glyph-header-size
+ write(struct.pack('<H', 2)) # glyph-stride
+ write(struct.pack('<Q', 32)) # glyph-body-size
# write glyphs
for idx in range(len(bits)):