[vlc-devel] [PATCH 4/7] playlist: cancel preparsing upon playback
Filip Roséen
filip at atch.se
Wed Mar 22 17:58:44 CET 2017
This will cancel any pending request for preparsing the relevant
playlist_item_t as preparsing the entity:
- is redundant since we are about to start playback,
- can remove metadata added during playback, and;
- can lead to duplicate entries in the playlist if the
playlist_item_t is a directory (as children are added each time
such entity is "played").
fixes: #17441
fixes: #17232
---
src/playlist/item.c | 2 +-
src/playlist/thread.c | 2 ++
2 files changed, 3 insertions(+), 1 deletion(-)
diff --git a/src/playlist/item.c b/src/playlist/item.c
index b166155387..9d77a663ad 100644
--- a/src/playlist/item.c
+++ b/src/playlist/item.c
@@ -776,7 +776,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
if( sys->b_preparse && !input_item_IsPreparsed( p_item->p_input )
&& (EMPTY_STR(psz_artist) || EMPTY_STR(psz_album)) )
libvlc_MetadataRequest( p_playlist->obj.libvlc, p_item->p_input, 0, -1,
- NULL );
+ p_item );
free( psz_artist );
free( psz_album );
}
diff --git a/src/playlist/thread.c b/src/playlist/thread.c
index 5e198a0a14..933244de75 100644
--- a/src/playlist/thread.c
+++ b/src/playlist/thread.c
@@ -205,6 +205,8 @@ static bool PlayItem( playlist_t *p_playlist, playlist_item_t *p_item )
assert( p_sys->p_input == NULL );
PL_UNLOCK;
+ libvlc_MetadataCancel( p_playlist->obj.libvlc, p_item );
+
input_thread_t *p_input_thread = input_Create( p_playlist, p_input, NULL,
p_sys->p_input_resource );
if( likely(p_input_thread != NULL) )
--
2.12.0
More information about the vlc-devel
mailing list