Package net.sf.saxon.expr
Class CompareToConstant
java.lang.Object
net.sf.saxon.expr.Expression
net.sf.saxon.expr.UnaryExpression
net.sf.saxon.expr.CompareToConstant
- All Implemented Interfaces:
- ComparisonExpression,- ExportAgent,- Locatable,- IdentityComparable,- Traceable
- Direct Known Subclasses:
- CompareToIntegerConstant,- CompareToStringConstant
This class implements a comparison of a computed value to a literal constant using one of the operators
 eq, ne, lt, gt, le, ge. The semantics are identical to ValueComparison, but this is a fast path for an
 important common case. Different subclasses handle different types of constant.
- 
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 SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected intGet the static properties of this expression (other than its type).booleanDetermine whether untyped atomic values should be converted to the type of the other operandevaluateItem(XPathContext context) Evaluate an expression as a single item.intGet the comparison operatorintAn implementation of Expression must provide at least one of the methods evaluateItem(), iterate(), or process().Determine the data type of the expression, if possible.getLhs()Get the left-hand operand of the comparisonGet the left-hand expressionprotected OperandRoleGet the usage (in terms of streamability analysis) of the single operandgetRhs()Get the right-hand operand of the comparisonabstract ExpressionGet the right-hand expressionintGet the primitive (singleton) operator used: one of Token.FEQ, Token.FNE, Token.FLT, Token.FGT, Token.FLE, Token.FGEstatic booleaninterpretComparisonResult(int operator, int c) Interpret the result of the comparisonoptimize(ExpressionVisitor visitor, ContextItemStaticInfo contextInfo) Perform optimisation of an expression and its subexpressions.Methods inherited from class net.sf.saxon.expr.UnaryExpressioncomputeCardinality, computeHashCode, displayOperator, emitExtraAttributes, equals, export, getBaseExpression, getOperand, operands, setBaseExpression, toShortString, toString, typeCheckMethods inherited from class net.sf.saxon.expr.ExpressionaddToPathMap, adoptChildExpression, allowExtractingCommonSubexpressions, checkedOperands, checkForUpdatingSubexpressions, checkPermittedContents, computeDependencies, computeStaticProperties, copy, dispatchTailCall, dynamicError, effectiveBooleanValue, evaluateAsString, explain, getCardinality, getConfiguration, getCost, getDependencies, getElaborator, getEvaluationMethod, getExpressionName, getExtraProperty, getIntegerBounds, getIntrinsicDependencies, 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, simplify, 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.expr.ComparisonExpressiongetAtomicComparer, getStringCollatorMethods inherited from interface net.sf.saxon.trace.TraceablegatherProperties
- 
Field Details- 
operatorprotected int operator
 
- 
- 
Constructor Details- 
CompareToConstant
 
- 
- 
Method Details- 
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
 
- 
getLhsExpressionDescription copied from interface:ComparisonExpressionGet the left-hand expression- Specified by:
- getLhsExpressionin interface- ComparisonExpression
- Returns:
- the first operand expression
 
- 
getLhsDescription copied from interface:ComparisonExpressionGet the left-hand operand of the comparison- Specified by:
- getLhsin interface- ComparisonExpression
- Returns:
- the first operand
 
- 
getRhsExpressionDescription copied from interface:ComparisonExpressionGet the right-hand expression- Specified by:
- getRhsExpressionin interface- ComparisonExpression
- Returns:
- the second operand expression
 
- 
getRhsDescription copied from interface:ComparisonExpressionGet the right-hand operand of the comparison- Specified by:
- getRhsin interface- ComparisonExpression
- Returns:
- the second operand
 
- 
getComparisonOperatorpublic int getComparisonOperator()Get the comparison operator
- 
getImplementationMethodpublic int getImplementationMethod()An implementation of Expression must provide at least one of the methods evaluateItem(), iterate(), or process(). This method indicates which of these methods is provided directly. The other methods will always be available indirectly, using an implementation that relies on one of the other methods.- Specified by:
- getImplementationMethodin class- Expression
- Returns:
- the value Expression.EVALUATE_METHOD
 
- 
computeSpecialPropertiesprotected int computeSpecialProperties()Description copied from class:UnaryExpressionGet the static properties of this expression (other than its type). The result is bit-signficant. These properties are used for optimizations. In general, if property bit is set, it is true, but if it is unset, the value is unknown.- Overrides:
- computeSpecialPropertiesin class- UnaryExpression
- Returns:
- the special properties, as a bit-significant integer
 
- 
evaluateItemEvaluate an expression as a single item. This always returns either a single Item or null (denoting the empty sequence). No conversion is done. This method should not be used unless the static type of the expression is a subtype of "item" or "item?": that is, it should not be called if the expression may return a sequence. There is no guarantee that this condition will be detected.- Overrides:
- evaluateItemin class- Expression
- 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
 
- 
optimizepublic Expression optimize(ExpressionVisitor visitor, ContextItemStaticInfo contextInfo) throws XPathException Perform optimisation of an expression and its subexpressions. This is the third and final phase of static optimization.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:
- optimizein class- UnaryExpression
- Parameters:
- visitor- the expression visitor
- contextInfo- 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
- Returns:
- the original expression, rewritten if appropriate to optimize execution
- Throws:
- XPathException- if an error is discovered during this phase (typically a type error)
 
- 
getItemTypeDetermine the data type of the expression, if possible. All expression return sequences, in general; this method determines the type of the items within the sequence, assuming that (a) this is known in advance, and (b) it is the same for all items in the sequence.This method should always return a result, though it may be the best approximation that is available at the time. - Overrides:
- getItemTypein class- UnaryExpression
- Returns:
- a value such as Type.STRING, Type.BOOLEAN, Type.NUMBER, Type.NODE, or Type.ITEM (meaning not known at compile time)
 
- 
getSingletonOperatorpublic int getSingletonOperator()Get the primitive (singleton) operator used: one of Token.FEQ, Token.FNE, Token.FLT, Token.FGT, Token.FLE, Token.FGE- Specified by:
- getSingletonOperatorin interface- ComparisonExpression
- Returns:
- the operator, as defined in class Token
 
- 
convertsUntypedToOtherpublic boolean convertsUntypedToOther()Determine whether untyped atomic values should be converted to the type of the other operand- Specified by:
- convertsUntypedToOtherin interface- ComparisonExpression
- Returns:
- true if untyped values should be converted to the type of the other operand, false if they should be converted to strings.
 
- 
interpretComparisonResultpublic static boolean interpretComparisonResult(int operator, int c) Interpret the result of the comparison
 
-