Wallogit.com
2017 © Pedro Peláez
A composer plugin, to help install packages of different types in custom paths.
A composer plugin to install different types of Composer packages in custom directories outside the default vendor folder., (*1)
This is not another composer-installer library for supporting non-composer package types i.e. application .. etc. This is only to add the flexibility of installing composer packages outside the vendor folder. This package only supports composer package types,, (*2)
https://getcomposer.org/doc/04-schema.md#type, (*3)
The type of the package. It defaults to library., (*4)
Package types are used for custom installation logic. If you have a package that needs some special logic, you can define a custom type. This could be a symfony-bundle, a wordpress-plugin or a typo3-module. These types will all be specific to certain projects, and they will need to provide an installer capable of installing packages of that type., (*5)
composer.json require section:: "require":{
"php": ">=5.3",
"mnsami/composer-custom-directory-installer": "1.1.*",
"monolog/monolog": "*"
}
extra section define the custom directory you want to the package to be installed in:: "extra":{
"installer-paths":{
"./monolog/": ["monolog/monolog"]
}
}
by adding the installer-paths part, you are telling composer to install the monolog package inside the monolog folder in your root directory., (*6)
composer/installers, in other words you can use variables like {$vendor} and {$name} in your installer-path section:: "extra": {
"installer-paths": {
"./customlibs/{$vendor}/db/{$name}": ["doctrine/orm"]
}
}
the above will manage to install the doctrine/orm package in the root folder of your project, under customlibs., (*7)
Composer type: project is not supported in this installer, as packages with type project only make sense to be used with application shells like symfony/framework-standard-edition, to be required by another package., (*8)