summaryrefslogtreecommitdiff
path: root/util/sectors2sqlite.py
diff options
context:
space:
mode:
authorLoïc Blot <nerzhul@users.noreply.github.com>2017-06-11 12:49:30 +0200
committerGitHub <noreply@github.com>2017-06-11 12:49:30 +0200
commit03ff53e16bafe1aaa278625864c546a525d08dfc (patch)
treecf2fa74250a2281fd0c812aae0d566577b75adf6 /util/sectors2sqlite.py
parent26e2eb019afa60c66c4dc89cf24bbf5b25c6a383 (diff)
downloadminetest-03ff53e16bafe1aaa278625864c546a525d08dfc.tar.gz
minetest-03ff53e16bafe1aaa278625864c546a525d08dfc.tar.bz2
minetest-03ff53e16bafe1aaa278625864c546a525d08dfc.zip
Remove minetestmapper from this repository (#5901)
It's now located at https://github.com/minetest/minetestmapper Remove colors.txt and sectors2sqlite too
Diffstat (limited to 'util/sectors2sqlite.py')
-rwxr-xr-xutil/sectors2sqlite.py132
1 files changed, 0 insertions, 132 deletions
diff --git a/util/sectors2sqlite.py b/util/sectors2sqlite.py
deleted file mode 100755
index 38261a498..000000000
--- a/util/sectors2sqlite.py
+++ /dev/null
@@ -1,132 +0,0 @@
-#!/usr/bin/python3
-
-# Loads block files from sectors folders into map.sqlite database.
-# The sectors folder should be safe to remove after this prints "Finished."
-
-import time, os, sys
-
-try:
- import sqlite3
-except:
- exit('You need to have the Python sqlite3 module.')
-
-path = "../world/"
-
-paths = []
-
-# sectors2 gets to try first
-if os.path.isdir(path + 'sectors2/'):
- paths.append('sectors2')
-if os.path.isdir(path + 'sectors/'):
- paths.append('sectors')
-
-if not paths:
- exit('Could not find sectors folder at ' + path + 'sectors2/ or ' + path + 'sectors/')
-
-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
- while u <= -2**63:
- u += 2**64
- return u
-
-# Convert sector folder(s) to integer
-def getSectorPos(dirname):
- if len(dirname) == 8:
- # Old layout
- x = parseSigned16bit(dirname[:4])
- z = parseSigned16bit(dirname[4:])
- elif len(dirname) == 7:
- # New layout
- x = parseSigned12bit(dirname[:3])
- z = parseSigned12bit(dirname[4:])
- else:
- print('Terrible sector at ' + dirname)
- return
-
- return x, z
-
-# Convert block file to integer position
-def getBlockPos(sectordir, blockfile):
- p2d = getSectorPos(sectordir)
-
- if not p2d:
- return
-
- if len(blockfile) != 4:
- print("Invalid block filename: " + blockfile)
-
- y = parseSigned16bit(blockfile)
-
- return p2d[0], y, p2d[1]
-
-# Convert location to integer
-def getBlockAsInteger(p):
- return int64(p[2]*16777216 + p[1]*4096 + p[0])
-
-# Init
-
-create = False
-if not os.path.isfile(path + 'map.sqlite'):
- create = True
-
-conn = sqlite3.connect(path + 'map.sqlite')
-
-if not conn:
- exit('Could not open database.')
-
-cur = conn.cursor()
-
-if create:
- cur.execute("CREATE TABLE IF NOT EXISTS `blocks` (`pos` INT NOT NULL PRIMARY KEY, `data` BLOB);")
- conn.commit()
- print('Created database at ' + path + 'map.sqlite')
-
-# Crawl the folders
-
-count = 0
-t = time.time()
-for base in paths:
- v = 0
- if base == 'sectors':
- v = 1
- elif base == 'sectors2':
- v= 2
- else:
- print('Ignoring base ' + base)
- continue
-
- for root, dirs, files in os.walk(path + base):
- if files:
- for block in files:
- pos = getBlockAsInteger(getBlockPos(root[(-8 if v == 1 else -7 if v == 2 else 0):], block))
-
- if pos is None:
- print('Ignoring broken path ' + root + '/' + block)
- continue
-
- f = open(root+'/'+block, 'rb')
- blob = f.read()
- f.close()
- if sys.version_info.major == 2:
- blob = buffer(blob)
- else:
- blob = memoryview(blob)
- cur.execute('INSERT OR IGNORE INTO `blocks` VALUES(?, ?)', (pos, blob))
- count += 1
-
- if(time.time() - t > 3):
- t = time.time()
- print(str(count)+' blocks processed...')
-
-conn.commit()
-
-print('Finished. (' + str(count) + ' blocks)')