Package org.apache.lucene.search.spans
Class NearSpansOrdered
java.lang.Object
org.apache.lucene.search.spans.Spans
org.apache.lucene.search.spans.NearSpansOrdered
A Spans that is formed from the ordered subspans of a SpanNearQuery
 where the subspans do not overlap and have a maximum slop between them.
 
 The formed spans only contains minimum slop matches.
 The matching slop is computed from the distance(s) between
 the non overlapping matching Spans.
 Successive matches are always formed from the successive Spans
 of the SpanNearQuery.
 
The formed spans may contain overlaps when the slop is at least 1. For example, when querying using
t1 t2 t3with slop at least 1, the fragment:
t1 t2 t1 t3 t2 t3matches twice:
t1 t2 .. t3
t1 .. t2 t3Expert: Only public for subclassing. Most implementations should not need this class
- 
Constructor SummaryConstructorsConstructorDescriptionNearSpansOrdered(SpanNearQuery spanNearQuery, AtomicReaderContext context, Bits acceptDocs, Map<Term, TermContext> termContexts) NearSpansOrdered(SpanNearQuery spanNearQuery, AtomicReaderContext context, Bits acceptDocs, Map<Term, TermContext> termContexts, boolean collectPayloads) 
- 
Method SummaryModifier and TypeMethodDescriptionlongcost()Returns the estimated cost of this spans.intdoc()Returns the document number of the current match.intend()Returns the end position of the current match.Collection<byte[]>Returns the payload data for the current span.Spans[]booleanChecks if a payload can be loaded at this position.booleannext()Move to the next match, returning true iff any such exists.booleanskipTo(int target) Skips to the first match beyond the current, whose document number is greater than or equal to target.intstart()Returns the start position of the current match.toString()
- 
Constructor Details- 
NearSpansOrderedpublic NearSpansOrdered(SpanNearQuery spanNearQuery, AtomicReaderContext context, Bits acceptDocs, Map<Term, TermContext> termContexts) throws IOException- Throws:
- IOException
 
- 
NearSpansOrderedpublic NearSpansOrdered(SpanNearQuery spanNearQuery, AtomicReaderContext context, Bits acceptDocs, Map<Term, TermContext> termContexts, boolean collectPayloads) throws IOException- Throws:
- IOException
 
 
- 
- 
Method Details- 
docpublic int doc()Description copied from class:SpansReturns the document number of the current match. Initially invalid.
- 
startpublic int start()Description copied from class:SpansReturns the start position of the current match. Initially invalid.
- 
endpublic int end()Description copied from class:SpansReturns the end position of the current match. Initially invalid.
- 
getSubSpans
- 
getPayloadDescription copied from class:SpansReturns the payload data for the current span. This is invalid untilSpans.next()is called for the first time. This method must not be called more than once after each call ofSpans.next(). However, most payloads are loaded lazily, so if the payload data for the current position is not needed, this method may not be called at all for performance reasons. An ordered SpanQuery does not lazy load, so if you have payloads in your index and you do not want ordered SpanNearQuerys to collect payloads, you can disable collection with a constructor option.
 
 Note that the return type is a collection, thus the ordering should not be relied upon.- Specified by:
- getPayloadin class- Spans
- Returns:
- a List of byte arrays containing the data of this payload, otherwise null if isPayloadAvailable is false
- Throws:
- IOException- if there is a low-level I/O error
 
- 
isPayloadAvailablepublic boolean isPayloadAvailable()Description copied from class:SpansChecks if a payload can be loaded at this position. Payloads can only be loaded once per call toSpans.next().- Specified by:
- isPayloadAvailablein class- Spans
- Returns:
- true if there is a payload available at this position that can be loaded
 
- 
costpublic long cost()Description copied from class:SpansReturns the estimated cost of this spans.This is generally an upper bound of the number of documents this iterator might match, but may be a rough heuristic, hardcoded value, or otherwise completely inaccurate. 
- 
nextDescription copied from class:SpansMove to the next match, returning true iff any such exists.- Specified by:
- nextin class- Spans
- Throws:
- IOException
 
- 
skipToDescription copied from class:SpansSkips to the first match beyond the current, whose document number is greater than or equal to target.The behavior of this method is undefined when called with target ≤ current, or after the iterator has exhausted. Both cases may result in unpredicted behavior.Returns true iff there is such a match. Behaves as if written: boolean skipTo(int target) { do { if (!next()) return false; } while (target > doc()); return true; }Most implementations are considerably more efficient than that.- Specified by:
- skipToin class- Spans
- Throws:
- IOException
 
- 
toString
 
-