X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/d63d2c3c6cbbd574dda4f8b00ebe6c661735edd5..191cade7c45bee53df2776ff5bb3f26b2cdafc12:/lib/service/servicemp3.h diff --git a/lib/service/servicemp3.h b/lib/service/servicemp3.h index 0f2c074f..cb400cc6 100644 --- a/lib/service/servicemp3.h +++ b/lib/service/servicemp3.h @@ -1,11 +1,16 @@ #ifndef __servicemp3_h #define __servicemp3_h +#ifdef HAVE_GSTREAMER +#include #include +#include -class eServiceFactoryMP3: public virtual iServiceHandler, public virtual iObject +class eStaticServiceMP3Info; + +class eServiceFactoryMP3: public iServiceHandler { -DECLARE_REF; +DECLARE_REF(eServiceFactoryMP3); public: eServiceFactoryMP3(); virtual ~eServiceFactoryMP3(); @@ -15,28 +20,87 @@ 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 eServiceMP3: public virtual iPlayableService, public virtual iPauseableService, public virtual iObject +class eStaticServiceMP3Info: public iStaticServiceInformation { + DECLARE_REF(eStaticServiceMP3Info); friend class eServiceFactoryMP3; - std::string filename; - eServiceMP3(const char *filename); - int ref; + eStaticServiceMP3Info(); public: - virtual ~eServiceMP3(); + RESULT getName(const eServiceReference &ref, std::string &name); + int getLength(const eServiceReference &ref); +}; + +typedef struct _GstElement GstElement; - // iObject - void AddRef(); - void Release(); +class eServiceMP3: public iPlayableService, public iPauseableService, + public iServiceInformation, public iSeekableService, public Object +{ +DECLARE_REF(eServiceMP3); +public: + virtual ~eServiceMP3(); // iPlayableService + RESULT connectEvent(const Slot2 &event, ePtr &connection); RESULT start(); - RESULT getIPausableService(ePtr &ptr); + RESULT stop(); + RESULT setTarget(int target); + + RESULT pause(ePtr &ptr); + RESULT setSlowMotion(int ratio); + RESULT setFastForward(int ratio); + + RESULT seek(ePtr &ptr); + // not implemented (yet) + RESULT audioTracks(ePtr &ptr) { ptr = 0; return -1; } + RESULT frontendStatusInfo(ePtr &ptr) { ptr = 0; return -1; } + RESULT subServices(ePtr &ptr) { ptr = 0; return -1; } + RESULT timeshift(ePtr &ptr) { ptr = 0; return -1; } + RESULT cueSheet(ePtr& ptr) { ptr = 0; return -1; } + // iPausableService RESULT pause(); RESULT unpause(); + + RESULT info(ePtr&); + + // iSeekableService + RESULT getLength(pts_t &SWIG_OUTPUT); + RESULT seekTo(pts_t to); + RESULT seekRelative(int direction, pts_t to); + RESULT getPlayPosition(pts_t &SWIG_OUTPUT); + RESULT setTrickmode(int trick); + RESULT isCurrentlySeekable(); + + // iServiceInformation + RESULT getName(std::string &name); + int getInfo(int w); + std::string getInfoString(int w); +private: + friend class eServiceFactoryMP3; + std::string m_filename; + eServiceMP3(const char *filename); + Signal2 m_event; + enum + { + stIdle, stRunning, stStopped, + }; + int m_state; + GstElement *m_gst_pipeline, *m_gst_audio; + GstTagList *m_stream_tags; + eFixedMessagePump m_pump; + + void gstBusCall(GstBus *bus, GstMessage *msg); + static GstBusSyncReply gstBusSyncHandler(GstBus *bus, GstMessage *message, gpointer user_data); + static void gstCBnewPad(GstElement *decodebin, GstPad *pad, gboolean last, gpointer data); + void gstPoll(const int&); }; +#endif #endif