X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d63d2c3c6cbbd574dda4f8b00ebe6c661735edd5..36f427fcb34bb0dafa3d395dbc6bfc060494c874:/lib/service/servicedvb.h diff --git a/lib/service/servicedvb.h b/lib/service/servicedvb.h index fac9edf2..f47c3906 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 virtual iServiceHandler, public virtual iObject +class eServiceFactoryDVB: public iServiceHandler { -DECLARE_REF; +DECLARE_REF(eServiceFactoryDVB); public: eServiceFactoryDVB(); virtual ~eServiceFactoryDVB(); @@ -18,28 +19,74 @@ 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 eDVBServiceList: public iListableService +{ +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; + eDVBServiceList(const eServiceReference &parent); + ePtr m_query; }; -class eDVBServicePlay: public virtual iPlayableService, public virtual iObject, public Object +class eDVBServicePlay: public iPlayableService, public iPauseableService, public iSeekableService, public Object, public iServiceInformation { -DECLARE_REF; +DECLARE_REF(eDVBServicePlay); +public: + virtual ~eDVBServicePlay(); + + // iPlayableService + RESULT connectEvent(const Slot2 &event, ePtr &connection); + RESULT start(); + RESULT stop(); + 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 getPlayPosition(pts_t &pos); + + // iServiceInformation + 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_serviceHandler; + eDVBServicePMTHandler m_service_handler; + eDVBServiceEITHandler m_event_handler; + + eDVBServicePlay(const eServiceReference &ref, eDVBService *service); - eDVBServicePlay(const eServiceReference &ref); + void gotNewEvent(); void serviceEvent(int event); -public: - virtual ~eDVBServicePlay(); - - // iPlayableService - RESULT start(); - RESULT getIPausableService(ePtr &ptr); + Signal2 m_event; + + int m_is_pvr, m_is_paused; }; #endif