Commit 22b2b54f authored by Jakob Leben's avatar Jakob Leben

playlist: only install input item event callbacks on items under category root

parent 07e20e1b
...@@ -153,6 +153,7 @@ struct playlist_item_t ...@@ -153,6 +153,7 @@ struct playlist_item_t
int i_id; /**< Playlist item specific id */ int i_id; /**< Playlist item specific id */
uint8_t i_flags; /**< Flags */ uint8_t i_flags; /**< Flags */
playlist_t *p_playlist; /**< Parent playlist */ playlist_t *p_playlist; /**< Parent playlist */
bool b_input_item_observer;
}; };
#define PLAYLIST_SAVE_FLAG 0x0001 /**< Must it be saved */ #define PLAYLIST_SAVE_FLAG 0x0001 /**< Must it be saved */
......
...@@ -171,7 +171,7 @@ static void uninstall_input_item_observer( playlist_item_t * p_item ) ...@@ -171,7 +171,7 @@ static void uninstall_input_item_observer( playlist_item_t * p_item )
* Playlist item creation * Playlist item creation
*****************************************************************************/ *****************************************************************************/
playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist, playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist,
input_item_t *p_input ) input_item_t *p_input, bool install_observer )
{ {
playlist_item_t* p_item = malloc( sizeof( playlist_item_t ) ); playlist_item_t* p_item = malloc( sizeof( playlist_item_t ) );
if( !p_item ) if( !p_item )
...@@ -189,7 +189,9 @@ playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist, ...@@ -189,7 +189,9 @@ playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist,
p_item->pp_children = NULL; p_item->pp_children = NULL;
p_item->i_flags = 0; p_item->i_flags = 0;
p_item->p_playlist = p_playlist; p_item->p_playlist = p_playlist;
p_item->b_input_item_observer = install_observer;
if( install_observer )
install_input_item_observer( p_item ); install_input_item_observer( p_item );
return p_item; return p_item;
...@@ -218,6 +220,7 @@ int playlist_ItemRelease( playlist_item_t *p_item ) ...@@ -218,6 +220,7 @@ int playlist_ItemRelease( playlist_item_t *p_item )
* Most of the modules does that. * Most of the modules does that.
* *
* Who wants to add proper memory management? */ * Who wants to add proper memory management? */
if( p_item->b_input_item_observer )
uninstall_input_item_observer( p_item ); uninstall_input_item_observer( p_item );
ARRAY_APPEND( pl_priv(p_playlist)->items_to_delete, p_item); ARRAY_APPEND( pl_priv(p_playlist)->items_to_delete, p_item);
return VLC_SUCCESS; return VLC_SUCCESS;
...@@ -423,14 +426,14 @@ int playlist_AddInput( playlist_t* p_playlist, input_item_t *p_input, ...@@ -423,14 +426,14 @@ int playlist_AddInput( playlist_t* p_playlist, input_item_t *p_input,
PL_LOCK_IF( !b_locked ); PL_LOCK_IF( !b_locked );
/* Add to ONELEVEL */ /* Add to ONELEVEL */
p_item_one = playlist_ItemNewFromInput( p_playlist, p_input ); p_item_one = playlist_ItemNewFromInput( p_playlist, p_input, false );
if( p_item_one == NULL ) return VLC_ENOMEM; if( p_item_one == NULL ) return VLC_ENOMEM;
AddItem( p_playlist, p_item_one, AddItem( p_playlist, p_item_one,
b_playlist ? p_playlist->p_local_onelevel : b_playlist ? p_playlist->p_local_onelevel :
p_playlist->p_ml_onelevel , i_mode, i_pos ); p_playlist->p_ml_onelevel , i_mode, i_pos );
/* Add to CATEGORY */ /* Add to CATEGORY */
p_item_cat = playlist_ItemNewFromInput( p_playlist, p_input ); p_item_cat = playlist_ItemNewFromInput( p_playlist, p_input, true );
if( p_item_cat == NULL ) return VLC_ENOMEM; if( p_item_cat == NULL ) return VLC_ENOMEM;
AddItem( p_playlist, p_item_cat, AddItem( p_playlist, p_item_cat,
b_playlist ? p_playlist->p_local_category : b_playlist ? p_playlist->p_local_category :
...@@ -475,13 +478,13 @@ int playlist_BothAddInput( playlist_t *p_playlist, ...@@ -475,13 +478,13 @@ int playlist_BothAddInput( playlist_t *p_playlist,
PL_LOCK_IF( !b_locked ); PL_LOCK_IF( !b_locked );
/* Add to category */ /* Add to category */
p_item_cat = playlist_ItemNewFromInput( p_playlist, p_input ); p_item_cat = playlist_ItemNewFromInput( p_playlist, p_input, true );
if( p_item_cat == NULL ) return VLC_ENOMEM; if( p_item_cat == NULL ) return VLC_ENOMEM;
AddItem( p_playlist, p_item_cat, p_direct_parent, i_mode, i_pos ); AddItem( p_playlist, p_item_cat, p_direct_parent, i_mode, i_pos );
/* Add to onelevel */ /* Add to onelevel */
/** \todo make a faster case for ml import */ /** \todo make a faster case for ml import */
p_item_one = playlist_ItemNewFromInput( p_playlist, p_input ); p_item_one = playlist_ItemNewFromInput( p_playlist, p_input, false );
if( p_item_one == NULL ) return VLC_ENOMEM; if( p_item_one == NULL ) return VLC_ENOMEM;
p_up = p_direct_parent; p_up = p_direct_parent;
...@@ -536,7 +539,7 @@ playlist_item_t * playlist_NodeAddInput( playlist_t *p_playlist, ...@@ -536,7 +539,7 @@ playlist_item_t * playlist_NodeAddInput( playlist_t *p_playlist,
return NULL; return NULL;
PL_LOCK_IF( !b_locked ); PL_LOCK_IF( !b_locked );
p_item = playlist_ItemNewFromInput( p_playlist, p_input ); p_item = playlist_ItemNewFromInput( p_playlist, p_input, true );
if( p_item == NULL ) return NULL; if( p_item == NULL ) return NULL;
AddItem( p_playlist, p_item, p_parent, i_mode, i_pos ); AddItem( p_playlist, p_item, p_parent, i_mode, i_pos );
......
...@@ -109,7 +109,8 @@ void pl_Deactivate (libvlc_int_t *); ...@@ -109,7 +109,8 @@ void pl_Deactivate (libvlc_int_t *);
/* */ /* */
playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist, playlist_item_t *playlist_ItemNewFromInput( playlist_t *p_playlist,
input_item_t *p_input ); input_item_t *p_input,
bool install_observer );
/* Engine */ /* Engine */
playlist_item_t * get_current_status_item( playlist_t * p_playlist); playlist_item_t * get_current_status_item( playlist_t * p_playlist);
......
...@@ -69,7 +69,7 @@ playlist_item_t * playlist_NodeCreate( playlist_t *p_playlist, ...@@ -69,7 +69,7 @@ playlist_item_t * playlist_NodeCreate( playlist_t *p_playlist,
p_new_input = input_item_NewWithType( VLC_OBJECT(p_playlist), NULL, p_new_input = input_item_NewWithType( VLC_OBJECT(p_playlist), NULL,
psz_name, 0, NULL, 0, -1, ITEM_TYPE_NODE ); psz_name, 0, NULL, 0, -1, ITEM_TYPE_NODE );
p_item = playlist_ItemNewFromInput( p_playlist, p_item = playlist_ItemNewFromInput( p_playlist,
p_input ? p_input : p_new_input ); p_input ? p_input : p_new_input, p_input == NULL );
if( p_new_input ) if( p_new_input )
vlc_gc_decref( p_new_input ); vlc_gc_decref( p_new_input );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment