add needed functions
[enigma2.git] / lib / dvb / decoder.h
index 6694e9fcdb60814f97a0ad260dfe808d1ee5b1d8..d1f040ec180852f8d2abacbefd5c1ebd1cdae0e1 100644 (file)
@@ -4,40 +4,72 @@
 #include <lib/base/object.h>
 #include <lib/dvb/demux.h>
 
-class eDVBAudio: public virtual iObject
+class eDVBAudio: public iObject
 {
-DECLARE_REF;
+DECLARE_REF(eDVBAudio);
 private:
        ePtr<eDVBDemux> m_demux;
        int m_fd, m_fd_demux;
 public:
+       enum {aMPEG, aAC3, aDTS };
        eDVBAudio(eDVBDemux *demux, int dev);
-       int startPid(int pid);
+       int startPid(int pid, int type);
        void stop();
+#if HAVE_DVB_API_VERSION < 3
+       void start();
+       void stopPid();
+#endif
+       void flush();
+       void freeze();
+       void unfreeze();
        virtual ~eDVBAudio();
 };
 
-class eDVBVideo: public virtual iObject
+class eDVBVideo: public iObject
 {
-DECLARE_REF;
+DECLARE_REF(eDVBVideo);
 private:
        ePtr<eDVBDemux> m_demux;
        int m_fd, m_fd_demux;
+       
+       int m_is_slow_motion, m_is_fast_forward;
 public:
        eDVBVideo(eDVBDemux *demux, int dev);
        int startPid(int pid);
        void stop();
+#if HAVE_DVB_API_VERSION < 3
+       void start();
+       void stopPid();
+#endif
+       void flush();
+       void freeze();
+       int setSlowMotion(int repeat);
+       int setFastForward(int skip);
+       void unfreeze();
        virtual ~eDVBVideo();
 };
 
-class eTSMPEGDecoder: public virtual iTSMPEGDecoder
+class eDVBPCR: public iObject
+{
+DECLARE_REF(eDVBPCR);
+private:
+       ePtr<eDVBDemux> m_demux;
+       int m_fd_demux;
+public:
+       eDVBPCR(eDVBDemux *demux);
+       int startPid(int pid);
+       void stop();
+       virtual ~eDVBPCR();
+};
+
+class eTSMPEGDecoder: public Object, public iTSMPEGDecoder
 {
-DECLARE_REF;
+DECLARE_REF(eTSMPEGDecoder);
 private:
        ePtr<eDVBDemux> m_demux;
        ePtr<eDVBAudio> m_audio;
        ePtr<eDVBVideo> m_video;
-       
+       ePtr<eDVBPCR> m_pcr;
        int m_vpid, m_apid, m_atype, m_pcrpid;
        enum
        {
@@ -47,6 +79,9 @@ private:
        };
        int m_changed;
        int setState();
+       ePtr<eConnection> m_demux_event;
+       
+       void demux_event(int event);
 public:
        enum { pidNone = -1 };
        eTSMPEGDecoder(eDVBDemux *demux, int decoder);
@@ -60,7 +95,9 @@ public:
        RESULT unfreeze();
        RESULT setSinglePictureMode(int when);
        RESULT setPictureSkipMode(int what);
+       RESULT setFastForward(int frames_to_skip);
        RESULT setSlowMotion(int repeat);
        RESULT setZoom(int what);
+       RESULT flush();
 };
 #endif