X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/ddc3964ed95d01e72229dc9af968a327cd84e56c..59efe28a00e5713ad5279ed976430da31292a129:/lib/service/servicemp3.h diff --git a/lib/service/servicemp3.h b/lib/service/servicemp3.h index cfca4242..558fd818 100644 --- a/lib/service/servicemp3.h +++ b/lib/service/servicemp3.h @@ -3,9 +3,11 @@ #include +class eStaticServiceMP3Info; + class eServiceFactoryMP3: public iServiceHandler { -DECLARE_REF; +DECLARE_REF(eServiceFactoryMP3); public: eServiceFactoryMP3(); virtual ~eServiceFactoryMP3(); @@ -15,11 +17,25 @@ 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: + ePtr m_service_info; +}; + +class eStaticServiceMP3Info: public iStaticServiceInformation +{ + DECLARE_REF(eStaticServiceMP3Info); + friend class eServiceFactoryMP3; + eStaticServiceMP3Info(); +public: + RESULT getName(const eServiceReference &ref, std::string &name); + int getLength(const eServiceReference &ref); }; class eServiceMP3: public iPlayableService, public iPauseableService, public iServiceInformation, public Object { -DECLARE_REF; +DECLARE_REF(eServiceMP3); private: friend class eServiceFactoryMP3; std::string filename; @@ -39,13 +55,14 @@ public: RESULT connectEvent(const Slot2 &event, ePtr &connection); RESULT start(); RESULT stop(); - RESULT getIPausableService(ePtr &ptr); + RESULT pause(ePtr &ptr); + RESULT seek(ePtr &ptr); // iPausableService RESULT pause(); RESULT unpause(); - RESULT getIServiceInformation(ePtr&); + RESULT info(ePtr&); // iServiceInformation RESULT getName(std::string &name);