Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save carlosleonam/bb1194f74d75df2cc134832a67c8c12f to your computer and use it in GitHub Desktop.
Save carlosleonam/bb1194f74d75df2cc134832a67c8c12f to your computer and use it in GitHub Desktop.
Composer vendor folder content not up to repo

Composer - tip

Composer vendor folder content not up to repo

Original

Composer Tip

Should I commit the dependencies in my vendor directory?

The general recommendation is no. The vendor directory (or wherever your dependencies are installed) should be added to .gitignore/svn:ignore/etc.

The best practice is to then have all the developers use Composer to install the dependencies. Similarly, the build server, CI, deployment tools etc should be adapted to run Composer as part of their project bootstrapping.

While it can be tempting to commit it in some environment, it leads to a few problems:

  • Large VCS repository size and diffs when you update code.
  • Duplication of the history of all your dependencies in your own VCS.
  • Adding dependencies installed via git to a git repo will show them as submodules. This is problematic because they are not real submodules, and you will run into issues.

If you really feel like you must do this, you have a few options:

  1. Limit yourself to installing tagged releases (no dev versions), so that you only get zipped installs, and avoid problems with the git "submodules".
  2. Use --prefer-dist or set preferred-install to dist in your config.
  3. Remove the .git directory of every dependency after the installation, then you can add them to your git repo. You can do that with rm -rf vendor/**/.git in ZSH or find vendor/ -type d -name ".git" -exec rm -rf {} \; in Bash. But this means you will have to delete those dependencies from disk before running composer update.
  4. Add a .gitignore rule (/vendor/**/.git) to ignore all the vendor .git folders. This approach does not require that you delete dependencies from disk prior to running a composer update.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment