|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectnet.sf.saxon.tree.iter.NodeWrappingAxisIterator<T,B>
public abstract class NodeWrappingAxisIterator<T extends NodeInfo,B>
An AxisIterator that wraps a Java Iterator. This is an abstract class, because the Java iterator does not hold enough information to support the getAnother() method, needed to implement the XPath last() function
| Field Summary |
|---|
| Fields inherited from interface net.sf.saxon.om.SequenceIterator |
|---|
GROUNDED, LAST_POSITION_FINDER, LOOKAHEAD |
| Constructor Summary | |
|---|---|
NodeWrappingAxisIterator(Iterator<B> base,
NodeWrappingFunction<B,T> wrappingFunction)
Create a SequenceIterator over a given iterator |
|
| Method Summary | |
|---|---|
Value |
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. |
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. |
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 |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Constructor Detail |
|---|
public NodeWrappingAxisIterator(Iterator<B> base,
NodeWrappingFunction<B,T> wrappingFunction)
base - the base IteratorwrappingFunction - a function that wraps objects of type B in a Saxon NodeInfo| Method Detail |
|---|
public boolean moveNext()
AxisIterator
moveNext in interface AxisIterator<T extends NodeInfo>
public AxisIterator iterateAxis(byte axis,
NodeTest test)
AxisIterator
iterateAxis in interface AxisIterator<T extends NodeInfo>axis - the axis to iterate over, using a constant such as
Axis.CHILDtest - a predicate to apply to the nodes before returning them.
public Value atomize()
throws XPathException
AxisIterator
atomize 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()
AxisIterator
getStringValue in interface AxisIterator<T extends NodeInfo>public boolean hasNext()
LookaheadIteratorSequenceIterator.LOOKAHEAD
hasNext in interface LookaheadIterator<T extends NodeInfo>public T next()
UnfailingIterator
next in interface SequenceIterator<T extends NodeInfo>next in interface AxisIterator<T extends NodeInfo>next in interface UnfailingIterator<T extends NodeInfo>public T current()
UnfailingIterator
current in interface SequenceIterator<T extends NodeInfo>current in interface AxisIterator<T extends NodeInfo>current in interface UnfailingIterator<T extends NodeInfo>public int position()
UnfailingIterator
position 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 abstract AxisIterator<T> getAnother()
UnfailingIterator
getAnother 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.
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||