Read

June 14, 2026 · View on GitHub

dependency status

Read

I'm no longer going to maintain this package on the AUR and I am looking for a new maintainer. If you're interested, please create an issue here.

Edit: This doesn't apply to crates.io, i will still maintain crates io

rs-pug

No browser, no ads, no Electron. Search YouTube and SoundCloud, queue tracks, play local files — all from your terminal.

Built in Rust with mpv, yt-dlp, and ratatui. Requires mpv and yt-dlp installed.

Plugins, themes and EQ presets from the community: all-rspug · Discord

img img

Installation

# Arch
yay -S rs-pug-git

# crates.io
cargo install rs-pug

# manual
git clone https://github.com/JustRoccat/rs-pug && cd rs-pug
cargo build --release && ./target/release/rs-pug

Dependencies

Required:

  • mpv
  • yt-dlp

Optional:

  • mpv-mpris (for media key / playerctl support)

Keybinds

KeyAction
15Switch tabs
TabSwitch panel focus
j / kMove up / down
/Search
EnterPlay
SpacePause / Resume
n / pNext / Previous
mMute
rCycle repeat mode
cContext menu
vToggle flat/organized view (Local tab)
qQuit

Contri-pug-ting

  1. Fork the repo
  2. Install dependencies
  3. Smash your head against the keyboard (Rust can be like that)
  4. Open a pull request

Lua plugin PRs especially welcome — API reference in docs.md.

Mouse Support

  • Scroll Wheel: Scroll through search results, playlists, and the queue.
  • Left Click: Click on tab icons at the top to switch between views.

Smart Queue

In the Options tab, you can trigger the Smart Queue. This feature analyzes the currently playing song and automatically finds similar tracks from the same uploader or with similar titles to keep the music flowing.

Customization

Themes

rs-pug comes with several built-in themes: dark (default), light, nord, gruvbox, and mono.

You can add your own themes by creating .json files in ~/.config/rs-pug/themes/.

Example mytheme.json:

{
  "text": [255, 255, 255],
  "dim": [100, 100, 100],
  "muted": [150, 150, 150],
  "info": [0, 255, 255],
  "warn": [255, 255, 0],
  "ok": [0, 255, 0],
  "primary": [255, 0, 255],
  "accent2": [200, 0, 200],
  "accent3": [100, 0, 100]
}

EQ Presets

Your custom EQ presets are stored as .json files in ~/.config/rs-pug/eqpresets/.

Local Music

By default, rs-pug scans ~/.config/rs-pug/music-local/. You can change this or add more directories in the Options tab. The app supports natural sorting and metadata extraction.

Playlists & Storage

Data is stored in a SQLite database at ~/.config/rs-pug/pug.db. Legacy JSON files are automatically migrated on first run.

  • Import path: ~/.config/rs-pug/import_playlist.json
  • Export path: ~/.config/rs-pug/exports/<playlist_name>.json

Plugins (Lua)

Drop Lua scripts into ~/.config/rs-pug/plugins/. They are loaded automatically and can react to keys, search queries, and playback events. See docs.md for the full API reference.

Lua plugins that change the stock UI are opt-in. Add this to ~/.config/rs-pug/config.toml to enable the new UI hooks (on_ui_config, on_ui_sections, on_ui_update, and on_ui_inject):

[lua]
allow-lua-ui-changes = true

The default is false, so legacy plugins using on_key, on_event, on_tabs, or on_ui_panels continue to work unchanged. When UI customization is enabled, plugin load/hook/layout issues are captured as non-fatal warnings and shown in the statusbar instead of crashing the app.

Downloading music

You can now download music using context menu

Configuration

Config file path: ~/.config/rs-pug/config.toml.

License

MIT

gif