From e81f683a1805871fa671485dc2a6327763ef1cf0 Mon Sep 17 00:00:00 2001 From: Romain Bignon Date: Mon, 30 Mar 2009 00:01:02 +0200 Subject: implemented the 'consume' mode Consume mode removes each song played --- src/playlist_state.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'src/playlist_state.c') diff --git a/src/playlist_state.c b/src/playlist_state.c index f5b1456d7..af0f7982b 100644 --- a/src/playlist_state.c +++ b/src/playlist_state.c @@ -35,6 +35,7 @@ #define PLAYLIST_STATE_FILE_RANDOM "random: " #define PLAYLIST_STATE_FILE_REPEAT "repeat: " #define PLAYLIST_STATE_FILE_SINGLE "single: " +#define PLAYLIST_STATE_FILE_CONSUME "consume: " #define PLAYLIST_STATE_FILE_CURRENT "current: " #define PLAYLIST_STATE_FILE_TIME "time: " #define PLAYLIST_STATE_FILE_CROSSFADE "crossfade: " @@ -74,6 +75,8 @@ playlist_state_save(FILE *fp, const struct playlist *playlist) playlist->queue.repeat); fprintf(fp, "%s%i\n", PLAYLIST_STATE_FILE_SINGLE, playlist->queue.single); + fprintf(fp, "%s%i\n", PLAYLIST_STATE_FILE_CONSUME, + playlist->queue.consume); fprintf(fp, "%s%i\n", PLAYLIST_STATE_FILE_CROSSFADE, (int)(getPlayerCrossFade())); fprintf(fp, "%s\n", PLAYLIST_STATE_FILE_PLAYLIST_BEGIN); @@ -146,6 +149,13 @@ playlist_state_restore(FILE *fp, struct playlist *playlist) setPlaylistSingleStatus(playlist, true); } else setPlaylistSingleStatus(playlist, false); + } else if (g_str_has_prefix(buffer, PLAYLIST_STATE_FILE_CONSUME)) { + if (strcmp + (&(buffer[strlen(PLAYLIST_STATE_FILE_CONSUME)]), + "1") == 0) { + setPlaylistConsumeStatus(playlist, true); + } else + setPlaylistConsumeStatus(playlist, false); } else if (g_str_has_prefix(buffer, PLAYLIST_STATE_FILE_CROSSFADE)) { setPlayerCrossFade(atoi (& -- cgit v1.2.3