πŸ“¦ sxyazi / yazi

πŸ’₯ Blazing fast terminal file manager written in Rust, based on async I/O.

β˜… 31.7k stars β‘‚ 699 forks πŸ‘ 31.7k watching βš–οΈ MIT License
androidasyncioclicommand-lineconcurrencycross-platformdeveloper-toolsfile-explorerfile-managerfilesystemlinuxmacosneovimproductivityrustterminaltuivimwindows
πŸ“₯ Clone https://github.com/sxyazi/yazi.git
HTTPS git clone https://github.com/sxyazi/yazi.git
SSH git clone git@github.com:sxyazi/yazi.git
CLI gh repo clone sxyazi/yazi
sxyazi sxyazi fix: make environment detection work on WSL 2 (#3587) ca4cc59 1 days ago πŸ“ History
πŸ“‚ main View all commits β†’
πŸ“ .cargo
πŸ“ .github
πŸ“ assets
πŸ“ nix
πŸ“ scripts
πŸ“ snap
πŸ“ yazi-actor
πŸ“ yazi-adapter
πŸ“ yazi-binding
πŸ“ yazi-boot
πŸ“ yazi-build
πŸ“ yazi-cli
πŸ“ yazi-codegen
πŸ“ yazi-config
πŸ“ yazi-core
πŸ“ yazi-dds
πŸ“ yazi-ffi
πŸ“ yazi-fm
πŸ“ yazi-fs
πŸ“ yazi-macro
πŸ“ yazi-packing
πŸ“ yazi-parser
πŸ“ yazi-plugin
πŸ“ yazi-proxy
πŸ“ yazi-scheduler
πŸ“ yazi-sftp
πŸ“ yazi-shared
πŸ“ yazi-shim
πŸ“ yazi-term
πŸ“ yazi-vfs
πŸ“ yazi-watcher
πŸ“ yazi-widgets
πŸ“„ .envrc
πŸ“„ .gitignore
πŸ“„ .luarc.json
πŸ“„ Cargo.lock
πŸ“„ Cargo.toml
πŸ“„ CHANGELOG.md
πŸ“„ CONTRIBUTING.md
πŸ“„ cspell.json
πŸ“„ flake.lock
πŸ“„ flake.nix
πŸ“„ LICENSE
πŸ“„ LICENSE-ICONS
πŸ“„ README.md
πŸ“„ rustfmt.toml
πŸ“„ stylua.toml
πŸ“„ README.md
Special thanks to:
Warp sponsorship
Warp, built for coding with multiple AI agents
Available for macOS, Linux 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

  • Usage: https://yazi-rs.github.io/docs/installation
  • Features: https://yazi-rs.github.io/features

Discussion

  • Discord Server (English mainly): https://discord.gg/qfADduSdJu
  • Telegram Group (Chinese mainly): https://t.me/yazi_rs

Image Preview

PlatformProtocolSupport
kitty (>= 0.28.0)Kitty unicode placeholdersβœ… Built-in
iTerm2Inline images protocolβœ… Built-in
WezTermInline images protocolβœ… Built-in
KonsoleKitty old protocolβœ… Built-in
footSixel graphics formatβœ… Built-in
GhosttyKitty unicode placeholdersβœ… Built-in
Windows Terminal (>= v1.22.10352.0)Sixel graphics formatβœ… Built-in
st with Sixel patchSixel graphics formatβœ… Built-in
Warp (macOS/Linux only)Inline images protocolβœ… Built-in
TabbyInline images protocolβœ… Built-in
VSCodeInline images protocolβœ… Built-in
RioInline images protocol❌ Rio renders images at incorrect sizes
Black BoxSixel graphics formatβœ… Built-in
BobcatInline images protocolβœ… Built-in
X11 / WaylandWindow system protocolβ˜‘οΈ Überzug++ required
FallbackASCII art (Unicode block)β˜‘οΈ Chafa required
See https://yazi-rs.github.io/docs/image-preview for details.

Special Thanks

RustRover logo

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.