2023-07-08 14:46:43 +03:00
## Yazi - ⚡️ Blazing Fast Terminal File Manager
2023-08-03 13:55:40 +03:00
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.
2023-07-08 14:46:43 +03:00
2023-09-13 14:49:45 +03:00
💫 A new article explaining its internal workings: [Why Yazi Fast? ](https://github.com/sxyazi/yazi/issues/143 )
2023-09-02 17:13:37 +03:00
- 🚀 **Full Asynchronous Support** : All I/O operations are asynchronous, CPU tasks are spread across multiple threads, making the most of available resources.
2023-09-12 17:05:28 +03:00
- 💪 **Powerful Async Task Scheduling and Management** : Provides real-time progress updates, task cancellation, and internal task priority assignment.
2023-09-03 07:06:45 +03:00
- 🖼️ **Built-in Support for Multiple Image Protocols** : Also integrated with Überzug++, covering almost all terminals.
2023-09-02 17:13:37 +03:00
- 🌟 **Built-in Code Highlighting and Image Encoding** : Combined with the pre-caching mechanism, greatly accelerates image and normal file loading.
- 🧰 Integration with fd, rg, fzf, zoxide
- 💫 Vim-like Input component, and Select component
2023-09-03 07:06:45 +03:00
- 🏷️ Multi-Tab Support, Scrollable Preview (for videos, PDFs, archives, directories, code, etc.)
- 🔄 Batch Renaming, Visual Mode, File Chooser
- 🎨 Theme System, Custom Layouts, Trash Bin, CSI u
- ... and more!
2023-09-02 17:13:37 +03:00
2023-09-11 17:41:28 +03:00
https://github.com/sxyazi/yazi/assets/17523360/d5d8427b-e0f3-4552-ae1a-553ba1a7d57e
2023-07-18 20:11:04 +03:00
2023-07-17 13:06:07 +03:00
⚠️ Note: Yazi is currently in active development and may be unstable. The API is subject to change without prior notice.
2023-07-08 14:46:43 +03:00
2023-09-01 10:52:48 +03:00
## Prerequisites
2023-07-08 14:46:43 +03:00
2023-09-01 10:52:48 +03:00
- nerd-fonts ([_optional_](https://github.com/sxyazi/yazi/wiki/I-don't-like-nerd%E2%80%90fonts!))
2023-08-09 14:12:15 +03:00
- 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)
2023-09-01 10:52:48 +03:00
## Installation
2023-08-09 14:12:15 +03:00
< details >
< summary > Arch Linux< / summary >
2023-07-20 09:12:37 +03:00
Install with paru or your favorite AUR helper:
2023-07-17 13:06:07 +03:00
```bash
2023-08-03 17:38:21 +03:00
paru -S yazi ffmpegthumbnailer unarchiver jq poppler fd ripgrep fzf zoxide
2023-07-20 09:12:37 +03:00
```
2023-08-02 09:49:40 +03:00
Or, you can replace `yazi` with `yazi-bin` package if you want pre-built binary instead of compiling by yourself.
2023-08-09 14:12:15 +03:00
< / details >
< details >
< summary > macOS< / summary >
2023-07-17 13:06:07 +03:00
2023-08-22 17:16:01 +03:00
Install Yazi and its dependencies with Homebrew:
2023-07-20 10:23:08 +03:00
2023-07-20 09:12:37 +03:00
```bash
2023-08-22 17:16:01 +03:00
brew install yazi ffmpegthumbnailer unar jq poppler fd ripgrep fzf zoxide
2023-07-17 13:06:07 +03:00
brew tap homebrew/cask-fonts & & brew install --cask font-symbols-only-nerd-font
```
2023-08-22 17:16:01 +03:00
If you prefer to use the most recent code, use `--HEAD` flag:
```bash
brew install yazi --HEAD
```
Or you can install Yazi via cargo:
2023-07-20 09:12:37 +03:00
```bash
cargo install --git https://github.com/sxyazi/yazi.git
```
2023-08-09 14:12:15 +03:00
< / details >
< details >
< summary > Nix< / summary >
2023-07-30 10:20:02 +03:00
2023-08-28 11:57:52 +03:00
The [Nix package of Yazi ](https://search.nixos.org/packages?channel=unstable&show=yazi ) is available. Nix users can install Yazi via:
2023-07-30 10:20:02 +03:00
```bash
2023-08-28 11:57:52 +03:00
# On NixOS:
nix-env -iA nixos.yazi
# On Non NixOS:
nix-env -iA nixpkgs.yazi
2023-07-30 10:20:02 +03:00
```
Or add the following to your configuration:
```nix
# configuration.nix
environment.systemPackages = with pkgs; [
2023-08-28 11:57:52 +03:00
yazi
2023-07-30 10:20:02 +03:00
];
```
2023-08-28 11:57:52 +03:00
You can also manage Yazi's configuration using the
[home-manager ](https://nix-community.github.io/home-manager/options.html#opt-programs.yazi.enable ).
2023-08-07 10:18:47 +03:00
2023-08-09 14:12:15 +03:00
< / details >
2023-09-01 10:52:48 +03:00
< details >
< summary > Windows< / summary >
See [Windows Installation Guide ](https://github.com/sxyazi/yazi/wiki/Windows-Installation-Guide ).
< / details >
2023-08-09 14:12:15 +03:00
< details >
< summary > Build from source< / summary >
2023-07-20 09:12:37 +03:00
2023-07-08 14:46:43 +03:00
Execute the following commands to clone the project and build Yazi:
```bash
git clone https://github.com/sxyazi/yazi.git
cd yazi
cargo build --release
```
2023-07-20 09:12:37 +03:00
Then, you can run:
2023-07-08 14:46:43 +03:00
```bash
./target/release/yazi
```
2023-08-09 14:12:15 +03:00
< / details >
2023-07-20 09:12:37 +03:00
## Usage
```bash
yazi
```
2023-08-09 14:12:15 +03:00
There is a wrapper of yazi, that provides the ability to change the current working directory when yazi exiting, feel free to use it:
2023-08-09 13:15:02 +03:00
```bash
function ya() {
2023-08-11 09:38:41 +03:00
tmp="$(mktemp -t "yazi-cwd.XXXXX")"
2023-08-09 13:15:02 +03:00
yazi --cwd-file="$tmp"
if cwd="$(cat -- "$tmp")" & & [ -n "$cwd" ] & & [ "$cwd" != "$PWD" ]; then
cd -- "$cwd"
fi
rm -f -- "$tmp"
}
```
2023-08-28 11:57:52 +03:00
## Configuration
If you want to use your own config, copy the [config folder ](./config/preset ) to `~/.config/yazi` , and modify it as you like.
[The documentation of all available options ](./config/docs )
2023-08-09 14:12:15 +03:00
## Discussion
- Discord Server (English mainly): https://discord.gg/qfADduSdJu
- Telegram Group (Chinese mainly): https://t.me/yazi_rs
2023-07-30 06:53:40 +03:00
## Image Preview
2023-09-02 07:55:24 +03:00
| Platform | Protocol | Support |
| ----------------- | -------------------------------------------------------------------------------- | --------------------- |
| Kitty | [Terminal graphics protocol ](https://sw.kovidgoyal.net/kitty/graphics-protocol/ ) | ✅ Built-in |
| WezTerm | [Terminal graphics protocol ](https://sw.kovidgoyal.net/kitty/graphics-protocol/ ) | ✅ Built-in |
| Konsole | [Terminal graphics protocol ](https://sw.kovidgoyal.net/kitty/graphics-protocol/ ) | ✅ Built-in |
| iTerm2 | [Inline images protocol ](https://iterm2.com/documentation-images.html ) | ✅ Built-in |
| Mintty (Git Bash) | [Inline images protocol ](https://iterm2.com/documentation-images.html ) | ✅ Built-in |
| Hyper | [Sixel graphics format ](https://www.vt100.net/docs/vt3xx-gp/chapter14.html ) | ✅ Built-in |
| foot | [Sixel graphics format ](https://www.vt100.net/docs/vt3xx-gp/chapter14.html ) | ✅ Built-in |
| Black Box | [Sixel graphics format ](https://www.vt100.net/docs/vt3xx-gp/chapter14.html ) | ✅ Built-in |
| X11 / Wayland | Window system protocol | ☑️ Überzug++ required |
| Fallback | [Chafa ](https://hpjansson.org/chafa/ ) | ☑️ Überzug++ required |
2023-07-30 06:53:40 +03:00
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++ ](https://github.com/jstkdng/ueberzugpp ) installed.
2023-09-13 17:44:27 +03:00
Here is a guide for tmux users: [Image preview within tmux ](https://github.com/sxyazi/yazi/wiki/Image-preview-within-tmux )
2023-07-08 14:46:43 +03:00
## TODO
2023-08-14 13:11:45 +03:00
See [Feature requests ](https://github.com/sxyazi/yazi/issues/51 ) for more details.
2023-07-08 14:46:43 +03:00
## License
Yazi is MIT licensed.