7. Running Tools

This chapter describes how to run specific tools using CriticalUp.

The examples in this chapter assume the following directory structure:

.
└── project
   └── criticalup.toml

After installing CriticalUp, authenticating, and installing a toolchain, CriticalUp can be used to run the specified tools from the installed toolchain.

CriticalUp will scan the working directory, then any parents, to discover the relevant criticalup.toml and determine which version of the tool to execute.

Note

If CriticalUp does not find a criticalup.toml in the current directory, it will search the parent directory, then the parent of that, up to the root directory of the system.

cd project
criticalup run rustc --help

7.1. Locating Tools

It is possible to find the absolute path of a tool for the current toolchain with the which command:

cd project
criticalup which rustc

7.2. Using the Binary Proxies

CriticalUp creates a number of binary proxies which can be used to run the appropriate Ferrocene binaries for a given workspace. These can be added to your shell path on any OS, or used as a rustup toolchain.

It’s important to note that these binaries share the same binary names as any Rust toolchain that may already be installed. If you already have Rust installed (for example, via rustup) you should either to remove it, use Ferrocene via criticalup run, or add Ferrocene as a rustup toolchain.

Optionally, Ferrocene can be used as a rustup toolchain that may feel familiar to some developers.

7.2.1. As a rustup toolchain

If you already have rustup installed, you can add a ferrocene toolchain:

criticalup link create

Alternatively:

rustup toolchain link ferrocene "$(criticalup link show)"

To verify the link was created, validate there is a ‘ferrocene’ line in the toolchain list:

rustup toolchain list -v

To remove the link:

criticalup link remove

Example usage:

cargo +ferrocene build --release
cargo +ferrocene test

It’s also possible to have rustup use the Ferrocene toolchain by default:

rustup default ferrocene

You can configure your project to use the ferrocene toolchain by default by creating a rust-toolchain.toml:

[toolchain]
channel = "ferrocene"

Then, by default, the Ferrocene toolchain created above should be used. Other rustup toolchains can still be used, for example, cargo +stable run.

7.2.2. On your shell path

7.2.2.1. Linux

Proxies are located at $XDG_DATA_HOME/criticalup/proxy/bin, typically this is ~/.local/share/criticalup/proxy/bin/.

You can add the following line to your ~/.bashrc or ~/.zshrc to add the binary proxies to your PATH:

export PATH="$PATH:$HOME/.local/share/criticalup/proxy/bin"

If you’re using a different shell, such as nushell, you may need to consult the shell’s documentation on how to add to the path.

7.2.2.2. macOS

Proxies are located at ~/Library/Application Support/criticalup/proxy/bin/.

You can add the following line to your ~/.zshrc to add the binary proxies to your PATH:

export PATH="$PATH:$HOME/Library/Application Support/criticalup/proxy/bin"

If you’re using a different shell, such as nushell, you may need to consult the shell’s documentation on how to add to the path.

7.2.2.3. Windows

Proxies are located at %appdata%\criticalup\proxy\bin\, typically this is ~\AppData\Roaming\criticalup\proxy\bin\.

On Windows 11, you can add the folder to your system path by hitting the Windows key and searching ‘Edit environment variables for your account’, then selecting the control panel. If you can’t find it, you can use the ‘Run’ dialog to directly launch it:

rundll32.exe sysdm.cpl,EditEnvironmentVariables

Once there, edit the PATH variable to include the following entry:

%USERPROFILE%\AppData\Roaming\criticalup\proxy\bin\

You’ll then need to sign out, and back in for changes to take effect.

If you’re using a different shell, such as nushell, you may need to consult the shell’s documentation on how to add to the path.