1 #include <lib/base/eerror.h>
2 #include <lib/base/object.h>
3 #include <lib/base/ebase.h>
5 #include <lib/service/servicemp3.h>
6 #include <lib/service/service.h>
7 #include <lib/base/init_num.h>
8 #include <lib/base/init.h>
12 eServiceFactoryMP3::eServiceFactoryMP3()
14 ePtr<eServiceCenter> sc;
16 eServiceCenter::getInstance(sc);
18 sc->addServiceFactory(eServiceFactoryMP3::id, this);
20 m_service_info = new eStaticServiceMP3Info();
23 eServiceFactoryMP3::~eServiceFactoryMP3()
25 ePtr<eServiceCenter> sc;
27 eServiceCenter::getInstance(sc);
29 sc->removeServiceFactory(eServiceFactoryMP3::id);
32 DEFINE_REF(eServiceFactoryMP3)
35 RESULT eServiceFactoryMP3::play(const eServiceReference &ref, ePtr<iPlayableService> &ptr)
38 ptr = new eServiceMP3(ref.path.c_str());
42 RESULT eServiceFactoryMP3::record(const eServiceReference &ref, ePtr<iRecordableService> &ptr)
48 RESULT eServiceFactoryMP3::list(const eServiceReference &, ePtr<iListableService> &ptr)
54 RESULT eServiceFactoryMP3::info(const eServiceReference &ref, ePtr<iStaticServiceInformation> &ptr)
60 // eStaticServiceMP3Info
63 // eStaticServiceMP3Info is seperated from eServiceMP3 to give information
64 // about unopened files.
66 // probably eServiceMP3 should use this class as well, and eStaticServiceMP3Info
67 // should have a database backend where ID3-files etc. are cached.
68 // this would allow listing the mp3 database based on certain filters.
70 DEFINE_REF(eStaticServiceMP3Info)
72 eStaticServiceMP3Info::eStaticServiceMP3Info()
76 RESULT eStaticServiceMP3Info::getName(const eServiceReference &ref, std::string &name)
78 name = "MP3 file: " + ref.path;
84 void eServiceMP3::test_end()
86 eDebug("end of mp3!");
90 eServiceMP3::eServiceMP3(const char *filename): filename(filename), test(eApp)
93 eDebug("SERVICEMP3 construct!");
96 eServiceMP3::~eServiceMP3()
98 eDebug("SERVICEMP3 destruct!");
99 if (m_state == stRunning)
103 DEFINE_REF(eServiceMP3);
105 RESULT eServiceMP3::connectEvent(const Slot2<void,iPlayableService*,int> &event, ePtr<eConnection> &connection)
107 connection = new eConnection((iPlayableService*)this, m_event.connect(event));
111 RESULT eServiceMP3::start()
113 assert(m_state == stIdle);
117 printf("mp3 starts\n");
118 printf("MP3: %s start\n", filename.c_str());
120 CONNECT(test.timeout, eServiceMP3::test_end);
121 m_event(this, evStart);
125 RESULT eServiceMP3::stop()
127 assert(m_state != stIdle);
128 if (m_state == stStopped)
131 printf("MP3: %s stop\n", filename.c_str());
133 m_event(this, evEnd);
137 RESULT eServiceMP3::pause(ePtr<iPauseableService> &ptr) { ptr=this; return 0; }
140 RESULT eServiceMP3::pause() { printf("mp3 pauses!\n"); return 0; }
141 RESULT eServiceMP3::unpause() { printf("mp3 unpauses!\n"); return 0; }
143 RESULT eServiceMP3::info(ePtr<iServiceInformation>&i) { i = this; return 0; }
145 RESULT eServiceMP3::getName(const eServiceReference &ref, std::string &name)
147 name = "MP3 File: " + filename;
151 eAutoInitPtr<eServiceFactoryMP3> init_eServiceFactoryMP3(eAutoInitNumbers::service+1, "eServiceFactoryMP3");