use custom similarity in search (if there is one)
This commit is contained in:
parent
a7fdd36f6e
commit
296b6b2f57
|
@ -0,0 +1,69 @@
|
|||
/*
|
||||
* Licensed to Elastic Search and Shay Banon under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. Elastic Search licenses this
|
||||
* file to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
|
||||
package org.elasticsearch.common.lucene.search;
|
||||
|
||||
import org.apache.lucene.index.IndexReader;
|
||||
import org.apache.lucene.search.IndexSearcher;
|
||||
|
||||
/**
|
||||
* @author kimchy (shay.banon)
|
||||
*/
|
||||
public class ExtendedIndexSearcher extends IndexSearcher {
|
||||
|
||||
public ExtendedIndexSearcher(IndexSearcher searcher) {
|
||||
super(searcher.getIndexReader());
|
||||
setSimilarity(searcher.getSimilarity());
|
||||
}
|
||||
|
||||
public ExtendedIndexSearcher(IndexReader r) {
|
||||
super(r);
|
||||
}
|
||||
|
||||
public IndexReader[] subReaders() {
|
||||
return this.subReaders;
|
||||
}
|
||||
|
||||
public int[] docStarts() {
|
||||
return this.docStarts;
|
||||
}
|
||||
|
||||
// taken from DirectoryReader#readerIndex
|
||||
|
||||
public int readerIndex(int doc) {
|
||||
int lo = 0; // search starts array
|
||||
int hi = subReaders.length - 1; // for first element less
|
||||
|
||||
while (hi >= lo) {
|
||||
int mid = (lo + hi) >>> 1;
|
||||
int midValue = docStarts[mid];
|
||||
if (doc < midValue)
|
||||
hi = mid - 1;
|
||||
else if (doc > midValue)
|
||||
lo = mid + 1;
|
||||
else { // found a match
|
||||
while (mid + 1 < subReaders.length && docStarts[mid + 1] == midValue) {
|
||||
mid++; // scan to last match
|
||||
}
|
||||
return mid;
|
||||
}
|
||||
}
|
||||
return hi;
|
||||
}
|
||||
}
|
|
@ -19,10 +19,11 @@
|
|||
|
||||
package org.elasticsearch.search.internal;
|
||||
|
||||
import org.apache.lucene.index.IndexReader;
|
||||
import org.apache.lucene.search.*;
|
||||
import org.elasticsearch.common.collect.Lists;
|
||||
import org.elasticsearch.common.lucene.MultiCollector;
|
||||
import org.elasticsearch.common.lucene.search.ExtendedIndexSearcher;
|
||||
import org.elasticsearch.index.engine.Engine;
|
||||
import org.elasticsearch.search.dfs.CachedDfSource;
|
||||
|
||||
import java.io.IOException;
|
||||
|
@ -31,7 +32,7 @@ import java.util.List;
|
|||
/**
|
||||
* @author kimchy (shay.banon)
|
||||
*/
|
||||
public class ContextIndexSearcher extends IndexSearcher {
|
||||
public class ContextIndexSearcher extends ExtendedIndexSearcher {
|
||||
|
||||
private SearchContext searchContext;
|
||||
|
||||
|
@ -43,42 +44,11 @@ public class ContextIndexSearcher extends IndexSearcher {
|
|||
|
||||
private boolean useGlobalCollectors = false;
|
||||
|
||||
public ContextIndexSearcher(SearchContext searchContext, IndexReader r) {
|
||||
super(r);
|
||||
public ContextIndexSearcher(SearchContext searchContext, Engine.Searcher searcher) {
|
||||
super(searcher.searcher());
|
||||
this.searchContext = searchContext;
|
||||
}
|
||||
|
||||
public IndexReader[] subReaders() {
|
||||
return this.subReaders;
|
||||
}
|
||||
|
||||
public int[] docStarts() {
|
||||
return this.docStarts;
|
||||
}
|
||||
|
||||
// taken from DirectoryReader#readerIndex
|
||||
|
||||
public int readerIndex(int doc) {
|
||||
int lo = 0; // search starts array
|
||||
int hi = subReaders.length - 1; // for first element less
|
||||
|
||||
while (hi >= lo) {
|
||||
int mid = (lo + hi) >>> 1;
|
||||
int midValue = docStarts[mid];
|
||||
if (doc < midValue)
|
||||
hi = mid - 1;
|
||||
else if (doc > midValue)
|
||||
lo = mid + 1;
|
||||
else { // found a match
|
||||
while (mid + 1 < subReaders.length && docStarts[mid + 1] == midValue) {
|
||||
mid++; // scan to last match
|
||||
}
|
||||
return mid;
|
||||
}
|
||||
}
|
||||
return hi;
|
||||
}
|
||||
|
||||
public void dfSource(CachedDfSource dfSource) {
|
||||
this.dfSource = dfSource;
|
||||
}
|
||||
|
|
|
@ -129,7 +129,7 @@ public class SearchContext implements Releasable {
|
|||
this.fetchResult = new FetchSearchResult(id, shardTarget);
|
||||
this.indexService = indexService;
|
||||
|
||||
this.searcher = new ContextIndexSearcher(this, engineSearcher.reader());
|
||||
this.searcher = new ContextIndexSearcher(this, engineSearcher);
|
||||
}
|
||||
|
||||
@Override public boolean release() throws ElasticSearchException {
|
||||
|
|
Loading…
Reference in New Issue