start on device list, don't crash when list is empty
[enigma2.git] / lib / dvb / epgcache.h
index c692bc22aa4d5a3db1f2637dd9dfb97734a8591a..fe768aee714c701bb00096c2fcd971d660e62220 100644 (file)
@@ -178,14 +178,16 @@ class eEPGCache: public eMainloop, private eThread, public Object
                std::map<__u8, mhw_theme_name_t> m_themes;
                std::map<__u32, mhw_title_t> m_titles;
                std::map<__u32, __u32> m_program_ids;
-               ePtr<eConnection> m_MHWConn;
-               ePtr<iDVBSectionReader> m_MHWReader;
-               eDVBSectionFilterMask m_MHWFilterMask;
+               ePtr<eConnection> m_MHWConn, m_MHWConn2;
+               ePtr<iDVBSectionReader> m_MHWReader, m_MHWReader2;
+               eDVBSectionFilterMask m_MHWFilterMask, m_MHWFilterMask2;
                eTimer m_MHWTimeoutTimer;
                bool m_MHWTimeoutet;
                void MHWTimeout() { m_MHWTimeoutet=true; }
                void readMHWData(const __u8 *data);
+               void readMHWData2(const __u8 *data);
                void startMHWReader(__u16 pid, __u8 tid);
+               void startMHWReader2(__u16 pid, __u8 tid, int ext=-1);
                void startTimeout(int msek);
                bool checkTimeout() { return m_MHWTimeoutet; }
                void cleanup();
@@ -293,17 +295,18 @@ public:
 #ifndef SWIG
        eEPGCache();
        ~eEPGCache();
-#endif
 
-       // called from main thread
-       inline void Lock();
-       inline void Unlock();
 #ifdef ENABLE_PRIVATE_EPG
        void PMTready(eDVBServicePMTHandler *pmthandler);
 #else
        void PMTready(eDVBServicePMTHandler *pmthandler) {}
 #endif
 
+#endif
+       // called from main thread
+       inline void Lock();
+       inline void Unlock();
+
        // at moment just for one service..
        RESULT startTimeQuery(const eServiceReference &service, time_t begin=-1, int minutes=-1);