aboutsummaryrefslogtreecommitdiffstats
path: root/src/playlist.c
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2009-01-23 00:10:38 +0100
committerMax Kellermann <max@duempel.org>2009-01-23 00:10:38 +0100
commit9da7ae02f06cfd90897b6e0c87619f546675b2e9 (patch)
tree0658fea6eaf9733870dc7218bc2694ac6dcf7aae /src/playlist.c
parent0d4319ed302d0cfd8afb4cc32caf727b23f25805 (diff)
downloadmpd-9da7ae02f06cfd90897b6e0c87619f546675b2e9.tar.gz
mpd-9da7ae02f06cfd90897b6e0c87619f546675b2e9.tar.xz
mpd-9da7ae02f06cfd90897b6e0c87619f546675b2e9.zip
playlist: restart playing in deleteFromPlaylist()
When a song is deleted, start playing the next song immediately, within deleteFromPlaylist(). This allows us to remove the ugly playlist_noGoToNext flag, and the currentSongInPlaylist() function.
Diffstat (limited to 'src/playlist.c')
-rw-r--r--src/playlist.c31
1 files changed, 9 insertions, 22 deletions
diff --git a/src/playlist.c b/src/playlist.c
index 9a6347770..2b8af836d 100644
--- a/src/playlist.c
+++ b/src/playlist.c
@@ -70,7 +70,6 @@ static Playlist playlist;
unsigned playlist_max_length;
static int playlist_stopOnError;
static unsigned playlist_errorCount;
-static int playlist_noGoToNext;
bool playlist_saveAbsolutePaths = DEFAULT_PLAYLIST_SAVE_ABSOLUTE_PATHS;
@@ -594,12 +593,19 @@ enum playlist_result deleteFromPlaylist(unsigned song)
/*if(playlist.current>=playlist.length) return playerStop(fd);
else return playPlaylistOrderNumber(fd,playlist.current); */
playerWait();
- playlist_noGoToNext = 1;
playlist.current = queue_next_order(&playlist.queue,
playlist.current);
if (playlist.current == (int)songOrder)
playlist.current = -1;
+
+ if (playlist.current >= 0)
+ /* play the song after the deleted one */
+ playPlaylistOrderNumber(playlist.current);
+ else
+ /* no songs left to play, stop playback
+ completely */
+ stopPlaylist();
}
if (!song_in_database(queue_get(&playlist.queue, song)))
@@ -645,7 +651,6 @@ void stopPlaylist(void)
playerWait();
playlist.queued = -1;
playlist.playing = false;
- playlist_noGoToNext = 0;
if (playlist.queue.random) {
unsigned current_position =
@@ -664,7 +669,6 @@ static void playPlaylistOrderNumber(int orderNum)
char *uri;
playlist.playing = true;
- playlist_noGoToNext = 0;
playlist.queued = -1;
song = queue_get_order(&playlist.queue, orderNum);
@@ -752,21 +756,6 @@ void syncPlayerAndPlaylist(void)
}
}
-static void currentSongInPlaylist(void)
-{
- if (!playlist.playing)
- return;
-
- playlist_stopOnError = 0;
-
- syncPlaylistWithQueue();
-
- if (playlist.current >= 0)
- playPlaylistOrderNumber(playlist.current);
- else
- stopPlaylist();
-}
-
void nextSongInPlaylist(void)
{
int next_order;
@@ -812,9 +801,7 @@ static void playPlaylistIfPlayerStopped(void)
|| error == PLAYER_ERROR_SYSTEM
|| playlist_errorCount >= queue_length(&playlist.queue))) {
stopPlaylist();
- } else if (playlist_noGoToNext)
- currentSongInPlaylist();
- else
+ } else
nextSongInPlaylist();
}
}