Class IntComparator.IntLeafComparator
java.lang.Object
NumericComparator<Integer>.NumericLeafComparator
org.apache.lucene.search.comparators.IntComparator.IntLeafComparator
- All Implemented Interfaces:
LeafFieldComparator
- Enclosing class:
- IntComparator
public class IntComparator.IntLeafComparator
extends NumericComparator<Integer>.NumericLeafComparator
Leaf comparator for
IntComparator
that provides skipping functionality-
Field Summary
Fields inherited from class org.apache.lucene.search.comparators.NumericComparator.NumericLeafComparator
docValues
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionint
compareBottom
(int doc) Compare the bottom of the queue with this doc.int
compareTop
(int doc) Compare the top value with this doc.void
copy
(int slot, int doc) This method is called when a new hit is competitive.protected void
encodeBottom
(byte[] packedValue) protected void
encodeTop
(byte[] packedValue) protected boolean
void
setBottom
(int slot) Set the bottom slot, ie the "weakest" (sorted last) entry in the queue.Methods inherited from class org.apache.lucene.search.comparators.NumericComparator.NumericLeafComparator
competitiveIterator, getNumericDocValues, setHitsThresholdReached, setScorer
-
Constructor Details
-
IntLeafComparator
- Throws:
IOException
-
-
Method Details
-
setBottom
Description copied from interface:LeafFieldComparator
Set the bottom slot, ie the "weakest" (sorted last) entry in the queue. WhenLeafFieldComparator.compareBottom(int)
is called, you should compare against this slot. This will always be called beforeLeafFieldComparator.compareBottom(int)
.- Specified by:
setBottom
in interfaceLeafFieldComparator
- Overrides:
setBottom
in classNumericComparator<Integer>.NumericLeafComparator
- Parameters:
slot
- the currently weakest (sorted last) slot in the queue- Throws:
IOException
-
compareBottom
Description copied from interface:LeafFieldComparator
Compare the bottom of the queue with this doc. This will only invoked after setBottom has been called. This should return the same result asFieldComparator.compare(int,int)
} as if bottom were slot1 and the new document were slot 2.For a search that hits many results, this method will be the hotspot (invoked by far the most frequently).
- Parameters:
doc
- that was hit- Returns:
- any
N < 0
if the doc's value is sorted after the bottom entry (not competitive), anyN > 0
if the doc's value is sorted before the bottom entry and0
if they are equal. - Throws:
IOException
-
compareTop
Description copied from interface:LeafFieldComparator
Compare the top value with this doc. This will only invoked after setTopValue has been called. This should return the same result asFieldComparator.compare(int,int)
} as if topValue were slot1 and the new document were slot 2. This is only called for searches that use searchAfter (deep paging).- Parameters:
doc
- that was hit- Returns:
- any
N < 0
if the doc's value is sorted after the top entry (not competitive), anyN > 0
if the doc's value is sorted before the top entry and0
if they are equal. - Throws:
IOException
-
copy
Description copied from interface:LeafFieldComparator
This method is called when a new hit is competitive. You should copy any state associated with this document that will be required for future comparisons, into the specified slot.- Specified by:
copy
in interfaceLeafFieldComparator
- Overrides:
copy
in classNumericComparator<Integer>.NumericLeafComparator
- Parameters:
slot
- which slot to copy the hit todoc
- docID relative to current reader- Throws:
IOException
-
isMissingValueCompetitive
protected boolean isMissingValueCompetitive()- Specified by:
isMissingValueCompetitive
in classNumericComparator<Integer>.NumericLeafComparator
-
encodeBottom
protected void encodeBottom(byte[] packedValue) - Specified by:
encodeBottom
in classNumericComparator<Integer>.NumericLeafComparator
-
encodeTop
protected void encodeTop(byte[] packedValue) - Specified by:
encodeTop
in classNumericComparator<Integer>.NumericLeafComparator
-