summaryrefslogtreecommitdiff
path: root/src/database.cpp
diff options
context:
space:
mode:
authorShadowNinja <shadowninja@minetest.net>2014-04-22 12:52:48 -0400
committerShadowNinja <shadowninja@minetest.net>2014-04-23 15:39:33 -0400
commit41bc24477b732b74bd18839a9742d32bd85d1b44 (patch)
tree40087c6360906e890e62d97e77582b82bea88ea1 /src/database.cpp
parent9ec281c712c0c7c3adac3847412f6e4d587abc00 (diff)
downloadminetest-41bc24477b732b74bd18839a9742d32bd85d1b44.tar.gz
minetest-41bc24477b732b74bd18839a9742d32bd85d1b44.tar.bz2
minetest-41bc24477b732b74bd18839a9742d32bd85d1b44.zip
Revert binary database block position encoding
This reverts commits a2003b0d553c7223a61c75e5dad79ea68e058ba2 and 54ffe2e5de9ce44129f84f4748743f893b75fda7. These weren't correct. Add a black magic warning instead.
Diffstat (limited to 'src/database.cpp')
-rw-r--r--src/database.cpp39
1 files changed, 30 insertions, 9 deletions
diff --git a/src/database.cpp b/src/database.cpp
index 15579a7f0..26f6992fc 100644
--- a/src/database.cpp
+++ b/src/database.cpp
@@ -20,6 +20,14 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "database.h"
#include "irrlichttypes.h"
+
+/****************
+ * Black magic! *
+ ****************
+ * The position hashing is very messed up.
+ * It's a lot more complicated than it looks.
+ */
+
static inline s16 unsigned_to_signed(u16 i, u16 max_positive)
{
if (i < max_positive) {
@@ -30,19 +38,32 @@ static inline s16 unsigned_to_signed(u16 i, u16 max_positive)
}
+// Modulo of a negative number does not work consistently in C
+static inline s64 pythonmodulo(s64 i, s16 mod)
+{
+ if (i >= 0) {
+ return i % mod;
+ }
+ return mod - ((-i) % mod);
+}
+
+
s64 Database::getBlockAsInteger(const v3s16 pos) const
{
- return (((u64) pos.Z) << 24) +
- (((u64) pos.Y) << 12) +
- ((u64) pos.X);
+ return (u64) pos.Z * 0x1000000 +
+ (u64) pos.Y * 0x1000 +
+ (u64) pos.X;
}
-v3s16 Database::getIntegerAsBlock(const s64 i) const
+
+v3s16 Database::getIntegerAsBlock(s64 i) const
{
- v3s16 pos;
- pos.Z = unsigned_to_signed((i >> 24) & 0xFFF, 0x1000 / 2);
- pos.Y = unsigned_to_signed((i >> 12) & 0xFFF, 0x1000 / 2);
- pos.X = unsigned_to_signed((i ) & 0xFFF, 0x1000 / 2);
- return pos;
+ v3s16 pos;
+ pos.X = unsigned_to_signed(pythonmodulo(i, 4096), 2048);
+ i = (i - pos.X) / 4096;
+ pos.Y = unsigned_to_signed(pythonmodulo(i, 4096), 2048);
+ i = (i - pos.Y) / 4096;
+ pos.Z = unsigned_to_signed(pythonmodulo(i, 4096), 2048);
+ return pos;
}