File "Units.php"

Full Path: /home/warrior1/public_html/wp-content-20241001222009/plugins/mailpoet/vendor-prefixed/nesbot/carbon/src/Carbon/Traits/Units.php
File size: 7.09 KB
MIME-type: text/x-php
Charset: utf-8

<?php
namespace MailPoetVendor\Carbon\Traits;
if (!defined('ABSPATH')) exit;
use MailPoetVendor\Carbon\CarbonConverterInterface;
use MailPoetVendor\Carbon\CarbonInterface;
use MailPoetVendor\Carbon\CarbonInterval;
use MailPoetVendor\Carbon\Exceptions\UnitException;
use Closure;
use DateInterval;
use ReturnTypeWillChange;
trait Units
{
 public function addRealUnit($unit, $value = 1)
 {
 switch ($unit) {
 // @call addRealUnit
 case 'micro':
 // @call addRealUnit
 case 'microsecond':
 $diff = $this->microsecond + $value;
 $time = $this->getTimestamp();
 $seconds = (int) \floor($diff / static::MICROSECONDS_PER_SECOND);
 $time += $seconds;
 $diff -= $seconds * static::MICROSECONDS_PER_SECOND;
 $microtime = \str_pad((string) $diff, 6, '0', \STR_PAD_LEFT);
 $tz = $this->tz;
 return $this->tz('UTC')->modify("@{$time}.{$microtime}")->tz($tz);
 // @call addRealUnit
 case 'milli':
 // @call addRealUnit
 case 'millisecond':
 return $this->addRealUnit('microsecond', $value * static::MICROSECONDS_PER_MILLISECOND);
 break;
 // @call addRealUnit
 case 'second':
 break;
 // @call addRealUnit
 case 'minute':
 $value *= static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'hour':
 $value *= static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'day':
 $value *= static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'week':
 $value *= static::DAYS_PER_WEEK * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'month':
 $value *= 30 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'quarter':
 $value *= static::MONTHS_PER_QUARTER * 30 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'year':
 $value *= 365 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'decade':
 $value *= static::YEARS_PER_DECADE * 365 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'century':
 $value *= static::YEARS_PER_CENTURY * 365 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 // @call addRealUnit
 case 'millennium':
 $value *= static::YEARS_PER_MILLENNIUM * 365 * static::HOURS_PER_DAY * static::MINUTES_PER_HOUR * static::SECONDS_PER_MINUTE;
 break;
 default:
 if ($this->localStrictModeEnabled ?? static::isStrictModeEnabled()) {
 throw new UnitException("Invalid unit for real timestamp add/sub: '{$unit}'");
 }
 return $this;
 }
 return $this->setTimestamp((int) ($this->getTimestamp() + $value));
 }
 public function subRealUnit($unit, $value = 1)
 {
 return $this->addRealUnit($unit, -$value);
 }
 public static function isModifiableUnit($unit)
 {
 static $modifiableUnits = [
 // @call addUnit
 'millennium',
 // @call addUnit
 'century',
 // @call addUnit
 'decade',
 // @call addUnit
 'quarter',
 // @call addUnit
 'week',
 // @call addUnit
 'weekday',
 ];
 return \in_array($unit, $modifiableUnits) || \in_array($unit, static::$units);
 }
 public function rawAdd(DateInterval $interval)
 {
 return parent::add($interval);
 }
 #[\ReturnTypeWillChange]
 public function add($unit, $value = 1, $overflow = null)
 {
 if (\is_string($unit) && \func_num_args() === 1) {
 $unit = CarbonInterval::make($unit);
 }
 if ($unit instanceof CarbonConverterInterface) {
 return $this->resolveCarbon($unit->convertDate($this, \false));
 }
 if ($unit instanceof Closure) {
 return $this->resolveCarbon($unit($this, \false));
 }
 if ($unit instanceof DateInterval) {
 return parent::add($unit);
 }
 if (\is_numeric($unit)) {
 [$value, $unit] = [$unit, $value];
 }
 return $this->addUnit($unit, $value, $overflow);
 }
 public function addUnit($unit, $value = 1, $overflow = null)
 {
 $date = $this;
 if (!\is_numeric($value) || !(float) $value) {
 return $date->isMutable() ? $date : $date->avoidMutation();
 }
 $unit = self::singularUnit($unit);
 $metaUnits = ['millennium' => [static::YEARS_PER_MILLENNIUM, 'year'], 'century' => [static::YEARS_PER_CENTURY, 'year'], 'decade' => [static::YEARS_PER_DECADE, 'year'], 'quarter' => [static::MONTHS_PER_QUARTER, 'month']];
 if (isset($metaUnits[$unit])) {
 [$factor, $unit] = $metaUnits[$unit];
 $value *= $factor;
 }
 if ($unit === 'weekday') {
 $weekendDays = static::getWeekendDays();
 if ($weekendDays !== [static::SATURDAY, static::SUNDAY]) {
 $absoluteValue = \abs($value);
 $sign = $value / \max(1, $absoluteValue);
 $weekDaysCount = 7 - \min(6, \count(\array_unique($weekendDays)));
 $weeks = \floor($absoluteValue / $weekDaysCount);
 for ($diff = $absoluteValue % $weekDaysCount; $diff; $diff--) {
 $date = $date->addDays($sign);
 while (\in_array($date->dayOfWeek, $weekendDays)) {
 $date = $date->addDays($sign);
 }
 }
 $value = $weeks * $sign;
 $unit = 'week';
 }
 $timeString = $date->toTimeString();
 } elseif ($canOverflow = \in_array($unit, ['month', 'year']) && ($overflow === \false || $overflow === null && ($ucUnit = \ucfirst($unit) . 's') && !($this->{'local' . $ucUnit . 'Overflow'} ?? static::{'shouldOverflow' . $ucUnit}()))) {
 $day = $date->day;
 }
 $value = (int) $value;
 if ($unit === 'milli' || $unit === 'millisecond') {
 $unit = 'microsecond';
 $value *= static::MICROSECONDS_PER_MILLISECOND;
 }
 // Work-around for bug https://bugs.php.net/bug.php?id=75642
 if ($unit === 'micro' || $unit === 'microsecond') {
 $microseconds = $this->micro + $value;
 $second = (int) \floor($microseconds / static::MICROSECONDS_PER_SECOND);
 $microseconds %= static::MICROSECONDS_PER_SECOND;
 if ($microseconds < 0) {
 $microseconds += static::MICROSECONDS_PER_SECOND;
 }
 $date = $date->microseconds($microseconds);
 $unit = 'second';
 $value = $second;
 }
 $date = $date->modify("{$value} {$unit}");
 if (isset($timeString)) {
 $date = $date->setTimeFromTimeString($timeString);
 } elseif (isset($canOverflow, $day) && $canOverflow && $day !== $date->day) {
 $date = $date->modify('last day of previous month');
 }
 if (!$date) {
 throw new UnitException('Unable to add unit ' . \var_export(\func_get_args(), \true));
 }
 return $date;
 }
 public function subUnit($unit, $value = 1, $overflow = null)
 {
 return $this->addUnit($unit, -$value, $overflow);
 }
 public function rawSub(DateInterval $interval)
 {
 return parent::sub($interval);
 }
 #[\ReturnTypeWillChange]
 public function sub($unit, $value = 1, $overflow = null)
 {
 if (\is_string($unit) && \func_num_args() === 1) {
 $unit = CarbonInterval::make($unit);
 }
 if ($unit instanceof CarbonConverterInterface) {
 return $this->resolveCarbon($unit->convertDate($this, \true));
 }
 if ($unit instanceof Closure) {
 return $this->resolveCarbon($unit($this, \true));
 }
 if ($unit instanceof DateInterval) {
 return parent::sub($unit);
 }
 if (\is_numeric($unit)) {
 [$value, $unit] = [$unit, $value];
 }
 return $this->addUnit($unit, -(float) $value, $overflow);
 }
 public function subtract($unit, $value = 1, $overflow = null)
 {
 if (\is_string($unit) && \func_num_args() === 1) {
 $unit = CarbonInterval::make($unit);
 }
 return $this->sub($unit, $value, $overflow);
 }
}