1
0
Fork 0

Merge remote-tracking branch 'digitalkaoz/issue_366'

pull/398/merge
Jordi Boggiano 2012-03-10 00:17:14 +01:00
commit 4f61ec6600
1 changed files with 15 additions and 10 deletions

View File

@ -56,26 +56,31 @@ EOT
}
$tokens = array_map('strtolower', $input->getArgument('tokens'));
$packages = array();
foreach ($repos->getPackages() as $package) {
foreach ($tokens as $token) {
if (false === ($pos = strpos($package->getName(), $token))) {
if (false === ($pos = strpos($package->getName(), $token)) && (false === strpos(join(',',$package->getKeywords() ?: array()), $token))) {
continue;
}
if ($platformRepo->hasPackage($package)) {
$type = '<info>platform: </info> ';
} elseif ($installedRepo->hasPackage($package)) {
$type = '<info>installed:</info> ';
if (false !== ($pos = strpos($package->getName(), $token))) {
$name = substr($package->getPrettyName(), 0, $pos)
. '<highlight>' . substr($package->getPrettyName(), $pos, strlen($token)) . '</highlight>'
. substr($package->getPrettyName(), $pos + strlen($token));
} else {
$type = '<comment>available:</comment> ';
$name = $package->getPrettyName();
}
$name = substr($package->getPrettyName(), 0, $pos)
. '<highlight>' . substr($package->getPrettyName(), $pos, strlen($token)) . '</highlight>'
. substr($package->getPrettyName(), $pos + strlen($token));
$output->writeln($type . ': ' . $name . ' <comment>' . $package->getPrettyVersion() . '</comment>');
$version = $installedRepo->hasPackage($package) ? '<info>'.$package->getPrettyVersion().'</info>' : $package->getPrettyVersion();
$packages[$name][$package->getPrettyVersion()] = $version;
continue 2;
}
}
foreach ($packages as $name => $versions) {
$output->writeln($name .' <comment>:</comment> '. join(', ', $versions));
}
}
}