@ -1378,17 +1378,19 @@ void ArenaWrappedDBIter::Init(Env* env, const ReadOptions& read_options,
const SequenceNumber & sequence ,
const SequenceNumber & sequence ,
uint64_t max_sequential_skip_in_iteration ,
uint64_t max_sequential_skip_in_iteration ,
uint64_t version_number ,
uint64_t version_number ,
ReadCallback * read_callback , bool allow_blob ) {
ReadCallback * read_callback , bool allow_blob ,
bool allow_refresh ) {
auto mem = arena_ . AllocateAligned ( sizeof ( DBIter ) ) ;
auto mem = arena_ . AllocateAligned ( sizeof ( DBIter ) ) ;
db_iter_ = new ( mem )
db_iter_ = new ( mem )
DBIter ( env , read_options , cf_options , cf_options . user_comparator , nullptr ,
DBIter ( env , read_options , cf_options , cf_options . user_comparator , nullptr ,
sequence , true , max_sequential_skip_in_iteration , read_callback ,
sequence , true , max_sequential_skip_in_iteration , read_callback ,
allow_blob ) ;
allow_blob ) ;
sv_number_ = version_number ;
sv_number_ = version_number ;
allow_refresh_ = allow_refresh ;
}
}
Status ArenaWrappedDBIter : : Refresh ( ) {
Status ArenaWrappedDBIter : : Refresh ( ) {
if ( cfd_ = = nullptr | | db_impl_ = = nullptr ) {
if ( cfd_ = = nullptr | | db_impl_ = = nullptr | | ! allow_refresh_ ) {
return Status : : NotSupported ( " Creating renew iterator is not allowed. " ) ;
return Status : : NotSupported ( " Creating renew iterator is not allowed. " ) ;
}
}
assert ( db_iter_ ! = nullptr ) ;
assert ( db_iter_ ! = nullptr ) ;
@ -1406,7 +1408,7 @@ Status ArenaWrappedDBIter::Refresh() {
SuperVersion * sv = cfd_ - > GetReferencedSuperVersion ( db_impl_ - > mutex ( ) ) ;
SuperVersion * sv = cfd_ - > GetReferencedSuperVersion ( db_impl_ - > mutex ( ) ) ;
Init ( env , read_options_ , * ( cfd_ - > ioptions ( ) ) , latest_seq ,
Init ( env , read_options_ , * ( cfd_ - > ioptions ( ) ) , latest_seq ,
sv - > mutable_cf_options . max_sequential_skip_in_iterations ,
sv - > mutable_cf_options . max_sequential_skip_in_iterations ,
cur_sv_number , read_callback_ , allow_blob_ ) ;
cur_sv_number , read_callback_ , allow_blob_ , allow_refresh_ ) ;
InternalIterator * internal_iter = db_impl_ - > NewInternalIterator (
InternalIterator * internal_iter = db_impl_ - > NewInternalIterator (
read_options_ , cfd_ , sv , & arena_ , db_iter_ - > GetRangeDelAggregator ( ) ) ;
read_options_ , cfd_ , sv , & arena_ , db_iter_ - > GetRangeDelAggregator ( ) ) ;
@ -1423,12 +1425,12 @@ ArenaWrappedDBIter* NewArenaWrappedDbIterator(
const ImmutableCFOptions & cf_options , const SequenceNumber & sequence ,
const ImmutableCFOptions & cf_options , const SequenceNumber & sequence ,
uint64_t max_sequential_skip_in_iterations , uint64_t version_number ,
uint64_t max_sequential_skip_in_iterations , uint64_t version_number ,
ReadCallback * read_callback , DBImpl * db_impl , ColumnFamilyData * cfd ,
ReadCallback * read_callback , DBImpl * db_impl , ColumnFamilyData * cfd ,
bool allow_blob ) {
bool allow_blob , bool allow_refresh ) {
ArenaWrappedDBIter * iter = new ArenaWrappedDBIter ( ) ;
ArenaWrappedDBIter * iter = new ArenaWrappedDBIter ( ) ;
iter - > Init ( env , read_options , cf_options , sequence ,
iter - > Init ( env , read_options , cf_options , sequence ,
max_sequential_skip_in_iterations , version_number , read_callback ,
max_sequential_skip_in_iterations , version_number , read_callback ,
allow_blob ) ;
allow_blob , allow_refresh ) ;
if ( db_impl ! = nullptr & & cfd ! = nullptr ) {
if ( db_impl ! = nullptr & & cfd ! = nullptr & & allow_refresh ) {
iter - > StoreRefreshInfo ( read_options , db_impl , cfd , read_callback ,
iter - > StoreRefreshInfo ( read_options , db_impl , cfd , read_callback ,
allow_blob ) ;
allow_blob ) ;
}
}