llvm-mc: Hopefully fix Mach-O tests on big-endian platforms, force values to be
authorDaniel Dunbar <daniel@zuster.org>
Sat, 22 Aug 2009 09:28:33 +0000 (09:28 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Sat, 22 Aug 2009 09:28:33 +0000 (09:28 +0000)
converted to Python ints if possible.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79736 91177308-0d34-0410-b5e6-96231b3b80d8

test/Scripts/macho-dump

index d37b545b2ab12633cc329045bf861b2961ffed99..c41482c6ebf2b54fc11de4dbb843a1091a58bd1d 100755 (executable)
@@ -37,7 +37,10 @@ class Reader:
       return struct.unpack('><'[self.isLSB] + 'H', self.read(2))[0]
 
    def read32(self):
-      return struct.unpack('><'[self.isLSB] + 'I', self.read(4))[0]
+      # Force to 32-bit, if possible; otherwise these might be long ints on a
+      # big-endian platform. FIXME: Why???
+      Value = struct.unpack('><'[self.isLSB] + 'I', self.read(4))[0]
+      return int(Value)
 
    def registerStringTable(self, strings):
       if self.string_table is not None: