Fix memory leak

Summary: There is a memory leak because TransformRepFactory does not delete its SliceTransform pointer. This patch adds a delete to the destructor.

Test Plan:
make check
make valgrind_check

Reviewers: dhruba, emayanke, haobo

Reviewed By: dhruba

CC: leveldb

Differential Revision: https://reviews.facebook.net/D12513
main
Jim Paton 12 years ago
parent 4504c99030
commit 5c3b254ef2
  1. 9
      include/rocksdb/memtablerep.h
  2. 3
      util/transformrep.cc

@ -180,7 +180,8 @@ public:
// over the entire collection is rare. // over the entire collection is rare.
// //
// Parameters: // Parameters:
// transform: The SliceTransform to bucket user keys on. // transform: The SliceTransform to bucket user keys on. TransformRepFactory
// assumes it does not own the pointer.
// bucket_count: Passed to the constructor of the underlying // bucket_count: Passed to the constructor of the underlying
// std::unordered_map of each TransformRep. On initialization, the // std::unordered_map of each TransformRep. On initialization, the
// underlying array will be at least bucket_count size. // underlying array will be at least bucket_count size.
@ -206,9 +207,13 @@ public:
// //
// Parameters: See TransformRepFactory. // Parameters: See TransformRepFactory.
class UnsortedRepFactory : public TransformRepFactory { class UnsortedRepFactory : public TransformRepFactory {
const SliceTransform* transform_;
public: public:
explicit UnsortedRepFactory(size_t bucket_count = 0, size_t num_locks = 1000) explicit UnsortedRepFactory(size_t bucket_count = 0, size_t num_locks = 1000)
: TransformRepFactory(NewNoopTransform(), bucket_count, num_locks) { } : TransformRepFactory(transform_ = NewNoopTransform(),
bucket_count,
num_locks) { }
virtual ~UnsortedRepFactory() { delete transform_; }
}; };
// PrefixHashReps bin user keys based on a fixed-size prefix. This optimizes for // PrefixHashReps bin user keys based on a fixed-size prefix. This optimizes for

@ -149,7 +149,8 @@ class PrefixHashRep : public TransformRep {
public: public:
PrefixHashRep(const KeyComparator& compare, Arena* arena, PrefixHashRep(const KeyComparator& compare, Arena* arena,
const SliceTransform* transform, size_t bucket_size, const SliceTransform* transform, size_t bucket_size,
size_t num_locks) : TransformRep(compare, arena, transform, size_t num_locks)
: TransformRep(compare, arena, transform,
bucket_size, num_locks) { } bucket_size, num_locks) { }
virtual std::shared_ptr<MemTableRep::Iterator> GetPrefixIterator( virtual std::shared_ptr<MemTableRep::Iterator> GetPrefixIterator(

Loading…
Cancel
Save