fix a segfault when deleteing the last song in the playlist and sync'ing metadata from the player
git-svn-id: https://svn.musicpd.org/mpd/trunk@1306 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
c9c6f1f071
commit
8fca32b12d
@ -71,21 +71,21 @@ typedef struct _Playlist {
|
||||
unsigned long version;
|
||||
} Playlist;
|
||||
|
||||
Playlist playlist;
|
||||
int playlist_state = PLAYLIST_STATE_STOP;
|
||||
int playlist_max_length;
|
||||
int playlist_stopOnError;
|
||||
int playlist_errorCount = 0;
|
||||
int playlist_queueError;
|
||||
int playlist_noGoToNext = 0;
|
||||
static Playlist playlist;
|
||||
static int playlist_state = PLAYLIST_STATE_STOP;
|
||||
static int playlist_max_length;
|
||||
static int playlist_stopOnError;
|
||||
static int playlist_errorCount = 0;
|
||||
static int playlist_queueError;
|
||||
static int playlist_noGoToNext = 0;
|
||||
|
||||
int playlist_saveAbsolutePaths;
|
||||
static int playlist_saveAbsolutePaths;
|
||||
|
||||
char * playlist_stateFile = NULL;
|
||||
static char * playlist_stateFile = NULL;
|
||||
|
||||
void swapOrder(int a, int b);
|
||||
int playPlaylistOrderNumber(FILE * fp, int orderNum);
|
||||
void randomizeOrder(int start, int end);
|
||||
static void swapOrder(int a, int b);
|
||||
static int playPlaylistOrderNumber(FILE * fp, int orderNum);
|
||||
static void randomizeOrder(int start, int end);
|
||||
|
||||
void incrPlaylistVersion() {
|
||||
static unsigned long max = ((unsigned long)1<<BITS_FOR_VERSION)-1;
|
||||
@ -93,6 +93,16 @@ void incrPlaylistVersion() {
|
||||
if(playlist.version>=max) playlist.version = 0;
|
||||
}
|
||||
|
||||
static void incrPlaylistCurrent() {
|
||||
if(playlist.current < 0) return;
|
||||
|
||||
if(playlist.current >= playlist.length-1) {
|
||||
if(playlist.repeat) playlist.current = 0;
|
||||
else playlist.current = -1;
|
||||
}
|
||||
else playlist.current++;
|
||||
}
|
||||
|
||||
void initPlaylist() {
|
||||
char * test;
|
||||
|
||||
@ -628,12 +638,15 @@ int deleteFromPlaylist(FILE * fp, int song) {
|
||||
playerStop(stderr);
|
||||
playlist_noGoToNext = 1;
|
||||
}
|
||||
else if(/*playlist_state!=PLAYLIST_STATE_STOP &&*/
|
||||
playlist.current>songOrder) {
|
||||
|
||||
if(playlist.current>=playlist.length) {
|
||||
incrPlaylistCurrent();
|
||||
}
|
||||
else if(playlist.current>songOrder) {
|
||||
playlist.current--;
|
||||
}
|
||||
|
||||
if(/*playlist_state!=PLAYLIST_STATE_STOP && */playlist.queued>songOrder) {
|
||||
if(playlist.queued>songOrder) {
|
||||
playlist.queued--;
|
||||
}
|
||||
|
||||
@ -745,7 +758,7 @@ void syncCurrentPlayerDecodeMetadata() {
|
||||
|
||||
if(!songPlayer) return;
|
||||
|
||||
if(playlist_state!=PLAYLIST_STATE_PLAY);
|
||||
if(playlist_state!=PLAYLIST_STATE_PLAY) return;
|
||||
|
||||
song = playlist.songs[playlist.order[playlist.current]];
|
||||
|
||||
@ -775,7 +788,7 @@ int currentSongInPlaylist(FILE * fp) {
|
||||
|
||||
syncPlaylistWithQueue(0);
|
||||
|
||||
if(playlist.current<playlist.length) {
|
||||
if(playlist.current>= 0 && playlist.current<playlist.length) {
|
||||
return playPlaylistOrderNumber(fp,playlist.current);
|
||||
}
|
||||
else return stopPlaylist(fp);;
|
||||
@ -783,16 +796,6 @@ int currentSongInPlaylist(FILE * fp) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
void incrPlaylistCurrent() {
|
||||
if(playlist.current >= playlist.length || (!playlist.repeat &&
|
||||
playlist.current == playlist.length-1))
|
||||
{
|
||||
playlist.current = -1;
|
||||
}
|
||||
else if(playlist.current == playlist.length-1) playlist.current = 0;
|
||||
else if(playlist.current >= 0) playlist.current++;
|
||||
}
|
||||
|
||||
int nextSongInPlaylist(FILE * fp) {
|
||||
if(playlist_state!=PLAYLIST_STATE_PLAY) return 0;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user