X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fdvb%2Fdemux.h;h=1a7db9791296190350adbb6f1caf9c580eb1e19b;hp=c7fa5bc0e3727f7d70e25c44a9944ab3fa91e3e8;hb=10e7e45ae92d4fe06f70126ed256b87896dbc432;hpb=1aeefd997cc362c3b37c1587c5f08891b35c3a75 diff --git a/lib/dvb/demux.h b/lib/dvb/demux.h index c7fa5bc..1a7db97 100644 --- a/lib/dvb/demux.h +++ b/lib/dvb/demux.h @@ -2,33 +2,59 @@ #define __dvb_demux_h #include -#include +#include class eDVBDemux: public iDVBDemux { - int adapter, demux; - friend class eDVBSectionReader; - friend class eDVBAudio; - friend class eDVBVideo; + DECLARE_REF(eDVBDemux); public: - DECLARE_REF + enum { + evtFlush + }; eDVBDemux(int adapter, int demux); virtual ~eDVBDemux(); + + RESULT setSourceFrontend(int fenum); + int getSource() { return source; } + RESULT setSourcePVR(int pvrnum); + RESULT createSectionReader(eMainloop *context, ePtr &reader); - RESULT getMPEGDecoder(ePtr &reader); + RESULT createPESReader(eMainloop *context, ePtr &reader); + RESULT createTSRecorder(ePtr &recorder); + RESULT getMPEGDecoder(ePtr &reader, int primary); + RESULT getSTC(pts_t &pts, int num); + RESULT getCADemuxID(uint8_t &id) { id = demux; return 0; } + RESULT flush(); + RESULT connectEvent(const Slot1 &event, ePtr &conn); + + int getRefCount() { return ref; } +private: + int adapter, demux, source; + + int m_dvr_busy; + friend class eDVBSectionReader; + friend class eDVBPESReader; + friend class eDVBAudio; + friend class eDVBVideo; + friend class eDVBPCR; + friend class eDVBTText; + friend class eDVBTSRecorder; + friend class eDVBCAService; + Signal1 m_event; + + int openDemux(void); }; class eDVBSectionReader: public iDVBSectionReader, public Object { - DECLARE_REF -private: + DECLARE_REF(eDVBSectionReader); int fd; Signal1 read; ePtr demux; int active; int checkcrc; void data(int); - eSocketNotifier *notifier; + ePtr notifier; public: eDVBSectionReader(eDVBDemux *demux, eMainloop *context, RESULT &res); @@ -38,4 +64,59 @@ public: RESULT connectRead(const Slot1 &read, ePtr &conn); }; +class eDVBPESReader: public iDVBPESReader, public Object +{ + DECLARE_REF(eDVBPESReader); + int m_fd; + Signal2 m_read; + ePtr m_demux; + int m_active; + void data(int); + ePtr m_notifier; +public: + eDVBPESReader(eDVBDemux *demux, eMainloop *context, RESULT &res); + virtual ~eDVBPESReader(); + RESULT start(int pid); + RESULT stop(); + RESULT connectRead(const Slot2 &read, ePtr &conn); +}; + +class eDVBRecordFileThread; + +class eDVBTSRecorder: public iDVBTSRecorder, public Object +{ + DECLARE_REF(eDVBTSRecorder); +public: + eDVBTSRecorder(eDVBDemux *demux); + ~eDVBTSRecorder(); + + RESULT start(); + RESULT addPID(int pid); + RESULT removePID(int pid); + + RESULT setTimingPID(int pid); + + RESULT setTargetFD(int fd); + RESULT setTargetFilename(const char *filename); + RESULT setBoundary(off_t max); + + RESULT stop(); + + RESULT connectEvent(const Slot1 &event, ePtr &conn); +private: + RESULT startPID(int pid); + void stopPID(int pid); + + eDVBRecordFileThread *m_thread; + void filepushEvent(int event); + + std::map m_pids; + Signal1 m_event; + + ePtr m_demux; + + int m_running, m_target_fd, m_source_fd; + std::string m_target_filename; +}; + #endif