Reverted inadvertent API change, improved API documentation

main
Malte Wunsch 9 years ago
parent 767279b41a
commit 70ff00c9de

@ -42,12 +42,11 @@ class WritableArrayRepository extends ArrayRepository implements WritableReposit
{ {
$packages = $this->getPackages(); $packages = $this->getPackages();
// get at most one package of each (name, version) combination, prefering non-aliased ones // get at most one package of each name, preferring non-aliased ones
$packagesByName = array(); $packagesByName = array();
foreach ($packages as $package) { foreach ($packages as $package) {
$index = $package->getName() . $package->getVersion(); if (!isset($packagesByName[$package->getName()]) || $packagesByName[$package->getName()] instanceof AliasPackage) {
if (!isset($packagesByName[$index]) || $packagesByName[$index] instanceof AliasPackage) { $packagesByName[$package->getName()] = $package;
$packagesByName[$index] = $package;
} }
} }

@ -41,14 +41,14 @@ interface WritableRepositoryInterface extends RepositoryInterface
public function removePackage(PackageInterface $package); public function removePackage(PackageInterface $package);
/** /**
* Get unique packages, with aliases resolved and removed * Get unique packages (at most one package of each name), with aliases resolved and removed.
* *
* @return PackageInterface[] * @return PackageInterface[]
*/ */
public function getCanonicalPackages(); public function getCanonicalPackages();
/** /**
* Forces a reload of all packages * Forces a reload of all packages.
*/ */
public function reload(); public function reload();
} }

@ -1,29 +0,0 @@
<?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\Test\Repository;
use Composer\Repository\WritableArrayRepository;
use Composer\TestCase;
final class WritableArrayRepositoryTest extends TestCase
{
public function testGetCanonicalPackagesReturnsDifferentVersionsOfSameNamedPackage()
{
$repository = new WritableArrayRepository();
$repository->addPackage($this->getPackage('foo', 1));
$repository->addPackage($this->getPackage('foo', 2));
$this->assertCount(2, $repository->getCanonicalPackages());
}
}
Loading…
Cancel
Save