X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/abea0c85ea0e0f9e7197664b70753fbe5f110b8d..f15ee3f6cd34e4552f50dcc92a994198ed3b2dfe:/lib/dvb/db.h diff --git a/lib/dvb/db.h b/lib/dvb/db.h index 3483e244..8bb0e5ae 100644 --- a/lib/dvb/db.h +++ b/lib/dvb/db.h @@ -12,6 +12,8 @@ class eDVBDB: public iDVBChannelList DECLARE_REF(eDVBDB); friend class eDVBDBQuery; friend class eDVBDBBouquetQuery; + friend class eDVBDBSatellitesQuery; + friend class eDVBDBProvidersQuery; private: struct channel { @@ -28,9 +30,7 @@ public: void save(); void loadBouquet(const char *path); - void saveBouquet(const char *path); void loadBouquets(); - void saveBouquets(); eDVBDB(); virtual ~eDVBDB(); @@ -54,13 +54,12 @@ class eDVBDBQueryBase: public iDVBChannelListQuery { DECLARE_REF(eDVBDBQueryBase); protected: - std::map >::iterator m_cursor; ePtr m_db; ePtr m_query; eServiceReference m_source; public: eDVBDBQueryBase(eDVBDB *db, const eServiceReference &source, eDVBChannelQuery *query); - int compareLessEqual(const eServiceReferenceDVB &a, const eServiceReferenceDVB &b); + virtual int compareLessEqual(const eServiceReferenceDVB &a, const eServiceReferenceDVB &b); }; class eDVBDBQuery: public eDVBDBQueryBase @@ -79,4 +78,27 @@ public: RESULT getNextResult(eServiceReferenceDVB &ref); }; +class eDVBDBListQuery: public eDVBDBQueryBase +{ +protected: + std::list m_list; + std::list::iterator m_cursor; +public: + eDVBDBListQuery(eDVBDB *db, const eServiceReference &source, eDVBChannelQuery *query); + RESULT getNextResult(eServiceReferenceDVB &ref); + int compareLessEqual(const eServiceReferenceDVB &a, const eServiceReferenceDVB &b); +}; + +class eDVBDBSatellitesQuery: public eDVBDBListQuery +{ +public: + eDVBDBSatellitesQuery(eDVBDB *db, const eServiceReference &source, eDVBChannelQuery *query); +}; + +class eDVBDBProvidersQuery: public eDVBDBListQuery +{ +public: + eDVBDBProvidersQuery(eDVBDB *db, const eServiceReference &source, eDVBChannelQuery *query); +}; + #endif