You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
49 lines
1.4 KiB
49 lines
1.4 KiB
3 months ago
|
# Composer - Include Files Plugin
|
||
|
|
||
|
When using the Composer Autoloader if you need project files included prior to files autoloaded by any of your dependencies your out of luck. No longer!
|
||
|
|
||
|
## Installation
|
||
|
|
||
|
```bash
|
||
|
composer require funkjedi/composer-include-files
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
Just add the files you need included using `"include_files"` and they will be include prior to any files included by your dependencies.
|
||
|
|
||
|
```json
|
||
|
// composer.json (project)
|
||
|
{
|
||
|
"extra": {
|
||
|
"include_files": [
|
||
|
"/path/to/file/you/want/to/include",
|
||
|
"/path/to/another/file/you/want/to/include"
|
||
|
]
|
||
|
},
|
||
|
}
|
||
|
```
|
||
|
|
||
|
## Specific Use Case
|
||
|
|
||
|
A good example of where this is required is when overriding helpers provided by Laravel.
|
||
|
|
||
|
In the past simply modifying `bootstrap/autoload.php` to include helpers was sufficient. However new versions of PHPUnit include the Composer Autoloader prior to executing the PHPUnit bootstrap file. Consequently this method of overriding helpers is no longer viable as it will trigger a fatal error when your bootstrap file is included.
|
||
|
|
||
|
But now we can use *Composer - Include Files Plugin* to have Composer include the files in the necessary order.
|
||
|
|
||
|
```json
|
||
|
// composer.json (project)
|
||
|
{
|
||
|
"require": {
|
||
|
"laravel/framework": "^5.2",
|
||
|
"funkjedi/composer-include-files": "^1.0",
|
||
|
},
|
||
|
"extra": {
|
||
|
"include_files": [
|
||
|
"app/helpers.php"
|
||
|
]
|
||
|
},
|
||
|
}
|
||
|
```
|