-
-void E_(AddToPlaylist)( demux_t *p_demux, playlist_t *p_playlist,
- input_item_t *p_input,
- playlist_item_t *p_item, int i_parent_id )
-{
- // Only add to parent if specific parent requested or not current
- // playlist item
- if( i_parent_id > 0 || ! (
- p_playlist->status.p_item &&
- p_playlist->status.p_item->p_input ==
- ((input_thread_t *)p_demux->p_parent)->input.p_item ) )
- {
- playlist_NodeAddInput( p_playlist, p_input, p_item,
- PLAYLIST_APPEND, PLAYLIST_END );
- }
- // Else, add to both
- else
- {
- playlist_BothAddInput( p_playlist, p_input, p_item,
- PLAYLIST_APPEND, PLAYLIST_END );
- }
- input_ItemCopyOptions( p_item->p_input, p_input );
-}
-
-
-vlc_bool_t E_(FindItem)( demux_t *p_demux, playlist_t *p_playlist,
- playlist_item_t **pp_item )
-{
- vlc_bool_t b_play = var_CreateGetBool( p_demux, "playlist-autostart" );
-
- if( b_play && p_playlist->status.p_item &&
- p_playlist->status.p_item->p_input ==
- ((input_thread_t *)p_demux->p_parent)->input.p_item )
- {
- msg_Dbg( p_playlist, "starting playlist playback" );
- *pp_item = p_playlist->status.p_item;
- b_play = VLC_TRUE;
- }
- else
- {
- input_item_t *p_current = ( (input_thread_t*)p_demux->p_parent)->
- input.p_item;
- *pp_item = playlist_LockItemGetByInput( p_playlist, p_current );
- if( !*pp_item )
- {
- msg_Dbg( p_playlist, "unable to find item in playlist");
- }
- msg_Dbg( p_playlist, "not starting playlist playback");
- b_play = VLC_FALSE;
- }
- return b_play;
-}