- Install in a project as a phar - recommended for most projects.
- Other installation methods
- Install as a composer dependency - super easy, but might be annoying to use when building a dist version of your project.
- Install globally as a phar - Puts the benefits of pup on your system (this is handy!).
- Install globally as a git clone - Same as the global phar approach, but you get the benefit of switching versions with git.
This adds pup
to your project for use in composer
in such a way that it can be run regardless of whether you have
run composer install
or composer install --no-dev
. There are a couple of steps:
- Create a
bin/
directory in your project - Add
pup.phar
to your.gitignore
- Add
pup.phar
to yourcomposer.json
scripts
You will need a place for composer
to place the phar
file. Create a bin/
directory in your project root and commit a .gitkeep
file into it:
mkdir bin
touch bin/.gitkeep
git commit bin/.gitkeep -m "Adding bin directory"
Edit your .gitignore
file (create that file if you don't have one) and add the following line:
pup.phar
Now we tell composer
to download the pup.phar
file into the bin/
directory if it is missing when we run composer pup
.
"scripts": {
"pup": [
"sh -c 'test -f ./bin/pup.phar || curl -o bin/pup.phar -L -C - https://github.com/stellarwp/pup/releases/download/VERSION/pup.phar'",
"@php ./bin/pup.phar"
]
}
If you want to install pup
as a composer dependency, simply:
composer require stellarwp/pup
When packaging zips, pup
will exclude vendor/stellarwp/pup
by default. It does this by using its
.distignore-defaults
file, which has vendor/stellarwp/pup
in it. It is likely that there are other packages that
come with pup
via Symfony
that you may want to exclude as well. You can add a .distignore
file to your project to
do so.
If you don't want the hassle of managing a .distignore
for the pup
dependencies, we suggest installing into your
project as a phar
instead.
Head to releases and download the pup.phar
and place it in a directory that is in your $PATH
(e.g. /usr/local/bin
).
cd /usr/local/bin
# Replace VERSION with the version you want to download
wget https://github.com/stellarwp/pup/releases/download/VERSION/pup.phar
mv pup.phar pup
chmod +x pup
This is easy peasy! Just clone the repo and run composer install
:
git clone git@github.com:stellarwp/pup.git
cd pup
composer install
Optionally, you can add the pup
directory to your $PATH
.