sxyazi / yazi
π₯ Blazing fast terminal file manager written in Rust, based on async I/O.
AI Architecture Analysis
This repository is indexed by RepoMind. By analyzing sxyazi/yazi in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.
Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context on-demand, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.
Repository Summary (README)
Preview![]() Warp, built for coding with multiple AI agents Available for macOS, Linux and Windows | The most powerful Git client for Mac and Windows |
|---|
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/spotter/fetcher; Just some pieces of Lua.
- βοΈ Virtual Filesystem: Remote file management, custom search engines.
- π‘ 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, code, directories, etc.)
- π Bulk Renaming, Archive Extraction, Visual Mode, File Chooser, Git Integration, Mount Manager
- π¨ Theme System, Mouse Support, Trash Bin, Custom Layouts, CSI u, OSC 52
- ... and more!
https://github.com/sxyazi/yazi/assets/17523360/92ff23fa-0cd5-4f04-b387-894c12265cc7
Project status
Public beta, can be used as a daily driver.
Yazi is currently in heavy development, expect breaking changes.
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 (>= 0.28.0) | 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.10352.0) | Sixel graphics format | β Built-in |
| st with Sixel patch | Sixel graphics format | β Built-in |
| Warp (macOS/Linux only) | Inline images protocol | β Built-in |
| Tabby | Inline images protocol | β Built-in |
| VSCode | Inline images protocol | β Built-in |
| Rio | Inline images protocol | β Rio renders images at incorrect sizes |
| Black Box | Sixel graphics format | β Built-in |
| Bobcat | Inline images protocol | β Built-in |
| X11 / Wayland | Window system protocol | βοΈ Γberzug++ required |
| Fallback | ASCII art (Unicode block) | βοΈ Chafa required (>= 1.16.0) |
See https://yazi-rs.github.io/docs/image-preview for details.
Special Thanks
Thanks to RustRover team for providing open-source licenses to support the maintenance of Yazi.
Active code contributors can contact @sxyazi to get a license (if any are still available).
License
Yazi is MIT-licensed. For more information check the LICENSE file.
