]> git.sesse.net Git - vlc/commitdiff
services_discovery: Make sure we kill also object created by the input.
authorPierre d'Herbemont <pdherbemont@videolan.org>
Tue, 22 Jul 2008 18:27:55 +0000 (20:27 +0200)
committerPierre d'Herbemont <pdherbemont@videolan.org>
Tue, 22 Jul 2008 18:28:13 +0000 (20:28 +0200)
This commit bother me. I don't see why we don't do it for all objects.

src/playlist/services_discovery.c

index 17bf55102b137ef3d627ce1d51e331ad6114e2d0..a4670e4f9b6da1e43578214d0868f2bef96f285f 100644 (file)
@@ -123,9 +123,21 @@ int services_discovery_Start ( services_discovery_t * p_sd )
 /***********************************************************************
  * Stop
  ***********************************************************************/
+static void ObjectKillChildrens( vlc_object_t *p_obj )
+{
+    vlc_list_t *p_list;
+    int i;
+    vlc_object_kill( p_obj );
+
+    p_list = vlc_list_children( p_obj );
+    for( i = 0; i < p_list->i_count; i++ )
+        ObjectKillChildrens( p_list->p_values[i].p_object );
+    vlc_list_release( p_list );
+}
+
 void services_discovery_Stop ( services_discovery_t * p_sd )
 {
-    vlc_object_kill( p_sd );
+    ObjectKillChildrens( p_sd );
     if( p_sd->pf_run ) vlc_thread_join( p_sd );
 
     module_Unneed( p_sd, p_sd->p_module );