+ RESULT info(ePtr<iServiceInformation>&);
+
+ // 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);
+
+ // iAudioTrackSelection
+ int getNumberOfTracks();
+ RESULT selectTrack(unsigned int i);
+ RESULT getTrackInfo(struct iAudioTrackInfo &, unsigned int n);
+ int getCurrentTrack();
+
+ // iAudioChannelSelection
+ int getCurrentChannel();
+ RESULT selectChannel(int i);
+
+ // iSubtitleOutput
+ RESULT enableSubtitles(eWidget *parent, SWIG_PYOBJECT(ePyObject) entry);
+ RESULT disableSubtitles(eWidget *parent);
+ PyObject *getSubtitleList();
+ PyObject *getCachedSubtitle();
+
+ struct audioStream
+ {
+ GstPad* pad;
+ audiotype_t type;
+ std::string language_code; /* iso-639, if available. */
+ audioStream()
+ :pad(0), type(atUnknown)
+ {
+ }
+ };
+ struct subtitleStream
+ {
+ GstPad* pad;
+ subtype_t type;
+ std::string language_code; /* iso-639, if available. */
+ subtitleStream()
+ :pad(0)
+ {
+ }
+ };
+ struct sourceStream
+ {
+ audiotype_t audiotype;
+ containertype_t containertype;
+ bool is_video;
+ bool is_streaming;
+ sourceStream()
+ :audiotype(atUnknown), containertype(ctNone), is_video(FALSE), is_streaming(FALSE)
+ {
+ }
+ };
+private:
+ int m_currentAudioStream;
+ int m_currentSubtitleStream;
+ int selectAudioStream(int i);
+ std::vector<audioStream> m_audioStreams;
+ std::vector<subtitleStream> m_subtitleStreams;
+ eSubtitleWidget *m_subtitle_widget;
+ int m_currentTrickRatio;
+ ePtr<eTimer> m_seekTimeout;
+ void seekTimeoutCB();
+ friend class eServiceFactoryMP3;
+ std::string m_filename;
+ eServiceMP3(const char *filename);
+ Signal2<void,iPlayableService*,int> m_event;
+ enum
+ {
+ stIdle, stRunning, stStopped,
+ };
+ int m_state;
+ GstElement *m_gst_pipeline;
+ GstTagList *m_stream_tags;
+ eFixedMessagePump<int> m_pump;
+ std::string m_error_message;
+
+ audiotype_t gstCheckAudioPad(GstStructure* structure);
+ void gstBusCall(GstBus *bus, GstMessage *msg);
+ static GstBusSyncReply gstBusSyncHandler(GstBus *bus, GstMessage *message, gpointer user_data);
+ static void gstCBpadAdded(GstElement *decodebin, GstPad *pad, gpointer data); /* for mpegdemux */
+ static void gstCBfilterPadAdded(GstElement *filter, GstPad *pad, gpointer user_data); /* for id3demux */
+ static void gstCBnewPad(GstElement *decodebin, GstPad *pad, gboolean last, gpointer data); /* for decodebin */
+ static void gstCBunknownType(GstElement *decodebin, GstPad *pad, GstCaps *l, gpointer data);
+ static void gstCBsubtitleAvail(GstElement *element, GstBuffer *buffer, GstPad *pad, gpointer user_data);
+ static void gstCBsubtitlePadEvent(GstPad *pad, GstEvent *event, gpointer user_data);
+ GstPad* gstCreateSubtitleSink(eServiceMP3* _this, subtype_t type);
+ void gstPoll(const int&);
+ gint m_aspect, m_width, m_height, m_framerate, m_progressive;