Awesome
The main branch is the upcoming v0.4 development version. Please see the shipped
tag for the stable version of Yazi.
For breaking changes, see Migrating to Yazi v0.4.0.
<br><br>
<div align="center"> <img src="assets/logo.png" alt="Yazi logo" width="20%"> </div>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++ and Chafa, 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, custom previewer/preloader/fetcher; Just some pieces of Lua.
- π‘ Data Distribution Service: Built on a client-server architecture (no additional server process required), integrated with a Lua-based publish-subscribe model, achieving cross-instance communication and state persistence.
- π¦ Package Manager: Install plugins and themes with one command, keeping them up to date, or pin them to a specific version.
- π§° Integration with ripgrep, fd, fzf, zoxide
- π« Vim-like input/pick/confirm/which/notify component, auto-completion for cd paths
- π·οΈ Multi-Tab Support, Cross-directory selection, Scrollable Preview (for videos, PDFs, archives, directories, code, etc.)
- π Bulk Renaming, Visual Mode, File Chooser
- π¨ Theme System, Mouse Support, Trash Bin, Custom Layouts, 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
- Discord Server (English mainly): https://discord.gg/qfADduSdJu
- Telegram Group (Chinese mainly): https://t.me/yazi_rs
Image Preview
Platform | Protocol | Support |
---|---|---|
kitty | Kitty unicode placeholders | β Built-in |
iTerm2 | Inline images protocol | β Built-in |
WezTerm | Inline images protocol | β Built-in |
Konsole | Kitty old protocol | β Built-in |
foot | Sixel graphics format | β Built-in |
Ghostty | Kitty unicode placeholders | β Built-in |
Windows Terminal (>= v1.22.2702.0) | Sixel graphics format | β Built-in |
st with Sixel patch | Sixel graphics format | β Built-in |
Tabby | Inline images protocol | β Built-in |
VSCode | Inline images protocol | β Built-in |
Rio | Inline images protocol | β Rio doesn't correctly clear images (#1786) |
Mintty (Git Bash) | Inline images protocol | β Built-in |
Black Box | Sixel graphics format | β Built-in |
Hyper | Inline images protocol | β Built-in |
X11 / Wayland | Window system protocol | βοΈ Γberzug++ required |
Fallback | ASCII art (Unicode block) | βοΈ Chafa required |
See https://yazi-rs.github.io/docs/image-preview for details.
<!-- Protocols --> <!-- Dependencies -->License
Yazi is MIT-licensed. For more information check the LICENSE file.