Package net.sf.saxon.value
Class BigIntegerValue
java.lang.Object
net.sf.saxon.value.Value
net.sf.saxon.value.AtomicValue
net.sf.saxon.value.NumericValue
net.sf.saxon.value.IntegerValue
net.sf.saxon.value.BigIntegerValue
- All Implemented Interfaces:
Serializable,Comparable,PullEvent,SequenceIterable,GroundedValue,Item,ValueRepresentation,ConversionResult
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
- See Also:
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final BigIntegerstatic final BigIntegerstatic final BigIntegerstatic final BigIntegerValueFields inherited from class net.sf.saxon.value.IntegerValue
MINUS_ONE, PLUS_ONE, SMALL_INTEGERSFields inherited from class net.sf.saxon.value.AtomicValue
typeLabelFields inherited from class net.sf.saxon.value.Value
EMPTY_CLASS_ARRAY, INDETERMINATE_ORDERINGFields inherited from interface net.sf.saxon.om.ValueRepresentation
EMPTY_VALUE_ARRAY -
Constructor Summary
ConstructorsConstructorDescriptionBigIntegerValue(long value) Construct an xs:integer value from a Java long.BigIntegerValue(BigInteger value) Construct an xs:integer value from a Java BigIntegerBigIntegerValue(BigInteger value, AtomicType typeLabel) Construct an xs:integer value from a Java BigInteger, supplying a type label. -
Method Summary
Modifier and TypeMethodDescriptionGet the value as a BigIntegerConvert the value to a BigDecimalceiling()Implement the XPath ceiling() functionintcompareTo(long other) Compare the value to a longintCompare the value to another numeric valueconvertPrimitive(BuiltInAtomicType requiredType, boolean validate, XPathContext context) Convert to target data typeconvertToSubType(BuiltInAtomicType type, boolean validate) This class allows subtypes of xs:integer to be held, as well as xs:integer values.copyAsSubType(AtomicType typeLabel) Create a copy of this atomic value, with a different type labeldiv(IntegerValue other) Divide by another integerbooleanReturn the effective boolean value of this integerfloor()Implement the XPath floor() functionGet the numeric value converted to a decimaldoubleGet the numeric value as a doubleGet an object that implements XML Schema comparison semanticsGet the value as a StringinthashCode()Get the hashCode.idiv(IntegerValue other) Integer divide by another integerbooleanDetermine whether the value is a whole number, that is, whether it compares equal to some integerbooleanTest whether the value is within the range that can be held in a 64-bit signed integerlongGet the value as a longminus(IntegerValue other) Subtract another integermod(IntegerValue other) Take modulo another integernegate()Negate the valueplus(IntegerValue other) Add another integerreduce()Reduce a value to its simplest form.round()Implement the XPath round() functionroundHalfToEven(int scale) Implement the XPath round-to-half-even() functiondoublesignum()Determine whether the value is negative, zero, or positivetimes(IntegerValue other) Multiply by another integerThis class allows subtypes of xs:integer to be held, as well as xs:integer values.Methods inherited from class net.sf.saxon.value.IntegerValue
checkBigRange, checkRange, getPrimitiveType, makeIntegerValue, signum, stringToIntegerMethods inherited from class net.sf.saxon.value.NumericValue
equals, getFloatValue, getXPathComparable, isInteger, parseNumber, promote, toStringMethods inherited from class net.sf.saxon.value.AtomicValue
asAtomic, checkPermittedContents, convert, convert, getCardinality, getComponent, getItemType, getLength, getStringValueCS, getTypedValue, getTypeLabel, isNaN, itemAt, iterate, process, setTypeLabel, subsequenceMethods inherited from class net.sf.saxon.value.Value
asItem, asItem, asIterator, asValue, convertToJava, fromItem, getCanonicalLexicalRepresentation, getIterator, iterate, makeQNameValue, stringToNumber
-
Field Details
-
MAX_LONG
-
MIN_LONG
-
MAX_UNSIGNED_LONG
-
ZERO
-
-
Constructor Details
-
BigIntegerValue
Construct an xs:integer value from a Java BigInteger- Parameters:
value- the supplied BigInteger
-
BigIntegerValue
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 Details
-
copyAsSubType
Create a copy of this atomic value, with a different type label- Specified by:
copyAsSubTypein 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
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:
convertToSubTypein 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
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:
validateAgainstSubTypein 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:
hashCodein classNumericValue- Returns:
- the hash code of the numeric value
- See Also:
-
longValue
public long longValue()Get the value as a long- Overrides:
longValuein classNumericValue- Returns:
- the value of the xs:integer, as a Java long
-
asBigInteger
Get the value as a BigInteger- Specified by:
asBigIntegerin 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
Convert the value to a BigDecimal- Returns:
- the resulting BigDecimal
-
effectiveBooleanValue
public boolean effectiveBooleanValue()Return the effective boolean value of this integer- Overrides:
effectiveBooleanValuein classAtomicValue- Returns:
- false if the integer is zero, otherwise true
-
compareTo
Compare the value to another numeric value- Specified by:
compareToin interfaceComparable- Overrides:
compareToin 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:
compareToin 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
-
convertPrimitive
public ConversionResult convertPrimitive(BuiltInAtomicType requiredType, boolean validate, XPathContext context) Convert to target data type- Specified by:
convertPrimitivein classAtomicValue- Parameters:
requiredType- identifies the required atomic typevalidate- 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.context- the XPath dynamic evaluation context- Returns:
- an AtomicValue, a value of the required type; or an ErrorValue
-
getStringValue
Get the value as a String- Specified by:
getStringValuein interfaceItem- Specified by:
getStringValuein interfaceValueRepresentation- Specified by:
getStringValuein classAtomicValue- Returns:
- a String representation of the value
- See Also:
-
getDoubleValue
public double getDoubleValue()Get the numeric value as a double- Overrides:
getDoubleValuein classNumericValue- Returns:
- A double representing this numeric value; NaN if it cannot be converted
-
getDecimalValue
Get the numeric value converted to a decimal- Overrides:
getDecimalValuein classNumericValue- Returns:
- a decimal representing this numeric value;
-
negate
Negate the value- Specified by:
negatein classNumericValue- Returns:
- the result of inverting the sign of the value
-
floor
Implement the XPath floor() function- Specified by:
floorin classNumericValue- Returns:
- the integer value, unchanged
-
ceiling
Implement the XPath ceiling() function- Specified by:
ceilingin classNumericValue- Returns:
- the integer value, unchanged
-
round
Implement the XPath round() function- Specified by:
roundin classNumericValue- Returns:
- the integer value, unchanged
-
roundHalfToEven
Implement the XPath round-to-half-even() function- Specified by:
roundHalfToEvenin 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 double signum()Determine whether the value is negative, zero, or positive- Specified by:
signumin classNumericValue- Returns:
- -1 if negative, 0 if zero, +1 if positive, NaN if NaN
-
isWholeNumber
public boolean isWholeNumber()Determine whether the value is a whole number, that is, whether it compares equal to some integer- Overrides:
isWholeNumberin classIntegerValue- Returns:
- always true for this implementation
-
plus
Add another integer- Specified by:
plusin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the addition
-
minus
Subtract another integer- Specified by:
minusin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the subtraction
-
times
Multiply by another integer- Specified by:
timesin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the multiplication
-
div
Divide by another integer- Specified by:
divin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the division
- Throws:
XPathException- if the other integer is zero
-
mod
Take modulo another integer- Specified by:
modin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the modulo operation (the remainder)
- Throws:
XPathException- if the other integer is zero
-
idiv
Integer divide by another integer- Specified by:
idivin classIntegerValue- Parameters:
other- the other integer- Returns:
- the result of the integer division
- Throws:
XPathException- if the other integer is zero
-
getSchemaComparable
Get an object that implements XML Schema comparison semantics- Specified by:
getSchemaComparablein classAtomicValue- Returns:
- a Comparable that follows XML Schema comparison rules
-
reduce
Reduce a value to its simplest form.- Overrides:
reducein classValue- Returns:
- the value in simplified form
- Throws:
XPathException
-