@ -32,11 +32,11 @@ struct PerfContext { 
			
		
	
		
		
			
				
					
					  uint64_t  block_decompress_time ;   // total nanos spent on block decompression
    uint64_t  block_decompress_time ;   // total nanos spent on block decompression
   
			
		
	
		
		
			
				
					
					  // total number of internal keys skipped over during iteration.
    // total number of internal keys skipped over during iteration.
   
			
		
	
		
		
			
				
					
					  // There are several reasons for it:
    // There are several reasons for it:
   
			
		
	
		
		
			
				
					
					  // 1. when calling Next(), iterator is in the position of the previous key, 
    // 1. when calling Next(), the  iterator is in the position of the previous
   
			
				
				
			
		
	
		
		
			
				
					
					  //    so that we'll need to skip it. It means this counter will always
    //    key,  so that we'll need to skip it. It means this counter will always
   
			
				
				
			
		
	
		
		
			
				
					
					  //    incrmented in Next().
    //    be  incre mented in Next().
   
			
				
				
			
		
	
		
		
			
				
					
					  // 2. when calling Next(), needs  to skip internal entries for the previous
    // 2. when calling Next(), we  need to skip internal entries for the previous
   
			
				
				
			
		
	
		
		
			
				
					
					  //    key that are overwritten.
    //    keys  that are overwritten.
   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					  // 3. when calling Next(), Seek() or SeekToFirst(), after previous key
    // 3. when calling Next(), Seek() or SeekToFirst(), after previous key
   
			
		
	
		
		
			
				
					
					  //    before calling Next(), the seek key in Seek() or the beginning for
    //    before calling Next(), the seek key in Seek() or the beginning for
   
			
		
	
		
		
			
				
					
					  //    SeekToFirst(), there may be one or more deleted keys before the next
    //    SeekToFirst(), there may be one or more deleted keys before the next
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -46,16 +46,15 @@ struct PerfContext { 
			
		
	
		
		
			
				
					
					  //    hidden by the tombstones will be included here.
    //    hidden by the tombstones will be included here.
   
			
		
	
		
		
			
				
					
					  // 4. symmetric cases for Prev() and SeekToLast()
    // 4. symmetric cases for Prev() and SeekToLast()
   
			
		
	
		
		
			
				
					
					  // We sometimes also skip entries of more recent updates than the snapshot
    // We sometimes also skip entries of more recent updates than the snapshot
   
			
		
	
		
		
			
				
					
					  // we read from, but it is not counted .
    // we read from, but they are not included in this counter .
   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  //
    //
   
			
		
	
		
		
			
				
					
					  uint64_t  internal_key_skipped_count ;    uint64_t  internal_key_skipped_count ;   
			
		
	
		
		
			
				
					
					  // Total number of deletes and single deletes skipped over during iteration
    // Total number of deletes and single deletes skipped over during iteration
   
			
		
	
		
		
			
				
					
					  // When calling Next(), Seek() or SeekToFirst(), after previous key before
    // When calling Next(), Seek() or SeekToFirst(), after previous position
   
			
				
				
			
		
	
		
		
			
				
					
					  // calling Next(), the seek key in Seek() or the beginning for SeekToFirst(),
    // before calling Next(), the seek key in Seek() or the beginning for
   
			
				
				
			
		
	
		
		
			
				
					
					  // there may be one or more deleted keys before the next valid key that the
    // SeekToFirst(), there may be one or more deleted keys before the next valid
   
			
				
				
			
		
	
		
		
			
				
					
					  // operation should place the iterator to. Every deleted key is counted once.
    // key. Every deleted key is counted once. We don't recount here if there are
   
			
				
				
			
		
	
		
		
			
				
					
					  // We don't recount here if there are still older updates invalidated by the
    // still older updates invalidated by the tombstones.
   
			
				
				
			
		
	
		
		
			
				
					
					  // tombstones.
   
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					  //
    //
   
			
		
	
		
		
			
				
					
					  uint64_t  internal_delete_skipped_count ;    uint64_t  internal_delete_skipped_count ;