@ -41,7 +41,6 @@ namespace rocksdb {
namespace log { class Writer ; }
namespace log { class Writer ; }
class Compaction ;
class Compaction ;
class CompactionPicker ;
class Iterator ;
class Iterator ;
class LogBuffer ;
class LogBuffer ;
class LookupKey ;
class LookupKey ;
@ -87,7 +86,6 @@ class Version {
// Append to *iters a sequence of iterators that will
// Append to *iters a sequence of iterators that will
// yield the contents of this Version when merged together.
// yield the contents of this Version when merged together.
// REQUIRES: This version has been saved (see VersionSet::SaveTo)
// REQUIRES: This version has been saved (see VersionSet::SaveTo)
void AddIterators ( const ReadOptions & , const EnvOptions & soptions ,
void AddIterators ( const ReadOptions & , const EnvOptions & soptions ,
MergeIteratorBuilder * merger_iter_builder ) ;
MergeIteratorBuilder * merger_iter_builder ) ;
@ -179,8 +177,11 @@ class Version {
int NumberLevels ( ) const { return num_levels_ ; }
int NumberLevels ( ) const { return num_levels_ ; }
// REQUIRES: lock is held
// REQUIRES: This version has been saved (see VersionSet::SaveTo)
int NumLevelFiles ( int level ) const { return files_ [ level ] . size ( ) ; }
int NumLevelFiles ( int level ) const {
assert ( finalized_ ) ;
return files_ [ level ] . size ( ) ;
}
// Return the combined file size of all files at the specified level.
// Return the combined file size of all files at the specified level.
uint64_t NumLevelBytes ( int level ) const ;
uint64_t NumLevelBytes ( int level ) const ;
@ -242,19 +243,31 @@ class Version {
size_t GetMemoryUsageByTableReaders ( ) ;
size_t GetMemoryUsageByTableReaders ( ) ;
// used to sort files by size
ColumnFamilyData * cfd ( ) const { return cfd_ ; }
struct Fsize {
int index ;
// REQUIRES: This version has been saved (see VersionSet::SaveTo)
FileMetaData * file ;
const std : : vector < FileMetaData * > & LevelFiles ( int level ) const {
} ;
assert ( finalized_ ) ;
return files_ [ level ] ;
}
// REQUIRES: lock is held
// Set the index that is used to offset into files_by_size_ to find
// the next compaction candidate file.
void SetNextCompactionIndex ( int level , int index ) {
next_file_to_compact_by_size_ [ level ] = index ;
}
// REQUIRES: lock is held
int NextCompactionIndex ( int level ) const {
return next_file_to_compact_by_size_ [ level ] ;
}
private :
private :
friend class Compaction ;
friend class VersionSet ;
friend class VersionSet ;
friend class DBImpl ;
friend class DBImpl ;
friend class CompactedDBImpl ;
friend class CompactedDBImpl ;
friend class ColumnFamilyData ;
friend class ColumnFamilyData ;
friend class CompactionPicker ;
friend class LevelCompactionPicker ;
friend class LevelCompactionPicker ;
friend class UniversalCompactionPicker ;
friend class UniversalCompactionPicker ;
friend class FIFOCompactionPicker ;
friend class FIFOCompactionPicker ;
@ -356,13 +369,11 @@ class Version {
// the number of samples
// the number of samples
uint64_t num_samples_ ;
uint64_t num_samples_ ;
~ Version ( ) ;
// Used to assert APIs that are only safe to use after the version
// is finalized
bool finalized_ ;
// re-initializes the index that is used to offset into files_by_size_
~ Version ( ) ;
// to find the next compaction candidate file.
void ResetNextCompactionIndex ( int level ) {
next_file_to_compact_by_size_ [ level ] = 0 ;
}
// No copying allowed
// No copying allowed
Version ( const Version & ) ;
Version ( const Version & ) ;