optimize matcher reset to not create unnecessary string objects

This commit is contained in:
Simon Willnauer 2013-03-30 15:50:36 +01:00
parent fefa8da2ea
commit e864d5785e
1 changed files with 15 additions and 9 deletions

View File

@ -22,7 +22,9 @@ package org.elasticsearch.search.facet.terms.strings;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import org.apache.lucene.index.AtomicReaderContext; import org.apache.lucene.index.AtomicReaderContext;
import org.apache.lucene.util.BytesRef; import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.CharsRef;
import org.apache.lucene.util.PriorityQueue; import org.apache.lucene.util.PriorityQueue;
import org.apache.lucene.util.UnicodeUtil;
import org.elasticsearch.common.CacheRecycler; import org.elasticsearch.common.CacheRecycler;
import org.elasticsearch.common.collect.BoundedTreeSet; import org.elasticsearch.common.collect.BoundedTreeSet;
import org.elasticsearch.index.fielddata.BytesValues; import org.elasticsearch.index.fielddata.BytesValues;
@ -50,7 +52,6 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
private final TermsFacet.ComparatorType comparatorType; private final TermsFacet.ComparatorType comparatorType;
private final int size; private final int size;
private final int numberOfShards;
private final int minCount; private final int minCount;
private final ImmutableSet<BytesRef> excluded; private final ImmutableSet<BytesRef> excluded;
private final Matcher matcher; private final Matcher matcher;
@ -65,7 +66,6 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
this.indexFieldData = indexFieldData; this.indexFieldData = indexFieldData;
this.size = size; this.size = size;
this.comparatorType = comparatorType; this.comparatorType = comparatorType;
this.numberOfShards = context.numberOfShards();
this.ordinalsCacheAbove = ordinalsCacheAbove; this.ordinalsCacheAbove = ordinalsCacheAbove;
if (excluded == null || excluded.isEmpty()) { if (excluded == null || excluded.isEmpty()) {
@ -92,8 +92,8 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
@Override @Override
public InternalFacet buildFacet(String facetName) { public InternalFacet buildFacet(String facetName) {
final CharsRef spare = new CharsRef();
AggregatorPriorityQueue queue = new AggregatorPriorityQueue(aggregators.size()); AggregatorPriorityQueue queue = new AggregatorPriorityQueue(aggregators.size());
for (ReaderAggregator aggregator : aggregators) { for (ReaderAggregator aggregator : aggregators) {
if (aggregator.nextPosition()) { if (aggregator.nextPosition()) {
queue.add(aggregator); queue.add(aggregator);
@ -124,10 +124,13 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
if (excluded != null && excluded.contains(value)) { if (excluded != null && excluded.contains(value)) {
continue; continue;
} }
// LUCENE 4 UPGRADE: use Lucene's RegexCapabilities if (matcher != null) {
if (matcher != null && !matcher.reset(value.utf8ToString()).matches()) { UnicodeUtil.UTF8toUTF16(value, spare);
assert spare.toString().equals(value.utf8ToString());
if (!matcher.reset(spare).matches()) {
continue; continue;
} }
}
InternalStringTermsFacet.TermEntry entry = new InternalStringTermsFacet.TermEntry(value, count); InternalStringTermsFacet.TermEntry entry = new InternalStringTermsFacet.TermEntry(value, count);
ordered.insertWithOverflow(entry); ordered.insertWithOverflow(entry);
} }
@ -167,10 +170,13 @@ public class TermsStringOrdinalsFacetExecutor extends FacetExecutor {
if (excluded != null && excluded.contains(value)) { if (excluded != null && excluded.contains(value)) {
continue; continue;
} }
// LUCENE 4 UPGRADE: use Lucene's RegexCapabilities if (matcher != null) {
if (matcher != null && !matcher.reset(value.utf8ToString()).matches()) { UnicodeUtil.UTF8toUTF16(value, spare);
assert spare.toString().equals(value.utf8ToString());
if (!matcher.reset(spare).matches()) {
continue; continue;
} }
}
InternalStringTermsFacet.TermEntry entry = new InternalStringTermsFacet.TermEntry(value, count); InternalStringTermsFacet.TermEntry entry = new InternalStringTermsFacet.TermEntry(value, count);
ordered.add(entry); ordered.add(entry);
} }