diff --git a/lucene/CHANGES.txt b/lucene/CHANGES.txt index fe1d1666a48..ed162b21863 100644 --- a/lucene/CHANGES.txt +++ b/lucene/CHANGES.txt @@ -60,6 +60,9 @@ API Changes no longer have an option to compute the maximum score when sorting by field. (Adrien Grand) +* LUCENE-8411: TopFieldCollector no longer takes a fillFields options, it now + always fills fields. (Adrien Grand) + Changes in Runtime Behavior * LUCENE-8333: Switch MoreLikeThis.setMaxDocFreqPct to use maxDoc instead of diff --git a/lucene/MIGRATE.txt b/lucene/MIGRATE.txt index 8467d7266bc..fb37a1cab3e 100644 --- a/lucene/MIGRATE.txt +++ b/lucene/MIGRATE.txt @@ -76,3 +76,9 @@ separate query: Thanks to other optimizations that were added to Lucene 8, this query will be able to efficiently select the top-scoring document without having to visit all matches. + +## TopFieldCollector always assumes fillFields=true ## + +Because filling sort values doesn't have a significant overhead, the fillFields +option has been removed from TopFieldCollector factory methods. Everything +behaves as if it was set to true. diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/ReadTask.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/ReadTask.java index f5873577921..ee066832cb7 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/ReadTask.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/ReadTask.java @@ -112,7 +112,7 @@ public abstract class ReadTask extends PerfTask { // Weight public again, we can go back to // pulling the Weight ourselves: TopFieldCollector collector = TopFieldCollector.create(sort, numHits, - true, withScore(), + withScore(), withTotalHits()); searcher.search(q, collector); hits = collector.topDocs(); diff --git a/lucene/core/src/java/org/apache/lucene/search/IndexSearcher.java b/lucene/core/src/java/org/apache/lucene/search/IndexSearcher.java index 64f61c0bdd7..d52e2f37023 100644 --- a/lucene/core/src/java/org/apache/lucene/search/IndexSearcher.java +++ b/lucene/core/src/java/org/apache/lucene/search/IndexSearcher.java @@ -512,9 +512,8 @@ public class IndexSearcher { @Override public TopFieldCollector newCollector() throws IOException { - final boolean fillFields = true; // TODO: don't pay the price for accurate hit counts by default - return TopFieldCollector.create(rewrittenSort, cappedNumHits, after, fillFields, doDocScores, true); + return TopFieldCollector.create(rewrittenSort, cappedNumHits, after, doDocScores, true); } @Override diff --git a/lucene/core/src/java/org/apache/lucene/search/SortRescorer.java b/lucene/core/src/java/org/apache/lucene/search/SortRescorer.java index d8e16b12b2d..93dd1265dc7 100644 --- a/lucene/core/src/java/org/apache/lucene/search/SortRescorer.java +++ b/lucene/core/src/java/org/apache/lucene/search/SortRescorer.java @@ -54,7 +54,7 @@ public class SortRescorer extends Rescorer { List leaves = searcher.getIndexReader().leaves(); - TopFieldCollector collector = TopFieldCollector.create(sort, topN, true, true, true); + TopFieldCollector collector = TopFieldCollector.create(sort, topN, true, true); // Now merge sort docIDs from hits, with reader's leaves: int hitUpto = 0; diff --git a/lucene/core/src/java/org/apache/lucene/search/TopDocs.java b/lucene/core/src/java/org/apache/lucene/search/TopDocs.java index 3a2fa58dc8f..25f7b34688d 100644 --- a/lucene/core/src/java/org/apache/lucene/search/TopDocs.java +++ b/lucene/core/src/java/org/apache/lucene/search/TopDocs.java @@ -140,7 +140,7 @@ public class TopDocs { } final FieldDoc fd = (FieldDoc) sd; if (fd.fields == null) { - throw new IllegalArgumentException("shard " + shardIDX + " did not set sort field values (FieldDoc.fields is null); you must pass fillFields=true to IndexSearcher.search on each shard"); + throw new IllegalArgumentException("shard " + shardIDX + " did not set sort field values (FieldDoc.fields is null)"); } } } diff --git a/lucene/core/src/java/org/apache/lucene/search/TopFieldCollector.java b/lucene/core/src/java/org/apache/lucene/search/TopFieldCollector.java index 3ccd9bb0480..7defdf90bdc 100644 --- a/lucene/core/src/java/org/apache/lucene/search/TopFieldCollector.java +++ b/lucene/core/src/java/org/apache/lucene/search/TopFieldCollector.java @@ -28,7 +28,7 @@ import org.apache.lucene.util.PriorityQueue; * A {@link Collector} that sorts by {@link SortField} using * {@link FieldComparator}s. *

- * See the {@link #create(org.apache.lucene.search.Sort, int, boolean, boolean, boolean)} method + * See the {@link #create(org.apache.lucene.search.Sort, int, boolean, boolean)} method * for instantiating a TopFieldCollector. * * @lucene.experimental @@ -97,9 +97,9 @@ public abstract class TopFieldCollector extends TopDocsCollector { final boolean mayNeedScoresTwice; final boolean trackTotalHits; - public SimpleFieldCollector(Sort sort, FieldValueHitQueue queue, int numHits, boolean fillFields, + public SimpleFieldCollector(Sort sort, FieldValueHitQueue queue, int numHits, boolean trackDocScores, boolean trackTotalHits) { - super(queue, numHits, fillFields, sort.needsScores() || trackDocScores); + super(queue, numHits, sort.needsScores() || trackDocScores); this.sort = sort; this.queue = queue; this.trackDocScores = trackDocScores; @@ -189,9 +189,9 @@ public abstract class TopFieldCollector extends TopDocsCollector { final boolean mayNeedScoresTwice; final boolean trackTotalHits; - public PagingFieldCollector(Sort sort, FieldValueHitQueue queue, FieldDoc after, int numHits, boolean fillFields, + public PagingFieldCollector(Sort sort, FieldValueHitQueue queue, FieldDoc after, int numHits, boolean trackDocScores, boolean trackTotalHits) { - super(queue, numHits, fillFields, trackDocScores || sort.needsScores()); + super(queue, numHits, trackDocScores || sort.needsScores()); this.sort = sort; this.queue = queue; this.trackDocScores = trackDocScores; @@ -290,8 +290,6 @@ public abstract class TopFieldCollector extends TopDocsCollector { private static final ScoreDoc[] EMPTY_SCOREDOCS = new ScoreDoc[0]; - private final boolean fillFields; - final int numHits; FieldValueHitQueue.Entry bottom = null; boolean queueFull; @@ -304,11 +302,10 @@ public abstract class TopFieldCollector extends TopDocsCollector { // internal versions. If someone will define a constructor with any other // visibility, then anyone will be able to extend the class, which is not what // we want. - private TopFieldCollector(PriorityQueue pq, int numHits, boolean fillFields, boolean needsScores) { + private TopFieldCollector(PriorityQueue pq, int numHits, boolean needsScores) { super(pq); this.needsScores = needsScores; this.numHits = numHits; - this.fillFields = fillFields; } @Override @@ -328,9 +325,6 @@ public abstract class TopFieldCollector extends TopDocsCollector { * the sort criteria (SortFields). * @param numHits * the number of results to collect. - * @param fillFields - * specifies whether the actual field values should be returned on - * the results (FieldDoc). * @param trackDocScores * specifies whether document scores should be tracked and set on the * results. Note that if set to false, then the results' scores will @@ -346,8 +340,8 @@ public abstract class TopFieldCollector extends TopDocsCollector { * the sort criteria. */ public static TopFieldCollector create(Sort sort, int numHits, - boolean fillFields, boolean trackDocScores, boolean trackTotalHits) { - return create(sort, numHits, null, fillFields, trackDocScores, trackTotalHits); + boolean trackDocScores, boolean trackTotalHits) { + return create(sort, numHits, null, trackDocScores, trackTotalHits); } /** @@ -364,9 +358,6 @@ public abstract class TopFieldCollector extends TopDocsCollector { * the number of results to collect. * @param after * only hits after this FieldDoc will be collected - * @param fillFields - * specifies whether the actual field values should be returned on - * the results (FieldDoc). * @param trackDocScores * specifies whether document scores should be tracked and set on the * results. Note that if set to false, then the results' scores will @@ -383,7 +374,7 @@ public abstract class TopFieldCollector extends TopDocsCollector { * the sort criteria. */ public static TopFieldCollector create(Sort sort, int numHits, FieldDoc after, - boolean fillFields, boolean trackDocScores, boolean trackTotalHits) { + boolean trackDocScores, boolean trackTotalHits) { if (sort.fields.length == 0) { throw new IllegalArgumentException("Sort must contain at least one field"); @@ -396,7 +387,7 @@ public abstract class TopFieldCollector extends TopDocsCollector { FieldValueHitQueue queue = FieldValueHitQueue.create(sort.fields, numHits); if (after == null) { - return new SimpleFieldCollector(sort, queue, numHits, fillFields, trackDocScores, trackTotalHits); + return new SimpleFieldCollector(sort, queue, numHits, trackDocScores, trackTotalHits); } else { if (after.fields == null) { throw new IllegalArgumentException("after.fields wasn't set; you must pass fillFields=true for the previous search"); @@ -406,7 +397,7 @@ public abstract class TopFieldCollector extends TopDocsCollector { throw new IllegalArgumentException("after.fields has " + after.fields.length + " values but sort has " + sort.getSort().length); } - return new PagingFieldCollector(sort, queue, after, numHits, fillFields, trackDocScores, trackTotalHits); + return new PagingFieldCollector(sort, queue, after, numHits, trackDocScores, trackTotalHits); } } @@ -434,17 +425,10 @@ public abstract class TopFieldCollector extends TopDocsCollector { @Override protected void populateResults(ScoreDoc[] results, int howMany) { - if (fillFields) { - // avoid casting if unnecessary. - FieldValueHitQueue queue = (FieldValueHitQueue) pq; - for (int i = howMany - 1; i >= 0; i--) { - results[i] = queue.fillFields(queue.pop()); - } - } else { - for (int i = howMany - 1; i >= 0; i--) { - Entry entry = pq.pop(); - results[i] = new FieldDoc(entry.doc, entry.score); - } + // avoid casting if unnecessary. + FieldValueHitQueue queue = (FieldValueHitQueue) pq; + for (int i = howMany - 1; i >= 0; i--) { + results[i] = queue.fillFields(queue.pop()); } } diff --git a/lucene/core/src/test/org/apache/lucene/index/TestIndexSorting.java b/lucene/core/src/test/org/apache/lucene/index/TestIndexSorting.java index 9f12ca215da..f454d484be9 100644 --- a/lucene/core/src/test/org/apache/lucene/index/TestIndexSorting.java +++ b/lucene/core/src/test/org/apache/lucene/index/TestIndexSorting.java @@ -2324,11 +2324,11 @@ public class TestIndexSorting extends LuceneTestCase { System.out.println("TEST: iter=" + iter + " numHits=" + numHits); } - TopFieldCollector c1 = TopFieldCollector.create(sort, numHits, true, true, true); + TopFieldCollector c1 = TopFieldCollector.create(sort, numHits, true, true); s1.search(new MatchAllDocsQuery(), c1); TopDocs hits1 = c1.topDocs(); - TopFieldCollector c2 = TopFieldCollector.create(sort, numHits, true, true, false); + TopFieldCollector c2 = TopFieldCollector.create(sort, numHits, true, false); s2.search(new MatchAllDocsQuery(), c2); TopDocs hits2 = c2.topDocs(); diff --git a/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java b/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java index 7522cd0b142..94857170982 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java @@ -386,10 +386,10 @@ public class TestBoolean2 extends LuceneTestCase { } // check diff (randomized) scorers (from AssertingSearcher) produce the same results - TopFieldCollector collector = TopFieldCollector.create(sort, 1000, false, true, false); + TopFieldCollector collector = TopFieldCollector.create(sort, 1000, true, false); searcher.search(q1, collector); ScoreDoc[] hits1 = collector.topDocs().scoreDocs; - collector = TopFieldCollector.create(sort, 1000, false, true, false); + collector = TopFieldCollector.create(sort, 1000, true, false); searcher.search(q1, collector); ScoreDoc[] hits2 = collector.topDocs().scoreDocs; tot+=hits2.length; @@ -402,10 +402,10 @@ public class TestBoolean2 extends LuceneTestCase { assertEquals(mulFactor*collector.totalHits + NUM_EXTRA_DOCS/2, hits4.totalHits); // test diff (randomized) scorers produce the same results on bigSearcher as well - collector = TopFieldCollector.create(sort, 1000 * mulFactor, false, true, false); + collector = TopFieldCollector.create(sort, 1000 * mulFactor, true, false); bigSearcher.search(q1, collector); hits1 = collector.topDocs().scoreDocs; - collector = TopFieldCollector.create(sort, 1000 * mulFactor, false, true, false); + collector = TopFieldCollector.create(sort, 1000 * mulFactor, true, false); bigSearcher.search(q1, collector); hits2 = collector.topDocs().scoreDocs; CheckHits.checkEqual(q1, hits1, hits2); diff --git a/lucene/core/src/test/org/apache/lucene/search/TestElevationComparator.java b/lucene/core/src/test/org/apache/lucene/search/TestElevationComparator.java index bc849e9e21f..5d5488a27ca 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestElevationComparator.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestElevationComparator.java @@ -86,7 +86,7 @@ public class TestElevationComparator extends LuceneTestCase { new SortField(null, SortField.Type.SCORE, reversed) ); - TopDocsCollector topCollector = TopFieldCollector.create(sort, 50, false, true, true); + TopDocsCollector topCollector = TopFieldCollector.create(sort, 50, true, true); searcher.search(newq.build(), topCollector); TopDocs topDocs = topCollector.topDocs(0, 10); diff --git a/lucene/core/src/test/org/apache/lucene/search/TestTopDocsMerge.java b/lucene/core/src/test/org/apache/lucene/search/TestTopDocsMerge.java index 65de8f52399..2174acf01c1 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestTopDocsMerge.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestTopDocsMerge.java @@ -281,7 +281,7 @@ public class TestTopDocsMerge extends LuceneTestCase { topHits = searcher.search(query, numHits); } } else { - final TopFieldCollector c = TopFieldCollector.create(sort, numHits, true, true, true); + final TopFieldCollector c = TopFieldCollector.create(sort, numHits, true, true); searcher.search(query, c); if (useFrom) { from = TestUtil.nextInt(random(), 0, numHits - 1); @@ -330,7 +330,7 @@ public class TestTopDocsMerge extends LuceneTestCase { if (sort == null) { subHits = subSearcher.search(w, numHits); } else { - final TopFieldCollector c = TopFieldCollector.create(sort, numHits, true, true, true); + final TopFieldCollector c = TopFieldCollector.create(sort, numHits, true, true); subSearcher.search(w, c); subHits = c.topDocs(0, numHits); } diff --git a/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollector.java b/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollector.java index a7f4cdaef45..1b214b1f667 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollector.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollector.java @@ -70,7 +70,7 @@ public class TestTopFieldCollector extends LuceneTestCase { Sort[] sort = new Sort[] { new Sort(SortField.FIELD_DOC), new Sort() }; for(int i = 0; i < sort.length; i++) { Query q = new MatchAllDocsQuery(); - TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, false, + TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, false, true); is.search(q, tdc); @@ -89,7 +89,7 @@ public class TestTopFieldCollector extends LuceneTestCase { Sort[] sort = new Sort[] {new Sort(SortField.FIELD_DOC), new Sort() }; for(int i = 0; i < sort.length; i++) { Query q = new MatchAllDocsQuery(); - TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, true, false, + TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, false, true); is.search(q, tdc); @@ -110,10 +110,10 @@ public class TestTopFieldCollector extends LuceneTestCase { // the index is not sorted TopDocsCollector tdc; if (i % 2 == 0) { - tdc = TopFieldCollector.create(sort, 10, true, false, false); + tdc = TopFieldCollector.create(sort, 10, false, false); } else { FieldDoc fieldDoc = new FieldDoc(1, Float.NaN, new Object[] { 1 }); - tdc = TopFieldCollector.create(sort, 10, fieldDoc, true, false, false); + tdc = TopFieldCollector.create(sort, 10, fieldDoc, false, false); } is.search(q, tdc); @@ -132,7 +132,7 @@ public class TestTopFieldCollector extends LuceneTestCase { Sort[] sort = new Sort[] {new Sort(SortField.FIELD_DOC), new Sort() }; for(int i = 0; i < sort.length; i++) { Query q = new MatchAllDocsQuery(); - TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, true, true, + TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, true, true); is.search(q, tdc); @@ -150,7 +150,7 @@ public class TestTopFieldCollector extends LuceneTestCase { // Two Sort criteria to instantiate the multi/single comparators. Sort[] sort = new Sort[] {new Sort(SortField.FIELD_DOC), new Sort() }; for(int i = 0; i < sort.length; i++) { - TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, true, true, true); + TopDocsCollector tdc = TopFieldCollector.create(sort[i], 10, true, true); TopDocs td = tdc.topDocs(); assertEquals(0, td.totalHits); } @@ -183,7 +183,7 @@ public class TestTopFieldCollector extends LuceneTestCase { final IndexSearcher searcher = new IndexSearcher(reader); for (Sort sort : new Sort[] {new Sort(SortField.FIELD_SCORE), new Sort(new SortField("f", SortField.Type.SCORE))}) { for (boolean doDocScores : new boolean[] {false, true}) { - final TopFieldCollector topCollector = TopFieldCollector.create(sort, TestUtil.nextInt(random(), 1, 2), true, doDocScores, true); + final TopFieldCollector topCollector = TopFieldCollector.create(sort, TestUtil.nextInt(random(), 1, 2), doDocScores, true); final Collector assertingCollector = new Collector() { @Override public LeafCollector getLeafCollector(LeafReaderContext context) throws IOException { diff --git a/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollectorEarlyTermination.java b/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollectorEarlyTermination.java index 2fd99d9a6e8..b910dd8f079 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollectorEarlyTermination.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestTopFieldCollectorEarlyTermination.java @@ -136,10 +136,9 @@ public class TestTopFieldCollectorEarlyTermination extends LuceneTestCase { } else { after = null; } - final boolean fillFields = random().nextBoolean(); final boolean trackDocScores = random().nextBoolean(); - final TopFieldCollector collector1 = TopFieldCollector.create(sort, numHits, after, fillFields, trackDocScores, true); - final TopFieldCollector collector2 = TopFieldCollector.create(sort, numHits, after, fillFields, trackDocScores, false); + final TopFieldCollector collector1 = TopFieldCollector.create(sort, numHits, after, trackDocScores, true); + final TopFieldCollector collector2 = TopFieldCollector.create(sort, numHits, after, trackDocScores, false); final Query query; if (random().nextBoolean()) { diff --git a/lucene/facet/src/java/org/apache/lucene/facet/DrillSideways.java b/lucene/facet/src/java/org/apache/lucene/facet/DrillSideways.java index 9badc8c3607..861a4a384e8 100644 --- a/lucene/facet/src/java/org/apache/lucene/facet/DrillSideways.java +++ b/lucene/facet/src/java/org/apache/lucene/facet/DrillSideways.java @@ -241,7 +241,7 @@ public class DrillSideways { @Override public TopFieldCollector newCollector() throws IOException { - return TopFieldCollector.create(sort, fTopN, after, true, doDocScores, true); + return TopFieldCollector.create(sort, fTopN, after, doDocScores, true); } @Override @@ -260,7 +260,7 @@ public class DrillSideways { } else { final TopFieldCollector hitCollector = - TopFieldCollector.create(sort, fTopN, after, true, doDocScores, true); + TopFieldCollector.create(sort, fTopN, after, doDocScores, true); DrillSidewaysResult r = search(query, hitCollector); return new DrillSidewaysResult(r.facets, hitCollector.topDocs()); } diff --git a/lucene/facet/src/java/org/apache/lucene/facet/FacetsCollector.java b/lucene/facet/src/java/org/apache/lucene/facet/FacetsCollector.java index 8c32f8cc370..94b5f4138f9 100644 --- a/lucene/facet/src/java/org/apache/lucene/facet/FacetsCollector.java +++ b/lucene/facet/src/java/org/apache/lucene/facet/FacetsCollector.java @@ -228,10 +228,8 @@ public class FacetsCollector extends SimpleCollector implements Collector { // remove this throw new IllegalArgumentException("after must be a FieldDoc; got " + after); } - boolean fillFields = true; hitsCollector = TopFieldCollector.create(sort, n, (FieldDoc) after, - fillFields, doDocScores, true); // TODO: can we disable exact hit counts } else { diff --git a/lucene/grouping/src/java/org/apache/lucene/search/grouping/BlockGroupingCollector.java b/lucene/grouping/src/java/org/apache/lucene/search/grouping/BlockGroupingCollector.java index f627adff268..80af1b8598e 100644 --- a/lucene/grouping/src/java/org/apache/lucene/search/grouping/BlockGroupingCollector.java +++ b/lucene/grouping/src/java/org/apache/lucene/search/grouping/BlockGroupingCollector.java @@ -270,10 +270,8 @@ public class BlockGroupingCollector extends SimpleCollector { * within each group * @param maxDocsPerGroup How many top documents to keep * within each group. - * @param fillSortFields If true then the Comparable - * values for the sort fields will be set */ - public TopGroups getTopGroups(Sort withinGroupSort, int groupOffset, int withinGroupOffset, int maxDocsPerGroup, boolean fillSortFields) throws IOException { + public TopGroups getTopGroups(Sort withinGroupSort, int groupOffset, int withinGroupOffset, int maxDocsPerGroup) throws IOException { //if (queueFull) { //System.out.println("getTopGroups groupOffset=" + groupOffset + " topNGroups=" + topNGroups); @@ -306,7 +304,7 @@ public class BlockGroupingCollector extends SimpleCollector { collector = TopScoreDocCollector.create(maxDocsPerGroup); } else { // Sort by fields - collector = TopFieldCollector.create(withinGroupSort, maxDocsPerGroup, fillSortFields, needsScores, true); // TODO: disable exact counts? + collector = TopFieldCollector.create(withinGroupSort, maxDocsPerGroup, needsScores, true); // TODO: disable exact counts? } float groupMaxScore = needsScores ? Float.NEGATIVE_INFINITY : Float.NaN; @@ -325,13 +323,9 @@ public class BlockGroupingCollector extends SimpleCollector { final Object[] groupSortValues; - if (fillSortFields) { - groupSortValues = new Comparable[comparators.length]; - for(int sortFieldIDX=0;sortFieldIDX[comparators.length]; + for(int sortFieldIDX=0;sortFieldIDX extends SimpleCollector { * number of unique groups collected is <= offset. * * @param groupOffset The offset in the collected groups - * @param fillFields Whether to fill to {@link SearchGroup#sortValues} * @return top groups, starting from offset */ - public Collection> getTopGroups(int groupOffset, boolean fillFields) throws IOException { + public Collection> getTopGroups(int groupOffset) throws IOException { //System.out.println("FP.getTopGroups groupOffset=" + groupOffset + " fillFields=" + fillFields + " groupMap.size()=" + groupMap.size()); @@ -140,11 +139,9 @@ public class FirstPassGroupingCollector extends SimpleCollector { // System.out.println(" group=" + (group.groupValue == null ? "null" : group.groupValue.toString())); SearchGroup searchGroup = new SearchGroup<>(); searchGroup.groupValue = group.groupValue; - if (fillFields) { - searchGroup.sortValues = new Object[sortFieldCount]; - for(int sortFieldIDX=0;sortFieldIDX topSearchGroups = firstPassCollector.getTopGroups(groupOffset, fillSortFields); + Collection topSearchGroups = firstPassCollector.getTopGroups(groupOffset); if (topSearchGroups == null) { return new TopGroups(new SortField[0], new SortField[0], 0, 0, new GroupDocs[0], Float.NaN); } @@ -155,7 +154,7 @@ public class GroupingSearch { int topNInsideGroup = groupDocsOffset + groupDocsLimit; TopGroupsCollector secondPassCollector = new TopGroupsCollector(grouper, topSearchGroups, groupSort, sortWithinGroup, topNInsideGroup, - includeScores, includeMaxScore, fillSortFields); + includeScores, includeMaxScore); if (cachedCollector != null && cachedCollector.isCached()) { cachedCollector.replay(secondPassCollector); @@ -177,7 +176,7 @@ public class GroupingSearch { BlockGroupingCollector c = new BlockGroupingCollector(groupSort, topN, includeScores, groupEndDocs); searcher.search(query, c); int topNInsideGroup = groupDocsOffset + groupDocsLimit; - return c.getTopGroups(sortWithinGroup, groupOffset, groupDocsOffset, topNInsideGroup, fillSortFields); + return c.getTopGroups(sortWithinGroup, groupOffset, groupDocsOffset, topNInsideGroup); } /** @@ -269,17 +268,6 @@ public class GroupingSearch { return this; } - /** - * Whether to also fill the sort fields per returned group and groups docs. - * - * @param fillSortFields Whether to also fill the sort fields per returned group and groups docs - * @return this - */ - public GroupingSearch setFillSortFields(boolean fillSortFields) { - this.fillSortFields = fillSortFields; - return this; - } - /** * Whether to include the scores per doc inside a group. * diff --git a/lucene/grouping/src/java/org/apache/lucene/search/grouping/TopGroupsCollector.java b/lucene/grouping/src/java/org/apache/lucene/search/grouping/TopGroupsCollector.java index eb7536634fa..519bd89ad91 100644 --- a/lucene/grouping/src/java/org/apache/lucene/search/grouping/TopGroupsCollector.java +++ b/lucene/grouping/src/java/org/apache/lucene/search/grouping/TopGroupsCollector.java @@ -56,12 +56,11 @@ public class TopGroupsCollector extends SecondPassGroupingCollector { * @param maxDocsPerGroup the maximum number of docs to collect for each group * @param getScores if true, record the scores of all docs in each group * @param getMaxScores if true, record the maximum score for each group - * @param fillSortFields if true, record the sort field values for all docs */ public TopGroupsCollector(GroupSelector groupSelector, Collection> groups, Sort groupSort, Sort withinGroupSort, - int maxDocsPerGroup, boolean getScores, boolean getMaxScores, boolean fillSortFields) { + int maxDocsPerGroup, boolean getScores, boolean getMaxScores) { super(groupSelector, groups, - new TopDocsReducer<>(withinGroupSort, maxDocsPerGroup, getScores, getMaxScores, fillSortFields)); + new TopDocsReducer<>(withinGroupSort, maxDocsPerGroup, getScores, getMaxScores)); this.groupSort = Objects.requireNonNull(groupSort); this.withinGroupSort = Objects.requireNonNull(withinGroupSort); this.maxDocsPerGroup = maxDocsPerGroup; @@ -115,13 +114,13 @@ public class TopGroupsCollector extends SecondPassGroupingCollector { private final boolean needsScores; TopDocsReducer(Sort withinGroupSort, - int maxDocsPerGroup, boolean getScores, boolean getMaxScores, boolean fillSortFields) { + int maxDocsPerGroup, boolean getScores, boolean getMaxScores) { this.needsScores = getScores || getMaxScores || withinGroupSort.needsScores(); if (withinGroupSort == Sort.RELEVANCE) { supplier = () -> new TopDocsAndMaxScoreCollector(true, TopScoreDocCollector.create(maxDocsPerGroup), null); } else { supplier = () -> { - TopFieldCollector topDocsCollector = TopFieldCollector.create(withinGroupSort, maxDocsPerGroup, fillSortFields, getScores, true); // TODO: disable exact counts? + TopFieldCollector topDocsCollector = TopFieldCollector.create(withinGroupSort, maxDocsPerGroup, getScores, true); // TODO: disable exact counts? MaxScoreCollector maxScoreCollector = getMaxScores ? new MaxScoreCollector() : null; return new TopDocsAndMaxScoreCollector(false, topDocsCollector, maxScoreCollector); }; diff --git a/lucene/grouping/src/test/org/apache/lucene/search/grouping/DistinctValuesCollectorTest.java b/lucene/grouping/src/test/org/apache/lucene/search/grouping/DistinctValuesCollectorTest.java index 89d9a6e4a46..2bdd9472c69 100644 --- a/lucene/grouping/src/test/org/apache/lucene/search/grouping/DistinctValuesCollectorTest.java +++ b/lucene/grouping/src/test/org/apache/lucene/search/grouping/DistinctValuesCollectorTest.java @@ -246,7 +246,7 @@ public class DistinctValuesCollectorTest extends AbstractGroupingTestCase { System.out.println("1st pass collector class name=" + firstCollector.getClass().getName()); System.out.println("2nd pass collector class name=" + distinctValuesCollector.getClass().getName()); System.out.println("Search term=" + term); - System.out.println("1st pass groups=" + firstCollector.getTopGroups(0, false)); + System.out.println("1st pass groups=" + firstCollector.getTopGroups(0)); System.out.println("Expected:"); printGroups(expectedResult); System.out.println("Actual:"); @@ -342,7 +342,7 @@ public class DistinctValuesCollectorTest extends AbstractGroupingTestCase { @SuppressWarnings({"unchecked","rawtypes"}) private , R extends Comparable> DistinctValuesCollector createDistinctCountCollector(FirstPassGroupingCollector firstPassGroupingCollector, String countField) throws IOException { - Collection> searchGroups = firstPassGroupingCollector.getTopGroups(0, false); + Collection> searchGroups = firstPassGroupingCollector.getTopGroups(0); GroupSelector selector = firstPassGroupingCollector.getGroupSelector(); if (ValueSourceGroupSelector.class.isAssignableFrom(selector.getClass())) { GroupSelector gs = new ValueSourceGroupSelector(new BytesRefFieldSource(countField), new HashMap<>()); diff --git a/lucene/grouping/src/test/org/apache/lucene/search/grouping/TestGrouping.java b/lucene/grouping/src/test/org/apache/lucene/search/grouping/TestGrouping.java index 75cf04f8aa5..bf3685320c6 100644 --- a/lucene/grouping/src/test/org/apache/lucene/search/grouping/TestGrouping.java +++ b/lucene/grouping/src/test/org/apache/lucene/search/grouping/TestGrouping.java @@ -145,7 +145,7 @@ public class TestGrouping extends LuceneTestCase { final FirstPassGroupingCollector c1 = createRandomFirstPassCollector(groupField, groupSort, 10); indexSearcher.search(new TermQuery(new Term("content", "random")), c1); - final TopGroupsCollector c2 = createSecondPassCollector(c1, groupSort, Sort.RELEVANCE, 0, 5, true, true, true); + final TopGroupsCollector c2 = createSecondPassCollector(c1, groupSort, Sort.RELEVANCE, 0, 5, true, true); indexSearcher.search(new TermQuery(new Term("content", "random")), c2); final TopGroups groups = c2.getTopGroups(0); @@ -219,11 +219,10 @@ public class TestGrouping extends LuceneTestCase { int groupOffset, int maxDocsPerGroup, boolean getScores, - boolean getMaxScores, - boolean fillSortFields) throws IOException { + boolean getMaxScores) throws IOException { - Collection> searchGroups = firstPassGroupingCollector.getTopGroups(groupOffset, fillSortFields); - return new TopGroupsCollector<>(firstPassGroupingCollector.getGroupSelector(), searchGroups, groupSort, sortWithinGroup, maxDocsPerGroup, getScores, getMaxScores, fillSortFields); + Collection> searchGroups = firstPassGroupingCollector.getTopGroups(groupOffset); + return new TopGroupsCollector<>(firstPassGroupingCollector.getGroupSelector(), searchGroups, groupSort, sortWithinGroup, maxDocsPerGroup, getScores, getMaxScores); } // Basically converts searchGroups from MutableValue to BytesRef if grouping by ValueSource @@ -235,11 +234,10 @@ public class TestGrouping extends LuceneTestCase { Sort sortWithinGroup, int maxDocsPerGroup, boolean getScores, - boolean getMaxScores, - boolean fillSortFields) throws IOException { + boolean getMaxScores) throws IOException { if (firstPassGroupingCollector.getGroupSelector().getClass().isAssignableFrom(TermGroupSelector.class)) { GroupSelector selector = (GroupSelector) firstPassGroupingCollector.getGroupSelector(); - return new TopGroupsCollector<>(selector, searchGroups, groupSort, sortWithinGroup, maxDocsPerGroup , getScores, getMaxScores, fillSortFields); + return new TopGroupsCollector<>(selector, searchGroups, groupSort, sortWithinGroup, maxDocsPerGroup , getScores, getMaxScores); } else { ValueSource vs = new BytesRefFieldSource(groupField); List> mvalSearchGroups = new ArrayList<>(searchGroups.size()); @@ -256,7 +254,7 @@ public class TestGrouping extends LuceneTestCase { mvalSearchGroups.add(sg); } ValueSourceGroupSelector selector = new ValueSourceGroupSelector(vs, new HashMap<>()); - return new TopGroupsCollector<>(selector, mvalSearchGroups, groupSort, sortWithinGroup, maxDocsPerGroup, getScores, getMaxScores, fillSortFields); + return new TopGroupsCollector<>(selector, mvalSearchGroups, groupSort, sortWithinGroup, maxDocsPerGroup, getScores, getMaxScores); } } @@ -288,13 +286,13 @@ public class TestGrouping extends LuceneTestCase { } } - private Collection> getSearchGroups(FirstPassGroupingCollector c, int groupOffset, boolean fillFields) throws IOException { + private Collection> getSearchGroups(FirstPassGroupingCollector c, int groupOffset) throws IOException { if (TermGroupSelector.class.isAssignableFrom(c.getGroupSelector().getClass())) { FirstPassGroupingCollector collector = (FirstPassGroupingCollector) c; - return collector.getTopGroups(groupOffset, fillFields); + return collector.getTopGroups(groupOffset); } else if (ValueSourceGroupSelector.class.isAssignableFrom(c.getGroupSelector().getClass())) { FirstPassGroupingCollector collector = (FirstPassGroupingCollector) c; - Collection> mutableValueGroups = collector.getTopGroups(groupOffset, fillFields); + Collection> mutableValueGroups = collector.getTopGroups(groupOffset); if (mutableValueGroups == null) { return null; } @@ -439,7 +437,6 @@ public class TestGrouping extends LuceneTestCase { private TopGroups slowGrouping(GroupDoc[] groupDocs, String searchTerm, - boolean fillFields, boolean getScores, boolean getMaxScores, boolean doAllGroups, @@ -480,9 +477,7 @@ public class TestGrouping extends LuceneTestCase { if (l == null) { //System.out.println(" add sortedGroup=" + groupToString(d.group)); sortedGroups.add(d.group); - if (fillFields) { - sortedGroupFields.add(fillFields(d, groupSort)); - } + sortedGroupFields.add(fillFields(d, groupSort)); l = new ArrayList<>(); groups.put(d.group, l); } @@ -512,11 +507,7 @@ public class TestGrouping extends LuceneTestCase { for(int docIDX=docOffset; docIDX < docIDXLimit; docIDX++) { final GroupDoc d = docs.get(docIDX); final FieldDoc fd; - if (fillFields) { - fd = new FieldDoc(d.id, getScores ? d.score : Float.NaN, fillFields(d, docSort)); - } else { - fd = new FieldDoc(d.id, getScores ? d.score : Float.NaN); - } + fd = new FieldDoc(d.id, getScores ? d.score : Float.NaN, fillFields(d, docSort)); hits[docIDX-docOffset] = fd; } } else { @@ -528,7 +519,7 @@ public class TestGrouping extends LuceneTestCase { docs.size(), hits, group, - fillFields ? sortedGroupFields.get(idx) : null); + sortedGroupFields.get(idx)); } if (doAllGroups) { @@ -838,7 +829,6 @@ public class TestGrouping extends LuceneTestCase { } final String searchTerm = "real" + random().nextInt(3); - final boolean fillFields = random().nextBoolean(); boolean getScores = random().nextBoolean(); final boolean getMaxScores = random().nextBoolean(); final Sort groupSort = getRandomSort(); @@ -929,7 +919,7 @@ public class TestGrouping extends LuceneTestCase { } // Get 1st pass top groups - final Collection> topGroups = getSearchGroups(c1, groupOffset, fillFields); + final Collection> topGroups = getSearchGroups(c1, groupOffset); final TopGroups groupsResult; if (VERBOSE) { System.out.println("TEST: first pass topGroups"); @@ -956,7 +946,7 @@ public class TestGrouping extends LuceneTestCase { } } - c2 = createSecondPassCollector(c1, groupSort, docSort, groupOffset, docOffset + docsPerGroup, getScores, getMaxScores, fillFields); + c2 = createSecondPassCollector(c1, groupSort, docSort, groupOffset, docOffset + docsPerGroup, getScores, getMaxScores); if (doCache) { if (cCache.isCached()) { if (VERBOSE) { @@ -987,7 +977,7 @@ public class TestGrouping extends LuceneTestCase { } } - final TopGroups expectedGroups = slowGrouping(groupDocs, searchTerm, fillFields, getScores, getMaxScores, doAllGroups, groupSort, docSort, topNGroups, docsPerGroup, groupOffset, docOffset); + final TopGroups expectedGroups = slowGrouping(groupDocs, searchTerm, getScores, getMaxScores, doAllGroups, groupSort, docSort, topNGroups, docsPerGroup, groupOffset, docOffset); if (VERBOSE) { if (expectedGroups == null) { @@ -1033,10 +1023,10 @@ public class TestGrouping extends LuceneTestCase { } } - assertEquals(docIDToID, expectedGroups, groupsResult, true, true, true, getScores, true); + assertEquals(docIDToID, expectedGroups, groupsResult, true, true, getScores, true); // Confirm merged shards match: - assertEquals(docIDToID, expectedGroups, topGroupsShards, true, false, fillFields, getScores, true); + assertEquals(docIDToID, expectedGroups, topGroupsShards, true, false, getScores, true); if (topGroupsShards != null) { verifyShards(shards.docStarts, topGroupsShards); } @@ -1059,7 +1049,7 @@ public class TestGrouping extends LuceneTestCase { // Get block grouping result: sBlocks.search(query, c4); @SuppressWarnings({"unchecked","rawtypes"}) - final TopGroups tempTopGroupsBlocks = (TopGroups) c3.getTopGroups(docSort, groupOffset, docOffset, docOffset+docsPerGroup, fillFields); + final TopGroups tempTopGroupsBlocks = (TopGroups) c3.getTopGroups(docSort, groupOffset, docOffset, docOffset+docsPerGroup); final TopGroups groupsResultBlocks; if (doAllGroups && tempTopGroupsBlocks != null) { assertEquals((int) tempTopGroupsBlocks.totalGroupCount, allGroupsCollector2.getGroupCount()); @@ -1132,8 +1122,8 @@ public class TestGrouping extends LuceneTestCase { } } - assertEquals(docIDToIDBlocks, expectedGroups, groupsResultBlocks, false, true, true, getScores, false); - assertEquals(docIDToIDBlocks, expectedGroups, topGroupsBlockShards, false, false, fillFields, getScores, false); + assertEquals(docIDToIDBlocks, expectedGroups, groupsResultBlocks, false, true, getScores, false); + assertEquals(docIDToIDBlocks, expectedGroups, topGroupsBlockShards, false, false, getScores, false); } r.close(); @@ -1187,7 +1177,7 @@ public class TestGrouping extends LuceneTestCase { } firstPassGroupingCollectors.add(firstPassCollector); subSearchers[shardIDX].search(w, firstPassCollector); - final Collection> topGroups = getSearchGroups(firstPassCollector, 0, true); + final Collection> topGroups = getSearchGroups(firstPassCollector, 0); if (topGroups != null) { if (VERBOSE) { System.out.println(" shard " + shardIDX + " s=" + subSearchers[shardIDX] + " totalGroupedHitCount=?" + " " + topGroups.size() + " groups:"); @@ -1218,7 +1208,7 @@ public class TestGrouping extends LuceneTestCase { final TopGroups[] shardTopGroups = new TopGroups[subSearchers.length]; for(int shardIDX=0;shardIDX secondPassCollector = createSecondPassCollector(firstPassGroupingCollectors.get(shardIDX), - groupField, mergedTopGroups, groupSort, docSort, docOffset + topNDocs, getScores, getMaxScores, true); + groupField, mergedTopGroups, groupSort, docSort, docOffset + topNDocs, getScores, getMaxScores); subSearchers[shardIDX].search(w, secondPassCollector); shardTopGroups[shardIDX] = getTopGroups(secondPassCollector, 0); if (VERBOSE) { @@ -1242,7 +1232,7 @@ public class TestGrouping extends LuceneTestCase { } } - private void assertEquals(int[] docIDtoID, TopGroups expected, TopGroups actual, boolean verifyGroupValues, boolean verifyTotalGroupCount, boolean verifySortValues, boolean testScores, boolean idvBasedImplsUsed) { + private void assertEquals(int[] docIDtoID, TopGroups expected, TopGroups actual, boolean verifyGroupValues, boolean verifyTotalGroupCount, boolean testScores, boolean idvBasedImplsUsed) { if (expected == null) { assertNull(actual); return; @@ -1274,9 +1264,7 @@ public class TestGrouping extends LuceneTestCase { } } - if (verifySortValues) { - assertArrayEquals(expectedGroup.groupSortValues, actualGroup.groupSortValues); - } + assertArrayEquals(expectedGroup.groupSortValues, actualGroup.groupSortValues); // TODO // assertEquals(expectedGroup.maxScore, actualGroup.maxScore); @@ -1297,9 +1285,7 @@ public class TestGrouping extends LuceneTestCase { // TODO: too anal for now //assertEquals(Float.NaN, actualFD.score); } - if (verifySortValues) { - assertArrayEquals(expectedFD.fields, actualFD.fields); - } + assertArrayEquals(expectedFD.fields, actualFD.fields); } } } diff --git a/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java b/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java index ad762245c94..35cb3df337a 100644 --- a/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java +++ b/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java @@ -647,7 +647,7 @@ public class AnalyzingInfixSuggester extends Lookup implements Closeable { //System.out.println("finalQuery=" + finalQuery); // Sort by weight, descending: - TopFieldCollector c = TopFieldCollector.create(SORT, num, true, false, false); + TopFieldCollector c = TopFieldCollector.create(SORT, num, false, false); List results = null; SearcherManager mgr; IndexSearcher searcher; diff --git a/solr/core/src/java/org/apache/solr/handler/component/ExpandComponent.java b/solr/core/src/java/org/apache/solr/handler/component/ExpandComponent.java index e7b5433cb74..3b81914e2b4 100644 --- a/solr/core/src/java/org/apache/solr/handler/component/ExpandComponent.java +++ b/solr/core/src/java/org/apache/solr/handler/component/ExpandComponent.java @@ -535,7 +535,7 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia DocIdSetIterator iterator = new BitSetIterator(groupBits, 0); // cost is not useful here int group; while ((group = iterator.nextDoc()) != DocIdSetIterator.NO_MORE_DOCS) { - Collector collector = (sort == null) ? TopScoreDocCollector.create(limit) : TopFieldCollector.create(sort, limit, false, false, true); + Collector collector = (sort == null) ? TopScoreDocCollector.create(limit) : TopFieldCollector.create(sort, limit, false, true); groups.put(group, collector); } @@ -619,7 +619,7 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia Iterator iterator = groupSet.iterator(); while (iterator.hasNext()) { LongCursor cursor = iterator.next(); - Collector collector = (sort == null) ? TopScoreDocCollector.create(limit) : TopFieldCollector.create(sort, limit, false, false, true); + Collector collector = (sort == null) ? TopScoreDocCollector.create(limit) : TopFieldCollector.create(sort, limit, false, true); groups.put(cursor.value, collector); } diff --git a/solr/core/src/java/org/apache/solr/search/Grouping.java b/solr/core/src/java/org/apache/solr/search/Grouping.java index fff536d6463..ba8f4cd5420 100644 --- a/solr/core/src/java/org/apache/solr/search/Grouping.java +++ b/solr/core/src/java/org/apache/solr/search/Grouping.java @@ -731,7 +731,7 @@ public class Grouping { return totalCount == TotalCount.grouped ? allGroupsCollector : null; } - topGroups = format == Format.grouped ? firstPass.getTopGroups(offset, false) : firstPass.getTopGroups(0, false); + topGroups = format == Format.grouped ? firstPass.getTopGroups(offset) : firstPass.getTopGroups(0); if (topGroups == null) { if (totalCount == TotalCount.grouped) { allGroupsCollector = new AllGroupsCollector<>(new TermGroupSelector(groupBy)); @@ -747,7 +747,7 @@ public class Grouping { groupedDocsToCollect = Math.max(groupedDocsToCollect, 1); Sort withinGroupSort = this.withinGroupSort != null ? this.withinGroupSort : Sort.RELEVANCE; secondPass = new TopGroupsCollector<>(new TermGroupSelector(groupBy), - topGroups, groupSort, withinGroupSort, groupedDocsToCollect, needScores, needScores, false + topGroups, groupSort, withinGroupSort, groupedDocsToCollect, needScores, needScores ); if (totalCount == TotalCount.grouped) { @@ -850,7 +850,7 @@ public class Grouping { if (withinGroupSort == null || withinGroupSort.equals(Sort.RELEVANCE)) { subCollector = topCollector = TopScoreDocCollector.create(groupDocsToCollect); } else { - topCollector = TopFieldCollector.create(searcher.weightSort(withinGroupSort), groupDocsToCollect, false, needScores, true); + topCollector = TopFieldCollector.create(searcher.weightSort(withinGroupSort), groupDocsToCollect, needScores, true); if (needScores) { maxScoreCollector = new MaxScoreCollector(); subCollector = MultiCollector.wrap(topCollector, maxScoreCollector); @@ -936,7 +936,7 @@ public class Grouping { return totalCount == TotalCount.grouped ? allGroupsCollector : null; } - topGroups = format == Format.grouped ? firstPass.getTopGroups(offset, false) : firstPass.getTopGroups(0, false); + topGroups = format == Format.grouped ? firstPass.getTopGroups(offset) : firstPass.getTopGroups(0); if (topGroups == null) { if (totalCount == TotalCount.grouped) { allGroupsCollector = new AllGroupsCollector<>(newSelector()); @@ -952,7 +952,7 @@ public class Grouping { groupdDocsToCollect = Math.max(groupdDocsToCollect, 1); Sort withinGroupSort = this.withinGroupSort != null ? this.withinGroupSort : Sort.RELEVANCE; secondPass = new TopGroupsCollector<>(newSelector(), - topGroups, groupSort, withinGroupSort, groupdDocsToCollect, needScores, needScores, false + topGroups, groupSort, withinGroupSort, groupdDocsToCollect, needScores, needScores ); if (totalCount == TotalCount.grouped) { diff --git a/solr/core/src/java/org/apache/solr/search/ReRankCollector.java b/solr/core/src/java/org/apache/solr/search/ReRankCollector.java index a94a4124abe..6b2588b27c0 100644 --- a/solr/core/src/java/org/apache/solr/search/ReRankCollector.java +++ b/solr/core/src/java/org/apache/solr/search/ReRankCollector.java @@ -67,7 +67,7 @@ public class ReRankCollector extends TopDocsCollector { } else { sort = sort.rewrite(searcher); //scores are needed for Rescorer (regardless of whether sort needs it) - this.mainCollector = TopFieldCollector.create(sort, Math.max(this.reRankDocs, length), false, true, true); + this.mainCollector = TopFieldCollector.create(sort, Math.max(this.reRankDocs, length), true, true); } this.searcher = searcher; this.reRankQueryRescorer = reRankQueryRescorer; diff --git a/solr/core/src/java/org/apache/solr/search/SolrIndexSearcher.java b/solr/core/src/java/org/apache/solr/search/SolrIndexSearcher.java index 122de2b1daa..30b094215cf 100644 --- a/solr/core/src/java/org/apache/solr/search/SolrIndexSearcher.java +++ b/solr/core/src/java/org/apache/solr/search/SolrIndexSearcher.java @@ -1536,11 +1536,8 @@ public class SolrIndexSearcher extends IndexSearcher implements Closeable, SolrI final Sort weightedSort = weightSort(cmd.getSort()); final CursorMark cursor = cmd.getCursorMark(); - // :TODO: make fillFields its own QueryCommand flag? ... - // ... see comments in populateNextCursorMarkFromTopDocs for cache issues (SOLR-5595) - final boolean fillFields = (null != cursor); final FieldDoc searchAfter = (null != cursor ? cursor.getSearchAfterFieldDoc() : null); - return TopFieldCollector.create(weightedSort, len, searchAfter, fillFields, needScores, true); + return TopFieldCollector.create(weightedSort, len, searchAfter, needScores, true); } } diff --git a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/QueryCommand.java b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/QueryCommand.java index 321936bf8c5..f88f170dd36 100644 --- a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/QueryCommand.java +++ b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/QueryCommand.java @@ -130,7 +130,7 @@ public class QueryCommand implements Command { if (sort == null || sort.equals(Sort.RELEVANCE)) { subCollector = topDocsCollector = TopScoreDocCollector.create(docsToCollect); } else { - topDocsCollector = TopFieldCollector.create(sort, docsToCollect, true, needScores, true); + topDocsCollector = TopFieldCollector.create(sort, docsToCollect, needScores, true); if (needScores) { maxScoreCollector = new MaxScoreCollector(); subCollector = MultiCollector.wrap(topDocsCollector, maxScoreCollector); diff --git a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/SearchGroupsFieldCommand.java b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/SearchGroupsFieldCommand.java index b81dda050a3..425a9877ff4 100644 --- a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/SearchGroupsFieldCommand.java +++ b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/SearchGroupsFieldCommand.java @@ -125,9 +125,9 @@ public class SearchGroupsFieldCommand implements Command> topGroups; if (firstPassGroupingCollector != null) { if (field.getType().getNumberType() != null) { - topGroups = GroupConverter.fromMutable(field, firstPassGroupingCollector.getTopGroups(0, true)); + topGroups = GroupConverter.fromMutable(field, firstPassGroupingCollector.getTopGroups(0)); } else { - topGroups = firstPassGroupingCollector.getTopGroups(0, true); + topGroups = firstPassGroupingCollector.getTopGroups(0); } } else { topGroups = Collections.emptyList(); diff --git a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/TopGroupsFieldCommand.java b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/TopGroupsFieldCommand.java index a4962789a0c..157e10da4cc 100644 --- a/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/TopGroupsFieldCommand.java +++ b/solr/core/src/java/org/apache/solr/search/grouping/distributed/command/TopGroupsFieldCommand.java @@ -136,11 +136,11 @@ public class TopGroupsFieldCommand implements Command> { ValueSource vs = fieldType.getValueSource(field, null); Collection> v = GroupConverter.toMutable(field, firstPhaseGroups); secondPassCollector = new TopGroupsCollector<>(new ValueSourceGroupSelector(vs, new HashMap<>()), - v, groupSort, withinGroupSort, maxDocPerGroup, needScores, needMaxScore, true + v, groupSort, withinGroupSort, maxDocPerGroup, needScores, needMaxScore ); } else { secondPassCollector = new TopGroupsCollector<>(new TermGroupSelector(field.getName()), - firstPhaseGroups, groupSort, withinGroupSort, maxDocPerGroup, needScores, needMaxScore, true + firstPhaseGroups, groupSort, withinGroupSort, maxDocPerGroup, needScores, needMaxScore ); } collectors.add(secondPassCollector); diff --git a/solr/core/src/test/org/apache/solr/search/TestSort.java b/solr/core/src/test/org/apache/solr/search/TestSort.java index abfbe8a52a9..f1d0817b914 100644 --- a/solr/core/src/test/org/apache/solr/search/TestSort.java +++ b/solr/core/src/test/org/apache/solr/search/TestSort.java @@ -284,7 +284,7 @@ public class TestSort extends SolrTestCaseJ4 { boolean trackScores = r.nextBoolean(); boolean scoreInOrder = r.nextBoolean(); - final TopFieldCollector topCollector = TopFieldCollector.create(sort, top, true, trackScores, true); + final TopFieldCollector topCollector = TopFieldCollector.create(sort, top, trackScores, true); final List collectedDocs = new ArrayList<>(); // delegate and collect docs ourselves