lowfi

lowfi is a tiny rust app that serves a single purpose: play lofi. It'll do this as simply as it can: no albums, no ads, just lofi.

example image

Disclaimer

As of the 1.7.0 version of lowfi, all of the audio files embedded by default are from chillhop.

Why?

I really hate modern music platforms, and I wanted a small, "suckless" app that would just play random lofi without video.

It was also designed to be fairly resilient to inconsistent networks, and as such it buffers 5 whole songs at a time instead of parts of the same song.

See Scraping if you're interested in downloading the tracks. Beware, there's a lot of them.

Installing

Note

If you're interested in maintaining a package for lowfi on package managers such as homebrew and the like, open an issue.

Dependencies

You'll need Rust 1.74.0+.

On MacOS & Windows, no extra dependencies are needed.

On Linux, you'll also need openssl & alsa, as well as their headers.

  • alsa-lib on Arch, libasound2-dev on Ubuntu.
  • openssl on Arch, libssl-dev on Ubuntu.

Make sure to also install pulseaudio-alsa if you're using PulseAudio.

Cargo

The recommended installation method is to use cargo:

cargo install lowfi

# If you want MPRIS support.
cargo install lowfi --features mpris

and making sure $HOME/.cargo/bin is added to $PATH.

Release Binaries

If you're struggling or unwilling to use cargo, you can just download precompiled binaries from the latest release.

AUR

yay -S lowfi

openSUSE

zypper install lowfi

Debian

Note

This uses an unofficial Debian repository maintained by Dario Griffo.

curl -sS https://debian.griffo.io/3B9335DF576D3D58059C6AA50B56A1A69762E9FF.asc | gpg --dearmor --yes -o /etc/apt/trusted.gpg.d/debian.griffo.io.gpg
echo "deb https://debian.griffo.io//apt $(lsb_release -sc 2>/dev/null) main" | sudo tee /etc/apt/sources.list.d/debian.griffo.io.list
sudo apt install -y lowfi

Fedora (COPR)

Note

This uses an unofficial COPR repository by FurqanHun.

sudo dnf copr enable furqanhun/lowfi
sudo dnf install lowfi

Manual

This is good for debugging, especially in issues.

git clone https://github.com/talwat/lowfi
cd lowfi

# If you want an actual binary
cargo build --release --all-features
./target/release/lowfi

# If you just want to test
cargo run --all-features

Usage

lowfi

Yeah, that's it.

Controls

Key Function
s, n, l Skip Song
p, Space Play/Pause
+, =, k, Volume Up 10%
Volume Up 1%
-, _, j, Volume Down 10%
Volume Down 1%
q, CTRL+C Quit

Note

Besides its regular controls, lowfi offers compatibility with Media Keys and MPRIS (with tools like playerctl).

MPRIS is currently optional feature in cargo (enabled with --features mpris) due to it being only for Linux, as well as the fact that the main point of lowfi is it's unique & minimal interface.

Extra Flags

If you have something you'd like to tweak about lowfi, you use additional flags which slightly tweak the UI or behaviour of the menu. The flags can be viewed with lowfi help.

Flag Function
-a, --alternate Use an alternate terminal screen
-m, --minimalist Hide the bottom control bar
-b, --borderless Exclude borders in UI
-p, --paused Start lowfi paused
-d, --debug Include ALSA & other logs
-w, --width <WIDTH> Width of the player, from 0 to 32 [default: 3]
-t, --track-list <TRACK_LIST> Use a custom track list
-s, --buffer-size <BUFFER_SIZE> Internal song buffer size [default: 5]

Scraping

lowfi also has a scrape command which is usually not relevant, but if you're trying to download some files from Lofi Girls' website, it can be useful.

An example of scrape is as follows,

lowfi scrape --extension zip --include-full

where more information can be found by running lowfi help scrape.

Custom Track Lists

Note

Some nice users, especially danielwerg, have aleady made alternative track lists located in the data directory of this repo. You can use them with lowfi by using the --tracks flag.

Feel free to contribute your own list with a PR.

lowfi also supports custom track lists, although the default one from Lofi Girl is embedded into the binary.

To use a custom list, use the --tracks flag. This can either be a path to some file, or it could also be the name of a file (without the .txt extension) in the data directory.

Note

Data directories:

  • Linux - ~/.local/share/lowfi
  • macOS - ~/Library/Application Support/lowfi
  • Windows - %appdata%\Roaming\lowfi

For example, lowfi --tracks minipop would load ~/.local/share/lowfi/minipop.txt. Whereas if you did lowfi --tracks ~/Music/minipop.txt it would load from that specified directory.

All tracks must be in the MP3 format, unless lowfi has been compiled with the extra-audio-formats feature which includes support for some others.

The Format

In lists, the first line is what's known as the header, followed by the rest of the tracks. Each track will be first appended to the header, and then use that to download the track.

Note

lowfi will not put a / between the base & track for added flexibility, so for most cases you should have a trailing / in your header.

The exception to this is if the track name begins with a protocol like https://, in which case the base will not be prepended to it. If all of your tracks are like this, then you can put noheader as the first line and not have a header at all.

For example, in this list:

https://lofigirl.com/wp-content/uploads/
2023/06/Foudroie-Finding-The-Edge-V2.mp3
2023/04/2-In-Front-Of-Me.mp3
https://file-examples.com/storage/fe85f7a43b689349d9c8f18/2017/11/file_example_MP3_1MG.mp3

lowfi would download these three URLs:

  • https://lofigirl.com/wp-content/uploads/2023/06/Foudroie-Finding-The-Edge-V2.mp3
  • https://file-examples.com/storage/fe85f7a43b689349d9c8f18/2017/11/file_example_MP3_1MG.mp3
  • https://lofigirl.com/wp-content/uploads/2023/04/2-In-Front-Of-Me.mp3

Additionally, you may also specify a custom display name for the track which is indicated by a !. For example, if you had an entry like this:

2023/04/2-In-Front-Of-Me.mp3!custom name

Then lowfi would download from the first section, and display the second as the track name.

You can also prepend file:// to the header track name, which will make lowfi treat it as a local file. This is useful if you want to use a local file as the base URL, such as:

file:///home/user/Music/
file.mp3
file:///home/user/Other Music/second-file.mp3

Further examples can be found in the data folder.

Description
No description provided
Readme MIT 2.4 MiB
Languages
Rust 99.9%
Shell 0.1%