Interface DataBlockEncoder.EncodedSeeker
- All Known Implementing Classes:
- AbstractDataBlockEncoder.AbstractEncodedSeeker,- BufferedDataBlockEncoder.BufferedEncodedSeeker,- CopyKeyDataBlockEncoder.SeekerStateBufferedEncodedSeeker,- DiffKeyDeltaEncoder.DiffSeekerStateBufferedEncodedSeeker,- FastDiffDeltaEncoder.FastDiffSeekerStateBufferedEncodedSeeker,- PrefixKeyDeltaEncoder.SeekerStateBufferedEncodedSeeker,- RowIndexSeekerV1
- Enclosing interface:
- DataBlockEncoder
public static interface DataBlockEncoder.EncodedSeeker
An interface which enable to seek while underlying data is encoded. It works on one HFileBlock,
 but it is reusable. See 
setCurrentBuffer(ByteBuff).- 
Method SummaryModifier and TypeMethodDescriptionintcompareKey(CellComparator comparator, ExtendedCell key) Compare the given key against the current keygetCell()Returns the Cell at the current position.getKey()From the current position creates a cell using the key part of the current bufferDoes a shallow copy of the value at the current position.booleannext()Move to next positionvoidrewind()Set position to beginning of given blockintseekToKeyInBlock(ExtendedCell key, boolean seekBefore) Moves the seeker position within the current block to: the last key that that is less than or equal to the given key ifseekBeforeis false the last key that is strictly less than the given key ifseekBeforeis true.voidsetCurrentBuffer(ByteBuff buffer) Set on which buffer there will be done seeking.
- 
Method Details- 
setCurrentBufferSet on which buffer there will be done seeking.- Parameters:
- buffer- Used for seeking.
 
- 
getKeyFrom the current position creates a cell using the key part of the current buffer- Returns:
- key at current position
 
- 
getValueShallowCopyDoes a shallow copy of the value at the current position. A shallow copy is possible because the returned buffer refers to the backing array of the original encoded buffer.- Returns:
- value at current position
 
- 
getCellReturns the Cell at the current position. Includes memstore timestamp.
- 
rewindvoid rewind()Set position to beginning of given block
- 
nextboolean next()Move to next position- Returns:
- true on success, false if there is no more positions.
 
- 
seekToKeyInBlockMoves the seeker position within the current block to:- the last key that that is less than or equal to the given key if seekBeforeis false
- the last key that is strictly less than the given key if seekBeforeis true. The caller is responsible for loading the previous block if the requested key turns out to be the first key of the current block.
 - Parameters:
- key- - Cell to which the seek should happen
- seekBefore- find the key strictly less than the given key in case of an exact match. Does not matter in case of an inexact match.
- Returns:
- 0 on exact match, 1 on inexact match.
 
- the last key that that is less than or equal to the given key if 
- 
compareKeyCompare the given key against the current key- Returns:
- -1 is the passed key is smaller than the current key, 0 if equal and 1 if greater
 
 
-