summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLogicParrot <LogicParrot@users.noreply.github.com>2016-04-20 23:53:38 +0200
committerLogicParrot <LogicParrot@users.noreply.github.com>2016-04-22 16:45:45 +0200
commit109a07fd95a001f296e67857f941e9cfeb8c46e7 (patch)
tree1f2081f5b7286b509644f6a2766235aa2041fbee
parentMerge pull request #3150 from LogicParrot/worldTweaks (diff)
downloadcuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar.gz
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar.bz2
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar.lz
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar.xz
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.tar.zst
cuberite-109a07fd95a001f296e67857f941e9cfeb8c46e7.zip
-rw-r--r--src/Vector3.h10
1 files changed, 4 insertions, 6 deletions
diff --git a/src/Vector3.h b/src/Vector3.h
index c4b72fd57..19ab0b021 100644
--- a/src/Vector3.h
+++ b/src/Vector3.h
@@ -396,13 +396,11 @@ public:
/** Provides a hash of a vector's contents */
size_t operator()(const Vector3<What> & a_Vector) const
{
- // Guaranteed to have no hash collisions for any 128x128x128 area
- size_t Hash = 0;
+ // Guaranteed to have non repeating hashes for any 128x128x128 area
+ size_t Hash = static_cast<size_t>(a_Vector.y);
+ Hash <<= 16;
Hash ^= static_cast<size_t>(a_Vector.x);
- Hash <<= 8;
- Hash ^= static_cast<size_t>(a_Vector.y);
- Hash <<= 8;
- Hash ^= static_cast<size_t>(a_Vector.z);
+ Hash ^= static_cast<size_t>(a_Vector.z) << 8;
return Hash;
}
};