diff options
| author | Chris Dyer <cdyer@cs.cmu.edu> | 2011-01-25 22:30:48 +0200 | 
|---|---|---|
| committer | Chris Dyer <cdyer@cs.cmu.edu> | 2011-01-25 22:30:48 +0200 | 
| commit | c4ade3091b812ca135ae6520fa7173e1bbf28754 (patch) | |
| tree | 2528af208f6dafd0c27dcbec0d2da291a9c93ca2 /klm/util/probing_hash_table.hh | |
| parent | d04c0ca2d9df0e147239b18e90650ca8bd51d594 (diff) | |
update kenlm
Diffstat (limited to 'klm/util/probing_hash_table.hh')
| -rw-r--r-- | klm/util/probing_hash_table.hh | 14 | 
1 files changed, 12 insertions, 2 deletions
| diff --git a/klm/util/probing_hash_table.hh b/klm/util/probing_hash_table.hh index 7b5cdc22..00be0ed7 100644 --- a/klm/util/probing_hash_table.hh +++ b/klm/util/probing_hash_table.hh @@ -77,6 +77,16 @@ template <class PackingT, class HashT, class EqualT = std::equal_to<typename Pac      void LoadedBinary() {} +    // Don't change anything related to GetKey,   +    template <class Key> bool UnsafeMutableFind(const Key key, MutableIterator &out) { +      for (MutableIterator i(begin_ + (hash_(key) % buckets_));;) { +        Key got(i->GetKey()); +        if (equal_(got, key)) { out = i; return true; } +        if (equal_(got, invalid_)) return false; +        if (++i == end_) i = begin_; +      }     +    } +      template <class Key> bool Find(const Key key, ConstIterator &out) const {  #ifdef DEBUG        assert(initialized_); @@ -84,8 +94,8 @@ template <class PackingT, class HashT, class EqualT = std::equal_to<typename Pac        for (ConstIterator i(begin_ + (hash_(key) % buckets_));;) {          Key got(i->GetKey());          if (equal_(got, key)) { out = i; return true; } -        if (equal_(got, invalid_)) { return false; } -        if (++i == end_) { i = begin_; } +        if (equal_(got, invalid_)) return false; +        if (++i == end_) i = begin_;        }          } | 
