1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- <?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\Installer;
- use Composer\Composer;
- use Composer\Package\Package;
- use Composer\IO\IOInterface;
- use Composer\Repository\InstalledRepositoryInterface;
- use Composer\Package\PackageInterface;
- /**
- * Installer for plugin packages
- *
- * @author Jordi Boggiano <j.boggiano@seld.be>
- * @author Nils Adermann <naderman@naderman.de>
- */
- class PluginInstaller extends LibraryInstaller
- {
- private $installationManager;
- private static $classCounter = 0;
- /**
- * Initializes Plugin installer.
- *
- * @param IOInterface $io
- * @param Composer $composer
- * @param string $type
- */
- public function __construct(IOInterface $io, Composer $composer, $type = 'library')
- {
- parent::__construct($io, $composer, 'composer-plugin');
- $this->installationManager = $composer->getInstallationManager();
- }
- /**
- * {@inheritDoc}
- */
- public function supports($packageType)
- {
- return $packageType === 'composer-plugin' || $packageType === 'composer-installer';
- }
- /**
- * {@inheritDoc}
- */
- public function install(InstalledRepositoryInterface $repo, PackageInterface $package)
- {
- $extra = $package->getExtra();
- if (empty($extra['class'])) {
- throw new \UnexpectedValueException('Error while installing '.$package->getPrettyName().', composer-plugin packages should have a class defined in their extra key to be usable.');
- }
- parent::install($repo, $package);
- $this->composer->getPluginManager()->registerPackage($package, true);
- }
- /**
- * {@inheritDoc}
- */
- public function update(InstalledRepositoryInterface $repo, PackageInterface $initial, PackageInterface $target)
- {
- $extra = $target->getExtra();
- if (empty($extra['class'])) {
- throw new \UnexpectedValueException('Error while installing '.$target->getPrettyName().', composer-plugin packages should have a class defined in their extra key to be usable.');
- }
- parent::update($repo, $initial, $target);
- $this->composer->getPluginManager()->registerPackage($target, true);
- }
- }
|