[vlc-devel] commit: libvlc_vlm_release : release events stuff Centralize vlm release operations in one new function : libvlc_vlm_release_internal ( Sébastien Escudier )

git version control git at videolan.org
Tue Jun 30 21:47:42 CEST 2009


vlc | branch: master | Sébastien Escudier <sebastien-devel at celeos.eu> | Mon Jun 15 15:30:32 2009 +0200| [a3fee044eb0b5eecd627000e20d94ce7f05e957c] | committer: Rémi Denis-Courmont 

libvlc_vlm_release : release events stuff Centralize vlm release operations in one new function : libvlc_vlm_release_internal

Signed-off-by: Rémi Denis-Courmont <remi at remlab.net>

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=a3fee044eb0b5eecd627000e20d94ce7f05e957c
---

 src/control/core.c            |   11 +++---
 src/control/libvlc_internal.h |   12 ++++++-
 src/control/vlm.c             |   72 +++++++++++++++++++++++++---------------
 3 files changed, 60 insertions(+), 35 deletions(-)

diff --git a/src/control/core.c b/src/control/core.c
index 4a258d2..9f180ea 100644
--- a/src/control/core.c
+++ b/src/control/core.c
@@ -139,8 +139,9 @@ libvlc_instance_t * libvlc_new( int argc, const char *const *argv,
     }
 
     p_new->p_libvlc_int = p_libvlc_int;
-    p_new->p_vlm = NULL;
-    p_new->p_event_manager = NULL;
+    p_new->libvlc_vlm.p_vlm = NULL;
+    p_new->libvlc_vlm.p_event_manager = NULL;
+    p_new->libvlc_vlm.pf_release = NULL;
     p_new->b_playlist_locked = 0;
     p_new->ref_count = 1;
     p_new->verbosity = 1;
@@ -175,10 +176,8 @@ void libvlc_release( libvlc_instance_t *p_instance )
     {
         vlc_mutex_destroy( lock );
         vlc_mutex_destroy( &p_instance->event_callback_lock );
-        if( p_instance->p_event_manager )
-            libvlc_event_manager_release( p_instance->p_event_manager );
-        if( p_instance->p_vlm )
-            vlm_Delete( p_instance->p_vlm );
+        if( p_instance->libvlc_vlm.pf_release )
+            p_instance->libvlc_vlm.pf_release( p_instance );
         libvlc_InternalCleanup( p_instance->p_libvlc_int );
         libvlc_InternalDestroy( p_instance->p_libvlc_int );
         free( p_instance );
diff --git a/src/control/libvlc_internal.h b/src/control/libvlc_internal.h
index 2d62b1b..64d8941 100644
--- a/src/control/libvlc_internal.h
+++ b/src/control/libvlc_internal.h
@@ -47,6 +47,8 @@ VLC_EXPORT (void, libvlc_InternalDestroy, ( libvlc_int_t * ) );
 VLC_EXPORT (int, libvlc_InternalAddIntf, ( libvlc_int_t *, const char * ) );
 VLC_EXPORT (void, libvlc_InternalWait, ( libvlc_int_t * ) );
 
+typedef void (*libvlc_vlm_release_func_t)( libvlc_instance_t * ) ;
+
 /***************************************************************************
  * Opaque structures for libvlc API
  ***************************************************************************/
@@ -57,11 +59,17 @@ typedef enum libvlc_lock_state_t
     libvlc_UnLocked
 } libvlc_lock_state_t;
 
+typedef struct libvlc_vlm_t
+{
+    vlm_t                  *p_vlm;
+    libvlc_event_manager_t *p_event_manager;
+    libvlc_vlm_release_func_t pf_release;
+} libvlc_vlm_t;
+
 struct libvlc_instance_t
 {
     libvlc_int_t *p_libvlc_int;
-    vlm_t        *p_vlm;
-    libvlc_event_manager_t *p_event_manager;
+    libvlc_vlm_t  libvlc_vlm;
     int           b_playlist_locked;
     unsigned      ref_count;
     int           verbosity;
diff --git a/src/control/vlm.c b/src/control/vlm.c
index bbeb883..b0b9393 100644
--- a/src/control/vlm.c
+++ b/src/control/vlm.c
@@ -76,7 +76,7 @@ char* libvlc_vlm_show_media( libvlc_instance_t *p_instance, char *psz_name,
     CHECK_VLM;
     asprintf( &psz_message, "show %s", psz_name );
     asprintf( &psz_response, "", psz_name );
-    vlm_ExecuteCommand( p_instance->p_vlm, psz_message, &answer );
+    vlm_ExecuteCommand( p_instance->libvlc_vlm.p_vlm, psz_message, &answer );
     if( answer->psz_value )
     {
         libvlc_exception_raise( p_exception, "Unable to call show %s: %s",
@@ -113,6 +113,10 @@ static int VlmEvent( vlc_object_t *p_this, const char * name,
     libvlc_event_manager_t *p_event_manager = (libvlc_event_manager_t *) param;
     libvlc_event_t libvlc_event;
 
+    VLC_UNUSED( p_this );
+    VLC_UNUSED( name );
+    VLC_UNUSED( old_val );
+
     libvlc_event.u.vlm_media_event.psz_media_name = event->psz_name;
 
     switch( event->i_type )
@@ -137,43 +141,69 @@ static int VlmEvent( vlc_object_t *p_this, const char * name,
     return 0;
 }
 
+static void libvlc_vlm_release_internal( libvlc_instance_t *p_instance )
+{
+    vlm_t *p_vlm = p_instance->libvlc_vlm.p_vlm;
+    if( !p_instance->libvlc_vlm.p_vlm )
+        return;
+    /* We need to remove medias in order to receive events */
+    vlm_Control( p_vlm, VLM_CLEAR_MEDIAS );
+    vlm_Control( p_vlm, VLM_CLEAR_SCHEDULES );
+
+    var_DelCallback( (vlc_object_t *)p_vlm, "intf-event", VlmEvent,
+                     p_instance->libvlc_vlm.p_event_manager );
+    p_instance->libvlc_vlm.pf_release = NULL;
+    libvlc_event_manager_release( p_instance->libvlc_vlm.p_event_manager );
+    p_instance->libvlc_vlm.p_event_manager = NULL;
+    vlm_Delete( p_vlm );
+    p_instance->libvlc_vlm.p_vlm = NULL;
+}
+
 static int libvlc_vlm_init( libvlc_instance_t *p_instance,
                             libvlc_exception_t *p_exception )
 {
-    if( !p_instance->p_event_manager )
+    if( !p_instance->libvlc_vlm.p_event_manager )
     {
-        p_instance->p_event_manager = libvlc_event_manager_new( p_instance->p_vlm,
+        p_instance->libvlc_vlm.p_event_manager = libvlc_event_manager_new( p_instance->libvlc_vlm.p_vlm,
                                                                 p_instance, p_exception );
-        libvlc_event_manager_register_event_type( p_instance->p_event_manager,
+        libvlc_event_manager_register_event_type( p_instance->libvlc_vlm.p_event_manager,
                                                   libvlc_VlmMediaAdded, NULL );
-        libvlc_event_manager_register_event_type( p_instance->p_event_manager,
+        libvlc_event_manager_register_event_type( p_instance->libvlc_vlm.p_event_manager,
                                                   libvlc_VlmMediaRemoved, NULL );
-        libvlc_event_manager_register_event_type( p_instance->p_event_manager,
+        libvlc_event_manager_register_event_type( p_instance->libvlc_vlm.p_event_manager,
                                                   libvlc_VlmMediaChanged, NULL );
-        libvlc_event_manager_register_event_type( p_instance->p_event_manager,
+        libvlc_event_manager_register_event_type( p_instance->libvlc_vlm.p_event_manager,
                                                   libvlc_VlmMediaInstanceStarted, NULL );
-        libvlc_event_manager_register_event_type( p_instance->p_event_manager,
+        libvlc_event_manager_register_event_type( p_instance->libvlc_vlm.p_event_manager,
                                                   libvlc_VlmMediaInstanceStopped, NULL );
     }
 
-    if( !p_instance->p_vlm )
+    if( !p_instance->libvlc_vlm.p_vlm )
     {
-        p_instance->p_vlm = vlm_New( p_instance->p_libvlc_int );
-        if( !p_instance->p_vlm )
+        p_instance->libvlc_vlm.p_vlm = vlm_New( p_instance->p_libvlc_int );
+        if( !p_instance->libvlc_vlm.p_vlm )
         {
             libvlc_exception_raise( p_exception,
                                     "Unable to create VLM." );
             return VLC_EGENERIC;
         }
-        var_AddCallback( (vlc_object_t *)p_instance->p_vlm, "intf-event", VlmEvent,
-                         p_instance->p_event_manager );
+        var_AddCallback( (vlc_object_t *)p_instance->libvlc_vlm.p_vlm, "intf-event", VlmEvent,
+                         p_instance->libvlc_vlm.p_event_manager );
+        p_instance->libvlc_vlm.pf_release = libvlc_vlm_release_internal;
     }
 
     return VLC_SUCCESS;
 }
+
+void libvlc_vlm_release( libvlc_instance_t *p_instance,
+                         libvlc_exception_t *p_exception)
+{
+    libvlc_vlm_release_internal( p_instance );
+}
+
 #define VLM_RET(p,ret) do {                                     \
     if( libvlc_vlm_init( p_instance, p_exception ) ) return ret;\
-    (p) = p_instance->p_vlm;                                    \
+    (p) = p_instance->libvlc_vlm.p_vlm;                                    \
   } while(0)
 #define VLM(p) VLM_RET(p,)
 
@@ -210,18 +240,6 @@ libvlc_vlm_get_media_instance( libvlc_instance_t *p_instance,
     return p_minstance;
 }
 
-
-void libvlc_vlm_release( libvlc_instance_t *p_instance,
-                         libvlc_exception_t *p_exception)
-{
-    vlm_t *p_vlm;
-
-    VLM(p_vlm);
-
-    vlm_Delete( p_vlm );
-    p_instance->p_vlm = NULL;
-}
-
 void libvlc_vlm_add_broadcast( libvlc_instance_t *p_instance,
                                const char *psz_name,
                                const char *psz_input,
@@ -588,5 +606,5 @@ libvlc_event_manager_t * libvlc_vlm_get_event_manager( libvlc_instance_t *p_inst
 {
     vlm_t *p_vlm;
     VLM_RET( p_vlm, NULL);
-    return p_instance->p_event_manager;
+    return p_instance->libvlc_vlm.p_event_manager;
 }




More information about the vlc-devel mailing list