Class SaxonDuration
DurationValue.
 The JAXP specification for this class defines it in terms of XML Schema 1.0 semantics. This defines a structure with six independent components (year, month, day, hour, minute, second). This implementation is more aligned to the XPath 2.0 semantics of the data type, which essentially defines duration as an integer number of months plus a decimal number of seconds.
- 
Constructor SummaryConstructorsConstructorDescriptionSaxonDuration(DurationValue duration) Create a SaxonDuration that wraps a supplied DurationValue
- 
Method SummaryModifier and TypeMethodDescriptionComputes a new duration whose value isthis+rhs.voidAdds this duration to aCalendarobject.intPartial order relation comparison with thisDurationinstance.Get the underlying DurationValuegetField(DatatypeConstants.Field field) Gets the value of a field.intgetSign()Returns the sign of this duration in -1,0, or 1.Get the type of this duration, as one of the values xs:duration, xs:dayTimeDuration, or xs:yearMonthDuration.inthashCode()Returns a hash code consistent with the definition of the equals method.booleanisSet(DatatypeConstants.Field field) Checks if a field is set.multiply(BigDecimal factor) Computes a new duration whose value isfactortimes longer than the value of this duration.negate()Returns a newDurationobject whose value is-this.normalizeWith(Calendar startTimeInstant) Converts the years and months fields into the days field by using a specific time instant as the reference point.Computes a new duration whose value isthis-rhs.Methods inherited from class javax.xml.datatype.DurationaddTo, equals, getDays, getHours, getMinutes, getMonths, getSeconds, getTimeInMillis, getTimeInMillis, getYears, isLongerThan, isShorterThan, multiply, toString
- 
Constructor Details- 
SaxonDurationCreate a SaxonDuration that wraps a supplied DurationValue- Parameters:
- duration- the value to be wrapped.
 
 
- 
- 
Method Details- 
getDurationValueGet the underlying DurationValue- Returns:
- the underlying DurationValue
 
- 
getXMLSchemaTypeGet the type of this duration, as one of the values xs:duration, xs:dayTimeDuration, or xs:yearMonthDuration. (Note that the XML Schema namespace URI is used, whereas the current implementation of the superclass uses a provisional URI allocated in a 2003 W3C working draft)- Overrides:
- getXMLSchemaTypein class- Duration
- Returns:
- the type of this duration, as one of the values xs:duration, xs:dayTimeDuration, or xs:yearMonthDuration
 
- 
getSignpublic int getSign()Returns the sign of this duration in -1,0, or 1.
- 
getFieldGets the value of a field.Fields of a duration object may contain arbitrary large value. Therefore this method is designed to return a Numberobject.In case of YEARS, MONTHS, DAYS, HOURS, and MINUTES, the returned number will be a non-negative integer. In case of seconds, the returned number may be a non-negative decimal value. The Saxon implementation of duration uses normalized values. This means that the YEARS and DAYS fields may be arbitrarily large, but other components will be limited in size: for example MINUTES will never exceed 60 and MONTHS will never exceed 12. - Specified by:
- getFieldin class- Duration
- Parameters:
- field- one of the six Field constants (YEARS, MONTHS, DAYS, HOURS, MINUTES, or SECONDS.)
- Returns:
- If the specified field is present, this method returns
         a non-null non-negative Numberobject that represents its value. If it is not present, return null. For YEARS, MONTHS, DAYS, HOURS, and MINUTES, this method returns aBigIntegerobject. For SECONDS, this method returns aBigDecimal.
- Throws:
- NullPointerException- If the- fieldis- null.
 
- 
isSetChecks if a field is set. In this implementation, all fields are always set.
- 
addComputes a new duration whose value is this+rhs.This implementation follows the XPath semantics. This means that the operation will fail if the duration is not a yearMonthDuration or a dayTimeDuration - Specified by:
- addin class- Duration
- Parameters:
- rhs-- Durationto add to this- Duration
- Returns:
- non-null valid Duration object.
- Throws:
- NullPointerException- If the rhs parameter is null.
- IllegalStateException- If the durations are not both dayTimeDurations, or both yearMonthDurations.
- See Also:
 
- 
subtractComputes a new duration whose value is this-rhs.This implementation follows the XPath semantics. This means that the operation will fail if the duration is not a yearMonthDuration or a dayTimeDuration. - Overrides:
- subtractin class- Duration
- Parameters:
- rhs-- Durationto subtract from this- Duration
- Returns:
- non-null valid Duration object.
- Throws:
- NullPointerException- If the rhs parameter is null.
- IllegalStateException- If the durations are not both dayTimeDurations, or both yearMonthDurations.
- See Also:
 
- 
addToAdds this duration to aCalendarobject.Calls Calendar.add(int, int)in the order of YEARS, MONTHS, DAYS, HOURS, MINUTES, SECONDS, and MILLISECONDS if those fields are present. Because theCalendarclass uses int to hold values, there are cases where this method won't work correctly (for example if values of fields exceed the range of int.)Also, since this duration class is a Gregorian duration, this method will not work correctly if the given Calendarobject is based on some other calendar systems.Any fractional parts of this Durationobject beyond milliseconds will be simply ignored. For example, if this duration is "P1.23456S", then 1 is added to SECONDS, 234 is added to MILLISECONDS, and the rest will be unused.Note that because Calendar.add(int, int)is usingint,Durationwith values beyond the range ofintin its fields will cause overflow/underflow to the givenCalendar.XMLGregorianCalendar.add(javax.xml.datatype.Duration)provides the same basic operation as this method while avoiding the overflow/underflow issues.- Specified by:
- addToin class- Duration
- Parameters:
- calendar- A calendar object whose value will be modified.
- Throws:
- NullPointerException- if the calendar parameter is null.
 
- 
multiplyComputes a new duration whose value isfactortimes longer than the value of this duration.This implementation follows the XPath semantics. This means that it is defined only on yearMonthDuration and dayTimeDuration. Other cases produce an IllegalStateException. - Specified by:
- multiplyin class- Duration
- Parameters:
- factor- to multiply by
- Returns:
- returns a non-null valid Durationobject
- Throws:
- IllegalStateException- if operation produces fraction in the months field.
- NullPointerException- if the- factorparameter is- null.
 
- 
negateReturns a newDurationobject whose value is-this.Since the Durationclass is immutable, this method doesn't change the value of this object. It simply computes a new Duration object and returns it.
- 
normalizeWithConverts the years and months fields into the days field by using a specific time instant as the reference point. This implementation does not support this method - Specified by:
- normalizeWithin class- Duration
- Parameters:
- startTimeInstant-- Calendarreference point.
- Returns:
- Durationof years and months of this- Durationas days.
- Throws:
- NullPointerException- If the startTimeInstant parameter is null.
- UnsupportedOperationException- Always thrown by this implementation.
 
- 
comparePartial order relation comparison with this Durationinstance.This implementation follows the XPath semantics. This means that the result is defined only for dayTimeDuration and yearMonthDuration values, and the result is never indeterminate. Return: - DatatypeConstants.LESSERif this- Durationis shorter than- durationparameter
- DatatypeConstants.EQUALif this- Durationis equal to- durationparameter
- DatatypeConstants.GREATERif this- Durationis longer than- durationparameter
- DatatypeConstants.INDETERMINATEif a conclusive partial order relation cannot be determined
 - Specified by:
- comparein class- Duration
- Parameters:
- rhs- duration to compare
- Returns:
- the relationship between thisDurationanddurationparameter asDatatypeConstants.LESSER,DatatypeConstants.EQUAL,DatatypeConstants.GREATERorDatatypeConstants.INDETERMINATE.
- Throws:
- UnsupportedOperationException- If the underlying implementation cannot reasonably process the request, e.g. W3C XML Schema allows for arbitrarily large/small/precise values, the request may be beyond the implementations capability.
- NullPointerException- if- durationis- null.
- IllegalArgumentException- if the operands are not dayTimeDuration or yearMonthDuration values.
- See Also:
 
- 
hashCodepublic int hashCode()Returns a hash code consistent with the definition of the equals method.
 
-