123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- <?php
- /*
- * This file is part of Composer.
- *
- * (c) Nils Adermann <naderman@naderman.de>
- * Jordi Boggiano <j.boggiano@seld.be>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Composer\Command;
- use Composer\Autoload\AutoloadGenerator;
- use Composer\DependencyResolver;
- use Composer\DependencyResolver\Pool;
- use Composer\DependencyResolver\Request;
- use Composer\DependencyResolver\Operation;
- use Composer\Package\LinkConstraint\VersionConstraint;
- use Composer\Repository\PlatformRepository;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- /**
- * @author Jordi Boggiano <j.boggiano@seld.be>
- * @author Ryan Weaver <ryan@knplabs.com>
- * @author Konstantin Kudryashov <ever.zet@gmail.com>
- */
- class InstallCommand extends Command
- {
- protected function configure()
- {
- $this
- ->setName('install')
- ->setDescription('Parses the composer.json file and downloads the needed dependencies.')
- ->setHelp(<<<EOT
- The <info>install</info> command reads the composer.json file from the
- current directory, processes it, and downloads and installs all the
- libraries and dependencies outlined in that file.
- <info>php composer install</info>
- EOT
- )
- ;
- }
- protected function execute(InputInterface $input, OutputInterface $output)
- {
- $composer = $this->getComposer();
- // creating repository pool
- $pool = new Pool;
- $pool->addRepository($composer->getRepositoryManager()->getLocalRepository());
- foreach ($composer->getRepositoryManager()->getRepositories() as $repository) {
- $pool->addRepository($repository);
- }
- // creating requirements request
- $request = new Request($pool);
- if ($composer->getLocker()->isLocked()) {
- $output->writeln('> Found lockfile. Reading.');
- foreach ($composer->getLocker()->getLockedPackages() as $package) {
- $constraint = new VersionConstraint('=', $package->getVersion());
- $request->install($package->getName(), $constraint);
- }
- } else {
- foreach ($composer->getPackage()->getRequires() as $link) {
- $request->install($link->getTarget(), $link->getConstraint());
- }
- }
- // prepare solver
- $installationManager = $composer->getInstallationManager();
- $localRepo = $composer->getRepositoryManager()->getLocalRepository();
- $installedRepo = new PlatformRepository($localRepo);
- $policy = new DependencyResolver\DefaultPolicy();
- $solver = new DependencyResolver\Solver($policy, $pool, $installedRepo);
- // solve dependencies
- $operations = $solver->solve($request);
- // check for missing deps
- // TODO this belongs in the solver, but this will do for now to report top-level deps missing at least
- foreach ($request->getJobs() as $job) {
- if ('install' === $job['cmd']) {
- foreach ($localRepo->getPackages() as $package) {
- if ($job['packageName'] === $package->getName()) {
- continue 2;
- }
- }
- foreach ($operations as $operation) {
- if ('install' === $operation->getJobType() && $job['packageName'] === $operation->getPackage()->getName()) {
- continue 2;
- }
- }
- throw new \UnexpectedValueException('Package '.$job['packageName'].' could not be resolved to an installable package.');
- }
- }
- // execute operations
- foreach ($operations as $operation) {
- $installationManager->execute($operation);
- }
- if (!$composer->getLocker()->isLocked()) {
- $composer->getLocker()->lockPackages($localRepo->getPackages());
- $output->writeln('> Locked');
- }
- $localRepo->write();
- $output->writeln('> Generating autoload.php');
- $generator = new AutoloadGenerator($localRepo, $composer->getPackage(), $installationManager);
- $generator->dump('.composer/autoload.php');
- $output->writeln('> Done');
- }
- }
|