💥 Blazing fast terminal file manager written in Rust, based on async I/O.
Go to file
2023-08-22 22:16:01 +08:00
adaptor feat: add doNotMoveCursor to ensure consistent behavior of WezTerm across all platforms 2023-08-20 16:41:48 -07:00
app feat: custom manager layout (#76) 2023-08-20 10:39:05 +08:00
config fix: don't follow the symbolic on Linux (#77) 2023-08-20 21:44:39 +08:00
core fix: don't follow the symbolic on Linux (#77) 2023-08-20 21:44:39 +08:00
shared feat: prepare for Windows (#44) 2023-08-19 11:10:26 +08:00
.gitignore refactor: use workspace to speed up builds (#13) 2023-08-02 10:29:49 +08:00
build.sh feat: prepare for Windows (#44) 2023-08-19 11:10:26 +08:00
Cargo.lock feat: windows clipboard support (#75) 2023-08-20 08:24:41 +08:00
Cargo.toml refactor: use workspace to speed up builds (#13) 2023-08-02 10:29:49 +08:00
cspell.json feat: add xclip and xsel support (#74) 2023-08-20 01:50:03 +08:00
LICENCE first commit 2023-07-08 19:46:43 +08:00
README.md docs: install with Homebrew (#80) 2023-08-22 22:16:01 +08:00
rustfmt.toml chore: add rustfmt.toml 2023-08-08 21:02:56 +08:00

Yazi - Blazing Fast Terminal File Manager

Yazi ("duck" in Chinese) is a terminal file manager written in Rust, based on non-blocking async I/O. It aims to provide an efficient, user-friendly, and customizable file management experience.

https://github.com/sxyazi/yazi/assets/17523360/740a41f4-3d24-4287-952c-3aec51520a32

⚠️ Note: Yazi is currently in active development and may be unstable. The API is subject to change without prior notice.

Installation

Before getting started, ensure that the following dependencies are installed on your system:

  • nerd-fonts (required)
  • ffmpegthumbnailer (optional, for video thumbnails)
  • unar (optional, for archive preview)
  • jq (optional, for JSON preview)
  • poppler (optional, for PDF preview)
  • fd (optional, for file searching)
  • rg (optional, for file content searching)
  • fzf (optional, for directory jumping)
  • zoxide (optional, for directory jumping)
Arch Linux

Install with paru or your favorite AUR helper:

paru -S yazi ffmpegthumbnailer unarchiver jq poppler fd ripgrep fzf zoxide

Or, you can replace yazi with yazi-bin package if you want pre-built binary instead of compiling by yourself.

macOS

Install Yazi and its dependencies with Homebrew:

brew install yazi ffmpegthumbnailer unar jq poppler fd ripgrep fzf zoxide
brew tap homebrew/cask-fonts && brew install --cask font-symbols-only-nerd-font

If you prefer to use the most recent code, use --HEAD flag:

brew install yazi --HEAD

Or you can install Yazi via cargo:

cargo install --git https://github.com/sxyazi/yazi.git
Nix

Nix users can install Yazi from the NUR:

nix-env -iA nur.repos.xyenon.yazi

Or add the following to your configuration:

# configuration.nix
environment.systemPackages = with pkgs; [
  nur.repos.xyenon.yazi
];

If you prefer to use the most recent code, use nur.repos.xyenon.yazi-unstable instead.

Build from source

Execute the following commands to clone the project and build Yazi:

git clone https://github.com/sxyazi/yazi.git
cd yazi
cargo build --release

Then, you can run:

./target/release/yazi

Usage

yazi

If you want to use your own config, copy the config folder to ~/.config/yazi, and modify it as you like.

There is a wrapper of yazi, that provides the ability to change the current working directory when yazi exiting, feel free to use it:

function ya() {
	tmp="$(mktemp -t "yazi-cwd.XXXXX")"
	yazi --cwd-file="$tmp"
	if cwd="$(cat -- "$tmp")" && [ -n "$cwd" ] && [ "$cwd" != "$PWD" ]; then
		cd -- "$cwd"
	fi
	rm -f -- "$tmp"
}

Discussion

Image Preview

Platform Protocol Support
Kitty Terminal graphics protocol Built-in
WezTerm Terminal graphics protocol Built-in
Konsole Terminal graphics protocol Built-in
iTerm2 Inline images protocol Built-in
Hyper Sixel graphics format Built-in
foot Sixel graphics format Built-in
X11 / Wayland Window system protocol ☑️ Überzug++ required
Fallback Chafa ☑️ Überzug++ required

Yazi automatically selects the appropriate preview method for you, based on the priority from top to bottom. That's relying on the $TERM, $TERM_PROGRAM, and $XDG_SESSION_TYPE variables, make sure you don't overwrite them by mistake!

For instance, if your terminal is Alacritty, which doesn't support displaying images itself, but you are running on an X11/Wayland environment, it will automatically use the "Window system protocol" to display images -- this requires you to have Überzug++ installed.

TODO

See Feature requests for more details.

License

Yazi is MIT licensed.