brush (Bo(u)rn(e) RUsty SHell) is a modern bash- and POSIX- compatible shell written in Rust. Run your existing scripts and .bashrc unchanged -- with syntax highlighting and auto-suggestions built in.
β
Your existing .bashrc just worksβaliases, functions, completions, all of it.
β¨ Syntax highlighting and auto-suggestions built in and enabled by default.
π§ͺ Validated against bash with ~1400 compatibility tests.
π§© Easily embeddable in your Rust apps using brush_core::Shell.
β οΈ Not everything works yet:coproc,select, ERR traps, and some edge cases aren't supported. See the Compatibility Reference for details.
$ cargo binstall brush-shell # using cargo-binstall
$ brew install brush # using Homebrew
$ pacman -S brush # Arch Linux
$ cargo install --locked brush-shell # Build from sourcesbrush is ready for use as a daily driver. We test every change against bash to keep it that way.
More detailed installation instructions are available below.
| Feature | Description | |
|---|---|---|
| β | 50+ builtins | echo, declare, read, complete, trap, ulimit, ... |
| β | Full expansions | brace, parameter, arithmetic, command/process substitution, globs, extglob, globstar |
| β | Control flow | if/for/while/until/case, &&/` |
| β | Redirection | here docs, here strings, fd duplication, process substitution redirects |
| β | Arrays & variables | indexed/associative arrays, dynamic variables, standard well-known variables, etc. |
| β | Programmable completion | Works with bash-completion out of the box |
| β | Job control | background jobs, suspend/resume, fg/bg/jobs |
| π· | Traps & options | EXIT/DEBUG traps work; signal traps and options in progress |
| Feature | Description | |
|---|---|---|
| β | Syntax highlighting | Real-time as you type (reedline) |
| β | Auto-suggestions | History-based hints as you type (reedline) |
| β | Rich prompts | PS1/PROMPT_COMMAND, right prompts, starship compatible |
| β | TOML config | ~/.config/brush/config.toml for persistent settings |
| π§ͺ | Extras | fzf/atuin support, zsh-style precmd/preexec hooks (experimental), VS Code terminal integration |
When you run brush, it should look exactly as bash does on your system: it processes your .bashrc and
other standard configuration. If you'd like to distinguish the look of brush from the other shells
on your system, you may author a ~/.brushrc file.
πΊ Installing using Homebrew (macOS/Linux)
Homebrew users can install using the brush formula:
brew install brushπ§ Installing on Arch Linux
Arch Linux users can install brush from the official extra repository:
pacman -S brushπ Installing prebuilt binaries via `cargo binstall`
You may use cargo binstall to install pre-built brush binaries. Once you've installed cargo-binstall you can run:
cargo binstall brush-shellπ Installing prebuilt binaries from GitHub
We publish prebuilt binaries of brush for Linux (x86_64, aarch64) and macOS (aarch64) to GitHub for official releases. You can manually download and extract the brush binary from one of the archives published there, or otherwise use the GitHub CLI to download it, e.g.:
gh release download --repo reubeno/brush --pattern "brush-x86_64-unknown-linux-gnu.*"After downloading the archive for your platform, you may verify its authenticity using the GitHub CLI, e.g.:
gh attestation verify brush-x86_64-unknown-linux-gnu.tar.gz --repo reubeno/brushπ§ Installing using Nix
If you are a Nix user, you can use the registered version:
nix run 'github:NixOS/nixpkgs/nixpkgs-unstable#brush' -- --versionπ¨ Building from sources
To build from sources, first install a working (and recent) rust toolchain; we recommend installing it via rustup. Then run:
cargo install --locked brush-shellThis project started out of curiosity and a desire to learnβwe're keeping that attitude. If something doesn't work the way you'd expect, let us know!
- Discord server β chat with the community
- Building from source β development workflow
- Contribution guidelines β how to submit changes
- Technical docs β architecture and reference
Other POSIX-ish shells implemented in non-C/C++ languages:
nushellβ modern Rust shell (providesreedline)fishβ user-friendly shell (Rust port in 4.0)Oilsβ bash-compatible with new Oil languagemvdan/shβ Go implementationrusty_bashβ another Rust bash-like shell
π Credits
This project relies on many excellent OSS crates:
reedlineβ readline-like input and interactive featuresclapβ command-line parsingfancy-regexβ regex supporttokioβ async runtimenixβ Unix/POSIX APIscriterion.rsβ benchmarkingbash-completionβ completion test suite
Licensed under the MIT license.

