X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0af11516cabc973907890f548925a66313c8d18c..d86dfb91c834be43d9bcddd69ddbc7e463825fbd:/lib/service/servicedvb.h diff --git a/lib/service/servicedvb.h b/lib/service/servicedvb.h index 1dd66e40..31eee1fe 100644 --- a/lib/service/servicedvb.h +++ b/lib/service/servicedvb.h @@ -20,45 +20,43 @@ public: RESULT record(const eServiceReference &, ePtr &ptr); RESULT list(const eServiceReference &, ePtr &ptr); RESULT info(const eServiceReference &, ePtr &ptr); + RESULT offlineOperations(const eServiceReference &, ePtr &ptr); private: RESULT lookupService(ePtr &ptr, const eServiceReference &ref); }; -class eDVBServiceList: public iListableService +class eBouquet; + +class eDVBServiceList: public iListableService, public iMutableServiceList { DECLARE_REF(eDVBServiceList); -private: - eServiceReference m_parent; - friend class eServiceFactoryDVB; - eDVBServiceList(const eServiceReference &parent); public: virtual ~eDVBServiceList(); RESULT getContent(std::list &list); RESULT getNext(eServiceReference &ptr); + int compareLessEqual(const eServiceReference &a, const eServiceReference &b); + + RESULT startEdit(ePtr &); + RESULT flushChanges(); + RESULT addService(eServiceReference &ref); + RESULT removeService(eServiceReference &ref); + RESULT moveService(eServiceReference &ref, int pos); +private: + RESULT startQuery(); + eServiceReference m_parent; + friend class eServiceFactoryDVB; + eDVBServiceList(const eServiceReference &parent); + ePtr m_query; + + /* for editing purposes. WARNING: lifetime issue! */ + eBouquet *m_bouquet; }; -class eDVBServicePlay: public iPlayableService, iSeekableService, public Object, public iServiceInformation +class eDVBServicePlay: public iPlayableService, public iPauseableService, + public iSeekableService, public Object, public iServiceInformation, + public iAudioTrackSelection { DECLARE_REF(eDVBServicePlay); -private: - friend class eServiceFactoryDVB; - eServiceReference m_reference; - - ePtr m_dvb_service; - - ePtr m_decoder; - - eDVBServicePMTHandler m_service_handler; - eDVBServiceEITHandler m_event_handler; - - eDVBServicePlay(const eServiceReference &ref, eDVBService *service); - - void gotNewEvent(); - - void serviceEvent(int event); - Signal2 m_event; - - int m_is_pvr; public: virtual ~eDVBServicePlay(); @@ -69,15 +67,46 @@ public: RESULT seek(ePtr &ptr); RESULT pause(ePtr &ptr); RESULT info(ePtr &ptr); + RESULT audioTracks(ePtr &ptr); + + // iPauseableService + RESULT pause(); + RESULT unpause(); // iSeekableService RESULT getLength(pts_t &len); RESULT seekTo(pts_t to); + RESULT seekRelative(int direction, pts_t to); RESULT getPlayPosition(pts_t &pos); // iServiceInformation RESULT getName(std::string &name); RESULT getEvent(ePtr &evt, int nownext); + + // iAudioTrackSelection + int getNumberOfTracks(); + RESULT selectTrack(unsigned int i); + RESULT getTrackInfo(struct iAudioTrackInfo &, unsigned int n); + +private: + friend class eServiceFactoryDVB; + eServiceReference m_reference; + + ePtr m_dvb_service; + + ePtr m_decoder; + + eDVBServicePMTHandler m_service_handler; + eDVBServiceEITHandler m_event_handler; + + eDVBServicePlay(const eServiceReference &ref, eDVBService *service); + + void gotNewEvent(); + + void serviceEvent(int event); + Signal2 m_event; + + int m_is_pvr, m_is_paused; }; #endif