@ -31,17 +31,15 @@ class HashSkipListRep : public MemTableRep {
virtual ~ HashSkipListRep ( ) ;
virtual ~ HashSkipListRep ( ) ;
virtual std : : shared_ptr < MemTableRep : : Iterator > GetIterator ( ) override ;
virtual MemTableRep : : Iterator * GetIterator ( ) override ;
virtual std : : shared_ptr < MemTableRep : : Iterator > GetIterator (
virtual MemTableRep : : Iterator * GetIterator ( const Slice & slice ) override ;
const Slice & slice ) override ;
virtual std : : shared_ptr < MemTableRep : : Iterator > GetPrefixIterator (
virtual MemTableRep : : Iterator * GetPrefixIterator ( const Slice & prefix )
const Slice & prefix ) override ;
virtual std : : shared_ptr < MemTableRep : : Iterator > GetDynamicPrefixIterator ( )
override ;
override ;
virtual MemTableRep : : Iterator * GetDynamicPrefixIterator ( ) override ;
private :
private :
friend class DynamicIterator ;
friend class DynamicIterator ;
typedef SkipList < const char * , MemTableRep : : KeyComparator & > Bucket ;
typedef SkipList < const char * , MemTableRep : : KeyComparator & > Bucket ;
@ -208,18 +206,15 @@ class HashSkipListRep : public MemTableRep {
virtual void SeekToLast ( ) { }
virtual void SeekToLast ( ) { }
private :
private :
} ;
} ;
std : : shared_ptr < EmptyIterator > empty_iterator_ ;
} ;
} ;
HashSkipListRep : : HashSkipListRep ( MemTableRep : : KeyComparator & compare ,
HashSkipListRep : : HashSkipListRep ( MemTableRep : : KeyComparator & compare ,
Arena * arena , const SliceTransform * transform , size_t bucket_size )
Arena * arena , const SliceTransform * transform ,
size_t bucket_size )
: bucket_size_ ( bucket_size ) ,
: bucket_size_ ( bucket_size ) ,
transform_ ( transform ) ,
transform_ ( transform ) ,
compare_ ( compare ) ,
compare_ ( compare ) ,
arena_ ( arena ) ,
arena_ ( arena ) {
empty_iterator_ ( std : : make_shared < EmptyIterator > ( ) ) {
buckets_ = new port : : AtomicPointer [ bucket_size ] ;
buckets_ = new port : : AtomicPointer [ bucket_size ] ;
for ( size_t i = 0 ; i < bucket_size_ ; + + i ) {
for ( size_t i = 0 ; i < bucket_size_ ; + + i ) {
@ -263,7 +258,7 @@ size_t HashSkipListRep::ApproximateMemoryUsage() {
return sizeof ( buckets_ ) ;
return sizeof ( buckets_ ) ;
}
}
std : : shared_ptr < MemTableRep : : Iterator > HashSkipListRep : : GetIterator ( ) {
MemTableRep : : Iterator * HashSkipListRep : : GetIterator ( ) {
auto list = new Bucket ( compare_ , arena_ ) ;
auto list = new Bucket ( compare_ , arena_ ) ;
for ( size_t i = 0 ; i < bucket_size_ ; + + i ) {
for ( size_t i = 0 ; i < bucket_size_ ; + + i ) {
auto bucket = GetBucket ( i ) ;
auto bucket = GetBucket ( i ) ;
@ -274,35 +269,30 @@ std::shared_ptr<MemTableRep::Iterator> HashSkipListRep::GetIterator() {
}
}
}
}
}
}
return std : : make_shared < Iterator > ( list ) ;
return new Iterator ( list ) ;
}
}
std : : shared_ptr < MemTableRep : : Iterator > HashSkipListRep : : GetPrefixIterator (
MemTableRep : : Iterator * HashSkipListRep : : GetPrefixIterator ( const Slice & prefix ) {
const Slice & prefix ) {
auto bucket = GetBucket ( prefix ) ;
auto bucket = GetBucket ( prefix ) ;
if ( bucket = = nullptr ) {
if ( bucket = = nullptr ) {
return empty_iterator_ ;
return new EmptyIterator ( ) ;
}
}
return std : : make_shared < Iterator > ( bucket , false ) ;
return new Iterator ( bucket , false ) ;
}
}
std : : shared_ptr < MemTableRep : : Iterator > HashSkipListRep : : GetIterator (
MemTableRep : : Iterator * HashSkipListRep : : GetIterator ( const Slice & slice ) {
const Slice & slice ) {
return GetPrefixIterator ( transform_ - > Transform ( slice ) ) ;
return GetPrefixIterator ( transform_ - > Transform ( slice ) ) ;
}
}
std : : shared_ptr < MemTableRep : : Iterator >
MemTableRep : : Iterator * HashSkipListRep : : GetDynamicPrefixIterator ( ) {
HashSkipListRep : : GetDynamicPrefixIterator ( ) {
return new DynamicIterator ( * this ) ;
return std : : make_shared < DynamicIterator > ( * this ) ;
}
}
} // anon namespace
} // anon namespace
std : : shared_ptr < MemTableRep >
MemTableRep * HashSkipListRepFactory : : CreateMemTableRep (
HashSkipListRepFactory : : CreateMemTableRep ( MemTableRep : : KeyComparator & compare ,
MemTableRep : : KeyComparator & compare , Arena * arena ) {
Arena * arena ) {
return new HashSkipListRep ( compare , arena , transform_ , bucket_count_ ) ;
return std : : make_shared < HashSkipListRep > ( compare , arena , transform_ ,
bucket_count_ ) ;
}
}
MemTableRepFactory * NewHashSkipListRepFactory (
MemTableRepFactory * NewHashSkipListRepFactory (