#ifndef LEVELDB_UTIL_STL_WRAPPERS_H_ #define LEVELDB_UTIL_STL_WRAPPERS_H_ #include "util/murmurhash.h" #include "util/coding.h" #include "leveldb/memtablerep.h" #include "leveldb/slice.h" namespace leveldb { namespace stl_wrappers { class Base { protected: const MemTableRep::KeyComparator& compare_; explicit Base(const MemTableRep::KeyComparator& compare) : compare_(compare) { } }; struct Compare : private Base { explicit Compare(const MemTableRep::KeyComparator& compare) : Base(compare) { } inline bool operator()(const char* a, const char* b) const { return compare_(a, b) < 0; } }; struct Hash { inline size_t operator()(const char* buf) const { Slice internal_key = GetLengthPrefixedSlice(buf); Slice value = GetLengthPrefixedSlice(internal_key.data() + internal_key.size()); unsigned int hval = MurmurHash(internal_key.data(), internal_key.size(), 0); hval = MurmurHash(value.data(), value.size(), hval); return hval; } }; struct KeyEqual : private Base { explicit KeyEqual(const MemTableRep::KeyComparator& compare) : Base(compare) { } inline bool operator()(const char* a, const char* b) const { return this->compare_(a, b) == 0; } }; } } #endif // LEVELDB_UTIL_STL_WRAPPERS_H_