💥 Blazing fast terminal file manager written in Rust, based on async I/O.
Go to file
2024-02-03 01:09:26 +08:00
.github feat: support Windows ARM64 (#558) 2024-01-22 13:57:36 +08:00
assets feat: add desktop entry and logo (#534) 2024-01-18 00:46:04 +08:00
nix feat: add desktop entry and logo (#534) 2024-01-18 00:46:04 +08:00
scripts feat: add prepend_keymap and append_keymap for configuring mixing (#546) 2024-01-20 13:55:57 +08:00
snap feat: add support for snap packages (#531) 2024-01-18 00:20:45 +08:00
yazi-adaptor feat: preview image over SSH (#585) 2024-01-31 00:35:23 +08:00
yazi-config feat: plugin interface for key events via ya.which() (#617) 2024-02-03 01:09:26 +08:00
yazi-core feat: plugin interface for key events via ya.which() (#617) 2024-02-03 01:09:26 +08:00
yazi-fm feat: plugin interface for key events via ya.which() (#617) 2024-02-03 01:09:26 +08:00
yazi-plugin feat: plugin interface for key events via ya.which() (#617) 2024-02-03 01:09:26 +08:00
yazi-scheduler feat: make trash crate optional on Android (#600) 2024-01-31 21:54:19 +08:00
yazi-shared feat: plugin interface for key events via ya.which() (#617) 2024-02-03 01:09:26 +08:00
.envrc refactor(nix): add shell completion and avoid impure (#293) 2023-10-22 08:10:53 +08:00
.gitignore chore: ignore configuration of editor (#322) 2023-10-26 23:02:37 +08:00
Cargo.lock perf: read directory in bulk in the background at startup (#599) 2024-01-31 01:22:55 +08:00
Cargo.toml feat: add more optimization options (#377) 2023-11-18 11:44:43 +08:00
cspell.json feat: support unyank (#313) 2024-01-31 21:53:30 +08:00
flake.lock fix: catchup with the latest stable Rust (#409) 2023-11-29 20:37:10 +08:00
flake.nix fix: catchup with the latest stable Rust (#409) 2023-11-29 20:37:10 +08:00
LICENSE fix: typo of LICENSE file (#201) 2023-09-21 23:11:51 +08:00
README.md perf: read directory in bulk in the background at startup (#599) 2024-01-31 01:22:55 +08:00
rustfmt.toml chore: add rustfmt.toml 2023-08-08 21:02:56 +08:00

Yazi - Blazing Fast Terminal File Manager

Yazi (means "duck") 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.

💡 A new article explaining its internal workings: Why is Yazi Fast?

  • 🚀 Full Asynchronous Support: All I/O operations are asynchronous, CPU tasks are spread across multiple threads, making the most of available resources.
  • 💪 Powerful Async Task Scheduling and Management: Provides real-time progress updates, task cancellation, and internal task priority assignment.
  • 🖼️ Built-in Support for Multiple Image Protocols: Also integrated with Überzug++, covering almost all terminals.
  • 🌟 Built-in Code Highlighting and Image Decoding: Combined with the pre-loading mechanism, greatly accelerates image and normal file loading.
  • 🔌 Concurrent Plugin System: UI plugins (rewriting most of the UI), functional plugins (coming soon), custom previewer, and custom preloader; Just some pieces of Lua.
  • 🧰 Integration with fd, rg, fzf, zoxide
  • 💫 Vim-like input/select component, auto-completion for cd paths
  • 🏷️ Multi-Tab Support, Scrollable Preview (for videos, PDFs, archives, directories, code, etc.)
  • 🔄 Bulk Renaming, Visual Mode, File Chooser
  • 🎨 Theme System, Custom Layouts, Trash Bin, CSI u
  • ... and more!

https://github.com/sxyazi/yazi/assets/17523360/92ff23fa-0cd5-4f04-b387-894c12265cc7

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

Documentation

Discussion

Image Preview

Platform Protocol Support
kitty Kitty unicode placeholders Built-in
Konsole Kitty old protocol Built-in
iTerm2 Inline images protocol Built-in
WezTerm Inline images protocol Built-in
Mintty (Git Bash) Inline images protocol Built-in
foot Sixel graphics format Built-in
Ghostty Kitty old protocol Built-in
Black Box Sixel graphics format Built-in
Tabby Sixel graphics format Built-in
Hyper 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.

Here is a guide for tmux users: Image preview within tmux

TODO

See Feature requests for more details.

License

Yazi is MIT licensed. For more information check the LICENSE file.