X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/1aeefd997cc362c3b37c1587c5f08891b35c3a75..4cd594ce7621755ce7a81a3f2bd6a31e5323e2a3:/lib/service/servicedvb.h diff --git a/lib/service/servicedvb.h b/lib/service/servicedvb.h index 6e901483..9ebd2773 100644 --- a/lib/service/servicedvb.h +++ b/lib/service/servicedvb.h @@ -1,14 +1,15 @@ -#ifndef __servicemp3_h -#define __servicemp3_h +#ifndef __servicedvb_h +#define __servicedvb_h #include #include #include +#include class eServiceFactoryDVB: public iServiceHandler { -DECLARE_REF; +DECLARE_REF(eServiceFactoryDVB); public: eServiceFactoryDVB(); virtual ~eServiceFactoryDVB(); @@ -18,22 +19,31 @@ public: RESULT play(const eServiceReference &, ePtr &ptr); 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 eDVBServicePlay: public iPlayableService, public Object, public iServiceInformation +class eDVBServiceList: public iListableService { -DECLARE_REF; +DECLARE_REF(eDVBServiceList); +public: + virtual ~eDVBServiceList(); + RESULT getContent(std::list &list); + RESULT getNext(eServiceReference &ptr); + int compareLessEqual(const eServiceReference &a, const eServiceReference &b); private: + RESULT startQuery(); + eServiceReference m_parent; friend class eServiceFactoryDVB; - eServiceReference m_reference; - - ePtr m_decoder; - - eDVBServicePMTHandler m_serviceHandler; - - eDVBServicePlay(const eServiceReference &ref); - - void serviceEvent(int event); + eDVBServiceList(const eServiceReference &parent); + ePtr m_query; +}; + +class eDVBServicePlay: public iPlayableService, public iPauseableService, public iSeekableService, public Object, public iServiceInformation +{ +DECLARE_REF(eDVBServicePlay); public: virtual ~eDVBServicePlay(); @@ -41,11 +51,43 @@ public: RESULT connectEvent(const Slot2 &event, ePtr &connection); RESULT start(); RESULT stop(); - RESULT getIPausableService(ePtr &ptr); - RESULT getIServiceInformation(ePtr &ptr); + RESULT seek(ePtr &ptr); + RESULT pause(ePtr &ptr); + RESULT info(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(eString &name); + RESULT getName(std::string &name); + RESULT getEvent(ePtr &evt, int nownext); + +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