summaryrefslogtreecommitdiff
path: root/core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java
diff options
context:
space:
mode:
Diffstat (limited to 'core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java')
-rw-r--r--core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java21
1 files changed, 14 insertions, 7 deletions
diff --git a/core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java b/core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java
index ee824ee13c..eb17daec5f 100644
--- a/core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java
+++ b/core/src/main/java/org/elasticsearch/search/highlight/vectorhighlight/FragmentBuilderHelper.java
@@ -27,7 +27,14 @@ import org.apache.lucene.search.vectorhighlight.FieldFragList.WeightedFragInfo.S
import org.apache.lucene.search.vectorhighlight.FragmentsBuilder;
import org.apache.lucene.util.CollectionUtil;
import org.apache.lucene.util.Version;
-import org.elasticsearch.index.analysis.*;
+import org.elasticsearch.index.analysis.CustomAnalyzer;
+import org.elasticsearch.index.analysis.EdgeNGramTokenFilterFactory;
+import org.elasticsearch.index.analysis.EdgeNGramTokenizerFactory;
+import org.elasticsearch.index.analysis.NGramTokenFilterFactory;
+import org.elasticsearch.index.analysis.NGramTokenizerFactory;
+import org.elasticsearch.index.analysis.NamedAnalyzer;
+import org.elasticsearch.index.analysis.TokenFilterFactory;
+import org.elasticsearch.index.analysis.WordDelimiterTokenFilterFactory;
import org.elasticsearch.index.mapper.FieldMapper;
import java.util.Comparator;
@@ -41,7 +48,7 @@ public final class FragmentBuilderHelper {
private FragmentBuilderHelper() {
// no instance
}
-
+
/**
* Fixes problems with broken analysis chains if positions and offsets are messed up that can lead to
* {@link StringIndexOutOfBoundsException} in the {@link FastVectorHighlighter}
@@ -70,7 +77,7 @@ public final class FragmentBuilderHelper {
return fragInfo;
}
}
-
+
private static int compare(int x, int y) {
return (x < y) ? -1 : ((x == y) ? 0 : 1);
}
@@ -82,19 +89,19 @@ public final class FragmentBuilderHelper {
}
if (analyzer instanceof CustomAnalyzer) {
final CustomAnalyzer a = (CustomAnalyzer) analyzer;
- if (a.tokenizerFactory() instanceof EdgeNGramTokenizerFactory
- || (a.tokenizerFactory() instanceof NGramTokenizerFactory
+ if (a.tokenizerFactory() instanceof EdgeNGramTokenizerFactory
+ || (a.tokenizerFactory() instanceof NGramTokenizerFactory
&& !((NGramTokenizerFactory)a.tokenizerFactory()).version().onOrAfter(Version.LUCENE_4_2))) {
// ngram tokenizer is broken before 4.2
return true;
}
TokenFilterFactory[] tokenFilters = a.tokenFilters();
for (TokenFilterFactory tokenFilterFactory : tokenFilters) {
- if (tokenFilterFactory instanceof WordDelimiterTokenFilterFactory
+ if (tokenFilterFactory instanceof WordDelimiterTokenFilterFactory
|| tokenFilterFactory instanceof EdgeNGramTokenFilterFactory) {
return true;
}
- if (tokenFilterFactory instanceof NGramTokenFilterFactory
+ if (tokenFilterFactory instanceof NGramTokenFilterFactory
&& !((NGramTokenFilterFactory)tokenFilterFactory).version().onOrAfter(Version.LUCENE_4_2)) {
// ngram token filter is broken before 4.2
return true;