org.apache.jackrabbit.core.query.lucene
Class CachingMultiIndexReader

java.lang.Object
  extended by org.apache.lucene.index.IndexReader
      extended by org.apache.lucene.index.MultiReader
          extended by org.apache.jackrabbit.core.query.lucene.CachingMultiIndexReader
All Implemented Interfaces:
HierarchyResolver, MultiIndexReader, ReleaseableIndexReader

public final class CachingMultiIndexReader
extends org.apache.lucene.index.MultiReader
implements HierarchyResolver, MultiIndexReader

Extends a MultiReader with support for cached TermDocs on FieldNames.UUID field.


Nested Class Summary
 
Nested classes/interfaces inherited from class org.apache.lucene.index.IndexReader
org.apache.lucene.index.IndexReader.FieldOption
 
Field Summary
 
Fields inherited from class org.apache.lucene.index.IndexReader
hasChanges
 
Constructor Summary
CachingMultiIndexReader(org.apache.jackrabbit.core.query.lucene.ReadOnlyIndexReader[] subReaders, org.apache.jackrabbit.core.query.lucene.DocNumberCache cache)
          Creates a new CachingMultiIndexReader based on sub readers.
 
Method Summary
 org.apache.jackrabbit.core.query.lucene.ForeignSegmentDocId createDocId(NodeId id)
          Creates a document id for the given node identifier.
protected  void doClose()
          
 int getDocumentNumber(org.apache.jackrabbit.core.query.lucene.ForeignSegmentDocId docId)
          Returns the document number for the passed docId.
 org.apache.lucene.index.IndexReader[] getIndexReaders()
          
 org.apache.jackrabbit.core.query.lucene.DocId getParentDocId(int n)
          Returns the DocId of the parent of n or DocId.NULL if n does not have a parent (n is the root node).
 int[] getParents(int n, int[] docNumbers)
          Returns the document number of the parent of n or an empty array if n does not have a parent (n is the root node).
 void release()
          Releases this index reader and potentially frees resources.
 org.apache.lucene.index.TermDocs termDocs(org.apache.lucene.index.Term term)
          
 
Methods inherited from class org.apache.lucene.index.MultiReader
docFreq, doCommit, document, doDelete, doSetNorm, doUndeleteAll, getFieldNames, getTermFreqVector, getTermFreqVector, getTermFreqVector, getTermFreqVectors, getVersion, hasDeletions, hasNorms, isCurrent, isDeleted, isOptimized, maxDoc, norms, norms, numDocs, reopen, termDocs, termPositions, terms, terms
 
Methods inherited from class org.apache.lucene.index.IndexReader
acquireWriteLock, close, commit, decRef, deleteDocument, deleteDocuments, directory, document, ensureOpen, flush, getCurrentVersion, getCurrentVersion, getCurrentVersion, getIndexCommit, getTermInfosIndexDivisor, incRef, indexExists, indexExists, indexExists, isLocked, isLocked, lastModified, lastModified, lastModified, listCommits, main, numDeletedDocs, open, open, open, open, open, open, open, open, open, setNorm, setNorm, setTermInfosIndexDivisor, termPositions, undeleteAll, unlock
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

CachingMultiIndexReader

public CachingMultiIndexReader(org.apache.jackrabbit.core.query.lucene.ReadOnlyIndexReader[] subReaders,
                               org.apache.jackrabbit.core.query.lucene.DocNumberCache cache)
Creates a new CachingMultiIndexReader based on sub readers.

Parameters:
subReaders - the sub readers.
cache - the document number cache.
Method Detail

getParents

public int[] getParents(int n,
                        int[] docNumbers)
                 throws IOException
Returns the document number of the parent of n or an empty array if n does not have a parent (n is the root node).

Specified by:
getParents in interface HierarchyResolver
Parameters:
n - the document number.
docNumbers - an array for reuse. An implementation should use the passed array as a container for the return value, unless the length of the returned array is different from docNumbers. In which case an implementation will create a new array with an appropriate size.
Returns:
the document number of n's parent.
Throws:
IOException - if an error occurs while reading from the index.

getParentDocId

public org.apache.jackrabbit.core.query.lucene.DocId getParentDocId(int n)
                                                             throws IOException
Returns the DocId of the parent of n or DocId.NULL if n does not have a parent (n is the root node).

Parameters:
n - the document number.
Returns:
the DocId of n's parent.
Throws:
IOException - if an error occurs while reading from the index.

termDocs

public org.apache.lucene.index.TermDocs termDocs(org.apache.lucene.index.Term term)
                                          throws IOException

Overrides:
termDocs in class org.apache.lucene.index.IndexReader
Throws:
IOException

release

public final void release()
                   throws IOException
Releases this index reader and potentially frees resources. In contrast to IndexReader.close() this method does not necessarily close the index reader, but gives the implementation the opportunity to do reference counting.

Specified by:
release in interface ReleaseableIndexReader
Throws:
IOException - if an error occurs while releasing the index reader.

doClose

protected void doClose()
                throws IOException

Overrides:
doClose in class org.apache.lucene.index.MultiReader
Throws:
IOException

getIndexReaders

public org.apache.lucene.index.IndexReader[] getIndexReaders()

Specified by:
getIndexReaders in interface MultiIndexReader
Returns:
the IndexReaders that are contained in this MultiIndexReader.

createDocId

public org.apache.jackrabbit.core.query.lucene.ForeignSegmentDocId createDocId(NodeId id)
                                                                        throws IOException
Creates a document id for the given node identifier.

Specified by:
createDocId in interface MultiIndexReader
Parameters:
id - the id of the node.
Returns:
a foreign segment doc id or null if there is no node with the given id.
Throws:
IOException - if an error occurs while reading from the index.

getDocumentNumber

public int getDocumentNumber(org.apache.jackrabbit.core.query.lucene.ForeignSegmentDocId docId)
Returns the document number for the passed docId. If the id is invalid -1 is returned.

Specified by:
getDocumentNumber in interface MultiIndexReader
Parameters:
docId - the document id to resolve.
Returns:
the document number or -1 if it is invalid (e.g. does not exist).


Copyright © 2004-2010 The Apache Software Foundation. All Rights Reserved.