No description
Find a file
alexis-opolka df8c0ff7b3 Update docs on widgets
Signed-off-by: alexis-opolka <53085471+alexis-opolka@users.noreply.github.com>
2025-04-30 22:14:03 +02:00
.github Fixes unintended changes on the CI 2025-03-29 09:09:26 +01:00
assets Add icon SVG (#537) 2021-04-23 11:45:54 -03:00
docs Update docs on widgets 2025-04-30 22:14:03 +02:00
scripts 2.24.0 bump (#935) 2025-01-29 20:18:21 -03:00
shell Update new-docs branch (#26) 2025-03-24 03:25:10 +01:00
src Cargo fmt 2025-04-01 08:45:12 +02:00
tests mvp. 2024-06-24 18:50:29 +08:00
.gitignore introduce use env_logger 2023-05-12 17:01:49 +08:00
Cargo.lock 2.24.0 bump (#935) 2025-01-29 20:18:21 -03:00
Cargo.toml 2.24.0 bump (#935) 2025-01-29 20:18:21 -03:00
LICENSE Change license to Apache 2.0 (#141) 2019-10-28 16:58:19 -03:00
Makefile Use correct bash binary in Makefile 2021-08-07 15:46:07 -03:00
README.md Removes the entry for the deprecated Alfred feature 2025-03-15 11:36:05 +01:00
rust-toolchain.toml Upgrade dependencies 2025-01-11 10:46:32 +01:00
rustfmt.toml Fix Ctrl-O behavior when snippet has variables (#437) 2020-11-27 09:35:15 -03:00

navi icon Actions Status GitHub release

An interactive cheatsheet tool for the command-line.

Demo

navi allows you to browse through cheatsheets (that you may write yourself or download from maintainers) and execute commands. Suggested values for arguments are dynamically displayed in a list.

Pros

  • it will spare you from knowing CLIs by heart
  • it will spare you from copy-pasting output from intermediate commands
  • it will make you type less
  • it will teach you new one-liners

It uses fzf or skim under the hood and it can be either used as a command or as a shell widget (à la Ctrl-R).

Table of contents

Installation

The recommended way to install navi is by running:

brew install navi

Note

For more details on how to install Navi, see docs/installation

navi can be installed with the following package managers:

Packaging status

Usage

There are multiple ways to use navi:

  • by typing navi in the terminal
    • pros: you have access to all possible subcommands and flags
  • as a shell widget for the terminal
    • pros: the shell history is correctly populated (i.e. with the actual command you ran instead of navi) and you can edit the command as you wish before executing it
  • as a Tmux widget
    • pros: you can use your cheatsheets in any command-line app even in SSH sessions
  • as aliases
  • as a shell scripting tool

In particular, check these instructions if you want to replicate what's shown in the demo above.

Cheatsheet repositories

Running navi for the first time will help you download and manage cheatsheets. By default, they are stored at ~/.local/share/navi/cheats/.

You can also:

Cheatsheet syntax

Cheatsheets are described in .cheat files that look like this:

% git, code

# Change branch
git checkout <branch>

$ branch: git branch | awk '{print $NF}'

The full syntax and examples can be found here.

Customization

You can:

More info

Please run the following command to read more about all possible options:

navi --help

In addition, please check the /docs folder or the website.