diff --git a/src/Composer/Command/CheckPlatformReqsCommand.php b/src/Composer/Command/CheckPlatformReqsCommand.php
index c03ed0804..bd42b65c6 100644
--- a/src/Composer/Command/CheckPlatformReqsCommand.php
+++ b/src/Composer/Command/CheckPlatformReqsCommand.php
@@ -5,6 +5,7 @@ namespace Composer\Command;
use Composer\Package\Link;
use Composer\Package\PackageInterface;
use Composer\Semver\Constraint\Constraint;
+use Composer\Semver\Constraint\MultiConstraint;
use Symfony\Component\Console\Helper\Table;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
@@ -28,20 +29,24 @@ EOT
$repos = $composer->getRepositoryManager()->getLocalRepository();
- $allPackages = array_merge($repos->getPackages(), array($composer->getPackage()));
- $requires = array();
+ $allPackages = array_merge(array($composer->getPackage()), $repos->getPackages());
+ $requires = $composer->getPackage()->getDevRequires();
+ foreach ($requires as $require => $link) {
+ $requires[$require] = array($link);
+ }
/**
* @var PackageInterface $package
*/
foreach ($allPackages as $package) {
- $requires = array_merge($requires, $package->getRequires());
+ foreach ($package->getRequires() as $require => $link) {
+ $requires[$require][] = $link;
+ }
}
+ ksort($requires);
$platformRepo = new PlatformRepository(array(), array());
-
$currentPlatformPackages = $platformRepo->getPackages();
-
$currentPlatformPackageMap = array();
/**
@@ -53,39 +58,55 @@ EOT
$results = array();
+ $exitCode = 0;
+
/**
* @var Link $require
*/
- foreach ($requires as $key => $require) {
- if (preg_match(PlatformRepository::PLATFORM_PACKAGE_REGEX, $key)) {
- if (isset($currentPlatformPackageMap[$key])) {
- // 检查版本
- $version = $currentPlatformPackageMap[$key]->getVersion();
- if (!$require->getConstraint()->matches(new Constraint('<=', $version))) {
+ foreach ($requires as $require => $links) {
+ if (preg_match(PlatformRepository::PLATFORM_PACKAGE_REGEX, $require)) {
+ if (isset($currentPlatformPackageMap[$require])) {
+ $pass = true;
+ $version = $currentPlatformPackageMap[$require]->getVersion();
+
+ foreach ($links as $link) {
+ if (!$link->getConstraint()->matches(new Constraint('<=', $version))) {
+ $results[] = array(
+ $currentPlatformPackageMap[$require]->getPrettyName(),
+ $currentPlatformPackageMap[$require]->getPrettyVersion(),
+ $link,
+ 'failed',
+ );
+ $pass = false;
+
+ $exitCode = max($exitCode, 1);
+ }
+ }
+
+ if ($pass) {
$results[] = array(
- $require,
- $currentPlatformPackageMap[$key],
- 'failed',
- );
- } else {
- $results[] = array(
- $require,
- $currentPlatformPackageMap[$key],
- 'success',
+ $currentPlatformPackageMap[$require]->getPrettyName(),
+ $currentPlatformPackageMap[$require]->getPrettyVersion(),
+ null,
+ 'success',
);
}
} else {
$results[] = array(
$require,
- null,
- 'miss',
+ 'n/a',
+ $links[0],
+ 'missing',
);
+
+ $exitCode = max($exitCode, 2);
}
}
}
$this->printTable($output, $results);
+ return $exitCode;
}
protected function printTable(OutputInterface $output, $results)
@@ -94,17 +115,14 @@ EOT
$rows = array();
foreach ($results as $result) {
/**
- * @var PackageInterface $platformPackage
- * @var Link $require
+ * @var Link|null $link
*/
- list($require, $platformPackage, $reason) = $result;
- $version = (strpos($platformPackage->getPrettyVersion(), 'No version set') === 0) ? '-' : $platformPackage->getPrettyVersion();
+ list($platformPackage, $version, $link, $status) = $result;
$rows[] = array(
- $platformPackage->getPrettyName(),
+ $platformPackage,
$version,
- $require->getDescription(),
- sprintf('%s (%s)', $require->getTarget(), $require->getPrettyConstraint()),
- $reason
+ $link ? sprintf('%s %s %s (%s)', $link->getSource(), $link->getDescription(), $link->getTarget(), $link->getPrettyConstraint()) : '',
+ $status
);
}
$table = array_merge($rows, $table);
@@ -116,4 +134,4 @@ EOT
$renderer->getStyle()->setCellRowContentFormat('%s ');
$renderer->setRows($table)->render();
}
-}
\ No newline at end of file
+}