commit
0f7a64839e
|
@ -28,6 +28,11 @@ class ArrayRepository extends BaseRepository
|
|||
{
|
||||
/** @var PackageInterface[] */
|
||||
protected $packages;
|
||||
|
||||
/**
|
||||
* @var PackageInterface[] indexed by package unique name and used to cache hasPackage calls
|
||||
*/
|
||||
protected $packageMap;
|
||||
|
||||
public function __construct(array $packages = array())
|
||||
{
|
||||
|
@ -121,15 +126,14 @@ class ArrayRepository extends BaseRepository
|
|||
*/
|
||||
public function hasPackage(PackageInterface $package)
|
||||
{
|
||||
$packageId = $package->getUniqueName();
|
||||
|
||||
foreach ($this->getPackages() as $repoPackage) {
|
||||
if ($packageId === $repoPackage->getUniqueName()) {
|
||||
return true;
|
||||
if ($this->packageMap === null) {
|
||||
$this->packageMap = array();
|
||||
foreach ($this->getPackages() as $repoPackage) {
|
||||
$this->packageMap[$repoPackage->getUniqueName()] = $repoPackage;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
return isset($this->packageMap[$package->getUniqueName()]);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -151,6 +155,9 @@ class ArrayRepository extends BaseRepository
|
|||
$this->addPackage($aliasedPackage);
|
||||
}
|
||||
}
|
||||
|
||||
// invalidate package map cache
|
||||
$this->packageMap = null;
|
||||
}
|
||||
|
||||
protected function createAliasPackage(PackageInterface $package, $alias, $prettyAlias)
|
||||
|
@ -171,6 +178,9 @@ class ArrayRepository extends BaseRepository
|
|||
if ($packageId === $repoPackage->getUniqueName()) {
|
||||
array_splice($this->packages, $key, 1);
|
||||
|
||||
// invalidate package map cache
|
||||
$this->packageMap = null;
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue