GithubHelp home page GithubHelp logo

d3v3l0 / zoxide Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ajeetdsouza/zoxide

0.0 0.0 0.0 295 KB

A faster way to navigate your filesystem

License: MIT License

Rust 90.65% Shell 6.23% Python 3.12%

zoxide's Introduction

zoxide

crates.io .github/workflows/release.yml

A faster way to navigate your filesystem

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.

demo

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

On Arch Linux Arch Linux

yay -S zoxide

On CentOS

dnf copr enable atim/zoxide
dnf install zoxide

On Fedora 32+ Fedora

dnf install zoxide

On FreeBSD FreeBSD

pkg install zoxide

On macOS / Linux (via Homebrew / Linuxbrew) Homebrew

brew install zoxide

On macOS (via MacPorts) MacPorts

port install zoxide

On NixOS nixpkgs unstable

nix-env -iA nixpkgs.zoxide

Other (via Cargo) crates.io package

cargo install zoxide -f

Other (via precompiled binary) GitHub releases

Use the installation script:

curl --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/ajeetdsouza/zoxide/master/install.sh | sh

Alternatively, you can also download a precompiled binary from the releases page and add it to your PATH.

Step 2: Installing fzf (optional)

If you want to use interactive fuzzy selection, you will also need to install fzf.

Step 3: 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

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 shells

Add the following line to your shell's configuration file:

eval "$(zoxide init posix --hook prompt)"

The prompt hook is recommended for POSIX shells because the default pwd hook creates a temporary file for every session, which are only deleted upon reboot. If you do want to use pwd hooks instead, you may want to set up traps to perform a cleanup once the shell exits:

trap '_zoxide_cleanup' EXIT HUP KILL TERM
trap '_zoxide_cleanup; trap - INT; kill -s INT "$$"' INT
trap '_zoxide_cleanup; trap - QUIT; kill -s QUIT "$$"' QUIT

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.

PowerShell

Add the following line to your profile:

Invoke-Expression (& {
    $hook = if ($PSVersionTable.PSVersion.Major -lt 6) { 'prompt' } else { 'pwd' }
    (zoxide init --hook $hook powershell) -join "`n"
})

zsh

Add the following line to your ~/.zshrc:

eval "$(zoxide init zsh)"

Configuration

init flags

  • --cmd: change the z command (and corresponding aliases) to something else
  • --hook <HOOK>: change the event that adds a new entry to the database (default: pwd)
    • none: never add entries (this will make zoxide useless unless you manually configure a hook)
    • prompt: add an entry at every prompt
    • pwd: add an entry whenever the current directory is changed
  • --no-aliases: don't define extra aliases like zi, zq, za, and zr

Environment variables

  • $_ZO_DATA_DIR: directory where zoxide will store its data files (default: platform-specific; see the dirs documentation for more information)
  • $_ZO_ECHO: when set to 1, z will print the matched directory before navigating to it
  • $_ZO_EXCLUDE_DIRS: list of directories separated by platform-specific characters (":" on Linux/macOS, ";" on Windows) to be excluded from the database
  • $_ZO_FZF_OPTS: custom flags to pass to fzf
  • $_ZO_MAXAGE: sets the maximum total age after which entries start getting deleted
  • $_ZO_RESOLVE_SYMLINKS: when set to 1, z add will resolve symlinks.

zoxide's People

Contributors

ajeetdsouza avatar alin23 avatar aruhier avatar cole-h avatar crazystylus avatar cust0dian avatar erichdongubler avatar fsommar avatar goodsyntax808 avatar herbygillot avatar ignatenkobrain avatar kseistrup avatar lzybkr avatar mqnfred avatar passchaos avatar qmx avatar rif avatar skorokithakis avatar spencerwooo avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.