|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectnet.sf.saxon.expr.ComputedExpression
net.sf.saxon.expr.AxisExpression
public final class AxisExpression
An AxisExpression is always obtained by simplifying a PathExpression. It represents a PathExpression that starts at the context node, and uses a simple node-test with no filters. For example "*", "title", "./item", "@*", or "ancestor::chapter*".
An AxisExpression delivers nodes in axis order (not in document order). To get nodes in document order, in the case of a reverse axis, the expression should be wrapped in a Reverser.
| Field Summary | |
|---|---|
(package private) int |
computedCardinality
|
| Fields inherited from class net.sf.saxon.expr.ComputedExpression |
|---|
locationId, staticProperties |
| Fields inherited from interface net.sf.saxon.expr.Expression |
|---|
EVALUATE_METHOD, ITERATE_METHOD, PROCESS_METHOD |
| Constructor Summary | |
|---|---|
AxisExpression(byte axis,
NodeTest nodeTest)
Constructor |
|
| Method Summary | |
|---|---|
int |
computeCardinality()
Specify that the expression returns a singleton |
int |
computeSpecialProperties()
Get the static properties of this expression (other than its type). |
void |
display(int level,
java.io.PrintStream out,
Configuration config)
Diagnostic print of expression structure |
boolean |
equals(java.lang.Object other)
Is this expression the same as another expression? |
byte |
getAxis()
Get the axis |
ItemType |
getContextItemType()
Get the static type of the context item for this AxisExpression. |
int |
getIntrinsicDependencies()
Determine which aspects of the context the expression depends on. |
ItemType |
getItemType(TypeHierarchy th)
Determine the data type of the items returned by this expression |
NodeTest |
getNodeTest()
Get the NodeTest. |
int |
hashCode()
get HashCode for comparing two expressions |
SequenceIterator |
iterate(XPathContext context)
Evaluate the path-expression in a given context to return a NodeSet |
Expression |
optimize(Optimizer opt,
StaticContext env,
ItemType contextItemType)
Perform optimisation of an expression and its subexpressions. |
Expression |
simplify(StaticContext env)
Simplify an expression |
java.lang.String |
toString()
Represent the expression as a string for diagnostics |
java.lang.String |
toString(NamePool pool)
Represent the expression as a string for diagnostics |
Expression |
typeCheck(StaticContext env,
ItemType contextItemType)
Type-check the expression |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Field Detail |
|---|
int computedCardinality
| Constructor Detail |
|---|
public AxisExpression(byte axis,
NodeTest nodeTest)
axis - The axis to be used in this AxisExpression: relevant constants are defined
in class net.sf.saxon.om.Axis.nodeTest - The conditions to be satisfied by selected nodes. May be null,
indicating that any node on the axis is acceptableAxis| Method Detail |
|---|
public Expression simplify(StaticContext env)
simplify in interface Expressionsimplify in class ComputedExpressionenv - the static context
public Expression typeCheck(StaticContext env,
ItemType contextItemType)
throws XPathException
env - the static context of the expressioncontextItemType - the static type of "." at the point where this expression is invoked.
The parameter is set to null if it is known statically that the context item will be undefined.
If the type of the context item is not known statically, the argument is set to
Type.ITEM_TYPE
StaticError - if an error is discovered during this phase
(typically a type error)
XPathExceptionpublic ItemType getContextItemType()
public Expression optimize(Optimizer opt,
StaticContext env,
ItemType contextItemType)
This method is called after all references to functions and variables have been resolved to the declaration of the function or variable, and after all type checking has been done.
opt - the optimizer in use. This provides access to supporting functions; it also allows
different optimization strategies to be used in different circumstances.env - the static context of the expressioncontextItemType - the static type of "." at the point where this expression is invoked.
The parameter is set to null if it is known statically that the context item will be undefined.
If the type of the context item is not known statically, the argument is set to
Type.ITEM_TYPE
public boolean equals(java.lang.Object other)
equals in class java.lang.Objectpublic int hashCode()
hashCode in class java.lang.Objectpublic int getIntrinsicDependencies()
getIntrinsicDependencies in class ComputedExpressionpublic int computeSpecialProperties()
computeSpecialProperties in class ComputedExpressionpublic final ItemType getItemType(TypeHierarchy th)
th -
public final int computeCardinality()
computeCardinality in class ComputedExpressionpublic byte getAxis()
public NodeTest getNodeTest()
public SequenceIterator iterate(XPathContext context)
throws XPathException
iterate in interface Expressioniterate in class ComputedExpressioncontext - the evaluation context
XPathException - if any dynamic error occurs evaluating the
expression
public void display(int level,
java.io.PrintStream out,
Configuration config)
level - indentation level for this expressionout - Output destinationpublic java.lang.String toString()
toString in class java.lang.Objectpublic java.lang.String toString(NamePool pool)
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||