No description
Find a file
Denis Isidoro ad46a3aa00
Merge pull request #560 from pbsds/patch-1
Rephrase etymology to active voice
2021-06-15 17:44:49 -03:00
.github Upgrade to GitHub-native Dependabot (#540) 2021-04-28 21:13:12 -03:00
assets Add icon SVG (#537) 2021-04-23 11:45:54 -03:00
docs Improve documentation (#529) 2021-04-19 10:42:27 -03:00
scripts Respect BIN_DIR in install script (#566) 2021-06-15 10:02:34 -03:00
shell Respect fzf-overrides in shell widget (#568) 2021-06-15 10:12:22 -03:00
src Bump crossterm from 0.19.0 to 0.20.0 (#564) 2021-06-15 10:16:54 -03:00
tests Replace ~ by $HOME (#565) 2021-06-15 09:43:40 -03:00
.gitignore Rust implementation (#197) 2020-03-04 18:01:23 -03:00
Cargo.lock Bump crossterm from 0.19.0 to 0.20.0 (#564) 2021-06-15 10:16:54 -03:00
Cargo.toml Bump crossterm from 0.19.0 to 0.20.0 (#564) 2021-06-15 10:16:54 -03:00
LICENSE Change license to Apache 2.0 (#141) 2019-10-28 16:58:19 -03:00
Makefile Refactor scripts (#527) 2021-04-19 09:54:35 -03:00
README.md Update README.md 2021-06-15 22:36:45 +02: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, skim, or Alfred under the hood and it can be either used as a command or as a shell widget (à la Ctrl-R).

Table of contents

Installation

navi can be installed with the following package managers:

Packaging status

The recommended way to install navi is by running:

brew install navi

If brew isn't available, you can check alternative install instructions.

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 aliases
  • as a shell scripting tool
  • as an Alfred workflow

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.

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.

Trying out online

If you don't have access to a Unix shell at the moment and you want to live preview navi, head to this playground. It'll start a docker container with instructions for you to install and use the tool. Note: login required.

Similar tools

There are many similar projects out there (beavr, bro, cheat, cheat.sh, cmdmenu, eg, how2, howdoi and tldr, to name a few).

They are excellent projects, but navi remains unique in the following ways:

  • it's natural to write cheatsheets tailored to your needs
  • arguments are neither hardcoded nor a simple template

Etymology

Navi is a character from The Legend of Zelda Ocarina of Time that provides Link with a variety of clues to help him solve puzzles and make progress in his quest.