The rules model all the historic and future transitions for a time-zone.
ZoneOffsetTransition
is used for known transitions, typically historic.
ZoneOffsetTransitionRule
is used for future transitions that are based
on the result of an algorithm.
The rules are loaded via ZoneRulesProvider
using a ZoneId
.
The same rules may be shared internally between multiple zone IDs.
Serializing an instance of ZoneRules
will store the entire set of rules.
It does not store the zone ID as it is not part of the state of this object.
A rule implementation may or may not store full information about historic and future transitions, and the information stored is only as accurate as that supplied to the implementation by the rules provider. Applications should treat the data provided as representing the best information available to the implementation of this rule.
Implementation Specification
This class is immutable and thread-safe.
Modifier and Type | Field and Description |
---|---|
private static final long | DAYS_0000_TO_1970
The number of days from year zero to year 1970. |
private static final int | DAYS_PER_CYCLE
The number of days in a 400 year cycle. |
private static final ZoneOffsetTransitionRule[] | EMPTY_LASTRULES
The zero-length lastrules array. |
private static final LocalDateTime[] | EMPTY_LDT_ARRAY
The zero-length ldt array. |
private static final long[] | EMPTY_LONG_ARRAY
The zero-length long array. |
private static final int | LAST_CACHED_YEAR
The last year to have its transitions cached. |
private final ZoneOffsetTransitionRule[] | lastRules
The last rule. |
private final transient ConcurrentMap | lastRulesCache
The map of recent transitions. |
private final long[] | savingsInstantTransitions
The transitions between instants (epoch seconds), sorted. |
private final LocalDateTime[] | savingsLocalTransitions
The transitions between local date-times, sorted. |
private static final long | serialVersionUID
Serialization version. |
private final ZoneOffset[] | standardOffsets
The standard offsets. |
private final long[] | standardTransitions
The transitions between standard offsets (epoch seconds), sorted. |
private final ZoneOffset[] | wallOffsets
The wall offsets. |
Access | Constructor and Description |
---|---|
pack-priv | ZoneRules(ZoneOffset
the standard offset to use before legal rules were set, not null baseStandardOffset, ZoneOffset the wall offset to use before legal rules were set, not null baseWallOffset, List<ZoneOffsetTransition> the list of changes to the standard offset, not null standardOffsetTransitionList, List<ZoneOffsetTransition> the list of transitions, not null transitionList, List<ZoneOffsetTransitionRule> the recurring last rules, size 16 or less, not null lastRules)Creates an instance. |
private | ZoneRules(long[]
the standard transitions, not null standardTransitions, ZoneOffset[] the standard offsets, not null standardOffsets, long[] the standard transitions, not null savingsInstantTransitions, ZoneOffset[] the wall offsets, not null wallOffsets, ZoneOffsetTransitionRule[] the recurring last rules, size 15 or less, not null lastRules)Constructor. |
private | ZoneRules(ZoneOffset
the offset this fixed zone rules is based on, not null offset)Creates an instance of ZoneRules that has fixed zone rules. |
Modifier and Type | Method and Description |
---|---|
public boolean | Returns: true if this rules is the same as that specifiedthe other rules, null returns false otherRules)Overrides java. |
private Object | Returns: the offset info, not nullthe date-time, not null dt, ZoneOffsetTransition the transition, not null trans)Finds the offset info for a local date-time and transition. |
private ZoneOffsetTransition[] | Returns: the transition array, not nullthe year, not null year)Finds the appropriate transition array for the given year. |
private int | |
public Duration | Returns: the difference between the standard and actual offset, not nullthe instant to find the daylight savings for, not null, but null
may be ignored if the rules have a single offset for all instants instant)Gets the amount of daylight savings in use for the specified instant in this zone. |
public ZoneOffset | |
public ZoneOffset | Returns: the best available offset for the local date-time, not nullthe local date-time to query, not null, but null
may be ignored if the rules have a single offset for all instants localDateTime)Gets a suitable offset for the specified local date-time in these rules. |
private Object | |
public ZoneOffset | Returns: the standard offset, not nullthe instant to find the offset information for, not null, but null
may be ignored if the rules have a single offset for all instants instant)Gets the standard offset for the specified instant in this zone. |
public ZoneOffsetTransition | Returns: the offset transition, null if the local date-time is not in transitionthe local date-time to query for offset transition, not null, but null
may be ignored if the rules have a single offset for all instants localDateTime)Gets the offset transition applicable at the specified local date-time in these rules. |
public List | Returns: an immutable list of transition rules, not nullGets the list of transition rules for years beyond those defined in the transition list. |
public List | Returns: an immutable list of fully defined transitions, not nullGets the complete list of fully defined transitions. |
public List | Returns: the list of valid offsets, may be immutable, not nullthe local date-time to query for valid offsets, not null, but null
may be ignored if the rules have a single offset for all instants localDateTime)Gets the offset applicable at the specified local date-time in these rules. |
public int | Returns: the hash codeOverrides java. #equals .
|
public boolean | Returns: true if the specified instant is in daylight savings, false otherwise.the instant to check the daylight savings for, not null, but null
may be ignored if the rules have a single offset for all instants instant)Checks if the specified instant is in daylight savings. |
public boolean | Returns: true if the time-zone is fixed and the offset never changesChecks of the zone rules are fixed, such that the offset never varies. |
public boolean | Returns: true if the offset date-time is valid for these rulesthe date-time to check, not null, but null
may be ignored if the rules have a single offset for all instants localDateTime, ZoneOffset the offset to check, null returns false offset)Checks if the offset date-time is valid for these rules. |
public ZoneOffsetTransition | Returns: the next transition after the specified instant, null if this is after the last transitionthe instant to get the next transition after, not null, but null
may be ignored if the rules have a single offset for all instants instant)Gets the next transition after the specified instant. |
public static ZoneRules | Returns: the zone rules, not nullthe standard offset to use before legal rules were set, not null baseStandardOffset, ZoneOffset the wall offset to use before legal rules were set, not null baseWallOffset, List<ZoneOffsetTransition> the list of changes to the standard offset, not null standardOffsetTransitionList, List<ZoneOffsetTransition> the list of transitions, not null transitionList, List<ZoneOffsetTransitionRule> the recurring last rules, size 16 or less, not null lastRules)Obtains an instance of a ZoneRules. |
public static ZoneRules | Returns: the zone rules, not nullthe offset this fixed zone rules is based on, not null offset)Obtains an instance of ZoneRules that has fixed zone rules. |
public ZoneOffsetTransition | Returns: the previous transition before the specified instant, null if this is before the first transitionthe instant to get the previous transition after, not null, but null
may be ignored if the rules have a single offset for all instants instant)Gets the previous transition before the specified instant. |
pack-priv static ZoneRules | Returns: the created object, not nullthe input stream, not null in)Reads the state from the stream. |
private void | |
public String | Returns: a string for debugging, not nullOverrides java. |
pack-priv void | |
private Object | Returns: the replacing object, not nullWrites the object using a dedicated serialized form. |
DAYS_0000_TO_1970 | back to summary |
---|---|
private static final long DAYS_0000_TO_1970 The number of days from year zero to year 1970. There are five 400 year cycles from year zero to 2000. There are 7 leap years from 1970 to 2000. |
DAYS_PER_CYCLE | back to summary |
---|---|
private static final int DAYS_PER_CYCLE The number of days in a 400 year cycle. |
EMPTY_LASTRULES | back to summary |
---|---|
private static final ZoneOffsetTransitionRule[] EMPTY_LASTRULES The zero-length lastrules array. |
EMPTY_LDT_ARRAY | back to summary |
---|---|
private static final LocalDateTime[] EMPTY_LDT_ARRAY The zero-length ldt array. |
EMPTY_LONG_ARRAY | back to summary |
---|---|
private static final long[] EMPTY_LONG_ARRAY The zero-length long array. |
LAST_CACHED_YEAR | back to summary |
---|---|
private static final int LAST_CACHED_YEAR The last year to have its transitions cached. |
lastRules | back to summary |
---|---|
private final ZoneOffsetTransitionRule[] lastRules The last rule. |
lastRulesCache | back to summary |
---|---|
private final transient ConcurrentMap<Integer, ZoneOffsetTransition[]> lastRulesCache The map of recent transitions. |
savingsInstantTransitions | back to summary |
---|---|
private final long[] savingsInstantTransitions The transitions between instants (epoch seconds), sorted. |
savingsLocalTransitions | back to summary |
---|---|
private final LocalDateTime[] savingsLocalTransitions The transitions between local date-times, sorted. This is a paired array, where the first entry is the start of the transition and the second entry is the end of the transition. |
serialVersionUID | back to summary |
---|---|
private static final long serialVersionUID Serialization version. |
standardOffsets | back to summary |
---|---|
private final ZoneOffset[] standardOffsets The standard offsets. |
standardTransitions | back to summary |
---|---|
private final long[] standardTransitions The transitions between standard offsets (epoch seconds), sorted. |
wallOffsets | back to summary |
---|---|
private final ZoneOffset[] wallOffsets The wall offsets. |
ZoneRules | back to summary |
---|---|
pack-priv ZoneRules(ZoneOffset baseStandardOffset, ZoneOffset baseWallOffset, List<ZoneOffsetTransition> standardOffsetTransitionList, List<ZoneOffsetTransition> transitionList, List<ZoneOffsetTransitionRule> lastRules) Creates an instance.
|
ZoneRules | back to summary |
---|---|
private ZoneRules(long[] standardTransitions, ZoneOffset[] standardOffsets, long[] savingsInstantTransitions, ZoneOffset[] wallOffsets, ZoneOffsetTransitionRule[] lastRules) Constructor.
|
ZoneRules | back to summary |
---|---|
private ZoneRules(ZoneOffset offset) Creates an instance of ZoneRules that has fixed zone rules.
|
equals | back to summary |
---|---|
public boolean equals(Object otherRules) Overrides java. Checks if this set of rules equals another. Two rule sets are equal if they will always result in the same output for any given input instant or local date-time. Rules from two different groups may return false even if they are in fact the same. This definition should result in implementations comparing their entire state. |
findOffsetInfo | back to summary |
---|---|
private Object findOffsetInfo(LocalDateTime dt, ZoneOffsetTransition trans) Finds the offset info for a local date-time and transition.
|
findTransitionArray | back to summary |
---|---|
private ZoneOffsetTransition[] findTransitionArray(int year) Finds the appropriate transition array for the given year.
|
findYear | back to summary |
---|---|
private int findYear(long epochSecond, ZoneOffset offset) |
getDaylightSavings | back to summary |
---|---|
public Duration getDaylightSavings(Instant instant) Gets the amount of daylight savings in use for the specified instant in this zone. This provides access to historic information on how the amount of daylight savings has changed over time. This is the difference between the standard offset and the actual offset. Typically the amount is zero during winter and one hour during summer. Time-zones are second-based, so the nanosecond part of the duration will be zero.
This default implementation calculates the duration from the
|
getOffset | back to summary |
---|---|
public ZoneOffset getOffset(Instant instant) Gets the offset applicable at the specified instant in these rules. The mapping from an instant to an offset is simple, there is only one valid offset for each instant. This method returns that offset.
|
getOffset | back to summary |
---|---|
public ZoneOffset getOffset(LocalDateTime localDateTime) Gets a suitable offset for the specified local date-time in these rules. The mapping from a local date-time to an offset is not straightforward. There are three cases:
Since, in the case of Gap and Overlap, the offset returned is a "best" value, rather
than the "correct" value, it should be treated with care. Applications that care
about the correct offset should use a combination of this method,
|
getOffsetInfo | back to summary |
---|---|
private Object getOffsetInfo(LocalDateTime dt) |
getStandardOffset | back to summary |
---|---|
public ZoneOffset getStandardOffset(Instant instant) Gets the standard offset for the specified instant in this zone. This provides access to historic information on how the standard offset has changed over time. The standard offset is the offset before any daylight saving time is applied. This is typically the offset applicable during winter.
|
getTransition | back to summary |
---|---|
public ZoneOffsetTransition getTransition(LocalDateTime localDateTime) Gets the offset transition applicable at the specified local date-time in these rules. The mapping from a local date-time to an offset is not straightforward. There are three cases:
There are various ways to handle the conversion from a ZoneOffsetTransition trans = rules.getTransition(localDT); if (trans != null) { // Gap or Overlap: determine what to do from transition } else { // Normal case: only one valid offset zoneOffset = rule.getOffset(localDT); }
|
getTransitionRules | back to summary |
---|---|
public List Gets the list of transition rules for years beyond those defined in the transition list.
The complete set of transitions for this rules instance is defined by this method
and
For any given If the zone defines daylight savings into the future, then the list will normally be of size two and hold information about entering and exiting daylight savings. If the zone does not have daylight savings, or information about future changes is uncertain, then the list will be empty. The list will be empty for fixed offset rules and for any time-zone where there is no daylight saving time. The list will also be empty if the transition rules are unknown.
|
getTransitions | back to summary |
---|---|
public List Gets the complete list of fully defined transitions.
The complete set of transitions for this rules instance is defined by this method
and The list will be empty for fixed offset rules and for any time-zone where there has only ever been a single offset. The list will also be empty if the transition rules are unknown.
|
getValidOffsets | back to summary |
---|---|
public List Gets the offset applicable at the specified local date-time in these rules. The mapping from a local date-time to an offset is not straightforward. There are three cases:
There are various ways to handle the conversion from a List<ZoneOffset> validOffsets = rules.getValidOffsets(localDT); if (validOffsets.size() == 1) { // Normal case: only one valid offset zoneOffset = validOffsets.get(0); } else { // Gap or Overlap: determine what to do from transition (which will be non-null) ZoneOffsetTransition trans = rules.getTransition(localDT); } In theory, it is possible for there to be more than two valid offsets. This would happen if clocks to be put back more than once in quick succession. This has never happened in the history of time-zones and thus has no special handling. However, if it were to happen, then the list would return more than 2 entries.
|
hashCode | back to summary |
---|---|
public int hashCode() Overrides java. Returns a suitable hash code given the definition of
|
isDaylightSavings | back to summary |
---|---|
public boolean isDaylightSavings(Instant instant) Checks if the specified instant is in daylight savings. This checks if the standard offset and the actual offset are the same for the specified instant. If they are not, it is assumed that daylight savings is in operation.
This default implementation compares the
|
isFixedOffset | back to summary |
---|---|
public boolean isFixedOffset() Checks of the zone rules are fixed, such that the offset never varies.
|
isValidOffset | back to summary |
---|---|
public boolean isValidOffset(LocalDateTime localDateTime, ZoneOffset offset) Checks if the offset date-time is valid for these rules. To be valid, the local date-time must not be in a gap and the offset must match one of the valid offsets.
This default implementation checks if
|
nextTransition | back to summary |
---|---|
public ZoneOffsetTransition nextTransition(Instant instant) Gets the next transition after the specified instant. This returns details of the next transition after the specified instant. For example, if the instant represents a point where "Summer" daylight savings time applies, then the method will return the transition to the next "Winter" time.
|
of | back to summary |
---|---|
public static ZoneRules of(ZoneOffset baseStandardOffset, ZoneOffset baseWallOffset, List<ZoneOffsetTransition> standardOffsetTransitionList, List<ZoneOffsetTransition> transitionList, List<ZoneOffsetTransitionRule> lastRules) Obtains an instance of a ZoneRules.
|
of | back to summary |
---|---|
public static ZoneRules of(ZoneOffset offset) Obtains an instance of ZoneRules that has fixed zone rules.
|
previousTransition | back to summary |
---|---|
public ZoneOffsetTransition previousTransition(Instant instant) Gets the previous transition before the specified instant. This returns details of the previous transition before the specified instant. For example, if the instant represents a point where "summer" daylight saving time applies, then the method will return the transition from the previous "winter" time.
|
readExternal | back to summary |
---|---|
pack-priv static ZoneRules readExternal(DataInput in) throws IOException, ClassNotFoundException Reads the state from the stream. The 1,024 limit to the lengths of stdTrans and savSize is intended to be the size well enough to accommodate the max number of transitions in current tzdb data (203 for Asia/Tehran).
|
readObject | back to summary |
---|---|
private void readObject(ObjectInputStream s) throws InvalidObjectException Defend against malicious streams.
|
toString | back to summary |
---|---|
public String toString() Overrides java. Returns a string describing this object. |
writeExternal | back to summary |
---|---|
pack-priv void writeExternal(DataOutput out) throws IOException Writes the state to the stream.
|
writeReplace | back to summary |
---|---|
private Object writeReplace() Writes the object using a dedicated serialized form.
|