File "FixerConfigurationResolver.php"
Full Path: /var/www/html/back/vendor/friendsofphp/php-cs-fixer/src/FixerConfiguration/FixerConfigurationResolver.php
File size: 4.81 KB
MIME-type: text/x-php
Charset: utf-8
<?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;
use PhpCsFixer\Future;
use PhpCsFixer\Preg;
use Symfony\Component\OptionsResolver\Exception\InvalidOptionsException;
use Symfony\Component\OptionsResolver\OptionsResolver;
/**
* @readonly
*
* @no-named-arguments Parameter names are not covered by the backward compatibility promise.
*/
final class FixerConfigurationResolver implements FixerConfigurationResolverInterface
{
/**
* @var list<FixerOptionInterface>
*
* @readonly
*/
private array $options;
/**
* @param iterable<FixerOptionInterface> $options
*/
public function __construct(iterable $options)
{
$fixerOptionSorter = new FixerOptionSorter();
$this->validateOptions($options);
$this->options = $fixerOptionSorter->sort($options);
if (0 === \count($this->options)) {
throw new \LogicException('Options cannot be empty.');
}
}
public function getOptions(): array
{
return $this->options;
}
public function resolve(array $configuration): array
{
$resolver = new OptionsResolver();
foreach ($this->options as $option) {
$name = $option->getName();
if ($option instanceof AliasedFixerOption) {
$alias = $option->getAlias();
if (\array_key_exists($alias, $configuration)) {
if (\array_key_exists($name, $configuration)) {
throw new InvalidOptionsException(\sprintf('Aliased option "%s"/"%s" is passed multiple times.', $name, $alias));
}
Future::triggerDeprecation(new \RuntimeException(\sprintf(
'Option "%s" is deprecated, use "%s" instead.',
$alias,
$name,
)));
$configuration[$name] = $configuration[$alias];
unset($configuration[$alias]);
}
}
if ($option->hasDefault()) {
$resolver->setDefault($name, $option->getDefault());
} else {
$resolver->setRequired($name);
}
$allowedValues = $option->getAllowedValues();
if (null !== $allowedValues) {
foreach ($allowedValues as &$allowedValue) {
if (\is_object($allowedValue) && \is_callable($allowedValue)) {
$allowedValue = static fn (/* mixed */ $values) => $allowedValue($values);
}
}
$resolver->setAllowedValues($name, $allowedValues);
}
$allowedTypes = $option->getAllowedTypes();
if (null !== $allowedTypes) {
$allowedTypesNormalised = array_map(
static function (string $type): string {
// Symfony OptionsResolver doesn't support `array<foo, bar>` natively, let's simplify the type
$matches = [];
if (true === Preg::match('/array<\w+,\s*(\??[\w\'|]+)>/', $type, $matches)) {
if ('?' === $matches[1][0]) {
return 'array';
}
if ("'" === $matches[1][0]) {
return 'string[]';
}
return $matches[1].'[]';
}
// Symfony OptionsResolver doesn't support 'class-string' natively, let's simplify the type
return str_replace('class-string', 'string', $type);
},
$allowedTypes,
);
$resolver->setAllowedTypes($name, $allowedTypesNormalised);
}
$normalizer = $option->getNormalizer();
if (null !== $normalizer) {
$resolver->setNormalizer($name, $normalizer);
}
}
return $resolver->resolve($configuration);
}
/**
* @param iterable<FixerOptionInterface> $options
*
* @throws \LogicException when the option is already defined
*/
private function validateOptions(iterable $options): void
{
$names = [];
foreach ($options as $option) {
$name = $option->getName();
if (\in_array($name, $names, true)) {
throw new \LogicException(\sprintf('The "%s" option is defined multiple times.', $name));
}
$names[] = $name;
}
}
}