[vlc-devel] commit: Moved input_EsOutDecodersIsEmpty to es_out_Control and cleaned its usage. (Laurent Aimar )

git version control git at videolan.org
Tue Nov 4 23:56:12 CET 2008


vlc | branch: master | Laurent Aimar <fenrir at videolan.org> | Sun Nov  2 19:00:22 2008 +0100| [b0bcb74cf24e97b0714da3604172f95b090b8009] | committer: Laurent Aimar 

Moved input_EsOutDecodersIsEmpty to es_out_Control and cleaned its usage.

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

 src/input/es_out.c |   54 ++++++++++++++++++++++++++++-----------------------
 src/input/es_out.h |   11 +++++++++-
 src/input/input.c  |   40 +++++++++++++++++---------------------
 3 files changed, 58 insertions(+), 47 deletions(-)

diff --git a/src/input/es_out.c b/src/input/es_out.c
index ea9124d..fd14795 100644
--- a/src/input/es_out.c
+++ b/src/input/es_out.c
@@ -471,30 +471,6 @@ void input_EsOutChangePosition( es_out_t *out )
     p_sys->i_preroll_end = -1;
 }
 
-bool input_EsOutDecodersIsEmpty( es_out_t *out )
-{
-    es_out_sys_t      *p_sys = out->p_sys;
-    int i;
-
-    if( p_sys->b_buffering && p_sys->p_pgrm )
-    {
-        EsOutDecodersStopBuffering( out, true );
-        if( p_sys->b_buffering )
-            return true;
-    }
-
-    for( i = 0; i < p_sys->i_es; i++ )
-    {
-        es_out_id_t *es = p_sys->es[i];
-
-        if( es->p_dec && !input_DecoderIsEmpty( es->p_dec ) )
-            return false;
-        if( es->p_dec_record && !input_DecoderIsEmpty( es->p_dec_record ) )
-            return false;
-    }
-    return true;
-}
-
 void input_EsOutFrameNext( es_out_t *out )
 {
     es_out_sys_t *p_sys = out->p_sys;
@@ -666,6 +642,31 @@ static es_out_id_t *EsOutGetFromID( es_out_t *out, int i_id )
     return NULL;
 }
 
+static bool EsOutDecodersIsEmpty( es_out_t *out )
+{
+    es_out_sys_t      *p_sys = out->p_sys;
+    int i;
+
+    if( p_sys->b_buffering && p_sys->p_pgrm )
+    {
+        EsOutDecodersStopBuffering( out, true );
+        if( p_sys->b_buffering )
+            return true;
+    }
+
+    for( i = 0; i < p_sys->i_es; i++ )
+    {
+        es_out_id_t *es = p_sys->es[i];
+
+        if( es->p_dec && !input_DecoderIsEmpty( es->p_dec ) )
+            return false;
+        if( es->p_dec_record && !input_DecoderIsEmpty( es->p_dec_record ) )
+            return false;
+    }
+    return true;
+}
+
+
 static void EsOutDecodersStopBuffering( es_out_t *out, bool b_forced )
 {
     es_out_sys_t *p_sys = out->p_sys;
@@ -2310,6 +2311,11 @@ static int EsOutControlLocked( es_out_t *out, int i_query, va_list args )
             *pb = p_sys->b_buffering;
             return VLC_SUCCESS;
 
+        case ES_OUT_GET_EMPTY:
+            pb = (bool *)va_arg( args, bool* );
+            *pb = EsOutDecodersIsEmpty( out );
+            return VLC_SUCCESS;
+
         default:
             msg_Err( p_sys->p_input, "unknown query in es_out_Control" );
             return VLC_EGENERIC;
diff --git a/src/input/es_out.h b/src/input/es_out.h
index 71bda21..7843c2a 100644
--- a/src/input/es_out.h
+++ b/src/input/es_out.h
@@ -43,6 +43,9 @@ enum es_out_query_private_e
 
     /* Get buffering state */
     ES_OUT_GET_BUFFERING,                           /* arg1=bool*               res=cannot fail */
+
+    /* Check if es_out has still data to play */
+    ES_OUT_GET_EMPTY,                               /* arg1=bool*               res=cannot fail */
 };
 
 static inline mtime_t es_out_GetWakeup( es_out_t *p_out )
@@ -61,7 +64,14 @@ static inline bool es_out_GetBuffering( es_out_t *p_out )
     assert( !i_ret );
     return b;
 }
+static inline bool es_out_GetEmpty( es_out_t *p_out )
+{
+    bool b;
+    int i_ret = es_out_Control( p_out, ES_OUT_GET_EMPTY, &b );
 
+    assert( !i_ret );
+    return b;
+}
 
 es_out_t  *input_EsOutNew( input_thread_t *, int i_rate );
 
@@ -70,7 +80,6 @@ int        input_EsOutSetRecord( es_out_t *, bool b_record );
 void       input_EsOutChangeRate( es_out_t *, int );
 void       input_EsOutChangePause( es_out_t *, bool b_paused, mtime_t i_date );
 void       input_EsOutChangePosition( es_out_t * );
-bool       input_EsOutDecodersIsEmpty( es_out_t * );
 void       input_EsOutFrameNext( es_out_t * );
 
 void       input_EsOutLock( es_out_t * );
diff --git a/src/input/input.c b/src/input/input.c
index 1813ff1..f9e217c 100644
--- a/src/input/input.c
+++ b/src/input/input.c
@@ -729,7 +729,7 @@ static void MainLoop( input_thread_t *p_input )
     /* Start the timer */
     stats_TimerStop( p_input, STATS_TIMER_INPUT_LAUNCHING );
 
-    while( !p_input->b_die && !p_input->b_error && !p_input->p->input.b_eof )
+    while( vlc_object_alive( p_input ) && !p_input->b_error )
     {
         bool b_force_update;
         int i_type;
@@ -750,9 +750,21 @@ static void MainLoop( input_thread_t *p_input )
 
         if( !b_paused )
         {
-            MainLoopDemux( p_input, &b_force_update, &i_start_mdate );
+            if( !p_input->p->input.b_eof )
+            {
+                MainLoopDemux( p_input, &b_force_update, &i_start_mdate );
 
-            i_wakeup = es_out_GetWakeup( p_input->p->p_es_out );
+                i_wakeup = es_out_GetWakeup( p_input->p->p_es_out );
+            }
+            else if( !p_input->b_eof && !es_out_GetEmpty( p_input->p->p_es_out ) )
+            {
+                msg_Dbg( p_input, "waiting decoder fifos to empty" );
+                i_wakeup = mdate() + INPUT_IDLE_SLEEP;
+            }
+            else
+            {
+                break;
+            }
         }
 
         /* */
@@ -797,26 +809,8 @@ static void MainLoop( input_thread_t *p_input )
         } while( i_current < i_wakeup );
     }
 
-    if( !p_input->b_eof && !p_input->b_error && p_input->p->input.b_eof )
-    {
-        /* We have finish to demux data but not to play them */
-        while( vlc_object_alive( p_input ) )
-        {
-            input_EsOutLock( p_input->p->p_es_out );
-            bool b_empty = input_EsOutDecodersIsEmpty( p_input->p->p_es_out );
-            input_EsOutUnlock( p_input->p->p_es_out );
-
-            if( b_empty )
-                break;
-
-            msg_Dbg( p_input, "waiting decoder fifos to empty" );
-
-            msleep( INPUT_IDLE_SLEEP );
-        }
-
-        /* We have finished */
+    if( !p_input->b_error )
         input_ChangeState( p_input, END_S );
-    }
 }
 
 static void InitStatistics( input_thread_t * p_input )
@@ -1601,6 +1595,7 @@ static bool Control( input_thread_t *p_input, int i_type,
             {
                 if( p_input->p->i_slave > 0 )
                     SlaveSeek( p_input );
+                p_input->p->input.b_eof = false;
 
                 b_force_update = true;
             }
@@ -1660,6 +1655,7 @@ static bool Control( input_thread_t *p_input, int i_type,
             {
                 if( p_input->p->i_slave > 0 )
                     SlaveSeek( p_input );
+                p_input->p->input.b_eof = false;
 
                 b_force_update = true;
             }




More information about the vlc-devel mailing list