Merge pull request #1380 from bamarni/depends-local

added a local option to the depends command
main
Jordi Boggiano 12 years ago
commit 8bbb358e1f

@ -12,7 +12,7 @@
namespace Composer\Command; namespace Composer\Command;
use Composer\Composer; use Composer\DependencyResolver\Pool;
use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Input\InputOption;
@ -36,7 +36,7 @@ class DependsCommand extends Command
->setDescription('Shows which packages depend on the given package') ->setDescription('Shows which packages depend on the given package')
->setDefinition(array( ->setDefinition(array(
new InputArgument('package', InputArgument::REQUIRED, 'Package to inspect'), new InputArgument('package', InputArgument::REQUIRED, 'Package to inspect'),
new InputOption('link-type', '', InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Link types to show (require, require-dev)', array_keys($this->linkTypes)) new InputOption('link-type', '', InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Link types to show (require, require-dev)', array_keys($this->linkTypes)),
)) ))
->setHelp(<<<EOT ->setHelp(<<<EOT
Displays detailed information about where a package is referenced. Displays detailed information about where a package is referenced.
@ -50,12 +50,21 @@ EOT
protected function execute(InputInterface $input, OutputInterface $output) protected function execute(InputInterface $input, OutputInterface $output)
{ {
$composer = $this->getComposer(); $repos = $this->getComposer()->getRepositoryManager()->getLocalRepositories();
$repos = $composer->getRepositoryManager()->getRepositories(); $needle = $input->getArgument('package');
$pool = new Pool();
foreach ($repos as $repo) {
$pool->addRepository($repo);
}
$packages = $pool->whatProvides($needle);
if (empty($packages)) {
throw new \InvalidArgumentException('Could not find package "'.$needle.'" in your project.');
}
$linkTypes = $this->linkTypes; $linkTypes = $this->linkTypes;
$needle = $input->getArgument('package');
$verbose = (bool) $input->getOption('verbose'); $verbose = (bool) $input->getOption('verbose');
$types = array_map(function ($type) use ($linkTypes) { $types = array_map(function ($type) use ($linkTypes) {
$type = rtrim($type, 's'); $type = rtrim($type, 's');
@ -66,13 +75,15 @@ EOT
return $type; return $type;
}, $input->getOption('link-type')); }, $input->getOption('link-type'));
$dependsOnPackages = false;
foreach ($repos as $repo) { foreach ($repos as $repo) {
$repo->filterPackages(function ($package) use ($needle, $types, $linkTypes, $output, $verbose) { $repo->filterPackages(function ($package) use ($needle, $types, $linkTypes, $output, $verbose, &$dependsOnPackages) {
static $outputPackages = array(); static $outputPackages = array();
foreach ($types as $type) { foreach ($types as $type) {
foreach ($package->{'get'.$linkTypes[$type]}() as $link) { foreach ($package->{'get'.$linkTypes[$type]}() as $link) {
if ($link->getTarget() === $needle) { if ($link->getTarget() === $needle) {
$dependsOnPackages = true;
if ($verbose) { if ($verbose) {
$output->writeln($package->getPrettyName() . ' ' . $package->getPrettyVersion() . ' <info>' . $type . '</info> ' . $link->getPrettyConstraint()); $output->writeln($package->getPrettyName() . ' ' . $package->getPrettyVersion() . ' <info>' . $type . '</info> ' . $link->getPrettyConstraint());
} elseif (!isset($outputPackages[$package->getName()])) { } elseif (!isset($outputPackages[$package->getName()])) {
@ -84,5 +95,9 @@ EOT
} }
}); });
} }
if (!$dependsOnPackages) {
$output->writeln('<info>There is no installed package depending on "'.$needle.'".</info>');
}
} }
} }

Loading…
Cancel
Save