net.sf.saxon.functions
Class FormatNumber2
java.lang.Object
net.sf.saxon.expr.ComputedExpression
net.sf.saxon.expr.FunctionCall
net.sf.saxon.functions.SystemFunction
net.sf.saxon.functions.FormatNumber2
- All Implemented Interfaces:
- Container, Expression, InstructionInfoProvider, java.io.Serializable, javax.xml.transform.SourceLocator, XSLTFunction
- public class FormatNumber2
- extends SystemFunction
- implements XSLTFunction
XSLT 2.0 implementation of format-number() function - removes the dependence on the JDK.
- See Also:
- Serialized Form
Methods inherited from class net.sf.saxon.functions.SystemFunction |
addContextDocumentArgument, computeCardinality, computeSpecialProperties, display, getDetails, getErrorCodeForTypeErrors, getItemType, getRequiredType, main, makeSystemFunction, setDetails, useContextItemAsDefault |
Methods inherited from class net.sf.saxon.expr.FunctionCall |
checkArgumentCount, getDisplayName, getFunctionNameCode, getNumberOfArguments, iterateSubExpressions, optimize, promote, setArguments, setFunctionNameCode, simplify, simplifyArguments, typeCheck |
Methods inherited from class net.sf.saxon.expr.ComputedExpression |
adoptChildExpression, checkPermittedContents, computeDependencies, computeStaticProperties, doPromotion, dynamicError, dynamicError, effectiveBooleanValue, getCardinality, getColumnNumber, getConstructType, getDependencies, getExecutable, getHostLanguage, getImplementationMethod, getInstructionInfo, getIntrinsicDependencies, getLineNumber, getLocationId, getLocationProvider, getParentExpression, getPublicId, getSlotsUsed, getSpecialProperties, getSystemId, hasBadParentPointer, iterate, markTailFunctionCalls, process, resetStaticProperties, setLocationId, setParentExpression, suppressValidation, typeError, typeError |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
FormatNumber2
public FormatNumber2()
checkArguments
public void checkArguments(StaticContext env)
throws XPathException
- Description copied from class:
SystemFunction
- Method called during static type checking
- Overrides:
checkArguments
in class SystemFunction
- Throws:
XPathException
fixup
public void fixup(DecimalSymbols dfs)
- Fixup: this is a callback from the DecimalFormatManager used once the xsl:decimal-format
element is identified
preEvaluate
public Expression preEvaluate(StaticContext env)
throws XPathException
- preEvaluate: this method suppresses compile-time evaluation by doing nothing.
We can't evaluate early because we don't have access to the DecimalFormatManager.
- Overrides:
preEvaluate
in class FunctionCall
- Throws:
XPathException
evaluateAsString
public java.lang.String evaluateAsString(XPathContext context)
throws XPathException
- Evaluate in a context where a string is wanted
- Specified by:
evaluateAsString
in interface Expression
- Overrides:
evaluateAsString
in class ComputedExpression
- Parameters:
context
- The context in which the expression is to be evaluated
- Returns:
- the value of the expression, evaluated in the current context.
The expression must return a string or (); if the value of the
expression is (), this method returns "".
- Throws:
XPathException
- if any dynamic error occurs evaluating the
expression
evaluateItem
public Item evaluateItem(XPathContext c)
throws XPathException
- Evaluate in a general context
- Specified by:
evaluateItem
in interface Expression
- Overrides:
evaluateItem
in class ComputedExpression
- Parameters:
c
- 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
adjustToDecimal
public static java.math.BigDecimal adjustToDecimal(double value,
int precision)
- Convert a double to a BigDecimal. In general there will be several BigDecimal values that
are equal to the supplied value, and the one we want to choose is the one with fewest non-zero
digits. The algorithm used is rather pragmatic: look for a string of zeroes or nines, try rounding
the number down or up as approriate, then convert the adjusted value to a double to see if it's
equal to the original: if not, use the original value unchanged.
- Parameters:
value
- the double to be convertedprecision
- 2 for a double, 1 for a float
- Returns:
- the result of conversion to a double