Class IndexSearchResultIterator
- java.lang.Object
-
- org.apache.cassandra.utils.AbstractGuavaIterator<PrimaryKey>
-
- org.apache.cassandra.index.sai.iterators.KeyRangeIterator
-
- org.apache.cassandra.index.sai.disk.IndexSearchResultIterator
-
- All Implemented Interfaces:
com.google.common.collect.PeekingIterator<PrimaryKey>
,java.io.Closeable
,java.lang.AutoCloseable
,java.util.Iterator<PrimaryKey>
public class IndexSearchResultIterator extends KeyRangeIterator
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.cassandra.index.sai.iterators.KeyRangeIterator
KeyRangeIterator.Builder
-
Nested classes/interfaces inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
AbstractGuavaIterator.State
-
-
Field Summary
-
Fields inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
next, state
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static IndexSearchResultIterator
build(java.util.List<KeyRangeIterator> sstableIntersections, KeyRangeIterator memtableResults, java.util.Set<SSTableIndex> referencedIndexes, QueryContext queryContext, java.lang.Runnable onClose)
static IndexSearchResultIterator
build(Expression expression, java.util.Collection<SSTableIndex> sstableIndexes, AbstractBounds<PartitionPosition> keyRange, QueryContext queryContext, boolean includeMemtables, java.lang.Runnable onClose)
Builds a newIndexSearchResultIterator
that wraps aKeyRangeUnionIterator
over the results of searching theMemtableIndex
and theSSTableIndex
es.void
close()
protected PrimaryKey
computeNext()
Returns the next element.protected void
performSkipTo(PrimaryKey nextKey)
Skip to nextKey.-
Methods inherited from class org.apache.cassandra.index.sai.iterators.KeyRangeIterator
empty, getMaximum, getMaxKeys, getMinimum, nullSafeMax, nullSafeMin, setOnClose, skipTo
-
Methods inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
endOfData, hasNext, next, peek, remove, tryToComputeNext
-
-
-
-
Method Detail
-
build
public static IndexSearchResultIterator build(Expression expression, java.util.Collection<SSTableIndex> sstableIndexes, AbstractBounds<PartitionPosition> keyRange, QueryContext queryContext, boolean includeMemtables, java.lang.Runnable onClose)
Builds a newIndexSearchResultIterator
that wraps aKeyRangeUnionIterator
over the results of searching theMemtableIndex
and theSSTableIndex
es.
-
build
public static IndexSearchResultIterator build(java.util.List<KeyRangeIterator> sstableIntersections, KeyRangeIterator memtableResults, java.util.Set<SSTableIndex> referencedIndexes, QueryContext queryContext, java.lang.Runnable onClose)
-
computeNext
protected PrimaryKey computeNext()
Description copied from class:AbstractGuavaIterator
Returns the next element. Note: the implementation must callAbstractGuavaIterator.endOfData()
when there are no elements left in the iteration. Failure to do so could result in an infinite loop.The initial invocation of
AbstractGuavaIterator.hasNext()
orAbstractGuavaIterator.next()
calls this method, as does the first invocation ofhasNext
ornext
following each successful call tonext
. Once the implementation either invokesendOfData
or throws an exception,computeNext
is guaranteed to never be called again.If this method throws an exception, it will propagate outward to the
hasNext
ornext
invocation that invoked this method. Any further attempts to use the iterator will result in anIllegalStateException
.The implementation of this method may not invoke the
hasNext
,next
, orAbstractGuavaIterator.peek()
methods on this instance; if it does, anIllegalStateException
will result.- Specified by:
computeNext
in classAbstractGuavaIterator<PrimaryKey>
- Returns:
- the next element if there was one. If
endOfData
was called during execution, the return value will be ignored.
-
performSkipTo
protected void performSkipTo(PrimaryKey nextKey)
Description copied from class:KeyRangeIterator
Skip to nextKey.That is, implementations should set up the iterator state such that calling computeNext() will return nextKey if present, or the first one after it if not present.
- Specified by:
performSkipTo
in classKeyRangeIterator
-
close
public void close()
- Specified by:
close
in interfacejava.lang.AutoCloseable
- Specified by:
close
in interfacejava.io.Closeable
- Overrides:
close
in classKeyRangeIterator
-
-