* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace RectorPrefix20211224\Symfony\Component\Console\Tester; use RectorPrefix20211224\Symfony\Component\Console\Command\Command; use RectorPrefix20211224\Symfony\Component\Console\Completion\CompletionInput; use RectorPrefix20211224\Symfony\Component\Console\Completion\CompletionSuggestions; /** * Eases the testing of command completion. * * @author Jérôme Tamarelle */ class CommandCompletionTester { private $command; public function __construct(\RectorPrefix20211224\Symfony\Component\Console\Command\Command $command) { $this->command = $command; } /** * Create completion suggestions from input tokens. */ public function complete(array $input) : array { $currentIndex = \count($input); if ('' === \end($input)) { \array_pop($input); } \array_unshift($input, $this->command->getName()); $completionInput = \RectorPrefix20211224\Symfony\Component\Console\Completion\CompletionInput::fromTokens($input, $currentIndex); $completionInput->bind($this->command->getDefinition()); $suggestions = new \RectorPrefix20211224\Symfony\Component\Console\Completion\CompletionSuggestions(); $this->command->complete($completionInput, $suggestions); $options = []; foreach ($suggestions->getOptionSuggestions() as $option) { $options[] = '--' . $option->getName(); } return \array_map('strval', \array_merge($options, $suggestions->getValueSuggestions())); } }