Package org.apache.lucene.search
Interface LeafFieldComparator
- 
- All Known Implementing Classes:
- DoubleComparator.DoubleLeafComparator,- FieldComparator.RelevanceComparator,- FieldComparator.TermValComparator,- FloatComparator.FloatLeafComparator,- IntComparator.IntLeafComparator,- LongComparator.LongLeafComparator,- NumericComparator.NumericLeafComparator,- SimpleFieldComparator
 
 public interface LeafFieldComparatorExpert: comparator that gets instantiated on each leaf from a top-levelFieldComparatorinstance.A leaf comparator must define these functions: - setBottom(int)This method is called by- FieldValueHitQueueto notify the FieldComparator of the current weakest ("bottom") slot. Note that this slot may not hold the weakest value according to your comparator, in cases where your comparator is not the primary one (ie, is only used to break ties from the comparators before it).
- compareBottom(int)Compare a new hit (docID) against the "weakest" (bottom) entry in the queue.
- compareTop(int)Compare a new hit (docID) against the top value previously set by a call to- FieldComparator.setTopValue(T).
- copy(int, int)Installs a new hit into the priority queue. The- FieldValueHitQueuecalls this method when a new hit is competitive.
 - See Also:
- FieldComparator
- WARNING: This API is experimental and might change in incompatible ways in the next release.
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description intcompareBottom(int doc)Compare the bottom of the queue with this doc.intcompareTop(int doc)Compare the top value with this doc.default DocIdSetIteratorcompetitiveIterator()Returns a competitive iteratorvoidcopy(int slot, int doc)This method is called when a new hit is competitive.voidsetBottom(int slot)Set the bottom slot, ie the "weakest" (sorted last) entry in the queue.default voidsetHitsThresholdReached()Informs this leaf comparator that hits threshold is reached.voidsetScorer(Scorable scorer)Sets the Scorer to use in case a document's score is needed.
 
- 
- 
- 
Method Detail- 
setBottomvoid setBottom(int slot) throws IOExceptionSet the bottom slot, ie the "weakest" (sorted last) entry in the queue. WhencompareBottom(int)is called, you should compare against this slot. This will always be called beforecompareBottom(int).- Parameters:
- slot- the currently weakest (sorted last) slot in the queue
- Throws:
- IOException
 
 - 
compareBottomint compareBottom(int doc) throws IOExceptionCompare 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 < 0if the doc's value is sorted after the bottom entry (not competitive), anyN > 0if the doc's value is sorted before the bottom entry and0if they are equal.
- Throws:
- IOException
 
 - 
compareTopint compareTop(int doc) throws IOExceptionCompare 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 < 0if the doc's value is sorted after the top entry (not competitive), anyN > 0if the doc's value is sorted before the top entry and0if they are equal.
- Throws:
- IOException
 
 - 
copyvoid copy(int slot, int doc) throws IOExceptionThis 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.- Parameters:
- slot- which slot to copy the hit to
- doc- docID relative to current reader
- Throws:
- IOException
 
 - 
setScorervoid setScorer(Scorable scorer) throws IOException Sets the Scorer to use in case a document's score is needed.- Parameters:
- scorer- Scorer instance that you should use to obtain the current hit's score, if necessary.
- Throws:
- IOException
 
 - 
competitiveIteratordefault DocIdSetIterator competitiveIterator() throws IOException Returns a competitive iterator- Returns:
- an iterator over competitive docs that are stronger than already collected docs or
     nullif such an iterator is not available for the current comparator or segment.
- Throws:
- IOException
 
 - 
setHitsThresholdReacheddefault void setHitsThresholdReached() throws IOExceptionInforms this leaf comparator that hits threshold is reached. This method is called from a collector when hits threshold is reached.- Throws:
- IOException
 
 
- 
 
-