2023-07-08 14:46:43 +03: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 configurable file management experience.
2023-07-19 04:06:42 +03:00
https://github.com/sxyazi/yazi/assets/17523360/740a41f4-3d24-4287-952c-3aec51520a32
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
## Installation
Before getting started, ensure that the following dependencies are installed on your system:
2023-07-15 16:24:12 +03:00
- nerd-fonts (required, for icons)
2023-07-08 14:46:43 +03:00
- jq (optional, for JSON preview)
2023-07-17 13:06:07 +03:00
- unar (optional, for archive preview)
2023-07-08 14:46:43 +03:00
- ffmpegthumbnailer (optional, for video thumbnails)
2023-07-09 14:12:58 +03:00
- fd (optional, for file searching)
2023-07-12 14:33:23 +03:00
- rg (optional, for file content searching)
- fzf (optional, for directory jumping)
2023-07-08 14:46:43 +03:00
- zoxide (optional, for directory jumping)
2023-07-20 09:12:37 +03:00
### Arch Linux
Install with paru or your favorite AUR helper:
2023-07-17 13:06:07 +03:00
```bash
2023-07-20 09:12:37 +03:00
paru -S yazi jq unarchiver ffmpegthumbnailer fd ripgrep fzf zoxide
```
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-07-20 09:12:37 +03:00
### macOS
2023-07-17 13:06:07 +03:00
2023-07-20 10:23:08 +03:00
Install the dependencies with Homebrew:
2023-07-20 09:12:37 +03:00
```bash
2023-07-17 13:06:07 +03:00
brew install jq unar ffmpegthumbnailer fd ripgrep fzf zoxide
brew tap homebrew/cask-fonts & & brew install --cask font-symbols-only-nerd-font
```
2023-07-30 06:53:40 +03:00
And download the latest release [from here ](https://github.com/sxyazi/yazi/releases ). 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-07-30 10:20:02 +03:00
### Nix
Nix users can install Yazi from [the NUR ](https://github.com/nix-community/nur-combined/blob/master/repos/xyenon/pkgs/yazi/default.nix ):
```bash
nix-env -iA nur.repos.xyenon.yazi
```
Or add the following to your configuration:
```nix
# configuration.nix
environment.systemPackages = with pkgs; [
nur.repos.xyenon.yazi
];
```
2023-07-20 09:12:37 +03:00
### Build from source
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-07-20 09:12:37 +03:00
## Usage
```bash
yazi
```
2023-08-02 05:40:40 +03:00
If you want to use your own config, copy the [config folder ](https://github.com/sxyazi/yazi/tree/main/config/preset ) to `~/.config/yazi` , and modify it as you like.
2023-07-19 14:42:59 +03:00
2023-07-30 06:53:40 +03:00
## Image Preview
2023-07-30 10:20:02 +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 |
2023-08-02 05:35:55 +03:00
| iTerm2 | [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 |
2023-07-30 10:20:02 +03:00
| 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-07-08 14:46:43 +03:00
## TODO
2023-07-17 19:34:58 +03:00
- [x] Add example config for general usage, currently please see my [another repo ](https://github.com/sxyazi/dotfiles/tree/main/yazi ) instead
2023-07-12 14:33:23 +03:00
- [x] Integration with fzf, zoxide for fast directory navigation
- [x] Integration with fd, rg for fuzzy file searching
2023-07-20 12:32:03 +03:00
- [x] Documentation of commands and options
2023-07-30 06:53:40 +03:00
- [x] Support for Überzug++ for image previews with X11/wayland environment
2023-07-09 14:12:58 +03:00
- [ ] Batch renaming support
2023-07-08 14:46:43 +03:00
## License
Yazi is MIT licensed.