public class

FilterIndexReader

extends IndexReader
java.lang.Object
   ↳ org.apache.lucene.index.IndexReader
     ↳ org.apache.lucene.index.FilterIndexReader
Known Direct Subclasses

Class Overview

A 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.

Summary

Nested Classes
class FilterIndexReader.FilterTermDocs Base class for filtering TermDocs implementations. 
class FilterIndexReader.FilterTermEnum Base class for filtering TermEnum implementations. 
class FilterIndexReader.FilterTermPositions Base class for filtering TermPositions implementations. 
Fields
protected IndexReader in
[Expand]
Inherited Fields
From class org.apache.lucene.index.IndexReader
Public Constructors
FilterIndexReader(IndexReader in)

Construct a FilterIndexReader based on the specified base reader.

Public Methods
void addReaderFinishedListener(IndexReader.ReaderFinishedListener listener)
Directory directory()
Returns the directory associated with this index.
int docFreq(Term t)
Returns the number of documents containing the term t.
Document document(int n, FieldSelector fieldSelector)
Get the Document at the n th position.
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
Collection<String> getFieldNames(IndexReader.FieldOption fieldNames)
Get a list of unique field names that exist in this index and have the specified field option information.
IndexReader[] getSequentialSubReaders()
Expert: returns the sequential sub readers that this reader is logically composed of.
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 getTermFreqVector(int docNumber, String field)
Return a term frequency vector for the specified document and field.
TermFreqVector[] getTermFreqVectors(int docNumber)
Return an array of term frequency vectors for the specified document.
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()
Checks is the index is optimized (if it has a single segment and no deletions).
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.
void removeReaderFinishedListener(IndexReader.ReaderFinishedListener listener)
Expert: remove a previously added IndexReader.ReaderFinishedListener.
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(Term t)
Returns an enumeration of all terms starting at a given term.
TermEnum terms()
Returns an enumeration of all the terms in the index.
String toString()
Protected Methods
void doClose()
Implements close.
void doCommit(Map<StringString> commitUserData)
Implements commit.
void doDelete(int n)
Implements deletion of the document numbered docNum.
void doSetNorm(int d, String f, byte b)
Implements setNorm in subclass.
void doUndeleteAll()
Implements actual undeleteAll() in subclass.
[Expand]
Inherited Methods
From class org.apache.lucene.index.IndexReader
From class java.lang.Object
From interface java.io.Closeable

Fields

protected IndexReader in

Public Constructors

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.

Parameters
in specified base reader.

Public Methods

public void addReaderFinishedListener (IndexReader.ReaderFinishedListener listener)

Expert: adds a IndexReader.ReaderFinishedListener. The provided listener is also added to any sub-readers, if this is a composite reader. Also, any reader reopened or cloned from this one will also copy the listeners at the time of reopen.

public Directory directory ()

Returns the directory associated with this index. The Default implementation returns the directory specified by subclasses when delegating to the IndexReader(Directory) constructor, or throws an UnsupportedOperationException if one was not specified.

public int docFreq (Term t)

Returns the number of documents containing the term t.

Throws
IOException

public Document document (int n, FieldSelector fieldSelector)

Get the Document 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 isDeleted(int) with the requested document ID to verify the document is not deleted.

Parameters
n Get the document at the nth position
fieldSelector 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.
Returns
  • The stored fields of the Document at the nth position

public Object getCoreCacheKey ()

If the subclass of FilteredIndexReader modifies the contents of the FieldCache, you must override this method to provide a different key

public Object getDeletesCacheKey ()

If the subclass of FilteredIndexReader modifies the deleted docs, you must override this method to provide a different key

public Collection<String> getFieldNames (IndexReader.FieldOption fieldNames)

Get a list of unique field names that exist in this index and have the specified field option information.

Parameters
fieldNames specifies which field option should be available for the returned fields
Returns
  • Collection of Strings indicating the names of the fields.

public IndexReader[] getSequentialSubReaders ()

Expert: returns the sequential sub readers that this reader is logically composed of. For example, IndexSearcher uses this API to drive searching by one sub reader at a time. If this reader is not composed of sequential child readers, it should return null. If this method returns an empty array, that means this reader is a null reader (for example a MultiReader that has no sub readers).

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 open(IndexCommit, boolean). Use the parent reader directly.

public 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.

Parameters
docNumber The number of the document to load the vector for
field The name of the field to load
mapper The TermVectorMapper to process the vector. Must not be null
Throws
IOException

public void getTermFreqVector (int docNumber, TermVectorMapper mapper)

Map all the term vectors for all fields in a Document

Parameters
docNumber The number of the document to load the vector for
mapper The TermVectorMapper to process the vector. Must not be null
Throws
IOException

public TermFreqVector getTermFreqVector (int docNumber, String field)

Return a term frequency vector for the specified document and field. The returned vector contains terms and frequencies for the terms in the specified field of this document, if the field had the storeTermVector flag set. If termvectors had been stored with positions or offsets, a TermPositionVector is returned.

Parameters
docNumber document for which the term frequency vector is returned
field field for which the term frequency vector is returned.
Returns
  • term frequency vector May be null if field does not exist in the specified document or term vector was not stored.
Throws
IOException

public TermFreqVector[] getTermFreqVectors (int docNumber)

Return an array of term frequency vectors for the specified document. The array contains a vector for each vectorized field in the document. Each vector contains terms and frequencies for all terms in a given vectorized field. If no such fields existed, the method returns null. The term vectors that are returned may either be of type TermFreqVector or of type TermPositionVector if positions or offsets have been stored.

Parameters
docNumber document for which term frequency vectors are returned
Returns
  • array of term frequency vectors. May be null if no term vectors have been stored for the specified document.
Throws
IOException

public long getVersion ()

Version number when this IndexReader was opened. Not implemented in the IndexReader base class.

If this reader is based on a Directory (ie, was created by calling open(IndexCommit, boolean), or reopen() 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 commit() is called.

If instead this reader is a near real-time reader (ie, obtained by a call to getReader(), or by calling reopen() on a near real-time reader), then this method returns the version of the last commit done by the writer. Note that even as further changes are made with the writer, the version will not changed until a commit is completed. Thus, you should not rely on this method to determine when a near real-time reader should be opened. Use isCurrent() instead.

public boolean hasDeletions ()

Returns true if any documents have been deleted

public boolean hasNorms (String field)

Returns true if there are norms stored for this field.

Throws
IOException

public boolean isCurrent ()

Check whether any new changes have occurred to the index since this reader was opened.

If this reader is based on a Directory (ie, was created by calling open(IndexCommit, boolean), or reopen() on a reader based on a Directory), then this method checks if any further commits (see commit() have occurred in that directory).

If instead this reader is a near real-time reader (ie, obtained by a call to getReader(), or by calling reopen() 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 reopen() to get a new reader that sees the changes.

public boolean isDeleted (int n)

Returns true if document n has been deleted

public boolean isOptimized ()

Checks is the index is optimized (if it has a single segment and no deletions). Not implemented in the IndexReader base class.

Returns
  • true if the index is optimized; false otherwise

public int maxDoc ()

Returns one greater than the largest possible document number. This may be used to, e.g., determine how big to allocate an array which will have an element for every document number in an index.

public byte[] norms (String f)

Returns the byte-encoded normalization factor for the named field of every document. This is used by the search code to score documents. Returns null if norms were not indexed for this field.

Throws
IOException

public void norms (String f, byte[] bytes, int offset)

Reads the byte-encoded normalization factor for the named field of every document. This is used by the search code to score documents.

Throws
IOException

public int numDocs ()

Returns the number of documents in this index.

public void removeReaderFinishedListener (IndexReader.ReaderFinishedListener listener)

Expert: remove a previously added IndexReader.ReaderFinishedListener.

public TermDocs termDocs ()

Returns an unpositioned TermDocs enumerator.

Note: the TermDocs returned is unpositioned. Before using it, ensure that you first position it with seek(Term) or seek(TermEnum).

Throws
IOException

public TermDocs termDocs (Term term)

Returns an enumeration of all the documents which contain term. 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:

    Term    =>    <docNum, freq>*

The enumeration is ordered by document number. Each document number is greater than all that precede it in the enumeration.

Throws
IOException

public TermPositions termPositions ()

Returns an unpositioned TermPositions enumerator.

Throws
IOException

public TermEnum terms (Term t)

Returns an enumeration of all terms starting at a given term. If the given term does not exist, the enumeration is positioned at the first term greater than the supplied term. The enumeration is ordered by Term.compareTo(). Each term is greater than all that precede it in the enumeration.

Throws
IOException

public TermEnum terms ()

Returns an enumeration of all the terms in the index. The enumeration is ordered by Term.compareTo(). Each term is greater than all that precede it in the enumeration. Note that after calling terms(), next() must be called on the resulting enumeration before calling other methods such as term().

Throws
IOException

public String toString ()

Protected Methods

protected void doClose ()

Implements close.

Throws
IOException

protected void doCommit (Map<StringString> commitUserData)

Implements commit.

Throws
IOException

protected void doDelete (int n)

Implements deletion of the document numbered docNum. Applications should call deleteDocument(int) or deleteDocuments(Term).

protected void doSetNorm (int d, String f, byte b)

Implements setNorm in subclass.

protected void doUndeleteAll ()

Implements actual undeleteAll() in subclass.