vendor/nesbot/carbon/src/Carbon/CarbonImmutable.php line 510

Open in your IDE?
  1. <?php
  2. /**
  3.  * This file is part of the Carbon package.
  4.  *
  5.  * (c) Brian Nesbitt <brian@nesbot.com>
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. namespace Carbon;
  11. use Carbon\Traits\Date;
  12. use Carbon\Traits\DeprecatedProperties;
  13. use DateTimeImmutable;
  14. use DateTimeInterface;
  15. use DateTimeZone;
  16. /**
  17.  * A simple API extension for DateTimeImmutable.
  18.  *
  19.  * @mixin DeprecatedProperties
  20.  *
  21.  * <autodoc generated by `composer phpdoc`>
  22.  *
  23.  * @property      int                          $year
  24.  * @property      int                          $yearIso
  25.  * @property      int                          $month
  26.  * @property      int                          $day
  27.  * @property      int                          $hour
  28.  * @property      int                          $minute
  29.  * @property      int                          $second
  30.  * @property      int                          $micro
  31.  * @property      int                          $microsecond
  32.  * @property      int|float|string             $timestamp                                                                           seconds since the Unix Epoch
  33.  * @property      string                       $englishDayOfWeek                                                                    the day of week in English
  34.  * @property      string                       $shortEnglishDayOfWeek                                                               the abbreviated day of week in English
  35.  * @property      string                       $englishMonth                                                                        the month in English
  36.  * @property      string                       $shortEnglishMonth                                                                   the abbreviated month in English
  37.  * @property      int                          $milliseconds
  38.  * @property      int                          $millisecond
  39.  * @property      int                          $milli
  40.  * @property      int                          $week                                                                                1 through 53
  41.  * @property      int                          $isoWeek                                                                             1 through 53
  42.  * @property      int                          $weekYear                                                                            year according to week format
  43.  * @property      int                          $isoWeekYear                                                                         year according to ISO week format
  44.  * @property      int                          $dayOfYear                                                                           1 through 366
  45.  * @property      int                          $age                                                                                 does a diffInYears() with default parameters
  46.  * @property      int                          $offset                                                                              the timezone offset in seconds from UTC
  47.  * @property      int                          $offsetMinutes                                                                       the timezone offset in minutes from UTC
  48.  * @property      int                          $offsetHours                                                                         the timezone offset in hours from UTC
  49.  * @property      CarbonTimeZone               $timezone                                                                            the current timezone
  50.  * @property      CarbonTimeZone               $tz                                                                                  alias of $timezone
  51.  * @property-read int                          $dayOfWeek                                                                           0 (for Sunday) through 6 (for Saturday)
  52.  * @property-read int                          $dayOfWeekIso                                                                        1 (for Monday) through 7 (for Sunday)
  53.  * @property-read int                          $weekOfYear                                                                          ISO-8601 week number of year, weeks starting on Monday
  54.  * @property-read int                          $daysInMonth                                                                         number of days in the given month
  55.  * @property-read string                       $latinMeridiem                                                                       "am"/"pm" (Ante meridiem or Post meridiem latin lowercase mark)
  56.  * @property-read string                       $latinUpperMeridiem                                                                  "AM"/"PM" (Ante meridiem or Post meridiem latin uppercase mark)
  57.  * @property-read string                       $timezoneAbbreviatedName                                                             the current timezone abbreviated name
  58.  * @property-read string                       $tzAbbrName                                                                          alias of $timezoneAbbreviatedName
  59.  * @property-read string                       $dayName                                                                             long name of weekday translated according to Carbon locale, in english if no translation available for current language
  60.  * @property-read string                       $shortDayName                                                                        short name of weekday translated according to Carbon locale, in english if no translation available for current language
  61.  * @property-read string                       $minDayName                                                                          very short name of weekday translated according to Carbon locale, in english if no translation available for current language
  62.  * @property-read string                       $monthName                                                                           long name of month translated according to Carbon locale, in english if no translation available for current language
  63.  * @property-read string                       $shortMonthName                                                                      short name of month translated according to Carbon locale, in english if no translation available for current language
  64.  * @property-read string                       $meridiem                                                                            lowercase meridiem mark translated according to Carbon locale, in latin if no translation available for current language
  65.  * @property-read string                       $upperMeridiem                                                                       uppercase meridiem mark translated according to Carbon locale, in latin if no translation available for current language
  66.  * @property-read int                          $noZeroHour                                                                          current hour from 1 to 24
  67.  * @property-read int                          $weeksInYear                                                                         51 through 53
  68.  * @property-read int                          $isoWeeksInYear                                                                      51 through 53
  69.  * @property-read int                          $weekOfMonth                                                                         1 through 5
  70.  * @property-read int                          $weekNumberInMonth                                                                   1 through 5
  71.  * @property-read int                          $firstWeekDay                                                                        0 through 6
  72.  * @property-read int                          $lastWeekDay                                                                         0 through 6
  73.  * @property-read int                          $daysInYear                                                                          365 or 366
  74.  * @property-read int                          $quarter                                                                             the quarter of this instance, 1 - 4
  75.  * @property-read int                          $decade                                                                              the decade of this instance
  76.  * @property-read int                          $century                                                                             the century of this instance
  77.  * @property-read int                          $millennium                                                                          the millennium of this instance
  78.  * @property-read bool                         $dst                                                                                 daylight savings time indicator, true if DST, false otherwise
  79.  * @property-read bool                         $local                                                                               checks if the timezone is local, true if local, false otherwise
  80.  * @property-read bool                         $utc                                                                                 checks if the timezone is UTC, true if UTC, false otherwise
  81.  * @property-read string                       $timezoneName                                                                        the current timezone name
  82.  * @property-read string                       $tzName                                                                              alias of $timezoneName
  83.  * @property-read string                       $locale                                                                              locale of the current instance
  84.  *
  85.  * @method        bool                         isUtc()                                                                              Check if the current instance has UTC timezone. (Both isUtc and isUTC cases are valid.)
  86.  * @method        bool                         isLocal()                                                                            Check if the current instance has non-UTC timezone.
  87.  * @method        bool                         isValid()                                                                            Check if the current instance is a valid date.
  88.  * @method        bool                         isDST()                                                                              Check if the current instance is in a daylight saving time.
  89.  * @method        bool                         isSunday()                                                                           Checks if the instance day is sunday.
  90.  * @method        bool                         isMonday()                                                                           Checks if the instance day is monday.
  91.  * @method        bool                         isTuesday()                                                                          Checks if the instance day is tuesday.
  92.  * @method        bool                         isWednesday()                                                                        Checks if the instance day is wednesday.
  93.  * @method        bool                         isThursday()                                                                         Checks if the instance day is thursday.
  94.  * @method        bool                         isFriday()                                                                           Checks if the instance day is friday.
  95.  * @method        bool                         isSaturday()                                                                         Checks if the instance day is saturday.
  96.  * @method        bool                         isSameYear(Carbon|DateTimeInterface|string|null $date = null)                        Checks if the given date is in the same year as the instance. If null passed, compare to now (with the same timezone).
  97.  * @method        bool                         isCurrentYear()                                                                      Checks if the instance is in the same year as the current moment.
  98.  * @method        bool                         isNextYear()                                                                         Checks if the instance is in the same year as the current moment next year.
  99.  * @method        bool                         isLastYear()                                                                         Checks if the instance is in the same year as the current moment last year.
  100.  * @method        bool                         isSameWeek(Carbon|DateTimeInterface|string|null $date = null)                        Checks if the given date is in the same week as the instance. If null passed, compare to now (with the same timezone).
  101.  * @method        bool                         isCurrentWeek()                                                                      Checks if the instance is in the same week as the current moment.
  102.  * @method        bool                         isNextWeek()                                                                         Checks if the instance is in the same week as the current moment next week.
  103.  * @method        bool                         isLastWeek()                                                                         Checks if the instance is in the same week as the current moment last week.
  104.  * @method        bool                         isSameDay(Carbon|DateTimeInterface|string|null $date = null)                         Checks if the given date is in the same day as the instance. If null passed, compare to now (with the same timezone).
  105.  * @method        bool                         isCurrentDay()                                                                       Checks if the instance is in the same day as the current moment.
  106.  * @method        bool                         isNextDay()                                                                          Checks if the instance is in the same day as the current moment next day.
  107.  * @method        bool                         isLastDay()                                                                          Checks if the instance is in the same day as the current moment last day.
  108.  * @method        bool                         isSameHour(Carbon|DateTimeInterface|string|null $date = null)                        Checks if the given date is in the same hour as the instance. If null passed, compare to now (with the same timezone).
  109.  * @method        bool                         isCurrentHour()                                                                      Checks if the instance is in the same hour as the current moment.
  110.  * @method        bool                         isNextHour()                                                                         Checks if the instance is in the same hour as the current moment next hour.
  111.  * @method        bool                         isLastHour()                                                                         Checks if the instance is in the same hour as the current moment last hour.
  112.  * @method        bool                         isSameMinute(Carbon|DateTimeInterface|string|null $date = null)                      Checks if the given date is in the same minute as the instance. If null passed, compare to now (with the same timezone).
  113.  * @method        bool                         isCurrentMinute()                                                                    Checks if the instance is in the same minute as the current moment.
  114.  * @method        bool                         isNextMinute()                                                                       Checks if the instance is in the same minute as the current moment next minute.
  115.  * @method        bool                         isLastMinute()                                                                       Checks if the instance is in the same minute as the current moment last minute.
  116.  * @method        bool                         isSameSecond(Carbon|DateTimeInterface|string|null $date = null)                      Checks if the given date is in the same second as the instance. If null passed, compare to now (with the same timezone).
  117.  * @method        bool                         isCurrentSecond()                                                                    Checks if the instance is in the same second as the current moment.
  118.  * @method        bool                         isNextSecond()                                                                       Checks if the instance is in the same second as the current moment next second.
  119.  * @method        bool                         isLastSecond()                                                                       Checks if the instance is in the same second as the current moment last second.
  120.  * @method        bool                         isSameMicro(Carbon|DateTimeInterface|string|null $date = null)                       Checks if the given date is in the same microsecond as the instance. If null passed, compare to now (with the same timezone).
  121.  * @method        bool                         isCurrentMicro()                                                                     Checks if the instance is in the same microsecond as the current moment.
  122.  * @method        bool                         isNextMicro()                                                                        Checks if the instance is in the same microsecond as the current moment next microsecond.
  123.  * @method        bool                         isLastMicro()                                                                        Checks if the instance is in the same microsecond as the current moment last microsecond.
  124.  * @method        bool                         isSameMicrosecond(Carbon|DateTimeInterface|string|null $date = null)                 Checks if the given date is in the same microsecond as the instance. If null passed, compare to now (with the same timezone).
  125.  * @method        bool                         isCurrentMicrosecond()                                                               Checks if the instance is in the same microsecond as the current moment.
  126.  * @method        bool                         isNextMicrosecond()                                                                  Checks if the instance is in the same microsecond as the current moment next microsecond.
  127.  * @method        bool                         isLastMicrosecond()                                                                  Checks if the instance is in the same microsecond as the current moment last microsecond.
  128.  * @method        bool                         isCurrentMonth()                                                                     Checks if the instance is in the same month as the current moment.
  129.  * @method        bool                         isNextMonth()                                                                        Checks if the instance is in the same month as the current moment next month.
  130.  * @method        bool                         isLastMonth()                                                                        Checks if the instance is in the same month as the current moment last month.
  131.  * @method        bool                         isCurrentQuarter()                                                                   Checks if the instance is in the same quarter as the current moment.
  132.  * @method        bool                         isNextQuarter()                                                                      Checks if the instance is in the same quarter as the current moment next quarter.
  133.  * @method        bool                         isLastQuarter()                                                                      Checks if the instance is in the same quarter as the current moment last quarter.
  134.  * @method        bool                         isSameDecade(Carbon|DateTimeInterface|string|null $date = null)                      Checks if the given date is in the same decade as the instance. If null passed, compare to now (with the same timezone).
  135.  * @method        bool                         isCurrentDecade()                                                                    Checks if the instance is in the same decade as the current moment.
  136.  * @method        bool                         isNextDecade()                                                                       Checks if the instance is in the same decade as the current moment next decade.
  137.  * @method        bool                         isLastDecade()                                                                       Checks if the instance is in the same decade as the current moment last decade.
  138.  * @method        bool                         isSameCentury(Carbon|DateTimeInterface|string|null $date = null)                     Checks if the given date is in the same century as the instance. If null passed, compare to now (with the same timezone).
  139.  * @method        bool                         isCurrentCentury()                                                                   Checks if the instance is in the same century as the current moment.
  140.  * @method        bool                         isNextCentury()                                                                      Checks if the instance is in the same century as the current moment next century.
  141.  * @method        bool                         isLastCentury()                                                                      Checks if the instance is in the same century as the current moment last century.
  142.  * @method        bool                         isSameMillennium(Carbon|DateTimeInterface|string|null $date = null)                  Checks if the given date is in the same millennium as the instance. If null passed, compare to now (with the same timezone).
  143.  * @method        bool                         isCurrentMillennium()                                                                Checks if the instance is in the same millennium as the current moment.
  144.  * @method        bool                         isNextMillennium()                                                                   Checks if the instance is in the same millennium as the current moment next millennium.
  145.  * @method        bool                         isLastMillennium()                                                                   Checks if the instance is in the same millennium as the current moment last millennium.
  146.  * @method        CarbonImmutable              years(int $value)                                                                    Set current instance year to the given value.
  147.  * @method        CarbonImmutable              year(int $value)                                                                     Set current instance year to the given value.
  148.  * @method        CarbonImmutable              setYears(int $value)                                                                 Set current instance year to the given value.
  149.  * @method        CarbonImmutable              setYear(int $value)                                                                  Set current instance year to the given value.
  150.  * @method        CarbonImmutable              months(int $value)                                                                   Set current instance month to the given value.
  151.  * @method        CarbonImmutable              month(int $value)                                                                    Set current instance month to the given value.
  152.  * @method        CarbonImmutable              setMonths(int $value)                                                                Set current instance month to the given value.
  153.  * @method        CarbonImmutable              setMonth(int $value)                                                                 Set current instance month to the given value.
  154.  * @method        CarbonImmutable              days(int $value)                                                                     Set current instance day to the given value.
  155.  * @method        CarbonImmutable              day(int $value)                                                                      Set current instance day to the given value.
  156.  * @method        CarbonImmutable              setDays(int $value)                                                                  Set current instance day to the given value.
  157.  * @method        CarbonImmutable              setDay(int $value)                                                                   Set current instance day to the given value.
  158.  * @method        CarbonImmutable              hours(int $value)                                                                    Set current instance hour to the given value.
  159.  * @method        CarbonImmutable              hour(int $value)                                                                     Set current instance hour to the given value.
  160.  * @method        CarbonImmutable              setHours(int $value)                                                                 Set current instance hour to the given value.
  161.  * @method        CarbonImmutable              setHour(int $value)                                                                  Set current instance hour to the given value.
  162.  * @method        CarbonImmutable              minutes(int $value)                                                                  Set current instance minute to the given value.
  163.  * @method        CarbonImmutable              minute(int $value)                                                                   Set current instance minute to the given value.
  164.  * @method        CarbonImmutable              setMinutes(int $value)                                                               Set current instance minute to the given value.
  165.  * @method        CarbonImmutable              setMinute(int $value)                                                                Set current instance minute to the given value.
  166.  * @method        CarbonImmutable              seconds(int $value)                                                                  Set current instance second to the given value.
  167.  * @method        CarbonImmutable              second(int $value)                                                                   Set current instance second to the given value.
  168.  * @method        CarbonImmutable              setSeconds(int $value)                                                               Set current instance second to the given value.
  169.  * @method        CarbonImmutable              setSecond(int $value)                                                                Set current instance second to the given value.
  170.  * @method        CarbonImmutable              millis(int $value)                                                                   Set current instance millisecond to the given value.
  171.  * @method        CarbonImmutable              milli(int $value)                                                                    Set current instance millisecond to the given value.
  172.  * @method        CarbonImmutable              setMillis(int $value)                                                                Set current instance millisecond to the given value.
  173.  * @method        CarbonImmutable              setMilli(int $value)                                                                 Set current instance millisecond to the given value.
  174.  * @method        CarbonImmutable              milliseconds(int $value)                                                             Set current instance millisecond to the given value.
  175.  * @method        CarbonImmutable              millisecond(int $value)                                                              Set current instance millisecond to the given value.
  176.  * @method        CarbonImmutable              setMilliseconds(int $value)                                                          Set current instance millisecond to the given value.
  177.  * @method        CarbonImmutable              setMillisecond(int $value)                                                           Set current instance millisecond to the given value.
  178.  * @method        CarbonImmutable              micros(int $value)                                                                   Set current instance microsecond to the given value.
  179.  * @method        CarbonImmutable              micro(int $value)                                                                    Set current instance microsecond to the given value.
  180.  * @method        CarbonImmutable              setMicros(int $value)                                                                Set current instance microsecond to the given value.
  181.  * @method        CarbonImmutable              setMicro(int $value)                                                                 Set current instance microsecond to the given value.
  182.  * @method        CarbonImmutable              microseconds(int $value)                                                             Set current instance microsecond to the given value.
  183.  * @method        CarbonImmutable              microsecond(int $value)                                                              Set current instance microsecond to the given value.
  184.  * @method        CarbonImmutable              setMicroseconds(int $value)                                                          Set current instance microsecond to the given value.
  185.  * @method        CarbonImmutable              setMicrosecond(int $value)                                                           Set current instance microsecond to the given value.
  186.  * @method        CarbonImmutable              addYears(int $value = 1)                                                             Add years (the $value count passed in) to the instance (using date interval).
  187.  * @method        CarbonImmutable              addYear()                                                                            Add one year to the instance (using date interval).
  188.  * @method        CarbonImmutable              subYears(int $value = 1)                                                             Sub years (the $value count passed in) to the instance (using date interval).
  189.  * @method        CarbonImmutable              subYear()                                                                            Sub one year to the instance (using date interval).
  190.  * @method        CarbonImmutable              addYearsWithOverflow(int $value = 1)                                                 Add years (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  191.  * @method        CarbonImmutable              addYearWithOverflow()                                                                Add one year to the instance (using date interval) with overflow explicitly allowed.
  192.  * @method        CarbonImmutable              subYearsWithOverflow(int $value = 1)                                                 Sub years (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  193.  * @method        CarbonImmutable              subYearWithOverflow()                                                                Sub one year to the instance (using date interval) with overflow explicitly allowed.
  194.  * @method        CarbonImmutable              addYearsWithoutOverflow(int $value = 1)                                              Add years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  195.  * @method        CarbonImmutable              addYearWithoutOverflow()                                                             Add one year to the instance (using date interval) with overflow explicitly forbidden.
  196.  * @method        CarbonImmutable              subYearsWithoutOverflow(int $value = 1)                                              Sub years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  197.  * @method        CarbonImmutable              subYearWithoutOverflow()                                                             Sub one year to the instance (using date interval) with overflow explicitly forbidden.
  198.  * @method        CarbonImmutable              addYearsWithNoOverflow(int $value = 1)                                               Add years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  199.  * @method        CarbonImmutable              addYearWithNoOverflow()                                                              Add one year to the instance (using date interval) with overflow explicitly forbidden.
  200.  * @method        CarbonImmutable              subYearsWithNoOverflow(int $value = 1)                                               Sub years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  201.  * @method        CarbonImmutable              subYearWithNoOverflow()                                                              Sub one year to the instance (using date interval) with overflow explicitly forbidden.
  202.  * @method        CarbonImmutable              addYearsNoOverflow(int $value = 1)                                                   Add years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  203.  * @method        CarbonImmutable              addYearNoOverflow()                                                                  Add one year to the instance (using date interval) with overflow explicitly forbidden.
  204.  * @method        CarbonImmutable              subYearsNoOverflow(int $value = 1)                                                   Sub years (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  205.  * @method        CarbonImmutable              subYearNoOverflow()                                                                  Sub one year to the instance (using date interval) with overflow explicitly forbidden.
  206.  * @method        CarbonImmutable              addMonths(int $value = 1)                                                            Add months (the $value count passed in) to the instance (using date interval).
  207.  * @method        CarbonImmutable              addMonth()                                                                           Add one month to the instance (using date interval).
  208.  * @method        CarbonImmutable              subMonths(int $value = 1)                                                            Sub months (the $value count passed in) to the instance (using date interval).
  209.  * @method        CarbonImmutable              subMonth()                                                                           Sub one month to the instance (using date interval).
  210.  * @method        CarbonImmutable              addMonthsWithOverflow(int $value = 1)                                                Add months (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  211.  * @method        CarbonImmutable              addMonthWithOverflow()                                                               Add one month to the instance (using date interval) with overflow explicitly allowed.
  212.  * @method        CarbonImmutable              subMonthsWithOverflow(int $value = 1)                                                Sub months (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  213.  * @method        CarbonImmutable              subMonthWithOverflow()                                                               Sub one month to the instance (using date interval) with overflow explicitly allowed.
  214.  * @method        CarbonImmutable              addMonthsWithoutOverflow(int $value = 1)                                             Add months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  215.  * @method        CarbonImmutable              addMonthWithoutOverflow()                                                            Add one month to the instance (using date interval) with overflow explicitly forbidden.
  216.  * @method        CarbonImmutable              subMonthsWithoutOverflow(int $value = 1)                                             Sub months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  217.  * @method        CarbonImmutable              subMonthWithoutOverflow()                                                            Sub one month to the instance (using date interval) with overflow explicitly forbidden.
  218.  * @method        CarbonImmutable              addMonthsWithNoOverflow(int $value = 1)                                              Add months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  219.  * @method        CarbonImmutable              addMonthWithNoOverflow()                                                             Add one month to the instance (using date interval) with overflow explicitly forbidden.
  220.  * @method        CarbonImmutable              subMonthsWithNoOverflow(int $value = 1)                                              Sub months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  221.  * @method        CarbonImmutable              subMonthWithNoOverflow()                                                             Sub one month to the instance (using date interval) with overflow explicitly forbidden.
  222.  * @method        CarbonImmutable              addMonthsNoOverflow(int $value = 1)                                                  Add months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  223.  * @method        CarbonImmutable              addMonthNoOverflow()                                                                 Add one month to the instance (using date interval) with overflow explicitly forbidden.
  224.  * @method        CarbonImmutable              subMonthsNoOverflow(int $value = 1)                                                  Sub months (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  225.  * @method        CarbonImmutable              subMonthNoOverflow()                                                                 Sub one month to the instance (using date interval) with overflow explicitly forbidden.
  226.  * @method        CarbonImmutable              addDays(int $value = 1)                                                              Add days (the $value count passed in) to the instance (using date interval).
  227.  * @method        CarbonImmutable              addDay()                                                                             Add one day to the instance (using date interval).
  228.  * @method        CarbonImmutable              subDays(int $value = 1)                                                              Sub days (the $value count passed in) to the instance (using date interval).
  229.  * @method        CarbonImmutable              subDay()                                                                             Sub one day to the instance (using date interval).
  230.  * @method        CarbonImmutable              addHours(int $value = 1)                                                             Add hours (the $value count passed in) to the instance (using date interval).
  231.  * @method        CarbonImmutable              addHour()                                                                            Add one hour to the instance (using date interval).
  232.  * @method        CarbonImmutable              subHours(int $value = 1)                                                             Sub hours (the $value count passed in) to the instance (using date interval).
  233.  * @method        CarbonImmutable              subHour()                                                                            Sub one hour to the instance (using date interval).
  234.  * @method        CarbonImmutable              addMinutes(int $value = 1)                                                           Add minutes (the $value count passed in) to the instance (using date interval).
  235.  * @method        CarbonImmutable              addMinute()                                                                          Add one minute to the instance (using date interval).
  236.  * @method        CarbonImmutable              subMinutes(int $value = 1)                                                           Sub minutes (the $value count passed in) to the instance (using date interval).
  237.  * @method        CarbonImmutable              subMinute()                                                                          Sub one minute to the instance (using date interval).
  238.  * @method        CarbonImmutable              addSeconds(int $value = 1)                                                           Add seconds (the $value count passed in) to the instance (using date interval).
  239.  * @method        CarbonImmutable              addSecond()                                                                          Add one second to the instance (using date interval).
  240.  * @method        CarbonImmutable              subSeconds(int $value = 1)                                                           Sub seconds (the $value count passed in) to the instance (using date interval).
  241.  * @method        CarbonImmutable              subSecond()                                                                          Sub one second to the instance (using date interval).
  242.  * @method        CarbonImmutable              addMillis(int $value = 1)                                                            Add milliseconds (the $value count passed in) to the instance (using date interval).
  243.  * @method        CarbonImmutable              addMilli()                                                                           Add one millisecond to the instance (using date interval).
  244.  * @method        CarbonImmutable              subMillis(int $value = 1)                                                            Sub milliseconds (the $value count passed in) to the instance (using date interval).
  245.  * @method        CarbonImmutable              subMilli()                                                                           Sub one millisecond to the instance (using date interval).
  246.  * @method        CarbonImmutable              addMilliseconds(int $value = 1)                                                      Add milliseconds (the $value count passed in) to the instance (using date interval).
  247.  * @method        CarbonImmutable              addMillisecond()                                                                     Add one millisecond to the instance (using date interval).
  248.  * @method        CarbonImmutable              subMilliseconds(int $value = 1)                                                      Sub milliseconds (the $value count passed in) to the instance (using date interval).
  249.  * @method        CarbonImmutable              subMillisecond()                                                                     Sub one millisecond to the instance (using date interval).
  250.  * @method        CarbonImmutable              addMicros(int $value = 1)                                                            Add microseconds (the $value count passed in) to the instance (using date interval).
  251.  * @method        CarbonImmutable              addMicro()                                                                           Add one microsecond to the instance (using date interval).
  252.  * @method        CarbonImmutable              subMicros(int $value = 1)                                                            Sub microseconds (the $value count passed in) to the instance (using date interval).
  253.  * @method        CarbonImmutable              subMicro()                                                                           Sub one microsecond to the instance (using date interval).
  254.  * @method        CarbonImmutable              addMicroseconds(int $value = 1)                                                      Add microseconds (the $value count passed in) to the instance (using date interval).
  255.  * @method        CarbonImmutable              addMicrosecond()                                                                     Add one microsecond to the instance (using date interval).
  256.  * @method        CarbonImmutable              subMicroseconds(int $value = 1)                                                      Sub microseconds (the $value count passed in) to the instance (using date interval).
  257.  * @method        CarbonImmutable              subMicrosecond()                                                                     Sub one microsecond to the instance (using date interval).
  258.  * @method        CarbonImmutable              addMillennia(int $value = 1)                                                         Add millennia (the $value count passed in) to the instance (using date interval).
  259.  * @method        CarbonImmutable              addMillennium()                                                                      Add one millennium to the instance (using date interval).
  260.  * @method        CarbonImmutable              subMillennia(int $value = 1)                                                         Sub millennia (the $value count passed in) to the instance (using date interval).
  261.  * @method        CarbonImmutable              subMillennium()                                                                      Sub one millennium to the instance (using date interval).
  262.  * @method        CarbonImmutable              addMillenniaWithOverflow(int $value = 1)                                             Add millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  263.  * @method        CarbonImmutable              addMillenniumWithOverflow()                                                          Add one millennium to the instance (using date interval) with overflow explicitly allowed.
  264.  * @method        CarbonImmutable              subMillenniaWithOverflow(int $value = 1)                                             Sub millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  265.  * @method        CarbonImmutable              subMillenniumWithOverflow()                                                          Sub one millennium to the instance (using date interval) with overflow explicitly allowed.
  266.  * @method        CarbonImmutable              addMillenniaWithoutOverflow(int $value = 1)                                          Add millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  267.  * @method        CarbonImmutable              addMillenniumWithoutOverflow()                                                       Add one millennium to the instance (using date interval) with overflow explicitly forbidden.
  268.  * @method        CarbonImmutable              subMillenniaWithoutOverflow(int $value = 1)                                          Sub millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  269.  * @method        CarbonImmutable              subMillenniumWithoutOverflow()                                                       Sub one millennium to the instance (using date interval) with overflow explicitly forbidden.
  270.  * @method        CarbonImmutable              addMillenniaWithNoOverflow(int $value = 1)                                           Add millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  271.  * @method        CarbonImmutable              addMillenniumWithNoOverflow()                                                        Add one millennium to the instance (using date interval) with overflow explicitly forbidden.
  272.  * @method        CarbonImmutable              subMillenniaWithNoOverflow(int $value = 1)                                           Sub millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  273.  * @method        CarbonImmutable              subMillenniumWithNoOverflow()                                                        Sub one millennium to the instance (using date interval) with overflow explicitly forbidden.
  274.  * @method        CarbonImmutable              addMillenniaNoOverflow(int $value = 1)                                               Add millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  275.  * @method        CarbonImmutable              addMillenniumNoOverflow()                                                            Add one millennium to the instance (using date interval) with overflow explicitly forbidden.
  276.  * @method        CarbonImmutable              subMillenniaNoOverflow(int $value = 1)                                               Sub millennia (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  277.  * @method        CarbonImmutable              subMillenniumNoOverflow()                                                            Sub one millennium to the instance (using date interval) with overflow explicitly forbidden.
  278.  * @method        CarbonImmutable              addCenturies(int $value = 1)                                                         Add centuries (the $value count passed in) to the instance (using date interval).
  279.  * @method        CarbonImmutable              addCentury()                                                                         Add one century to the instance (using date interval).
  280.  * @method        CarbonImmutable              subCenturies(int $value = 1)                                                         Sub centuries (the $value count passed in) to the instance (using date interval).
  281.  * @method        CarbonImmutable              subCentury()                                                                         Sub one century to the instance (using date interval).
  282.  * @method        CarbonImmutable              addCenturiesWithOverflow(int $value = 1)                                             Add centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  283.  * @method        CarbonImmutable              addCenturyWithOverflow()                                                             Add one century to the instance (using date interval) with overflow explicitly allowed.
  284.  * @method        CarbonImmutable              subCenturiesWithOverflow(int $value = 1)                                             Sub centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  285.  * @method        CarbonImmutable              subCenturyWithOverflow()                                                             Sub one century to the instance (using date interval) with overflow explicitly allowed.
  286.  * @method        CarbonImmutable              addCenturiesWithoutOverflow(int $value = 1)                                          Add centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  287.  * @method        CarbonImmutable              addCenturyWithoutOverflow()                                                          Add one century to the instance (using date interval) with overflow explicitly forbidden.
  288.  * @method        CarbonImmutable              subCenturiesWithoutOverflow(int $value = 1)                                          Sub centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  289.  * @method        CarbonImmutable              subCenturyWithoutOverflow()                                                          Sub one century to the instance (using date interval) with overflow explicitly forbidden.
  290.  * @method        CarbonImmutable              addCenturiesWithNoOverflow(int $value = 1)                                           Add centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  291.  * @method        CarbonImmutable              addCenturyWithNoOverflow()                                                           Add one century to the instance (using date interval) with overflow explicitly forbidden.
  292.  * @method        CarbonImmutable              subCenturiesWithNoOverflow(int $value = 1)                                           Sub centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  293.  * @method        CarbonImmutable              subCenturyWithNoOverflow()                                                           Sub one century to the instance (using date interval) with overflow explicitly forbidden.
  294.  * @method        CarbonImmutable              addCenturiesNoOverflow(int $value = 1)                                               Add centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  295.  * @method        CarbonImmutable              addCenturyNoOverflow()                                                               Add one century to the instance (using date interval) with overflow explicitly forbidden.
  296.  * @method        CarbonImmutable              subCenturiesNoOverflow(int $value = 1)                                               Sub centuries (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  297.  * @method        CarbonImmutable              subCenturyNoOverflow()                                                               Sub one century to the instance (using date interval) with overflow explicitly forbidden.
  298.  * @method        CarbonImmutable              addDecades(int $value = 1)                                                           Add decades (the $value count passed in) to the instance (using date interval).
  299.  * @method        CarbonImmutable              addDecade()                                                                          Add one decade to the instance (using date interval).
  300.  * @method        CarbonImmutable              subDecades(int $value = 1)                                                           Sub decades (the $value count passed in) to the instance (using date interval).
  301.  * @method        CarbonImmutable              subDecade()                                                                          Sub one decade to the instance (using date interval).
  302.  * @method        CarbonImmutable              addDecadesWithOverflow(int $value = 1)                                               Add decades (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  303.  * @method        CarbonImmutable              addDecadeWithOverflow()                                                              Add one decade to the instance (using date interval) with overflow explicitly allowed.
  304.  * @method        CarbonImmutable              subDecadesWithOverflow(int $value = 1)                                               Sub decades (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  305.  * @method        CarbonImmutable              subDecadeWithOverflow()                                                              Sub one decade to the instance (using date interval) with overflow explicitly allowed.
  306.  * @method        CarbonImmutable              addDecadesWithoutOverflow(int $value = 1)                                            Add decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  307.  * @method        CarbonImmutable              addDecadeWithoutOverflow()                                                           Add one decade to the instance (using date interval) with overflow explicitly forbidden.
  308.  * @method        CarbonImmutable              subDecadesWithoutOverflow(int $value = 1)                                            Sub decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  309.  * @method        CarbonImmutable              subDecadeWithoutOverflow()                                                           Sub one decade to the instance (using date interval) with overflow explicitly forbidden.
  310.  * @method        CarbonImmutable              addDecadesWithNoOverflow(int $value = 1)                                             Add decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  311.  * @method        CarbonImmutable              addDecadeWithNoOverflow()                                                            Add one decade to the instance (using date interval) with overflow explicitly forbidden.
  312.  * @method        CarbonImmutable              subDecadesWithNoOverflow(int $value = 1)                                             Sub decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  313.  * @method        CarbonImmutable              subDecadeWithNoOverflow()                                                            Sub one decade to the instance (using date interval) with overflow explicitly forbidden.
  314.  * @method        CarbonImmutable              addDecadesNoOverflow(int $value = 1)                                                 Add decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  315.  * @method        CarbonImmutable              addDecadeNoOverflow()                                                                Add one decade to the instance (using date interval) with overflow explicitly forbidden.
  316.  * @method        CarbonImmutable              subDecadesNoOverflow(int $value = 1)                                                 Sub decades (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  317.  * @method        CarbonImmutable              subDecadeNoOverflow()                                                                Sub one decade to the instance (using date interval) with overflow explicitly forbidden.
  318.  * @method        CarbonImmutable              addQuarters(int $value = 1)                                                          Add quarters (the $value count passed in) to the instance (using date interval).
  319.  * @method        CarbonImmutable              addQuarter()                                                                         Add one quarter to the instance (using date interval).
  320.  * @method        CarbonImmutable              subQuarters(int $value = 1)                                                          Sub quarters (the $value count passed in) to the instance (using date interval).
  321.  * @method        CarbonImmutable              subQuarter()                                                                         Sub one quarter to the instance (using date interval).
  322.  * @method        CarbonImmutable              addQuartersWithOverflow(int $value = 1)                                              Add quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  323.  * @method        CarbonImmutable              addQuarterWithOverflow()                                                             Add one quarter to the instance (using date interval) with overflow explicitly allowed.
  324.  * @method        CarbonImmutable              subQuartersWithOverflow(int $value = 1)                                              Sub quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly allowed.
  325.  * @method        CarbonImmutable              subQuarterWithOverflow()                                                             Sub one quarter to the instance (using date interval) with overflow explicitly allowed.
  326.  * @method        CarbonImmutable              addQuartersWithoutOverflow(int $value = 1)                                           Add quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  327.  * @method        CarbonImmutable              addQuarterWithoutOverflow()                                                          Add one quarter to the instance (using date interval) with overflow explicitly forbidden.
  328.  * @method        CarbonImmutable              subQuartersWithoutOverflow(int $value = 1)                                           Sub quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  329.  * @method        CarbonImmutable              subQuarterWithoutOverflow()                                                          Sub one quarter to the instance (using date interval) with overflow explicitly forbidden.
  330.  * @method        CarbonImmutable              addQuartersWithNoOverflow(int $value = 1)                                            Add quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  331.  * @method        CarbonImmutable              addQuarterWithNoOverflow()                                                           Add one quarter to the instance (using date interval) with overflow explicitly forbidden.
  332.  * @method        CarbonImmutable              subQuartersWithNoOverflow(int $value = 1)                                            Sub quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  333.  * @method        CarbonImmutable              subQuarterWithNoOverflow()                                                           Sub one quarter to the instance (using date interval) with overflow explicitly forbidden.
  334.  * @method        CarbonImmutable              addQuartersNoOverflow(int $value = 1)                                                Add quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  335.  * @method        CarbonImmutable              addQuarterNoOverflow()                                                               Add one quarter to the instance (using date interval) with overflow explicitly forbidden.
  336.  * @method        CarbonImmutable              subQuartersNoOverflow(int $value = 1)                                                Sub quarters (the $value count passed in) to the instance (using date interval) with overflow explicitly forbidden.
  337.  * @method        CarbonImmutable              subQuarterNoOverflow()                                                               Sub one quarter to the instance (using date interval) with overflow explicitly forbidden.
  338.  * @method        CarbonImmutable              addWeeks(int $value = 1)                                                             Add weeks (the $value count passed in) to the instance (using date interval).
  339.  * @method        CarbonImmutable              addWeek()                                                                            Add one week to the instance (using date interval).
  340.  * @method        CarbonImmutable              subWeeks(int $value = 1)                                                             Sub weeks (the $value count passed in) to the instance (using date interval).
  341.  * @method        CarbonImmutable              subWeek()                                                                            Sub one week to the instance (using date interval).
  342.  * @method        CarbonImmutable              addWeekdays(int $value = 1)                                                          Add weekdays (the $value count passed in) to the instance (using date interval).
  343.  * @method        CarbonImmutable              addWeekday()                                                                         Add one weekday to the instance (using date interval).
  344.  * @method        CarbonImmutable              subWeekdays(int $value = 1)                                                          Sub weekdays (the $value count passed in) to the instance (using date interval).
  345.  * @method        CarbonImmutable              subWeekday()                                                                         Sub one weekday to the instance (using date interval).
  346.  * @method        CarbonImmutable              addRealMicros(int $value = 1)                                                        Add microseconds (the $value count passed in) to the instance (using timestamp).
  347.  * @method        CarbonImmutable              addRealMicro()                                                                       Add one microsecond to the instance (using timestamp).
  348.  * @method        CarbonImmutable              subRealMicros(int $value = 1)                                                        Sub microseconds (the $value count passed in) to the instance (using timestamp).
  349.  * @method        CarbonImmutable              subRealMicro()                                                                       Sub one microsecond to the instance (using timestamp).
  350.  * @method        CarbonPeriod                 microsUntil($endDate = null, int $factor = 1)                                        Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each microsecond or every X microseconds if a factor is given.
  351.  * @method        CarbonImmutable              addRealMicroseconds(int $value = 1)                                                  Add microseconds (the $value count passed in) to the instance (using timestamp).
  352.  * @method        CarbonImmutable              addRealMicrosecond()                                                                 Add one microsecond to the instance (using timestamp).
  353.  * @method        CarbonImmutable              subRealMicroseconds(int $value = 1)                                                  Sub microseconds (the $value count passed in) to the instance (using timestamp).
  354.  * @method        CarbonImmutable              subRealMicrosecond()                                                                 Sub one microsecond to the instance (using timestamp).
  355.  * @method        CarbonPeriod                 microsecondsUntil($endDate = null, int $factor = 1)                                  Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each microsecond or every X microseconds if a factor is given.
  356.  * @method        CarbonImmutable              addRealMillis(int $value = 1)                                                        Add milliseconds (the $value count passed in) to the instance (using timestamp).
  357.  * @method        CarbonImmutable              addRealMilli()                                                                       Add one millisecond to the instance (using timestamp).
  358.  * @method        CarbonImmutable              subRealMillis(int $value = 1)                                                        Sub milliseconds (the $value count passed in) to the instance (using timestamp).
  359.  * @method        CarbonImmutable              subRealMilli()                                                                       Sub one millisecond to the instance (using timestamp).
  360.  * @method        CarbonPeriod                 millisUntil($endDate = null, int $factor = 1)                                        Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each millisecond or every X milliseconds if a factor is given.
  361.  * @method        CarbonImmutable              addRealMilliseconds(int $value = 1)                                                  Add milliseconds (the $value count passed in) to the instance (using timestamp).
  362.  * @method        CarbonImmutable              addRealMillisecond()                                                                 Add one millisecond to the instance (using timestamp).
  363.  * @method        CarbonImmutable              subRealMilliseconds(int $value = 1)                                                  Sub milliseconds (the $value count passed in) to the instance (using timestamp).
  364.  * @method        CarbonImmutable              subRealMillisecond()                                                                 Sub one millisecond to the instance (using timestamp).
  365.  * @method        CarbonPeriod                 millisecondsUntil($endDate = null, int $factor = 1)                                  Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each millisecond or every X milliseconds if a factor is given.
  366.  * @method        CarbonImmutable              addRealSeconds(int $value = 1)                                                       Add seconds (the $value count passed in) to the instance (using timestamp).
  367.  * @method        CarbonImmutable              addRealSecond()                                                                      Add one second to the instance (using timestamp).
  368.  * @method        CarbonImmutable              subRealSeconds(int $value = 1)                                                       Sub seconds (the $value count passed in) to the instance (using timestamp).
  369.  * @method        CarbonImmutable              subRealSecond()                                                                      Sub one second to the instance (using timestamp).
  370.  * @method        CarbonPeriod                 secondsUntil($endDate = null, int $factor = 1)                                       Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each second or every X seconds if a factor is given.
  371.  * @method        CarbonImmutable              addRealMinutes(int $value = 1)                                                       Add minutes (the $value count passed in) to the instance (using timestamp).
  372.  * @method        CarbonImmutable              addRealMinute()                                                                      Add one minute to the instance (using timestamp).
  373.  * @method        CarbonImmutable              subRealMinutes(int $value = 1)                                                       Sub minutes (the $value count passed in) to the instance (using timestamp).
  374.  * @method        CarbonImmutable              subRealMinute()                                                                      Sub one minute to the instance (using timestamp).
  375.  * @method        CarbonPeriod                 minutesUntil($endDate = null, int $factor = 1)                                       Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each minute or every X minutes if a factor is given.
  376.  * @method        CarbonImmutable              addRealHours(int $value = 1)                                                         Add hours (the $value count passed in) to the instance (using timestamp).
  377.  * @method        CarbonImmutable              addRealHour()                                                                        Add one hour to the instance (using timestamp).
  378.  * @method        CarbonImmutable              subRealHours(int $value = 1)                                                         Sub hours (the $value count passed in) to the instance (using timestamp).
  379.  * @method        CarbonImmutable              subRealHour()                                                                        Sub one hour to the instance (using timestamp).
  380.  * @method        CarbonPeriod                 hoursUntil($endDate = null, int $factor = 1)                                         Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each hour or every X hours if a factor is given.
  381.  * @method        CarbonImmutable              addRealDays(int $value = 1)                                                          Add days (the $value count passed in) to the instance (using timestamp).
  382.  * @method        CarbonImmutable              addRealDay()                                                                         Add one day to the instance (using timestamp).
  383.  * @method        CarbonImmutable              subRealDays(int $value = 1)                                                          Sub days (the $value count passed in) to the instance (using timestamp).
  384.  * @method        CarbonImmutable              subRealDay()                                                                         Sub one day to the instance (using timestamp).
  385.  * @method        CarbonPeriod                 daysUntil($endDate = null, int $factor = 1)                                          Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each day or every X days if a factor is given.
  386.  * @method        CarbonImmutable              addRealWeeks(int $value = 1)                                                         Add weeks (the $value count passed in) to the instance (using timestamp).
  387.  * @method        CarbonImmutable              addRealWeek()                                                                        Add one week to the instance (using timestamp).
  388.  * @method        CarbonImmutable              subRealWeeks(int $value = 1)                                                         Sub weeks (the $value count passed in) to the instance (using timestamp).
  389.  * @method        CarbonImmutable              subRealWeek()                                                                        Sub one week to the instance (using timestamp).
  390.  * @method        CarbonPeriod                 weeksUntil($endDate = null, int $factor = 1)                                         Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each week or every X weeks if a factor is given.
  391.  * @method        CarbonImmutable              addRealMonths(int $value = 1)                                                        Add months (the $value count passed in) to the instance (using timestamp).
  392.  * @method        CarbonImmutable              addRealMonth()                                                                       Add one month to the instance (using timestamp).
  393.  * @method        CarbonImmutable              subRealMonths(int $value = 1)                                                        Sub months (the $value count passed in) to the instance (using timestamp).
  394.  * @method        CarbonImmutable              subRealMonth()                                                                       Sub one month to the instance (using timestamp).
  395.  * @method        CarbonPeriod                 monthsUntil($endDate = null, int $factor = 1)                                        Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each month or every X months if a factor is given.
  396.  * @method        CarbonImmutable              addRealQuarters(int $value = 1)                                                      Add quarters (the $value count passed in) to the instance (using timestamp).
  397.  * @method        CarbonImmutable              addRealQuarter()                                                                     Add one quarter to the instance (using timestamp).
  398.  * @method        CarbonImmutable              subRealQuarters(int $value = 1)                                                      Sub quarters (the $value count passed in) to the instance (using timestamp).
  399.  * @method        CarbonImmutable              subRealQuarter()                                                                     Sub one quarter to the instance (using timestamp).
  400.  * @method        CarbonPeriod                 quartersUntil($endDate = null, int $factor = 1)                                      Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each quarter or every X quarters if a factor is given.
  401.  * @method        CarbonImmutable              addRealYears(int $value = 1)                                                         Add years (the $value count passed in) to the instance (using timestamp).
  402.  * @method        CarbonImmutable              addRealYear()                                                                        Add one year to the instance (using timestamp).
  403.  * @method        CarbonImmutable              subRealYears(int $value = 1)                                                         Sub years (the $value count passed in) to the instance (using timestamp).
  404.  * @method        CarbonImmutable              subRealYear()                                                                        Sub one year to the instance (using timestamp).
  405.  * @method        CarbonPeriod                 yearsUntil($endDate = null, int $factor = 1)                                         Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each year or every X years if a factor is given.
  406.  * @method        CarbonImmutable              addRealDecades(int $value = 1)                                                       Add decades (the $value count passed in) to the instance (using timestamp).
  407.  * @method        CarbonImmutable              addRealDecade()                                                                      Add one decade to the instance (using timestamp).
  408.  * @method        CarbonImmutable              subRealDecades(int $value = 1)                                                       Sub decades (the $value count passed in) to the instance (using timestamp).
  409.  * @method        CarbonImmutable              subRealDecade()                                                                      Sub one decade to the instance (using timestamp).
  410.  * @method        CarbonPeriod                 decadesUntil($endDate = null, int $factor = 1)                                       Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each decade or every X decades if a factor is given.
  411.  * @method        CarbonImmutable              addRealCenturies(int $value = 1)                                                     Add centuries (the $value count passed in) to the instance (using timestamp).
  412.  * @method        CarbonImmutable              addRealCentury()                                                                     Add one century to the instance (using timestamp).
  413.  * @method        CarbonImmutable              subRealCenturies(int $value = 1)                                                     Sub centuries (the $value count passed in) to the instance (using timestamp).
  414.  * @method        CarbonImmutable              subRealCentury()                                                                     Sub one century to the instance (using timestamp).
  415.  * @method        CarbonPeriod                 centuriesUntil($endDate = null, int $factor = 1)                                     Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each century or every X centuries if a factor is given.
  416.  * @method        CarbonImmutable              addRealMillennia(int $value = 1)                                                     Add millennia (the $value count passed in) to the instance (using timestamp).
  417.  * @method        CarbonImmutable              addRealMillennium()                                                                  Add one millennium to the instance (using timestamp).
  418.  * @method        CarbonImmutable              subRealMillennia(int $value = 1)                                                     Sub millennia (the $value count passed in) to the instance (using timestamp).
  419.  * @method        CarbonImmutable              subRealMillennium()                                                                  Sub one millennium to the instance (using timestamp).
  420.  * @method        CarbonPeriod                 millenniaUntil($endDate = null, int $factor = 1)                                     Return an iterable period from current date to given end (string, DateTime or Carbon instance) for each millennium or every X millennia if a factor is given.
  421.  * @method        CarbonImmutable              roundYear(float $precision = 1, string $function = "round")                          Round the current instance year with given precision using the given function.
  422.  * @method        CarbonImmutable              roundYears(float $precision = 1, string $function = "round")                         Round the current instance year with given precision using the given function.
  423.  * @method        CarbonImmutable              floorYear(float $precision = 1)                                                      Truncate the current instance year with given precision.
  424.  * @method        CarbonImmutable              floorYears(float $precision = 1)                                                     Truncate the current instance year with given precision.
  425.  * @method        CarbonImmutable              ceilYear(float $precision = 1)                                                       Ceil the current instance year with given precision.
  426.  * @method        CarbonImmutable              ceilYears(float $precision = 1)                                                      Ceil the current instance year with given precision.
  427.  * @method        CarbonImmutable              roundMonth(float $precision = 1, string $function = "round")                         Round the current instance month with given precision using the given function.
  428.  * @method        CarbonImmutable              roundMonths(float $precision = 1, string $function = "round")                        Round the current instance month with given precision using the given function.
  429.  * @method        CarbonImmutable              floorMonth(float $precision = 1)                                                     Truncate the current instance month with given precision.
  430.  * @method        CarbonImmutable              floorMonths(float $precision = 1)                                                    Truncate the current instance month with given precision.
  431.  * @method        CarbonImmutable              ceilMonth(float $precision = 1)                                                      Ceil the current instance month with given precision.
  432.  * @method        CarbonImmutable              ceilMonths(float $precision = 1)                                                     Ceil the current instance month with given precision.
  433.  * @method        CarbonImmutable              roundDay(float $precision = 1, string $function = "round")                           Round the current instance day with given precision using the given function.
  434.  * @method        CarbonImmutable              roundDays(float $precision = 1, string $function = "round")                          Round the current instance day with given precision using the given function.
  435.  * @method        CarbonImmutable              floorDay(float $precision = 1)                                                       Truncate the current instance day with given precision.
  436.  * @method        CarbonImmutable              floorDays(float $precision = 1)                                                      Truncate the current instance day with given precision.
  437.  * @method        CarbonImmutable              ceilDay(float $precision = 1)                                                        Ceil the current instance day with given precision.
  438.  * @method        CarbonImmutable              ceilDays(float $precision = 1)                                                       Ceil the current instance day with given precision.
  439.  * @method        CarbonImmutable              roundHour(float $precision = 1, string $function = "round")                          Round the current instance hour with given precision using the given function.
  440.  * @method        CarbonImmutable              roundHours(float $precision = 1, string $function = "round")                         Round the current instance hour with given precision using the given function.
  441.  * @method        CarbonImmutable              floorHour(float $precision = 1)                                                      Truncate the current instance hour with given precision.
  442.  * @method        CarbonImmutable              floorHours(float $precision = 1)                                                     Truncate the current instance hour with given precision.
  443.  * @method        CarbonImmutable              ceilHour(float $precision = 1)                                                       Ceil the current instance hour with given precision.
  444.  * @method        CarbonImmutable              ceilHours(float $precision = 1)                                                      Ceil the current instance hour with given precision.
  445.  * @method        CarbonImmutable              roundMinute(float $precision = 1, string $function = "round")                        Round the current instance minute with given precision using the given function.
  446.  * @method        CarbonImmutable              roundMinutes(float $precision = 1, string $function = "round")                       Round the current instance minute with given precision using the given function.
  447.  * @method        CarbonImmutable              floorMinute(float $precision = 1)                                                    Truncate the current instance minute with given precision.
  448.  * @method        CarbonImmutable              floorMinutes(float $precision = 1)                                                   Truncate the current instance minute with given precision.
  449.  * @method        CarbonImmutable              ceilMinute(float $precision = 1)                                                     Ceil the current instance minute with given precision.
  450.  * @method        CarbonImmutable              ceilMinutes(float $precision = 1)                                                    Ceil the current instance minute with given precision.
  451.  * @method        CarbonImmutable              roundSecond(float $precision = 1, string $function = "round")                        Round the current instance second with given precision using the given function.
  452.  * @method        CarbonImmutable              roundSeconds(float $precision = 1, string $function = "round")                       Round the current instance second with given precision using the given function.
  453.  * @method        CarbonImmutable              floorSecond(float $precision = 1)                                                    Truncate the current instance second with given precision.
  454.  * @method        CarbonImmutable              floorSeconds(float $precision = 1)                                                   Truncate the current instance second with given precision.
  455.  * @method        CarbonImmutable              ceilSecond(float $precision = 1)                                                     Ceil the current instance second with given precision.
  456.  * @method        CarbonImmutable              ceilSeconds(float $precision = 1)                                                    Ceil the current instance second with given precision.
  457.  * @method        CarbonImmutable              roundMillennium(float $precision = 1, string $function = "round")                    Round the current instance millennium with given precision using the given function.
  458.  * @method        CarbonImmutable              roundMillennia(float $precision = 1, string $function = "round")                     Round the current instance millennium with given precision using the given function.
  459.  * @method        CarbonImmutable              floorMillennium(float $precision = 1)                                                Truncate the current instance millennium with given precision.
  460.  * @method        CarbonImmutable              floorMillennia(float $precision = 1)                                                 Truncate the current instance millennium with given precision.
  461.  * @method        CarbonImmutable              ceilMillennium(float $precision = 1)                                                 Ceil the current instance millennium with given precision.
  462.  * @method        CarbonImmutable              ceilMillennia(float $precision = 1)                                                  Ceil the current instance millennium with given precision.
  463.  * @method        CarbonImmutable              roundCentury(float $precision = 1, string $function = "round")                       Round the current instance century with given precision using the given function.
  464.  * @method        CarbonImmutable              roundCenturies(float $precision = 1, string $function = "round")                     Round the current instance century with given precision using the given function.
  465.  * @method        CarbonImmutable              floorCentury(float $precision = 1)                                                   Truncate the current instance century with given precision.
  466.  * @method        CarbonImmutable              floorCenturies(float $precision = 1)                                                 Truncate the current instance century with given precision.
  467.  * @method        CarbonImmutable              ceilCentury(float $precision = 1)                                                    Ceil the current instance century with given precision.
  468.  * @method        CarbonImmutable              ceilCenturies(float $precision = 1)                                                  Ceil the current instance century with given precision.
  469.  * @method        CarbonImmutable              roundDecade(float $precision = 1, string $function = "round")                        Round the current instance decade with given precision using the given function.
  470.  * @method        CarbonImmutable              roundDecades(float $precision = 1, string $function = "round")                       Round the current instance decade with given precision using the given function.
  471.  * @method        CarbonImmutable              floorDecade(float $precision = 1)                                                    Truncate the current instance decade with given precision.
  472.  * @method        CarbonImmutable              floorDecades(float $precision = 1)                                                   Truncate the current instance decade with given precision.
  473.  * @method        CarbonImmutable              ceilDecade(float $precision = 1)                                                     Ceil the current instance decade with given precision.
  474.  * @method        CarbonImmutable              ceilDecades(float $precision = 1)                                                    Ceil the current instance decade with given precision.
  475.  * @method        CarbonImmutable              roundQuarter(float $precision = 1, string $function = "round")                       Round the current instance quarter with given precision using the given function.
  476.  * @method        CarbonImmutable              roundQuarters(float $precision = 1, string $function = "round")                      Round the current instance quarter with given precision using the given function.
  477.  * @method        CarbonImmutable              floorQuarter(float $precision = 1)                                                   Truncate the current instance quarter with given precision.
  478.  * @method        CarbonImmutable              floorQuarters(float $precision = 1)                                                  Truncate the current instance quarter with given precision.
  479.  * @method        CarbonImmutable              ceilQuarter(float $precision = 1)                                                    Ceil the current instance quarter with given precision.
  480.  * @method        CarbonImmutable              ceilQuarters(float $precision = 1)                                                   Ceil the current instance quarter with given precision.
  481.  * @method        CarbonImmutable              roundMillisecond(float $precision = 1, string $function = "round")                   Round the current instance millisecond with given precision using the given function.
  482.  * @method        CarbonImmutable              roundMilliseconds(float $precision = 1, string $function = "round")                  Round the current instance millisecond with given precision using the given function.
  483.  * @method        CarbonImmutable              floorMillisecond(float $precision = 1)                                               Truncate the current instance millisecond with given precision.
  484.  * @method        CarbonImmutable              floorMilliseconds(float $precision = 1)                                              Truncate the current instance millisecond with given precision.
  485.  * @method        CarbonImmutable              ceilMillisecond(float $precision = 1)                                                Ceil the current instance millisecond with given precision.
  486.  * @method        CarbonImmutable              ceilMilliseconds(float $precision = 1)                                               Ceil the current instance millisecond with given precision.
  487.  * @method        CarbonImmutable              roundMicrosecond(float $precision = 1, string $function = "round")                   Round the current instance microsecond with given precision using the given function.
  488.  * @method        CarbonImmutable              roundMicroseconds(float $precision = 1, string $function = "round")                  Round the current instance microsecond with given precision using the given function.
  489.  * @method        CarbonImmutable              floorMicrosecond(float $precision = 1)                                               Truncate the current instance microsecond with given precision.
  490.  * @method        CarbonImmutable              floorMicroseconds(float $precision = 1)                                              Truncate the current instance microsecond with given precision.
  491.  * @method        CarbonImmutable              ceilMicrosecond(float $precision = 1)                                                Ceil the current instance microsecond with given precision.
  492.  * @method        CarbonImmutable              ceilMicroseconds(float $precision = 1)                                               Ceil the current instance microsecond with given precision.
  493.  * @method        string                       shortAbsoluteDiffForHumans(DateTimeInterface $other = null, int $parts = 1)          Get the difference (short format, 'Absolute' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  494.  * @method        string                       longAbsoluteDiffForHumans(DateTimeInterface $other = null, int $parts = 1)           Get the difference (long format, 'Absolute' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  495.  * @method        string                       shortRelativeDiffForHumans(DateTimeInterface $other = null, int $parts = 1)          Get the difference (short format, 'Relative' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  496.  * @method        string                       longRelativeDiffForHumans(DateTimeInterface $other = null, int $parts = 1)           Get the difference (long format, 'Relative' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  497.  * @method        string                       shortRelativeToNowDiffForHumans(DateTimeInterface $other = null, int $parts = 1)     Get the difference (short format, 'RelativeToNow' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  498.  * @method        string                       longRelativeToNowDiffForHumans(DateTimeInterface $other = null, int $parts = 1)      Get the difference (long format, 'RelativeToNow' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  499.  * @method        string                       shortRelativeToOtherDiffForHumans(DateTimeInterface $other = null, int $parts = 1)   Get the difference (short format, 'RelativeToOther' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  500.  * @method        string                       longRelativeToOtherDiffForHumans(DateTimeInterface $other = null, int $parts = 1)    Get the difference (long format, 'RelativeToOther' mode) in a human readable format in the current locale. ($other and $parts parameters can be swapped.)
  501.  * @method        static CarbonImmutable|false createFromFormat(string $format, string $time, string|DateTimeZone $timezone = null) Parse a string into a new CarbonImmutable object according to the specified format.
  502.  * @method        static CarbonImmutable       __set_state(array $array)                                                            https://php.net/manual/en/datetime.set-state.php
  503.  *
  504.  * </autodoc>
  505.  */
  506. class CarbonImmutable extends DateTimeImmutable implements CarbonInterface
  507. {
  508.     use Date {
  509.         __clone as dateTraitClone;
  510.     }
  511.     public function __clone()
  512.     {
  513.         $this->dateTraitClone();
  514.         $this->endOfTime false;
  515.         $this->startOfTime false;
  516.     }
  517.     /**
  518.      * Create a very old date representing start of time.
  519.      *
  520.      * @return static
  521.      */
  522.     public static function startOfTime(): self
  523.     {
  524.         $date = static::parse('0001-01-01')->years(self::getStartOfTimeYear());
  525.         $date->startOfTime true;
  526.         return $date;
  527.     }
  528.     /**
  529.      * Create a very far date representing end of time.
  530.      *
  531.      * @return static
  532.      */
  533.     public static function endOfTime(): self
  534.     {
  535.         $date = static::parse('9999-12-31 23:59:59.999999')->years(self::getEndOfTimeYear());
  536.         $date->endOfTime true;
  537.         return $date;
  538.     }
  539.     /**
  540.      * @codeCoverageIgnore
  541.      */
  542.     private static function getEndOfTimeYear(): int
  543.     {
  544.         if (version_compare(PHP_VERSION'7.3.0-dev''<')) {
  545.             return 145261681241552;
  546.         }
  547.         // Remove if https://bugs.php.net/bug.php?id=81107 is fixed
  548.         if (version_compare(PHP_VERSION'8.1.0-dev''>=')) {
  549.             return 1118290769066902787;
  550.         }
  551.         return PHP_INT_MAX;
  552.     }
  553.     /**
  554.      * @codeCoverageIgnore
  555.      */
  556.     private static function getStartOfTimeYear(): int
  557.     {
  558.         if (version_compare(PHP_VERSION'7.3.0-dev''<')) {
  559.             return -135908816449551;
  560.         }
  561.         // Remove if https://bugs.php.net/bug.php?id=81107 is fixed
  562.         if (version_compare(PHP_VERSION'8.1.0-dev''>=')) {
  563.             return -1118290769066898816;
  564.         }
  565.         return max(PHP_INT_MIN, -9223372036854773760);
  566.     }
  567. }