Users might file an issue while running an older version, but the issue
has already been fixed in master. Adding the git revision to the version
output will expedite this diagnosis. For example:
$ zoxide -V
zoxide 0.3.0-0191eea
|
||
|---|---|---|
| .github/workflows | ||
| src | ||
| .gitignore | ||
| CHANGELOG.md | ||
| Cargo.lock | ||
| Cargo.toml | ||
| LICENSE | ||
| README.md | ||
| build.rs | ||
| init.fish | ||
| install.sh | ||
| ranger_zoxide.py | ||
| zoxide.plugin.zsh | ||
README.md
zoxide
A cd command that learns your habits
Table of contents
Introduction
zoxide is a blazing fast alternative to cd, inspired by
z and z.lua.
It keeps track of the directories you use most frequently, and uses a ranking algorithm
to navigate to the best match.
Examples
z foo # cd to highest ranked directory matching foo
z foo bar # cd to highest ranked directory matching foo and bar
z foo/ # can also cd into actual directories
zi foo # cd with interactive selection using fzf
zq foo # echo the best match, don't cd
za /foo # add /foo to the database
zr /foo # remove /foo from the database
Getting started
Step 1: Installing zoxide
If you have Rust, this should be as simple as:
cargo install zoxide -f
Otherwise, try the install script:
curl --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/ajeetdsouza/zoxide/master/install.sh | sh
If you want the interactive fuzzy selection feature, you will also need to install
fzf.
Step 2: Adding zoxide to your shell
If you currently use z, z.lua, or zsh-z, you may want to first import
your existing database into zoxide:
zoxide import /path/to/db
zsh
Add the following line to your ~/.zshrc:
eval "$(zoxide init zsh)"
bash
Add the following line to your ~/.bashrc:
eval "$(zoxide init bash)"
fish
Add the following line to your ~/.config/fish/config.fish:
zoxide init fish | source
POSIX
Add the following line to your shell's configuration file:
eval "$(zoxide init posix)"
NOTE: If you modify your PS1 at any point, you may need to re-run the above command. This is due
to the fact that the hook is stored in PS1, in order to be evaluated every time the prompt is
displayed.
NOTE: PWD hooks are currently not supported for POSIX shells.
Configuration
init flags
--no-define-aliases: don't define extra aliases likezi,zq,za, andzr--hook <HOOK>: change the event that adds a new entry to the database (default:prompt)none: never add entries (this will makezoxideuseless unless you manually configure a hook)prompt: add an entry at every promptpwd: add an entry whenever you change directories
Environment variables
$_ZO_DATA_DIR: directory wherezoxidewill store its data files (default: platform-specific; see thedirsdocumentation for more information)$_ZO_ECHO:zwill print the matched directory before navigating to it$_ZO_EXCLUDE_DIRS: list of directories separated by platform-specific characters (":" on Linux and macOS, and ";" on Windows) to be excluded from the database$_ZO_MAXAGE: sets the maximum total rank after which entries start getting deleted