Class DayTimeDurationValue
- All Implemented Interfaces:
- Comparable<XPathComparable>,- Iterable<AtomicValue>,- AtomicMatchKey,- XPathComparable,- AtomicSequence,- GroundedValue,- IdentityComparable,- Item,- Sequence,- ConversionResult,- ContextFreeAtomicValue
Internally this is held as an integer number of seconds held in a positive long, a positive integer number of microseconds in the range 0 to 999,999,999, and a boolean sign. Some of the constructor and accessor methods cannot handle the full range of values.
- 
Nested Class SummaryNested classes/interfaces inherited from class net.sf.saxon.value.DurationValueDurationValue.DurationComparable
- 
Field SummaryFields inherited from class net.sf.saxon.value.DurationValue_months, _nanoseconds, _negative, _secondsFields inherited from class net.sf.saxon.value.AtomicValuetypeLabel
- 
Constructor SummaryConstructorsConstructorDescriptionDayTimeDurationValue(int sign, int days, int hours, int minutes, long seconds, int microseconds) Create a dayTimeDuration given the number of days, hours, minutes, and seconds.DayTimeDurationValue(int days, int hours, int minutes, long seconds, int nanoseconds) Create a dayTimeDuration given the number of days, hours, minutes, seconds, and nanoseconds.DayTimeDurationValue(int days, int hours, int minutes, long seconds, int nanoseconds, AtomicType typeLabel) Create a dayTimeDuration given the number of days, hours, minutes, seconds, and nanoseconds.
- 
Method SummaryModifier and TypeMethodDescriptionadd(DurationValue other) Add two dayTimeDurationsintcompareTo(XPathComparable other) Compare the value to another duration valuecopyAsSubType(AtomicType typeLabel) Create a copy of this atomic value, with a different type labeldivide(double n) Divide duration by a number.divide(DurationValue other) Find the ratio between two durationsstatic DayTimeDurationValuefromJavaDuration(Duration duration) Factory method taking a Java 8Durationobjectstatic DayTimeDurationValuefromMicroseconds(long microseconds) Construct a duration value as a number of microseconds.static DayTimeDurationValuefromMilliseconds(long milliseconds) Construct a duration value as a number of milliseconds.static DayTimeDurationValuefromNanoseconds(long nanoseconds) Construct a duration value as a number of nanoseconds.static DayTimeDurationValuefromSeconds(BigDecimal seconds) Construct a duration value as a number of seconds.static DayTimeDurationValuefromSeconds(BigDecimal seconds, AtomicType typeLabel) longGet the length of duration in microseconds, as a longlongGet the length of duration in microseconds, as a longdoubleGet the length of duration in seconds.Convert to stringDetermine the primitive type of the value.Get an XPathComparable object that supports the semantics of context-free eq and lt comparisons between atomic values.getXPathComparable(StringCollator collator, int implicitTimezone) Get an object value that implements the XPath equality and ordering comparison semantics for this value.getXPathMatchKey(StringCollator collator, int implicitTimezone) Get a Comparable value that implements the XPath ordering comparison semantics for this value.static ConversionResultFactory method: create a duration value from a supplied string, in ISO 8601 format[-]PnDTnHnMnSmultiply(double n) Multiply duration by a number.multiply(long factor) Multiply a duration by an integermultiply(BigDecimal factor) Multiply a duration by a decimalnegate()Negate a duration (same as subtracting from zero, but it preserves the type of the original duration)subtract(DurationValue other) Subtract two dayTime-durationsConvert this value to a Java 8DurationobjectMethods inherited from class net.sf.saxon.value.DurationValuebadDuration, badDuration, equals, formatFractionalSeconds, getComponent, getDays, getHours, getMicroseconds, getMinutes, getMonths, getNanoseconds, getSchemaComparable, getSeconds, getTotalMonths, getTotalSeconds, getYears, hashCode, isNegativeDuration, makeDuration, makeDuration, signum, simpleIntegerMethods inherited from class net.sf.saxon.value.AtomicValueasAtomic, asMapKey, atomize, checkPermittedContents, checkValidInJavascript, effectiveBooleanValue, getCanonicalLexicalRepresentation, getCardinality, getGenre, getItemType, getLength, getUnicodeStringValue, getUType, head, identityHashCode, isIdentical, isIdentical, isNaN, isUntypedAtomic, itemAt, iterate, iterator, show, toShortString, toStringMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface net.sf.saxon.expr.sort.AtomicMatchKeyasAtomicMethods inherited from interface net.sf.saxon.om.GroundedValueasIterable, concatenate, containsNode, materializeMethods inherited from interface net.sf.saxon.om.ItemgetStringValue, isStreamed, reduce, subsequenceMethods inherited from interface java.lang.IterableforEach, spliteratorMethods inherited from interface net.sf.saxon.om.SequencemakeRepeatable
- 
Constructor Details- 
DayTimeDurationValuepublic DayTimeDurationValue(int sign, int days, int hours, int minutes, long seconds, int microseconds) throws IllegalArgumentException Create a dayTimeDuration given the number of days, hours, minutes, and seconds. This constructor performs limited validation. The components (apart from sign) must all be non-negative integers; they need not be normalized (for example, 36 hours is acceptable)Note: for historic reasons this constructor only supports microsecond precision. For nanosecond precision, use the constructor DayTimeDurationValue(int, int, int, long, int)- Parameters:
- sign- positive number for positive durations, negative for negative duratoins
- days- number of days
- hours- number of hours
- minutes- number of minutes
- seconds- number of seconds
- microseconds- number of microseconds
- Throws:
- IllegalArgumentException- if the value is out of range; specifically, if the total number of seconds exceeds 2^63; or if any of the values is negative
 
- 
DayTimeDurationValuepublic DayTimeDurationValue(int days, int hours, int minutes, long seconds, int nanoseconds) throws IllegalArgumentException Create a dayTimeDuration given the number of days, hours, minutes, seconds, and nanoseconds. This constructor performs limited validation. The components need not be normalized (for example, 36 hours is acceptable)To construct a positive duration, all the component values should be positive integers (or zero). To construct a negative duration, all the component values should be negative integers (or zero). - Parameters:
- days- number of days
- hours- number of hours
- minutes- number of minutes
- seconds- number of seconds
- nanoseconds- number of nanoseconds
- Throws:
- IllegalArgumentException- if the value is out of range; specifically, if the total number of seconds exceeds 2^63; or if some values are positive and others are negative
 
- 
DayTimeDurationValuepublic DayTimeDurationValue(int days, int hours, int minutes, long seconds, int nanoseconds, AtomicType typeLabel) throws IllegalArgumentException Create a dayTimeDuration given the number of days, hours, minutes, seconds, and nanoseconds. This constructor performs limited validation. The components need not be normalized (for example, 36 hours is acceptable)To construct a positive duration, all the component values should be positive integers (or zero). To construct a negative duration, all the component values should be negative integers (or zero). - Parameters:
- days- number of days
- hours- number of hours
- minutes- number of minutes
- seconds- number of seconds
- nanoseconds- number of nanoseconds
- Throws:
- IllegalArgumentException- if the value is out of range; specifically, if the total number of seconds exceeds 2^63; or if some values are positive and others are negative
 
 
- 
- 
Method Details- 
makeDayTimeDurationValueFactory method: create a duration value from a supplied string, in ISO 8601 format[-]PnDTnHnMnS- Parameters:
- s- the lexical representation of the xs:dayTimeDuration value
- Returns:
- a DayTimeDurationValueif the format is correct, or aValidationFailureif not
 
- 
copyAsSubTypeCreate a copy of this atomic value, with a different type label- Overrides:
- copyAsSubTypein class- DurationValue
- 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
 
- 
getPrimitiveTypeDetermine the primitive type of the value. This delivers the same answer as getItemType().getPrimitiveItemType(). The primitive types are the 19 primitive types of XML Schema, plus xs:integer, xs:dayTimeDuration and xs:yearMonthDuration, and xs:untypedAtomic. For external objects, the result is AnyAtomicType.- Overrides:
- getPrimitiveTypein class- DurationValue
- Returns:
- the primitive type
 
- 
getPrimitiveStringValueConvert to string- Overrides:
- getPrimitiveStringValuein class- DurationValue
- Returns:
- ISO 8601 representation.
 
- 
getLengthInSecondspublic double getLengthInSeconds()Get the length of duration in seconds. Note this may involve loss of precision. For an exact result, useDurationValue.getTotalSeconds()- Overrides:
- getLengthInSecondsin class- DurationValue
- Returns:
- an approximation to the length of the duration in seconds, expressed as a double.
 
- 
getLengthInMicrosecondspublic long getLengthInMicroseconds()Get the length of duration in microseconds, as a long- Returns:
- the length in nanoseconds, divided by one thousand, rounded towards zero
- Throws:
- ArithmeticException- if the number of microseconds is too high to be returned as a long.
 
- 
getLengthInNanosecondspublic long getLengthInNanoseconds()Get the length of duration in microseconds, as a long- Returns:
- the length in nanoseconds, divided by one thousand, rounded towards zero
- Throws:
- ArithmeticException- if the number of nanoseconds is too high to be returned as a long.
 
- 
fromSecondsConstruct a duration value as a number of seconds.- Parameters:
- seconds- the number of seconds in the duration. May be negative
- Returns:
- the xs:dayTimeDuration value with the specified length
- Throws:
- ArithmeticException- if the number of (whole) seconds exceeds 2^63
 
- 
fromSeconds
- 
fromMillisecondsConstruct a duration value as a number of milliseconds.- Parameters:
- milliseconds- the number of milliseconds in the duration (may be negative)
- Returns:
- the corresponding xs:dayTimeDuration value
- Throws:
- ValidationException- if implementation-defined limits are exceeded, specifically if the total number of seconds exceeds 2^63.
 
- 
fromMicrosecondspublic static DayTimeDurationValue fromMicroseconds(long microseconds) throws IllegalArgumentException Construct a duration value as a number of microseconds.- Parameters:
- microseconds- the number of microseconds in the duration.
- Returns:
- the xs:dayTimeDuration represented by the given number of microseconds
- Throws:
- IllegalArgumentException
 
- 
fromNanosecondspublic static DayTimeDurationValue fromNanoseconds(long nanoseconds) throws IllegalArgumentException Construct a duration value as a number of nanoseconds.- Parameters:
- nanoseconds- the number of nanoseconds in the duration.
- Returns:
- the xs:dayTimeDuration represented by the given number of nanoseconds
- Throws:
- IllegalArgumentException
 
- 
fromJavaDurationFactory method taking a Java 8Durationobject- Parameters:
- duration- a duration as a Java 8- java.time.Duration
- Returns:
- the new xs:dayTimeDuration
- Since:
- 9.9
 
- 
toJavaDurationConvert this value to a Java 8Durationobject- Returns:
- the duration expressed as a Java 8 java.time.Duration
- Since:
- 9.9
 
- 
multiplyMultiply a duration by an integer- Overrides:
- multiplyin class- DurationValue
- Parameters:
- factor- the number to multiply by
- Returns:
- the result of the multiplication
- Throws:
- XPathException- if an error is detected
 
- 
multiplyMultiply duration by a number. Follows the semantics of op:multiply-dayTimeDuration.- Overrides:
- multiplyin class- DurationValue
- Parameters:
- n- the number to multiply by.
- Returns:
- the result of the multiplication
- Throws:
- XPathException- if the operand is Infinite or NaN, or if the resulting duration exceeds Saxon limits (2^63 seconds)
 
- 
multiplyDescription copied from class:DurationValueMultiply a duration by a decimal- Overrides:
- multiplyin class- DurationValue
- Parameters:
- factor- the number to multiply by
- Returns:
- the result of the multiplication
- Throws:
- XPathException- if an error is detected
 
- 
divideDivide duration by a number. Follows the semantics of op:divide-dayTimeDuration.- Overrides:
- dividein class- DurationValue
- Parameters:
- n- the number to divide by.
- Returns:
- the result of the division
- Throws:
- XPathException- if the operand is zero or NaN, or if the resulting duration exceeds Saxon limits (2^63 seconds)
 
- 
divideFind the ratio between two durations- Overrides:
- dividein class- DurationValue
- Parameters:
- other- the dividend
- Returns:
- the ratio, as a decimal
- Throws:
- XPathException- when dividing by zero, or when dividing two durations of different type
 
- 
addAdd two dayTimeDurations- Overrides:
- addin class- DurationValue
- Parameters:
- other- the duration to be added to this one
- Returns:
- the sum of the two durations
- Throws:
- XPathException- if an error is detected
 
- 
subtractSubtract two dayTime-durations- Overrides:
- subtractin class- DurationValue
- Parameters:
- other- the duration to be subtracted from this one
- Returns:
- the difference of the two durations
- Throws:
- XPathException- if an error is detected
 
- 
negateNegate a duration (same as subtracting from zero, but it preserves the type of the original duration)- Overrides:
- negatein class- DurationValue
- Returns:
- the original duration with its sign reversed, retaining its type
- Throws:
- IllegalArgumentException- in the extremely unlikely event that the duration is one that cannot be negated (because the limit for positive durations is one second off from the limit for negative durations)
 
- 
getXPathComparableDescription copied from class:AtomicValueGet an object value that implements the XPath equality and ordering comparison semantics for this value. A collation is supplied for comparing strings, and an implicit timezone for comparing date/time values that have no saved timezone. An atomic value may return itself as the result, provided that its ordering rules are independent of the collation and timezone, and provided that it implements the XPathComparable interface: which means that its compareTo, equals, and hashCode methods must be compatible with the rules for XPath value comparisons.- Overrides:
- getXPathComparablein class- DurationValue
- Parameters:
- collator- the collation to be used when comparing strings
- implicitTimezone- the implicit timezone in the dynamic context, used when comparing dates/times with and without timezone
- Returns:
- an Object that implements the XPath value comparison semantics with respect to this atomic value. For an atomic type that is not ordered (according to XPath rules), return null.
 
- 
getXPathComparableDescription copied from interface:ContextFreeAtomicValueGet an XPathComparable object that supports the semantics of context-free eq and lt comparisons between atomic values. Note that in many cases the returned XPathComparable will be the AtomicValue itself; however because of the constraints of the genericComparableinterface, this cannot be assumed.- Specified by:
- getXPathComparablein interface- ContextFreeAtomicValue
- Returns:
- an XPathComparable that can be used in comparisons with other atomic values.
 
- 
compareToCompare the value to another duration value- Specified by:
- compareToin interface- Comparable<XPathComparable>
- Parameters:
- other- The other dateTime value
- Returns:
- negative value if this one is the smaller, 0 if they are equal, positive value if this one is the greater.
- Throws:
- ClassCastException- if the other value is not a DayTimeDurationValue
 
- 
getXPathMatchKeyGet a Comparable value that implements the XPath ordering comparison semantics for this value. Returns null if the value is not comparable according to XPath rules. The default implementation returns the value itself. This is modified for types such as xs:duration which allow ordering comparisons in XML Schema, but not in XPath.- Overrides:
- getXPathMatchKeyin class- DurationValue
- Parameters:
- collator- Collation used for string comparison
- implicitTimezone- XPath dynamic context
- Returns:
- an Object whose equals() and hashCode() methods implement the XPath comparison semantics with respect to this atomic value. If ordered is specified, the result will either be null if no ordering is defined, or will be a Comparable
 
 
-