]> git.sesse.net Git - vlc/commitdiff
Replace intf_StopThread() with intf_DestroyAll()
authorRémi Denis-Courmont <remi@remlab.net>
Sat, 23 May 2009 17:45:24 +0000 (20:45 +0300)
committerRémi Denis-Courmont <remi@remlab.net>
Sat, 23 May 2009 18:14:09 +0000 (21:14 +0300)
include/vlc_interface.h
src/interface/interface.c
src/libvlc.c
src/libvlc.h
src/libvlccore.sym

index e368d0bad9aea2aeb64bc3843952f7d62ce6099f..62def6425496dcd124d77e77a17c27fb09d8e2f3 100644 (file)
@@ -100,7 +100,6 @@ struct intf_dialog_args_t
  *****************************************************************************/
 VLC_EXPORT( int, intf_Create, ( vlc_object_t *, const char * ) );
 #define intf_Create(a,b) intf_Create(VLC_OBJECT(a),b)
-VLC_EXPORT( void,              intf_StopThread, ( intf_thread_t * ) );
 
 #define intf_Eject(a,b) __intf_Eject(VLC_OBJECT(a),b)
 VLC_EXPORT( int, __intf_Eject, ( vlc_object_t *, const char * ) );
index d2fb15426e7c2841b96743c26bc0498e5c389bf8..b492efb61131b76d1499dc84dd7ea8960cc12f66 100644 (file)
@@ -58,20 +58,6 @@ static void * MonitorLibVLCDeath( vlc_object_t *p_this );
 static int AddIntfCallback( vlc_object_t *, char const *,
                             vlc_value_t , vlc_value_t , void * );
 
-/**
- * Destroy the interface after the main loop endeed.
- *
- * @param p_obj: the interface thread
- */
-static void intf_Destroy( vlc_object_t *obj )
-{
-    intf_thread_t *p_intf = (intf_thread_t *)obj;
-
-    free( p_intf->psz_intf );
-    config_ChainDestroy( p_intf->p_cfg );
-}
-
-
 #undef intf_Create
 /**
  * Create and start an interface.
@@ -116,7 +102,6 @@ int intf_Create( vlc_object_t *p_this, const char *psz_module )
 
     /* Attach interface to its parent object */
     vlc_object_attach( p_intf, p_this );
-    vlc_object_set_destructor( p_intf, intf_Destroy );
 #if defined( __APPLE__ ) || defined( WIN32 )
     p_intf->b_should_run_on_first_thread = false;
 #endif
@@ -134,8 +119,7 @@ int intf_Create( vlc_object_t *p_this, const char *psz_module )
     if( p_intf->p_module == NULL )
     {
         msg_Err( p_intf, "no suitable interface module" );
-        vlc_object_release( p_intf );
-        return VLC_EGENERIC;
+        goto error;
     }
 
     if( p_intf->pf_run == NULL )
@@ -150,19 +134,12 @@ int intf_Create( vlc_object_t *p_this, const char *psz_module )
                                VLC_THREAD_PRIORITY_LOW ) )
         {
             msg_Err( p_intf, "cannot spawn libvlc death monitoring thread" );
-            vlc_object_release( p_intf );
-            return VLC_ENOMEM;
+            goto error;
         }
         p_intf->pf_run( p_intf );
 
-        /* Make sure our MonitorLibVLCDeath thread exit */
-        vlc_object_kill( p_intf );
         /* It is monitoring libvlc, not the p_intf */
         vlc_object_kill( p_intf->p_libvlc );
-        vlc_thread_join( p_intf );
-
-        vlc_object_detach( p_intf );
-        vlc_object_release( p_intf );
     }
     else
 #endif
@@ -171,28 +148,49 @@ int intf_Create( vlc_object_t *p_this, const char *psz_module )
                            VLC_THREAD_PRIORITY_LOW ) )
     {
         msg_Err( p_intf, "cannot spawn interface thread" );
-        vlc_object_release( p_intf );
-        return VLC_EGENERIC;
+        goto error;
     }
 
     return VLC_SUCCESS;
+
+error:
+    if( p_intf->p_module )
+        module_unneed( p_intf, p_intf->p_module );
+    config_ChainDestroy( p_intf->p_cfg );
+    free( p_intf->psz_intf );
+    vlc_object_release( p_intf );
+    return VLC_EGENERIC;
 }
 
 
 /**
- * Stops the interface thread
- *
- * This function asks the interface thread to stop
- * @param p_intf the interface thread
+ * Stops and destroys all interfaces
+ * @param p_libvlc the LibVLC instance
  */
-void intf_StopThread( intf_thread_t *p_intf )
+void intf_DestroyAll( libvlc_int_t *p_libvlc )
 {
-    /* Tell the interface to die */
-    vlc_object_kill( p_intf );
-    if( p_intf->pf_run )
-        vlc_thread_join( p_intf );
+    vlc_list_t *l = vlc_list_find( VLC_OBJECT(p_libvlc), VLC_OBJECT_INTF, FIND_CHILD );
+
+    /* Tell the interfaces to die */
+    for( int i = 0; i < l->i_count; i++ )
+        vlc_object_kill( l->p_values[i].p_object );
+
+    /* Cleanup the interfaces */
+    for( int i = 0; i < l->i_count; i++ )
+    {
+        intf_thread_t *p_intf = (intf_thread_t *)l->p_values[i].p_object;
+
+        if( p_intf->pf_run )
+            vlc_thread_join( p_intf );
+        module_unneed( p_intf, p_intf->p_module );
+        free( p_intf->psz_intf );
+        config_ChainDestroy( p_intf->p_cfg );
+    }
 
-    module_unneed( p_intf, p_intf->p_module );
+    /* Destroy objects */
+    for( int i = 0; i < l->i_count; i++ )
+        vlc_object_release( l->p_values[i].p_object ); /* for intf_Create() */
+    vlc_list_release( l );
 }
 
 /* Following functions are local */
index e9e0b0435e034e3450a466dbad33584d71d420f0..3d543729246accf8d910dff2d841c56e1622ca40 100644 (file)
@@ -1032,14 +1032,7 @@ void libvlc_InternalCleanup( libvlc_int_t *p_libvlc )
 
     /* Ask the interfaces to stop and destroy them */
     msg_Dbg( p_libvlc, "removing all interfaces" );
-    intf_thread_t *p_intf;
-    while( (p_intf = vlc_object_find( p_libvlc, VLC_OBJECT_INTF, FIND_CHILD )) )
-    {
-        intf_StopThread( p_intf );
-        vlc_object_detach( p_intf );
-        vlc_object_release( p_intf ); /* for intf_Create() */
-        vlc_object_release( p_intf ); /* for vlc_object_find() */
-    }
+    intf_DestroyAll( p_libvlc );
 
 #ifdef ENABLE_VLM
     /* Destroy VLM if created in libvlc_InternalInit */
index 6d9ead252dad9759e509d200584892e0b71c0a0c..f6d44026f329d9de571dc32f2fc8777ac2d538a4 100644 (file)
@@ -233,6 +233,7 @@ static inline libvlc_priv_t *libvlc_priv (libvlc_int_t *libvlc)
 }
 
 void playlist_ServicesDiscoveryKillAll( playlist_t *p_playlist );
+void intf_DestroyAll( libvlc_int_t * );
 
 #define libvlc_stats( o ) (libvlc_priv((VLC_OBJECT(o))->p_libvlc)->b_stats)
 
index 01742744046c7c15641a79bf1013230611c8345d..0b0f405ea350cab89142b449dd4cfd20486faacc 100644 (file)
@@ -205,7 +205,6 @@ input_Stop
 input_vaControl
 intf_Create
 __intf_Eject
-intf_StopThread
 IsUTF8
 libvlc_InternalAddIntf
 libvlc_InternalCleanup