Fix processing of blocks below y=0 in sectors2sqlite.py.
authorKahrl <kahrl@gmx.net>
Mon, 26 Sep 2011 11:10:22 +0000 (13:10 +0200)
committerKahrl <kahrl@gmx.net>
Mon, 26 Sep 2011 11:10:22 +0000 (13:10 +0200)
util/sectors2sqlite.py

index 16ee7aae41f0ca74cb2d773b734c2a922e09d959..178842129482857f45dba84c1ecf1d273a28191b 100755 (executable)
@@ -23,10 +23,14 @@ if os.path.isdir(path + 'sectors/'):
 if not paths:
        exit('Could not find sectors folder at ' + path + 'sectors2/ or ' + path + 'sectors/')
 
-def uint(u):
+def parseSigned12bit(u):
        u = int('0x'+u, 16)
        return (u if u < 2**11 else u - 2**12)
 
+def parseSigned16bit(u):
+       u = int('0x'+u, 16)
+       return (u if u < 2**15 else u - 2**16)
+
 def int64(u):
        while u >= 2**63:
                u -= 2**64
@@ -38,12 +42,12 @@ def int64(u):
 def getSectorPos(dirname):
        if len(dirname) == 8:
                # Old layout
-               x = uint(dirname[:4])
-               z = uint(dirname[4:])
+               x = parseSigned16bit(dirname[:4])
+               z = parseSigned16bit(dirname[4:])
        elif len(dirname) == 7:
                # New layout
-               x = uint(dirname[:3])
-               z = uint(dirname[4:])
+               x = parseSigned12bit(dirname[:3])
+               z = parseSigned12bit(dirname[4:])
        else:
                print('Terrible sector at ' + dirname)
                return
@@ -60,7 +64,7 @@ def getBlockPos(sectordir, blockfile):
        if len(blockfile) != 4:
                print("Invalid block filename: " + blockfile)
        
-       y = uint(blockfile)
+       y = parseSigned16bit(blockfile)
        
        return p2d[0], y, p2d[1]