[vlc-commits] chromecast: EOF when finished or Error

Thomas Guillem git at videolan.org
Wed Jan 31 16:25:48 CET 2018


vlc | branch: master | Thomas Guillem <thomas at gllm.fr> | Mon Jan 29 16:18:06 2018 +0100| [6839ba7a8d600e7fc05723bf2a946e7063fdc570] | committer: Thomas Guillem

chromecast: EOF when finished or Error

Avoid false positives.

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

 modules/stream_out/chromecast/chromecast_ctrl.cpp | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/modules/stream_out/chromecast/chromecast_ctrl.cpp b/modules/stream_out/chromecast/chromecast_ctrl.cpp
index e059392c9f..1976b51b80 100644
--- a/modules/stream_out/chromecast/chromecast_ctrl.cpp
+++ b/modules/stream_out/chromecast/chromecast_ctrl.cpp
@@ -455,7 +455,11 @@ void intf_sys_t::processMediaMessage( const castchannel::CastMessage& msg )
                 if ( m_state == Buffering )
                     setState( LoadFailed );
                 else
+                {
+                    if (idleReason == "FINISHED")
+                        m_eof = true;
                     setState( Ready );
+                }
             }
         }
         else
@@ -480,7 +484,6 @@ void intf_sys_t::processMediaMessage( const castchannel::CastMessage& msg )
                 {
                     /* TODO reset demux PCR ? */
                     m_time_playback_started = mdate();
-                    m_eof = false;
                     setState( Playing );
                 }
             }
@@ -493,8 +496,6 @@ void intf_sys_t::processMediaMessage( const castchannel::CastMessage& msg )
                      * request more input) but this state is fetched only when
                      * the input has reached EOF. */
 
-                    if( m_state == Playing )
-                        m_eof = true;
                     m_time_playback_started = VLC_TS_INVALID;
                     setState( Buffering );
                 }
@@ -727,7 +728,7 @@ void intf_sys_t::waitSeekDone()
 bool intf_sys_t::isFinishedPlaying()
 {
     vlc_mutex_locker locker(&m_lock);
-    return m_state == Ready || m_state == LoadFailed || m_state == Dead || m_eof;
+    return m_state == LoadFailed || m_state == Dead || m_eof;
 }
 
 void intf_sys_t::setTitle(const char* psz_title)



More information about the vlc-commits mailing list