|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectnet.sf.saxon.value.Value
net.sf.saxon.value.AtomicValue
net.sf.saxon.value.NumericValue
net.sf.saxon.value.DecimalValue
public final class DecimalValue
A decimal value
| Nested Class Summary | |
|---|---|
protected static class |
DecimalValue.DecimalComparable
|
| Field Summary | |
|---|---|
static BigDecimal |
BIG_DECIMAL_ONE
|
static BigDecimal |
BIG_DECIMAL_ONE_MILLION
|
static BigInteger |
BIG_INTEGER_TEN
|
static int |
DIVIDE_PRECISION
|
static DecimalValue |
ONE
|
static DecimalValue |
ONE_POINT_ONE
|
static DecimalValue |
THREE
|
static DecimalValue |
TWO
|
static DecimalValue |
TWO_POINT_ONE
|
static DecimalValue |
ZERO
|
| Fields inherited from class net.sf.saxon.value.AtomicValue |
|---|
typeLabel |
| Fields inherited from class net.sf.saxon.value.Value |
|---|
INDETERMINATE_ORDERING |
| Fields inherited from interface net.sf.saxon.om.ValueRepresentation |
|---|
EMPTY_VALUE_ARRAY |
| Constructor Summary | |
|---|---|
DecimalValue(BigDecimal value)
Constructor supplying a BigDecimal |
|
DecimalValue(double in)
Constructor supplying a double |
|
DecimalValue(long in)
Constructor supplying a long integer |
|
| Method Summary | |
|---|---|
NumericValue |
abs()
Get the absolute value as defined by the XPath abs() function |
static boolean |
castableAsDecimal(CharSequence in)
Test whether a string is castable to a decimal value |
NumericValue |
ceiling()
Implement the XPath ceiling() function |
int |
compareTo(long other)
Compare the value to a long |
int |
compareTo(Object other)
Compare the value to another numeric value |
ConversionResult |
convertPrimitive(BuiltInAtomicType requiredType,
boolean validate,
ConversionRules rules)
Convert to target data type |
AtomicValue |
copyAsSubType(AtomicType typeLabel)
Create a copy of this atomic value, with a difNferent type label |
static FastStringBuffer |
decimalToString(BigDecimal value,
FastStringBuffer fsb)
Convert a decimal value to a string, using the XPath rules for formatting |
boolean |
effectiveBooleanValue()
Get the effective boolean value of the value |
NumericValue |
floor()
Implement the XPath floor() function |
CharSequence |
getCanonicalLexicalRepresentation()
Get the canonical lexical representation as defined in XML Schema. |
BigDecimal |
getDecimalValue()
Get the value |
CharSequence |
getPrimitiveStringValue()
Get the value as a String |
BuiltInAtomicType |
getPrimitiveType()
Determine the primitive type of the value. |
Comparable |
getSchemaComparable()
Get an object that implements XML Schema comparison semantics |
int |
hashCode()
Get the hashCode. |
boolean |
isIdentical(Value v)
Determine whether two atomic values are identical, as determined by XML Schema rules. |
boolean |
isWholeNumber()
Determine whether the value is a whole number, that is, whether it compares equal to some integer |
static ConversionResult |
makeDecimalValue(CharSequence in,
boolean validate)
Factory method to construct a DecimalValue from a string |
NumericValue |
negate()
Negate the value |
NumericValue |
round(int scale)
Implement the XPath round() function |
NumericValue |
roundHalfToEven(int scale)
Implement the XPath round-half-to-even() function |
double |
signum()
Determine whether the value is negative, zero, or positive |
| Methods inherited from class net.sf.saxon.value.NumericValue |
|---|
equals, getDoubleValue, getFloatValue, getXPathComparable, isInteger, longValue, parseNumber, toString |
| Methods inherited from class net.sf.saxon.value.AtomicValue |
|---|
asAtomic, checkPermittedContents, convert, convert, convert, getCardinality, getComponent, getItemType, getLength, getStringValue, getStringValueCS, getTypedValue, getTypeLabel, isNaN, itemAt, iterate, process, setTypeLabel, subsequence |
| Methods inherited from class net.sf.saxon.value.Value |
|---|
asItem, asItem, asIterator, asValue, convertToJava, fromItem, getIterator, iterate, reduce |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Field Detail |
|---|
public static final int DIVIDE_PRECISION
public static final BigDecimal BIG_DECIMAL_ONE
public static final BigInteger BIG_INTEGER_TEN
public static final BigDecimal BIG_DECIMAL_ONE_MILLION
public static final DecimalValue ZERO
public static final DecimalValue ONE
public static final DecimalValue ONE_POINT_ONE
public static final DecimalValue TWO
public static final DecimalValue TWO_POINT_ONE
public static final DecimalValue THREE
| Constructor Detail |
|---|
public DecimalValue(BigDecimal value)
value - the value of the DecimalValue
public DecimalValue(double in)
throws ValidationException
in - the value of the DecimalValue
ValidationExceptionpublic DecimalValue(long in)
in - the value of the DecimalValue| Method Detail |
|---|
public static ConversionResult makeDecimalValue(CharSequence in,
boolean validate)
in - the value of the DecimalValuevalidate - true if validation is required; false if the caller knows that the value is valid
public static boolean castableAsDecimal(CharSequence in)
in - the string to be tested
public AtomicValue copyAsSubType(AtomicType typeLabel)
copyAsSubType in class AtomicValuetypeLabel - the type label of the new copy. The caller is responsible for checking that
the value actually conforms to this type.
public BuiltInAtomicType getPrimitiveType()
getPrimitiveType in class AtomicValuepublic BigDecimal getDecimalValue()
getDecimalValue in class NumericValuepublic int hashCode()
hashCode in class NumericValueNumericValue.hashCode()public boolean effectiveBooleanValue()
AtomicValue
effectiveBooleanValue in class AtomicValue
public ConversionResult convertPrimitive(BuiltInAtomicType requiredType,
boolean validate,
ConversionRules rules)
convertPrimitive in class AtomicValuerequiredType - the required atomic type. This must either be a primitive type, or a built-in
type derived from the same primitive type as this atomic value.validate - true if validation is required. If set to false, the caller guarantees that
the value is valid for the target data type, and that further validation
is therefore not required.
Note that a validation failure may be reported even if validation was not requested.
public CharSequence getCanonicalLexicalRepresentation()
getCanonicalLexicalRepresentation in class Valuepublic CharSequence getPrimitiveStringValue()
getPrimitiveStringValue in class AtomicValue
public static FastStringBuffer decimalToString(BigDecimal value,
FastStringBuffer fsb)
value - the decimal value to be convertedfsb - the FastStringBuffer to which the value is to be appended
public NumericValue negate()
negate in class NumericValuepublic NumericValue floor()
floor in class NumericValuepublic NumericValue ceiling()
ceiling in class NumericValuepublic NumericValue round(int scale)
round in class NumericValuepublic NumericValue roundHalfToEven(int scale)
roundHalfToEven in class NumericValuescale - the decimal position for rounding: e.g. 2 rounds to a
multiple of 0.01, while -2 rounds to a multiple of 100
public double signum()
signum in class NumericValuepublic boolean isWholeNumber()
isWholeNumber in class NumericValuepublic NumericValue abs()
abs in class NumericValuepublic int compareTo(Object other)
compareTo in interface ComparablecompareTo in class NumericValueother - The other numeric value
public int compareTo(long other)
compareTo in class NumericValueother - the value to be compared with
public Comparable getSchemaComparable()
getSchemaComparable in class AtomicValuepublic boolean isIdentical(Value v)
Note that even this check ignores the type annotation of the value. The integer 3 and the short 3 are considered identical, even though they are not fully interchangeable. "Identical" means the same point in the value space, regardless of type annotation.
NaN is identical to itself.
isIdentical in class AtomicValuev - the other value to be compared with this one
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||