Recipe Parameters
Recipes may have parameters. Here recipe build
has a parameter called
target
:
build target:
@echo 'Building {{target}}…'
cd {{target}} && make
To pass arguments on the command line, put them after the recipe name:
$ just build my-awesome-project
Building my-awesome-project…
cd my-awesome-project && make
To pass arguments to a dependency, put the dependency in parentheses along with the arguments:
default: (build "main")
build target:
@echo 'Building {{target}}…'
cd {{target}} && make
Variables can also be passed as arguments to dependencies:
target := "main"
_build version:
@echo 'Building {{version}}…'
cd {{version}} && make
build: (_build target)
A command’s arguments can be passed to dependency by putting the dependency in parentheses along with the arguments:
build target:
@echo "Building {{target}}…"
push target: (build target)
@echo 'Pushing {{target}}…'
Parameters may have default values:
default := 'all'
test target tests=default:
@echo 'Testing {{target}}:{{tests}}…'
./test --tests {{tests}} {{target}}
Parameters with default values may be omitted:
$ just test server
Testing server:all…
./test --tests all server
Or supplied:
$ just test server unit
Testing server:unit…
./test --tests unit server
Default values may be arbitrary expressions, but expressions containing the
+
, &&
, ||
, or /
operators must be parenthesized:
arch := "wasm"
test triple=(arch + "-unknown-unknown") input=(arch / "input.dat"):
./test {{triple}}
The last parameter of a recipe may be variadic, indicated with either a +
or
a *
before the argument name:
backup +FILES:
scp {{FILES}} me@server.com:
Variadic parameters prefixed with +
accept one or more arguments and expand
to a string containing those arguments separated by spaces:
$ just backup FAQ.md GRAMMAR.md
scp FAQ.md GRAMMAR.md me@server.com:
FAQ.md 100% 1831 1.8KB/s 00:00
GRAMMAR.md 100% 1666 1.6KB/s 00:00
Variadic parameters prefixed with *
accept zero or more arguments and
expand to a string containing those arguments separated by spaces, or an empty
string if no arguments are present:
commit MESSAGE *FLAGS:
git commit {{FLAGS}} -m "{{MESSAGE}}"
Variadic parameters can be assigned default values. These are overridden by arguments passed on the command line:
test +FLAGS='-q':
cargo test {{FLAGS}}
{{…}}
substitutions may need to be quoted if they contain spaces. For
example, if you have the following recipe:
search QUERY:
lynx https://www.google.com/?q={{QUERY}}
And you type:
$ just search "cat toupee"
just
will run the command lynx https://www.google.com/?q=cat toupee
, which
will get parsed by sh
as lynx
, https://www.google.com/?q=cat
, and
toupee
, and not the intended lynx
and https://www.google.com/?q=cat toupee
.
You can fix this by adding quotes:
search QUERY:
lynx 'https://www.google.com/?q={{QUERY}}'
Parameters prefixed with a $
will be exported as environment variables:
foo $bar:
echo $bar