X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/8948b15a69b1f155389107ac0ff73a65cc0b7337..319b1d154578f02388b6a7910c5048ed3bab1343:/lib/dvb/pmt.h diff --git a/lib/dvb/pmt.h b/lib/dvb/pmt.h index 995cc9be..79d7917c 100644 --- a/lib/dvb/pmt.h +++ b/lib/dvb/pmt.h @@ -15,14 +15,14 @@ #include #include -class eDVBServicePMTHandler; +class eDVBCAService; typedef std::map CAServiceMap; class eDVBCAService: public Object { eServiceReferenceDVB m_service; - uint8_t m_used_demux[10]; + uint8_t m_used_demux[32]; unsigned int m_prev_build_hash; int m_sock, m_clilen; @@ -37,8 +37,8 @@ class eDVBCAService: public Object eDVBCAService(); ~eDVBCAService(); public: - static RESULT register_service( const eServiceReferenceDVB &ref, int demux_num, eDVBCAService *&caservice ); - static RESULT unregister_service( const eServiceReferenceDVB &ref, int demux_num, eTable *ptr ); + static RESULT register_service( const eServiceReferenceDVB &ref, int demux_nums[2], eDVBCAService *&caservice ); + static RESULT unregister_service( const eServiceReferenceDVB &ref, int demux_nums[2], eTable *ptr ); void buildCAPMT(eTable *ptr); }; @@ -61,11 +61,15 @@ class eDVBServicePMTHandler: public Object void channelStateChanged(iDVBChannel *); ePtr m_channelStateChanged_connection; + void channelEvent(iDVBChannel *, int event); + ePtr m_channelEvent_connection; void PMTready(int error); void PATready(int error); int m_use_decode_demux; + uint8_t m_decode_demux_num; + public: eDVBServicePMTHandler(); ~eDVBServicePMTHandler(); @@ -78,7 +82,10 @@ public: eventNoPATEntry, // no pat entry for the corresponding SID could be found eventNoPMT, // no pmt could be received (timeout) eventNewProgramInfo, // we just received a PMT - eventTuned // a channel was sucessfully (re-)tuned in, you may start additional filters now + eventTuned, // a channel was sucessfully (re-)tuned in, you may start additional filters now + + eventSOF, // seek pre start + eventEOF, // a file playback did end }; Signal1 serviceEvent; @@ -106,6 +113,7 @@ public: // ca info int pcrPid; int pmtPid; + int textPid; bool isCrypted; }; @@ -118,8 +126,10 @@ public: int getPMT(ePtr > &ptr) { return m_PMT.getCurrent(ptr); } int getChannel(eUsePtr &channel); - int tune(eServiceReferenceDVB &ref, int use_decode_demux); + int tune(eServiceReferenceDVB &ref, int use_decode_demux, eCueSheet *sg=0); void free(); + + int m_pmt_pid; }; #endif