public class FilterIndexReader extends IndexReader
FilterIndexReader contains another IndexReader, which it
uses as its basic source of data, possibly transforming the data along the
way or providing additional functionality. The class
FilterIndexReader itself simply implements all abstract methods
of IndexReader with versions that pass all requests to the
contained index reader. Subclasses of FilterIndexReader may
further override some of these methods and may also provide additional
methods and fields.
Note: The default implementation of IndexReader.doOpenIfChanged()
throws UnsupportedOperationException (like the base class),
so it's not possible to reopen a FilterIndexReader.
To reopen, you have to first reopen the underlying reader
and wrap it again with the custom filter.
| Modifier and Type | Class and Description |
|---|---|
static class |
FilterIndexReader.FilterTermDocs
Base class for filtering
TermDocs implementations. |
static class |
FilterIndexReader.FilterTermEnum
Base class for filtering
TermEnum implementations. |
static class |
FilterIndexReader.FilterTermPositions
Base class for filtering
TermPositions implementations. |
IndexReader.ReaderClosedListener| Modifier and Type | Field and Description |
|---|---|
protected IndexReader |
in |
hasChanges| Constructor and Description |
|---|
FilterIndexReader(IndexReader in)
Construct a FilterIndexReader based on the specified base reader.
|
| Modifier and Type | Method and Description |
|---|---|
Directory |
directory()
Returns the directory associated with this index.
|
int |
docFreq(Term t)
Returns the number of documents containing the term
t. |
protected void |
doClose()
Implements close.
|
protected void |
doCommit(Map<String,String> commitUserData)
Deprecated.
|
Document |
document(int n,
FieldSelector fieldSelector)
Get the
Document at the n
th position. |
protected void |
doDelete(int n)
Deprecated.
|
protected void |
doSetNorm(int d,
String f,
byte b)
Deprecated.
|
protected void |
doUndeleteAll()
Deprecated.
|
Map<String,String> |
getCommitUserData()
Retrieve the String userData optionally passed to
IndexWriter#commit.
|
Object |
getCoreCacheKey()
If the subclass of FilteredIndexReader modifies the
contents of the FieldCache, you must override this
method to provide a different key
|
Object |
getDeletesCacheKey()
If the subclass of FilteredIndexReader modifies the
deleted docs, you must override this method to provide
a different key
|
FieldInfos |
getFieldInfos()
Get the
FieldInfos describing all fields in
this reader. |
IndexCommit |
getIndexCommit()
Expert: return the IndexCommit that this reader has
opened.
|
IndexReader[] |
getSequentialSubReaders()
Expert: returns the sequential sub readers that this
reader is logically composed of.
|
TermFreqVector |
getTermFreqVector(int docNumber,
String field)
Return a term frequency vector for the specified document and field.
|
void |
getTermFreqVector(int docNumber,
String field,
TermVectorMapper mapper)
Load the Term Vector into a user-defined data structure instead of relying on the parallel arrays of
the
TermFreqVector. |
void |
getTermFreqVector(int docNumber,
TermVectorMapper mapper)
Map all the term vectors for all fields in a Document
|
TermFreqVector[] |
getTermFreqVectors(int docNumber)
Return an array of term frequency vectors for the specified document.
|
int |
getTermInfosIndexDivisor()
For IndexReader implementations that use
TermInfosReader to read terms, this returns the
current indexDivisor as specified when the reader was
opened.
|
long |
getUniqueTermCount()
Returns the number of unique terms (across all fields)
in this reader.
|
long |
getVersion()
Version number when this IndexReader was opened.
|
boolean |
hasDeletions()
Returns true if any documents have been deleted
|
boolean |
hasNorms(String field)
Returns true if there are norms stored for this field.
|
boolean |
isCurrent()
Check whether any new changes have occurred to the
index since this reader was opened.
|
boolean |
isDeleted(int n)
Returns true if document n has been deleted
|
boolean |
isOptimized()
Deprecated.
|
int |
maxDoc()
Returns one greater than the largest possible document number.
|
byte[] |
norms(String f)
Returns the byte-encoded normalization factor for the named field of
every document.
|
void |
norms(String f,
byte[] bytes,
int offset)
Reads the byte-encoded normalization factor for the named field of every
document.
|
int |
numDocs()
Returns the number of documents in this index.
|
TermDocs |
termDocs()
Returns an unpositioned
TermDocs enumerator. |
TermDocs |
termDocs(Term term)
Returns an enumeration of all the documents which contain
term. |
TermPositions |
termPositions()
Returns an unpositioned
TermPositions enumerator. |
TermEnum |
terms()
Returns an enumeration of all the terms in the index.
|
TermEnum |
terms(Term t)
Returns an enumeration of all terms starting at a given term.
|
String |
toString() |
acquireWriteLock, addReaderClosedListener, clone, clone, close, commit, commit, decRef, deleteDocument, deleteDocuments, document, doOpenIfChanged, doOpenIfChanged, doOpenIfChanged, doOpenIfChanged, ensureOpen, flush, flush, getCommitUserData, getCurrentVersion, getRefCount, incRef, indexExists, lastModified, listCommits, numDeletedDocs, open, open, open, open, open, open, open, open, open, open, open, openIfChanged, openIfChanged, openIfChanged, openIfChanged, removeReaderClosedListener, reopen, reopen, reopen, reopen, setNorm, setNorm, termPositions, tryIncRef, undeleteAllprotected IndexReader in
public FilterIndexReader(IndexReader in)
Construct a FilterIndexReader based on the specified base reader. Directory locking for delete, undeleteAll, and setNorm operations is left to the base reader.
Note that base reader is closed if this FilterIndexReader is closed.
in - specified base reader.public Directory directory()
IndexReaderdirectory in class IndexReaderpublic IndexCommit getIndexCommit() throws IOException
IndexReadergetIndexCommit in class IndexReaderIOExceptionpublic FieldInfos getFieldInfos()
IndexReaderFieldInfos describing all fields in
this reader. NOTE: do not make any changes to the
returned FieldInfos!getFieldInfos in class IndexReaderpublic int getTermInfosIndexDivisor()
IndexReadergetTermInfosIndexDivisor in class IndexReaderpublic TermFreqVector[] getTermFreqVectors(int docNumber) throws IOException
IndexReaderTermFreqVector
or of type TermPositionVector if
positions or offsets have been stored.getTermFreqVectors in class IndexReaderdocNumber - document for which term frequency vectors are returnedIOException - if index cannot be accessedField.TermVectorpublic TermFreqVector getTermFreqVector(int docNumber, String field) throws IOException
IndexReaderTermPositionVector is returned.getTermFreqVector in class IndexReaderdocNumber - document for which the term frequency vector is returnedfield - field for which the term frequency vector is returned.IOException - if index cannot be accessedField.TermVectorpublic void getTermFreqVector(int docNumber,
String field,
TermVectorMapper mapper)
throws IOException
IndexReaderTermFreqVector.getTermFreqVector in class IndexReaderdocNumber - The number of the document to load the vector forfield - The name of the field to loadmapper - The TermVectorMapper to process the vector. Must not be nullIOException - if term vectors cannot be accessed or if they do not exist on the field and doc. specified.public void getTermFreqVector(int docNumber,
TermVectorMapper mapper)
throws IOException
IndexReadergetTermFreqVector in class IndexReaderdocNumber - The number of the document to load the vector formapper - The TermVectorMapper to process the vector. Must not be nullIOException - if term vectors cannot be accessed or if they do not exist on the field and doc. specified.public long getUniqueTermCount()
throws IOException
IndexReadergetUniqueTermCount in class IndexReaderIOExceptionpublic int numDocs()
IndexReadernumDocs in class IndexReaderpublic int maxDoc()
IndexReadermaxDoc in class IndexReaderpublic Document document(int n, FieldSelector fieldSelector) throws CorruptIndexException, IOException
IndexReaderDocument at the n
th position. The FieldSelector may be used to determine
what Fields to load and how they should
be loaded. NOTE: If this Reader (more specifically, the underlying
FieldsReader) is closed before the lazy
Field is loaded an exception may be
thrown. If you want the value of a lazy
Field to be available after closing you
must explicitly load it or fetch the Document again with a new loader.
NOTE: for performance reasons, this method does not check if the
requested document is deleted, and therefore asking for a deleted document
may yield unspecified results. Usually this is not required, however you
can call IndexReader.isDeleted(int) with the requested document ID to verify
the document is not deleted.
document in class IndexReadern - Get the document at the nth positionfieldSelector - The FieldSelector to use to determine what
Fields should be loaded on the Document. May be null, in which case
all Fields will be loaded.Document at the nth positionCorruptIndexException - if the index is corruptIOException - if there is a low-level IO errorFieldable,
FieldSelector,
SetBasedFieldSelector,
LoadFirstFieldSelectorpublic boolean isDeleted(int n)
IndexReaderisDeleted in class IndexReaderpublic boolean hasDeletions()
IndexReaderhasDeletions in class IndexReader@Deprecated protected void doUndeleteAll() throws CorruptIndexException, IOException
doUndeleteAll in class IndexReaderCorruptIndexExceptionIOExceptionpublic boolean hasNorms(String field) throws IOException
IndexReaderhasNorms in class IndexReaderIOExceptionpublic byte[] norms(String f) throws IOException
IndexReadernorms in class IndexReaderIOExceptionAbstractField.setBoost(float)public void norms(String f, byte[] bytes, int offset) throws IOException
IndexReadernorms in class IndexReaderIOExceptionAbstractField.setBoost(float)@Deprecated protected void doSetNorm(int d, String f, byte b) throws CorruptIndexException, IOException
doSetNorm in class IndexReaderCorruptIndexExceptionIOExceptionpublic TermEnum terms() throws IOException
IndexReaderTermEnum.next() must be called
on the resulting enumeration before calling other methods such as
TermEnum.term().terms in class IndexReaderIOException - if there is a low-level IO errorpublic TermEnum terms(Term t) throws IOException
IndexReaderterms in class IndexReaderIOException - if there is a low-level IO errorpublic int docFreq(Term t) throws IOException
IndexReadert.docFreq in class IndexReaderIOException - if there is a low-level IO errorpublic TermDocs termDocs() throws IOException
IndexReaderTermDocs enumerator.
Note: the TermDocs returned is unpositioned. Before using it, ensure
that you first position it with TermDocs.seek(Term) or
TermDocs.seek(TermEnum).
termDocs in class IndexReaderIOException - if there is a low-level IO errorpublic TermDocs termDocs(Term term) throws IOException
IndexReaderterm. For each document, the document number, the frequency of
the term in that document is also provided, for use in
search scoring. If term is null, then all non-deleted
docs are returned with freq=1.
Thus, this method implements the mapping:
The enumeration is ordered by document number. Each document number is greater than all that precede it in the enumeration.
termDocs in class IndexReaderIOException - if there is a low-level IO errorpublic TermPositions termPositions() throws IOException
IndexReaderTermPositions enumerator.termPositions in class IndexReaderIOException - if there is a low-level IO error@Deprecated protected void doDelete(int n) throws CorruptIndexException, IOException
docNum.
Applications should call IndexReader.deleteDocument(int) or IndexReader.deleteDocuments(Term).doDelete in class IndexReaderCorruptIndexExceptionIOException@Deprecated protected void doCommit(Map<String,String> commitUserData) throws IOException
doCommit in class IndexReaderIOExceptionprotected void doClose()
throws IOException
IndexReaderdoClose in class IndexReaderIOExceptionpublic long getVersion()
IndexReaderIf this reader is based on a Directory (ie, was
created by calling IndexReader.open(org.apache.lucene.store.Directory), or IndexReader.openIfChanged(org.apache.lucene.index.IndexReader) on
a reader based on a Directory), then this method
returns the version recorded in the commit that the
reader opened. This version is advanced every time
IndexWriter.commit() is called.
getVersion in class IndexReaderpublic boolean isCurrent()
throws CorruptIndexException,
IOException
IndexReaderIf this reader is based on a Directory (ie, was
created by calling IndexReader.open(org.apache.lucene.store.Directory), or IndexReader.openIfChanged(org.apache.lucene.index.IndexReader) on
a reader based on a Directory), then this method checks
if any further commits (see IndexWriter.commit()
have occurred in that directory).
If instead this reader is a near real-time reader
(ie, obtained by a call to IndexWriter.getReader(), or by calling IndexReader.openIfChanged(org.apache.lucene.index.IndexReader)
on a near real-time reader), then this method checks if
either a new commmit has occurred, or any new
uncommitted changes have taken place via the writer.
Note that even if the writer has only performed
merging, this method will still return false.
In any event, if this returns false, you should call
IndexReader.openIfChanged(org.apache.lucene.index.IndexReader) to get a new reader that sees the
changes.
isCurrent in class IndexReaderCorruptIndexException - if the index is corruptIOException - if there is a low-level IO error@Deprecated public boolean isOptimized()
isOptimized in class IndexReaderpublic IndexReader[] getSequentialSubReaders()
IndexReader
NOTE: You should not try using sub-readers returned by
this method to make any changes (setNorm, deleteDocument,
etc.). While this might succeed for one composite reader
(like MultiReader), it will most likely lead to index
corruption for other readers (like DirectoryReader obtained
through IndexReader.open(org.apache.lucene.store.Directory). Use the parent reader directly.
getSequentialSubReaders in class IndexReaderpublic Map<String,String> getCommitUserData()
IndexReaderIndexWriter.commit(Map) has never been called for
this index.getCommitUserData in class IndexReaderpublic Object getCoreCacheKey()
getCoreCacheKey in class IndexReaderpublic Object getDeletesCacheKey()
getDeletesCacheKey in class IndexReaderpublic String toString()
toString in class IndexReader