Class DescendantContext
- java.lang.Object
-
- org.apache.commons.jxpath.ri.EvalContext
-
- org.apache.commons.jxpath.ri.axes.DescendantContext
-
- All Implemented Interfaces:
java.util.Iterator,ExpressionContext
public class DescendantContext extends EvalContext
An EvalContext that walks the "descendant::" and "descendant-or-self::" axes.- Version:
- $Revision: 670727 $ $Date: 2008-06-23 15:10:38 -0500 (Mon, 23 Jun 2008) $
-
-
Field Summary
Fields Modifier and Type Field Description private NodePointercurrentNodePointerprivate static NodeTestELEMENT_NODE_TESTprivate booleanincludeSelfprivate NodeTestnodeTestprivate booleansetStartedprivate java.util.Stackstack-
Fields inherited from class org.apache.commons.jxpath.ri.EvalContext
parentContext, position, rootContext
-
-
Constructor Summary
Constructors Constructor Description DescendantContext(EvalContext parentContext, boolean includeSelf, NodeTest nodeTest)Create a new DescendantContext.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description NodePointergetCurrentNodePointer()Returns the current context node.booleanisChildOrderingRequired()Even if this context has the natural ordering and therefore does not require collecting and sorting all nodes prior to returning them, such operation may be required for any child context.private booleanisRecursive()Checks if we are reentering a bean we have already seen and if so returns true to prevent infinite recursion.booleannextNode()Returns true if there is another object in the current set.voidreset()Sets current position = 0, which is the pre-iteration state.booleansetPosition(int position)Moves the current position to the specified index.-
Methods inherited from class org.apache.commons.jxpath.ri.EvalContext
getContextNodeList, getContextNodePointer, getCurrentPosition, getDocumentOrder, getJXPathContext, getNodeSet, getPosition, getRootContext, getSingleNodePointer, getValue, hasNext, next, nextSet, remove, sortPointers, toString
-
-
-
-
Field Detail
-
nodeTest
private NodeTest nodeTest
-
setStarted
private boolean setStarted
-
stack
private java.util.Stack stack
-
currentNodePointer
private NodePointer currentNodePointer
-
includeSelf
private boolean includeSelf
-
ELEMENT_NODE_TEST
private static final NodeTest ELEMENT_NODE_TEST
-
-
Constructor Detail
-
DescendantContext
public DescendantContext(EvalContext parentContext, boolean includeSelf, NodeTest nodeTest)
Create a new DescendantContext.- Parameters:
parentContext- parent contextincludeSelf- whether to include this nodenodeTest- test
-
-
Method Detail
-
isChildOrderingRequired
public boolean isChildOrderingRequired()
Description copied from class:EvalContextEven if this context has the natural ordering and therefore does not require collecting and sorting all nodes prior to returning them, such operation may be required for any child context.- Overrides:
isChildOrderingRequiredin classEvalContext- Returns:
- boolean
-
getCurrentNodePointer
public NodePointer getCurrentNodePointer()
Description copied from class:EvalContextReturns the current context node. Undefined before the beginning of the iteration.- Specified by:
getCurrentNodePointerin classEvalContext- Returns:
- NodePoiner
-
reset
public void reset()
Description copied from class:EvalContextSets current position = 0, which is the pre-iteration state.- Overrides:
resetin classEvalContext
-
setPosition
public boolean setPosition(int position)
Description copied from class:EvalContextMoves the current position to the specified index. Used with integer predicates to quickly get to the n'th element of the node set. Returns false if the position is out of the node set range. You can call it with 0 as the position argument to restart the iteration.- Overrides:
setPositionin classEvalContext- Parameters:
position- to set- Returns:
- boolean
-
nextNode
public boolean nextNode()
Description copied from class:EvalContextReturns true if there is another object in the current set. Switches the current position and node to the next object.- Specified by:
nextNodein classEvalContext- Returns:
- boolean
-
isRecursive
private boolean isRecursive()
Checks if we are reentering a bean we have already seen and if so returns true to prevent infinite recursion.- Returns:
- boolean
-
-