Advanced tasksLearn how to interact with pixi tasks
Danger
This is the old documentation website please visit the new site
When building a package, you often have to do more than just run the code. Steps like formatting, linting, compiling, testing, benchmarking, etc. are often part of a project. With pixi tasks, this should become much easier to do.
Here are some quick examples
Depends on
Just like packages can depend on other packages, our tasks can depend on other tasks. This allows for complete pipelines to be run with a single command.
An obvious example is compiling before running an application.
Checkout our cpp_sdl
example for a running example.
In that package we have some tasks that depend on each other, so we can assure that when you run pixi run start
everything is set up as expected.
Results in the following lines added to the pixi.toml
The tasks will be executed after each other:
- First
configure
because it has no dependencies. - Then
build
as it only depends onconfigure
. - Then
start
as all it dependencies are run.
If one of the commands fails (exit with non-zero code.) it will stop and the next one will not be started.
With this logic, you can also create aliases as you don't have to specify any command in a task.
Results in the following pixi.toml
.
Now run both tools with one command.
Working directory
Pixi tasks support the definition of a working directory.
cwd
" stands for Current Working Directory.
The directory is relative to the pixi package root, where the pixi.toml
file is located.
Consider a pixi project structured as follows:
To add a task to run the bar.py
file, use:
This will add the following line to pixi.toml
:
Our task runner: deno_task_shell
To support the different OS's (Windows, OSX and Linux), pixi integrates a shell that can run on all of them.
This is deno_task_shell
.
The task shell is a limited implementation of a bourne-shell interface.
Built-in commands
Next to running actual executable like ./myprogram
, cmake
or python
the shell has some built-in commandos.
cp
: Copies files.mv
: Moves files.rm
: Remove files or directories. Ex:rm -rf [FILE]...
- Commonly used to recursively delete files or directories.mkdir
: Makes directories. Ex.mkdir -p DIRECTORY...
- Commonly used to make a directory and all its parents with no error if it exists.pwd
: Prints the name of the current/working directory.sleep
: Delays for a specified amount of time. Ex.sleep 1
to sleep for 1 second,sleep 0.5
to sleep for half a second, orsleep 1m
to sleep a minuteecho
: Displays a line of text.cat
: Concatenates files and outputs them on stdout. When no arguments are provided, it reads and outputs stdin.exit
: Causes the shell to exit.unset
: Unsets environment variables.xargs
: Builds arguments from stdin and executes a command.
Syntax
- Boolean list: use
&&
or||
to separate two commands.&&
: if the command before&&
succeeds continue with the next command.||
: if the command before||
fails continue with the next command.
- Sequential lists: use
;
to run two commands without checking if the first command failed or succeeded. - Environment variables:
- Set env variable using:
export ENV_VAR=value
- Use env variable using:
$ENV_VAR
- unset env variable using
unset ENV_VAR
- Set env variable using:
- Shell variables: Shell variables are similar to environment variables, but won’t be exported to spawned commands.
- Set them:
VAR=value
- use them:
VAR=value && echo $VAR
- Set them:
- Pipelines: Use the stdout output of a command into the stdin a following command
|
:echo Hello | python receiving_app.py
|&
: use this to also get the stderr as input.
- Command substitution:
$()
to use the output of a command as input for another command.python main.py $(git rev-parse HEAD)
- Negate exit code:
!
before any command will negate the exit code from 1 to 0 or visa-versa. - Redirects:
>
to redirect the stdout to a file.echo hello > file.txt
will puthello
infile.txt
and overwrite existing text.python main.py 2> file.txt
will put thestderr
output infile.txt
.python main.py &> file.txt
will put thestderr
andstdout
infile.txt
.echo hello > file.txt
will appendhello
to the existingfile.txt
.
- Glob expansion:
*
to expand all options.echo *.py
will echo all filenames that end with.py
echo **/*.py
will echo all filenames that end with.py
in this directory and all descendant directories.echo data[0-9].csv
will echo all filenames that have a single number afterdata
and before.csv
More info in deno_task_shell
documentation.