npm install --global please-runner
# or
yarn global add please-runner
please
please <script name> [...args]
please --help
please makes it super simple to write and manage project scripts.
When we say “simple”, we really mean it. Write your scripts as plain old executable files – be it in bash, python, JavaScript or any other language of choice. Put them in a scripts/
directory in your project root.
Now, whenever you run please <script name>
, we’ll politely run scripts/<script name>
for you.
We’ll execute scripts/<script name>
for you.
We’ll pass any args over to your script.
You’re looking at it.
Prints the version number and exits.
As opposed to many other script runners, please makes it super easy to pass arguments to scripts. We’ll pass them over to the executable just as you’d expect.
So, when you run please build --mode=dev --target='release v3.0.0'
, we’ll spawn scripts/build --mode=dev --target='release v3.0.0'
.
When you run please
without any arguments, we’ll print a list of all available scripts. Just for your convenience.
Ever felt lost in a project, not knowing if there’s a script for what you want to do? With please, no-one will ever feel lost again! Just add a one-liner summary to your script, right below the shebang. please will politely show that summary whenever it lists available scripts.
Gone are the days of undocumented builds!
One-liner summary doesn’t cut it? Worry not! The effortless handling of arguments makes it really easy for you to add a --help
option to any please script. Feel free to make it print a one-liner description – or a full-blown, manpage-like overview of workflows and options.
Believe it or not – once we’ve started documenting our own scripts with --help
, we never want to look back.
You don’t need to be in the root directory of your project to access a please script. If please doesn’t find a scripts/
subdirectory in your current working directory, it will go up your directory tree, looking for your scripts.
So instead of getting out of your way to type cd ../../..; please make things happen
or ../../../scripts/make things happen
, you can just call please make things happen
. please will take care of finding that script for you so you can stay focused on what you’re doing.
If you’re looking after a monorepo, apart from project-wide scripts in the root directory you might need package-wide scripts in subdirectories. Normally, please stops looking for scripts as soon as it finds a scripts/
directory. You can change that though if you want please to access both package-wide scripts and project-wide scripts from the package directory. Just add a .pleaserc
file to your package directory and set the subproject
property to true
with JSON or YAML:
subproject:
true
Boom! We have you covered.
please scripts are just executable files. You might have noticed this already, but you can run them on a friend’s computer without installing please. Just run scripts/start
instead of please start
.
As well as that, because each of your scripts defines its interpreter explicitly through the shebang, you can use them in any shell.
One more note. please is so simple, that it doesn’t need any configuration. No more “weird, it works on my laptop” problems.
At the moment, it’s most convenient if you save scripts without without a file name extension (i. e. scripts/run
rather than scripts/run.sh
). If it’s a problem for you, drop us a line.
For future compatibility, make sure your script names don’t begin with a dash (-
). Unsurprisingly, please --help
will not run scripts/--help
.
Windows support isn’t there just yet. It’s perfectly possible though. So if you need it, don’t hesitate to give us a shout.
Script summaries currently only work with scripts written in sh, bash, python and javascript. Let us know if you’d like us to support other languages.
Many thanks to Lisa Krymova for the elegant bowtie icon in our logo.
Many thanks to Catharsis Fonts for the amazing open-source font we’ve used in the wordmark.