public class GDurationBuilder extends Object implements GDurationSpecification, Serializable
GDurations.| Constructor and Description | 
|---|
| GDurationBuilder()Constructs an empty GDurationBuilder representing zero seconds. | 
| GDurationBuilder(GDurationSpecification gDuration)Constructs a GDurationBuilder from another GDurationBuilderSpecification. | 
| GDurationBuilder(int sign,
                int year,
                int month,
                int day,
                int hour,
                int minute,
                int second,
                BigDecimal fraction)Constructs a GDurationBuilder with the specified sign,
 year, month, day, hours, minutes, seconds, and optional
 fractional seconds. | 
| GDurationBuilder(String s)Constructs a GDuration from a lexical
 representation. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addGDuration(GDurationSpecification duration)Adds to this duration. | 
| Object | clone()Builds another GDurationBuilder with the same value
 as this one. | 
| int | compareToGDuration(GDurationSpecification duration)Comparison to another GDuration. | 
| int | getDay()Gets the day-of-month component. | 
| BigDecimal | getFraction()Gets the fraction-of-second. | 
| int | getHour()Gets the hour-of-day component. | 
| int | getMinute()Gets the minute-of-hour component. | 
| int | getMonth()Gets the month-of-year component. | 
| int | getSecond()Gets the second-of-minute component. | 
| int | getSign()Returns the sign of the duration: +1 is forwards
 and -1 is backwards in time. | 
| int | getYear()Gets the year component. | 
| boolean | isImmutable()All GDuration instances return true. | 
| boolean | isValid()Returns true if all of the individual components
 of the duration are nonnegative. | 
| void | normalize()Normalize a duration value. | 
| void | setDay(int day)Sets the day component. | 
| void | setFraction(BigDecimal fraction)Sets the fraction-of-second component. | 
| void | setHour(int hour)Sets the hour component. | 
| void | setMinute(int minute)Sets the minute component. | 
| void | setMonth(int month)Sets the month component. | 
| void | setSecond(int second)Sets the second component. | 
| void | setSign(int sign)Sets the sign. | 
| void | setYear(int year)Sets the year component. | 
| static String | stripTrailingZeros(String s) | 
| void | subtractGDuration(GDurationSpecification duration)Subtracts from this duration. | 
| GDuration | toGDuration()Builds a GDuration from this GDurationBuilder. | 
| static String | toPlainString(BigDecimal bd) | 
| String | toString()The natural string representation of the duration. | 
public GDurationBuilder()
public GDurationBuilder(String s)
public GDurationBuilder(int sign,
                        int year,
                        int month,
                        int day,
                        int hour,
                        int minute,
                        int second,
                        BigDecimal fraction)
sign - +1 for a positive duration, -1 for a negative durationIllegalArgumentException - if the sign is not 1 or -1public GDurationBuilder(GDurationSpecification gDuration)
public Object clone()
public GDuration toGDuration()
public void addGDuration(GDurationSpecification duration)
public void subtractGDuration(GDurationSpecification duration)
public final void setSign(int sign)
public void setYear(int year)
public void setMonth(int month)
public void setDay(int day)
public void setHour(int hour)
public void setMinute(int minute)
public void setSecond(int second)
public void setFraction(BigDecimal fraction)
public final boolean isImmutable()
isImmutable in interface GDurationSpecificationpublic final int getSign()
getSign in interface GDurationSpecificationpublic final int getYear()
getYear in interface GDurationSpecificationpublic final int getMonth()
getMonth in interface GDurationSpecificationpublic final int getDay()
getDay in interface GDurationSpecificationpublic final int getHour()
getHour in interface GDurationSpecificationpublic final int getMinute()
getMinute in interface GDurationSpecificationpublic final int getSecond()
getSecond in interface GDurationSpecificationpublic BigDecimal getFraction()
getFraction in interface GDurationSpecificationpublic boolean isValid()
isValid in interface GDurationSpecificationpublic void normalize()
Most duration specifications can be normalized to valid durations with all positive components, but not all of them can.
The only situations which cannot be normalized are where the year/month and the day/hour/minute/second offsets are of opposite sign. Days cannot be carried into months since the length of a Gregorian month is variable depending on when the duration is applied. In these cases, this method normalizes the components so that "day" is the only negative component.
public final int compareToGDuration(GDurationSpecification duration)
compareToGDuration in interface GDurationSpecificationpublic String toString()
Any components that are zero are omitted. Note that if the duration is invalid, i.e., it has negative components, those negative components are serialized out here. To check for validity, use the isValid() method; and to normalize most durations to a valid form use the normalize() method.
public static String toPlainString(BigDecimal bd)