show "in timer" icon also in multiepg
[enigma2.git] / lib / dvb / pmt.h
index e260ddd2b94d87394d8cb2ee43f04665bc3eb160..79d7917c251b684c02a0739b473dcee29c974957 100644 (file)
@@ -1,6 +1,7 @@
 #ifndef __lib_dvb_dvbmid_h
 #define __lib_dvb_dvbmid_h
 
+#include <map>
 #include <lib/dvb/idvb.h>
 #include <lib/dvb/dvb.h>
 #include <lib/dvb/idemux.h>
 #include <unistd.h>
 #include <fcntl.h>
 
-class eDVBServicePMTHandler;
+class eDVBCAService;
+
+typedef std::map<eServiceReferenceDVB, eDVBCAService*> CAServiceMap;
 
 class eDVBCAService: public Object
 {
-       eDVBServicePMTHandler &m_parent;
-       int m_sock, m_clilen;
+       eServiceReferenceDVB m_service;
+       uint8_t m_used_demux[32];
+       unsigned int m_prev_build_hash;
+
+       int m_sock, m_clilen; 
        struct sockaddr_un m_servaddr;
        unsigned int m_sendstate;
-       unsigned char *m_capmt;
+       unsigned char m_capmt[2048];
        eTimer m_retryTimer;
        void sendCAPMT();
        void Connect();
+
+       static CAServiceMap exist;
+       eDVBCAService();
+       ~eDVBCAService();
 public:
-       eDVBCAService( eDVBServicePMTHandler &parent )
-               :m_parent(parent), m_sendstate(0), m_capmt(NULL), m_retryTimer(eApp)
-       {
-               CONNECT(m_retryTimer.timeout, eDVBCAService::sendCAPMT);
-               Connect();
-//             eDebug("[eDVBCAHandler] new service %s", service.toString().c_str() );
-       }
-       ~eDVBCAService()
-       {
-               delete [] m_capmt;
-               ::close(m_sock);
-//             eDebug("[eDVBCAHandler] leave service %s", me.toString().c_str() );
-       }
-       void buildCAPMT();
+       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<ProgramMapSection> *ptr );
+       void buildCAPMT(eTable<ProgramMapSection> *ptr);
 };
 
 class eDVBServicePMTHandler: public Object
@@ -50,7 +49,6 @@ class eDVBServicePMTHandler: public Object
        ePtr<eDVBService> m_service;
 
        int m_last_channel_state;
-       uint16_t m_pmt_pid;
        eDVBCAService *m_ca_servicePtr;
 
        eAUTable<eTable<ProgramMapSection> > m_PMT;
@@ -63,9 +61,15 @@ class eDVBServicePMTHandler: public Object
        
        void channelStateChanged(iDVBChannel *);
        ePtr<eConnection> m_channelStateChanged_connection;
+       void channelEvent(iDVBChannel *, int event);
+       ePtr<eConnection> 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();
@@ -73,18 +77,23 @@ public:
        enum
        {
                eventNoResources,  // a requested resource couldn't be allocated
+               eventTuneFailed,   // tune failed
                eventNoPAT,        // no pat could be received (timeout)
                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<void,int> serviceEvent;
-       
+
        struct videoStream
        {
                int pid;
+               int component_tag;
        };
        
        struct audioStream
@@ -92,7 +101,9 @@ public:
                int pid;
                enum { atMPEG, atAC3, atDTS };
                int type; // mpeg2, ac3, dts, ...
-               // language code, ...
+               
+               int component_tag;
+               std::string language_code; /* iso-639, if available. */
        };
        
        struct program
@@ -101,13 +112,24 @@ public:
                std::vector<audioStream> audioStreams;
                // ca info
                int pcrPid;
+               int pmtPid;
+               int textPid;
+               bool isCrypted;
        };
        
        int getProgramInfo(struct program &program);
-       int getDemux(ePtr<iDVBDemux> &demux);
+       int getDataDemux(ePtr<iDVBDemux> &demux);
+       int getDecodeDemux(ePtr<iDVBDemux> &demux);
+       
        int getPVRChannel(ePtr<iDVBPVRChannel> &pvr_channel);
+       int getService(eServiceReferenceDVB &service) { service = m_reference; return 0; }
+       int getPMT(ePtr<eTable<ProgramMapSection> > &ptr) { return m_PMT.getCurrent(ptr); }
+       int getChannel(eUsePtr<iDVBChannel> &channel);
+
+       int tune(eServiceReferenceDVB &ref, int use_decode_demux, eCueSheet *sg=0);
+       void free();
        
-       int tune(eServiceReferenceDVB &ref);    
+       int m_pmt_pid;
 };
 
 #endif