mirror of https://github.com/YosysHQ/yosys.git
hashlib: use hash_t across the board
This commit is contained in:
parent
c73c88033d
commit
b8738e2bd7
|
@ -83,7 +83,7 @@ class Hasher {
|
||||||
// traditionally 5381 is used as starting value for the djb2 hash
|
// traditionally 5381 is used as starting value for the djb2 hash
|
||||||
state = 5381;
|
state = 5381;
|
||||||
}
|
}
|
||||||
static void set_fudge(uint32_t f) {
|
static void set_fudge(hash_t f) {
|
||||||
fudge = f;
|
fudge = f;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,6 +108,7 @@ class Hasher {
|
||||||
state = mkhash((uint32_t)(i >> 32ULL), state);
|
state = mkhash((uint32_t)(i >> 32ULL), state);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
[[nodiscard]]
|
||||||
hash_t yield() {
|
hash_t yield() {
|
||||||
return (hash_t)state;
|
return (hash_t)state;
|
||||||
}
|
}
|
||||||
|
@ -241,6 +242,7 @@ struct hash_obj_ops {
|
||||||
* desirable qualities of the hash function
|
* desirable qualities of the hash function
|
||||||
*/
|
*/
|
||||||
template<typename T>
|
template<typename T>
|
||||||
|
[[nodiscard]]
|
||||||
Hasher::hash_t run_hash(const T& obj) {
|
Hasher::hash_t run_hash(const T& obj) {
|
||||||
Hasher h;
|
Hasher h;
|
||||||
h.acc(obj);
|
h.acc(obj);
|
||||||
|
@ -345,7 +347,7 @@ class dict {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int do_hash(const K &key) const
|
Hasher::hash_t do_hash(const K &key) const
|
||||||
{
|
{
|
||||||
Hasher::hash_t hash = 0;
|
Hasher::hash_t hash = 0;
|
||||||
if (!hashtable.empty())
|
if (!hashtable.empty())
|
||||||
|
@ -360,13 +362,13 @@ class dict {
|
||||||
|
|
||||||
for (int i = 0; i < int(entries.size()); i++) {
|
for (int i = 0; i < int(entries.size()); i++) {
|
||||||
do_assert(-1 <= entries[i].next && entries[i].next < int(entries.size()));
|
do_assert(-1 <= entries[i].next && entries[i].next < int(entries.size()));
|
||||||
int hash = do_hash(entries[i].udata.first);
|
Hasher::hash_t hash = do_hash(entries[i].udata.first);
|
||||||
entries[i].next = hashtable[hash];
|
entries[i].next = hashtable[hash];
|
||||||
hashtable[hash] = i;
|
hashtable[hash] = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_erase(int index, int hash)
|
int do_erase(int index, Hasher::hash_t hash)
|
||||||
{
|
{
|
||||||
do_assert(index < int(entries.size()));
|
do_assert(index < int(entries.size()));
|
||||||
if (hashtable.empty() || index < 0)
|
if (hashtable.empty() || index < 0)
|
||||||
|
@ -389,7 +391,7 @@ class dict {
|
||||||
|
|
||||||
if (index != back_idx)
|
if (index != back_idx)
|
||||||
{
|
{
|
||||||
int back_hash = do_hash(entries[back_idx].udata.first);
|
Hasher::hash_t back_hash = do_hash(entries[back_idx].udata.first);
|
||||||
|
|
||||||
k = hashtable[back_hash];
|
k = hashtable[back_hash];
|
||||||
do_assert(0 <= k && k < int(entries.size()));
|
do_assert(0 <= k && k < int(entries.size()));
|
||||||
|
@ -415,7 +417,7 @@ class dict {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_lookup(const K &key, int &hash) const
|
int do_lookup(const K &key, Hasher::hash_t &hash) const
|
||||||
{
|
{
|
||||||
if (hashtable.empty())
|
if (hashtable.empty())
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -435,7 +437,7 @@ class dict {
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_insert(const K &key, int &hash)
|
int do_insert(const K &key, Hasher::hash_t &hash)
|
||||||
{
|
{
|
||||||
if (hashtable.empty()) {
|
if (hashtable.empty()) {
|
||||||
entries.emplace_back(std::pair<K, T>(key, T()), -1);
|
entries.emplace_back(std::pair<K, T>(key, T()), -1);
|
||||||
|
@ -448,7 +450,7 @@ class dict {
|
||||||
return entries.size() - 1;
|
return entries.size() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_insert(const std::pair<K, T> &value, int &hash)
|
int do_insert(const std::pair<K, T> &value, Hasher::hash_t &hash)
|
||||||
{
|
{
|
||||||
if (hashtable.empty()) {
|
if (hashtable.empty()) {
|
||||||
entries.emplace_back(value, -1);
|
entries.emplace_back(value, -1);
|
||||||
|
@ -461,7 +463,7 @@ class dict {
|
||||||
return entries.size() - 1;
|
return entries.size() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_insert(std::pair<K, T> &&rvalue, int &hash)
|
int do_insert(std::pair<K, T> &&rvalue, Hasher::hash_t &hash)
|
||||||
{
|
{
|
||||||
if (hashtable.empty()) {
|
if (hashtable.empty()) {
|
||||||
auto key = rvalue.first;
|
auto key = rvalue.first;
|
||||||
|
@ -573,7 +575,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> insert(const K &key)
|
std::pair<iterator, bool> insert(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -583,7 +585,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> insert(const std::pair<K, T> &value)
|
std::pair<iterator, bool> insert(const std::pair<K, T> &value)
|
||||||
{
|
{
|
||||||
int hash = do_hash(value.first);
|
Hasher::hash_t hash = do_hash(value.first);
|
||||||
int i = do_lookup(value.first, hash);
|
int i = do_lookup(value.first, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -593,7 +595,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> insert(std::pair<K, T> &&rvalue)
|
std::pair<iterator, bool> insert(std::pair<K, T> &&rvalue)
|
||||||
{
|
{
|
||||||
int hash = do_hash(rvalue.first);
|
Hasher::hash_t hash = do_hash(rvalue.first);
|
||||||
int i = do_lookup(rvalue.first, hash);
|
int i = do_lookup(rvalue.first, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -603,7 +605,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> emplace(K const &key, T const &value)
|
std::pair<iterator, bool> emplace(K const &key, T const &value)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -613,7 +615,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> emplace(K const &key, T &&rvalue)
|
std::pair<iterator, bool> emplace(K const &key, T &&rvalue)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -623,7 +625,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> emplace(K &&rkey, T const &value)
|
std::pair<iterator, bool> emplace(K &&rkey, T const &value)
|
||||||
{
|
{
|
||||||
int hash = do_hash(rkey);
|
Hasher::hash_t hash = do_hash(rkey);
|
||||||
int i = do_lookup(rkey, hash);
|
int i = do_lookup(rkey, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -633,7 +635,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> emplace(K &&rkey, T &&rvalue)
|
std::pair<iterator, bool> emplace(K &&rkey, T &&rvalue)
|
||||||
{
|
{
|
||||||
int hash = do_hash(rkey);
|
Hasher::hash_t hash = do_hash(rkey);
|
||||||
int i = do_lookup(rkey, hash);
|
int i = do_lookup(rkey, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -643,35 +645,35 @@ public:
|
||||||
|
|
||||||
int erase(const K &key)
|
int erase(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int index = do_lookup(key, hash);
|
int index = do_lookup(key, hash);
|
||||||
return do_erase(index, hash);
|
return do_erase(index, hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator erase(iterator it)
|
iterator erase(iterator it)
|
||||||
{
|
{
|
||||||
int hash = do_hash(it->first);
|
Hasher::hash_t hash = do_hash(it->first);
|
||||||
do_erase(it.index, hash);
|
do_erase(it.index, hash);
|
||||||
return ++it;
|
return ++it;
|
||||||
}
|
}
|
||||||
|
|
||||||
int count(const K &key) const
|
int count(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
return i < 0 ? 0 : 1;
|
return i < 0 ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int count(const K &key, const_iterator it) const
|
int count(const K &key, const_iterator it) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
return i < 0 || i > it.index ? 0 : 1;
|
return i < 0 || i > it.index ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator find(const K &key)
|
iterator find(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return end();
|
return end();
|
||||||
|
@ -680,7 +682,7 @@ public:
|
||||||
|
|
||||||
const_iterator find(const K &key) const
|
const_iterator find(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return end();
|
return end();
|
||||||
|
@ -689,7 +691,7 @@ public:
|
||||||
|
|
||||||
T& at(const K &key)
|
T& at(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
throw std::out_of_range("dict::at()");
|
throw std::out_of_range("dict::at()");
|
||||||
|
@ -698,7 +700,7 @@ public:
|
||||||
|
|
||||||
const T& at(const K &key) const
|
const T& at(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
throw std::out_of_range("dict::at()");
|
throw std::out_of_range("dict::at()");
|
||||||
|
@ -707,7 +709,7 @@ public:
|
||||||
|
|
||||||
const T& at(const K &key, const T &defval) const
|
const T& at(const K &key, const T &defval) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return defval;
|
return defval;
|
||||||
|
@ -716,7 +718,7 @@ public:
|
||||||
|
|
||||||
T& operator[](const K &key)
|
T& operator[](const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
i = do_insert(std::pair<K, T>(key, T()), hash);
|
i = do_insert(std::pair<K, T>(key, T()), hash);
|
||||||
|
@ -804,7 +806,7 @@ protected:
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int do_hash(const K &key) const
|
Hasher::hash_t do_hash(const K &key) const
|
||||||
{
|
{
|
||||||
Hasher::hash_t hash = 0;
|
Hasher::hash_t hash = 0;
|
||||||
if (!hashtable.empty())
|
if (!hashtable.empty())
|
||||||
|
@ -819,13 +821,13 @@ protected:
|
||||||
|
|
||||||
for (int i = 0; i < int(entries.size()); i++) {
|
for (int i = 0; i < int(entries.size()); i++) {
|
||||||
do_assert(-1 <= entries[i].next && entries[i].next < int(entries.size()));
|
do_assert(-1 <= entries[i].next && entries[i].next < int(entries.size()));
|
||||||
int hash = do_hash(entries[i].udata);
|
Hasher::hash_t hash = do_hash(entries[i].udata);
|
||||||
entries[i].next = hashtable[hash];
|
entries[i].next = hashtable[hash];
|
||||||
hashtable[hash] = i;
|
hashtable[hash] = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_erase(int index, int hash)
|
int do_erase(int index, Hasher::hash_t hash)
|
||||||
{
|
{
|
||||||
do_assert(index < int(entries.size()));
|
do_assert(index < int(entries.size()));
|
||||||
if (hashtable.empty() || index < 0)
|
if (hashtable.empty() || index < 0)
|
||||||
|
@ -846,7 +848,7 @@ protected:
|
||||||
|
|
||||||
if (index != back_idx)
|
if (index != back_idx)
|
||||||
{
|
{
|
||||||
int back_hash = do_hash(entries[back_idx].udata);
|
Hasher::hash_t back_hash = do_hash(entries[back_idx].udata);
|
||||||
|
|
||||||
k = hashtable[back_hash];
|
k = hashtable[back_hash];
|
||||||
if (k == back_idx) {
|
if (k == back_idx) {
|
||||||
|
@ -870,7 +872,7 @@ protected:
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_lookup(const K &key, int &hash) const
|
int do_lookup(const K &key, Hasher::hash_t &hash) const
|
||||||
{
|
{
|
||||||
if (hashtable.empty())
|
if (hashtable.empty())
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -890,7 +892,7 @@ protected:
|
||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_insert(const K &value, int &hash)
|
int do_insert(const K &value, Hasher::hash_t &hash)
|
||||||
{
|
{
|
||||||
if (hashtable.empty()) {
|
if (hashtable.empty()) {
|
||||||
entries.emplace_back(value, -1);
|
entries.emplace_back(value, -1);
|
||||||
|
@ -903,7 +905,7 @@ protected:
|
||||||
return entries.size() - 1;
|
return entries.size() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_insert(K &&rvalue, int &hash)
|
int do_insert(K &&rvalue, Hasher::hash_t &hash)
|
||||||
{
|
{
|
||||||
if (hashtable.empty()) {
|
if (hashtable.empty()) {
|
||||||
entries.emplace_back(std::forward<K>(rvalue), -1);
|
entries.emplace_back(std::forward<K>(rvalue), -1);
|
||||||
|
@ -1010,7 +1012,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> insert(const K &value)
|
std::pair<iterator, bool> insert(const K &value)
|
||||||
{
|
{
|
||||||
int hash = do_hash(value);
|
Hasher::hash_t hash = do_hash(value);
|
||||||
int i = do_lookup(value, hash);
|
int i = do_lookup(value, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -1020,7 +1022,7 @@ public:
|
||||||
|
|
||||||
std::pair<iterator, bool> insert(K &&rvalue)
|
std::pair<iterator, bool> insert(K &&rvalue)
|
||||||
{
|
{
|
||||||
int hash = do_hash(rvalue);
|
Hasher::hash_t hash = do_hash(rvalue);
|
||||||
int i = do_lookup(rvalue, hash);
|
int i = do_lookup(rvalue, hash);
|
||||||
if (i >= 0)
|
if (i >= 0)
|
||||||
return std::pair<iterator, bool>(iterator(this, i), false);
|
return std::pair<iterator, bool>(iterator(this, i), false);
|
||||||
|
@ -1036,35 +1038,35 @@ public:
|
||||||
|
|
||||||
int erase(const K &key)
|
int erase(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int index = do_lookup(key, hash);
|
int index = do_lookup(key, hash);
|
||||||
return do_erase(index, hash);
|
return do_erase(index, hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator erase(iterator it)
|
iterator erase(iterator it)
|
||||||
{
|
{
|
||||||
int hash = do_hash(*it);
|
Hasher::hash_t hash = do_hash(*it);
|
||||||
do_erase(it.index, hash);
|
do_erase(it.index, hash);
|
||||||
return ++it;
|
return ++it;
|
||||||
}
|
}
|
||||||
|
|
||||||
int count(const K &key) const
|
int count(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
return i < 0 ? 0 : 1;
|
return i < 0 ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int count(const K &key, const_iterator it) const
|
int count(const K &key, const_iterator it) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
return i < 0 || i > it.index ? 0 : 1;
|
return i < 0 || i > it.index ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator find(const K &key)
|
iterator find(const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return end();
|
return end();
|
||||||
|
@ -1073,7 +1075,7 @@ public:
|
||||||
|
|
||||||
const_iterator find(const K &key) const
|
const_iterator find(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return end();
|
return end();
|
||||||
|
@ -1082,7 +1084,7 @@ public:
|
||||||
|
|
||||||
bool operator[](const K &key)
|
bool operator[](const K &key)
|
||||||
{
|
{
|
||||||
int hash = do_hash(key);
|
Hasher::hash_t hash = do_hash(key);
|
||||||
int i = do_lookup(key, hash);
|
int i = do_lookup(key, hash);
|
||||||
return i >= 0;
|
return i >= 0;
|
||||||
}
|
}
|
||||||
|
@ -1176,7 +1178,7 @@ public:
|
||||||
|
|
||||||
int operator()(const K &key)
|
int operator()(const K &key)
|
||||||
{
|
{
|
||||||
int hash = database.do_hash(key);
|
Hasher::hash_t hash = database.do_hash(key);
|
||||||
int i = database.do_lookup(key, hash);
|
int i = database.do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
i = database.do_insert(key, hash);
|
i = database.do_insert(key, hash);
|
||||||
|
@ -1185,7 +1187,7 @@ public:
|
||||||
|
|
||||||
int at(const K &key) const
|
int at(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = database.do_hash(key);
|
Hasher::hash_t hash = database.do_hash(key);
|
||||||
int i = database.do_lookup(key, hash);
|
int i = database.do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
throw std::out_of_range("idict::at()");
|
throw std::out_of_range("idict::at()");
|
||||||
|
@ -1194,7 +1196,7 @@ public:
|
||||||
|
|
||||||
int at(const K &key, int defval) const
|
int at(const K &key, int defval) const
|
||||||
{
|
{
|
||||||
int hash = database.do_hash(key);
|
Hasher::hash_t hash = database.do_hash(key);
|
||||||
int i = database.do_lookup(key, hash);
|
int i = database.do_lookup(key, hash);
|
||||||
if (i < 0)
|
if (i < 0)
|
||||||
return defval;
|
return defval;
|
||||||
|
@ -1203,7 +1205,7 @@ public:
|
||||||
|
|
||||||
int count(const K &key) const
|
int count(const K &key) const
|
||||||
{
|
{
|
||||||
int hash = database.do_hash(key);
|
Hasher::hash_t hash = database.do_hash(key);
|
||||||
int i = database.do_lookup(key, hash);
|
int i = database.do_lookup(key, hash);
|
||||||
return i < 0 ? 0 : 1;
|
return i < 0 ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue