public abstract class NodeWrappingAxisIterator<T extends NodeInfo,B> extends Object implements AxisIterator<T>, LookaheadIterator<T>, UnfailingIterator<T>
GROUNDED, LAST_POSITION_FINDER, LOOKAHEAD| Constructor and Description |
|---|
NodeWrappingAxisIterator(Iterator<B> base,
NodeWrappingFunction<B,T> wrappingFunction)
Create a SequenceIterator over a given iterator
|
| Modifier and Type | Method and Description |
|---|---|
Sequence |
atomize()
Return the atomized value of the current node.
|
void |
close()
Close the iterator.
|
T |
current()
Get the current item in the sequence.
|
abstract AxisIterator<T> |
getAnother()
Get another iterator over the same sequence of items, positioned at the
start of the sequence.
|
Iterator<B> |
getBaseIterator() |
NodeWrappingFunction<B,T> |
getNodeWrappingFunction() |
int |
getProperties()
Get properties of this iterator, as a bit-significant integer.
|
CharSequence |
getStringValue()
Return the string value of the current node.
|
boolean |
hasNext()
Determine whether there are more items to come.
|
boolean |
isIgnorable(B node) |
AxisIterator |
iterateAxis(byte axis,
NodeTest test)
Return an iterator over an axis, starting at the current node.
|
boolean |
moveNext()
Move to the next node, without returning it.
|
T |
next()
Get the next item in the sequence.
|
int |
position()
Get the current position
|
public NodeWrappingAxisIterator(Iterator<B> base, NodeWrappingFunction<B,T> wrappingFunction)
base - the base IteratorwrappingFunction - a function that wraps objects of type B in a Saxon NodeInfopublic NodeWrappingFunction<B,T> getNodeWrappingFunction()
public boolean moveNext()
AxisIteratormoveNext in interface AxisIterator<T extends NodeInfo>public AxisIterator iterateAxis(byte axis, NodeTest test)
AxisIteratoriterateAxis in interface AxisIterator<T extends NodeInfo>axis - the axis to iterate over, using a constant such as
AxisInfo.CHILDtest - a predicate to apply to the nodes before returning them.public Sequence atomize() throws XPathException
AxisIteratoratomize in interface AxisIterator<T extends NodeInfo>XPathException - if the current node
cannot be atomized, for example because it is an element node with
element-only content.public CharSequence getStringValue()
AxisIteratorgetStringValue in interface AxisIterator<T extends NodeInfo>public boolean hasNext()
LookaheadIteratorSequenceIterator.LOOKAHEADhasNext in interface LookaheadIterator<T extends NodeInfo>public T next()
UnfailingIteratornext in interface SequenceIterator<T extends NodeInfo>next in interface AxisIterator<T extends NodeInfo>next in interface UnfailingIterator<T extends NodeInfo>public T current()
UnfailingIteratorcurrent in interface SequenceIterator<T extends NodeInfo>current in interface AxisIterator<T extends NodeInfo>current in interface UnfailingIterator<T extends NodeInfo>public int position()
UnfailingIteratorposition in interface SequenceIterator<T extends NodeInfo>position in interface UnfailingIterator<T extends NodeInfo>public void close()
SequenceIterator(Currently, closing an iterator is important only when the data is being "pushed" in another thread. Closing the iterator terminates that thread and means that it needs to do no additional work. Indeed, failing to close the iterator may cause the push thread to hang waiting for the buffer to be emptied.)
close in interface SequenceIterator<T extends NodeInfo>public boolean isIgnorable(B node)
public abstract AxisIterator<T> getAnother()
UnfailingIteratorgetAnother in interface SequenceIterator<T extends NodeInfo>getAnother in interface AxisIterator<T extends NodeInfo>getAnother in interface UnfailingIterator<T extends NodeInfo>public int getProperties()
getProperties in interface SequenceIterator<T extends NodeInfo>SequenceIterator.GROUNDED, SequenceIterator.LAST_POSITION_FINDER,
and SequenceIterator.LOOKAHEAD. It is always
acceptable to return the value zero, indicating that there are no known special properties.
It is acceptable for the properties of the iterator to change depending on its state.Copyright (c) 2004-2013 Saxonica Limited. All rights reserved.