bacon is a background code checker.

It's designed for minimal interaction so that you can just let it run, alongside your editor, and be notified of warnings, errors, or test failures in your Rust code.

It conveys the information you need even in a small terminal so that you can keep more screen estate for your other tasks.

It shows you errors before warnings, and the first errors before the last ones, so you don't have to scroll up to find what's relevant.

vi-and-bacon

You don't have to remember commands: the essential ones are listed on bottom and the few other ones are shown on a hit on the h key.

Installation

Run

cargo install --locked bacon

Run this command too if you want to update bacon. Configuration has always been retro-compatible so you won't lose anything.

Usage

Launch bacon in a terminal you'll keep visible

bacon

This launches the default job, usually based on cargo check : Bacon will watch the source directories and shows you the errors and warnings found by the cargo command.

You may decide to launch and watch tests by either hitting the t key, or by launching bacon with

bacon test

or bacon nextest if you're a nextest user.

test

When there's a failure, hit f to restrict the job to the failing test. Hit esc to get back to all tests.

While in bacon, you can see Clippy warnings by hitting the c key. And you get back to your previous job with esc

You may also open the cargo doc in your browser with the d key.

You can configure and launch the jobs of your choice: tests, specific target compilations, examples, etc. and look at the results while you code.

Run bacon --help to see all launch arguments, and read the cookbook.

Configuration

See config for details, but here's the crust:

Global Preferences

The prefs.toml file lets you define key bindings, or always start in summary mode or with lines wrapped.

To create a default preferences file, use bacon --prefs.

Shortcut:

$EDITOR "$(bacon --prefs)"

Project Settings

You'll define in the bacon.toml file the jobs you need, perhaps an example to check, a run with special parameters, or the settings of clippy, as well as shortcuts to run those jobs.

Create a bacon.toml file by running

bacon --init

This file already contains some standard jobs. Add your own, for example

[jobs.check-win]
command = ["cargo", "check", "--target", "x86_64-pc-windows-gnu"]