123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- <?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\Repository;
- use Composer\Package\PackageInterface;
- use Composer\Package\CompletePackage;
- use Composer\Package\Version\VersionParser;
- use Composer\Plugin\PluginInterface;
- /**
- * @author Jordi Boggiano <j.boggiano@seld.be>
- */
- class PlatformRepository extends ArrayRepository
- {
- const PLATFORM_PACKAGE_REGEX = '{^(?:php(?:-64bit)?|hhvm|(?:ext|lib)-[^/]+)$}i';
- /**
- * Defines overrides so that the platform can be mocked
- *
- * Should be an array of package name => version number mappings
- *
- * @var array
- */
- private $overrides = array();
- public function __construct(array $packages = array(), array $overrides = array())
- {
- parent::__construct($packages);
- foreach ($overrides as $name => $version) {
- $this->overrides[strtolower($name)] = array('name' => $name, 'version' => $version);
- }
- }
- protected function initialize()
- {
- parent::initialize();
- $versionParser = new VersionParser();
- // Add each of the override versions as options.
- // Later we might even replace the extensions instead.
- foreach ($this->overrides as $override) {
- // Check that it's a platform package.
- if (!preg_match(self::PLATFORM_PACKAGE_REGEX, $override['name'])) {
- throw new \InvalidArgumentException('Invalid platform package name in config.platform: '.$override['name']);
- }
- $version = $versionParser->normalize($override['version']);
- $package = new CompletePackage($override['name'], $version, $override['version']);
- $package->setDescription('Overridden virtual platform package '.$override['name']);
- parent::addPackage($package);
- }
- $prettyVersion = PluginInterface::PLUGIN_API_VERSION;
- $version = $versionParser->normalize($prettyVersion);
- $composerPluginApi = new CompletePackage('composer-plugin-api', $version, $prettyVersion);
- $composerPluginApi->setDescription('The Composer Plugin API');
- $this->addPackage($composerPluginApi);
- try {
- $prettyVersion = PHP_VERSION;
- $version = $versionParser->normalize($prettyVersion);
- } catch (\UnexpectedValueException $e) {
- $prettyVersion = preg_replace('#^([^~+-]+).*$#', '$1', PHP_VERSION);
- $version = $versionParser->normalize($prettyVersion);
- }
- $php = new CompletePackage('php', $version, $prettyVersion);
- $php->setDescription('The PHP interpreter');
- $this->addPackage($php);
- if (PHP_INT_SIZE === 8) {
- $php64 = new CompletePackage('php-64bit', $version, $prettyVersion);
- $php64->setDescription('The PHP interpreter (64bit)');
- $this->addPackage($php64);
- }
- $loadedExtensions = get_loaded_extensions();
- // Extensions scanning
- foreach ($loadedExtensions as $name) {
- if (in_array($name, array('standard', 'Core'))) {
- continue;
- }
- $reflExt = new \ReflectionExtension($name);
- try {
- $prettyVersion = $reflExt->getVersion();
- $version = $versionParser->normalize($prettyVersion);
- } catch (\UnexpectedValueException $e) {
- $prettyVersion = '0';
- $version = $versionParser->normalize($prettyVersion);
- }
- $packageName = $this->buildPackageName($name);
- $ext = new CompletePackage($packageName, $version, $prettyVersion);
- $ext->setDescription('The '.$name.' PHP extension');
- $this->addPackage($ext);
- }
- // Another quick loop, just for possible libraries
- // Doing it this way to know that functions or constants exist before
- // relying on them.
- foreach ($loadedExtensions as $name) {
- $prettyVersion = null;
- switch ($name) {
- case 'curl':
- $curlVersion = curl_version();
- $prettyVersion = $curlVersion['version'];
- break;
- case 'iconv':
- $prettyVersion = ICONV_VERSION;
- break;
- case 'intl':
- $name = 'ICU';
- if (defined('INTL_ICU_VERSION')) {
- $prettyVersion = INTL_ICU_VERSION;
- } else {
- $reflector = new \ReflectionExtension('intl');
- ob_start();
- $reflector->info();
- $output = ob_get_clean();
- preg_match('/^ICU version => (.*)$/m', $output, $matches);
- $prettyVersion = $matches[1];
- }
- break;
- case 'libxml':
- $prettyVersion = LIBXML_DOTTED_VERSION;
- break;
- case 'openssl':
- $prettyVersion = preg_replace_callback('{^(?:OpenSSL\s*)?([0-9.]+)([a-z]?).*}', function ($match) {
- return $match[1] . (empty($match[2]) ? '' : '.'.(ord($match[2]) - 96));
- }, OPENSSL_VERSION_TEXT);
- break;
- case 'pcre':
- $prettyVersion = preg_replace('{^(\S+).*}', '$1', PCRE_VERSION);
- break;
- case 'uuid':
- $prettyVersion = phpversion('uuid');
- break;
- case 'xsl':
- $prettyVersion = LIBXSLT_DOTTED_VERSION;
- break;
- default:
- // None handled extensions have no special cases, skip
- continue 2;
- }
- try {
- $version = $versionParser->normalize($prettyVersion);
- } catch (\UnexpectedValueException $e) {
- continue;
- }
- $lib = new CompletePackage('lib-'.$name, $version, $prettyVersion);
- $lib->setDescription('The '.$name.' PHP library');
- $this->addPackage($lib);
- }
- if (defined('HHVM_VERSION')) {
- try {
- $prettyVersion = HHVM_VERSION;
- $version = $versionParser->normalize($prettyVersion);
- } catch (\UnexpectedValueException $e) {
- $prettyVersion = preg_replace('#^([^~+-]+).*$#', '$1', HHVM_VERSION);
- $version = $versionParser->normalize($prettyVersion);
- }
- $hhvm = new CompletePackage('hhvm', $version, $prettyVersion);
- $hhvm->setDescription('The HHVM Runtime (64bit)');
- $this->addPackage($hhvm);
- }
- }
- /**
- * {@inheritDoc}
- */
- public function addPackage(PackageInterface $package)
- {
- // Skip if overridden
- if (isset($this->overrides[strtolower($package->getName())])) {
- return;
- }
- parent::addPackage($package);
- }
- private function buildPackageName($name)
- {
- return 'ext-' . str_replace(' ', '-', $name);
- }
- }
|