@ -887,7 +887,7 @@ class LevelIterator final : public InternalIterator {
void SeekToFirst ( ) override ;
void SeekToFirst ( ) override ;
void SeekToLast ( ) override ;
void SeekToLast ( ) override ;
void Next ( ) final override ;
void Next ( ) final override ;
bool NextAndGetResult ( Slice * ret_key ) override ;
bool NextAndGetResult ( IterateResult * resul t ) override ;
void Prev ( ) override ;
void Prev ( ) override ;
bool Valid ( ) const override { return file_iter_ . Valid ( ) ; }
bool Valid ( ) const override { return file_iter_ . Valid ( ) ; }
@ -895,23 +895,38 @@ class LevelIterator final : public InternalIterator {
assert ( Valid ( ) ) ;
assert ( Valid ( ) ) ;
return file_iter_ . key ( ) ;
return file_iter_ . key ( ) ;
}
}
Slice value ( ) const override {
Slice value ( ) const override {
assert ( Valid ( ) ) ;
assert ( Valid ( ) ) ;
return file_iter_ . value ( ) ;
return file_iter_ . value ( ) ;
}
}
Status status ( ) const override {
Status status ( ) const override {
return file_iter_ . iter ( ) ? file_iter_ . status ( ) : Status : : OK ( ) ;
return file_iter_ . iter ( ) ? file_iter_ . status ( ) : Status : : OK ( ) ;
}
}
inline bool MayBeOutOfLowerBound ( ) override {
assert ( Valid ( ) ) ;
return may_be_out_of_lower_bound_ & & file_iter_ . MayBeOutOfLowerBound ( ) ;
}
inline bool MayBeOutOfUpperBound ( ) override {
assert ( Valid ( ) ) ;
return file_iter_ . MayBeOutOfUpperBound ( ) ;
}
void SetPinnedItersMgr ( PinnedIteratorsManager * pinned_iters_mgr ) override {
void SetPinnedItersMgr ( PinnedIteratorsManager * pinned_iters_mgr ) override {
pinned_iters_mgr_ = pinned_iters_mgr ;
pinned_iters_mgr_ = pinned_iters_mgr ;
if ( file_iter_ . iter ( ) ) {
if ( file_iter_ . iter ( ) ) {
file_iter_ . SetPinnedItersMgr ( pinned_iters_mgr ) ;
file_iter_ . SetPinnedItersMgr ( pinned_iters_mgr ) ;
}
}
}
}
bool IsKeyPinned ( ) const override {
bool IsKeyPinned ( ) const override {
return pinned_iters_mgr_ & & pinned_iters_mgr_ - > PinningEnabled ( ) & &
return pinned_iters_mgr_ & & pinned_iters_mgr_ - > PinningEnabled ( ) & &
file_iter_ . iter ( ) & & file_iter_ . IsKeyPinned ( ) ;
file_iter_ . iter ( ) & & file_iter_ . IsKeyPinned ( ) ;
}
}
bool IsValuePinned ( ) const override {
bool IsValuePinned ( ) const override {
return pinned_iters_mgr_ & & pinned_iters_mgr_ - > PinningEnabled ( ) & &
return pinned_iters_mgr_ & & pinned_iters_mgr_ - > PinningEnabled ( ) & &
file_iter_ . iter ( ) & & file_iter_ . IsValuePinned ( ) ;
file_iter_ . iter ( ) & & file_iter_ . IsValuePinned ( ) ;
@ -954,12 +969,16 @@ class LevelIterator final : public InternalIterator {
smallest_compaction_key = ( * compaction_boundaries_ ) [ file_index_ ] . smallest ;
smallest_compaction_key = ( * compaction_boundaries_ ) [ file_index_ ] . smallest ;
largest_compaction_key = ( * compaction_boundaries_ ) [ file_index_ ] . largest ;
largest_compaction_key = ( * compaction_boundaries_ ) [ file_index_ ] . largest ;
}
}
may_be_out_of_lower_bound_ =
read_options_ . iterate_lower_bound ! = nullptr & &
user_comparator_ . Compare ( ExtractUserKey ( file_smallest_key ( file_index_ ) ) ,
* read_options_ . iterate_lower_bound ) < 0 ;
return table_cache_ - > NewIterator (
return table_cache_ - > NewIterator (
read_options_ , env_options_ , icomparator_ , * file_meta . file_metadata ,
read_options_ , env_options_ , icomparator_ , * file_meta . file_metadata ,
range_del_agg_ , prefix_extractor_ ,
range_del_agg_ , prefix_extractor_ ,
nullptr /* don't need reference to table */ ,
nullptr /* don't need reference to table */ , file_read_hist_ ,
file_read_hist_ , f or_compaction_ , nullptr /* arena */ , skip_filters_ ,
for_compaction_ , nullptr /* arena */ , skip_filters_ , level _ ,
level_ , smallest_compaction_key , largest_compaction_key ) ;
smallest_compaction_key , largest_compaction_key ) ;
}
}
TableCache * table_cache_ ;
TableCache * table_cache_ ;
@ -975,6 +994,7 @@ class LevelIterator final : public InternalIterator {
bool should_sample_ ;
bool should_sample_ ;
bool for_compaction_ ;
bool for_compaction_ ;
bool skip_filters_ ;
bool skip_filters_ ;
bool may_be_out_of_lower_bound_ = true ;
size_t file_index_ ;
size_t file_index_ ;
int level_ ;
int level_ ;
RangeDelAggregator * range_del_agg_ ;
RangeDelAggregator * range_del_agg_ ;
@ -1043,11 +1063,12 @@ void LevelIterator::SeekToLast() {
void LevelIterator : : Next ( ) { NextImpl ( ) ; }
void LevelIterator : : Next ( ) { NextImpl ( ) ; }
bool LevelIterator : : NextAndGetResult ( Slice * ret_key ) {
bool LevelIterator : : NextAndGetResult ( IterateResult * resul t ) {
NextImpl ( ) ;
NextImpl ( ) ;
bool is_valid = Valid ( ) ;
bool is_valid = Valid ( ) ;
if ( is_valid ) {
if ( is_valid ) {
* ret_key = key ( ) ;
result - > key = key ( ) ;
result - > may_be_out_of_upper_bound = MayBeOutOfUpperBound ( ) ;
}
}
return is_valid ;
return is_valid ;
}
}
@ -4278,10 +4299,9 @@ Status VersionSet::Recover(
" , last_sequence is % " PRIu64 " , log_number is % " PRIu64
" , last_sequence is % " PRIu64 " , log_number is % " PRIu64
" ,prev_log_number is % " PRIu64 " ,max_column_family is % " PRIu32
" ,prev_log_number is % " PRIu64 " ,max_column_family is % " PRIu32
" ,min_log_number_to_keep is % " PRIu64 " \n " ,
" ,min_log_number_to_keep is % " PRIu64 " \n " ,
manifest_path . c_str ( ) , manifest_file_number_ ,
manifest_path . c_str ( ) , manifest_file_number_ , next_file_number_ . load ( ) ,
next_file_number_ . load ( ) , last_sequence_ . load ( ) , log_number ,
last_sequence_ . load ( ) , log_number , prev_log_number_ ,
prev_log_number_ , column_family_set_ - > GetMaxColumnFamily ( ) ,
column_family_set_ - > GetMaxColumnFamily ( ) , min_log_number_to_keep_2pc ( ) ) ;
min_log_number_to_keep_2pc ( ) ) ;
for ( auto cfd : * column_family_set_ ) {
for ( auto cfd : * column_family_set_ ) {
if ( cfd - > IsDropped ( ) ) {
if ( cfd - > IsDropped ( ) ) {