first commit
This commit is contained in:
136
lib/tus/vendor/symfony/clock/DatePoint.php
vendored
Normal file
136
lib/tus/vendor/symfony/clock/DatePoint.php
vendored
Normal file
@@ -0,0 +1,136 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Clock;
|
||||
|
||||
/**
|
||||
* An immmutable DateTime with stricter error handling and return types than the native one.
|
||||
*
|
||||
* @author Nicolas Grekas <p@tchwork.com>
|
||||
*/
|
||||
final class DatePoint extends \DateTimeImmutable
|
||||
{
|
||||
/**
|
||||
* @throws \DateMalformedStringException When $datetime is invalid
|
||||
*/
|
||||
public function __construct(string $datetime = 'now', ?\DateTimeZone $timezone = null, ?parent $reference = null)
|
||||
{
|
||||
$now = $reference ?? Clock::get()->now();
|
||||
|
||||
if ('now' !== $datetime) {
|
||||
if (!$now instanceof static) {
|
||||
$now = static::createFromInterface($now);
|
||||
}
|
||||
|
||||
if (\PHP_VERSION_ID < 80300) {
|
||||
try {
|
||||
$builtInDate = new parent($datetime, $timezone ?? $now->getTimezone());
|
||||
$timezone = $builtInDate->getTimezone();
|
||||
} catch (\Exception $e) {
|
||||
throw new \DateMalformedStringException($e->getMessage(), $e->getCode(), $e);
|
||||
}
|
||||
} else {
|
||||
$builtInDate = new parent($datetime, $timezone ?? $now->getTimezone());
|
||||
$timezone = $builtInDate->getTimezone();
|
||||
}
|
||||
|
||||
$now = $now->setTimezone($timezone)->modify($datetime);
|
||||
|
||||
if ('00:00:00.000000' === $builtInDate->format('H:i:s.u')) {
|
||||
$now = $now->setTime(0, 0);
|
||||
}
|
||||
} elseif (null !== $timezone) {
|
||||
$now = $now->setTimezone($timezone);
|
||||
}
|
||||
|
||||
if (\PHP_VERSION_ID < 80200) {
|
||||
$now = (array) $now;
|
||||
$this->date = $now['date'];
|
||||
$this->timezone_type = $now['timezone_type'];
|
||||
$this->timezone = $now['timezone'];
|
||||
$this->__wakeup();
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
$this->__unserialize((array) $now);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \DateMalformedStringException When $format or $datetime are invalid
|
||||
*/
|
||||
public static function createFromFormat(string $format, string $datetime, ?\DateTimeZone $timezone = null): static
|
||||
{
|
||||
return parent::createFromFormat($format, $datetime, $timezone) ?: throw new \DateMalformedStringException(static::getLastErrors()['errors'][0] ?? 'Invalid date string or format.');
|
||||
}
|
||||
|
||||
public static function createFromInterface(\DateTimeInterface $object): static
|
||||
{
|
||||
return parent::createFromInterface($object);
|
||||
}
|
||||
|
||||
public static function createFromMutable(\DateTime $object): static
|
||||
{
|
||||
return parent::createFromMutable($object);
|
||||
}
|
||||
|
||||
public function add(\DateInterval $interval): static
|
||||
{
|
||||
return parent::add($interval);
|
||||
}
|
||||
|
||||
public function sub(\DateInterval $interval): static
|
||||
{
|
||||
return parent::sub($interval);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \DateMalformedStringException When $modifier is invalid
|
||||
*/
|
||||
public function modify(string $modifier): static
|
||||
{
|
||||
if (\PHP_VERSION_ID < 80300) {
|
||||
return @parent::modify($modifier) ?: throw new \DateMalformedStringException(error_get_last()['message'] ?? sprintf('Invalid modifier: "%s".', $modifier));
|
||||
}
|
||||
|
||||
return parent::modify($modifier);
|
||||
}
|
||||
|
||||
public function setTimestamp(int $value): static
|
||||
{
|
||||
return parent::setTimestamp($value);
|
||||
}
|
||||
|
||||
public function setDate(int $year, int $month, int $day): static
|
||||
{
|
||||
return parent::setDate($year, $month, $day);
|
||||
}
|
||||
|
||||
public function setISODate(int $year, int $week, int $day = 1): static
|
||||
{
|
||||
return parent::setISODate($year, $week, $day);
|
||||
}
|
||||
|
||||
public function setTime(int $hour, int $minute, int $second = 0, int $microsecond = 0): static
|
||||
{
|
||||
return parent::setTime($hour, $minute, $second, $microsecond);
|
||||
}
|
||||
|
||||
public function setTimezone(\DateTimeZone $timezone): static
|
||||
{
|
||||
return parent::setTimezone($timezone);
|
||||
}
|
||||
|
||||
public function getTimezone(): \DateTimeZone
|
||||
{
|
||||
return parent::getTimezone() ?: throw new \DateInvalidTimeZoneException('The DatePoint object has no timezone.');
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user