“Just” (or “Justfile”) is a handy command-line tool that simplifies the execution of project-specific commands tasks. In this tutorial, we’ll explore why and how to use “Just” to enhance your day-by-day command line tasks.
Introduction to “Just”
As a developer, I have been using the command line script files (e.g. bashrc) as a repository of functions to manage all of my daily tasks. For example, shortcuts to build artifacts or to start docker images. At the end of the day, the number of functions or aliases grew up so much I simply forgot I had them available.
That’s where I switched to “Just“. Just is a command-line tool that allows you to define, save, and run project-specific commands in a more human-readable and convenient way. It abstracts away the complexities of running lengthy command lines or scripts and provides a simplified interface for executing tasks.
Advantages of Using “Just”
- Simplified Command Execution: With “Just,” you can define meaningful names for your project-specific tasks, making it easier to execute them. This simplifies the process, especially for team members who may not be familiar with the intricacies of your project.
- Improved Readability: “Justfiles” are typically more readable than complex command lines. This enhances the understanding of project tasks and aids collaboration within your team.
- Customization: You can extend “Just” commands to include additional logic or steps beyond what your build system offers. This flexibility helps integrate with other tools and customize your project’s workflow.
- Separation of Concerns: You can avoid to fill up your profile commands with a myriad of functions. You can define simple justfile to cover standard development tasks.
3. Getting Started with “Just”
To get started with “Just,” follow these steps:
Step 1: Installation: Install the “Just” command-line tool on your system. You can usually do this using a package manager or by downloading the binary from the official “Just” repository. For example, to install just from the binaries, you can do it with a single command:
curl --proto '=https' --tlsv1.2 -sSf https://just.systems/install.sh | bash -s -- --to DEST
Step 2: Edit Justfile: Open the Justfile in a text editor and define your project-specific commands. Let’s see how to do it in the next paragraphs.
4. Creating and Using a Justfile
Firstly, just searches for a justfile
in the current directory written in its particular syntax. Within the justfile, you define your project’s tasks and their corresponding commands. Here’s a simple example:
# Justfile set shell := ["bash", "-uc"] # Build the project build: mvn clean install # Run tests test: mvn test
The above is a sample justfile which applies some settings in the environment (the shell to use) and then defines two tasks. At the end of the day, you will use plain bash/sh syntax for your tasks, in combination with some shortcuts available in just.
Firstly, by executing “just --list
” you can see the list of tasks which are evailable:
just --list build test
Then, by executing only “just”, it will execute by default the first task (build)
just
On the other hand, if you provide the task name, it will execute that specific task. For example:
just test
Within your justfile, you can define aliases that you can use in your justfile using the := operator. Also, you can use backticks to have shell expansion. For example, the following snippet declares the JAVA_HOME alias to the value returned by the ‘jbang jdk home 11’ command:
JAVA_HOME := `jbang jdk home 11`
You can also provide parameter to your just tasks in a simple way. For example:
salute guy: @echo "Hello {{guy}}!"
The above salute function accepts the variable guy as parameter, therefore you can call is as follows:
just salute frank Hello frank!
Finally, if you want to use a non-default filename for just, simply pass it as argument to the --justfile
as follows:
just --color <COLOR> --dump-format <FORMAT> --justfile <JUSTFILE>
A justfile for Quarkus
As an example, here is a basic justfile I’m using to build a Quarkus project:
# Build and Run tests build: mvn clean verify # Build without test quick: mvn clean package -DskipTests # Launch dev mode dev: mvn quarkus:dev run: quick java -jar target/quarkus-app/quarkus-run.jar
You can find the GitHub project here, which contains links to the documentation and some examples of just: https://github.com/casey/just/