@ -219,12 +219,12 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // input_iter: if it is not null, update this one and return it as Iterator
    // input_iter: if it is not null, update this one and return it as Iterator
   
			
		
	
		
		
			
				
					
					  template  < typename  TBlockIter >    template  < typename  TBlockIter >   
			
		
	
		
		
			
				
					
					  static  TBlockIter *  NewDataBlockIterator (    TBlockIter *  NewDataBlockIterator (   
			
				
				
			
		
	
		
		
			
				
					
					      const  Rep *  rep ,  const  Re adOptions &  ro ,  const  BlockHandle &  block_hanlde ,        const  ReadOptions &  ro ,  const  BlockHandle &  block_hanlde ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					      TBlockIter *  input_iter  =  nullptr ,  bool  is_index  =  false ,        TBlockIter *  input_iter  =  nullptr ,  bool  is_index  =  false ,   
			
		
	
		
		
			
				
					
					      bool  key_includes_seq  =  true ,  bool  index_key_is_full  =  true ,        bool  key_includes_seq  =  true ,  bool  index_key_is_full  =  true ,   
			
		
	
		
		
			
				
					
					      GetContext *  get_context  =  nullptr ,  Status  s  =  Status ( ) ,        GetContext *  get_context  =  nullptr ,  Status  s  =  Status ( ) ,   
			
		
	
		
		
			
				
					
					      FilePrefetchBuffer *  prefetch_buffer  =  nullptr ) ;        FilePrefetchBuffer *  prefetch_buffer  =  nullptr )  const  ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  class  PartitionedIndexIteratorState ;    class  PartitionedIndexIteratorState ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -238,6 +238,14 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					  friend  class  MockedBlockBasedTable ;    friend  class  MockedBlockBasedTable ;   
			
		
	
		
		
			
				
					
					  static  std : : atomic < uint64_t >  next_cache_key_id_ ;    static  std : : atomic < uint64_t >  next_cache_key_id_ ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  Cache : : Handle *  GetEntryFromCache ( Cache *  block_cache ,  const  Slice &  key ,   
			
		
	
		
		
			
				
					
					                                   Tickers  block_cache_miss_ticker ,   
			
		
	
		
		
			
				
					
					                                   Tickers  block_cache_hit_ticker ,   
			
		
	
		
		
			
				
					
					                                   uint64_t *  block_cache_miss_stats ,   
			
		
	
		
		
			
				
					
					                                   uint64_t *  block_cache_hit_stats ,   
			
		
	
		
		
			
				
					
					                                   Statistics *  statistics ,   
			
		
	
		
		
			
				
					
					                                   GetContext *  get_context )  const ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // If block cache enabled (compressed or uncompressed), looks for the block
    // If block cache enabled (compressed or uncompressed), looks for the block
   
			
		
	
		
		
			
				
					
					  // identified by handle in (1) uncompressed cache, (2) compressed cache, and
    // identified by handle in (1) uncompressed cache, (2) compressed cache, and
   
			
		
	
		
		
			
				
					
					  // then (3) file. If found, inserts into the cache(s) that were searched
    // then (3) file. If found, inserts into the cache(s) that were searched
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -247,22 +255,20 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					  // @param block_entry value is set to the uncompressed block if found. If
    // @param block_entry value is set to the uncompressed block if found. If
   
			
		
	
		
		
			
				
					
					  //    in uncompressed block cache, also sets cache_handle to reference that
    //    in uncompressed block cache, also sets cache_handle to reference that
   
			
		
	
		
		
			
				
					
					  //    block.
    //    block.
   
			
		
	
		
		
			
				
					
					  static  Status  MaybeReadBlockAndLoadToCache (    Status  MaybeReadBlockAndLoadToCache (   
			
				
				
			
		
	
		
		
			
				
					
					      FilePrefetchBuffer *  prefetch_buffer ,  const  Rep *  rep ,        FilePrefetchBuffer *  prefetch_buffer ,  const  ReadOptions &  ro ,   
			
				
				
			
		
	
		
		
			
				
					
					      const  ReadOptions &  ro ,  const  BlockHandle &  handle ,        const  BlockHandle &  handle ,  const  UncompressionDict &  uncompression_dict ,   
			
				
				
			
		
	
		
		
			
				
					
					      const  UncompressionDict &  uncompression_dict ,   
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					      CachableEntry < Block > *  block_entry ,  bool  is_index  =  false ,        CachableEntry < Block > *  block_entry ,  bool  is_index  =  false ,   
			
		
	
		
		
			
				
					
					      GetContext *  get_context  =  nullptr ) ;        GetContext *  get_context  =  nullptr )  const  ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Similar to the above, with one crucial difference: it will retrieve the
    // Similar to the above, with one crucial difference: it will retrieve the
   
			
		
	
		
		
			
				
					
					  // block from the file even if there are no caches configured (assuming the
    // block from the file even if there are no caches configured (assuming the
   
			
		
	
		
		
			
				
					
					  // read options allow I/O).
    // read options allow I/O).
   
			
		
	
		
		
			
				
					
					  static  Status  RetrieveBlock ( FilePrefetchBuffer *  prefetch_buffer ,    Status  RetrieveBlock ( FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					                              const  Rep *  rep ,  const  ReadOptions &  ro ,                         const  ReadOptions &  ro ,  const  BlockHandle &  handle ,   
			
				
				
			
		
	
		
		
			
				
					
					                              const  BlockHandle &  handle ,   
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                       const  UncompressionDict &  uncompression_dict ,                         const  UncompressionDict &  uncompression_dict ,   
			
		
	
		
		
			
				
					
					                       CachableEntry < Block > *  block_entry ,  bool  is_index ,                         CachableEntry < Block > *  block_entry ,  bool  is_index ,   
			
		
	
		
		
			
				
					
					                               GetContext *  get_context ) ;                         GetContext *  get_context )  const  ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // For the following two functions:
    // For the following two functions:
   
			
		
	
		
		
			
				
					
					  // if `no_io == true`, we will not try to read filter/index from sst file
    // if `no_io == true`, we will not try to read filter/index from sst file
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -276,9 +282,9 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					      const  bool  is_a_filter_partition ,  bool  no_io ,  GetContext *  get_context ,        const  bool  is_a_filter_partition ,  bool  no_io ,  GetContext *  get_context ,   
			
		
	
		
		
			
				
					
					      const  SliceTransform *  prefix_extractor  =  nullptr )  const ;        const  SliceTransform *  prefix_extractor  =  nullptr )  const ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  static  CachableEntry < UncompressionDict >  GetUncompressionDict (    CachableEntry < UncompressionDict >  GetUncompressionDict (   
			
				
				
			
		
	
		
		
			
				
					
					      const  Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,  bool  no_io ,        FilePrefetchBuffer *  prefetch_buffer ,  bool  no_io ,   
			
				
				
			
		
	
		
		
			
				
					
					      GetContext *  get_context ) ;        GetContext *  get_context )  const  ;   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Get the iterator from the index reader.
    // Get the iterator from the index reader.
   
			
		
	
		
		
			
				
					
					  // If input_iter is not set, return new Iterator
    // If input_iter is not set, return new Iterator
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -301,13 +307,12 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					  // pointer to the block as well as its block handle.
    // pointer to the block as well as its block handle.
   
			
		
	
		
		
			
				
					
					  // @param uncompression_dict Data for presetting the compression library's
    // @param uncompression_dict Data for presetting the compression library's
   
			
		
	
		
		
			
				
					
					  //    dictionary.
    //    dictionary.
   
			
		
	
		
		
			
				
					
					  static  Status  GetDataBlockFromCache (    Status  GetDataBlockFromCache (   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      const  Slice &  block_cache_key ,  const  Slice &  compressed_block_cache_key ,        const  Slice &  block_cache_key ,  const  Slice &  compressed_block_cache_key ,   
			
		
	
		
		
			
				
					
					      Cache *  block_cache ,  Cache *  block_cache_compressed ,  const  Rep *  rep ,         Cache *  block_cache ,  Cache *  block_cache_compressed ,   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      const  ReadOptions &  read_options ,  CachableEntry < Block > *  block ,        const  ReadOptions &  read_options ,  CachableEntry < Block > *  block ,   
			
		
	
		
		
			
				
					
					      const  UncompressionDict &  uncompression_dict ,        const  UncompressionDict &  uncompression_dict ,  bool  is_index  =  false ,   
			
				
				
			
		
	
		
		
			
				
					
					      size_t  read_amp_bytes_per_bit ,  bool  is_index  =  false ,        GetContext *  get_context  =  nullptr )  const ;   
			
				
				
			
		
	
		
		
			
				
					
					      GetContext *  get_context  =  nullptr ) ;   
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Put a raw block (maybe compressed) to the corresponding block caches.
    // Put a raw block (maybe compressed) to the corresponding block caches.
   
			
		
	
		
		
			
				
					
					  // This method will perform decompression against raw_block if needed and then
    // This method will perform decompression against raw_block if needed and then
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -319,16 +324,16 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					  // PutDataBlockToCache(). After the call, the object will be invalid.
    // PutDataBlockToCache(). After the call, the object will be invalid.
   
			
		
	
		
		
			
				
					
					  // @param uncompression_dict Data for presetting the compression library's
    // @param uncompression_dict Data for presetting the compression library's
   
			
		
	
		
		
			
				
					
					  //    dictionary.
    //    dictionary.
   
			
		
	
		
		
			
				
					
					  static  Status  PutDataBlockToCache (    Status  PutDataBlockToCache ( const  Slice &  block_cache_key ,   
			
				
				
			
		
	
		
		
			
				
					
					      const  Slice &  block_cache_key , const  Slice &  compressed_block_cache_key ,                                const  Slice &  compressed_block_cache_key ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                             Cache *  block_cache ,  Cache *  block_cache_compressed ,                               Cache *  block_cache ,  Cache *  block_cache_compressed ,   
			
		
	
		
		
			
				
					
					      const  ReadOptions &  read_options ,  const  ImmutableCFOptions &  ioptions ,                               CachableEntry < Block > *  cached_block  ,   
			
				
				
			
		
	
		
		
			
				
					
					      CachableEntry < Block > *  block , BlockContents *  raw_block_contents ,                                BlockContents *  raw_block_contents ,   
			
				
				
			
		
	
		
		
			
				
					
					      CompressionType  raw_block_comp_type ,  uint32_t  format_version ,                                CompressionType  raw_block_comp_type ,   
			
				
				
			
		
	
		
		
			
				
					
					      const  UncompressionDict &  uncompression_dict ,  SequenceNumber  seq_no ,                                const  UncompressionDict &  uncompression_dict ,   
			
				
				
			
		
	
		
		
			
				
					
					      size_t  read_amp_bytes_per_bit ,  MemoryAllocator *  memory_allocator ,                               SequenceNumber  seq_no  ,   
			
				
				
			
		
	
		
		
			
				
					
					      bool  is_index  =  false ,  Cache : : Priority  pri  =  Cache : : Priority : : LOW ,                               MemoryAllocator *  memory_allocator ,  bool  is_index  ,   
			
				
				
			
		
	
		
		
			
				
					
					      GetContext *  get_context  =  nullptr )  ;                                GetContext *  get_context )  const ;   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Calls (*handle_result)(arg, ...) repeatedly, starting with the entry found
    // Calls (*handle_result)(arg, ...) repeatedly, starting with the entry found
   
			
		
	
		
		
			
				
					
					  // after a call to Seek(key), until handle_result returns false.
    // after a call to Seek(key), until handle_result returns false.
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -336,8 +341,6 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					  friend  class  TableCache ;    friend  class  TableCache ;   
			
		
	
		
		
			
				
					
					  friend  class  BlockBasedTableBuilder ;    friend  class  BlockBasedTableBuilder ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  void  ReadMeta ( const  Footer &  footer ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Figure the index type, update it in rep_, and also return it.
    // Figure the index type, update it in rep_, and also return it.
   
			
		
	
		
		
			
				
					
					  BlockBasedTableOptions : : IndexType  UpdateIndexType ( ) ;    BlockBasedTableOptions : : IndexType  UpdateIndexType ( ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -365,28 +368,25 @@ class BlockBasedTable : public TableReader { 
			
		
	
		
		
			
				
					
					      TailPrefetchStats *  tail_prefetch_stats ,  const  bool  prefetch_all ,        TailPrefetchStats *  tail_prefetch_stats ,  const  bool  prefetch_all ,   
			
		
	
		
		
			
				
					
					      const  bool  preload_all ,        const  bool  preload_all ,   
			
		
	
		
		
			
				
					
					      std : : unique_ptr < FilePrefetchBuffer > *  prefetch_buffer ) ;        std : : unique_ptr < FilePrefetchBuffer > *  prefetch_buffer ) ;   
			
		
	
		
		
			
				
					
					  static  Status  ReadMetaBlock ( Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,    Status  ReadMetaBlock ( FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					                       std : : unique_ptr < Block > *  meta_block ,                         std : : unique_ptr < Block > *  meta_block ,   
			
		
	
		
		
			
				
					
					                       std : : unique_ptr < InternalIterator > *  iter ) ;                         std : : unique_ptr < InternalIterator > *  iter ) ;   
			
		
	
		
		
			
				
					
					  static  Status  TryReadPropertiesWithGlobalSeqno (    Status  TryReadPropertiesWithGlobalSeqno ( FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					      Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer , const  Slice &  handle_value ,                                             const  Slice &  handle_value ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                                          TableProperties * *  table_properties ) ;                                            TableProperties * *  table_properties ) ;   
			
		
	
		
		
			
				
					
					  static  Status  ReadPropertiesBlock ( Rep *  rep ,    Status  ReadPropertiesBlock ( FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					                                    FilePrefetchBuffer *  prefetch_buffer ,   
			
		
	
		
		
	
		
		
			
				
					
					                             InternalIterator *  meta_iter ,                               InternalIterator *  meta_iter ,   
			
		
	
		
		
			
				
					
					                             const  SequenceNumber  largest_seqno ) ;                               const  SequenceNumber  largest_seqno ) ;   
			
		
	
		
		
			
				
					
					  static  Status  ReadRangeDelBlock (    Status  ReadRangeDelBlock ( FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					      Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,   
			
		
	
		
		
	
		
		
			
				
					
					                           InternalIterator *  meta_iter ,                             InternalIterator *  meta_iter ,   
			
		
	
		
		
			
				
					
					                           const  InternalKeyComparator &  internal_comparator ) ;                             const  InternalKeyComparator &  internal_comparator ) ;   
			
		
	
		
		
			
				
					
					  static  Status  ReadCompressionDictBlock (    Status  ReadCompressionDictBlock (   
			
				
				
			
		
	
		
		
			
				
					
					      const  Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,        FilePrefetchBuffer *  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					      std : : unique_ptr < const  BlockContents > *  compression_dict_block ) ;        std : : unique_ptr < const  BlockContents > *  compression_dict_block )  const ;   
			
				
				
			
		
	
		
		
			
				
					
					  static  Status  PrefetchIndexAndFilterBlocks (    Status  PrefetchIndexAndFilterBlocks (   
			
				
				
			
		
	
		
		
			
				
					
					      Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,        FilePrefetchBuffer *  prefetch_buffer ,  InternalIterator *  meta_iter ,   
			
				
				
			
		
	
		
		
			
				
					
					      InternalIterator *  meta_iter ,  BlockBasedTable *  new_table ,        BlockBasedTable *  new_table ,  bool  prefetch_all ,   
			
				
				
			
		
	
		
		
			
				
					
					      bool  prefetch_all ,  const  BlockBasedTableOptions &  table_options ,        const  BlockBasedTableOptions &  table_options ,  const  int  level ) ;   
			
				
				
			
		
	
		
		
			
				
					
					      const  int  level ) ;   
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  Status  VerifyChecksumInMetaBlocks ( InternalIteratorBase < Slice > *  index_iter ) ;    Status  VerifyChecksumInMetaBlocks ( InternalIteratorBase < Slice > *  index_iter ) ;   
			
		
	
		
		
			
				
					
					  Status  VerifyChecksumInBlocks ( InternalIteratorBase < BlockHandle > *  index_iter ) ;    Status  VerifyChecksumInBlocks ( InternalIteratorBase < BlockHandle > *  index_iter ) ;