1
0
Fork 0

Small tweaks for consistency, refs #3639

pull/4761/head
Jordi Boggiano 2016-01-10 12:35:39 +00:00
parent 721acf3c93
commit 633e9f91a1
1 changed files with 28 additions and 41 deletions

View File

@ -14,6 +14,7 @@ namespace Composer\Command;
use Composer\Composer; use Composer\Composer;
use Composer\Installer; use Composer\Installer;
use Composer\IO\IOInterface;
use Composer\Plugin\CommandEvent; use Composer\Plugin\CommandEvent;
use Composer\Plugin\PluginEvents; use Composer\Plugin\PluginEvents;
use Symfony\Component\Console\Helper\Table; use Symfony\Component\Console\Helper\Table;
@ -55,7 +56,7 @@ class UpdateCommand extends Command
new InputOption('ignore-platform-reqs', null, InputOption::VALUE_NONE, 'Ignore platform requirements (php & ext- packages).'), new InputOption('ignore-platform-reqs', null, InputOption::VALUE_NONE, 'Ignore platform requirements (php & ext- packages).'),
new InputOption('prefer-stable', null, InputOption::VALUE_NONE, 'Prefer stable versions of dependencies.'), new InputOption('prefer-stable', null, InputOption::VALUE_NONE, 'Prefer stable versions of dependencies.'),
new InputOption('prefer-lowest', null, InputOption::VALUE_NONE, 'Prefer lowest versions of dependencies.'), new InputOption('prefer-lowest', null, InputOption::VALUE_NONE, 'Prefer lowest versions of dependencies.'),
new InputOption('interactive', 'i', InputOption::VALUE_NONE, 'interactive interface with autocompletion that can help to select the packages to update.'), new InputOption('interactive', 'i', InputOption::VALUE_NONE, 'Interactive interface with autocompletion to select the packages to update.'),
)) ))
->setHelp(<<<EOT ->setHelp(<<<EOT
The <info>update</info> command reads the composer.json file from the The <info>update</info> command reads the composer.json file from the
@ -73,6 +74,9 @@ You may also use an asterisk (*) pattern to limit the update operation to packag
from a specific vendor: from a specific vendor:
<info>php composer.phar update vendor/package1 foo/* [...]</info> <info>php composer.phar update vendor/package1 foo/* [...]</info>
To select packages names interactively with auto-completion use <info>-i</info>.
EOT EOT
) )
; ;
@ -95,7 +99,7 @@ EOT
$packages = $input->getArgument('packages'); $packages = $input->getArgument('packages');
if ($input->getOption('interactive')) { if ($input->getOption('interactive')) {
$packages = $this->getPackagesInteractively($input, $output, $composer, $packages); $packages = $this->getPackagesInteractively($io, $input, $output, $composer, $packages);
} }
$composer->getDownloadManager()->setOutputProgress(!$input->getOption('no-progress')); $composer->getDownloadManager()->setOutputProgress(!$input->getOption('no-progress'));
@ -155,55 +159,43 @@ EOT
return $install->run(); return $install->run();
} }
private function getPackagesInteractively(InputInterface $input, OutputInterface $output, Composer $composer, $packages) private function getPackagesInteractively(IOInterface $io, InputInterface $input, OutputInterface $output, Composer $composer, array $packages)
{ {
if (!$input->isInteractive()) { if (!$input->isInteractive()) {
throw new \InvalidArgumentException('--interactive cannot be used in non-interactive terminals.'); throw new \InvalidArgumentException('--interactive cannot be used in non-interactive terminals.');
} }
$packagesMap = $composer->getRepositoryManager() $requires = array_merge(
->getLocalRepository()->getPackages(); $composer->getPackage()->getRequires(),
$composer->getPackage()->getDevRequires()
$requiredPackageNames = array(); );
foreach ( $autocompleterValues = array();
array_merge( foreach ($requires as $require) {
$composer->getPackage()->getRequires(), $autocompleterValues[strtolower($require->getTarget())] = $require->getTarget();
$composer->getPackage()->getDevRequires()
) as $require) {
$requiredPackageNames[] = $require->getTarget();
} }
$InstalledPackageNames = array(); $installedPackages = $composer->getRepositoryManager()->getLocalRepository()->getPackages();
foreach ($packagesMap as $package) { foreach ($installedPackages as $package) {
$InstalledPackageNames[] = $package->getPrettyName(); $autocompleterValues[$package->getName()] = $package->getPrettyName();
} }
$autocompleterValues = array_unique( $helper = $this->getHelper('question');
array_merge($InstalledPackageNames, $requiredPackageNames) $question = new Question('<comment>Enter package name: </comment>', null);
);
$helper = $this->getHelper('question'); $io->writeError('<info>Press enter without value to end submission</info>');
$question = new Question(
'<comment>Enter package name: </comment>',
null
);
$packages = is_array($packages) ? $packages : array();
$output->writeln('<info>NB: Empty package ends submission.</info>'); // I couldn't find any better for now!
do { do {
$autocompleterValues = array_diff($autocompleterValues, $packages);
$question->setAutocompleterValues($autocompleterValues); $question->setAutocompleterValues($autocompleterValues);
$addedPackage = $helper->ask($input, $output, $question); $addedPackage = $helper->ask($input, $output, $question);
if (!is_string($addedPackage)) { if (!is_string($addedPackage) || empty($addedPackage)) {
break; break;
} }
$addedPackage = strtolower($addedPackage);
if (!in_array($addedPackage, $packages)) { if (!in_array($addedPackage, $packages)) {
$packages[] = $addedPackage; $packages[] = $addedPackage;
$autocompleterValues = array_diff($autocompleterValues, array($addedPackage));
} else {
$output->writeln(sprintf('<error>The package "%s" was already added.</error>', $package));
} }
} while (true); } while (true);
@ -214,20 +206,15 @@ EOT
$table = new Table($output); $table = new Table($output);
$table->setHeaders(array('Selected packages')); $table->setHeaders(array('Selected packages'));
foreach ((array)$packages as $package) { foreach ($packages as $package) {
$table->addRow(array($package)); $table->addRow(array($package));
} }
$table->render(); $table->render();
$continue = new ConfirmationQuestion( if ($io->askConfirmation(sprintf(
sprintf( 'Would you like to continue and update the above package%s [<comment>yes</comment>]? ',
'<question>Would you like to continue and update the above package%s [yes|no] ?</question><info> (yes) </info>', 1 === count($packages) ? '' : 's'
1 === count($packages) ? '' : 's' ), true)) {
),
true
);
if ($helper->ask($input, $output, $continue)) {
return $packages; return $packages;
} }