Documentation
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/you/Music/Jimi Hendrix/Are You Experienced/" (plays the \'Are you Experienced?\' album)
kew play "/home/you/Music/Jimi Hendrix/Are You Experienced/Purple Haze.flac" (plays Purple Haze)
kew play <album path> <album path> <song path> (kew play accepts multiple paths)
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/you/Music/" (changes the path)
Key Bindings
Basic
- Play/Enqueue/Dequeue: Enter or middle mouse.
- Toggle Play/Pause: Space, p or right mouse.
- Volume: + - (alt: = -).
- Switch Track: ← → (alt: h l).
- Switch View: F2-F6, (macOS/Android: Shift+z,+x,+c,+v,+b), Tab or click the footer.
- Stop: Alt+s.
- Cycle Color Modes: i.
- Cycle Themes: t.
- Clear Playlist: Backspace.
- Delete from Playlist: Del.
- Repeat: r.
- Shuffle: s.
- Quit: Esc or q.
Advanced
Library
- Update: u.
- Sort: o (by age/alhabetically).
Track View
- Cycle Visualizer Modes: v.
- ASCII Covers: b.
Playlist
- Save: x (places .m3u in your music folder, named after the first song).
- Move songs: f g.
- Jump to song: number + G or Enter.
General
- Lyrics View: m.
- Seek a and d or drag the progress bar.
- Previous View Shift+Tab.
- Add to Favorites: .. Play favorites with:
kew . - Notifications on/off: n.
Crossfade
- Always on/off: z.
- Quick: Shift+d.
- Medium: Shift+f.
- Slow: Shift+g.
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/ke wstaterc.
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.
Layouts
It’s possible to define your own layout in kew. How to make one is described in LAYOUTS-HOWTO.md
The layout used by kew is called current.layout.
Replace current.layout to change the layout. If breaking changes are introduced, current.layout will be renamed to current.layout.bak, before the new one is copied over.
Layouts are in ~/.config/kew/layouts (~/Library/Preferences/kew/layouts on macOS).
If layouts aren’t working, try re-installing kew or running ‘sudo make install’ if you ran make yourself.
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/.
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 Are We Sixel Yet?.
Playlists
To load a playlist: type kew list <name>
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 .
Visualizations / Chroma
Starting with kew 4.0, you can add visualizations to kew by installing Chroma, an app by another developer.
You’ll need to install a specific commit, which is the latest one that works.
How to install Chroma:
git clone https://github.com/yuri-xyz/chroma.git
cd chroma
git checkout fb00b6e
cargo install --path . --features audio
Enable and cycle through the visualizations 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.
Chroma Configuration
You can customize Chroma’s behavior in your kewrc file:
- chromaPath: Path to a custom Chroma preset file. If set, this preset will be used instead of the built-in ones.
- chromaDevice: Specify the audio device for Chroma to capture from (e.g., "PipeWire Sound Server"). Use chroma –list-audio-devices, to find available devices.
[chroma]
chromaPath=/path/to/your/custom.preset
chromaDevice=PipeWire Sound Server
Scrobbling
kew’s private and offline nature means we don’t support Scrobbling/last.fm dire ctly. Instead tools such as PanoScrobbler are recommended. See: https://github.com/kawaiiDango/pano-scrobbler.
How to make sure kew is offline and private
kew itself does not have telemetry, it does not collect data and send to kew servers, it does not access the internet.
However, if Discord RPC is enabled and Discord is running, data about what you are listening to will end up on Discord servers.
To ensure the best privacy, two settings have to be set as following in the settings file kewrc:
allowNotifications=0
discordRPCEnabled=0
in kewstaterc, make sure this is set:
allowNotifications=0
kewstaterc tracks in-app choices so if you press ‘n’ for toggling notifications, the value will change.
Notifications means desktop notifications (MPRIS/DBUS) which is local, but is broadcast to other apps on your machine that are listening. It’s generally not logged unless an app on your machine that is listening logs it.
To force notifications to be always off, compile with:
make USE_DBUS=0 -j
To erase traces of your kew listening after uninstall, you need to delete the library.dat file in ~/.config/kew.
License
Licensed under GPLv2+. See LICENSE for more information.
