This library provides tools for an opinionated composer workflow with Drupal.
When invoked, it creates a Drupal root that can respond to requests routed to it from a web server. This allows you to develop at the module and/or project level and treat Drupal itself as a dependency.
Use composer.
The algorithm is something like this:
- copy
drupal/drupal
out of vendor and into the given drupal path (default:./www
) - link modules and themes installed with composer from vendor into the drupal root
- link directories from the
./modules
directory intosites/all/modules
- link directories from the
./themes
directory intosites/all/themes
- link files that look like module files into a directory in
sites/all/modules
according to the basename of the*.info
file - link
cnf/settings.php
intosites/default
- link
vendor
intosites/default
- link
cnf/files
intosites/default
You have the choice of using a small commandline application or a script handler.
vendor/bin/drupal_tangle -h
Usage:
drupal:tangle [project] [drupal]
Arguments:
project path to project to tangle
drupal path to drupal in which to tangle (default: "www")
You can automate the use of the tangler in response to composer events like so:
{
...
"scripts": {
"post-install-cmd": [
"Drupal\\Tangler\\ScriptHandler::postUpdate",
],
"post-update-cmd": [
"Drupal\\Tangler\\ScriptHandler::postUpdate"
]
},
...
}
Note that you can just trigger the executable with these events, in which case
the values for the different *-cmd
events above would be like this:
[
"vendor/bin/drupal_tangle"
]
- Allow appropriate configuration, such as name of drupal subdir, and origin of
settings.php
- Support development of a theme or profile
- Support for placing things in the
sites/all/libraries
directory (not because this is ever a good idea, but because some projects require it)
- Support for multi-site