mirror of
https://github.com/rectorphp/rector.git
synced 2025-02-25 20:23:49 +01:00
105 lines
6.2 KiB
PHP
105 lines
6.2 KiB
PHP
<?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 RectorPrefix20220304\Symfony\Component\Console\DependencyInjection;
|
|
|
|
use RectorPrefix20220304\Symfony\Component\Console\Command\Command;
|
|
use RectorPrefix20220304\Symfony\Component\Console\Command\LazyCommand;
|
|
use RectorPrefix20220304\Symfony\Component\Console\CommandLoader\ContainerCommandLoader;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\Argument\ServiceClosureArgument;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\Compiler\ServiceLocatorTagPass;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\ContainerBuilder;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\Reference;
|
|
use RectorPrefix20220304\Symfony\Component\DependencyInjection\TypedReference;
|
|
/**
|
|
* Registers console commands.
|
|
*
|
|
* @author Grégoire Pineau <lyrixx@lyrixx.info>
|
|
*/
|
|
class AddConsoleCommandPass implements \RectorPrefix20220304\Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface
|
|
{
|
|
public function process(\RectorPrefix20220304\Symfony\Component\DependencyInjection\ContainerBuilder $container)
|
|
{
|
|
$commandServices = $container->findTaggedServiceIds('console.command', \true);
|
|
$lazyCommandMap = [];
|
|
$lazyCommandRefs = [];
|
|
$serviceIds = [];
|
|
foreach ($commandServices as $id => $tags) {
|
|
$definition = $container->getDefinition($id);
|
|
$definition->addTag('container.no_preload');
|
|
$class = $container->getParameterBag()->resolveValue($definition->getClass());
|
|
if (isset($tags[0]['command'])) {
|
|
$aliases = $tags[0]['command'];
|
|
} else {
|
|
if (!($r = $container->getReflectionClass($class))) {
|
|
throw new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException(\sprintf('Class "%s" used for service "%s" cannot be found.', $class, $id));
|
|
}
|
|
if (!$r->isSubclassOf(\RectorPrefix20220304\Symfony\Component\Console\Command\Command::class)) {
|
|
throw new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException(\sprintf('The service "%s" tagged "%s" must be a subclass of "%s".', $id, 'console.command', \RectorPrefix20220304\Symfony\Component\Console\Command\Command::class));
|
|
}
|
|
$aliases = $class::getDefaultName();
|
|
}
|
|
$aliases = \explode('|', $aliases ?? '');
|
|
$commandName = \array_shift($aliases);
|
|
if ($isHidden = '' === $commandName) {
|
|
$commandName = \array_shift($aliases);
|
|
}
|
|
if (null === $commandName) {
|
|
if (!$definition->isPublic() || $definition->isPrivate() || $definition->hasTag('container.private')) {
|
|
$commandId = 'console.command.public_alias.' . $id;
|
|
$container->setAlias($commandId, $id)->setPublic(\true);
|
|
$id = $commandId;
|
|
}
|
|
$serviceIds[] = $id;
|
|
continue;
|
|
}
|
|
$description = $tags[0]['description'] ?? null;
|
|
unset($tags[0]);
|
|
$lazyCommandMap[$commandName] = $id;
|
|
$lazyCommandRefs[$id] = new \RectorPrefix20220304\Symfony\Component\DependencyInjection\TypedReference($id, $class);
|
|
foreach ($aliases as $alias) {
|
|
$lazyCommandMap[$alias] = $id;
|
|
}
|
|
foreach ($tags as $tag) {
|
|
if (isset($tag['command'])) {
|
|
$aliases[] = $tag['command'];
|
|
$lazyCommandMap[$tag['command']] = $id;
|
|
}
|
|
$description = $description ?? $tag['description'] ?? null;
|
|
}
|
|
$definition->addMethodCall('setName', [$commandName]);
|
|
if ($aliases) {
|
|
$definition->addMethodCall('setAliases', [$aliases]);
|
|
}
|
|
if ($isHidden) {
|
|
$definition->addMethodCall('setHidden', [\true]);
|
|
}
|
|
if (!$description) {
|
|
if (!($r = $container->getReflectionClass($class))) {
|
|
throw new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException(\sprintf('Class "%s" used for service "%s" cannot be found.', $class, $id));
|
|
}
|
|
if (!$r->isSubclassOf(\RectorPrefix20220304\Symfony\Component\Console\Command\Command::class)) {
|
|
throw new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException(\sprintf('The service "%s" tagged "%s" must be a subclass of "%s".', $id, 'console.command', \RectorPrefix20220304\Symfony\Component\Console\Command\Command::class));
|
|
}
|
|
$description = $class::getDefaultDescription();
|
|
}
|
|
if ($description) {
|
|
$definition->addMethodCall('setDescription', [$description]);
|
|
$container->register('.' . $id . '.lazy', \RectorPrefix20220304\Symfony\Component\Console\Command\LazyCommand::class)->setArguments([$commandName, $aliases, $description, $isHidden, new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Argument\ServiceClosureArgument($lazyCommandRefs[$id])]);
|
|
$lazyCommandRefs[$id] = new \RectorPrefix20220304\Symfony\Component\DependencyInjection\Reference('.' . $id . '.lazy');
|
|
}
|
|
}
|
|
$container->register('console.command_loader', \RectorPrefix20220304\Symfony\Component\Console\CommandLoader\ContainerCommandLoader::class)->setPublic(\true)->addTag('container.no_preload')->setArguments([\RectorPrefix20220304\Symfony\Component\DependencyInjection\Compiler\ServiceLocatorTagPass::register($container, $lazyCommandRefs), $lazyCommandMap]);
|
|
$container->setParameter('console.command.ids', $serviceIds);
|
|
}
|
|
}
|