Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/ecommerce/vendor/friendsofphp/php-cs-fixer/src/FixerConfiguration/ |
<?php
declare(strict_types=1);
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <fabien@symfony.com>
* Dariusz RumiĆski <dariusz.ruminski@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace PhpCsFixer\FixerConfiguration;
final class FixerOption implements FixerOptionInterface
{
/**
* @var string
*/
private $name;
/**
* @var string
*/
private $description;
/**
* @var mixed
*/
private $default;
/**
* @var bool
*/
private $isRequired;
/**
* @var null|string[]
*/
private $allowedTypes;
/**
* @var null|array
*/
private $allowedValues;
/**
* @var null|\Closure
*/
private $normalizer;
/**
* @param mixed $default
* @param null|string[] $allowedTypes
*/
public function __construct(
string $name,
string $description,
bool $isRequired = true,
$default = null,
?array $allowedTypes = null,
?array $allowedValues = null,
?\Closure $normalizer = null
) {
if ($isRequired && null !== $default) {
throw new \LogicException('Required options cannot have a default value.');
}
if (null !== $allowedValues) {
foreach ($allowedValues as &$allowedValue) {
if ($allowedValue instanceof \Closure) {
$allowedValue = $this->unbind($allowedValue);
}
}
}
$this->name = $name;
$this->description = $description;
$this->isRequired = $isRequired;
$this->default = $default;
$this->allowedTypes = $allowedTypes;
$this->allowedValues = $allowedValues;
if (null !== $normalizer) {
$this->normalizer = $this->unbind($normalizer);
}
}
/**
* {@inheritdoc}
*/
public function getName(): string
{
return $this->name;
}
/**
* {@inheritdoc}
*/
public function getDescription(): string
{
return $this->description;
}
/**
* {@inheritdoc}
*/
public function hasDefault(): bool
{
return !$this->isRequired;
}
/**
* {@inheritdoc}
*/
public function getDefault()
{
if (!$this->hasDefault()) {
throw new \LogicException('No default value defined.');
}
return $this->default;
}
/**
* {@inheritdoc}
*/
public function getAllowedTypes(): ?array
{
return $this->allowedTypes;
}
/**
* {@inheritdoc}
*/
public function getAllowedValues(): ?array
{
return $this->allowedValues;
}
/**
* {@inheritdoc}
*/
public function getNormalizer(): ?\Closure
{
return $this->normalizer;
}
/**
* Unbinds the given closure to avoid memory leaks.
*
* The closures provided to this class were probably defined in a fixer
* class and thus bound to it by default. The configuration will then be
* stored in {@see AbstractFixer::$configurationDefinition}, leading to the
* following cyclic reference:
*
* fixer -> configuration definition -> options -> closures -> fixer
*
* This cyclic reference prevent the garbage collector to free memory as
* all elements are still referenced.
*
* See {@see https://bugs.php.net/bug.php?id=69639 Bug #69639} for details.
*/
private function unbind(\Closure $closure): \Closure
{
return $closure->bindTo(null);
}
}