diff --git a/UPGRADE-2.0.md b/UPGRADE-2.0.md
index 22486cae0..ba9fa3615 100644
--- a/UPGRADE-2.0.md
+++ b/UPGRADE-2.0.md
@@ -28,6 +28,7 @@
- there is a top level `"dev"` key which stores whether dev requirements were installed or not
- `PreFileDownloadEvent` now receives an `HttpDownloader` instance instead of `RemoteFilesystem`, and that instance can not be overridden by listeners anymore
- `VersionSelector::findBestCandidate`'s third argument (phpVersion) was removed in favor of passing in a complete PlatformRepository instance into the constructor
+- `InitCommand::determineRequirements`'s fourth argument (phpVersion) should now receive a complete PlatformRepository instance or null if platform requirements are to be ignored
- `IOInterface` now extends PSR-3's `LoggerInterface`, and has new `writeRaw` + `writeErrorRaw` methods
- `RepositoryInterface` changes:
- A new `loadPackages(array $packageNameMap, array $acceptableStabilities, array $stabilityFlags)` function was added for use during pool building
diff --git a/src/Composer/Command/CreateProjectCommand.php b/src/Composer/Command/CreateProjectCommand.php
index 9263ba7ee..2b3c7b20d 100644
--- a/src/Composer/Command/CreateProjectCommand.php
+++ b/src/Composer/Command/CreateProjectCommand.php
@@ -336,25 +336,20 @@ EOT
$repositorySet = new RepositorySet($stability);
$repositorySet->addRepository($sourceRepo);
- $phpVersion = null;
- $prettyPhpVersion = null;
+ $platformRepo = null;
if (!$ignorePlatformReqs) {
$platformOverrides = $config->get('platform') ?: array();
- // initialize $this->repos as it is used by the parent InitCommand
- $platform = new PlatformRepository(array(), $platformOverrides);
- $phpPackage = $platform->findPackage('php', '*');
- $phpVersion = $phpPackage->getVersion();
- $prettyPhpVersion = $phpPackage->getPrettyVersion();
+ $platformRepo = new PlatformRepository(array(), $platformOverrides);
}
// find the latest version if there are multiple
- $versionSelector = new VersionSelector($repositorySet);
+ $versionSelector = new VersionSelector($repositorySet, $platformRepo);
$package = $versionSelector->findBestCandidate($name, $packageVersion, $phpVersion, $stability);
if (!$package) {
$errorMessage = "Could not find package $name with " . ($packageVersion ? "version $packageVersion" : "stability $stability");
- if ($phpVersion && $versionSelector->findBestCandidate($name, $packageVersion, null, $stability)) {
- throw new \InvalidArgumentException($errorMessage .' in a version installable using your PHP version '.$prettyPhpVersion.'.');
+ if ($platformRepo && $versionSelector->findBestCandidate($name, $packageVersion, $stability, true)) {
+ throw new \InvalidArgumentException($errorMessage .' in a version installable using your PHP version, PHP extensions and Composer version.');
}
throw new \InvalidArgumentException($errorMessage .'.');
diff --git a/src/Composer/Command/InitCommand.php b/src/Composer/Command/InitCommand.php
index 8f101515c..ecbbbf1e0 100644
--- a/src/Composer/Command/InitCommand.php
+++ b/src/Composer/Command/InitCommand.php
@@ -345,13 +345,21 @@ EOT
// prepare to resolve dependencies
$repos = $this->getRepos();
$preferredStability = $minimumStability ?: 'stable';
- $phpVersion = $repos->findPackage('php', '*')->getPrettyVersion();
+ $platformRepo = null;
+ if ($repos instanceof CompositeRepository) {
+ foreach ($repos->getRepositories() as $candidateRepo) {
+ if ($candidateRepo instanceof PlatformRepository) {
+ $platformRepo = $candidateRepo;
+ break;
+ }
+ }
+ }
$question = 'Would you like to define your dependencies (require) interactively [yes]? ';
$require = $input->getOption('require');
$requirements = array();
if ($require || $io->askConfirmation($question, true)) {
- $requirements = $this->determineRequirements($input, $output, $require, $phpVersion, $preferredStability);
+ $requirements = $this->determineRequirements($input, $output, $require, $platformRepo, $preferredStability);
}
$input->setOption('require', $requirements);
@@ -359,7 +367,7 @@ EOT
$requireDev = $input->getOption('require-dev');
$devRequirements = array();
if ($requireDev || $io->askConfirmation($question, true)) {
- $devRequirements = $this->determineRequirements($input, $output, $requireDev, $phpVersion, $preferredStability);
+ $devRequirements = $this->determineRequirements($input, $output, $requireDev, $platformRepo, $preferredStability);
}
$input->setOption('require-dev', $devRequirements);
}
@@ -403,7 +411,7 @@ EOT
return $this->repos;
}
- final protected function determineRequirements(InputInterface $input, OutputInterface $output, $requires = array(), $phpVersion = null, $preferredStability = 'stable', $checkProvidedVersions = true, $fixed = false)
+ final protected function determineRequirements(InputInterface $input, OutputInterface $output, $requires = array(), PlatformRepository $platformRepo = null, $preferredStability = 'stable', $checkProvidedVersions = true, $fixed = false)
{
if ($requires) {
$requires = $this->normalizeRequirements($requires);
@@ -413,7 +421,7 @@ EOT
foreach ($requires as $requirement) {
if (!isset($requirement['version'])) {
// determine the best version automatically
- list($name, $version) = $this->findBestVersionAndNameForPackage($input, $requirement['name'], $phpVersion, $preferredStability, null, null, $fixed);
+ list($name, $version) = $this->findBestVersionAndNameForPackage($input, $requirement['name'], $platformRepo, $preferredStability, null, null, $fixed);
$requirement['version'] = $version;
// replace package name from packagist.org
@@ -426,7 +434,7 @@ EOT
));
} else {
// check that the specified version/constraint exists before we proceed
- list($name, $version) = $this->findBestVersionAndNameForPackage($input, $requirement['name'], $phpVersion, $preferredStability, $checkProvidedVersions ? $requirement['version'] : null, 'dev', $fixed);
+ list($name, $version) = $this->findBestVersionAndNameForPackage($input, $requirement['name'], $platformRepo, $preferredStability, $checkProvidedVersions ? $requirement['version'] : null, 'dev', $fixed);
// replace package name from packagist.org
$requirement['name'] = $name;
@@ -550,7 +558,7 @@ EOT
);
if (false === $constraint) {
- list($name, $constraint) = $this->findBestVersionAndNameForPackage($input, $package, $phpVersion, $preferredStability);
+ list($name, $constraint) = $this->findBestVersionAndNameForPackage($input, $package, $platformRepo, $preferredStability);
$io->writeError(sprintf(
'Using version %s for %s',
@@ -723,7 +731,7 @@ EOT
*
* @param InputInterface $input
* @param string $name
- * @param string|null $phpVersion
+ * @param PlatformRepository|null $platformRepo
* @param string $preferredStability
* @param string|null $requiredVersion
* @param string $minimumStability
@@ -731,18 +739,18 @@ EOT
* @throws \InvalidArgumentException
* @return array name version
*/
- private function findBestVersionAndNameForPackage(InputInterface $input, $name, $phpVersion, $preferredStability = 'stable', $requiredVersion = null, $minimumStability = null, $fixed = null)
+ private function findBestVersionAndNameForPackage(InputInterface $input, $name, PlatformRepository $platformRepo = null, $preferredStability = 'stable', $requiredVersion = null, $minimumStability = null, $fixed = null)
{
- // find the latest version allowed in this repo set
- $versionSelector = new VersionSelector($this->getRepositorySet($input, $minimumStability));
+ // ignore platform repo if platform requirements are ignored
$ignorePlatformReqs = $input->hasOption('ignore-platform-reqs') && $input->getOption('ignore-platform-reqs');
-
- // ignore phpVersion if platform requirements are ignored
if ($ignorePlatformReqs) {
- $phpVersion = null;
+ $platformRepo = null;
}
- $package = $versionSelector->findBestCandidate($name, $requiredVersion, $phpVersion, $preferredStability);
+ // find the latest version allowed in this repo set
+ $versionSelector = new VersionSelector($this->getRepositorySet($input, $minimumStability), $platformRepo);
+
+ $package = $versionSelector->findBestCandidate($name, $requiredVersion, $preferredStability);
if (!$package) {
// platform packages can not be found in the pool in versions other than the local platform's has
@@ -752,28 +760,26 @@ EOT
}
// Check whether the PHP version was the problem
- if ($phpVersion && $versionSelector->findBestCandidate($name, $requiredVersion, null, $preferredStability)) {
+ if ($platformRepo && $versionSelector->findBestCandidate($name, $requiredVersion, $preferredStability, true)) {
throw new \InvalidArgumentException(sprintf(
- 'Package %s at version %s has a PHP requirement incompatible with your PHP version (%s)',
+ 'Package %s at version %s has a PHP requirement incompatible with your PHP version, PHP extensions and Composer version',
$name,
- $requiredVersion,
- $phpVersion
+ $requiredVersion
));
}
// Check whether the required version was the problem
- if ($requiredVersion && $versionSelector->findBestCandidate($name, null, $phpVersion, $preferredStability)) {
+ if ($requiredVersion && $versionSelector->findBestCandidate($name, null, $preferredStability)) {
throw new \InvalidArgumentException(sprintf(
'Could not find package %s in a version matching %s',
$name,
$requiredVersion
));
}
- // Check whether the PHP version was the problem
- if ($phpVersion && $versionSelector->findBestCandidate($name)) {
+ // Check whether the PHP version was the problem for all versions
+ if ($platformRepo && $versionSelector->findBestCandidate($name, null, $preferredStability, true)) {
throw new \InvalidArgumentException(sprintf(
- 'Could not find package %s in any version matching your PHP version (%s)',
- $name,
- $phpVersion
+ 'Could not find package %s in any version matching your PHP version, PHP extensions and Composer version',
+ $name
));
}
diff --git a/src/Composer/Command/RequireCommand.php b/src/Composer/Command/RequireCommand.php
index 7e290aca6..4bc08905b 100644
--- a/src/Composer/Command/RequireCommand.php
+++ b/src/Composer/Command/RequireCommand.php
@@ -166,7 +166,7 @@ EOT
$platformOverrides = $composer->getConfig()->get('platform') ?: array();
// initialize $this->repos as it is used by the parent InitCommand
$this->repos = new CompositeRepository(array_merge(
- array(new PlatformRepository(array(), $platformOverrides)),
+ array($platformRepo = new PlatformRepository(array(), $platformOverrides)),
$repos
));
@@ -176,9 +176,16 @@ EOT
$preferredStability = $composer->getPackage()->getMinimumStability();
}
- $phpVersion = $this->repos->findPackage('php', '*')->getPrettyVersion();
try {
- $requirements = $this->determineRequirements($input, $output, $input->getArgument('packages'), $phpVersion, $preferredStability, !$input->getOption('no-update'), $input->getOption('fixed'));
+ $requirements = $this->determineRequirements(
+ $input,
+ $output,
+ $input->getArgument('packages'),
+ $input->getOption('ignore-platform-reqs') ? null : $platformRepo,
+ $preferredStability,
+ !$input->getOption('no-update'),
+ $input->getOption('fixed')
+ );
} catch (\Exception $e) {
if ($this->newlyCreated) {
throw new \RuntimeException('No composer.json present in the current directory, this may be the cause of the following exception.', 0, $e);
diff --git a/src/Composer/Command/ShowCommand.php b/src/Composer/Command/ShowCommand.php
index b153c408c..b928765f9 100644
--- a/src/Composer/Command/ShowCommand.php
+++ b/src/Composer/Command/ShowCommand.php
@@ -151,7 +151,6 @@ EOT
}
$platformRepo = new PlatformRepository(array(), $platformOverrides);
$lockedRepo = null;
- $phpVersion = $platformRepo->findPackage('php', '*')->getVersion();
if ($input->getOption('self')) {
$package = $this->getComposer()->getPackage();
@@ -249,7 +248,7 @@ EOT
} else {
$latestPackage = null;
if ($input->getOption('latest')) {
- $latestPackage = $this->findLatestPackage($package, $composer, $phpVersion);
+ $latestPackage = $this->findLatestPackage($package, $composer, $platformRepo);
}
if ($input->getOption('outdated') && $input->getOption('strict') && $latestPackage && $latestPackage->getFullPrettyVersion() !== $package->getFullPrettyVersion() && !$latestPackage->isAbandoned()) {
$exitCode = 1;
@@ -382,7 +381,7 @@ EOT
if ($showLatest && $showVersion) {
foreach ($packages[$type] as $package) {
if (is_object($package)) {
- $latestPackage = $this->findLatestPackage($package, $composer, $phpVersion, $showMinorOnly);
+ $latestPackage = $this->findLatestPackage($package, $composer, $platformRepo, $showMinorOnly);
if ($latestPackage === false) {
continue;
}
@@ -1180,18 +1179,18 @@ EOT
/**
* Given a package, this finds the latest package matching it
*
- * @param PackageInterface $package
- * @param Composer $composer
- * @param string $phpVersion
- * @param bool $minorOnly
+ * @param PackageInterface $package
+ * @param Composer $composer
+ * @param PlatformRepository $platformRepo
+ * @param bool $minorOnly
*
* @return PackageInterface|false
*/
- private function findLatestPackage(PackageInterface $package, Composer $composer, $phpVersion, $minorOnly = false)
+ private function findLatestPackage(PackageInterface $package, Composer $composer, PlatformRepository $platformRepo, $minorOnly = false)
{
// find the latest version allowed in this repo set
$name = $package->getName();
- $versionSelector = new VersionSelector($this->getRepositorySet($composer));
+ $versionSelector = new VersionSelector($this->getRepositorySet($composer), $platformRepo);
$stability = $composer->getPackage()->getMinimumStability();
$flags = $composer->getPackage()->getStabilityFlags();
if (isset($flags[$name])) {
@@ -1212,7 +1211,7 @@ EOT
$targetVersion = '^' . $package->getVersion();
}
- return $versionSelector->findBestCandidate($name, $targetVersion, $phpVersion, $bestStability);
+ return $versionSelector->findBestCandidate($name, $targetVersion, $bestStability);
}
private function getRepositorySet(Composer $composer)