public class CompletionWeight extends Weight
setNextMatch(IntsRef)
,
boost()
and context()
to calculate the boost and extract the context of
a matched path prefix.Weight.DefaultBulkScorer
parentQuery
Constructor and Description |
---|
CompletionWeight(CompletionQuery query,
Automaton automaton)
Creates a weight for
query with an automaton ,
using the reader for index stats |
Modifier and Type | Method and Description |
---|---|
protected float |
boost()
Returns the boost of the partial path set by
setNextMatch(IntsRef) |
BulkScorer |
bulkScorer(LeafReaderContext context)
Optional method, to return a
BulkScorer to
score the query and send hits to a Collector . |
protected java.lang.CharSequence |
context()
Returns the context of the partial path set by
setNextMatch(IntsRef) |
Explanation |
explain(LeafReaderContext context,
int doc)
An explanation of the score computation for the named document.
|
void |
extractTerms(java.util.Set<Term> terms)
Expert: adds all terms occurring in this query to the terms set.
|
Automaton |
getAutomaton()
Returns the automaton specified
by the
CompletionQuery |
boolean |
isCacheable(LeafReaderContext ctx)
This object can be cached
|
Scorer |
scorer(LeafReaderContext context)
Returns a
Scorer which can iterate in order over all matching
documents and assign them a score. |
protected void |
setNextMatch(IntsRef pathPrefix)
Set for every partial path in the index that matched the query
automaton.
|
getQuery, matches, scorerSupplier
public CompletionWeight(CompletionQuery query, Automaton automaton) throws java.io.IOException
query
with an automaton
,
using the reader
for index statsjava.io.IOException
public Automaton getAutomaton()
CompletionQuery
public BulkScorer bulkScorer(LeafReaderContext context) throws java.io.IOException
Weight
BulkScorer
to
score the query and send hits to a Collector
.
Only queries that have a different top-level approach
need to override this; the default implementation
pulls a normal Scorer
and iterates and
collects the resulting hits which are not marked as deleted.bulkScorer
in class Weight
context
- the LeafReaderContext
for which to return the Scorer
.BulkScorer
which scores documents and
passes them to a collector.java.io.IOException
- if there is a low-level I/O errorprotected void setNextMatch(IntsRef pathPrefix)
boost()
and context()
to return an appropriate value with respect to the current pathPrefix.pathPrefix
- the prefix of a matched pathprotected float boost()
setNextMatch(IntsRef)
protected java.lang.CharSequence context()
setNextMatch(IntsRef)
public Scorer scorer(LeafReaderContext context) throws java.io.IOException
Weight
Scorer
which can iterate in order over all matching
documents and assign them a score.
NOTE: null can be returned if no documents will be scored by this query.
NOTE: The returned Scorer
does not have
LeafReader.getLiveDocs()
applied, they need to be checked on top.
scorer
in class Weight
context
- the LeafReaderContext
for which to return the Scorer
.Scorer
which scores documents in/out-of order.java.io.IOException
- if there is a low-level I/O errorpublic boolean isCacheable(LeafReaderContext ctx)
true
if the object can be cached against a given leafSegmentCacheable.isCacheable(LeafReaderContext)
public void extractTerms(java.util.Set<Term> terms)
Weight
Weight
was created with needsScores == true
then this
method will only extract terms which are used for scoring, otherwise it
will extract all terms which are used for matching.extractTerms
in class Weight
public Explanation explain(LeafReaderContext context, int doc) throws java.io.IOException
Weight
explain
in class Weight
context
- the readers context to create the Explanation
for.doc
- the document's id relative to the given context's readerjava.io.IOException
- if an IOException
occursCopyright © 2000–2019 The Apache Software Foundation. All rights reserved.