2013-08-22 23:10:02 -07:00
|
|
|
#ifndef LEVELDB_UTIL_STL_WRAPPERS_H_
|
|
|
|
#define LEVELDB_UTIL_STL_WRAPPERS_H_
|
|
|
|
|
|
|
|
#include "util/murmurhash.h"
|
|
|
|
#include "util/coding.h"
|
|
|
|
|
2013-08-23 08:38:13 -07:00
|
|
|
#include "rocksdb/memtablerep.h"
|
|
|
|
#include "rocksdb/slice.h"
|
2013-08-22 23:10:02 -07:00
|
|
|
|
|
|
|
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_
|