[vlc-devel] [PATCH 1/9] input: change input_Read() behavior

Rémi Denis-Courmont remi at remlab.net
Wed Jun 1 16:19:57 CEST 2016


Le 2016-06-01 13:24, Thomas Guillem a écrit :
> Users will have more control when they need to read an input 
> synchronously.
> They'll be able to interrupt it from an other thread for example. 
> This
> function can now be used to preparse an item if the input_thread_t
> was created with input_CreatePreparser().

> ---
>  include/vlc_input.h                    |  3 +-
>  lib/media_list.c                       |  9 ++++-
>  modules/services_discovery/mediadirs.c |  7 +++-
>  src/input/input.c                      | 72
> ++++++++++++++++++++--------------
>  src/playlist/loadsave.c                | 15 ++++++-
>  5 files changed, 70 insertions(+), 36 deletions(-)
>
> diff --git a/include/vlc_input.h b/include/vlc_input.h
> index 7633e9d..f72f8d2 100644
> --- a/include/vlc_input.h
> +++ b/include/vlc_input.h
> @@ -509,8 +509,7 @@ VLC_API int input_Start( input_thread_t * );
>
>  VLC_API void input_Stop( input_thread_t * );
>
> -VLC_API int input_Read( vlc_object_t *, input_item_t * );
> -#define input_Read(a,b) input_Read(VLC_OBJECT(a),b)
> +VLC_API int input_Read( input_thread_t *, bool );

I don't get why the flag is needed.

>
>  VLC_API int input_vaControl( input_thread_t *, int i_query, va_list  
> );
>
> diff --git a/lib/media_list.c b/lib/media_list.c
> index 82fee60..7d8737c 100644
> --- a/lib/media_list.c
> +++ b/lib/media_list.c
> @@ -267,7 +267,14 @@ libvlc_media_list_add_file_content(
> libvlc_media_list_t * p_mlist,
>          return -1;
>      }
>
> -    input_Read( p_mlist->p_libvlc_instance->p_libvlc_int, 
> p_input_item );
> +    input_thread_t *p_input =
> +        input_Create( p_mlist->p_libvlc_instance->p_libvlc_int,
> p_input_item,
> +                      NULL, NULL );
> +    if( p_input != NULL )
> +    {
> +        input_Read( p_input, false );
> +        input_Close( p_input );
> +    }
>      return 0;
>  }
>
> diff --git a/modules/services_discovery/mediadirs.c
> b/modules/services_discovery/mediadirs.c
> index 0d1c262..957daa5 100644
> --- a/modules/services_discovery/mediadirs.c
> +++ b/modules/services_discovery/mediadirs.c
> @@ -205,7 +205,12 @@ static void *Run( void *data )
>          vlc_event_attach( p_em, vlc_InputItemSubItemAdded,
>                            input_item_subitem_added, p_sd );
>
> -        input_Read( p_sd, p_root );
> +        input_thread_t *p_input = input_Create( p_sd, p_root, NULL, 
> NULL );
> +        if( p_input != NULL )
> +        {
> +            input_Read( p_input, false );
> +            input_Close( p_input );
> +        }
>
>          vlc_event_detach( p_em, vlc_InputItemSubItemAdded,
>                            input_item_subitem_added, p_sd );
> diff --git a/src/input/input.c b/src/input/input.c
> index 5307203..effca97 100644
> --- a/src/input/input.c
> +++ b/src/input/input.c
> @@ -55,8 +55,8 @@
>
> 
> /*****************************************************************************
>   * Local prototypes
>
> 
> *****************************************************************************/
> -static  void *Run( void * );
> -static  void *Preparse( void * );
> +static  void Run( input_thread_t * );
> +static  void Preparse( input_thread_t * );
>
>  static input_thread_t * Create  ( vlc_object_t *, input_item_t *,
>                                    const char *, bool, 
> input_resource_t * );
> @@ -126,27 +126,29 @@ input_thread_t *input_Create( vlc_object_t 
> *p_parent,
>      return Create( p_parent, p_item, psz_log, false, p_resource );
>  }
>
> -#undef input_Read
>  /**
> - * Initialize an input thread and run it until it stops by itself.
> + * Read a input_thread_t created by input_Create() or
> input_CreatePreparser().
>   *
> - * \param p_parent a vlc_object
> - * \param p_item an input item
> + * The read is executed in the current thread and is blockling. This
> function
> + * can be interrupted with input_Stop()
> + *
> + * \param the input thread to read
> + * \param true if the interrupt context is handled by the 
> input_thead_t
>   * \return an error code, VLC_SUCCESS on success
>   */
> -int input_Read( vlc_object_t *p_parent, input_item_t *p_item )
> +int input_Read( input_thread_t *p_input, bool b_interrupt )
>  {
> -    input_thread_t *p_input = Create( p_parent, p_item, NULL, false, 
> NULL );
> -    if( !p_input )
> -        return VLC_EGENERIC;
> +    if( b_interrupt )
> +        vlc_interrupt_set(&p_input->p->interrupt);
>
> -    if( !Init( p_input ) )
> -    {
> -        MainLoop( p_input, false );
> -        End( p_input );
> -    }
> +    if( p_input->b_preparsing )
> +        Preparse( p_input );
> +    else
> +        Run( p_input );
> +
> +    if( b_interrupt )
> +        vlc_interrupt_set( NULL );
>
> -    vlc_object_release( p_input );
>      return VLC_SUCCESS;
>  }
>
> @@ -156,6 +158,26 @@ input_thread_t *input_CreatePreparser(
> vlc_object_t *parent,
>      return Create( parent, item, NULL, true, NULL );
>  }
>
> +static void *ThreadRun( void *obj )
> +{
> +    input_thread_t *p_input = (input_thread_t *)obj;
> +
> +    vlc_interrupt_set(&p_input->p->interrupt);
> +
> +    Run( p_input );
> +    return NULL;
> +}
> +
> +static void *ThreadPreparse( void *obj )
> +{
> +    input_thread_t *p_input = (input_thread_t *)obj;
> +
> +    vlc_interrupt_set(&p_input->p->interrupt);
> +
> +    Preparse( p_input );
> +    return NULL;
> +}
> +
>  /**
>   * Start a input_thread_t created by input_Create.
>   *
> @@ -165,10 +187,10 @@ input_thread_t *input_CreatePreparser(
> vlc_object_t *parent,
>   */
>  int input_Start( input_thread_t *p_input )
>  {
> -    void *(*func)(void *) = Run;
> +    void *(*func)(void *) = ThreadRun;
>
>      if( p_input->b_preparsing )
> -        func = Preparse;
> +        func = ThreadPreparse;
>
>      assert( !p_input->p->is_running );
>      /* Create thread and wait for its readiness. */
> @@ -471,12 +493,8 @@ static input_thread_t *Create( vlc_object_t
> *p_parent, input_item_t *p_item,
>   * This is the "normal" thread that spawns the input processing 
> chain,
>   * reads the stream, cleans up and waits
>
> 
> *****************************************************************************/
> -static void *Run( void *obj )
> +static void Run( input_thread_t *p_input )
>  {
> -    input_thread_t *p_input = (input_thread_t *)obj;
> -
> -    vlc_interrupt_set(&p_input->p->interrupt);
> -
>      if( !Init( p_input ) )
>      {
>          if( p_input->p->b_can_pace_control &&
> p_input->p->b_out_pace_control )
> @@ -493,15 +511,10 @@ static void *Run( void *obj )
>      }
>
>      input_SendEventDead( p_input );
> -    return NULL;
>  }
>
> -static void *Preparse( void *obj )
> +static void Preparse( input_thread_t *p_input )
>  {
> -    input_thread_t *p_input = (input_thread_t *)obj;
> -
> -    vlc_interrupt_set(&p_input->p->interrupt);
> -
>      if( !Init( p_input ) )
>      {   /* if the demux is a playlist, call Mainloop that will call
>           * demux_Demux in order to fetch sub items */
> @@ -518,7 +531,6 @@ static void *Preparse( void *obj )
>      }
>
>      input_SendEventDead( p_input );
> -    return NULL;
>  }
>
>  bool input_Stopped( input_thread_t *input )
> diff --git a/src/playlist/loadsave.c b/src/playlist/loadsave.c
> index adbc92d..e5754a3 100644
> --- a/src/playlist/loadsave.c
> +++ b/src/playlist/loadsave.c
> @@ -88,6 +88,17 @@ out:
>     return ret;
>  }
>
> +static int item_Read( vlc_object_t *p_parent, input_item_t *p_item )
> +{
> +    input_thread_t *p_input = input_Create( p_parent, p_item, NULL, 
> NULL );
> +    if( p_input == NULL )
> +        return VLC_EGENERIC;
> +
> +    input_Read( p_input, false );
> +    input_Close( p_input );
> +    return VLC_SUCCESS;
> +}
> +
>  int playlist_Import( playlist_t *p_playlist, const char *psz_file )
>  {
>      input_item_t *p_input;
> @@ -105,7 +116,7 @@ int playlist_Import( playlist_t *p_playlist,
> const char *psz_file )
>      vlc_object_t *dummy = vlc_object_create( p_playlist, sizeof 
> (*dummy) );
>      var_Create( dummy, "meta-file", VLC_VAR_VOID );
>
> -    int ret = input_Read( dummy, p_input );
> +    int ret = item_Read( dummy, p_input );
>
>      vlc_object_release( dummy );
>      return ret;
> @@ -175,7 +186,7 @@ int playlist_MLLoad( playlist_t *p_playlist )
>
>      vlc_object_t *dummy = vlc_object_create( p_playlist, sizeof 
> (*dummy) );
>      var_Create( dummy, "meta-file", VLC_VAR_VOID );
> -    input_Read( dummy, p_input );
> +    item_Read( dummy, p_input );
>      vlc_object_release( dummy );
>
>      vlc_event_detach( &p_input->event_manager,
> vlc_InputItemSubItemTreeAdded,

-- 
Rémi Denis-Courmont
http://www.remlab.net/


More information about the vlc-devel mailing list