java.lang.Object
org.apache.lucene.search.MultiLeafFieldComparator
- All Implemented Interfaces:
LeafFieldComparator
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final LeafFieldComparator[]private final LeafFieldComparatorprivate final intprivate final int[] -
Constructor Summary
ConstructorsConstructorDescriptionMultiLeafFieldComparator(LeafFieldComparator[] comparators, int[] reverseMul) -
Method Summary
Modifier and TypeMethodDescriptionintcompareBottom(int doc) Compare the bottom of the queue with this doc.intcompareTop(int doc) Compare the top value with this doc.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.voidInforms this leaf comparator that hits threshold is reached.voidSets the Scorer to use in case a document's score is needed.
-
Field Details
-
comparators
-
reverseMul
private final int[] reverseMul -
firstComparator
-
firstReverseMul
private final int firstReverseMul
-
-
Constructor Details
-
MultiLeafFieldComparator
MultiLeafFieldComparator(LeafFieldComparator[] comparators, int[] reverseMul)
-
-
Method Details
-
setBottom
Description copied from interface:LeafFieldComparatorSet 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:
setBottomin interfaceLeafFieldComparator- Parameters:
slot- the currently weakest (sorted last) slot in the queue- Throws:
IOException
-
compareBottom
Description copied from interface:LeafFieldComparatorCompare 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).
- Specified by:
compareBottomin interfaceLeafFieldComparator- 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
-
compareTop
Description copied from interface:LeafFieldComparatorCompare 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).- Specified by:
compareTopin interfaceLeafFieldComparator- 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
-
copy
Description copied from interface:LeafFieldComparatorThis 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:
copyin interfaceLeafFieldComparator- Parameters:
slot- which slot to copy the hit todoc- docID relative to current reader- Throws:
IOException
-
setScorer
Description copied from interface:LeafFieldComparatorSets the Scorer to use in case a document's score is needed.- Specified by:
setScorerin interfaceLeafFieldComparator- Parameters:
scorer- Scorer instance that you should use to obtain the current hit's score, if necessary.- Throws:
IOException
-
setHitsThresholdReached
Description copied from interface:LeafFieldComparatorInforms this leaf comparator that hits threshold is reached. This method is called from a collector when hits threshold is reached.- Specified by:
setHitsThresholdReachedin interfaceLeafFieldComparator- Throws:
IOException
-
competitiveIterator
Description copied from interface:LeafFieldComparatorReturns a competitive iterator- Specified by:
competitiveIteratorin interfaceLeafFieldComparator- 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
-