Package net.sf.saxon.expr
Class CastingExpression
java.lang.Object
net.sf.saxon.expr.Expression
net.sf.saxon.expr.UnaryExpression
net.sf.saxon.expr.CastingExpression
- All Implemented Interfaces:
- ExportAgent,- Locatable,- IdentityComparable,- Traceable
- Direct Known Subclasses:
- CastableExpression,- CastExpression
Casting Expression: abstract superclass for "cast as X" and "castable as X", which share a good deal of logic
- 
Field SummaryFieldsFields inherited from class net.sf.saxon.expr.ExpressionEFFECTIVE_BOOLEAN_VALUE, EVALUATE_METHOD, ITEM_FEED_METHOD, ITERATE_METHOD, MAX_COST, MAX_SEQUENCE_LENGTH, MAX_STRING_LENGTH, PROCESS_METHOD, staticProperties, UNBOUNDED_LOWER, UNBOUNDED_UPPER, UPDATE_METHOD, WATCH_METHOD
- 
Constructor SummaryConstructorsConstructorDescriptionCastingExpression(Expression source, AtomicType target, boolean allowEmpty) Create a cast expression
- 
Method SummaryModifier and TypeMethodDescriptionbooleanAsk whether the expression accepts an empty sequence as input (producing an empty sequence as output)protected intDetermine the special properties of this expressionprotected voidexport(ExpressionPresenter out, String elemName) Export expression structure to SEF file.Get the Converter allocated to implement this cast expression, if anyintGet the expression's dependencies.Get the namespace resolver, if anyprotected OperandRoleGet the usage (in terms of streamability analysis) of the single operandGet the primitive base type of the target type of the castGet the target type (the result type)booleanAsk whether the operand to the cast expression was supplied in the form of a string literal.voidsetAllowEmpty(boolean allow) Say whether the expression accepts an empty sequence as input (producing an empty sequence as output)voidsetOperandIsStringLiteral(boolean option) Say whether the operand to the cast expression was supplied in the form of a string literal.voidsetTargetType(AtomicType type) Set the target typesimplify()Simplify the expressionMethods inherited from class net.sf.saxon.expr.UnaryExpressioncomputeCardinality, computeHashCode, displayOperator, emitExtraAttributes, equals, export, getBaseExpression, getItemType, getOperand, operands, optimize, setBaseExpression, toShortString, toString, typeCheckMethods inherited from class net.sf.saxon.expr.ExpressionaddToPathMap, adoptChildExpression, allowExtractingCommonSubexpressions, checkedOperands, checkForUpdatingSubexpressions, checkPermittedContents, computeDependencies, computeStaticProperties, copy, dispatchTailCall, dynamicError, effectiveBooleanValue, evaluateAsString, evaluateItem, explain, getCardinality, getConfiguration, getCost, getDependencies, getElaborator, getEvaluationMethod, getExpressionName, getExtraProperty, getImplementationMethod, getIntegerBounds, getLocalRetainedStaticContext, getLocation, getNetCost, getObjectName, getPackageData, getParentExpression, getProperties, getProperty, getRetainedStaticContext, getScopingExpression, getSlotsUsed, getSpecialProperties, getStaticBaseURI, getStaticBaseURIString, getStaticType, getStaticUType, getStreamerName, getTracingTag, hasCompatibleStaticContext, hashCode, hasSpecialProperty, hasVariableBinding, identityHashCode, implementsStaticTypeCheck, isCallOn, isEqual, isIdentical, isInstruction, isLiftable, isMultiThreaded, isStaticPropertiesKnown, isSubtreeExpression, isUpdatingExpression, isVacuousExpression, iterate, makeElaborator, markTailFunctionCalls, operandList, operandSparseList, optimizeChildren, prepareForStreaming, process, resetLocalStaticProperties, restoreParentPointers, setEvaluationMethod, setExtraProperty, setFiltered, setFlattened, setLocation, setParentExpression, setRetainedStaticContext, setRetainedStaticContextLocally, setRetainedStaticContextThoroughly, setStaticProperty, simplifyChildren, staticTypeCheck, supportsLazyEvaluation, suppressValidation, toPattern, typeCheckChildren, typeError, unordered, verifyParentPointers, withLocationMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface net.sf.saxon.trace.TraceablegatherProperties
- 
Field Details- 
converter
 
- 
- 
Constructor Details- 
CastingExpressionCreate a cast expression- Parameters:
- source- expression giving the value to be converted
- target- the type to which the value is to be converted
- allowEmpty- true if the expression allows an empty sequence as input, producing an empty sequence as output. If false, an empty sequence is a type error.
 
 
- 
- 
Method Details- 
getTargetPrimitiveTypeGet the primitive base type of the target type of the cast- Returns:
- the primitive type of the target type
 
- 
setTargetTypeSet the target type- Parameters:
- type- the target type for the cast
 
- 
getTargetTypeGet the target type (the result type)- Returns:
- the target type
 
- 
getOperandRoleDescription copied from class:UnaryExpressionGet the usage (in terms of streamability analysis) of the single operand- Specified by:
- getOperandRolein class- UnaryExpression
- Returns:
- the operand usage
 
- 
setAllowEmptypublic void setAllowEmpty(boolean allow) Say whether the expression accepts an empty sequence as input (producing an empty sequence as output)- Parameters:
- allow- true if an empty sequence is accepted
 
- 
allowsEmptypublic boolean allowsEmpty()Ask whether the expression accepts an empty sequence as input (producing an empty sequence as output)- Returns:
- true if an empty sequence is accepted
 
- 
setOperandIsStringLiteralpublic void setOperandIsStringLiteral(boolean option) Say whether the operand to the cast expression was supplied in the form of a string literal. This is relevant only for XPath 2.0 / XQuery 1.0, and then only when the target type is a QName or NOTATION.- Parameters:
- option- true if the operand was supplied as a string literal
 
- 
isOperandIsStringLiteralpublic boolean isOperandIsStringLiteral()Ask whether the operand to the cast expression was supplied in the form of a string literal. This is relevant only for XPath 2.0 / XQuery 1.0, and then only when the target type is a QName or NOTATION.- Returns:
- true if the operand was supplied as a string literal
 
- 
getConverterGet the Converter allocated to implement this cast expression, if any- Returns:
- the Converter if one has been statically allocated, or null if not
 
- 
getNamespaceResolverGet the namespace resolver, if any- Returns:
- the namespace resolver that was statically allocated if the target type is namespace-sensitive
 
- 
getIntrinsicDependenciespublic int getIntrinsicDependencies()Get the expression's dependencies. If the target type is namespace-sensitive, then the expression has a dependency on the namespace bindings in the static context- Overrides:
- getIntrinsicDependenciesin class- Expression
- Returns:
- the expression's dependencies.
 
- 
simplifySimplify the expression- Overrides:
- simplifyin class- Expression
- Returns:
- the simplified expression (or the original if unchanged, or if modified in-situ)
- Throws:
- XPathException- if an error is discovered during expression rewriting
 
- 
computeSpecialPropertiesprotected int computeSpecialProperties()Determine the special properties of this expression- Overrides:
- computeSpecialPropertiesin class- UnaryExpression
- Returns:
- StaticProperty.NO_NODES_NEWLY_CREATED.
 
- 
exportExport expression structure to SEF file. The abstract expression tree is written to the supplied output destination. Helper method for subclasses.- Parameters:
- out- the destination of the output
- elemName- the element name to be used in the SEF file
- Throws:
- XPathException- if output fails
 
 
-