Class CopticChronology.DayOfMonthRule

  • All Implemented Interfaces:
    java.io.Serializable, java.lang.Comparable<CalendricalRule<?>>, java.util.Comparator<Calendrical>
    Enclosing class:
    CopticChronology

    private static final class CopticChronology.DayOfMonthRule
    extends DateTimeFieldRule<java.lang.Integer>
    implements java.io.Serializable
    Rule implementation.
    • Field Detail

      • INSTANCE

        private static final DateTimeFieldRule<java.lang.Integer> INSTANCE
        Singleton instance.
      • serialVersionUID

        private static final long serialVersionUID
        A serialization identifier for this class.
        See Also:
        Constant Field Values
    • Constructor Detail

      • DayOfMonthRule

        private DayOfMonthRule()
        Constructor.
    • Method Detail

      • readResolve

        private java.lang.Object readResolve()
      • getMaximumValue

        public int getMaximumValue​(Calendrical calendrical)
        Description copied from class: DateTimeFieldRule
        Gets the minimum value that the field can take using the specified calendrical information to refine the accuracy of the response.

        The result of this method will still be inaccurate if there is insufficient information in the calendrical.

        For example, if this field is the ISO day-of-month field, then the number of days in the month varies depending on the month and year. If both the month and year can be derived from the calendrical, then the maximum value returned will be accurate. Otherwise the 'best guess' value from DateTimeFieldRule.getMaximumValue() will be returned.

        The default implementation returns DateTimeFieldRule.getMaximumValue(). Subclasses must override this as necessary.

        Overrides:
        getMaximumValue in class DateTimeFieldRule<java.lang.Integer>
        Parameters:
        calendrical - context calendrical, not null
        Returns:
        the minimum value of the field given the context
      • derive

        protected java.lang.Integer derive​(Calendrical calendrical)
        Description copied from class: CalendricalRule
        Derives the value of this rule from a calendrical.

        This method derives the value for this field from other fields in the calendrical without directly querying the calendrical for the value.

        For example, if this field is quarter-of-year, then the value can be derived from month-of-year.

        The implementation only needs to derive the value based on its immediate parents. The use of Calendrical.get(javax.time.calendar.CalendricalRule<T>) will extract any further parents on demand.

        A typical implementation of this method obtains the parent value and performs a calculation. For example, here is a simple implementation for the quarter-of-year field:

         Integer moyVal = calendrical.get(ISOChronology.monthOfYearRule());
         return (moyVal != null ? ((moyVal - 1) % 4) + 1) : null;
         

        This method is designed to be overridden in subclasses. The subclass implementation must be thread-safe. The subclass implementation must not request the value of this rule from the specified calendrical, otherwise a stack overflow error will occur.

        Overrides:
        derive in class CalendricalRule<java.lang.Integer>
        Parameters:
        calendrical - the calendrical to derive from, not null
        Returns:
        the derived value, null if unable to derive