Package net.sf.saxon.expr
Class InstanceOfExpression
java.lang.Object
net.sf.saxon.expr.Expression
net.sf.saxon.expr.UnaryExpression
net.sf.saxon.expr.InstanceOfExpression
- All Implemented Interfaces:
Serializable
,SourceLocator
,LocationProvider
,SaxonLocator
,EvaluableItem
,SequenceIterable
,InstructionInfo
,Locator
InstanceOf Expression: implements "Expr instance of data-type"
- See Also:
-
Field Summary
Fields inherited from class net.sf.saxon.expr.UnaryExpression
operand
Fields inherited from class net.sf.saxon.expr.Expression
EVALUATE_METHOD, ITERATE_METHOD, locationId, PROCESS_METHOD, staticProperties
-
Constructor Summary
ConstructorsConstructorDescriptionInstanceOfExpression
(Expression source, SequenceType target) Construct an "instance of" expression in the form "source instance of target" -
Method Summary
Modifier and TypeMethodDescriptionint
Determine the cardinalitycopy()
Copy an expression.boolean
effectiveBooleanValue
(XPathContext context) Evaluate the expression as a booleanboolean
Is this expression the same as another expression?evaluateItem
(XPathContext context) Evaluate the expressionvoid
explain
(ExpressionPresenter destination) Diagnostic print of expression structure.Determine the data type of the result of the InstanceOf expressionint
Get the cardinality that we are testing for membership ofGet the item type that we are testing for membership ofoptimize
(ExpressionVisitor visitor, ItemType contextItemType) Perform optimisation of an expression and its subexpressions.typeCheck
(ExpressionVisitor visitor, ItemType contextItemType) Type-check the expressionMethods inherited from class net.sf.saxon.expr.UnaryExpression
computeSpecialProperties, displayExpressionName, displayOperator, getBaseExpression, hashCode, iterateSubExpressions, promote, replaceSubExpression, simplify, toString
Methods inherited from class net.sf.saxon.expr.Expression
addToPathMap, adoptChildExpression, checkForUpdatingSubexpressions, checkPermittedContents, computeDependencies, computeStaticProperties, display, doPromotion, dynamicError, evaluateAsString, evaluatePendingUpdates, explain, findParentOf, getCardinality, getColumnNumber, getColumnNumber, getConstructType, getContainer, getDependencies, getExecutable, getHostLanguage, getImplementationMethod, getIntrinsicDependencies, getLineNumber, getLineNumber, getLocationId, getLocationProvider, getObjectName, getProperties, getProperty, getPublicId, getSlotsUsed, getSpecialProperties, getSystemId, getSystemId, hasLoopingSubexpression, implementsStaticTypeCheck, isUpdatingExpression, iterate, iterateEvents, markTailFunctionCalls, process, resetLocalStaticProperties, setContainer, setFiltered, setFlattened, setLocationId, staticTypeCheck, suppressValidation, typeError
-
Constructor Details
-
InstanceOfExpression
Construct an "instance of" expression in the form "source instance of target"- Parameters:
source
- the expression whose type is to be testedtarget
- the type against which it is tested
-
-
Method Details
-
getRequiredItemType
Get the item type that we are testing for membership of- Returns:
- the item type
-
getRequiredCardinality
public int getRequiredCardinality()Get the cardinality that we are testing for membership of- Returns:
- the required cardinality
-
typeCheck
public Expression typeCheck(ExpressionVisitor visitor, ItemType contextItemType) throws XPathException Type-check the expression- Overrides:
typeCheck
in classUnaryExpression
- Parameters:
visitor
- an expression visitorcontextItemType
- 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 toType.ITEM_TYPE
- Returns:
- the checked expression
- Throws:
XPathException
- if an error is discovered during this phase (typically a type error)
-
optimize
public Expression optimize(ExpressionVisitor visitor, ItemType contextItemType) throws XPathException Perform optimisation of an expression and its subexpressions.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.
- Overrides:
optimize
in classUnaryExpression
- Parameters:
visitor
- an expression visitorcontextItemType
- 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 toType.ITEM_TYPE
- Returns:
- the original expression, rewritten if appropriate to optimize execution
- Throws:
XPathException
- if an error is discovered during this phase (typically a type error)
-
equals
Is this expression the same as another expression?- Overrides:
equals
in classUnaryExpression
-
computeCardinality
public int computeCardinality()Determine the cardinality- Overrides:
computeCardinality
in classUnaryExpression
- Returns:
- the computed cardinality, as one of the values
StaticProperty.ALLOWS_ZERO_OR_ONE
,StaticProperty.EXACTLY_ONE
,StaticProperty.ALLOWS_ONE_OR_MORE
,StaticProperty.ALLOWS_ZERO_OR_MORE
-
copy
Copy an expression. This makes a deep copy.- Specified by:
copy
in classExpression
- Returns:
- the copy of the original expression
-
getItemType
Determine the data type of the result of the InstanceOf expression- Overrides:
getItemType
in classUnaryExpression
- Parameters:
th
- the type hierarchy cache- Returns:
- the item type of the items in the result sequence, insofar as this is known statically.
-
evaluateItem
Evaluate the expression- Specified by:
evaluateItem
in interfaceEvaluableItem
- Overrides:
evaluateItem
in classExpression
- Parameters:
context
- The context in which the expression is to be evaluated- Returns:
- the node or atomic value that results from evaluating the expression; or null to indicate that the result is an empty sequence
- Throws:
XPathException
- if any dynamic error occurs evaluating the expression
-
effectiveBooleanValue
Evaluate the expression as a boolean- Overrides:
effectiveBooleanValue
in classExpression
- Parameters:
context
- The context in which the expression is to be evaluated- Returns:
- the effective boolean value
- Throws:
XPathException
- if any dynamic error occurs evaluating the expression
-
explain
Diagnostic print of expression structure. The abstract expression tree is written to the supplied output destination.- Overrides:
explain
in classUnaryExpression
- Parameters:
destination
- the expression presenter used to display the structure
-