]> git.sesse.net Git - vlc/commitdiff
Fix #1487 - race condition
authorRafaël Carré <funman@videolan.org>
Tue, 6 May 2008 21:55:58 +0000 (23:55 +0200)
committerRafaël Carré <funman@videolan.org>
Tue, 6 May 2008 21:56:16 +0000 (23:56 +0200)
src/playlist/control.c
src/playlist/engine.c

index d07f5d140e5b88b5705ee7457a661f6b37f57015..bbaa74b0c4cff610d38ef149164dd7ed4b7503e7 100644 (file)
@@ -437,6 +437,7 @@ playlist_item_t * playlist_NextItem( playlist_t *p_playlist )
                                    p_playlist->status.p_item );
 
         p_playlist->i_current_index++;
+        assert( p_playlist->i_current_index <= p_playlist->current.i_size );
         if( p_playlist->i_current_index == p_playlist->current.i_size )
         {
             if( !b_loop || p_playlist->current.i_size == 0 ) return NULL;
index f39f60355ac6582e58dd205ffeb665b23dda1315..5e0cecd74d960f0c38df670d51fbbfa71fedaf52 100644 (file)
@@ -352,7 +352,9 @@ check_input:
          *  - Request, running requested -> start new item
          *  - Request, stopped requested -> collect garbage
         */
-        if( p_playlist->request.i_status != PLAYLIST_STOPPED )
+        int i_status = p_playlist->request.b_request ?
+            p_playlist->request.i_status : p_playlist->status.i_status;
+        if( i_status != PLAYLIST_STOPPED )
         {
             msg_Dbg( p_playlist, "starting new item" );
             p_item = playlist_NextItem( p_playlist );