- add "getCurrent" to service listbox
[enigma2.git] / lib / service / servicemp3.h
index 940e141d86360905a6fc6e7bee69c2c9bc4ed914..40287ae53d3fbb9f1a2d99bdbcf068b1e0b33e00 100644 (file)
@@ -3,6 +3,8 @@
 
 #include <lib/service/iservice.h>
 
+class eStaticServiceMP3Info;
+
 class eServiceFactoryMP3: public iServiceHandler
 {
 DECLARE_REF;
@@ -15,6 +17,18 @@ public:
        RESULT play(const eServiceReference &, ePtr<iPlayableService> &ptr);
        RESULT record(const eServiceReference &, ePtr<iRecordableService> &ptr);
        RESULT list(const eServiceReference &, ePtr<iListableService> &ptr);
+       RESULT info(const eServiceReference &, ePtr<iStaticServiceInformation> &ptr);
+private:
+       ePtr<eStaticServiceMP3Info> m_service_info;
+};
+
+class eStaticServiceMP3Info: public iServiceInformation
+{
+       DECLARE_REF;
+       friend class eServiceFactoryMP3;
+       eStaticServiceMP3Info();
+public:
+       RESULT getName(const eServiceReference &ref, std::string &name);
 };
 
 class eServiceMP3: public iPlayableService, public iPauseableService, public iServiceInformation, public Object
@@ -39,16 +53,16 @@ public:
        RESULT connectEvent(const Slot2<void,iPlayableService*,int> &event, ePtr<eConnection> &connection);
        RESULT start();
        RESULT stop();
-       RESULT getIPausableService(ePtr<iPauseableService> &ptr);
+       RESULT pause(ePtr<iPauseableService> &ptr);
 
                // iPausableService
        RESULT pause();
        RESULT unpause();
        
-       RESULT getIServiceInformation(ePtr<iServiceInformation>&);
+       RESULT info(ePtr<iServiceInformation>&);
        
                // iServiceInformation
-       RESULT getName(eString &name);
+       RESULT getName(const eServiceReference &ref, std::string &name);
 };
 
 #endif