Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mediamonks/composer-vendor-cleaner
Clean your composer vendor directory
https://github.com/mediamonks/composer-vendor-cleaner
cleaner composer vendor
Last synced: about 2 months ago
JSON representation
Clean your composer vendor directory
- Host: GitHub
- URL: https://github.com/mediamonks/composer-vendor-cleaner
- Owner: mediamonks
- License: mit
- Created: 2016-04-26T13:59:05.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-03-06T14:59:43.000Z (almost 7 years ago)
- Last Synced: 2024-11-20T07:36:24.542Z (2 months ago)
- Topics: cleaner, composer, vendor
- Language: PHP
- Homepage:
- Size: 17.6 KB
- Stars: 26
- Watchers: 7
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Total Downloads](https://poser.pugx.org/mediamonks/composer-vendor-cleaner/downloads)](https://packagist.org/packages/mediamonks/composer-vendor-cleaner)
[![Latest Stable Version](https://poser.pugx.org/mediamonks/composer-vendor-cleaner/v/stable)](https://packagist.org/packages/mediamonks/composer-vendor-cleaner)
[![Latest Unstable Version](https://poser.pugx.org/mediamonks/composer-vendor-cleaner/v/unstable)](https://packagist.org/packages/mediamonks/composer-vendor-cleaner)
[![License](https://poser.pugx.org/mediamonks/composer-vendor-cleaner/license)](https://packagist.org/packages/mediamonks/composer-vendor-cleaner)# MediaMonks Composer Vendor Cleaner
Sometimes there are still some unfortunate cases when you need to send your vendor dir to some place and you want it to go as fast as possible.
This package provides a simple script which will try to remove as much stuff as possible without breaking your app.Don't forget to run ``composer install`` with ``--no-dev`` when creating a package for non-development environments, it will already save you loads space and files if you have packages defined in ``require-dev``!
## How it works
The script simply reads all package dirs within the vendor dir (``/``) and removed files from that dir which are not used for running your project.
For most packages this means it will remove docs and tests but also the composer files, licenses and readme's.Since not all packages can be cleaned the same way the ``type`` in ``composer.json`` of the package is used to determine the cleaning handler.
Currently these handlers are available:
### SymfonyBundleHandler
Used when the type is set to ``symfony-bundle``, removes the ``Tests`` dir if it's present
### DefaultHandler
For all other types, removes all folders except the ones that are defined in the ``autoload`` section of the composer.json
## Usage
Clean up current vendor dir:
```
php vendor/mediamonks/composer-vendor-cleaner/bin/clean
```Clean up specific vendor dir:
```
php vendor/mediamonks/composer-vendor-cleaner/bin/clean --dir /path/to/different/vendor/
```To just view what it will do without removing the actual files you can do a dry run:
```
php vendor/mediamonks/composer-vendor-cleaner/bin/clean --dry-run
```## Options
You pass the location of a json file to set some options which can influence the cleaning process:
```
php vendor/mediamonks/composer-vendor-cleaner/bin/clean --options /path/to/options.json
```The current supported options are:
- Excluding entire packages
- Excluding specific dirs for a package
- Excluding specific files for a packageYou can simply look at the provided ``options.json`` (_which is used by default_) to see how the options are defined.
## Disclaimer
This script is under development and is not tested extensively yet so use at your own risk!
## We can use your help!
This script was mainly created to clean up Symfony Framework projects but with your help we can make it work for other frameworks too.
Please create your own handlers, improve the cleaning on current handlers and send in a PR.