Package org.apache.lucene.search.suggest
Class SortedInputIterator
java.lang.Object
org.apache.lucene.search.suggest.SortedInputIterator
- All Implemented Interfaces:
- InputIterator,- BytesRefIterator
This wrapper buffers incoming elements and makes sure they are sorted based on given comparator.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.apache.lucene.search.suggest.InputIteratorInputIterator.InputIteratorWrapper
- 
Field SummaryFields inherited from interface org.apache.lucene.search.suggest.InputIteratorEMPTY
- 
Constructor SummaryConstructorsConstructorDescriptionSortedInputIterator(Directory tempDir, String tempFileNamePrefix, InputIterator source) Creates a new sorted wrapper, using natural order for sorting.SortedInputIterator(Directory tempDir, String tempFileNamePrefix, InputIterator source, Comparator<BytesRef> comparator) Creates a new sorted wrapper, sorting by BytesRef (ascending) then cost (ascending).
- 
Method SummaryModifier and TypeMethodDescriptioncontexts()A term's contexts context can be used to filter suggestions.protected longdecode(BytesRef scratch, ByteArrayDataInput tmpInput) decodes the weight at the current positiondecodeContexts(BytesRef scratch, ByteArrayDataInput tmpInput) decodes the contexts at the current positionprotected BytesRefdecodePayload(BytesRef scratch, ByteArrayDataInput tmpInput) decodes the payload at the current positionprotected voidencode(OfflineSorter.ByteSequencesWriter writer, ByteArrayDataOutput output, byte[] buffer, BytesRef spare, BytesRef payload, Set<BytesRef> contexts, long weight) encodes an entry (bytes+(contexts)+(payload)+weight) to the provided writerbooleanReturns true if the iterator has contextsbooleanReturns true if the iterator has payloadsnext()payload()An arbitrary byte[] to record per suggestion.longweight()A term's weight, higher numbers mean better suggestions.
- 
Constructor Details- 
SortedInputIteratorpublic SortedInputIterator(Directory tempDir, String tempFileNamePrefix, InputIterator source) throws IOException Creates a new sorted wrapper, using natural order for sorting.- Throws:
- IOException
 
- 
SortedInputIteratorpublic SortedInputIterator(Directory tempDir, String tempFileNamePrefix, InputIterator source, Comparator<BytesRef> comparator) throws IOException Creates a new sorted wrapper, sorting by BytesRef (ascending) then cost (ascending).- Throws:
- IOException
 
 
- 
- 
Method Details- 
next- Specified by:
- nextin interface- BytesRefIterator
- Throws:
- IOException
 
- 
weightpublic long weight()Description copied from interface:InputIteratorA term's weight, higher numbers mean better suggestions.- Specified by:
- weightin interface- InputIterator
 
- 
payloadDescription copied from interface:InputIteratorAn arbitrary byte[] to record per suggestion. SeeLookup.LookupResult.payloadto retrieve the payload for each suggestion.- Specified by:
- payloadin interface- InputIterator
 
- 
hasPayloadspublic boolean hasPayloads()Description copied from interface:InputIteratorReturns true if the iterator has payloads- Specified by:
- hasPayloadsin interface- InputIterator
 
- 
contextsDescription copied from interface:InputIteratorA term's contexts context can be used to filter suggestions. May return null, if suggest entries do not have any context- Specified by:
- contextsin interface- InputIterator
 
- 
hasContextspublic boolean hasContexts()Description copied from interface:InputIteratorReturns true if the iterator has contexts- Specified by:
- hasContextsin interface- InputIterator
 
- 
encodeprotected void encode(OfflineSorter.ByteSequencesWriter writer, ByteArrayDataOutput output, byte[] buffer, BytesRef spare, BytesRef payload, Set<BytesRef> contexts, long weight) throws IOException encodes an entry (bytes+(contexts)+(payload)+weight) to the provided writer- Throws:
- IOException
 
- 
decodedecodes the weight at the current position
- 
decodeContextsdecodes the contexts at the current position
- 
decodePayloaddecodes the payload at the current position
 
-