add seekToPosition to DVBChannel
authorFelix Domke <tmbinc@elitedvb.net>
Sun, 13 Nov 2005 04:28:50 +0000 (04:28 +0000)
committerFelix Domke <tmbinc@elitedvb.net>
Sun, 13 Nov 2005 04:28:50 +0000 (04:28 +0000)
lib/dvb/dvb.cpp
lib/dvb/dvb.h
lib/dvb/idvb.h

index 13ae224..a2a3775 100644 (file)
@@ -619,11 +619,30 @@ RESULT eDVBChannel::getCurrentPosition(pts_t &pos)
 
 RESULT eDVBChannel::seekTo(pts_t &pts)
 {
 
 RESULT eDVBChannel::seekTo(pts_t &pts)
 {
+#if 0
+       eDebug("eDVBChannel: seekTo .. %llx", pts);
        m_pvr_thread->pause();
        if (m_decoder_demux)
                m_decoder_demux->get().flush();
                /* demux will also flush all decoder.. */
        m_pvr_thread->pause();
        if (m_decoder_demux)
                m_decoder_demux->get().flush();
                /* demux will also flush all decoder.. */
-//     m_pvr_thread->seek(pts);
+       
+       off_t r;
+       
+       if (!m_tstools.getPosition(pts, r));
+               m_pvr_thread->seek(r);
+       else
+               eDebug("getPosition failed!");
        m_pvr_thread->resume();
        m_pvr_thread->resume();
+#endif
 }
 
 }
 
+RESULT eDVBChannel::seekToPosition(int relative, const off_t &r)
+{
+       eDebug("eDVBChannel: seekToPosition .. %llx", r);
+       m_pvr_thread->pause();
+       if (m_decoder_demux)
+               m_decoder_demux->get().flush();
+               /* demux will also flush all decoder.. */
+       m_pvr_thread->seek(relative ? SEEK_CUR : SEEK_SET, r);
+       m_pvr_thread->resume();
+}
index f858625..01a0e47 100644 (file)
@@ -193,6 +193,7 @@ public:
        RESULT getLength(pts_t &len);
        RESULT getCurrentPosition(pts_t &pos);
        RESULT seekTo(pts_t &pts);
        RESULT getLength(pts_t &len);
        RESULT getCurrentPosition(pts_t &pos);
        RESULT seekTo(pts_t &pts);
+       RESULT seekToPosition(int relative, const off_t &off);
 
 private:
        ePtr<eDVBAllocatedFrontend> m_frontend;
 
 private:
        ePtr<eDVBAllocatedFrontend> m_frontend;
index bd528f0..de481d7 100644 (file)
@@ -481,8 +481,7 @@ public:
        virtual RESULT getLength(pts_t &pts) = 0;
        virtual RESULT getCurrentPosition(pts_t &pos) = 0;
        virtual RESULT seekTo(pts_t &pts) = 0;
        virtual RESULT getLength(pts_t &pts) = 0;
        virtual RESULT getCurrentPosition(pts_t &pos) = 0;
        virtual RESULT seekTo(pts_t &pts) = 0;
-       
-       // seekTo ...
+       virtual RESULT seekToPosition(int relative, const off_t &pts) = 0;
 };
 
 class iDVBSectionReader;
 };
 
 class iDVBSectionReader;