mile23/drupal-merge-plugin

Dependency discovery for Drupal contrib projects.

Installs: 290

Dependents: 0

Suggesters: 0

Security: 0

Stars: 7

Watchers: 3

Forks: 0

Open Issues: 1

Type:composer-plugin

dev-master 2016-09-25 13:55 UTC

This package is auto-updated.

Last update: 2019-12-17 01:48:29 UTC


README

Note: This project is in development. It currently does not have even any releases. Want to help? Try using it. File issues. Run the tests. Write tests. Thanks. :-)

This plugin is currently being considered for use in the drupalci_testbot. Want to participate in this decision? Talk here: https://www.drupal.org/node/2597778

What?

drupal-merge-plugin is a Composer plugin that allows Drupal extensions to specify their own Composer-based dependencies without extra infrastructure. This includes Drupal modules, themes, and profiles.

This plugin is an evolution of the plugin_manager module concept, using Drupal extension discovery to merge Composer-based dependencies.

It builds on the Wikimedia project's composer-merge-plugin, and inherits some of that project's behaviors.

You can read the documentation for Wikimedia's composer-merge-plugin here: https://github.com/wikimedia/composer-merge-plugin

Why?

Adding packagist.drupal-composer.org to your composer.json file is enough to help it find Drupal extensions, and install them along with their dependencies.

However, if you need to update, or re-install without a lock file, that won't be enough to manage those dependencies.

With this plugin, that's possible.

Once you're using this plugin, it will search for composer.json files within the extensions present in your Drupal project's file system, and then try to satisfy them. If they can't be satisfied (due to version constraints, etc.) then Composer will tell you.

Note that the plugin does not care if a given extension is enabled or not. It will satisfy all extensions in the Drupal filesystem regardless of the extension's enabled status.

How?

At the command line, type this:

$ composer require mile23/drupal-merge-plugin

This adds the plugin to your Drupal project.

In order to get Drupal extensions using Composer, you must then add the special Drupal Packagist clone to your repositories section. There are instructions here: https://www.drupal.org/node/2718229

Basically, add a repository like this to your composer.json file:

"repositories": {
    "drupal": {
        "type": "composer",
        "url":  "https://packages.drupal.org/8"
    }
}

Then you can add Drupal extensions:

$ composer require drupal/your-module-here

You can add command-line scripts to your composer.json like this:

"scripts": {
    "list-extensions": "Mile23\\DrupalMerge\\Script::listExtensions",
    "list-managed-extensions": "Mile23\\DrupalMerge\\Script::listManagedExtensions",
    "list-unmanaged-extensions": "Mile23\\DrupalMerge\\Script::listUnmanagedExtensions",
},

Once you've done that, you can list available modules by their Composer status.

  • composer list-extensions gives you all discoverable Drupal extensions which have a composer.json file.
  • composer list-managed-extensions gives you the Drupal extensions which are in the requires section of the current Composer package. Restated: If the extension is in your composer.json file, it appears in this list.
  • composer list-unmanaged-extensions gives you a list of extensions which have composer.json files, but which are not listed as dependencies in the current project. These would be extensions downloaded as tarballs, for instance.

What Should My Contrib Module's composer.json File Look Like?

Drupal extensions SHOULD NOT specify that they depend on this plugin. Only project-level composer.json files should use this plugin.

This plugin's behavior might also conflict with other Composer solutions built by the Drupal community.

You can supply a composer.json file per extension, at any folder depth supported by normal Drupal module discovery.

Your composer.json file must be in the same directory as the extension's .info.yml file.

Your comopser.json file should pass the test of running composer validate from the command line.

If your composer.json file does not specify requires and/or requires-dev, then this plugin probably won't be terribly useful to you.

drupal-merge-plugin will use the same merging rules as wikimedia/composer-merge-plugin. That is, requires and requires-dev will be merged, along with other sections of composer.json. Consult the composer-merge-plugin documentation for more information.

You should NOT use the autoload feature of Composer for your extension. Drupal will autoload the module as needed.

drupal-merge-plugin uses the same project type naming convention as composer-installers. This means your module's type field should be drupal-module. This allows the composer-installer plugin to place your module in the proper directory, and allows drupal-merge-plugin to discover it.