Package net.sf.saxon.value
Class BigIntegerValue
- java.lang.Object
-
- net.sf.saxon.value.AtomicValue
-
- net.sf.saxon.value.NumericValue
-
- net.sf.saxon.value.DecimalValue
-
- net.sf.saxon.value.IntegerValue
-
- net.sf.saxon.value.BigIntegerValue
-
- All Implemented Interfaces:
java.lang.Comparable<NumericValue>
,java.lang.Iterable<AtomicValue>
,AtomicMatchKey
,AtomicSequence
,GroundedValue
,IdentityComparable
,Item
,Sequence
,ConversionResult
public final class BigIntegerValue extends IntegerValue
An integer value: note this is a subtype of decimal in XML Schema, not a primitive type. The abstract class IntegerValue is used to represent any xs:integer value; this implementation is used for values that do not fit comfortably in a Java long; including the built-in subtype xs:unsignedLong
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected static class
BigIntegerValue.BigIntegerComparable
A Comparable that performs comparison of BigInteger values either with other BigInteger values or with other representations of XPath numeric values
-
Field Summary
Fields Modifier and Type Field Description static java.math.BigInteger
MAX_LONG
static java.math.BigInteger
MAX_UNSIGNED_LONG
static java.math.BigInteger
MIN_LONG
static BigIntegerValue
ZERO
-
Fields inherited from class net.sf.saxon.value.AtomicValue
typeLabel
-
Fields inherited from interface net.sf.saxon.expr.sort.AtomicMatchKey
NaN_MATCH_KEY
-
-
Constructor Summary
Constructors Constructor Description BigIntegerValue(long value)
Construct an xs:integer value from a Java long.BigIntegerValue(java.math.BigInteger value)
Construct an xs:integer value from a Java BigIntegerBigIntegerValue(java.math.BigInteger value, AtomicType typeLabel)
Construct an xs:integer value from a Java BigInteger, supplying a type label.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description NumericValue
abs()
Get the absolute value as defined by the XPath abs() functionBigIntegerValue
asAtomic()
Calling this method on a ConversionResult returns the AtomicValue that results from the conversion if the conversion was successful, and throws a ValidationException explaining the conversion error otherwise.java.math.BigInteger
asBigInteger()
Get the value as a BigIntegerjava.math.BigDecimal
asDecimal()
Convert the value to a BigDecimalint
asSubscript()
Test whether a number is a possible subscript into a sequence, that is, a whole number greater than zero and less than 2^31NumericValue
ceiling()
Implement the XPath ceiling() functionint
compareTo(long other)
Compare the value to a longint
compareTo(NumericValue other)
Compare the value to another numeric valueValidationFailure
convertToSubType(BuiltInAtomicType type, boolean validate)
This class allows subtypes of xs:integer to be held, as well as xs:integer values.AtomicValue
copyAsSubType(AtomicType typeLabel)
Create a copy of this atomic value, with a different type labelNumericValue
div(IntegerValue other)
Divide by another integerboolean
effectiveBooleanValue()
Return the effective boolean value of this integerNumericValue
floor()
Implement the XPath floor() functionjava.math.BigDecimal
getDecimalValue()
Get the numeric value converted to a decimaldouble
getDoubleValue()
Get the numeric value as a doublefloat
getFloatValue()
Get the numeric value converted to a floatjava.lang.String
getPrimitiveStringValue()
Get the value as a Stringjava.lang.Comparable
getSchemaComparable()
Get an object that implements XML Schema comparison semanticsint
hashCode()
Get the hashCode.IntegerValue
idiv(IntegerValue other)
Integer divide by another integerboolean
isWholeNumber()
Determine whether the value is a whole number, that is, whether it compares equal to some integerboolean
isWithinLongRange()
Test whether the value is within the range that can be held in a 64-bit signed integerlong
longValue()
Get the value as a longIntegerValue
minus(IntegerValue other)
Subtract another integerIntegerValue
mod(IntegerValue other)
Take modulo another integerNumericValue
negate()
Negate the valueIntegerValue
plus(IntegerValue other)
Add another integerIntegerValue
reduce()
Reduce a value to its simplest form.NumericValue
round(int scale)
Implement the XPath round() functionNumericValue
roundHalfToEven(int scale)
Implement the XPath round-to-half-even() functionint
signum()
Determine whether the value is negative, zero, or positiveIntegerValue
times(IntegerValue other)
Multiply by another integerValidationFailure
validateAgainstSubType(BuiltInAtomicType type)
This class allows subtypes of xs:integer to be held, as well as xs:integer values.-
Methods inherited from class net.sf.saxon.value.IntegerValue
castableAsInteger, checkBigRange, checkRange, div, getMaxInclusive, getMinInclusive, getPrimitiveType, idiv, isIdentical, makeIntegerValue, makeIntegerValue, makeIntegerValue, mod, signum, stringToInteger
-
Methods inherited from class net.sf.saxon.value.NumericValue
equals, getXPathComparable, isInteger, isNegativeZero, parseNumber, toString
-
Methods inherited from class net.sf.saxon.value.AtomicValue
asMapKey, atomize, checkPermittedContents, checkValidInJavascript, getCanonicalLexicalRepresentation, getCardinality, getComponent, getGenre, getItemType, getLength, getStringValue, getStringValueCS, getUType, head, identityHashCode, isIdentical, isNaN, itemAt, iterate, iterator, setTypeLabel
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface net.sf.saxon.om.GroundedValue
asIterable, concatenate, containsNode, materialize
-
Methods inherited from interface net.sf.saxon.om.Item
isStreamed, subsequence, toShortString
-
Methods inherited from interface net.sf.saxon.om.Sequence
makeRepeatable
-
-
-
-
Field Detail
-
MAX_LONG
public static final java.math.BigInteger MAX_LONG
-
MIN_LONG
public static final java.math.BigInteger MIN_LONG
-
MAX_UNSIGNED_LONG
public static final java.math.BigInteger MAX_UNSIGNED_LONG
-
ZERO
public static final BigIntegerValue ZERO
-
-
Constructor Detail
-
BigIntegerValue
public BigIntegerValue(java.math.BigInteger value)
Construct an xs:integer value from a Java BigInteger- Parameters:
value
- the supplied BigInteger
-
BigIntegerValue
public BigIntegerValue(java.math.BigInteger value, AtomicType typeLabel)
Construct an xs:integer value from a Java BigInteger, supplying a type label. It is the caller's responsibility to ensure that the supplied value conforms with the rules for the specified type.- Parameters:
value
- the value of the integertypeLabel
- the type, which must represent a type derived from xs:integer
-
BigIntegerValue
public BigIntegerValue(long value)
Construct an xs:integer value from a Java long. Note: normally, if the value fits in a long, then an Int64Value should be used. This constructor is largely for internal use, when operations are required that require two integers to use the same implementation class to be used.- Parameters:
value
- the supplied Java long
-
-
Method Detail
-
copyAsSubType
public AtomicValue copyAsSubType(AtomicType typeLabel)
Create a copy of this atomic value, with a different type label- Specified by:
copyAsSubType
in classAtomicValue
- Parameters:
typeLabel
- the type label of the new copy. The caller is responsible for checking that the value actually conforms to this type.- Returns:
- the copied value
-
convertToSubType
public ValidationFailure convertToSubType(BuiltInAtomicType type, boolean validate)
This class allows subtypes of xs:integer to be held, as well as xs:integer values. This method sets the required type label. Note that this method modifies the value in situ.- Specified by:
convertToSubType
in classIntegerValue
- Parameters:
type
- the subtype of integer requiredvalidate
- true if validation is required, false if the caller warrants that the value is valid for the subtype- Returns:
- null if the operation succeeds, or a ValidationException if the value is out of range
-
validateAgainstSubType
public ValidationFailure validateAgainstSubType(BuiltInAtomicType type)
This class allows subtypes of xs:integer to be held, as well as xs:integer values. This method checks that the value is valid against the rules for a given subtype.- Specified by:
validateAgainstSubType
in classIntegerValue
- Parameters:
type
- the subtype of integer required- Returns:
- null if the operation succeeds, or a ValidationException if the value is out of range
-
hashCode
public int hashCode()
Get the hashCode. This must conform to the rules for other NumericValue hashcodes- Specified by:
hashCode
in classNumericValue
- Returns:
- the hash code of the numeric value
- See Also:
NumericValue.hashCode()
-
longValue
public long longValue()
Get the value as a long- Specified by:
longValue
in classNumericValue
- Returns:
- the value of the xs:integer, as a Java long
-
asBigInteger
public java.math.BigInteger asBigInteger()
Get the value as a BigInteger- Specified by:
asBigInteger
in classIntegerValue
- Returns:
- the value of the xs:integer as a Java BigInteger
-
isWithinLongRange
public boolean isWithinLongRange()
Test whether the value is within the range that can be held in a 64-bit signed integer- Returns:
- true if the value is within range for a long
-
asDecimal
public java.math.BigDecimal asDecimal()
Convert the value to a BigDecimal- Returns:
- the resulting BigDecimal
-
effectiveBooleanValue
public boolean effectiveBooleanValue()
Return the effective boolean value of this integer- Specified by:
effectiveBooleanValue
in interfaceGroundedValue
- Specified by:
effectiveBooleanValue
in classNumericValue
- Returns:
- false if the integer is zero, otherwise true
-
compareTo
public int compareTo(NumericValue other)
Compare the value to another numeric value- Specified by:
compareTo
in interfacejava.lang.Comparable<NumericValue>
- Overrides:
compareTo
in classNumericValue
- Parameters:
other
- the numeric value to be compared to this value- Returns:
- -1 if this value is less than the other, 0 if they are equal, +1 if this value is greater
-
compareTo
public int compareTo(long other)
Compare the value to a long- Specified by:
compareTo
in classNumericValue
- Parameters:
other
- the value to be compared with- Returns:
- -1 if this is less, 0 if this is equal, +1 if this is greater or if this is NaN
-
getPrimitiveStringValue
public java.lang.String getPrimitiveStringValue()
Get the value as a String- Specified by:
getPrimitiveStringValue
in classAtomicValue
- Returns:
- a String representation of the value
-
getDoubleValue
public double getDoubleValue()
Get the numeric value as a double- Specified by:
getDoubleValue
in classNumericValue
- Returns:
- A double representing this numeric value; NaN if it cannot be converted
-
getDecimalValue
public java.math.BigDecimal getDecimalValue()
Get the numeric value converted to a decimal- Specified by:
getDecimalValue
in classIntegerValue
- Returns:
- a decimal representing this numeric value;
-
getFloatValue
public float getFloatValue()
Get the numeric value converted to a float- Specified by:
getFloatValue
in classNumericValue
- Returns:
- a float representing this numeric value; NaN if it cannot be converted
-
negate
public NumericValue negate()
Negate the value- Specified by:
negate
in classNumericValue
- Returns:
- the result of inverting the sign of the value
-
floor
public NumericValue floor()
Implement the XPath floor() function- Specified by:
floor
in classNumericValue
- Returns:
- the integer value, unchanged
-
ceiling
public NumericValue ceiling()
Implement the XPath ceiling() function- Specified by:
ceiling
in classNumericValue
- Returns:
- the integer value, unchanged
-
round
public NumericValue round(int scale)
Implement the XPath round() function- Specified by:
round
in classNumericValue
- Parameters:
scale
- the number of decimal places required in the result (supply 0 for rounding to an integer)- Returns:
- the integer value, unchanged
-
roundHalfToEven
public NumericValue roundHalfToEven(int scale)
Implement the XPath round-to-half-even() function- Specified by:
roundHalfToEven
in classNumericValue
- Parameters:
scale
- number of digits required after the decimal point; the value -2 (for example) means round to a multiple of 100- Returns:
- if the scale is >=0, return this value unchanged. Otherwise round it to a multiple of 10**-scale
-
signum
public int signum()
Determine whether the value is negative, zero, or positive- Specified by:
signum
in classNumericValue
- Returns:
- -1 if negative, 0 if zero, +1 if positive, NaN if NaN
-
abs
public NumericValue abs()
Get the absolute value as defined by the XPath abs() function- Specified by:
abs
in classNumericValue
- Returns:
- the absolute value
-
isWholeNumber
public boolean isWholeNumber()
Determine whether the value is a whole number, that is, whether it compares equal to some integer- Overrides:
isWholeNumber
in classIntegerValue
- Returns:
- always true for this implementation
-
asSubscript
public int asSubscript()
Test whether a number is a possible subscript into a sequence, that is, a whole number greater than zero and less than 2^31- Specified by:
asSubscript
in classNumericValue
- Returns:
- the number as an int if it is a possible subscript, or -1 otherwise
-
plus
public IntegerValue plus(IntegerValue other)
Add another integer- Specified by:
plus
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the addition
-
minus
public IntegerValue minus(IntegerValue other)
Subtract another integer- Specified by:
minus
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the subtraction
-
times
public IntegerValue times(IntegerValue other)
Multiply by another integer- Specified by:
times
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the multiplication
-
div
public NumericValue div(IntegerValue other) throws XPathException
Divide by another integer- Specified by:
div
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the division
- Throws:
XPathException
- if the other integer is zero
-
mod
public IntegerValue mod(IntegerValue other) throws XPathException
Take modulo another integer- Specified by:
mod
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the modulo operation (the remainder)
- Throws:
XPathException
- if the other integer is zero
-
idiv
public IntegerValue idiv(IntegerValue other) throws XPathException
Integer divide by another integer- Specified by:
idiv
in classIntegerValue
- Parameters:
other
- the other integer- Returns:
- the result of the integer division
- Throws:
XPathException
- if the other integer is zero
-
getSchemaComparable
public java.lang.Comparable getSchemaComparable()
Get an object that implements XML Schema comparison semantics- Specified by:
getSchemaComparable
in interfaceAtomicSequence
- Specified by:
getSchemaComparable
in classAtomicValue
- Returns:
- a Comparable that follows XML Schema comparison rules
-
reduce
public IntegerValue reduce()
Reduce a value to its simplest form.- Returns:
- the simplified sequence
-
asAtomic
public BigIntegerValue asAtomic()
Description copied from class:AtomicValue
Calling this method on a ConversionResult returns the AtomicValue that results from the conversion if the conversion was successful, and throws a ValidationException explaining the conversion error otherwise.Use this method if you are calling a conversion method that returns a ConversionResult, and if you want to throw an exception if the conversion fails.
- Specified by:
asAtomic
in interfaceAtomicMatchKey
- Specified by:
asAtomic
in interfaceConversionResult
- Overrides:
asAtomic
in classAtomicValue
- Returns:
- the atomic value that results from the conversion if the conversion was successful
-
-