1
0
Fork 0

Merge pull request #208 from stof/find_packages

Find packages
pull/212/merge
Jordi Boggiano 2012-01-16 13:13:46 -08:00
commit 05c84e9dfd
3 changed files with 27 additions and 9 deletions

View File

@ -85,11 +85,9 @@ EOT
$composer->getRepositoryManager()->getRepositories()
);
foreach ($repos as $repository) {
foreach ($repository->getPackages() as $package) {
if ($package->getName() === $input->getArgument('package')) {
if (null === $highestVersion || version_compare($package->getVersion(), $highestVersion->getVersion(), '>=')) {
$highestVersion = $package;
}
foreach ($repository->findPackagesByName($input->getArgument('package')) as $package) {
if (null === $highestVersion || version_compare($package->getVersion(), $highestVersion->getVersion(), '>=')) {
$highestVersion = $package;
}
}
}
@ -135,10 +133,8 @@ EOT
$versions = array();
foreach ($composer->getRepositoryManager()->getRepositories() as $repository) {
foreach ($repository->getPackages() as $version) {
if ($version->getName() === $package->getName()) {
$versions[] = $version->getPrettyVersion();
}
foreach ($repository->findPackagesByName($package->getName()) as $version) {
$versions[] = $version->getPrettyVersion();
}
}

View File

@ -41,6 +41,19 @@ class ArrayRepository implements RepositoryInterface
}
}
/**
* {@inheritDoc}
*/
public function findPackagesByName($name)
{
// normalize name
$name = strtolower($name);
return array_filter($this->getPackages(), function (PackageInterface $package) use ($name) {
return $package->getName() === $name;
});
}
/**
* {@inheritDoc}
*/

View File

@ -41,6 +41,15 @@ interface RepositoryInterface extends \Countable
*/
function findPackage($name, $version);
/**
* Searches for packages by it's name.
*
* @param string $name package name
*
* @return array
*/
function findPackagesByName($name);
/**
* Returns list of registered packages.
*