Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Canop/bacon
background rust code check
https://github.com/Canop/bacon
cargo check compilation hacktoberfest rust terminal
Last synced: 2 months ago
JSON representation
background rust code check
- Host: GitHub
- URL: https://github.com/Canop/bacon
- Owner: Canop
- License: agpl-3.0
- Created: 2020-10-29T12:53:20.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-27T09:48:34.000Z (3 months ago)
- Last Synced: 2024-10-27T10:58:40.537Z (3 months ago)
- Topics: cargo, check, compilation, hacktoberfest, rust, terminal
- Language: Rust
- Homepage: https://dystroy.org/bacon
- Size: 1.52 MB
- Stars: 1,914
- Watchers: 12
- Forks: 69
- Open Issues: 35
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - Canop/bacon - background code checker (Rust)
- awesome-rust - bacon - watch (Development tools / Web Servers)
- awesome-rust-cn - bacon - watch (开发工具 Development tools / Web服务器 Web Servers)
- awesome-rust - bacon - background rust code checker, similar to cargo-watch (Development tools / Web Servers)
- fucking-awesome-rust - bacon - background rust code checker, similar to cargo-watch (Development tools / Web Servers)
- fucking-awesome-rust - bacon - background rust code checker, similar to cargo-watch (Development tools / Web Servers)
- awesome-repositories - Canop/bacon - background code checker (Rust)
README
![bacon][logo]
[logo]: img/logo-text.png?raw=true "bacon"
[![Latest Version][s1]][l1] [![site][s4]][l4] [![Chat on Miaou][s2]][l2] [![License: AGPL v3][s3]][l3]
[s1]: https://img.shields.io/crates/v/bacon.svg
[l1]: https://crates.io/crates/bacon[s2]: https://dystroy.org/chat-shield.svg
[l2]: https://miaou.dystroy.org/3768?rust[s3]: https://img.shields.io/badge/License-AGPL_v3-blue.svg
[l3]: https://www.gnu.org/licenses/agpl-3.0[s4]: https://dystroy.org/dystroy-doc-pink-shield.svg
[l4]: https://dystroy.org/bacon**bacon** is a background rust 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.
![screenshot](doc/screenshot.png)
# Documentation
The **[bacon website](https://dystroy.org/bacon)** is a complete guide.
Below is only a short overview.
## install
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.
## check the current project
bacon
That's how you'll usually launch bacon, because other jobs like `test`, `clippy`, `doc`, your own ones, are just a key away: You'll hit c to see Clippy warnings, t for the tests, d to open the documentation, etc.
## check another project
bacon --path ../broot
or
bacon ../broot
## check all targets (tests, examples, benches, etc)
bacon --job check-all
When there's no ambiguity, you may omit the `--job` part:
bacon check-all
## run clippy instead of cargo check
bacon clippy
This will run against all targets like `check-all` does.
## run tests
bacon test
or `bacon nextest` if you're a nextest user.
![bacon test](doc/test.png)
When there's a failure, hit f to restrict the job to the failing test.
Hit esc to get back to all tests.## define your own jobs
First create a `bacon.toml` file by running
bacon --init
This file already contains some standard jobs. Add your own, for example
```toml
[jobs.check-win]
command = ["cargo", "check", "--target", "x86_64-pc-windows-gnu", "--color", "always"]
```or
```toml
[jobs.check-examples]
command = ["cargo", "check", "--examples", "--color", "always"]
watch = ["examples"] # src is implicitly included
```*Don't forget the `--color always` part: bacon uses style information to recognize warnings and errors.*
and run
bacon check-win
or
bacon check-examples
The `bacon.toml` file may evolve with the features and settings of your project and should be added to source control.
## Licences
Bacon is licenced under [AGPL-3.0](https://www.gnu.org/licenses/agpl-3.0.en.html).
You're free to use it to compile the Rust projects of your choice, even commercial.The logo is designed by [Peter Varo][pv] and licensed under a
[Creative Commons Attribution-ShareAlike 4.0 International License][cc-lic].
[![license][cc-img]][cc-lic][pv]: https://petervaro.com
[cc-lic]: https://creativecommons.org/licenses/by-sa/4.0
[cc-img]: https://i.creativecommons.org/l/by-sa/4.0/80x15.png