Commit 6aa4b20f authored by Feng Xiao's avatar Feng Xiao Committed by GitHub

Merge pull request #3327 from htuch/fix-3322

Use consistent hash across NDEBUG/!NDEBUG builds.
parents 71f2f0d7 f6ff32cd
...@@ -862,14 +862,7 @@ class Map { ...@@ -862,14 +862,7 @@ class Map {
size_type BucketNumber(const Key& k) const { size_type BucketNumber(const Key& k) const {
// We inherit from hasher, so one-arg operator() provides a hash function. // We inherit from hasher, so one-arg operator() provides a hash function.
size_type h = (*const_cast<InnerMap*>(this))(k); size_type h = (*const_cast<InnerMap*>(this))(k);
// To help prevent people from making assumptions about the hash function,
// we use the seed differently depending on NDEBUG. The default hash
// function, the seeding, etc., are all likely to change in the future.
#ifndef NDEBUG
return (h * (seed_ | 1)) & (num_buckets_ - 1);
#else
return (h + seed_) & (num_buckets_ - 1); return (h + seed_) & (num_buckets_ - 1);
#endif
} }
bool IsMatch(const Key& k0, const Key& k1) const { bool IsMatch(const Key& k0, const Key& k1) const {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment