Music for the Shell. https://ko-fi.com/ravachol
  • C 96%
  • C++ 3%
  • Objective-C 0.5%
  • Makefile 0.4%
  • Nix 0.1%
Find a file
ravachol 4ef2489a66
Some checks failed
macOS Latest Build Check / macOS Build Check (push) Has been cancelled
Ubuntu Build Check / Ubuntu Build Check (push) Has been cancelled
macOS x86_64 Build Check / Build on Intel macOS (push) Has been cancelled
docs, better valgrind command example
2026-02-27 13:54:06 +01:00
.github workflow 2025-11-24 21:04:14 +01:00
docs docs, better valgrind command example 2026-02-27 13:54:06 +01:00
images Revert "readme" 2025-12-02 05:39:48 +01:00
include miniaudio revert previous commit, remove stop_at_shutdown() 2026-02-19 16:15:15 +01:00
locale added back chroma, random for now, to use press c in track view, b to disable 2025-12-25 15:56:38 +01:00
po added back chroma, random for now, to use press c in track view, b to disable 2025-12-25 15:56:38 +01:00
src Fixed updating library can cause segmentation fault 2026-02-27 00:47:16 +09:00
themes themepack txt 2025-11-28 19:34:41 +01:00
.clang-format rename local variables to snake_case 2025-10-27 03:28:50 +01:00
.clangd readme + changelog + themes 2025-10-05 01:25:23 +02:00
.editorconfig added authors.md, changelog.md, developers.md 2024-12-09 08:40:13 +01:00
.gitignore readme 2025-10-06 14:44:44 +02:00
flake.nix Removed install check in flake 2026-02-01 11:58:34 +01:00
kew.pot added back chroma, random for now, to use press c in track view, b to disable 2025-12-25 15:56:38 +01:00
LICENSE initial commit 2023-10-10 17:15:17 +02:00
Makefile Improve makefile macOS Now Playing 2026-02-23 02:52:22 +09:00
Makefile.i18n add japanese translation 2025-11-05 21:35:55 +01:00
play add script that creates a alias for kew named play, so you can type play nirvana. this was the original intent 2025-10-09 00:51:18 +02:00
PRIVACY_POLICY.md add PRIVACY_POLICY.md and TERMS.md 2026-02-16 14:15:37 +01:00
README.md docs, better valgrind command example 2026-02-27 13:54:06 +01:00
README_zh_CN.md docs(README_zh_CN.md): refine translation 2025-10-24 15:52:07 +08:00
TERMS.md add PRIVACY_POLICY.md and TERMS.md 2026-02-16 14:15:37 +01:00

kew Logo



License
English | 简体中文

kew (/kjuː/) is a terminal music player.

Features

  • Search a music library with partial titles from the command-line.
  • Creates a playlist automatically based on matched song, album or artist.
  • Private, no data is collected by kew*.
  • Music without distractions or algorithmic manipulation.
  • Full color covers in sixel-capable terminals.
  • Visualizer with various settings.
  • Edit the playlist by adding, removing and reordering songs.
  • Gapless playback.
  • Explore the library and enqueue files or folders.
  • Search your music library and add to the queue.
  • Supports MP3, FLAC, MPEG-4/M4A (AAC), OPUS, OGG, Webm and WAV audio.
  • Supports desktop events through MPRIS.
  • Supports lyrics through .lrc files, embedded SYLT (Mp3) or Vorbis comments (Flac,Ogg,Opus).
  • Use themes or colors derived from covers.

*kew displays it's status in Discord by default, but this can be disabled both in Discord and in the kew config file kewrc.

⚠️ This repository has moved to Codeberg!

Active development and issue tracking now happens at Codeberg. Please open new issues and pull requests there.

Installing

Packaging status

Install through your package manager or homebrew (macOS). If you can't find it on your distro, or you want the bleeding edge, follow the Manual Installation Instructions. For NixOS, there is a Nix Flake.

Usage

kew creates a playlist with the contents of the first directory or file whose name matches the arguments you provide in the command-line.

kew cure great

This creates and starts playing a playlist with 'The cure greatest hits' if it's in your music library.

It works best when your music library is organized this way:

artist folder->album folder(s)->track(s).

Example commands

kew (starting kew with no arguments opens the library view where you can choose what to play)

kew all (plays all songs, up to 50 000, in your library, shuffled)

kew albums (plays all albums, up to 2000, randomly one after the other)

kew moonlight son (finds and plays moonlight sonata)

kew moon (finds and plays moonlight sonata)

kew beet (finds and plays all music files under "beethoven" directory)

kew dir <album name> (sometimes, if names collide, it's necessary to specify it's a directory you want)

kew song <song> (or a song)

kew play "/home/joe/Musik/Fridge - (2007) The Sun/" (Plays this album, location can be anywhere)

kew play "/home/joe/Musik/moonlight sonata.flac" (Plays moonlight sonata, location can be anywhere)

kew play <album path> <album path> <song path> (play can take multiple album paths or song paths and add them all into temporary playlist)

kew list <playlist> (or a playlist)

kew theme midnight (sets the 'midnight.theme' theme).

kew shuffle <album name> (shuffles the playlist. shuffle needs to come first.)

kew artistA:artistB:artistC (plays all three artists, shuffled)

kew --help, -? or -h

kew --version or -v

kew --nocover

kew --noui (completely hides the UI)

kew -q <song>, --quitonstop (exits after finishing playing the playlist)

kew -e <song>, --exact (specifies you want an exact (but not case sensitive) match, of for instance an album)

kew . loads kew favorites.m3u

kew path "/home/joe/Musik/" (changes the path)

Key Bindings

Basic

  • Enter to play or enqueue/dequeue.
  • Space, p or right mouse to play or pause.
  • Use + (or =), - keys to adjust the volume.
  • Use , or h, l keys to switch tracks.
  • Alt+s to stop.
  • F2 or Shift+z (macOS/Android) to show/hide playlist view.
  • F3 or Shift+x (macOS/Android) to show/hide library view.
  • F4 or Shift+c (macOS/Android) to show/hide track view.
  • F5 or Shift+v (macOS/Android) to show/hide search view.
  • F6 or Shift+b (macOS/Android) to show/hide key bindings view.
  • i to cycle colors derived from kewrc, theme or track cover.
  • t to cycle themes.
  • Backspace to clear the playlist.
  • Delete to remove a single playlist entry.
  • r to cycle repeat settings (repeat, repeat list, off).
  • s to shuffle the playlist.

Advanced

  • u to update the library.

  • m show full page lyrics in track view. See Lyrics

  • v to toggle the visualizer.

  • b to toggle album covers drawn in ascii or as a normal image.

  • n to toggle notifications.

  • a to seek back. keep pressed for a longer duration, it executes the seek when you release the key.

  • d to seek forward. keep pressed for a longer duration, it executes the seek when you release the key.

  • x to save the currently loaded playlist to a m3u file in your music folder.

  • Tab to switch to next view.

  • Shift+Tab to switch to previous view.

  • f, g to move songs up or down the playlist.

  • number + G or Enter to go to specific song number in the playlist.

  • . to add currently playing song to kew favorites.m3u (run with "kew .").

  • Esc to quit.

Configuration

Linux: ~/.config/kew/

macOS: ~/Library/Preferences/kew/

Key bindings can be added like this:

bind = +, volUp, +5%

If you have an old install of kew, delete the kewrc file to make this style of bindings appear.

kew state (for settings that can be changed in-app) is kept in ~/.config/kew/kewstaterc.

If you change a setting in-app it will be tracked by kewstaterc and not kewrc.

kewrc is never changed by kew with the exception of when you run kew path.

If you delete your kewrc a new default one will be generated. You wont get newer config options listed in your config file unless you do this.

Themes

Press t to cycle available themes.

To set a theme from the command-line, run:

kew theme <themename> (ie 'kew theme midnight')

Put themes in ~/.config/kew/themes (~/Library/Preferences/kew/themes on macOS).

Do not edit the included themes as they are managed by kew. Instead make a copy with a different name and edit that.

Try the theme editor (by @bholroyd): https://bholroyd.github.io/Kew-tip/.

Visulizations / Chroma

Starting with kew 4.0, you can add visualizations to kew by installing Chroma:

https://github.com/yuri-xyz/chroma

Enable and cycle through them by pressing c in track view.

Disable by pressing b.



This works by kew being fed frames from Chroma and does not add bloat to kew.

If Colors or Graphics Look Wrong

Cycle i until they look right.

Press v to turn off visualizer.

Press b for ASCII covers.

A terminal emulator that can handle TrueColor and sixels is recommended. See Sixels in Terminal.

Lyrics

Lyrics can be read from a provided .lrc file that matches the audio file in name and content, from Vorbis comment metadata or from SYLT embedded tags on mp3 files.

Timestamped lyrics will be shown automatically in track view. Press m show full page lyrics.

Playlists

To load a playlist: type kew list

To export a playlist, press x. This will save a file in your music path with the name of the first song in the queue.

There is also a favorites playlist function:

Add current song: press .

To load 'kew list fav': kew .

Scrobbling

kew's private and offline nature means we don't support Scrobbling/last.fm directly. Instead tools such as PanoScrobbler are recommended. See: https://github.com/kawaiiDango/pano-scrobbler.

License

Licensed under GPL. See LICENSE for more information.

Star History

Star History Chart

Github Stars: GitHub stars

Codeberg Stars: Codeberg stars

Attributions

Attributions

kew makes use of the following great open source projects:

Chafa by Hans Petter Jansson - https://hpjansson.org/chafa/

Chroma by yuri-xyz - https://github.com/yuri-xyz/chroma

TagLib by TagLib Team - https://taglib.org/

Faad2 by fabian_deb, knik, menno - https://sourceforge.net/projects/faac/

FFTW by Matteo Frigo and Steven G. Johnson - https://www.fftw.org/

Libopus by Opus - https://opus-codec.org/

Libvorbis by Xiph.org - https://xiph.org/

Miniaudio by David Reid - https://github.com/mackron/miniaudio

Minimp4 by Lieff - https://github.com/lieff/minimp4

Nestegg by Mozilla - https://github.com/mozilla/nestegg

Img_To_Txt by Danny Burrows - https://github.com/danny-burrows/img_to_txt

TermBox2 (adapted for input handling only) - By nsf and Adam Saponara https://github.com/termbox/termbox2

Authors

See AUTHORS.

Contact

Comments? Suggestions? Send mail to kew-player@proton.me.