Commit 7485eaa5 authored by alexpott's avatar alexpott

Issue #2608174 by webflo, hussainweb: Update composer-merge-plugin to latest version

parent ec438eb4
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
"license": "GPL-2.0+", "license": "GPL-2.0+",
"require": { "require": {
"composer/installers": "^1.0.21", "composer/installers": "^1.0.21",
"wikimedia/composer-merge-plugin": "^1.3.0" "wikimedia/composer-merge-plugin": "~1.3"
}, },
"replace": { "replace": {
"drupal/core": "~8.0" "drupal/core": "~8.0"
......
...@@ -4,8 +4,8 @@ ...@@ -4,8 +4,8 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
"This file is @generated automatically" "This file is @generated automatically"
], ],
"hash": "2be29019515c847055593ea41b88475d", "hash": "dac77f10c1f7585fd1f7344c6a376338",
"content-hash": "f38613812a285c03a1a18458384fe0b1", "content-hash": "73cbcb262208c5d802cb528279f2a95c",
"packages": [ "packages": [
{ {
"name": "composer/installers", "name": "composer/installers",
...@@ -1980,16 +1980,16 @@ ...@@ -1980,16 +1980,16 @@
}, },
{ {
"name": "wikimedia/composer-merge-plugin", "name": "wikimedia/composer-merge-plugin",
"version": "dev-master", "version": "v1.3.0",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/wikimedia/composer-merge-plugin.git", "url": "https://github.com/wikimedia/composer-merge-plugin.git",
"reference": "47bb3388cfeae41a38087ac8465a7d08fa92ea2e" "reference": "bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/wikimedia/composer-merge-plugin/zipball/f770a4dd9771041f713f5ba3d8e4ba702015653d", "url": "https://api.github.com/repos/wikimedia/composer-merge-plugin/zipball/bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9",
"reference": "47bb3388cfeae41a38087ac8465a7d08fa92ea2e", "reference": "bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
...@@ -1999,8 +1999,7 @@ ...@@ -1999,8 +1999,7 @@
"require-dev": { "require-dev": {
"composer/composer": "1.0.*@dev", "composer/composer": "1.0.*@dev",
"jakub-onderka/php-parallel-lint": "~0.8", "jakub-onderka/php-parallel-lint": "~0.8",
"phpspec/prophecy-phpunit": "~1.0", "phpunit/phpunit": "~4.8|~5.0",
"phpunit/phpunit": "~4.0",
"squizlabs/php_codesniffer": "~2.1.0" "squizlabs/php_codesniffer": "~2.1.0"
}, },
"type": "composer-plugin", "type": "composer-plugin",
...@@ -2026,7 +2025,7 @@ ...@@ -2026,7 +2025,7 @@
} }
], ],
"description": "Composer plugin to merge multiple composer.json files", "description": "Composer plugin to merge multiple composer.json files",
"time": "2015-09-22 21:14:25" "time": "2015-11-06 20:31:16"
}, },
{ {
"name": "zendframework/zend-diactoros", "name": "zendframework/zend-diactoros",
......
...@@ -96,58 +96,6 @@ ...@@ -96,58 +96,6 @@
"zikula" "zikula"
] ]
}, },
{
"name": "wikimedia/composer-merge-plugin",
"version": "dev-master",
"version_normalized": "9999999-dev",
"source": {
"type": "git",
"url": "https://github.com/wikimedia/composer-merge-plugin.git",
"reference": "47bb3388cfeae41a38087ac8465a7d08fa92ea2e"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/wikimedia/composer-merge-plugin/zipball/f770a4dd9771041f713f5ba3d8e4ba702015653d",
"reference": "47bb3388cfeae41a38087ac8465a7d08fa92ea2e",
"shasum": ""
},
"require": {
"composer-plugin-api": "^1.0",
"php": ">=5.3.2"
},
"require-dev": {
"composer/composer": "1.0.*@dev",
"jakub-onderka/php-parallel-lint": "~0.8",
"phpspec/prophecy-phpunit": "~1.0",
"phpunit/phpunit": "~4.0",
"squizlabs/php_codesniffer": "~2.1.0"
},
"time": "2015-09-22 21:14:25",
"type": "composer-plugin",
"extra": {
"branch-alias": {
"dev-master": "1.3.x-dev"
},
"class": "Wikimedia\\Composer\\MergePlugin"
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Wikimedia\\Composer\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Bryan Davis",
"email": "bd808@wikimedia.org"
}
],
"description": "Composer plugin to merge multiple composer.json files"
},
{ {
"name": "composer/semver", "name": "composer/semver",
"version": "1.0.0", "version": "1.0.0",
...@@ -3858,5 +3806,56 @@ ...@@ -3858,5 +3806,56 @@
"keywords": [ "keywords": [
"templating" "templating"
] ]
},
{
"name": "wikimedia/composer-merge-plugin",
"version": "v1.3.0",
"version_normalized": "1.3.0.0",
"source": {
"type": "git",
"url": "https://github.com/wikimedia/composer-merge-plugin.git",
"reference": "bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/wikimedia/composer-merge-plugin/zipball/bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9",
"reference": "bfed1f8d4eb97e9ba80eee57ea46229d7e5364d9",
"shasum": ""
},
"require": {
"composer-plugin-api": "^1.0",
"php": ">=5.3.2"
},
"require-dev": {
"composer/composer": "1.0.*@dev",
"jakub-onderka/php-parallel-lint": "~0.8",
"phpunit/phpunit": "~4.8|~5.0",
"squizlabs/php_codesniffer": "~2.1.0"
},
"time": "2015-11-06 20:31:16",
"type": "composer-plugin",
"extra": {
"branch-alias": {
"dev-master": "1.3.x-dev"
},
"class": "Wikimedia\\Composer\\MergePlugin"
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Wikimedia\\Composer\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Bryan Davis",
"email": "bd808@wikimedia.org"
}
],
"description": "Composer plugin to merge multiple composer.json files"
} }
] ]
{
"phabricator.uri" : "https://phabricator.wikimedia.org/",
"repository.callsign" : "GCMP",
"history.immutable" : false,
"unit.engine": "PhpunitTestEngine"
}
{
"exclude": "(^vendor/)",
"linters": {
"php": {
"type": "php",
"include": "(\\.php$)"
},
"json": {
"type": "json",
"include": "(\\.json$)"
}
}
}
[![Latest Stable Version](https://img.shields.io/packagist/v/wikimedia/composer-merge-plugin.svg?style=flat)](https://packagist.org/packages/wikimedia/composer-merge-plugin) [![License](https://img.shields.io/packagist/l/wikimedia/composer-merge-plugin.svg?style=flat)](https://github.com/wikimedia/composer-merge-plugin/blob/master/LICENSE) [![Latest Stable Version]](https://packagist.org/packages/wikimedia/composer-merge-plugin) [![License]](https://github.com/wikimedia/composer-merge-plugin/blob/master/LICENSE)
[![Build Status](https://img.shields.io/travis/wikimedia/composer-merge-plugin.svg?style=flat)](https://travis-ci.org/wikimedia/composer-merge-plugin) [![Build Status]](https://travis-ci.org/wikimedia/composer-merge-plugin)
[![Code Coverage](https://img.shields.io/scrutinizer/coverage/g/wikimedia/composer-merge-plugin/master.svg?style=flat)](https://scrutinizer-ci.com/g/wikimedia/composer-merge-plugin/?branch=master) [![Code Coverage]](https://scrutinizer-ci.com/g/wikimedia/composer-merge-plugin/?branch=master)
Composer Merge Plugin Composer Merge Plugin
===================== =====================
Merge one or more additional composer.json files at [Composer] runtime. Merge multiple composer.json files at [Composer] runtime.
Composer Merge Plugin is intended to allow easier dependency management for Composer Merge Plugin is intended to allow easier dependency management for
applications which ship a composer.json file and expect some deployments to applications which ship a composer.json file and expect some deployments to
install additional Composer managed libraries. It does this by allowing the install additional Composer managed libraries. It does this by allowing the
application's top level `composer.json` file to provide a list of optional application's top level `composer.json` file to provide a list of optional
additional configuration files. When Composer is run it will parse these files additional configuration files. When Composer is run it will parse these files
and merge their configuration into the base configuration. This combined and merge their configuration settings into the base configuration. This
configuration will allow downloading additional libraries and generating the combined configuration will then be used when downloading additional libraries
autoloader. It was specifically created to help with installation of and generating the autoloader.
[MediaWiki] which has core Composer managed library requirements and optional
libraries and extensions which may also be managed via Composer. Composer Merge Plugin was created to help with installation of [MediaWiki]
which has core library requirements as well as optional libraries and
extensions which may be managed via Composer.
Installation Installation
------------ ------------
``` ```
$ composer require wikimedia/composer-merge-plugin $ composer require wikimedia/composer-merge-plugin
``` ```
...@@ -40,58 +43,101 @@ Usage ...@@ -40,58 +43,101 @@ Usage
"composer.local.json", "composer.local.json",
"extensions/*/composer.json" "extensions/*/composer.json"
], ],
"recurse": false, "require": [
"submodule/composer.json"
],
"recurse": true,
"replace": false, "replace": false,
"merge-dev": true,
"merge-extra": false "merge-extra": false
} }
} }
} }
``` ```
The `include` key can specify either a single value or an array of values.
Each value is treated as a `glob()` pattern identifying additional
composer.json style configuration files to merge into the configuration for
the current Composer execution. By default the merge plugin is recursive, if
an included file also has a "merge-plugin" section it will also be processed.
This functionality can be disabled by setting `"recurse": false` inside the
"merge-plugin" section.
These sections of the found configuration files will be merged into the root Plugin configuration
package configuration as though they were directly included in the top-level --------------------
composer.json file:
The plugin reads its configuration from the `merge-plugin` section of your
composer.json's `extra` section. An `include` setting is required to tell
Composer Merge Plugin which file(s) to merge.
### include
The `include` setting can specify either a single value or an array of values.
Each value is treated as a PHP `glob()` pattern identifying additional
composer.json style configuration files to merge into the root package
configuration for the current Composer execution.
The following sections of the found configuration files will be merged into
the Composer root package configuration as though they were directly included
in the top-level composer.json file:
* [autoload](https://getcomposer.org/doc/04-schema.md#autoload) * [autoload](https://getcomposer.org/doc/04-schema.md#autoload)
* [autoload-dev](https://getcomposer.org/doc/04-schema.md#autoload-dev) * [autoload-dev](https://getcomposer.org/doc/04-schema.md#autoload-dev)
(optional, see [merge-dev](#merge-dev) below)
* [conflict](https://getcomposer.org/doc/04-schema.md#conflict) * [conflict](https://getcomposer.org/doc/04-schema.md#conflict)
* [provide](https://getcomposer.org/doc/04-schema.md#provide) * [provide](https://getcomposer.org/doc/04-schema.md#provide)
* [replace](https://getcomposer.org/doc/04-schema.md#replace) * [replace](https://getcomposer.org/doc/04-schema.md#replace)
* [repositories](https://getcomposer.org/doc/04-schema.md#repositories) * [repositories](https://getcomposer.org/doc/04-schema.md#repositories)
* [require](https://getcomposer.org/doc/04-schema.md#require) * [require](https://getcomposer.org/doc/04-schema.md#require)
* [require-dev](https://getcomposer.org/doc/04-schema.md#require-dev) * [require-dev](https://getcomposer.org/doc/04-schema.md#require-dev)
(optional, see [merge-dev](#merge-dev) below)
* [suggest](https://getcomposer.org/doc/04-schema.md#suggest) * [suggest](https://getcomposer.org/doc/04-schema.md#suggest)
* [extra](https://getcomposer.org/doc/04-schema.md#extra)
(optional, see [merge-extra](#merge-extra) below)
### require
The `require` setting is identical to `[include](#include)` except when
a pattern fails to match at least one file then it will cause an error.
### recurse
By default the merge plugin is recursive; if an included file has
a `merge-plugin` section it will also be processed. This functionality can be
disabled by adding a `"recurse": false` setting.
A `"merge-extra": true` setting enables the merging of the "extra" section of
included files as well. The normal merge mode for the extra section is to ### replace
accept the first version of any key found (e.g. a key in the master config
wins over the version found in an imported config). If `replace` mode is By default, Composer's conflict resolution engine is used to determine which
active (see below) then this behavior changes and the last found key will win version of a package should be installed when multiple files specify the same
(the key in the master config is replaced by the key in the imported config). package. A `"replace": true` setting can be provided to change to a "last
Note that the `merge-plugin` key itself is excluded from this merge process. version specified wins" conflict resolution strategy. In this mode, duplicate
Your mileage with merging the extra section will vary depending on the plugins package declarations found in merged files will overwrite the declarations
being used and the order in which they are processed by Composer. made by earlier files. Files are loaded in the order specified by the
`include` setting with globbed files being processed in alphabetical order.
By default, Composer's normal conflict resolution engine is used to determine
which version of a package should be installed if multiple files specify the
same package. A `"replace": true` setting can be provided inside the ### merge-dev
"merge-plugin" section to change to a "last version specified wins" conflict
resolution strategy. In this mode, duplicate package declarations in merged By default, `autoload-dev` and `require-dev` sections of included files are
files will overwrite the declarations made in earlier files. Files are loaded merged. A `"merge-dev": false` setting will disable this behavior.
in the order specified in the `include` section with globbed files being
loaded in alphabetical order.
### merge-extra
A `"merge-extra": true` setting enables the merging the contents of the
`extra` section of included files as well. The normal merge mode for the extra
section is to accept the first version of any key found (e.g. a key in the
master config wins over the version found in any imported config). If
`replace` mode is active ([see above](#replace)) then this behavior changes
and the last key found will win (e.g. the key in the master config is replaced
by the key in the imported config). The usefulness of merging the extra
section will vary depending on the Composer plugins being used and the order
in which they are processed by Composer.
Note that `merge-plugin` sections are excluded from the merge process, but are
always processed by the plugin unless [recursion](#recurse) is disabled.
Running tests Running tests
------------- -------------
``` ```
$ composer install $ composer install
$ composer test $ composer test
...@@ -100,6 +146,7 @@ $ composer test ...@@ -100,6 +146,7 @@ $ composer test
Contributing Contributing
------------ ------------
Bug, feature requests and other issues should be reported to the [GitHub Bug, feature requests and other issues should be reported to the [GitHub
project]. We accept code and documentation contributions via Pull Requests on project]. We accept code and documentation contributions via Pull Requests on
GitHub as well. GitHub as well.
...@@ -119,6 +166,7 @@ GitHub as well. ...@@ -119,6 +166,7 @@ GitHub as well.
License License
------- -------
Composer Merge plugin is licensed under the MIT license. See the `LICENSE` Composer Merge plugin is licensed under the MIT license. See the `LICENSE`
file for more details. file for more details.
...@@ -129,3 +177,7 @@ file for more details. ...@@ -129,3 +177,7 @@ file for more details.
[GitHub project]: https://github.com/wikimedia/composer-merge-plugin [GitHub project]: https://github.com/wikimedia/composer-merge-plugin
[PSR-2 Coding Standard]: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md [PSR-2 Coding Standard]: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md
[PHP Code Sniffer]: http://pear.php.net/package/PHP_CodeSniffer [PHP Code Sniffer]: http://pear.php.net/package/PHP_CodeSniffer
[Latest Stable Version]: https://img.shields.io/packagist/v/wikimedia/composer-merge-plugin.svg?style=flat
[License]: https://img.shields.io/packagist/l/wikimedia/composer-merge-plugin.svg?style=flat
[Build Status]: https://img.shields.io/travis/wikimedia/composer-merge-plugin.svg?style=flat
[Code Coverage]: https://img.shields.io/scrutinizer/coverage/g/wikimedia/composer-merge-plugin/master.svg?style=flat
...@@ -18,8 +18,7 @@ ...@@ -18,8 +18,7 @@
"require-dev": { "require-dev": {
"composer/composer": "1.0.*@dev", "composer/composer": "1.0.*@dev",
"jakub-onderka/php-parallel-lint": "~0.8", "jakub-onderka/php-parallel-lint": "~0.8",
"phpspec/prophecy-phpunit": "~1.0", "phpunit/phpunit": "~4.8|~5.0",
"phpunit/phpunit": "~4.0",
"squizlabs/php_codesniffer": "~2.1.0" "squizlabs/php_codesniffer": "~2.1.0"
}, },
"autoload": { "autoload": {
......
...@@ -42,24 +42,60 @@ public function __construct($name, IOInterface $io) ...@@ -42,24 +42,60 @@ public function __construct($name, IOInterface $io)
/** /**
* Log a debug message * Log a debug message
* *
* Messages will be output at the "very verbose" logging level (eg `-vv`
* needed on the Composer command).
*
* @param string $message
*/
public function debug($message)
{
if ($this->inputOutput->isVeryVerbose()) {
$message = " <info>[{$this->name}]</info> {$message}";
$this->log($message);
}
}
/**
* Log an informative message
*
* Messages will be output at the "verbose" logging level (eg `-v` needed * Messages will be output at the "verbose" logging level (eg `-v` needed
* on the Composer command). * on the Composer command).
* *
* @param string $message * @param string $message
*/ */
public function debug($message) public function info($message)
{ {
if ($this->inputOutput->isVerbose()) { if ($this->inputOutput->isVerbose()) {
$message = " <info>[{$this->name}]</info> {$message}"; $message = " <info>[{$this->name}]</info> {$message}";
$this->log($message);
}
}
if (method_exists($this->inputOutput, 'writeError')) { /**
$this->inputOutput->writeError($message); * Log a warning message
} else { *
// @codeCoverageIgnoreStart * @param string $message
// Backwards compatiblity for Composer before cb336a5 */
$this->inputOutput->write($message); public function warning($message)
// @codeCoverageIgnoreEnd {
} $message = " <error>[{$this->name}]</error> {$message}";
$this->log($message);
}
/**
* Write a message
*
* @param string $message
*/
protected function log($message)
{
if (method_exists($this->inputOutput, 'writeError')) {
$this->inputOutput->writeError($message);
} else {
// @codeCoverageIgnoreStart
// Backwards compatiblity for Composer before cb336a5
$this->inputOutput->write($message);
// @codeCoverageIgnoreEnd
} }
} }
} }
......
<?php
/**
* This file is part of the Composer Merge plugin.
*
* Copyright (C) 2015 Bryan Davis, Wikimedia Foundation, and contributors
*
* This software may be modified and distributed under the terms of the MIT
* license. See the LICENSE file for details.
*/
namespace Wikimedia\Composer\Merge;
/**
* @author Bryan Davis <bd808@bd808.com>
*/
class MissingFileException extends \RuntimeException
{
}
...@@ -11,9 +11,6 @@ ...@@ -11,9 +11,6 @@
namespace Wikimedia\Composer\Merge; namespace Wikimedia\Composer\Merge;
use Composer\Composer; use Composer\Composer;
use Composer\Package\AliasPackage;
use Composer\Package\RootPackage;
use UnexpectedValueException;
/** /**
* Mutable plugin state * Mutable plugin state
...@@ -32,6 +29,11 @@ class PluginState ...@@ -32,6 +29,11 @@ class PluginState
*/ */
protected $includes = array(); protected $includes = array();
/**
* @var array $requires
*/
protected $requires = array();
/** /**
* @var array $duplicateLinks * @var array $duplicateLinks
*/ */
...@@ -52,6 +54,12 @@ class PluginState ...@@ -52,6 +54,12 @@ class PluginState
*/ */
protected $replace = false; protected $replace = false;
/**
* Whether to merge the -dev sections.
* @var bool $mergeDev
*/
protected $mergeDev = true;
/** /**
* Whether to merge the extra section. * Whether to merge the extra section.
* *
...@@ -99,12 +107,14 @@ public function __construct(Composer $composer) ...@@ -99,12 +107,14 @@ public function __construct(Composer $composer)
*/ */
public function loadSettings() public function loadSettings()
{ {
$extra = $this->getRootPackage()->getExtra(); $extra = $this->composer->getPackage()->getExtra();
$config = array_merge( $config = array_merge(
array( array(
'include' => array(), 'include' => array(),
'require' => array(),
'recurse' => true, 'recurse' => true,
'replace' => false, 'replace' => false,
'merge-dev' => true,
'merge-extra' => false, 'merge-extra' => false,
), ),
isset($extra['merge-plugin']) ? $extra['merge-plugin'] : array() isset($extra['merge-plugin']) ? $extra['merge-plugin'] : array()
...@@ -112,41 +122,32 @@ public function loadSettings() ...@@ -112,41 +122,32 @@ public function loadSettings()
$this->includes = (is_array($config['include'])) ? $this->includes = (is_array($config['include'])) ?
$config['include'] : array($config['include']); $config['include'] : array($config['include']);
$this->requires = (is_array($config['require'])) ?
$config['require'] : array($config['require']);
$this->recurse = (bool)$config['recurse']; $this->recurse = (bool)$config['recurse'];
$this->replace = (bool)$config['replace']; $this->replace = (bool)$config['replace'];
$this->mergeDev = (bool)$config['merge-dev'];
$this->mergeExtra = (bool)$config['merge-extra']; $this->mergeExtra = (bool)$config['merge-extra'];
} }
/** /**
* Get the root package * Get list of filenames and/or glob patterns to include
* *
* @return RootPackage * @return array
*/ */
public function getRootPackage() public function getIncludes()
{ {
$root = $this->composer->getPackage(); return $this->includes;
if ($root instanceof AliasPackage) {
$root = $root->getAliasOf();
}
// @codeCoverageIgnoreStart
if (!$root instanceof RootPackage) {
throw new UnexpectedValueException(
'Expected instance of RootPackage, got ' .
get_class($root)
);
}
// @codeCoverageIgnoreEnd
return $root;
} }
/** /**
* Get list of filenames and/or glob patterns to include * Get list of filenames and/or glob patterns to require
* *
* @return array * @return array
*/ */
public function getIncludes() public function getRequires()
{ {
return $this->includes; return $this->requires;
} }
/** /**
...@@ -216,7 +217,7 @@ public function setDevMode($flag) ...@@ -216,7 +217,7 @@ public function setDevMode($flag)
*/ */
public function isDevMode() public function isDevMode()
{ {
return $this->devMode; return $this->mergeDev && $this->devMode;
} }
/** /**
......