Class DecoratedDateTimeField
- java.lang.Object
 - 
- org.joda.time.DateTimeField
 - 
- org.joda.time.field.BaseDateTimeField
 - 
- org.joda.time.field.DecoratedDateTimeField
 
 
 
 
- 
- Direct Known Subclasses:
 DividedDateTimeField,OffsetDateTimeField,RemainderDateTimeField,ZeroIsMaxDateTimeField
public abstract class DecoratedDateTimeField extends BaseDateTimeField
DecoratedDateTimeFieldextendsBaseDateTimeField, implementing only the minimum required set of methods. These implemented methods delegate to a wrapped field.This design allows new DateTimeField types to be defined that piggyback on top of another, inheriting all the safe method implementations from BaseDateTimeField. Should any method require pure delegation to the wrapped field, simply override and use the provided getWrappedField method.
DecoratedDateTimeField is thread-safe and immutable, and its subclasses must be as well.
- Since:
 - 1.0
 - See Also:
 DelegatedDateTimeField
 
- 
- 
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intget(long instant)Get the value of this field from the milliseconds.DurationFieldgetDurationField()Returns the duration per unit value of this field.intgetMaximumValue()Get the maximum allowable value for this field.intgetMinimumValue()Get the minimum allowable value for this field.DurationFieldgetRangeDurationField()Returns the range duration of this field.DateTimeFieldgetWrappedField()Gets the wrapped date time field.booleanisLenient()Returns true if the set method is lenient.longroundFloor(long instant)Round to the lowest whole unit of this field.longset(long instant, int value)Sets a value in the milliseconds supplied.- 
Methods inherited from class org.joda.time.field.BaseDateTimeField
add, add, add, addWrapField, addWrapField, addWrapPartial, getAsShortText, getAsShortText, getAsShortText, getAsShortText, getAsShortText, getAsText, getAsText, getAsText, getAsText, getAsText, getDifference, getDifferenceAsLong, getLeapAmount, getLeapDurationField, getMaximumShortTextLength, getMaximumTextLength, getMaximumValue, getMaximumValue, getMaximumValue, getMinimumValue, getMinimumValue, getMinimumValue, getName, getType, isLeap, isSupported, remainder, roundCeiling, roundHalfCeiling, roundHalfEven, roundHalfFloor, set, set, set, set, toString 
- 
Methods inherited from class org.joda.time.DateTimeField
setExtended 
 - 
 
 - 
 
- 
- 
Method Detail
- 
getWrappedField
public final DateTimeField getWrappedField()
Gets the wrapped date time field.- Returns:
 - the wrapped DateTimeField
 
 
- 
isLenient
public boolean isLenient()
Description copied from class:DateTimeFieldReturns true if the set method is lenient. If so, it accepts values that are out of bounds. For example, a lenient day of month field accepts 32 for January, converting it to February 1.- Specified by:
 isLenientin classDateTimeField- Returns:
 - true if this field is lenient
 
 
- 
get
public int get(long instant)
Description copied from class:BaseDateTimeFieldGet the value of this field from the milliseconds.- Specified by:
 getin classBaseDateTimeField- Parameters:
 instant- the milliseconds from 1970-01-01T00:00:00Z to query- Returns:
 - the value of the field, in the units of the field
 
 
- 
set
public long set(long instant, int value)Description copied from class:BaseDateTimeFieldSets a value in the milliseconds supplied.The value of this field will be set. If the value is invalid, an exception if thrown.
If setting this field would make other fields invalid, then those fields may be changed. For example if the current date is the 31st January, and the month is set to February, the day would be invalid. Instead, the day would be changed to the closest value - the 28th/29th February as appropriate.
- Specified by:
 setin classBaseDateTimeField- Parameters:
 instant- the milliseconds from 1970-01-01T00:00:00Z to set invalue- the value to set, in the units of the field- Returns:
 - the updated milliseconds
 
 
- 
getDurationField
public DurationField getDurationField()
Description copied from class:BaseDateTimeFieldReturns the duration per unit value of this field. For example, if this field represents "hour of day", then the unit duration is an hour.- Specified by:
 getDurationFieldin classBaseDateTimeField- Returns:
 - the duration of this field, or UnsupportedDurationField if field has no duration
 
 
- 
getRangeDurationField
public DurationField getRangeDurationField()
Description copied from class:BaseDateTimeFieldReturns the range duration of this field. For example, if this field represents "hour of day", then the range duration is a day.- Specified by:
 getRangeDurationFieldin classBaseDateTimeField- Returns:
 - the range duration of this field, or null if field has no range
 
 
- 
getMinimumValue
public int getMinimumValue()
Description copied from class:BaseDateTimeFieldGet the minimum allowable value for this field.- Specified by:
 getMinimumValuein classBaseDateTimeField- Returns:
 - the minimum valid value for this field, in the units of the field
 
 
- 
getMaximumValue
public int getMaximumValue()
Description copied from class:BaseDateTimeFieldGet the maximum allowable value for this field.- Specified by:
 getMaximumValuein classBaseDateTimeField- Returns:
 - the maximum valid value for this field, in the units of the field
 
 
- 
roundFloor
public long roundFloor(long instant)
Description copied from class:BaseDateTimeFieldRound to the lowest whole unit of this field. After rounding, the value of this field and all fields of a higher magnitude are retained. The fractional millis that cannot be expressed in whole increments of this field are set to minimum.For example, a datetime of 2002-11-02T23:34:56.789, rounded to the lowest whole hour is 2002-11-02T23:00:00.000.
- Specified by:
 roundFloorin classBaseDateTimeField- Parameters:
 instant- the milliseconds from 1970-01-01T00:00:00Z to round- Returns:
 - rounded milliseconds
 
 
 - 
 
 -