Constructor and Description |
---|
CachingWrapperFilter(Filter filter)
Wraps another filter's result and caches it.
|
CachingWrapperFilter(Filter filter,
boolean recacheDeletes)
Wraps another filter's result and caches it.
|
Modifier and Type | Method and Description |
---|---|
protected DocIdSet |
docIdSetToCache(DocIdSet docIdSet,
AtomicReader reader)
Provide the DocIdSet to be cached, using the DocIdSet provided
by the wrapped Filter.
|
boolean |
equals(Object o) |
DocIdSet |
getDocIdSet(AtomicReaderContext context,
Bits acceptDocs)
Creates a
DocIdSet enumerating the documents that should be
permitted in search results. |
int |
hashCode() |
String |
toString() |
public CachingWrapperFilter(Filter filter)
CachingWrapperFilter(Filter,boolean)
for an explanation.
This constructor is recommended for often changing indexes.filter
- Filter to cache results ofCachingWrapperFilter(Filter,boolean)
public CachingWrapperFilter(Filter filter, boolean recacheDeletes)
recacheDeletes
is true
, then new deletes (for example
after DirectoryReader.openIfChanged(org.apache.lucene.index.DirectoryReader)
) will cause the filter
DocIdSet
to be recached.
If your index changes seldom, it is recommended to use recacheDeletes=true
,
as recaching will only occur when the index is reopened.
For near-real-time indexes or indexes that are often
reopened with (e.g., DirectoryReader.openIfChanged(org.apache.lucene.index.DirectoryReader)
is used), you should
pass recacheDeletes=false
. This will cache the filter results omitting
deletions and will AND them in while scoring.
filter
- Filter to cache results ofrecacheDeletes
- if deletions on the underlying index should recacheprotected DocIdSet docIdSetToCache(DocIdSet docIdSet, AtomicReader reader) throws IOException
This implementation returns the given DocIdSet
, if DocIdSet.isCacheable()
returns true
, else it copies the DocIdSetIterator
into
a FixedBitSet
.
IOException
public DocIdSet getDocIdSet(AtomicReaderContext context, Bits acceptDocs) throws IOException
Filter
DocIdSet
enumerating the documents that should be
permitted in search results. NOTE: null can be
returned if no documents are accepted by this Filter.
Note: This method will be called once per segment in
the index during searching. The returned DocIdSet
must refer to document IDs for that segment, not for
the top-level reader.
getDocIdSet
in class Filter
context
- a AtomicReaderContext
instance opened on the index currently
searched on. Note, it is likely that the provided reader info does not
represent the whole underlying index i.e. if the index has more than
one segment the given reader only represents a single segment.
The provided context is always an atomic context, so you can call
AtomicReader.fields()
on the context's reader, for example.acceptDocs
- Bits that represent the allowable docs to match (typically deleted docs
but possibly filtering other documents)IOException
Copyright © 2000-2012 Apache Software Foundation. All Rights Reserved.