macfja / composer-phar-bin
Composer plugin to replace dev dependencies by Phar
Installs: 44
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Type:composer-plugin
Requires
- php: ^7.1
- composer-plugin-api: ^1.0
- ext-simplexml: *
- symfony/process: >= 3
- webmozart/path-util: ^2.1
Requires (Dev)
- composer/composer: ^1.10
- ergebnis/composer-normalize: *
- friendsofphp/php-cs-fixer: ^2.16
- jakub-onderka/php-parallel-lint: ^1.0
- pdepend/pdepend: ^2.5.0
- phan/phan: ^1.1.10 || ^2
- phploc/phploc: >= 2
- phpmd/phpmd: ^2.2.3
- phpstan/phpstan: ^0.10
- rskuipers/php-assumptions: ^0.8.0
- sebastian/phpcpd: ^5.0.1
- theseer/phpdox: ^0.12.0
- vimeo/psalm: ^3.9
This package is auto-updated.
Last update: 2024-12-29 06:02:03 UTC
README
The plugin replace development dependencies by their Phar.
Why ?
I encounter several times a dependency lock on dev tool (code quality, documentation generation, etc.), and most of the time those tool have a Phar binary.
To manage those Phar, solution already exist, like Phive, but it's an another tool to install, another set of commands to run.
So, I create this Composer plugin to integrate Phive into Composer in the less visible way.
How it's works ?
When run composer install
, composer update
, or composer require
, the plugin will check if any of your require-dev
packages exist in the Phive repository.
If found then Phive will link the Phar in your composer binaries so scripts will continue to work and the dependency will be ignore (so its sub-dependencies).
Installation
Simply run: composer require macfja/composer-phar-bin
, and then a composer install
.
Or globally: composer global require macfja/composer-phar-bin
.
Any later composer install
, composer update
, or composer require
will trigger the dependencies replacement.
How prevent a package to be replace ?
If for some reason need a package known by Phive to not be replace by its Phar, you can add in you (root) composer.json
a list of package to don't replace.
In the extra
section add composer-phar-bin
object that contains an array named exclude
of Composer packages.
Example
In the following example, phpunit/phpunit
will be downloaded and managed by Composer, but phan/phan
will be replace by its Phar.
{ "name": "macfja/composer-phar-bin-test", "require-dev": { "macfja/composer-phar-bin": "^1.0.0", "phpunit/phpunit": "^9.1", "phan/phan": "^2.7" }, "extra": { "composer-phar-bin": { "exclude": ["phpunit/phpunit"] } } }
Limitation
The plugin only work after been installed. That seem obvious but there are cases which are tedious to understand because of this.
Dependencies conflicts on new a environment
Let's imagine that you use the plugin and you have virtually some conflict. Everything work fine, the plugin replace conflicting libraries with their Phar.
Someone want to install the project, but Composer complaint about some packages ("Your requirements could not be resolved to an installable set of packages.").
The reason is probably because you don't commit your composer.lock
file, so Composer is trying to solve all dependencies, and as our plugin is not yet installed and loaded, it can't do its magic.
How to solve this ?
You have several solutions to solve this:
- you can commit your
composer.lock
file - you can generate it gradually: remove all dev dependencies, then install your project (
composer install
), and now readd all you dev dependencies - you can install the plugin globally (so it will always be loaded)
Missing phars on fresh install
You download a project with a composer.lock
, run composer install
.
Everything seem ok, but when you first run a composer script, Composer complain about missing file.
The issue here is that the Composer read the composer.lock
file, and so only install your dependencies, excluding the ones that are manage by our plugin.
But as the plugin is not loaded (because not yet installed) it doesn't install phar.
How to solve this ?
You have two options:
- simply rerun
composer install
- install the plugin globally (so it will always be loaded)
Contributing
You can contribute to the library. To do so, you have Github issues to:
- ask your question
- request any change (typo, bad code, etc.)
- and much more...
You also have PR to:
- suggest a correction
- and much more...
Local installation
First clone the project (either this repository, or your fork), next run:
make install # Install project vendor make all # Run QA tools + generate docs
Validate your code
When you done writing your code run the following command check if the quality meet defined rule and to format it:
make analyze # Run QA tools
License
The MIT License (MIT). Please see License File for more information.