diff options
author | Christian Hesse <mail@eworm.de> | 2016-10-05 23:54:20 +0200 |
---|---|---|
committer | Christian Hesse <mail@eworm.de> | 2016-10-05 23:54:20 +0200 |
commit | 071597337d00070b44e67fcc1458bcf1f5f343a6 (patch) | |
tree | dccce6c41dbab8b9a78c777463377e70aeb04eac | |
parent | 90b01922ea7622de0eab2216912445040389ed5c (diff) | |
parent | 86aaf24691e1d9035a3db86e2df03c49e7675d6c (diff) | |
download | mpd-notification-071597337d00070b44e67fcc1458bcf1f5f343a6.tar.gz mpd-notification-071597337d00070b44e67fcc1458bcf1f5f343a6.tar.zst |
Merge branch 'config'
-rw-r--r-- | Makefile | 1 | ||||
-rw-r--r-- | README.md | 27 | ||||
-rw-r--r-- | mpd-notification.c | 15 | ||||
-rw-r--r-- | mpd-notification.h | 2 |
4 files changed, 40 insertions, 5 deletions
@@ -9,6 +9,7 @@ RM := rm # flags CFLAGS += -std=c11 -O2 -fPIC -Wall -Werror +CFLAGS += -liniparser CFLAGS += $(shell pkg-config --cflags --libs libmpdclient) CFLAGS += $(shell pkg-config --cflags --libs libnotify) LIBAV_CFLAGS := $(shell pkg-config --cflags --libs libavformat libavutil 2>/dev/null) @@ -20,6 +20,7 @@ Requirements To compile and run `mpd-notification` you need: +* [iniparser](http://ndevilla.free.fr/iniparser/) * [libav](https://libav.org/) or [ffmpeg](https://www.ffmpeg.org/) * [libnotify](http://library.gnome.org/devel/notification-spec/) * [libmpdclient](http://www.musicpd.org/libs/libmpdclient/) @@ -69,16 +70,32 @@ or `systemctl --user enable mpd-notification`. * *-v*: verbose output * *-V*: print version information +Configuration +------------- + +Configuration options can be read from a configuration file. `mpd` +tries to read `~/.local/mpd-notification.conf`, which is expected to +look like this: + + host = localhost + port = 6600 + music-dir = /srv/media/music/ + scale = 200 + timeout = 20 + +Unused options can be commented or removed completely. + Artwork ------- `mpd` does not provide any information where it finds its music files. To make `mpd-notification` display album artwork you need to tell it where to look for -artwork. You can do that by exporting `XDG_MUSIC_DIR` to your environment or by -specifying `-m` or `--music-dir` on the command line. `mpd-notification` reads -album artwork from `mp3` files, otherwise an image file containing the artwork -needs to be placed in the same directory as the media file and named -`cover.jpg`, `cover.png`, `folder.jpg` or `folder.png`. +artwork. You can do that by exporting `XDG_MUSIC_DIR` to your environment, by +specifying `-m` or `--music-dir` on the command line or by setting `music-dir` +in configuration file. `mpd-notification` reads album artwork from `mp3` +files, otherwise an image file containing the artwork needs to be placed +in the same directory as the media file and named `cover.jpg`, +`cover.png`, `folder.jpg` or `folder.png`. ### Upstream diff --git a/mpd-notification.c b/mpd-notification.c index f504836..543f60a 100644 --- a/mpd-notification.c +++ b/mpd-notification.c @@ -176,6 +176,7 @@ char * append_string(char * string, const char * format, const char delim, const /*** main ***/ int main(int argc, char ** argv) { + dictionary * ini = NULL; const char * title = NULL, * artist = NULL, * album = NULL; char * notifystr = NULL; GdkPixbuf * pixbuf = NULL; @@ -198,6 +199,17 @@ int main(int argc, char ** argv) { music_dir = getenv("XDG_MUSIC_DIR"); + /* parse config file */ + if (chdir(getenv("HOME")) == 0 && access(".config/mpd-notification.conf", R_OK) == 0 && + (ini = iniparser_load(".config/mpd-notification.conf")) != NULL) { + file_workaround = iniparser_getboolean(ini, ":notification-file-workaround", file_workaround); + mpd_host = iniparser_getstring(ini, ":host", mpd_host); + mpd_port = iniparser_getint(ini, ":port", mpd_port); + notification_timeout = iniparser_getint(ini, ":timeout", notification_timeout); + music_dir = iniparser_getstring(ini, ":music-dir", music_dir); + scale = iniparser_getint(ini, ":scale", scale); + } + /* get the verbose status */ while ((i = getopt_long(argc, argv, optstring, options_long, NULL)) != -1) { switch (i) { @@ -435,5 +447,8 @@ nonotification: g_object_unref(G_OBJECT(notification)); notify_uninit(); + if (ini != NULL) + iniparser_freedict(ini); + return EXIT_SUCCESS; } diff --git a/mpd-notification.h b/mpd-notification.h index 0cbd370..52fbec9 100644 --- a/mpd-notification.h +++ b/mpd-notification.h @@ -10,6 +10,8 @@ #define _GNU_SOURCE +#include <iniparser.h> + #include <mpd/client.h> #include <libnotify/notify.h> |