From a2aa167e6eded5f788cbf6d04b7fd2ee0f66bb1c Mon Sep 17 00:00:00 2001 From: Martijn van Groningen Date: Sat, 26 Apr 2014 00:01:52 +0700 Subject: [PATCH] Don't create docCounts equal to maxOrd for the GlobalOrdinalsStringTermsAggregator.WithHash impl. Relates #5873 --- .../GlobalOrdinalsStringTermsAggregator.java | 32 +++++++++++-------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/src/main/java/org/elasticsearch/search/aggregations/bucket/terms/GlobalOrdinalsStringTermsAggregator.java b/src/main/java/org/elasticsearch/search/aggregations/bucket/terms/GlobalOrdinalsStringTermsAggregator.java index 3f24f3ed9ad..7042fcc1934 100644 --- a/src/main/java/org/elasticsearch/search/aggregations/bucket/terms/GlobalOrdinalsStringTermsAggregator.java +++ b/src/main/java/org/elasticsearch/search/aggregations/bucket/terms/GlobalOrdinalsStringTermsAggregator.java @@ -42,9 +42,9 @@ import java.util.Arrays; */ public class GlobalOrdinalsStringTermsAggregator extends AbstractStringTermsAggregator { - private final ValuesSource.Bytes.WithOrdinals.FieldData valuesSource; - private BytesValues.WithOrdinals globalValues; - private Ordinals.Docs globalOrdinals; + protected final ValuesSource.Bytes.WithOrdinals.FieldData valuesSource; + protected BytesValues.WithOrdinals globalValues; + protected Ordinals.Docs globalOrdinals; public GlobalOrdinalsStringTermsAggregator(String name, AggregatorFactories factories, ValuesSource.Bytes.WithOrdinals.FieldData valuesSource, long estimatedBucketCount, InternalOrder order, int requiredSize, int shardSize, long minDocCount, AggregationContext aggregationContext, Aggregator parent) { @@ -52,10 +52,6 @@ public class GlobalOrdinalsStringTermsAggregator extends AbstractStringTermsAggr this.valuesSource = valuesSource; } - protected long createBucketOrd(long termOrd) { - return termOrd; - } - protected long getBucketOrd(long termOrd) { return termOrd; } @@ -77,7 +73,7 @@ public class GlobalOrdinalsStringTermsAggregator extends AbstractStringTermsAggr final int numOrds = globalOrdinals.setDocument(doc); for (int i = 0; i < numOrds; i++) { final long globalOrd = globalOrdinals.nextOrd(); - collectExistingBucket(doc, createBucketOrd(globalOrd)); + collectExistingBucket(doc, globalOrd); } } @@ -146,12 +142,22 @@ public class GlobalOrdinalsStringTermsAggregator extends AbstractStringTermsAggr } @Override - protected long createBucketOrd(long termOrd) { - long bucketOrd = bucketOrds.add(termOrd); - if (bucketOrd < 0) { - bucketOrd = -1 - bucketOrd; + public void setNextReader(AtomicReaderContext reader) { + globalValues = valuesSource.globalBytesValues(); + globalOrdinals = globalValues.ordinals(); + } + + @Override + public void collect(int doc, long owningBucketOrdinal) throws IOException { + final int numOrds = globalOrdinals.setDocument(doc); + for (int i = 0; i < numOrds; i++) { + final long globalOrd = globalOrdinals.nextOrd(); + long bucketOrd = bucketOrds.add(globalOrd); + if (bucketOrd < 0) { + bucketOrd = -1 - bucketOrd; + } + collectBucket(doc, bucketOrd); } - return bucketOrd; } @Override