File "AutoPHPMigrationRiskySet.php"

Full Path: /var/www/html/back/vendor/friendsofphp/php-cs-fixer/src/RuleSet/Sets/AutoPHPMigrationRiskySet.php
File size: 1.46 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\RuleSet\Sets;

use PhpCsFixer\RuleSet\AbstractRuleSetDefinition;
use PhpCsFixer\RuleSet\AutomaticMigrationSetTrait;
use PhpCsFixer\RuleSet\AutomaticRuleSetDefinitionInterface;

/**
 * @internal
 *
 * @no-named-arguments Parameter names are not covered by the backward compatibility promise.
 */
final class AutoPHPMigrationRiskySet extends AbstractRuleSetDefinition implements AutomaticRuleSetDefinitionInterface
{
    use AutomaticMigrationSetTrait;

    public function getName(): string
    {
        return '@'.lcfirst(ltrim(parent::getName(), '@'));
    }

    public function getRules(): array
    {
        return [
            $this->calculateTargetSet($this->getName(), 'PHP', $this->isRisky()) => true,
        ];
    }

    public function getDescription(): string
    {
        return 'Migration rules to improve code towards the minimum ``PHP`` supported by your project (taken from ``composer.json`` file).';
    }

    public function getRulesCandidates(): array
    {
        $sets = array_values(self::calculateCandidateSets('PHP', $this->isRisky()));
        ksort($sets);

        return array_combine($sets, array_fill(0, \count($sets), true));
    }
}