A lightweight terminal music player with mpv engine and auto-setup
Project description
FreeThullu Music Player 🐙🎵
Version 1.0.7
A powerful, hybrid music player that summons your beats from the deep. Featuring a modern GUI (PyQt6) for desktop comfort and a robust CLI mode for terminal dwellers.
✨ Features
- Hybrid Interface:
- GUI: Modern Dark Theme, Tabbed Interface (Now Playing, Library, Search, Queue), and Animated Visuals.
- CLI: Lightweight, keyboard-driven terminal interface.
- Universal Playback:
- Local Library: Deep recursive scanning, instant filtering, and file management.
- Online Streaming: Seamless YouTube and SoundCloud (prefix
sc:) integration.
- Immersive Experience:
- Animated FreeThullu: Watch the Great Old One pulse to the rhythm.
- Synced Lyrics: Automatic fetching from LRCLib and Letras.mus.br.
- Smart Queue:
- Manage your playlist with ease.
- Context Menus: Right-click to add multiple items to the queue.
- Jump: Double-click any item in the queue to play immediately.
- Cross-Platform: Native support for Linux and Windows (with auto-mpv setup).
🚀 Installation
Via PIP
pip install cli-music-player-cthulhu
System Requirements
- Python 3.9+
- Linux: Requires
mpv(sudo apt install mpv/sudo pacman -S mpv). - Windows: Auto-downloads
mpvon first run.
🎮 Usage
🖥️ Graphical Interface (Recommended)
Launch the full experience:
musicplayer-gui
Controls:
- Navigation: Use tabs to switch views.
- Library: Type in the filter box. Press Enter to trigger a deep recursive search in subfolders.
- Search: Type queries for YouTube. Prefix with
sc:for SoundCloud. - Queueing: Select multiple items (Ctrl/Shift+Click) -> Right Click -> Add to Queue.
- Debug Mode: Run
musicplayer-gui --debugto see backend logs.
📟 Terminal Interface
Launch the lightweight TUI:
musicplayer
Controls: Space (Pause), / (Search), a (Queue), q (Quit).
📦 Building from Source
To build standalone executables (Linux/Windows):
-
Clone and Install Dependencies:
git clone https://github.com/thiagofmendonca/cli-music-player.git cd cli-music-player pip install . pip install pyinstaller
-
Build:
# Linux pyinstaller --noconfirm --onefile --windowed --name "FreeThulluPlayer" --add-data "musicplayer/assets:musicplayer/assets" --icon "musicplayer/assets/frame1.png" --hidden-import "musicplayer" run_gui.py # Windows (PowerShell) pyinstaller --noconfirm --onefile --windowed --name "FreeThulluPlayer" --add-data "musicplayer/assets;musicplayer/assets" --icon "musicplayer/assets/frame1.png" --hidden-import "musicplayer" run_gui.py
📜 License
GNU Affero General Public License v3.0 (AGPLv3)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cli_music_player_cthulhu-1.0.7.tar.gz.
File metadata
- Download URL: cli_music_player_cthulhu-1.0.7.tar.gz
- Upload date:
- Size: 521.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
df0291cdc43d9502d6707a9ba3ff2bd3a45cbb9d2290ce036cbb2db367fc4383
|
|
| MD5 |
efa0abefc1021b4ecd9f74365d2f1bc5
|
|
| BLAKE2b-256 |
a97d9a6f929fc03270055a660b675b93f025f05f4fd45ca313c109e223769cf9
|
Provenance
The following attestation bundles were made for cli_music_player_cthulhu-1.0.7.tar.gz:
Publisher:
python-publish.yml on thiagofmendonca/cli-music-player
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cli_music_player_cthulhu-1.0.7.tar.gz -
Subject digest:
df0291cdc43d9502d6707a9ba3ff2bd3a45cbb9d2290ce036cbb2db367fc4383 - Sigstore transparency entry: 836516027
- Sigstore integration time:
-
Permalink:
thiagofmendonca/cli-music-player@9e828b291c54d0bb7520f3204e941adb92043b79 -
Branch / Tag:
refs/tags/v1.0.7 - Owner: https://github.com/thiagofmendonca
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@9e828b291c54d0bb7520f3204e941adb92043b79 -
Trigger Event:
release
-
Statement type:
File details
Details for the file cli_music_player_cthulhu-1.0.7-py3-none-any.whl.
File metadata
- Download URL: cli_music_player_cthulhu-1.0.7-py3-none-any.whl
- Upload date:
- Size: 523.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e4bc318b8e4c7db935d9eb3f345f9e56d5e51c5ba1f13bfe112c07486fa41db0
|
|
| MD5 |
8848ff34e3e0859cc7a3306008193d36
|
|
| BLAKE2b-256 |
0784fd3d3799a9a94cd6d5653d753f44075e4b95882102b0c9192e7d914aa95a
|
Provenance
The following attestation bundles were made for cli_music_player_cthulhu-1.0.7-py3-none-any.whl:
Publisher:
python-publish.yml on thiagofmendonca/cli-music-player
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cli_music_player_cthulhu-1.0.7-py3-none-any.whl -
Subject digest:
e4bc318b8e4c7db935d9eb3f345f9e56d5e51c5ba1f13bfe112c07486fa41db0 - Sigstore transparency entry: 836516029
- Sigstore integration time:
-
Permalink:
thiagofmendonca/cli-music-player@9e828b291c54d0bb7520f3204e941adb92043b79 -
Branch / Tag:
refs/tags/v1.0.7 - Owner: https://github.com/thiagofmendonca
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@9e828b291c54d0bb7520f3204e941adb92043b79 -
Trigger Event:
release
-
Statement type: