This application works in extension to the Lollypop Music Player to allow users to search for and play songs from a command-line interface.
It works in two parts. The first one, the play python module, does most of the work. It accepts a series of search terms and then looks through a compatible SQLite3 database (the Lollypop music player database, by default) for the songs before launching the Lollypop music player.
The second part, the key listener, will listen for arguments for the python module from the keyboard without changing window focus, with audio feedback to ensure that the user knows that they are inputing into the program. This part will need to be run by a user added to the input
user group.
To anyone who finds this useful.
I've recently taken on a new job, and, due to the demands of a full-time developer job, I will no longer be able to maintain this project. I've had a lot of fun with it, but continuing it for the future is simply unfeasible.
With that said, this application is fully open-source, and anyone is available to freely use it, modify it, or maintain their own copy. The only thing I require is that the copyright, license, and source is preserved. I hope that you are able to make full use of this application.
May God bless you all,
Markil 3
Running make
will build the play_capture and play_repeat utilities.
To install, run make install
. This will install the utilities to $HOME/.local/bin and the python module to the standard installation directories via pip. For convenience, a "play" utility is installed to the user bin directory for running the python module.
By default, the Python module will pull music from the databases maintained by the Lollypop music player at ~/.local/share/lollypop (specifically, lollpop.db and playlists.db). However, you can supply your own and pass the directory containing the two databases via the --directory argument.
In either case, there must be two databases. The lollypop.db database will contain the tracks as well as additional information like albums and artists. There is also a playlists.db that contains playlist information.
commandlinePlay requires 4 tables from lollypop.db: tracks, albums, artists, and track_artists.
This row contains tracks.
column | type | description |
---|---|---|
id | INTEGER | The ID of the track. This is used to join this table with other tables. |
uri | TEXT | The URI to the file of the song. |
name | TEXT | The title of the song. |
album_id | INTEGER | The ID of the album the song belongs to. This corresponds to an album in the albums table. |
This row contains albums.
column | type | description |
---|---|---|
id | INTEGER | The ID of the album. This is used to join this table with tracks . |
name | TEXT | The name of the album. |
This table contains artists, with each row being an artist.
column | type | description |
---|---|---|
id | INTEGER | The ID of the artist. This is used to join this table with track_artists . |
name | TEXT | The name of the artist. |
This table joins tracks and artists, with each row being an artist that contributed to a song.
column | type | description |
---|---|---|
track_id | INTEGER | The ID of a song. This is used to join this table with tracks . |
artist_id | INTEGER | The ID of an artist that contributed to the song. This corresponds to an id in artists . |
This database contains playlist information. It is separate from the lollypop.db
database, as tracks are represented using only their file paths here.
This table contains all playlists, with each row being a playlist.
column | type | description |
---|---|---|
id | INTEGER | The ID of a playlist. |
name | TEXT | The name of a playlist. |
This table contains all tracks that are part of a playlist. Each row corresponds to a single track.
column | type | description |
---|---|---|
playlist_id | INT | The ID of the playlist that this track belongs to. This corresponds to a playlist in the playlists table. |
uri | TEXT | The link to the track as a URI path. |