aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorShadowNinja <shadowninja@minetest.net>2014-04-15 16:07:53 -0400
committerShadowNinja <shadowninja@minetest.net>2014-04-15 16:09:15 -0400
commit54ffe2e5de9ce44129f84f4748743f893b75fda7 (patch)
treef888b2f75e669912ad870df52a28be6f0dcf0a8d /src
parent118e2ae865bd7a0020586ef72d05bf14d66f4eae (diff)
downloadminetest-54ffe2e5de9ce44129f84f4748743f893b75fda7.tar.gz
minetest-54ffe2e5de9ce44129f84f4748743f893b75fda7.tar.bz2
minetest-54ffe2e5de9ce44129f84f4748743f893b75fda7.zip
Use binary operators rather than "Python modulo" in decoding block positions
Diffstat (limited to 'src')
-rw-r--r--src/database.cpp38
-rw-r--r--src/database.h4
2 files changed, 19 insertions, 23 deletions
diff --git a/src/database.cpp b/src/database.cpp
index e3d92f915..cf208be8d 100644
--- a/src/database.cpp
+++ b/src/database.cpp
@@ -20,33 +20,29 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "database.h"
#include "irrlichttypes.h"
-static s32 unsignedToSigned(s32 i, s32 max_positive)
+static inline s16 unsigned_to_signed(u16 i, u16 max_positive)
{
- if(i < max_positive)
+ if (i < max_positive) {
return i;
- else
- return i - 2*max_positive;
+ } else {
+ return i - (max_positive * 2);
+ }
}
-// modulo of a negative number does not work consistently in C
-static s64 pythonmodulo(s64 i, s64 mod)
-{
- if(i >= 0)
- return i % mod;
- return mod - ((-i) % mod);
-}
-s64 Database::getBlockAsInteger(const v3s16 pos) {
- return (u64) pos.Z * 16777216 +
- (u64) pos.Y * 4096 +
+s64 Database::getBlockAsInteger(const v3s16 pos) const
+{
+ return (u64) pos.Z * 0x1000000 +
+ (u64) pos.Y * 0x1000 +
(u64) pos.X;
}
-v3s16 Database::getIntegerAsBlock(s64 i) {
- s32 x = unsignedToSigned(pythonmodulo(i, 4096), 2048);
- i = (i - x) / 4096;
- s32 y = unsignedToSigned(pythonmodulo(i, 4096), 2048);
- i = (i - y) / 4096;
- s32 z = unsignedToSigned(pythonmodulo(i, 4096), 2048);
- return v3s16(x,y,z);
+v3s16 Database::getIntegerAsBlock(const 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;
}
+
diff --git a/src/database.h b/src/database.h
index 4ce80ed93..a86861379 100644
--- a/src/database.h
+++ b/src/database.h
@@ -34,8 +34,8 @@ public:
virtual void saveBlock(MapBlock *block)=0;
virtual MapBlock* loadBlock(v3s16 blockpos)=0;
- s64 getBlockAsInteger(const v3s16 pos);
- v3s16 getIntegerAsBlock(s64 i);
+ s64 getBlockAsInteger(const v3s16 pos) const;
+ v3s16 getIntegerAsBlock(const s64 i) const;
virtual void listAllLoadableBlocks(std::list<v3s16> &dst)=0;
virtual int Initialized(void)=0;
virtual ~Database() {};