Package net.sf.saxon.tree.tiny
Class NamedChildIterator
- java.lang.Object
-
- net.sf.saxon.tree.tiny.NamedChildIterator
-
- All Implemented Interfaces:
Closeable,AutoCloseable,AtomizedValueIterator<NodeInfo>,SequenceIterator<NodeInfo>,AxisIterator,LookaheadIterator<NodeInfo>,UnfailingIterator<NodeInfo>
final class NamedChildIterator extends Object implements AxisIterator, LookaheadIterator<NodeInfo>, AtomizedValueIterator<NodeInfo>
This class is a fast path iterator for the child axis in the TinyTree, where the axis specifies an explicit name test for the required element nodes.
-
-
Field Summary
-
Fields inherited from interface net.sf.saxon.om.SequenceIterator
ATOMIZING, GROUNDED, LAST_POSITION_FINDER, LOOKAHEAD
-
-
Constructor Summary
Constructors Constructor Description NamedChildIterator(TinyTree tree, TinyNodeImpl node, int fingerprint)Return an enumeration over children or siblings of the context node
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intgetProperties()Get properties of this iterator, as a bit-significant integer.booleanhasNext()Test whether there are any more nodes to come.NodeInfonext()Return the next node in the sequenceAtomicSequencenextAtomizedValue()Deliver the atomic value that is next in the atomized result-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface net.sf.saxon.om.SequenceIterator
close, forEachOrFail, materialize
-
Methods inherited from interface net.sf.saxon.tree.iter.UnfailingIterator
firstWith, forEach, toGroundedValue, toList
-
-
-
-
Constructor Detail
-
NamedChildIterator
NamedChildIterator(TinyTree tree, TinyNodeImpl node, int fingerprint)
Return an enumeration over children or siblings of the context node- Parameters:
tree- The TinyTree containing the context nodenode- The context node, the start point for the iterationfingerprint- The fingerprint of the required element children
-
-
Method Detail
-
next
public NodeInfo next()
Return the next node in the sequence- Specified by:
nextin interfaceAxisIterator- Specified by:
nextin interfaceSequenceIterator<NodeInfo>- Specified by:
nextin interfaceUnfailingIterator<NodeInfo>- Returns:
- the next node, or null if the end of the sequence is reached
-
nextAtomizedValue
public AtomicSequence nextAtomizedValue() throws XPathException
Deliver the atomic value that is next in the atomized result- Specified by:
nextAtomizedValuein interfaceAtomizedValueIterator<NodeInfo>- Returns:
- the next atomic value
- Throws:
XPathException- if a failure occurs reading or atomizing the next value
-
hasNext
public boolean hasNext()
Test whether there are any more nodes to come. This method is used only when testing whether the current item is the last in the sequence. It's not especially efficient, but is more efficient than the alternative strategy which involves counting how many nodes there are in the sequence.- Specified by:
hasNextin interfaceLookaheadIterator<NodeInfo>- Returns:
- true if there are more items in the sequence
-
getProperties
public int getProperties()
Description copied from interface:SequenceIteratorGet properties of this iterator, as a bit-significant integer.- Specified by:
getPropertiesin interfaceSequenceIterator<NodeInfo>- Returns:
- the properties of this iterator. This will be some combination of
properties such as
SequenceIterator.GROUNDED,SequenceIterator.LAST_POSITION_FINDER, andSequenceIterator.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.
-
-