Skip to content

far-blue/composer-merge-plugin

 
 

Repository files navigation

Latest Stable Version License Build Status Code Coverage

Composer Merge Plugin

Merge one or more additional composer.json files at runtime.

Installation

$ composer require wikimedia/composer-merge-plugin

Usage

{
    "require": {
        "wikimedia/composer-merge-plugin": "dev-master"
    },
    "extra": {
        "merge-plugin": {
            "include": [
                "composer.local.json",
                "extensions/*/composer.json"
            ],
            "recurse": false,
            "replace": 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.

The "require", "require-dev", "repositories" and "suggest" sections of the found configuration files will be merged into the root package configuration as though they were directly included in the top-level composer.json file.

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-plugin" section to change to a "last version specified wins" conflict resolution strategy. In this mode, duplicate package declarations in merged files will overwrite the declarations made in earlier files. Files are loaded in the order specified in the include section with globbed files being loaded in alphabetical order.

Running tests

$ composer install
$ composer test

Contributing

Bug, feature requests and other issues should be reported to the GitHub project. We accept code and documentation contributions via Pull Requests on GitHub as well.

  • PSR-2 Coding Standard is used by the project. The included test configuration uses PHP Code Sniffer to validate the conventions.
  • Tests are encouraged. Our test coverage isn't perfect but we'd like it to get better rather than worse, so please try to include tests with your changes.
  • Keep the documentation up to date. Make sure README.md and other relevant documentation is kept up to date with your changes.
  • One pull request per feature. Try to keep your changes focused on solving a single problem. This will make it easier for us to review the change and easier for you to make sure you have updated the necessary tests and documentation.

License

Composer Merge plugin is licensed under the MIT license. See the LICENSE file for more details.


About

Merge one or more additional composer.json files at runtime

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%