summaryrefslogtreecommitdiff
path: root/src/settings.c
diff options
context:
space:
mode:
authorLars-Dominik Braun <PromyLOPh@gmail.com>2008-08-19 10:35:06 +0200
committerLars-Dominik Braun <PromyLOPh@gmail.com>2008-08-19 10:35:06 +0200
commitb41828790865da036488dc21fe5f9fbc2001db0e (patch)
treeb95fd1f576d35ae04862604301f7ffdc78475630 /src/settings.c
parent69c04691c486aaf39cbe3c70e9e3cb47a2ad934a (diff)
downloadpianobar-b41828790865da036488dc21fe5f9fbc2001db0e.tar.gz
pianobar-b41828790865da036488dc21fe5f9fbc2001db0e.tar.bz2
pianobar-b41828790865da036488dc21fe5f9fbc2001db0e.zip
Allow key shortcut configuration via config file
Some code restructuring was made, too: - Move UI functions to ui.c and ui_act.c - Change default keys for loving and banning to + and -
Diffstat (limited to 'src/settings.c')
-rw-r--r--src/settings.c100
1 files changed, 100 insertions, 0 deletions
diff --git a/src/settings.c b/src/settings.c
index ae34078..e756364 100644
--- a/src/settings.c
+++ b/src/settings.c
@@ -20,12 +20,15 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
*/
+/* application settings */
+
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include "settings.h"
#include "config.h"
+#include "ui_act.h"
/* tries to guess your config dir; somehow conforming to
* http://standards.freedesktop.org/basedir-spec/basedir-spec-0.6.html
@@ -60,6 +63,15 @@ void BarSettingsInit (BarSettings_t *settings) {
}
void BarSettingsDestroy (BarSettings_t *settings) {
+ BarKeyShortcut_t *curShortcut, *lastShortcut;
+
+ while (curShortcut != NULL) {
+ lastShortcut = curShortcut;
+ curShortcut = curShortcut->next;
+ free (lastShortcut->description);
+ free (lastShortcut->configKey);
+ free (lastShortcut);
+ }
free (settings->controlProxy);
free (settings->username);
free (settings->password);
@@ -68,17 +80,79 @@ void BarSettingsDestroy (BarSettings_t *settings) {
memset (settings, 0, sizeof (*settings));
}
+void BarSettingsAppendKey (BarKeyShortcut_t *shortcut,
+ BarSettings_t *settings) {
+ BarKeyShortcut_t *tmp = calloc (1, sizeof (*tmp));
+
+ /* copy shortcut */
+ memcpy (tmp, shortcut, sizeof (*tmp));
+ if (shortcut->description != NULL) {
+ tmp->description = strdup (shortcut->description);
+ }
+ if (shortcut->configKey != NULL) {
+ tmp->configKey = strdup (shortcut->configKey);
+ }
+
+ if (settings->keys == NULL) {
+ settings->keys = tmp;
+ } else {
+ BarKeyShortcut_t *curShortcut = settings->keys;
+ while (curShortcut->next != NULL) {
+ curShortcut = curShortcut->next;
+ }
+ curShortcut->next = tmp;
+ }
+}
+
/* read app settings from file; format is: key = value\n
* @param where to save these settings
* @return nothing yet
*/
void BarSettingsRead (BarSettings_t *settings) {
+ /* FIXME: what is the max length of a path? */
char configfile[1024], key[256], val[256];
FILE *configfd;
+ BarKeyShortcut_t defaultKeys[] = {
+ {'?', BarUiActHelp, NULL, "act_help", NULL},
+ {'+', BarUiActLoveSong, "love current song", "act_songlove",
+ NULL},
+ {'-', BarUiActBanSong, "ban current song", "act_songban", NULL},
+ {'a', BarUiActAddMusic, "add music to current station",
+ "act_stationaddmusic", NULL},
+ {'c', BarUiActCreateStation, "create new station",
+ "act_stationcreate", NULL},
+ {'d', BarUiActDeleteStation, "delete current station",
+ "act_stationdelete", NULL},
+ {'e', BarUiActExplain, "explain why this song is played",
+ "act_songexplain", NULL},
+ {'g', BarUiActStationFromGenre, "add genre station",
+ "act_stationaddbygenre", NULL},
+ {'i', BarUiActSongInfo,
+ "print verbose information about current song",
+ "act_songinfo", NULL},
+ {'m', BarUiActMoveSong, "move song to different station",
+ "act_songmove", NULL},
+ {'n', BarUiActSkipSong, "next song", "act_songnext", NULL},
+ {'p', BarUiActPause, "pause/continue", "act_songpause", NULL},
+ {'q', BarUiActQuit, "quit", "act_quit", NULL},
+ {'r', BarUiActRenameStation, "rename current station",
+ "act_stationrename", NULL},
+ {'s', BarUiActSelectStation, "change station",
+ "act_stationchange", NULL},
+ {'t', BarUiActTempBanSong, "tired (ban song for 1 month)",
+ "act_songtired", NULL},
+ {'u', BarUiActPrintUpcoming, "upcoming songs", "act_upcoming",
+ NULL},
+ {'x', BarUiActSelectQuickMix, "select quickmix stations",
+ "act_stationselectquickmix", NULL},
+ };
+ BarKeyShortcut_t *curShortcut;
+ size_t i;
BarGetXdgConfigDir (PACKAGE "/config", configfile, sizeof (configfile));
if ((configfd = fopen (configfile, "r")) == NULL) {
printf ("config file at %s not found\n", configfile);
+ /* FIXME: what about setting default values? */
return;
}
@@ -120,6 +194,15 @@ void BarSettingsRead (BarSettings_t *settings) {
} else {
settings->disableSecureLogin = 0;
}
+ } else if (memcmp ("act_", key, 4) == 0) {
+ /* keyboard shortcuts */
+ for (i = 0; i < sizeof (defaultKeys) / sizeof (*defaultKeys);
+ i++) {
+ if (strcmp (defaultKeys[i].configKey, key) == 0) {
+ defaultKeys[i].key = val[0];
+ BarSettingsAppendKey (&defaultKeys[i], settings);
+ }
+ }
}
}
@@ -129,10 +212,27 @@ void BarSettingsRead (BarSettings_t *settings) {
settings->lastfmScrobblePercent > 100) {
settings->lastfmScrobblePercent = 50;
}
+
/* only scrobble tracks if username and password are set */
if (settings->lastfmUser != NULL && settings->lastfmPassword != NULL) {
settings->enableScrobbling = 1;
}
+ /* all actions available? append default actions if necessary */
+ for (i = 0; i < sizeof (defaultKeys) / sizeof (*defaultKeys); i++) {
+ char shortcutAvailable = 0;
+ curShortcut = settings->keys;
+ while (curShortcut != NULL) {
+ if (curShortcut->cmd == defaultKeys[i].cmd) {
+ shortcutAvailable = 1;
+ break;
+ }
+ curShortcut = curShortcut->next;
+ }
+ if (!shortcutAvailable) {
+ BarSettingsAppendKey (&defaultKeys[i], settings);
+ }
+ }
+
fclose (configfd);
}